diff --git a/.sass-lint.yml b/.sass-lint.yml
index 9069d10ac..2387b7552 100644
--- a/.sass-lint.yml
+++ b/.sass-lint.yml
@@ -13,14 +13,8 @@
 # File Options
 files:
   ignore:
-   - 'sass/vendor/**/*.scss'
-   - 'sass/tests/**/*.scss'
-   - 'bourbon/app/**/*.scss'
-   - 'bourbon-neat/app/**/*.scss'
+   - './assets/foundation/_settings.scss'
    - './assets/sass/style.scss'
-   - './assets/sass/base/_scaffolding.scss'
-   - './assets/sass/plugins/_gravity-forms.scss'
-   - './assets/sass/utilities/mixins/_omega-reset.scss'
 
 # Rule Configuration
 rules:
@@ -31,7 +25,7 @@ rules:
   mixins-before-declarations:
   - 1
   -
-    exclude: ['grid-media'] # allow @include grid-media();
+    exclude: ['breakpoint'] # allow @include breakpoint();
 
   # Line Spacing
   empty-line-between-blocks:
diff --git a/Gulpfile.js b/Gulpfile.js
index aed97e4ed..86d49fa01 100644
--- a/Gulpfile.js
+++ b/Gulpfile.js
@@ -45,34 +45,35 @@ const autoprefixer = require( 'autoprefixer' ),
 		paths.foundationJS + 'foundation.util.mediaQuery.js',
 
 		// Optional Foundation components.
-		// To disable, just comment them out.
-		paths.foundationJS + 'foundation.abide.js',
-		paths.foundationJS + 'foundation.accordion.js',
+		// To enable, just uncomment and re-run `gulp scripts`.
+
+		// paths.foundationJS + 'foundation.abide.js',
+		// paths.foundationJS + 'foundation.accordion.js',
 		paths.foundationJS + 'foundation.accordionMenu.js',
-		paths.foundationJS + 'foundation.drilldown.js',
-		paths.foundationJS + 'foundation.dropdown.js',
+		// paths.foundationJS + 'foundation.drilldown.js',
+		// paths.foundationJS + 'foundation.dropdown.js',
 		paths.foundationJS + 'foundation.dropdownMenu.js',
-		paths.foundationJS + 'foundation.equalizer.js',
-		paths.foundationJS + 'foundation.interchange.js',
-		paths.foundationJS + 'foundation.magellan.js',
+		// paths.foundationJS + 'foundation.equalizer.js',
+		// paths.foundationJS + 'foundation.interchange.js',
+		// paths.foundationJS + 'foundation.magellan.js',
 		paths.foundationJS + 'foundation.offcanvas.js',
-		paths.foundationJS + 'foundation.orbit.js',
+		// paths.foundationJS + 'foundation.orbit.js',
 		paths.foundationJS + 'foundation.responsiveMenu.js',
 		paths.foundationJS + 'foundation.responsiveToggle.js',
-		paths.foundationJS + 'foundation.reveal.js',
-		paths.foundationJS + 'foundation.slider.js',
-		paths.foundationJS + 'foundation.sticky.js',
-		paths.foundationJS + 'foundation.tabs.js',
-		paths.foundationJS + 'foundation.toggler.js',
-		paths.foundationJS + 'foundation.tooltip.js',
+		// paths.foundationJS + 'foundation.reveal.js',
+		// paths.foundationJS + 'foundation.slider.js',
+		// paths.foundationJS + 'foundation.sticky.js',
+		// paths.foundationJS + 'foundation.tabs.js',
+		// paths.foundationJS + 'foundation.toggler.js',
+		// paths.foundationJS + 'foundation.tooltip.js',
 		paths.foundationJS + 'foundation.util.box.js',
 		paths.foundationJS + 'foundation.util.keyboard.js',
 		paths.foundationJS + 'foundation.util.motion.js',
 		paths.foundationJS + 'foundation.util.nest.js',
-		paths.foundationJS + 'foundation.util.timerAndImageLoader.js',
-		paths.foundationJS + 'foundation.util.touch.js',
+		// paths.foundationJS + 'foundation.util.timerAndImageLoader.js',
+		// paths.foundationJS + 'foundation.util.touch.js',
 		paths.foundationJS + 'foundation.util.triggers.js',
-		paths.foundationJS + 'foundation.zf.responsiveAccordionTabs.js',
+		// paths.foundationJS + 'foundation.zf.responsiveAccordionTabs.js',
 
 		// Required theme scripts.
 		paths.concat_scripts
diff --git a/acf-json/group_58ebcc07bfbd7.json b/acf-json/group_58ebcc07bfbd7.json
new file mode 100644
index 000000000..7abe48bf3
--- /dev/null
+++ b/acf-json/group_58ebcc07bfbd7.json
@@ -0,0 +1,133 @@
+{
+    "key": "group_58ebcc07bfbd7",
+    "title": "Fields: Background Options - To Clone",
+    "fields": [
+        {
+            "key": "field_58ebccf18512c",
+            "label": "Background Type",
+            "name": "background_type",
+            "type": "select",
+            "instructions": "Choose a type of background.",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "choices": {
+                "null": "None",
+                "color": "Color",
+                "image": "Image",
+                "video": "Video"
+            },
+            "default_value": [],
+            "allow_null": 0,
+            "multiple": 0,
+            "ui": 1,
+            "ajax": 0,
+            "return_format": "array",
+            "placeholder": ""
+        },
+        {
+            "key": "field_58ebcd698512e",
+            "label": "Background Color",
+            "name": "background_color",
+            "type": "color_picker",
+            "instructions": "Select a background color.",
+            "required": 0,
+            "conditional_logic": [
+                [
+                    {
+                        "field": "field_58ebccf18512c",
+                        "operator": "==",
+                        "value": "color"
+                    }
+                ]
+            ],
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "default_value": ""
+        },
+        {
+            "key": "field_58ebcda08512f",
+            "label": "Background Image",
+            "name": "background_image",
+            "type": "image",
+            "instructions": "Add\/Upload an image file. (1920x1080px .jpg, .png)",
+            "required": 0,
+            "conditional_logic": [
+                [
+                    {
+                        "field": "field_58ebccf18512c",
+                        "operator": "==",
+                        "value": "image"
+                    }
+                ]
+            ],
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "return_format": "array",
+            "preview_size": "medium",
+            "library": "all",
+            "min_width": "",
+            "min_height": "",
+            "min_size": "",
+            "max_width": "",
+            "max_height": "",
+            "max_size": "",
+            "mime_types": "jpg, png"
+        },
+        {
+            "key": "field_59416a7edea96",
+            "label": "Background Video",
+            "name": "background_video",
+            "type": "file",
+            "instructions": "Add\/Upload a 1920x1080 .mp4 video file. Note: background videos are only supported on hero's.",
+            "required": 0,
+            "conditional_logic": [
+                [
+                    {
+                        "field": "field_58ebccf18512c",
+                        "operator": "==",
+                        "value": "video"
+                    }
+                ]
+            ],
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "return_format": "array",
+            "library": "all",
+            "min_size": "",
+            "max_size": "",
+            "mime_types": "mp4"
+        }
+    ],
+    "location": [
+        [
+            {
+                "param": "post_type",
+                "operator": "==",
+                "value": "post"
+            }
+        ]
+    ],
+    "menu_order": 0,
+    "position": "normal",
+    "style": "default",
+    "label_placement": "top",
+    "instruction_placement": "label",
+    "hide_on_screen": "",
+    "active": 0,
+    "description": "",
+    "modified": 1497463817
+}
\ No newline at end of file
diff --git a/acf-json/group_58ebdb1fb1278.json b/acf-json/group_58ebdb1fb1278.json
new file mode 100644
index 000000000..5edf55038
--- /dev/null
+++ b/acf-json/group_58ebdb1fb1278.json
@@ -0,0 +1,451 @@
+{
+    "key": "group_58ebdb1fb1278",
+    "title": "Global Content Blocks",
+    "fields": [
+        {
+            "key": "field_58ebdb2e95d03",
+            "label": "Content Blocks",
+            "name": "content_blocks",
+            "type": "flexible_content",
+            "instructions": "",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "",
+                "class": "",
+                "id": ""
+            },
+            "layouts": {
+                "58ebe1abceb3a": {
+                    "key": "58ebe1abceb3a",
+                    "name": "generic_content",
+                    "label": "Generic Content",
+                    "display": "block",
+                    "sub_fields": [
+                        {
+                            "key": "field_59416885e6fd7",
+                            "label": "Block Content",
+                            "name": "",
+                            "type": "tab",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "placement": "top",
+                            "endpoint": 0
+                        },
+                        {
+                            "key": "field_58ebe1c0ceb3b",
+                            "label": "Generic Content",
+                            "name": "content",
+                            "type": "wysiwyg",
+                            "instructions": "Add content and media below. Also supports shortcodes and oEmbeds.",
+                            "required": 1,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "default_value": "",
+                            "tabs": "all",
+                            "toolbar": "full",
+                            "media_upload": 1,
+                            "delay": 0
+                        },
+                        {
+                            "key": "field_594169c698fad",
+                            "label": "Block Options",
+                            "name": "block_options",
+                            "type": "clone",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "clone": [
+                                "group_594168e03b544"
+                            ],
+                            "display": "seamless",
+                            "layout": "block",
+                            "prefix_label": 0,
+                            "prefix_name": 0
+                        }
+                    ],
+                    "min": "",
+                    "max": ""
+                },
+                "58ebe820e12b2": {
+                    "key": "58ebe820e12b2",
+                    "name": "hero",
+                    "label": "Hero",
+                    "display": "block",
+                    "sub_fields": [
+                        {
+                            "key": "field_59416d6104f5e",
+                            "label": "Block Content",
+                            "name": "",
+                            "type": "tab",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "placement": "top",
+                            "endpoint": 0
+                        },
+                        {
+                            "key": "field_59416dec934f9",
+                            "label": "Headline",
+                            "name": "headline",
+                            "type": "text",
+                            "instructions": "Write a catchy headline!",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "50",
+                                "class": "",
+                                "id": ""
+                            },
+                            "default_value": "",
+                            "placeholder": "",
+                            "prepend": "",
+                            "append": "",
+                            "maxlength": ""
+                        },
+                        {
+                            "key": "field_59416dfa934fa",
+                            "label": "Text",
+                            "name": "text",
+                            "type": "text",
+                            "instructions": "Write a short blurb to compliment the headline.",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "50",
+                                "class": "",
+                                "id": ""
+                            },
+                            "default_value": "",
+                            "placeholder": "",
+                            "prepend": "",
+                            "append": "",
+                            "maxlength": ""
+                        },
+                        {
+                            "key": "field_59416e35934fb",
+                            "label": "Button",
+                            "name": "button",
+                            "type": "clone",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "clone": [
+                                "group_59416d894b7c7"
+                            ],
+                            "display": "seamless",
+                            "layout": "block",
+                            "prefix_label": 0,
+                            "prefix_name": 0
+                        },
+                        {
+                            "key": "field_59416d4b04f5d",
+                            "label": "Block Options",
+                            "name": "block_options",
+                            "type": "clone",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "clone": [
+                                "group_594168e03b544"
+                            ],
+                            "display": "seamless",
+                            "layout": "block",
+                            "prefix_label": 0,
+                            "prefix_name": 0
+                        }
+                    ],
+                    "min": "",
+                    "max": ""
+                },
+                "59089f8b3f35e": {
+                    "key": "59089f8b3f35e",
+                    "name": "fifty_fifty_block",
+                    "label": "Fifty\/Fifty Block",
+                    "display": "block",
+                    "sub_fields": [
+                        {
+                            "key": "field_59416bdbf0b0a",
+                            "label": "Select Layout",
+                            "name": "",
+                            "type": "tab",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "placement": "top",
+                            "endpoint": 0
+                        },
+                        {
+                            "key": "field_59089fd63f35f",
+                            "label": "Block layout:",
+                            "name": "block_layout",
+                            "type": "select",
+                            "instructions": "Choose which block layout you'd like to use.",
+                            "required": 1,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "50",
+                                "class": "",
+                                "id": ""
+                            },
+                            "choices": {
+                                "media_text": "Media\/Text",
+                                "text_media": "Text\/Media",
+                                "text_text": "Text\/Text"
+                            },
+                            "default_value": [
+                                "media_text"
+                            ],
+                            "allow_null": 0,
+                            "multiple": 0,
+                            "ui": 0,
+                            "ajax": 0,
+                            "return_format": "value",
+                            "placeholder": ""
+                        },
+                        {
+                            "key": "field_59416beff0b0b",
+                            "label": "Block Content",
+                            "name": "",
+                            "type": "tab",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "placement": "top",
+                            "endpoint": 0
+                        },
+                        {
+                            "key": "field_5908a1724dd19",
+                            "label": "Left Side Content",
+                            "name": "content_left",
+                            "type": "wysiwyg",
+                            "instructions": "Add content and media below. Also supports shortcodes and oEmbeds.",
+                            "required": 1,
+                            "conditional_logic": [
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "text_media"
+                                    }
+                                ],
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "text_text"
+                                    }
+                                ]
+                            ],
+                            "wrapper": {
+                                "width": "",
+                                "class": "text-right",
+                                "id": ""
+                            },
+                            "default_value": "",
+                            "tabs": "all",
+                            "toolbar": "full",
+                            "media_upload": 1,
+                            "delay": 0
+                        },
+                        {
+                            "key": "field_5908a2874dd20",
+                            "label": "Left Side Image",
+                            "name": "media_left",
+                            "type": "image",
+                            "instructions": "Add or Upload an image. (640x480px .jpg, .png)",
+                            "required": 0,
+                            "conditional_logic": [
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "media_text"
+                                    }
+                                ]
+                            ],
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "return_format": "array",
+                            "preview_size": "medium",
+                            "library": "all",
+                            "min_width": "",
+                            "min_height": "",
+                            "min_size": "",
+                            "max_width": "",
+                            "max_height": "",
+                            "max_size": "",
+                            "mime_types": "jpg, jpeg, png, gif"
+                        },
+                        {
+                            "key": "field_5908a2174dd1d",
+                            "label": "Right Side Image",
+                            "name": "media_right",
+                            "type": "image",
+                            "instructions": "Add or Upload an image. (640x480px .jpg, .png)",
+                            "required": 0,
+                            "conditional_logic": [
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "text_media"
+                                    }
+                                ]
+                            ],
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "return_format": "array",
+                            "preview_size": "medium",
+                            "library": "all",
+                            "min_width": "",
+                            "min_height": "",
+                            "min_size": "",
+                            "max_width": "",
+                            "max_height": "",
+                            "max_size": "",
+                            "mime_types": "jpg, jpeg, png, gif"
+                        },
+                        {
+                            "key": "field_5908a6054dd26",
+                            "label": "Right Side Content",
+                            "name": "content_right",
+                            "type": "wysiwyg",
+                            "instructions": "Add content and media below. Also supports shortcodes and oEmbeds.",
+                            "required": 1,
+                            "conditional_logic": [
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "text_text"
+                                    }
+                                ],
+                                [
+                                    {
+                                        "field": "field_59089fd63f35f",
+                                        "operator": "==",
+                                        "value": "media_text"
+                                    }
+                                ]
+                            ],
+                            "wrapper": {
+                                "width": "",
+                                "class": "text-right",
+                                "id": ""
+                            },
+                            "default_value": "",
+                            "tabs": "all",
+                            "toolbar": "full",
+                            "media_upload": 1,
+                            "delay": 0
+                        },
+                        {
+                            "key": "field_59416b913f18e",
+                            "label": "Block Options",
+                            "name": "block_options",
+                            "type": "clone",
+                            "instructions": "",
+                            "required": 0,
+                            "conditional_logic": 0,
+                            "wrapper": {
+                                "width": "",
+                                "class": "",
+                                "id": ""
+                            },
+                            "clone": [
+                                "group_594168e03b544"
+                            ],
+                            "display": "seamless",
+                            "layout": "block",
+                            "prefix_label": 0,
+                            "prefix_name": 0
+                        }
+                    ],
+                    "min": "",
+                    "max": ""
+                }
+            },
+            "button_label": "Add Block",
+            "min": "",
+            "max": ""
+        }
+    ],
+    "location": [
+        [
+            {
+                "param": "page_template",
+                "operator": "==",
+                "value": "page-acf.php"
+            }
+        ]
+    ],
+    "menu_order": 0,
+    "position": "normal",
+    "style": "default",
+    "label_placement": "top",
+    "instruction_placement": "label",
+    "hide_on_screen": [
+        "the_content",
+        "excerpt",
+        "custom_fields",
+        "discussion",
+        "comments",
+        "revisions",
+        "slug",
+        "author",
+        "format",
+        "categories",
+        "tags",
+        "send-trackbacks"
+    ],
+    "active": 1,
+    "description": "",
+    "modified": 1497462283
+}
\ No newline at end of file
diff --git a/acf-json/group_594168e03b544.json b/acf-json/group_594168e03b544.json
new file mode 100644
index 000000000..2630ff94b
--- /dev/null
+++ b/acf-json/group_594168e03b544.json
@@ -0,0 +1,82 @@
+{
+    "key": "group_594168e03b544",
+    "title": "Tab: Block Options - To Clone",
+    "fields": [
+        {
+            "key": "field_594169a1ee486",
+            "label": "Block Options",
+            "name": "",
+            "type": "tab",
+            "instructions": "",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "",
+                "class": "",
+                "id": ""
+            },
+            "placement": "top",
+            "endpoint": 0
+        },
+        {
+            "key": "field_594169467c667",
+            "label": "Background Options",
+            "name": "background_options",
+            "type": "clone",
+            "instructions": "",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "",
+                "class": "",
+                "id": ""
+            },
+            "clone": [
+                "group_58ebcc07bfbd7"
+            ],
+            "display": "seamless",
+            "layout": "block",
+            "prefix_label": 0,
+            "prefix_name": 0
+        },
+        {
+            "key": "field_594169727c668",
+            "label": "Other Options",
+            "name": "other_options",
+            "type": "clone",
+            "instructions": "",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "",
+                "class": "",
+                "id": ""
+            },
+            "clone": [
+                "group_594168e970d85"
+            ],
+            "display": "seamless",
+            "layout": "block",
+            "prefix_label": 0,
+            "prefix_name": 0
+        }
+    ],
+    "location": [
+        [
+            {
+                "param": "post_type",
+                "operator": "==",
+                "value": "post"
+            }
+        ]
+    ],
+    "menu_order": 0,
+    "position": "normal",
+    "style": "default",
+    "label_placement": "top",
+    "instruction_placement": "label",
+    "hide_on_screen": "",
+    "active": 0,
+    "description": "",
+    "modified": 1497459128
+}
\ No newline at end of file
diff --git a/acf-json/group_594168e970d85.json b/acf-json/group_594168e970d85.json
new file mode 100644
index 000000000..85a09c232
--- /dev/null
+++ b/acf-json/group_594168e970d85.json
@@ -0,0 +1,58 @@
+{
+    "key": "group_594168e970d85",
+    "title": "Fields: Block Options - To Clone",
+    "fields": [
+        {
+            "key": "field_594168fa457bd",
+            "label": "Font Color",
+            "name": "font_color",
+            "type": "color_picker",
+            "instructions": "Change the text color of this block.",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "default_value": ""
+        },
+        {
+            "key": "field_5941ea778fe87",
+            "label": "Custom CSS Class",
+            "name": "custom_css_class",
+            "type": "text",
+            "instructions": "Add a custom CSS class to this block.",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "default_value": "",
+            "placeholder": "custom-class",
+            "prepend": "",
+            "append": "",
+            "maxlength": ""
+        }
+    ],
+    "location": [
+        [
+            {
+                "param": "post_type",
+                "operator": "==",
+                "value": "post"
+            }
+        ]
+    ],
+    "menu_order": 0,
+    "position": "normal",
+    "style": "default",
+    "label_placement": "top",
+    "instruction_placement": "label",
+    "hide_on_screen": "",
+    "active": 0,
+    "description": "",
+    "modified": 1497492999
+}
\ No newline at end of file
diff --git a/acf-json/group_59416d894b7c7.json b/acf-json/group_59416d894b7c7.json
new file mode 100644
index 000000000..44bad5ee1
--- /dev/null
+++ b/acf-json/group_59416d894b7c7.json
@@ -0,0 +1,59 @@
+{
+    "key": "group_59416d894b7c7",
+    "title": "Fields: Button - To Clone",
+    "fields": [
+        {
+            "key": "field_59416d96077a8",
+            "label": "Button Text",
+            "name": "button_text",
+            "type": "text",
+            "instructions": "Write a short call to action.",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "default_value": "",
+            "placeholder": "",
+            "prepend": "",
+            "append": "",
+            "maxlength": ""
+        },
+        {
+            "key": "field_59416db5077a9",
+            "label": "Button URL",
+            "name": "button_url",
+            "type": "url",
+            "instructions": "Where will this button link to?",
+            "required": 0,
+            "conditional_logic": 0,
+            "wrapper": {
+                "width": "50",
+                "class": "",
+                "id": ""
+            },
+            "default_value": "",
+            "placeholder": ""
+        }
+    ],
+    "location": [
+        [
+            {
+                "param": "post_type",
+                "operator": "==",
+                "value": "post"
+            }
+        ]
+    ],
+    "menu_order": 0,
+    "position": "normal",
+    "style": "default",
+    "label_placement": "top",
+    "instruction_placement": "label",
+    "hide_on_screen": "",
+    "active": 0,
+    "description": "",
+    "modified": 1497460184
+}
\ No newline at end of file
diff --git a/assets/sass/base/_helpers.scss b/assets/sass/base/_helpers.scss
new file mode 100644
index 000000000..e10f2c281
--- /dev/null
+++ b/assets/sass/base/_helpers.scss
@@ -0,0 +1,47 @@
+//--------------------------------------------------------------
+// Helpers
+//--------------------------------------------------------------
+
+//-----------------------------------------
+// Full Width
+//-----------------------------------------
+.full-width {
+	margin-left: rem-calc(-35);
+	max-width: calc(100% + 70px);
+	width: calc(100% + 70px);
+
+	@include breakpoint(tablet-landscape) {
+		margin-left: rem-calc(-115);
+		max-width: calc(100% + 230px);
+		width: calc(100% + 230px);
+	}
+} // .full-width
+
+//-----------------------------------------
+// Image As Background
+//-----------------------------------------
+.image-as-background {
+	background-position: center center;
+	background-repeat: no-repeat;
+	background-size: cover;
+} // .image-as-background
+
+//-----------------------------------------
+// Video As Background
+//-----------------------------------------
+.video-as-background {
+	@include size(100%);
+
+	display: block;
+	object-fit: cover;
+	object-position: center top;
+	position: absolute;
+	z-index: 1;
+} // .video-as-background
+
+//-----------------------------------------
+// SVG Definitions
+//-----------------------------------------
+.svg-defs {
+	display: none;
+} // .svg-defs
diff --git a/assets/sass/base/_wordpress.scss b/assets/sass/base/_wordpress.scss
new file mode 100644
index 000000000..e895793c9
--- /dev/null
+++ b/assets/sass/base/_wordpress.scss
@@ -0,0 +1,193 @@
+//--------------------------------------------------------------
+// WordPress Classes
+//--------------------------------------------------------------
+
+//-----------------------------------------
+// Alignments
+//-----------------------------------------
+.alignleft {
+	display: inline;
+	float: left;
+	margin: 0 $global-margin 0 0;
+} // .alignleft
+
+.alignright {
+	display: inline;
+	float: right;
+	margin: 0 0 0 $global-margin;
+} // .alignright
+
+.aligncenter {
+	display: block;
+	margin-left: auto;
+	margin-right: auto;
+} // .aligncenter
+
+//-----------------------------------------
+// Typography
+//-----------------------------------------
+pre {
+	background-color: $code-background;
+	color: $code-color;
+	font-family: $font-family-monospace;
+	font-size: em(15);
+	font-weight: $code-font-weight;
+	line-height: $global-lineheight;
+	margin: $paragraph-margin-bottom 0 $paragraph-margin-bottom;
+	overflow: auto;
+	padding: $code-padding;
+	white-space: pre;
+	word-break: normal;
+	word-wrap: normal;
+} // pre
+
+code,
+kbd,
+tt,
+var {
+	font-family: $font-family-monospace;
+	font-size: em(15);
+} // code, kbd, tt, var
+
+abbr,
+acronym {
+	border-bottom: $code-border;
+	cursor: help;
+} // abbr, acronym
+
+mark,
+ins {
+	text-decoration: none;
+} // mark, ins
+
+sup,
+sub {
+	font-size: 75%;
+	height: 0;
+	line-height: 0;
+	position: relative;
+	vertical-align: baseline;
+} // sup, sub
+
+sup {
+	bottom: 1ex;
+} // sup
+
+sub {
+	top: 0.5ex;
+} // sub
+
+small {
+	font-size: 75%;
+} // small
+
+big {
+	font-size: 125%;
+} // big
+
+//-----------------------------------------
+// Screen Readers
+//-----------------------------------------
+.screen-reader-text {
+	@include element-invisible;
+} // .screen-reader-text
+
+//-----------------------------------------
+// Captions
+//-----------------------------------------
+.wp-caption {
+	margin: 0 0 $global-margin 0;
+	max-width: 100%;
+
+	img[class*='wp-image-'] {
+		display: block;
+		margin: 0 auto;
+	} // img[class*="wp-image-"]
+
+	// Add auto margins so image is centered
+	&.aligncenter {
+		margin: 0 auto $global-margin auto;
+	} // &.aligncenter
+
+	// Add a margin right to left-aligned images with captions
+	&.alignleft {
+		margin-right: $global-margin;
+	} // &.alignleft
+
+	// Add a margin left to right-aligned images with captions
+	&.alignright {
+		margin-left: $global-margin;
+	} // &.alignright
+
+	// Add top and bottom margin to caption text
+	.wp-caption-text {
+		margin: $global-margin 0;
+	} // .wp-caption-text
+} // .wp-caption
+
+// Image caption text
+.wp-caption-text {
+	text-align: center;
+} // .wp-caption-text
+
+//-----------------------------------------
+// Galleries
+//-----------------------------------------
+.gallery {
+	margin: 0 0 $global-margin 0;
+} // .gallery
+
+// Gallery caption
+.gallery-caption {
+	display: block;
+} // .gallery-caption
+
+// Gallery items
+.gallery-item {
+	@include size(100% auto);
+
+	display: inline-block;
+	text-align: center;
+	vertical-align: top;
+
+	.gallery-columns-2 & {
+		max-width: 50%;
+	} // .gallery-columns-2 &
+
+	.gallery-columns-3 & {
+		max-width: 33.33%;
+	} // .gallery-columns-3 &
+
+	.gallery-columns-4 & {
+		max-width: 25%;
+	} // .gallery-columns-4 &
+
+	.gallery-columns-5 & {
+		max-width: 20%;
+	} // .gallery-columns-5 &
+
+	.gallery-columns-6 & {
+		max-width: 16.66%;
+	} // .gallery-columns-6 &
+
+	.gallery-columns-7 & {
+		max-width: 14.28%;
+	} // .gallery-columns-7 &
+
+	.gallery-columns-8 & {
+		max-width: 12.5%;
+	} // .gallery-columns-8 &
+
+	.gallery-columns-9 & {
+		max-width: 11.11%;
+	} // .gallery-columns-9 &
+} // .gallery-item
+
+//-----------------------------------------
+// Misc.
+//-----------------------------------------
+.wp-smiley {
+	@include margin-padding-reset;
+
+	border: none;
+} // .wp-smiley
diff --git a/assets/sass/base/index.scss b/assets/sass/base/index.scss
index e69de29bb..5a9321365 100644
--- a/assets/sass/base/index.scss
+++ b/assets/sass/base/index.scss
@@ -0,0 +1,2 @@
+@import 'helpers';
+@import 'wordpress';
diff --git a/assets/sass/components/_content-blocks.scss b/assets/sass/components/_content-blocks.scss
new file mode 100644
index 000000000..bccc50cbd
--- /dev/null
+++ b/assets/sass/components/_content-blocks.scss
@@ -0,0 +1,6 @@
+//--------------------------------------------------------------
+// Content Blocks
+//--------------------------------------------------------------
+.content-block {
+	padding: $global-padding;
+} // .content-block
\ No newline at end of file
diff --git a/assets/sass/components/_navigation.scss b/assets/sass/components/_navigation.scss
index e914b34e1..86bc73338 100644
--- a/assets/sass/components/_navigation.scss
+++ b/assets/sass/components/_navigation.scss
@@ -1,14 +1,26 @@
 //--------------------------------------------------------------
 // Primary Navigation Menu
-//
-// Styles for the primary navigation menu in the header and the off-canvas mobile menu.
 //--------------------------------------------------------------
 
-// Target the off-canvas menu.
+//-----------------------------------------
+// Hamburger Icon
+//-----------------------------------------
+.hamburger-icon {
+	@include hamburger($black, $medium-gray, 20px, 16px, 2px, 3);
+} // .hamburger
+
+//-----------------------------------------
+// Off Canvas Drawer
+//-----------------------------------------
 .off-canvas {
 
+	// When the admin bar is present.
+	.admin-bar & {
+		padding-top: $global-padding * 3.5;
+	} // .admin-bar
+
 	// Indent our submenus on mobile.
 	.is-accordion-submenu {
-		padding-left: 1rem;
+		padding-left: $global-padding;
 	} // .is-accordion-submenu
 } // .off-canvas
diff --git a/assets/sass/components/index.scss b/assets/sass/components/index.scss
index cd24ca4ce..31f72c816 100644
--- a/assets/sass/components/index.scss
+++ b/assets/sass/components/index.scss
@@ -1 +1,2 @@
-@import "navigation";
+@import 'navigation';
+@import 'content-blocks';
\ No newline at end of file
diff --git a/assets/sass/foundation/_components.scss b/assets/sass/foundation/_components.scss
index 8ddd8f9ac..5526d392d 100644
--- a/assets/sass/foundation/_components.scss
+++ b/assets/sass/foundation/_components.scss
@@ -1,44 +1,44 @@
 //--------------------------------------------------------------
 // Foundation components.
 //
-// Comment out uneeded items!
+// To enable, just uncomment and re-run `gulp styles`.
 //--------------------------------------------------------------
 @include foundation-global-styles;
-// @include foundation-grid; // Use flex grid instead.
+// @include foundation-grid;
 @include foundation-flex-grid;
 @include foundation-flex-classes;
 @include foundation-typography;
 @include foundation-forms;
 @include foundation-button;
-@include foundation-accordion;
-@include foundation-accordion-menu;
-@include foundation-badge;
-@include foundation-breadcrumbs;
+// @include foundation-accordion;
+// @include foundation-accordion-menu;
+// @include foundation-badge;
+// @include foundation-breadcrumbs;
 @include foundation-button-group;
-@include foundation-callout;
-@include foundation-card;
-@include foundation-close-button;
+// @include foundation-callout;
+// @include foundation-card;
+// @include foundation-close-button;
 @include foundation-menu;
-@include foundation-menu-icon;
-@include foundation-drilldown-menu;
+// @include foundation-menu-icon;
+// @include foundation-drilldown-menu;
 @include foundation-dropdown;
 @include foundation-dropdown-menu;
-@include foundation-responsive-embed;
-@include foundation-label;
-@include foundation-media-object;
+// @include foundation-responsive-embed;
+// @include foundation-label;
+// @include foundation-media-object;
 @include foundation-off-canvas;
-@include foundation-orbit;
-@include foundation-pagination;
-@include foundation-progress-bar;
-@include foundation-slider;
-@include foundation-sticky;
-@include foundation-reveal;
-@include foundation-switch;
-@include foundation-table;
-@include foundation-tabs;
-@include foundation-thumbnail;
-@include foundation-title-bar;
-@include foundation-tooltip;
-@include foundation-top-bar;
+// @include foundation-orbit;
+// @include foundation-pagination;
+// @include foundation-progress-bar;
+// @include foundation-slider;
+// @include foundation-sticky;
+// @include foundation-reveal;
+// @include foundation-switch;
+// @include foundation-table;
+// @include foundation-tabs;
+// @include foundation-thumbnail;
+// @include foundation-title-bar;
+// @include foundation-tooltip;
+// @include foundation-top-bar;
 @include foundation-visibility-classes;
 @include foundation-float-classes;
diff --git a/assets/sass/foundation/_settings.scss b/assets/sass/foundation/_settings.scss
index 665ba5b5d..348806697 100644
--- a/assets/sass/foundation/_settings.scss
+++ b/assets/sass/foundation/_settings.scss
@@ -48,7 +48,7 @@
 // ---------
 
 $global-font-size: 100%;
-$global-width: rem-calc(1200);
+$global-width: rem-calc(960);
 $global-lineheight: 1.5;
 $foundation-palette: (
   primary: #1779ba,
diff --git a/assets/sass/sections/_comments.scss b/assets/sass/sections/_comments.scss
new file mode 100644
index 000000000..f83c672fc
--- /dev/null
+++ b/assets/sass/sections/_comments.scss
@@ -0,0 +1,240 @@
+//--------------------------------------------------------------
+// Comments
+//--------------------------------------------------------------
+
+//-----------------------------------------
+// Comment area scaffolding
+//-----------------------------------------
+.comments-area {
+	border-top: $input-border;
+	margin: $global-margin 0;
+
+	@include breakpoint(desktop) {
+		margin-left: auto;
+		margin-right: auto;
+	}
+
+	.comment-reply-title {
+		margin-top: $global-margin;
+	} // .comment-reply-title
+
+	.comments-title {
+		font-size: em(24);
+		margin-top: $global-margin;
+	} // .comments-title
+
+	.comment-notes {
+		font-size: em(16);
+		margin-top: $global-margin;
+	} // .comment-notes
+} // .comments-area
+
+//-----------------------------------------
+// Labels
+//-----------------------------------------
+.comment-form-comment,
+.comment-form-author,
+.comment-form-email,
+.comment-form-url {
+
+	label {
+		float: left;
+		font-size: em(16);
+		text-transform: uppercase;
+		width: 100%;
+	} // label
+} // .comment-form-comment, .comment-form-author, .comment-form-email, .comment-form-url
+
+//-----------------------------------------
+// The comment form.
+//-----------------------------------------
+.comment-form {
+	@include clearfix;
+
+	width: 100%;
+
+	// Any input (except submit button)
+	input:not(.submit) {
+		clear: both;
+		transition: border 0.2s ease-in-out;
+		width: 100%;
+
+		@include breakpoint(phone-landscape) {
+			max-width: rem-calc(250);
+		}
+	} // input:not(.submit)
+
+	// Comment text area.
+	textarea {
+		max-width: rem-calc(870);
+		transition: border 0.2s ease-in-out;
+	} // textara
+
+	.form-submit {
+		margin: 0;
+	} // .form-submit
+
+	// Submit button.
+	input[type='submit'] {
+		width: rem-calc(196);
+	} // input[type="submit"]
+} // .comment-form
+
+//-----------------------------------------
+// Comments
+//-----------------------------------------
+.comment-list {
+	@include list-reset;
+
+	margin: 0;
+
+	// Even comments get nice gray background.
+	.even:not(.bypostauthor) > .comment-body {
+		background-color: $medium-gray;
+	} // .even > .comment-body
+
+	// Each comment body.
+	.comment-body {
+		margin: $global-margin 0;
+		padding: $global-padding;
+	} // .comment-body
+
+	// Comment content.
+	.comment-content {
+		margin: $global-margin 0;
+		max-width: rem-calc(936);
+	} // .comment-content
+
+	// Comment meta.
+	.comment-meta {
+		@include clearfix;
+
+		margin: 0 0 $global-margin 0;
+	} // .comment-meta
+
+	// The comment author name.
+	.comment-author {
+		line-height: 1;
+	} // .comment-author
+
+	// The date/time.
+	.comment-metadata {
+		line-height: 1;
+		margin-top: rem-calc(5);
+
+		a {
+			color: $black;
+			text-decoration: none;
+		} // a
+
+		time,
+		.comment-edit-link {
+			font-size: em(12);
+		} // time, .comment-edit-link
+	} // .comment-metadata
+
+	// Comments avatar.
+	.avatar {
+		border-radius: 50%;
+		float: left;
+		margin: 0 $global-margin 0 0;
+	} // .avatar
+
+	// By post author.
+	.bypostauthor {
+		background-color: get-color(secondary);
+		display: block;
+	} // .bypostauthor
+
+	// The reply link/button thingy.
+	.comment-reply-link {
+		font-weight: 700;
+	} // .comment-reply-link
+
+	// If someone replies with code...
+	pre,
+	code {
+		margin: 0;
+		width: 100%;
+	} // pre, code
+} // .comment-list
+
+//-----------------------------------------
+// Nested children scaffolding.
+//-----------------------------------------
+.comment-list {
+
+	// Comment children.
+	.children {
+		list-style: none;
+		margin: $global-margin * 2 0;
+		padding-left: $global-padding;
+
+		@include breakpoint(phone-landscape) {
+			padding-left: $global-padding * 2;
+		}
+
+		@include breakpoint(tablet-portrait) {
+			padding-left: $global-padding * 4;
+		}
+
+		.depth-4,
+		.depth-5,
+		.depth-6,
+		.depth-7,
+		.depth-8,
+		.depth-9,
+		.depth-10 {
+
+			// Increase line height on mobile for better readability.
+			.comment-author {
+				line-height: 1.25;
+
+				@include breakpoint(phone-landscape) {
+					line-height: 1;
+				}
+			} // .comment-author
+		} // .depth-x
+	} // .children
+} // .comment-list
+
+//-----------------------------------------
+// Inline reply
+//-----------------------------------------
+.comment-list {
+
+	.comment-respond {
+		background-color: $white;
+		padding: $global-padding 0;
+
+		@include breakpoint(phone-landscape) {
+			padding-left: $global-padding * 2;
+			padding-right: $global-padding * 2;
+		}
+
+		.comment-reply-title {
+
+			// The "cancel reply".
+			a {
+				display: inline-block;
+				text-transform: lowercase;
+
+				&::before {
+					content: '(';
+				}
+
+				&::after {
+					content: ')';
+				}
+			} // a
+		} // .comment-reply-title
+
+		.form-submit {
+			margin: 0;
+
+			input[type='submit'] {
+				margin-top: rem-calc(5);
+			}
+		} // .form-submit
+	} // .comment-respond
+} // .comment-list
diff --git a/assets/sass/sections/_content.scss b/assets/sass/sections/_content.scss
new file mode 100644
index 000000000..4d7492fc1
--- /dev/null
+++ b/assets/sass/sections/_content.scss
@@ -0,0 +1,100 @@
+//--------------------------------------------------------------
+// Content
+//--------------------------------------------------------------
+
+// Sticky and comments Link.
+.sticky,
+.comments-link {
+	display: block;
+} // .sticky, .comments-link
+
+// hentry
+.hentry {
+	margin: 0 0 $global-margin * 2 0;
+} // .hentry
+
+// Byline and update post date.
+.byline,
+.updated:not(.published) {
+	display: none;
+} // .byline, .updated:not(.published)
+
+// Byline for single and group.
+.single .byline,
+.group-blog .byline {
+	display: inline;
+} // .single .byline, .group-blog .byline
+
+// Page content, entry content and entry summary.
+.page-content,
+.entry-content,
+.entry-summary {
+	margin: $global-margin * 2 0 0;
+} // .page-content, .entry-content, .entry-summary
+
+// Page links.
+.page-links {
+	clear: both;
+	margin: 0 0 $global-margin * 2 0;
+} // .page-links
+
+// Tags links.
+.tags-links {
+	margin-left: $global-margin * 2;
+} // .tags-links
+
+// Edit link.
+.edit-link {
+	a {
+		font-size: em(12);
+		text-transform: lowercase;
+
+		&::before {
+			content: '(';
+		}
+
+		&::after {
+			content: ')';
+		}
+	} // a
+} // .edit-link
+
+// Asides.
+.blog .format-aside .entry-title,
+.archive .format-aside .entry-title {
+	display: none;
+} // .blog .format-aside .entry-title, .archive .format-aside .entry-title
+
+// Navigation on Comment, Post and Posts.
+.comment-navigation,
+.posts-navigation,
+.post-navigation {
+
+	.site-main & {
+		margin: 0 0 $global-margin 0;
+		overflow: hidden;
+	} // .site-main &
+
+	.nav-previous {
+		@include size(50% auto);
+
+		float: left;
+	} // &.nav-previous
+
+	.nav-next {
+		@include size(50% auto);
+
+		float: right;
+		text-align: right;
+	} // &.nav-next
+} // .comment-navigation, .posts-navigation, .post-navigation
+
+// Word wrapping.
+.entry-title,
+.entry-content,
+.comments-title,
+.comment-content,
+.widget-title,
+.widget {
+	@include word-break;
+} // .entry-title, .entry-content, .comments-title, .comment-content, .widget-title, .widget
\ No newline at end of file
diff --git a/assets/sass/sections/_footer.scss b/assets/sass/sections/_footer.scss
new file mode 100644
index 000000000..696f52343
--- /dev/null
+++ b/assets/sass/sections/_footer.scss
@@ -0,0 +1,6 @@
+//--------------------------------------------------------------
+// Site Footer
+//--------------------------------------------------------------
+.site-footer {
+	margin: $global-margin * 2 auto;
+} // .site-footer
diff --git a/assets/sass/sections/_header.scss b/assets/sass/sections/_header.scss
new file mode 100644
index 000000000..68abd063f
--- /dev/null
+++ b/assets/sass/sections/_header.scss
@@ -0,0 +1,6 @@
+//--------------------------------------------------------------
+// Site Header
+//--------------------------------------------------------------
+.site-header {
+	margin: $global-margin * 2 auto;
+} // .site-header
diff --git a/assets/sass/sections/_hero.scss b/assets/sass/sections/_hero.scss
new file mode 100644
index 000000000..ad5be6acf
--- /dev/null
+++ b/assets/sass/sections/_hero.scss
@@ -0,0 +1,54 @@
+//--------------------------------------------------------------
+// Hero
+//--------------------------------------------------------------
+.hero {
+	overflow-y: hidden;
+	position: relative;
+	z-index: 1;
+
+	// Optional transparent overlay.
+	&::after {
+		@include size(100%);
+		@include position(absolute, 0 0 null null);
+
+		background-color: rgba($black, 0.7);
+		content: '';
+		z-index: 2;
+	} // .hero::after
+
+	// Content container.
+	&-content {
+		padding: $global-padding * 4 0;
+		position: relative;
+		z-index: 3;
+
+		@include breakpoint(admin-bar) {
+			padding: $global-padding * 8 0;
+		}
+	} // .hero-content
+
+	// Headline container.
+	&-headline {
+		font-size: rem-calc(48);
+		line-height: 1.2;
+		margin-bottom: $global-padding * 2;
+
+		@include breakpoint(medium) {
+			margin-bottom: $global-padding;
+		}
+	} // .hero-headline
+
+	// Text/burb container.
+	&-text {
+		font-size: rem-calc(18);
+
+		@include breakpoint(medium) {
+			font-size: rem-calc(24);
+		}
+	} // .hero-text
+
+	// CTA button.
+	&-button {
+		margin-top: rem-calc(10);
+	} // .hero-button
+} // .hero
diff --git a/assets/sass/sections/index.scss b/assets/sass/sections/index.scss
index e69de29bb..32662bbe3 100644
--- a/assets/sass/sections/index.scss
+++ b/assets/sass/sections/index.scss
@@ -0,0 +1,5 @@
+@import 'comments';
+@import 'content';
+@import 'footer';
+@import 'header';
+@import 'hero';
diff --git a/assets/sass/style.scss b/assets/sass/style.scss
index f107feb92..121a5061f 100644
--- a/assets/sass/style.scss
+++ b/assets/sass/style.scss
@@ -19,6 +19,11 @@
 // Load Foundation.
 @import 'foundation/index';
 
+// Load custom variables, functions, and mixins.
+@import 'utilities/variables/index';
+@import 'utilities/functions/index';
+@import 'utilities/mixins/index';
+
 // Our most basic level file type (variables, typography, etc).
 @import 'base/index';
 
diff --git a/assets/sass/utilities/functions/_contains.scss b/assets/sass/utilities/functions/_contains.scss
new file mode 100644
index 000000000..f2c9e8562
--- /dev/null
+++ b/assets/sass/utilities/functions/_contains.scss
@@ -0,0 +1,33 @@
+//--------------------------------------------------------------
+// Contains
+//--------------------------------------------------------------
+
+////
+/// @author Bourbon v5
+/// @group Thoughtbot
+////
+
+/// Checks if a list contains a value(s).
+///
+/// @argument {list} $list
+///   The list to check against.
+///
+/// @argument {list} $values
+///   A single value or list of values to check for.
+///
+/// @return {boolean}
+///
+/// @access private
+
+@function _contains(
+  $list,
+  $values...
+) {
+  @each $value in $values {
+    @if type-of(index($list, $value)) != "number" {
+      @return false;
+    }
+  }
+
+  @return true;
+}
diff --git a/assets/sass/utilities/functions/_is-size.scss b/assets/sass/utilities/functions/_is-size.scss
new file mode 100644
index 000000000..806ac7c0b
--- /dev/null
+++ b/assets/sass/utilities/functions/_is-size.scss
@@ -0,0 +1,25 @@
+// ----------------------------------------------------------------------
+// Is Size
+// ----------------------------------------------------------------------
+
+////
+/// @author Bourbon v5
+/// @group Thoughtbot
+////
+
+/// Checks for a valid CSS size.
+///
+/// @argument {string} $value
+///
+/// @return {boolean}
+///
+/// @require {function} _contains
+///
+/// @require {function} _is-length
+///
+/// @access private
+
+@function _is-size($value) {
+  @return _is-length($value)
+          or _contains("fill" "fit-content" "min-content" "max-content", $value);
+}
diff --git a/assets/sass/utilities/functions/_unpack-shorthand.scss b/assets/sass/utilities/functions/_unpack-shorthand.scss
new file mode 100644
index 000000000..9f3efb00a
--- /dev/null
+++ b/assets/sass/utilities/functions/_unpack-shorthand.scss
@@ -0,0 +1,36 @@
+// ----------------------------------------------------------------------
+// Unpack Shorthand Values
+// ----------------------------------------------------------------------
+
+////
+/// @author Bourbon v5
+/// @group Thoughtbot
+////
+
+/// Transforms shorthand that can range from 1-to-4 values to be 4 values.
+///
+/// @argument {list} $shorthand
+///
+/// @example scss
+///   .element {
+///     margin: _unpack-shorthand(1em 2em);
+///   }
+///
+///   // CSS Output
+///   .element {
+///     margin: 1em 2em 1em 2em;
+///   }
+///
+/// @access private
+
+@function _unpack-shorthand($shorthand) {
+  @if length($shorthand) == 1 {
+    @return nth($shorthand, 1) nth($shorthand, 1) nth($shorthand, 1) nth($shorthand, 1);
+  } @else if length($shorthand) == 2 {
+    @return nth($shorthand, 1) nth($shorthand, 2) nth($shorthand, 1) nth($shorthand, 2);
+  } @else if length($shorthand) == 3 {
+    @return nth($shorthand, 1) nth($shorthand, 2) nth($shorthand, 3) nth($shorthand, 2);
+  } @else {
+    @return $shorthand;
+  }
+}
diff --git a/assets/sass/utilities/functions/index.scss b/assets/sass/utilities/functions/index.scss
new file mode 100644
index 000000000..86fa5d6ae
--- /dev/null
+++ b/assets/sass/utilities/functions/index.scss
@@ -0,0 +1,3 @@
+@import 'contains';
+@import 'is-size';
+@import 'unpack-shorthand';
diff --git a/assets/sass/utilities/mixins/_list-reset.scss b/assets/sass/utilities/mixins/_list-reset.scss
new file mode 100644
index 000000000..19ffde2a5
--- /dev/null
+++ b/assets/sass/utilities/mixins/_list-reset.scss
@@ -0,0 +1,33 @@
+// ----------------------------------------------------------------------
+// List Reset
+// ----------------------------------------------------------------------
+
+////
+/// @author Greg Rickaby
+/// @group wds
+////
+
+/// Reset all padding and styles on both unordered and ordered lists.
+///
+/// @example scss - Basic Usage Sass
+///    .foo-list {
+///        @include list-reset;
+///    }
+///
+/// @example scss - Basic Usage CSS Output
+///    .foo-list {
+///         clear: both;
+///			content: "";
+///			display: table;
+///        	margin: 0;
+///        	padding: 0;
+///        	list-style: none;
+///
+///    }
+
+@mixin list-reset {
+	@include clearfix;
+	@include margin-padding-reset;
+
+	list-style: none;
+}
diff --git a/assets/sass/utilities/mixins/_margin-padding-reset.scss b/assets/sass/utilities/mixins/_margin-padding-reset.scss
new file mode 100644
index 000000000..d871e4e16
--- /dev/null
+++ b/assets/sass/utilities/mixins/_margin-padding-reset.scss
@@ -0,0 +1,26 @@
+// ----------------------------------------------------------------------
+// Margin & Padding Reset
+// ----------------------------------------------------------------------
+
+////
+/// @author Greg Rickaby
+/// @group wds
+////
+
+/// Resets margin and padding on any element
+///
+/// @example scss - Basic Usage Sass
+///    .foo {
+///			@include margin-padding-reset;
+///    }
+///
+/// @example scss - Basic Usage CSS Output
+///    .foo {
+///         margin: 0;
+///         padding: 0;
+///    }
+
+@mixin margin-padding-reset {
+	margin: 0;
+	padding: 0;
+}
diff --git a/assets/sass/utilities/mixins/_position.scss b/assets/sass/utilities/mixins/_position.scss
new file mode 100644
index 000000000..6520fe541
--- /dev/null
+++ b/assets/sass/utilities/mixins/_position.scss
@@ -0,0 +1,69 @@
+// ----------------------------------------------------------------------
+// Position
+// ----------------------------------------------------------------------
+
+////
+/// @author Bourbon v5
+/// @group Thoughtbot
+////
+
+/// Provides a concise, one-line method for setting an element’s positioning
+/// properties: `position`, `top`, `right`, `bottom` and `left`. Use a `null`
+/// value to “skip” an edge of the box.
+///
+/// @argument {string} $position
+///   A CSS position value.
+///
+/// @argument {list} $box-edge-values
+///   List of lengths; accepts CSS shorthand.
+///
+/// @example scss
+///   .element {
+///     @include position(relative, 0 null null 10em);
+///   }
+///
+///   // CSS Output
+///   .element {
+///     left: 10em;
+///     position: relative;
+///     top: 0;
+///   }
+///
+/// @example scss
+///   .element {
+///     @include position(absolute, 0);
+///   }
+///
+///   // CSS Output
+///   .element {
+///     position: absolute;
+///     top: 0;
+///     right: 0;
+///     bottom: 0;
+///     left: 0;
+///   }
+///
+/// @require {function} _is-length
+///
+/// @require {function} _unpack-shorthand
+
+@mixin position(
+  $position,
+  $box-edge-values
+) {
+  $box-edge-values: _unpack-shorthand($box-edge-values);
+  $offsets: (
+    top:    nth($box-edge-values, 1),
+    right:  nth($box-edge-values, 2),
+    bottom: nth($box-edge-values, 3),
+    left:   nth($box-edge-values, 4),
+  );
+
+  position: $position;
+
+  @each $offset, $value in $offsets {
+    @if _is-length($value) {
+      #{$offset}: $value;
+    }
+  }
+}
diff --git a/assets/sass/utilities/mixins/_size.scss b/assets/sass/utilities/mixins/_size.scss
new file mode 100644
index 000000000..cc52b237c
--- /dev/null
+++ b/assets/sass/utilities/mixins/_size.scss
@@ -0,0 +1,50 @@
+@charset "UTF-8";
+
+/// Sets the `width` and `height` of the element in one statement.
+///
+/// @argument {number (with unit) | string} $width
+///
+/// @argument {number (with unit) | string} $height [$width]
+///
+/// @example scss
+///   .first-element {
+///     @include size(2em);
+///   }
+///
+///   // CSS Output
+///   .first-element {
+///     width: 2em;
+///     height: 2em;
+///   }
+///
+/// @example scss
+///   .second-element {
+///     @include size(auto, 10em);
+///   }
+///
+///   // CSS Output
+///   .second-element {
+///     width: auto;
+///     height: 10em;
+///   }
+///
+/// @require {function} _is-size
+
+@mixin size(
+  $width,
+  $height: $width
+) {
+  @if _is-size($height) {
+    height: $height;
+  } @else {
+    @error "`#{$height}` is not a valid length for the `$height` argument " +
+           "in the `size` mixin.";
+  }
+
+  @if _is-size($width) {
+    width: $width;
+  } @else {
+    @error "`#{$width}` is not a valid length for the `$width` argument " +
+           "in the `size` mixin.";
+  }
+}
diff --git a/assets/sass/utilities/mixins/_word-break.scss b/assets/sass/utilities/mixins/_word-break.scss
new file mode 100644
index 000000000..8f5b2e5eb
--- /dev/null
+++ b/assets/sass/utilities/mixins/_word-break.scss
@@ -0,0 +1,31 @@
+//--------------------------------------------------------------
+// Word Break
+//--------------------------------------------------------------
+
+////
+/// @author Stacy Kvernmo
+/// @group wds
+////
+
+/// Keep words together if possible, but force break anything that is too long
+/// @param {String} $word-break [keep-all]
+///      `normal` | `break-all` | `keep-all`
+///
+/// @link https://developer.mozilla.org/en-US/docs/Web/CSS/word-break View background information about word-break here
+/// @link http://sassmeister.com/gist/3f09e69a73e14859f967 View word-break in action
+///
+/// @example scss - Basic Usage Sass
+///    .break-long-words-only {
+///        @include word-break(keep-all);
+///    }
+///
+/// @example scss - Basic Usage CSS Output
+///    .break-long-words-only {
+///            word-wrap: break-word;
+///            word-break: keep-all;
+///     }
+
+@mixin word-break($word-break: keep-all) {
+	word-break: $word-break;
+	word-wrap: break-word;
+}
diff --git a/assets/sass/utilities/mixins/index.scss b/assets/sass/utilities/mixins/index.scss
new file mode 100644
index 000000000..469f0e4cf
--- /dev/null
+++ b/assets/sass/utilities/mixins/index.scss
@@ -0,0 +1,5 @@
+@import 'list-reset';
+@import 'margin-padding-reset';
+@import 'position';
+@import 'size';
+@import 'word-break';
\ No newline at end of file
diff --git a/assets/sass/utilities/variables/_breakpoints.scss b/assets/sass/utilities/variables/_breakpoints.scss
new file mode 100644
index 000000000..9a01e7833
--- /dev/null
+++ b/assets/sass/utilities/variables/_breakpoints.scss
@@ -0,0 +1,50 @@
+//--------------------------------------------------------------
+// Media Query Breakpoints
+//--------------------------------------------------------------
+
+/// Custom Media Query Breakpoints
+///
+/// Since each version of Foundation may
+/// require us to update _settings.scss,
+/// create a custom list of breakpoints
+/// and merge the two together.
+///
+/// @group wds
+
+$custom-breakpoints: (
+	phone-portrait: 360px,
+	phone-landscape: 640px,
+	tablet-portrait: 768px,
+	wp-admin-bar: 783px,
+	tablet-landscape: 1024px,
+	desktop: 1366px,
+	large-desktop: 1680px
+);
+
+/// Merge custom breakpoints with Foundation.
+///
+/// @example scss - Basic Usage Sass
+///    .foo {
+///			@include breakpoint(tablet-portrait) {
+///			   width: rem-calc(240);
+///			}
+///    }
+///
+/// @example scss - Basic Usage CSS Output
+///    .foo {
+///         @media (min-width: 48em) {
+///         	width: 15rem;
+///         }
+///    }
+
+$breakpoints: map-merge($breakpoints, $custom-breakpoints);
+
+/// Merge custom breakpoint classes with Foundation.
+///
+/// @example html - Basic Usage CSS Class
+///    <div class="column tablet-portrait">
+///       <p>Foo text</p>
+///    </div>
+
+$custom-breakpoint-keys: map-keys($custom-breakpoints); // Create a list of custom breakpoint names.
+$breakpoint-classes: join($breakpoint-classes, $custom-breakpoint-keys); // Merge the custom breakpoint names (keys) with Foundation.
diff --git a/assets/sass/utilities/variables/index.scss b/assets/sass/utilities/variables/index.scss
new file mode 100644
index 000000000..b433f0fe5
--- /dev/null
+++ b/assets/sass/utilities/variables/index.scss
@@ -0,0 +1 @@
+@import 'breakpoints';
diff --git a/assets/scripts/project.js b/assets/scripts/project.js
index 9567669cd..f0cc1a9b2 100644
--- a/assets/scripts/project.js
+++ b/assets/scripts/project.js
@@ -632,630 +632,316 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 !function ($) {
 
   /**
-   * Abide module.
-   * @module foundation.abide
+   * AccordionMenu module.
+   * @module foundation.accordionMenu
+   * @requires foundation.util.keyboard
+   * @requires foundation.util.motion
+   * @requires foundation.util.nest
    */
 
-  var Abide = function () {
+  var AccordionMenu = function () {
     /**
-     * Creates a new instance of Abide.
+     * Creates a new instance of an accordion menu.
      * @class
-     * @fires Abide#init
-     * @param {Object} element - jQuery object to add the trigger to.
+     * @fires AccordionMenu#init
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
      * @param {Object} options - Overrides to the default plugin settings.
      */
-    function Abide(element) {
-      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
-
-      _classCallCheck(this, Abide);
+    function AccordionMenu(element, options) {
+      _classCallCheck(this, AccordionMenu);
 
       this.$element = element;
-      this.options = $.extend({}, Abide.defaults, this.$element.data(), options);
+      this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+
+      Foundation.Nest.Feather(this.$element, 'accordion');
 
       this._init();
 
-      Foundation.registerPlugin(this, 'Abide');
+      Foundation.registerPlugin(this, 'AccordionMenu');
+      Foundation.Keyboard.register('AccordionMenu', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_RIGHT': 'open',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'close',
+        'ESCAPE': 'closeAll'
+      });
     }
 
     /**
-     * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+     * Initializes the accordion menu by hiding all nested menus.
      * @private
      */
 
 
-    _createClass(Abide, [{
+    _createClass(AccordionMenu, [{
       key: '_init',
       value: function _init() {
-        this.$inputs = this.$element.find('input, textarea, select');
+        this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
+        this.$element.attr({
+          'role': 'menu',
+          'aria-multiselectable': this.options.multiOpen
+        });
 
+        this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
+        this.$menuLinks.each(function () {
+          var linkId = this.id || Foundation.GetYoDigits(6, 'acc-menu-link'),
+              $elem = $(this),
+              $sub = $elem.children('[data-submenu]'),
+              subId = $sub[0].id || Foundation.GetYoDigits(6, 'acc-menu'),
+              isActive = $sub.hasClass('is-active');
+          $elem.attr({
+            'aria-controls': subId,
+            'aria-expanded': isActive,
+            'role': 'menuitem',
+            'id': linkId
+          });
+          $sub.attr({
+            'aria-labelledby': linkId,
+            'aria-hidden': !isActive,
+            'role': 'menu',
+            'id': subId
+          });
+        });
+        var initPanes = this.$element.find('.is-active');
+        if (initPanes.length) {
+          var _this = this;
+          initPanes.each(function () {
+            _this.down($(this));
+          });
+        }
         this._events();
       }
 
       /**
-       * Initializes events for Abide.
+       * Adds event handlers for items within the menu.
        * @private
        */
 
     }, {
       key: '_events',
       value: function _events() {
-        var _this2 = this;
+        var _this = this;
 
-        this.$element.off('.abide').on('reset.zf.abide', function () {
-          _this2.resetForm();
-        }).on('submit.zf.abide', function () {
-          return _this2.validateForm();
-        });
+        this.$element.find('li').each(function () {
+          var $submenu = $(this).children('[data-submenu]');
 
-        if (this.options.validateOn === 'fieldChange') {
-          this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
-            _this2.validateInput($(e.target));
-          });
-        }
+          if ($submenu.length) {
+            $(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();
+              }
 
-        if (this.options.liveValidate) {
-          this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
-            _this2.validateInput($(e.target));
+              return;
+            }
           });
-        }
 
-        if (this.options.validateOnBlur) {
-          this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
-            _this2.validateInput($(e.target));
+          Foundation.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 ($element.children('[data-submenu]').length) {
+                _this.toggle($element.children('[data-submenu]'));
+              }
+            },
+            closeAll: function closeAll() {
+              _this.hideAll();
+            },
+            handled: function handled(preventDefault) {
+              if (preventDefault) {
+                e.preventDefault();
+              }
+              e.stopImmediatePropagation();
+            }
           });
-        }
+        }); //.attr('tabindex', 0);
       }
 
       /**
-       * Calls necessary functions to update Abide upon DOM change
-       * @private
+       * Closes all panes of the menu.
+       * @function
        */
 
     }, {
-      key: '_reflow',
-      value: function _reflow() {
-        this._init();
+      key: 'hideAll',
+      value: function hideAll() {
+        this.up(this.$element.find('[data-submenu]'));
       }
 
       /**
-       * 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
+       * Opens all panes of the menu.
+       * @function
        */
 
     }, {
-      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;
+      key: 'showAll',
+      value: function showAll() {
+        this.down(this.$element.find('[data-submenu]'));
       }
 
       /**
-       * Based on $el, get the first element with selector in this order:
-       * 1. The element's direct sibling('s).
-       * 3. The element's parent's children.
-       *
-       * 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.
+       * Toggles the open/close state of a submenu.
+       * @function
+       * @param {jQuery} $target - the submenu to toggle
        */
 
     }, {
-      key: 'findFormError',
-      value: function findFormError($el) {
-        var $error = $el.siblings(this.options.formErrorSelector);
-
-        if (!$error.length) {
-          $error = $el.parent().find(this.options.formErrorSelector);
+      key: 'toggle',
+      value: function toggle($target) {
+        if (!$target.is(':animated')) {
+          if (!$target.is(':hidden')) {
+            this.up($target);
+          } else {
+            this.down($target);
+          }
         }
-
-        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
+       * Opens the sub-menu defined by `$target`.
+       * @param {jQuery} $target - Sub-menu to open.
+       * @fires AccordionMenu#down
        */
 
     }, {
-      key: 'findLabel',
-      value: function findLabel($el) {
-        var id = $el[0].id;
-        var $label = this.$element.find('label[for="' + id + '"]');
+      key: 'down',
+      value: function down($target) {
+        var _this = this;
 
-        if (!$label.length) {
-          return $el.closest('label');
+        if (!this.options.multiOpen) {
+          this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));
         }
 
-        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 _this3 = this;
-
-        var labels = $els.map(function (i, el) {
-          var id = el.id;
-          var $label = _this3.$element.find('label[for="' + id + '"]');
+        $target.addClass('is-active').attr({ 'aria-hidden': false }).parent('.is-accordion-submenu-parent').attr({ 'aria-expanded': true });
 
-          if (!$label.length) {
-            $label = $(el).closest('label');
-          }
-          return $label[0];
+        //Foundation.Move(this.options.slideSpeed, $target, function() {
+        $target.slideDown(_this.options.slideSpeed, function () {
+          /**
+           * Fires when the menu is done opening.
+           * @event AccordionMenu#down
+           */
+          _this.$element.trigger('down.zf.accordionMenu', [$target]);
         });
-
-        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
+       * 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: 'addErrorClasses',
-      value: function addErrorClasses($el) {
-        var $label = this.findLabel($el);
-        var $formError = this.findFormError($el);
-
-        if ($label.length) {
-          $label.addClass(this.options.labelErrorClass);
-        }
+      key: 'up',
+      value: function up($target) {
+        var _this = this;
+        //Foundation.Move(this.options.slideSpeed, $target, function(){
+        $target.slideUp(_this.options.slideSpeed, function () {
+          /**
+           * Fires when the menu is done collapsing up.
+           * @event AccordionMenu#up
+           */
+          _this.$element.trigger('up.zf.accordionMenu', [$target]);
+        });
+        //});
 
-        if ($formError.length) {
-          $formError.addClass(this.options.formErrorClass);
-        }
+        var $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);
 
-        $el.addClass(this.options.inputErrorClass).attr('data-invalid', '');
+        $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', 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
-       *
+       * Destroys an instance of accordion menu.
+       * @fires AccordionMenu#destroyed
        */
 
     }, {
-      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 ($formErrors.length) {
-          $formErrors.removeClass(this.options.formErrorClass);
-        }
+      key: 'destroy',
+      value: function destroy() {
+        this.$element.find('[data-submenu]').slideDown(0).css('display', '');
+        this.$element.find('a').off('click.zf.accordionMenu');
 
-        $els.removeClass(this.options.inputErrorClass).removeAttr('data-invalid');
+        Foundation.Nest.Burn(this.$element, 'accordion');
+        Foundation.unregisterPlugin(this);
       }
+    }]);
 
-      /**
-       * 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
-       */
+    return AccordionMenu;
+  }();
 
-    }, {
-      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'));
-        }
+  AccordionMenu.defaults = {
+    /**
+     * Amount of time to animate the opening of a submenu in ms.
+     * @option
+     * @type {number}
+     * @default 250
+     */
+    slideSpeed: 250,
+    /**
+     * Allow the menu to have multiple open panes.
+     * @option
+     * @type {boolean}
+     * @default true
+     */
+    multiOpen: true
+  };
 
-        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).removeAttr('data-invalid');
-      }
-
-      /**
-       * 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="' + $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 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]').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="' + 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 _this4 = this;
-
-        required = required ? true : false;
-
-        var clear = validators.split(' ').map(function (v) {
-          return _this4.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;
-
-        $('.' + 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('').removeAttr('data-invalid');
-        $(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).removeAttr('data-invalid');
-        $(':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]);
-      }
-
-      /**
-       * 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));
-        });
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Abide;
-  }();
-
-  /**
-   * 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',
-
-    /**
-     * 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}|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})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/,
-      // 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})$/
-    },
-
-    /**
-     * 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 $('#' + el.attr('data-equalto')).val() === el.val();
-      }
-    }
-
-    // Window exports
-  };Foundation.plugin(Abide, 'Abide');
-}(jQuery);
-'use strict';
+  // Window exports
+  Foundation.plugin(AccordionMenu, 'AccordionMenu');
+}(jQuery);
+'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; }; }();
 
@@ -1264,6273 +950,485 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 !function ($) {
 
   /**
-   * Accordion module.
-   * @module foundation.accordion
+   * DropdownMenu module.
+   * @module foundation.dropdown-menu
    * @requires foundation.util.keyboard
-   * @requires foundation.util.motion
+   * @requires foundation.util.box
+   * @requires foundation.util.nest
    */
 
-  var Accordion = function () {
+  var DropdownMenu = function () {
     /**
-     * Creates a new instance of an accordion.
+     * Creates a new instance of DropdownMenu.
      * @class
-     * @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.
+     * @fires DropdownMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
      */
-    function Accordion(element, options) {
-      _classCallCheck(this, Accordion);
+    function DropdownMenu(element, options) {
+      _classCallCheck(this, DropdownMenu);
 
       this.$element = element;
-      this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);
+      this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);
 
+      Foundation.Nest.Feather(this.$element, 'dropdown');
       this._init();
 
-      Foundation.registerPlugin(this, 'Accordion');
-      Foundation.Keyboard.register('Accordion', {
-        'ENTER': 'toggle',
-        'SPACE': 'toggle',
-        'ARROW_DOWN': 'next',
-        'ARROW_UP': 'previous'
+      Foundation.registerPlugin(this, 'DropdownMenu');
+      Foundation.Keyboard.register('DropdownMenu', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close'
       });
     }
 
     /**
-     * Initializes the accordion by animating the preset active pane(s).
+     * Initializes the plugin, and calls _prepareMenu
      * @private
+     * @function
      */
 
 
-    _createClass(Accordion, [{
+    _createClass(DropdownMenu, [{
       key: '_init',
       value: function _init() {
-        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 || Foundation.GetYoDigits(6, 'accordion'),
-              linkId = el.id || id + '-label';
-
-          $el.find('a:first').attr({
-            'aria-controls': id,
-            'role': 'tab',
-            'id': linkId,
-            'aria-expanded': false,
-            'aria-selected': false
-          });
+        var subs = this.$element.find('li.is-dropdown-submenu-parent');
+        this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
 
-          $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) {
-          this.down($initActive, true);
+        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.$element.hasClass(this.options.rightClass) || this.options.alignment === 'right' || Foundation.rtl() || this.$element.parents('.top-bar-right').is('*')) {
+          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';
+      }
 
       /**
-       * Adds event handlers for items within the accordion.
+       * Adds event listeners to elements within the menu
        * @private
+       * @function
        */
 
     }, {
       key: '_events',
       value: function _events() {
-        var _this = this;
+        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', '.' + parClass),
+              hasSub = $elem.hasClass(parClass),
+              hasClicked = $elem.attr('data-is-click') === 'true',
+              $sub = $elem.children('.is-dropdown-submenu');
 
-        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) {
+          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();
-              _this.toggle($tabContent);
-            }).on('keydown.zf.accordion', function (e) {
-              Foundation.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();
-                }
-              });
-            });
+              e.stopImmediatePropagation();
+              _this._show($sub);
+              $elem.add($elem.parentsUntil(_this.$element, '.' + parClass)).attr('data-is-click', true);
+            }
           }
-        });
-      }
+        };
 
-      /**
-       * Toggles the selected content pane's open/close state.
-       * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
-       * @function
-       */
+        if (this.options.clickOpen || hasTouch) {
+          this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
+        }
 
-    }, {
-      key: 'toggle',
-      value: function toggle($target) {
-        if ($target.parent().hasClass('is-active')) {
-          this.up($target);
-        } else {
-          this.down($target);
+        // 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();
+            }
+          });
         }
-      }
-
-      /**
-       * 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 _this2 = this;
-
-        $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
-           */
-          _this2.$element.trigger('down.zf.accordion', [$target]);
-        });
-
-        $('#' + $target.attr('aria-labelledby')).attr({
-          'aria-expanded': true,
-          'aria-selected': true
-        });
-      }
-
-      /**
-       * Closes the tab defined by `$target`.
-       * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
-       * @fires Accordion#up
-       * @function
-       */
-
-    }, {
-      key: 'up',
-      value: function up($target) {
-        var $aunts = $target.parent().siblings(),
-            _this = this;
-
-        if (!this.options.allowAllClosed && !$aunts.hasClass('is-active') || !$target.parent().hasClass('is-active')) {
-          return;
-        }
-
-        // Foundation.Move(this.options.slideSpeed, $target, function(){
-        $target.slideUp(_this.options.slideSpeed, function () {
-          /**
-           * Fires when the tab is done collapsing up.
-           * @event Accordion#up
-           */
-          _this.$element.trigger('up.zf.accordion', [$target]);
-        });
-        // });
-
-        $target.attr('aria-hidden', true).parent().removeClass('is-active');
-
-        $('#' + $target.attr('aria-labelledby')).attr({
-          'aria-expanded': false,
-          'aria-selected': false
-        });
-      }
-
-      /**
-       * 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');
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Accordion;
-  }();
-
-  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
-  };
-
-  // Window exports
-  Foundation.plugin(Accordion, 'Accordion');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * AccordionMenu module.
-   * @module foundation.accordionMenu
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.motion
-   * @requires foundation.util.nest
-   */
-
-  var AccordionMenu = function () {
-    /**
-     * Creates a new instance of an accordion menu.
-     * @class
-     * @fires AccordionMenu#init
-     * @param {jQuery} element - jQuery object to make into an accordion menu.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function AccordionMenu(element, options) {
-      _classCallCheck(this, AccordionMenu);
-
-      this.$element = element;
-      this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);
-
-      Foundation.Nest.Feather(this.$element, 'accordion');
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'AccordionMenu');
-      Foundation.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
-     */
-
-
-    _createClass(AccordionMenu, [{
-      key: '_init',
-      value: function _init() {
-        this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
-        this.$element.attr({
-          'role': 'menu',
-          'aria-multiselectable': this.options.multiOpen
-        });
-
-        this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
-        this.$menuLinks.each(function () {
-          var linkId = this.id || Foundation.GetYoDigits(6, 'acc-menu-link'),
-              $elem = $(this),
-              $sub = $elem.children('[data-submenu]'),
-              subId = $sub[0].id || Foundation.GetYoDigits(6, 'acc-menu'),
-              isActive = $sub.hasClass('is-active');
-          $elem.attr({
-            'aria-controls': subId,
-            'aria-expanded': isActive,
-            'role': 'menuitem',
-            'id': linkId
-          });
-          $sub.attr({
-            'aria-labelledby': linkId,
-            'aria-hidden': !isActive,
-            'role': 'menu',
-            'id': subId
-          });
-        });
-        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) {
-            $(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;
-            }
-          });
-
-          Foundation.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 ($element.children('[data-submenu]').length) {
-                _this.toggle($element.children('[data-submenu]'));
-              }
-            },
-            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 _this = this;
-
-        if (!this.options.multiOpen) {
-          this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));
-        }
-
-        $target.addClass('is-active').attr({ 'aria-hidden': false }).parent('.is-accordion-submenu-parent').attr({ 'aria-expanded': true });
-
-        //Foundation.Move(this.options.slideSpeed, $target, function() {
-        $target.slideDown(_this.options.slideSpeed, function () {
-          /**
-           * 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
-       */
-
-    }, {
-      key: 'up',
-      value: function up($target) {
-        var _this = this;
-        //Foundation.Move(this.options.slideSpeed, $target, function(){
-        $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 $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);
-
-        $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
-      }
-
-      /**
-       * 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');
-
-        Foundation.Nest.Burn(this.$element, 'accordion');
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return AccordionMenu;
-  }();
-
-  AccordionMenu.defaults = {
-    /**
-     * Amount of time to animate the opening of a submenu in ms.
-     * @option
-     * @type {number}
-     * @default 250
-     */
-    slideSpeed: 250,
-    /**
-     * Allow the menu to have multiple open panes.
-     * @option
-     * @type {boolean}
-     * @default true
-     */
-    multiOpen: true
-  };
-
-  // Window exports
-  Foundation.plugin(AccordionMenu, 'AccordionMenu');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Drilldown module.
-   * @module foundation.drilldown
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.motion
-   * @requires foundation.util.nest
-   */
-
-  var Drilldown = function () {
-    /**
-     * Creates a new instance of a drilldown menu.
-     * @class
-     * @param {jQuery} element - jQuery object to make into an accordion menu.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function Drilldown(element, options) {
-      _classCallCheck(this, Drilldown);
-
-      this.$element = element;
-      this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);
-
-      Foundation.Nest.Feather(this.$element, 'drilldown');
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'Drilldown');
-      Foundation.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
-     */
-
-
-    _createClass(Drilldown, [{
-      key: '_init',
-      value: function _init() {
-        this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
-        this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]');
-        this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'menuitem').find('a');
-        this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || Foundation.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 class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menu-item"></li>');
-          }
-          $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
-          $link.children('[data-submenu]').attr({
-            'aria-hidden': true,
-            'tabindex': 0,
-            'role': 'menu'
-          });
-          _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');
-            });
-          }
-        });
-        this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
-      }
-
-      /**
-       * 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);
-        }
-      }
-
-      /**
-       * 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);
-        $('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;
-            }
-          });
-
-          Foundation.Keyboard.handleKey(e, 'Drilldown', {
-            next: function next() {
-              if ($element.is(_this.$submenuAnchors)) {
-                _this._show($element.parent('li'));
-                $element.parent('li').one(Foundation.transitionend($element), function () {
-                  $element.parent('li').find('ul li a').filter(_this.$menuItems).first().focus();
-                });
-                return true;
-              }
-            },
-            previous: function previous() {
-              _this._hide($element.parent('li').parent('ul'));
-              $element.parent('li').parent('ul').one(Foundation.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 (!$element.is(_this.$menuItems)) {
-                // not menu item means back button
-                _this._hide($element.parent('li').parent('ul'));
-                $element.parent('li').parent('ul').one(Foundation.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)) {
-                _this._show($element.parent('li'));
-                $element.parent('li').one(Foundation.transitionend($element), function () {
-                  $element.parent('li').find('ul li a').filter(_this.$menuItems).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(Foundation.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);
-        });
-      }
-
-      /**
-       * 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) {
-        if (this.options.autoHeight) this.$wrapper.css({ height: $elem.children('[data-submenu]').data('calcHeight') });
-        $elem.attr('aria-expanded', true);
-        $elem.children('[data-submenu]').addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
-        /**
-         * Fires when the submenu has opened.
-         * @event Drilldown#open
-         */
-        this.$element.trigger('open.zf.drilldown', [$elem]);
-      }
-    }, {
-      key: '_hide',
-
-
-      /**
-       * Hides a submenu
-       * @function
-       * @fires Drilldown#hide
-       * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
-       */
-      value: function _hide($elem) {
-        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(Foundation.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;
-        this.$submenus.add(this.$element).each(function () {
-          var numOfElems = $(this).children('li').length;
-          var height = Foundation.Box.GetDimensions(this).height;
-          maxHeight = height > maxHeight ? height : maxHeight;
-          if (_this.options.autoHeight) {
-            $(this).data('calcHeight', height);
-            if (!$(this).hasClass('is-drilldown-submenu')) result['height'] = height;
-          }
-        });
-
-        if (!this.options.autoHeight) result['min-height'] = maxHeight + 'px';
-
-        result['max-width'] = 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');
-        Foundation.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.$submenus.removeClass('drilldown-submenu-cover-previous');
-
-        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;
-          }
-        });
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Drilldown;
-  }();
-
-  Drilldown.defaults = {
-    /**
-     * 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
-  };
-
-  // Window exports
-  Foundation.plugin(Drilldown, 'Drilldown');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Dropdown module.
-   * @module foundation.dropdown
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.box
-   * @requires foundation.util.triggers
-   */
-
-  var Dropdown = function () {
-    /**
-     * Creates a new instance of a dropdown.
-     * @class
-     * @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.
-     */
-    function Dropdown(element, options) {
-      _classCallCheck(this, Dropdown);
-
-      this.$element = element;
-      this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);
-      this._init();
-
-      Foundation.registerPlugin(this, 'Dropdown');
-      Foundation.Keyboard.register('Dropdown', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ESCAPE': 'close'
-      });
-    }
-
-    /**
-     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
-     * @function
-     * @private
-     */
-
-
-    _createClass(Dropdown, [{
-      key: '_init',
-      value: function _init() {
-        var $id = this.$element.attr('id');
-
-        this.$anchor = $('[data-toggle="' + $id + '"]').length ? $('[data-toggle="' + $id + '"]') : $('[data-open="' + $id + '"]');
-        this.$anchor.attr({
-          'aria-controls': $id,
-          'data-is-focus': false,
-          'data-yeti-box': $id,
-          'aria-haspopup': true,
-          'aria-expanded': false
-
-        });
-
-        if (this.options.parentClass) {
-          this.$parent = this.$element.parents('.' + this.options.parentClass);
-        } else {
-          this.$parent = null;
-        }
-        this.options.positionClass = this.getPositionClass();
-        this.counter = 4;
-        this.usedPositions = [];
-        this.$element.attr({
-          'aria-hidden': 'true',
-          'data-yeti-box': $id,
-          'data-resize': $id,
-          'aria-labelledby': this.$anchor[0].id || Foundation.GetYoDigits(6, 'dd-anchor')
-        });
-        this._events();
-      }
-
-      /**
-       * Helper function to determine current orientation of dropdown pane.
-       * @function
-       * @returns {String} position - string value of a position class.
-       */
-
-    }, {
-      key: 'getPositionClass',
-      value: function getPositionClass() {
-        var verticalPosition = this.$element[0].className.match(/(top|left|right|bottom)/g);
-        verticalPosition = verticalPosition ? verticalPosition[0] : '';
-        var horizontalPosition = /float-(\S+)/.exec(this.$anchor[0].className);
-        horizontalPosition = horizontalPosition ? horizontalPosition[1] : '';
-        var position = horizontalPosition ? horizontalPosition + ' ' + verticalPosition : verticalPosition;
-
-        return position;
-      }
-
-      /**
-       * Adjusts the dropdown panes orientation by adding/removing positioning classes.
-       * @function
-       * @private
-       * @param {String} position - position class to remove.
-       */
-
-    }, {
-      key: '_reposition',
-      value: function _reposition(position) {
-        this.usedPositions.push(position ? position : 'bottom');
-        //default, try switching to opposite side
-        if (!position && this.usedPositions.indexOf('top') < 0) {
-          this.$element.addClass('top');
-        } else if (position === 'top' && this.usedPositions.indexOf('bottom') < 0) {
-          this.$element.removeClass(position);
-        } else if (position === 'left' && this.usedPositions.indexOf('right') < 0) {
-          this.$element.removeClass(position).addClass('right');
-        } else if (position === 'right' && this.usedPositions.indexOf('left') < 0) {
-          this.$element.removeClass(position).addClass('left');
-        }
-
-        //if default change didn't work, try bottom or left first
-        else if (!position && this.usedPositions.indexOf('top') > -1 && this.usedPositions.indexOf('left') < 0) {
-            this.$element.addClass('left');
-          } else if (position === 'top' && this.usedPositions.indexOf('bottom') > -1 && this.usedPositions.indexOf('left') < 0) {
-            this.$element.removeClass(position).addClass('left');
-          } else if (position === 'left' && this.usedPositions.indexOf('right') > -1 && this.usedPositions.indexOf('bottom') < 0) {
-            this.$element.removeClass(position);
-          } else if (position === 'right' && this.usedPositions.indexOf('left') > -1 && this.usedPositions.indexOf('bottom') < 0) {
-            this.$element.removeClass(position);
-          }
-          //if nothing cleared, set to bottom
-          else {
-              this.$element.removeClass(position);
-            }
-        this.classChanged = true;
-        this.counter--;
-      }
-
-      /**
-       * Sets the position and orientation of the dropdown pane, checks for collisions.
-       * Recursively calls itself if a collision is detected, with a new position class.
-       * @function
-       * @private
-       */
-
-    }, {
-      key: '_setPosition',
-      value: function _setPosition() {
-        if (this.$anchor.attr('aria-expanded') === 'false') {
-          return false;
-        }
-        var position = this.getPositionClass(),
-            $eleDims = Foundation.Box.GetDimensions(this.$element),
-            $anchorDims = Foundation.Box.GetDimensions(this.$anchor),
-            _this = this,
-            direction = position === 'left' ? 'left' : position === 'right' ? 'left' : 'top',
-            param = direction === 'top' ? 'height' : 'width',
-            offset = param === 'height' ? this.options.vOffset : this.options.hOffset;
-
-        if ($eleDims.width >= $eleDims.windowDims.width || !this.counter && !Foundation.Box.ImNotTouchingYou(this.$element, this.$parent)) {
-          var newWidth = $eleDims.windowDims.width,
-              parentHOffset = 0;
-          if (this.$parent) {
-            var $parentDims = Foundation.Box.GetDimensions(this.$parent),
-                parentHOffset = $parentDims.offset.left;
-            if ($parentDims.width < newWidth) {
-              newWidth = $parentDims.width;
-            }
-          }
-
-          this.$element.offset(Foundation.Box.GetOffsets(this.$element, this.$anchor, 'center bottom', this.options.vOffset, this.options.hOffset + parentHOffset, true)).css({
-            'width': newWidth - this.options.hOffset * 2,
-            'height': 'auto'
-          });
-          this.classChanged = true;
-          return false;
-        }
-
-        this.$element.offset(Foundation.Box.GetOffsets(this.$element, this.$anchor, position, this.options.vOffset, this.options.hOffset));
-
-        while (!Foundation.Box.ImNotTouchingYou(this.$element, this.$parent, true) && this.counter) {
-          this._reposition(position);
-          this._setPosition();
-        }
-      }
-
-      /**
-       * 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)
-        });
-
-        if (this.options.hover) {
-          this.$anchor.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
-            var bodyData = $('body').data();
-            if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
-              clearTimeout(_this.timeout);
-              _this.timeout = setTimeout(function () {
-                _this.open();
-                _this.$anchor.data('hover', true);
-              }, _this.options.hoverDelay);
-            }
-          }).on('mouseleave.zf.dropdown', function () {
-            clearTimeout(_this.timeout);
-            _this.timeout = setTimeout(function () {
-              _this.close();
-              _this.$anchor.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.$anchor.data('hover', false);
-              }, _this.options.hoverDelay);
-            });
-          }
-        }
-        this.$anchor.add(this.$element).on('keydown.zf.dropdown', function (e) {
-
-          var $target = $(this),
-              visibleFocusableElements = Foundation.Keyboard.findFocusable(_this.$element);
-
-          Foundation.Keyboard.handleKey(e, 'Dropdown', {
-            open: function open() {
-              if ($target.is(_this.$anchor)) {
-                _this.open();
-                _this.$element.attr('tabindex', -1).focus();
-                e.preventDefault();
-              }
-            },
-            close: function close() {
-              _this.close();
-              _this.$anchor.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.$anchor.is(e.target) || _this.$anchor.find(e.target).length) {
-            return;
-          }
-          if (_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.$anchor.addClass('hover').attr({ 'aria-expanded': true });
-        // this.$element/*.show()*/;
-        this._setPosition();
-        this.$element.addClass('is-open').attr({ 'aria-hidden': false });
-
-        if (this.options.autoFocus) {
-          var $focusable = Foundation.Keyboard.findFocusable(this.$element);
-          if ($focusable.length) {
-            $focusable.eq(0).focus();
-          }
-        }
-
-        if (this.options.closeOnClick) {
-          this._addBodyHandler();
-        }
-
-        if (this.options.trapFocus) {
-          Foundation.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.$anchor.removeClass('hover').attr('aria-expanded', false);
-
-        if (this.classChanged) {
-          var curPositionClass = this.getPositionClass();
-          if (curPositionClass) {
-            this.$element.removeClass(curPositionClass);
-          }
-          this.$element.addClass(this.options.positionClass
-          /*.hide()*/).css({ height: '', width: '' });
-          this.classChanged = false;
-          this.counter = 4;
-          this.usedPositions.length = 0;
-        }
-        /**
-         * Fires once the dropdown is no longer visible.
-         * @event Dropdown#hide
-         */
-        this.$element.trigger('hide.zf.dropdown', [this.$element]);
-
-        if (this.options.trapFocus) {
-          Foundation.Keyboard.releaseFocus(this.$element);
-        }
-      }
-
-      /**
-       * Toggles the dropdown pane's visibility.
-       * @function
-       */
-
-    }, {
-      key: 'toggle',
-      value: function toggle() {
-        if (this.$element.hasClass('is-open')) {
-          if (this.$anchor.data('hover')) return;
-          this.close();
-        } else {
-          this.open();
-        }
-      }
-
-      /**
-       * Destroys the dropdown.
-       * @function
-       */
-
-    }, {
-      key: 'destroy',
-      value: function destroy() {
-        this.$element.off('.zf.trigger').hide();
-        this.$anchor.off('.zf.dropdown');
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return 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 1
-     */
-    vOffset: 1,
-    /**
-     * Number of pixels between the dropdown pane and the triggering element on open.
-     * @option
-     * @type {number}
-     * @default 1
-     */
-    hOffset: 1,
-    /**
-     * Class applied to adjust open position. JS will test and fill this in.
-     * @option
-     * @type {string}
-     * @default ''
-     */
-    positionClass: '',
-    /**
-     * 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
-
-    // Window exports
-  };Foundation.plugin(Dropdown, 'Dropdown');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * DropdownMenu module.
-   * @module foundation.dropdown-menu
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.box
-   * @requires foundation.util.nest
-   */
-
-  var DropdownMenu = function () {
-    /**
-     * Creates a new instance of DropdownMenu.
-     * @class
-     * @fires DropdownMenu#init
-     * @param {jQuery} element - jQuery object to make into a dropdown menu.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function DropdownMenu(element, options) {
-      _classCallCheck(this, DropdownMenu);
-
-      this.$element = element;
-      this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);
-
-      Foundation.Nest.Feather(this.$element, 'dropdown');
-      this._init();
-
-      Foundation.registerPlugin(this, 'DropdownMenu');
-      Foundation.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
-     */
-
-
-    _createClass(DropdownMenu, [{
-      key: '_init',
-      value: function _init() {
-        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.$element.hasClass(this.options.rightClass) || this.options.alignment === 'right' || Foundation.rtl() || this.$element.parents('.top-bar-right').is('*')) {
-          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';
-      }
-
-      /**
-       * 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', '.' + 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', 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() {
-            if (!$element.is(':last-child')) {
-              $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.find('a:first').focus(); // focus to first element
-              e.preventDefault();
-            },
-            handled: function handled() {
-              e.stopImmediatePropagation();
-            }
-          };
-
-          if (isTab) {
-            if (_this._isVertical()) {
-              // vertical menu
-              if (Foundation.rtl()) {
-                // 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 (Foundation.rtl()) {
-                // 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 (Foundation.rtl()) {
-              // 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
-              });
-            }
-          }
-          Foundation.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 = Foundation.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 = Foundation.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
-       */
-
-    }, {
-      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;
-        }
-        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
-       */
-
-    }, {
-      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');
-        Foundation.Nest.Burn(this.$element, 'dropdown');
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return DropdownMenu;
-  }();
-
-  /**
-   * 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 `'left'` or `'right'`.
-     * @option
-     * @type {string}
-     * @default 'left'
-     */
-    alignment: 'left',
-    /**
-     * 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
-  };
-
-  // Window exports
-  Foundation.plugin(DropdownMenu, 'DropdownMenu');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Equalizer module.
-   * @module foundation.equalizer
-   * @requires foundation.util.mediaQuery
-   * @requires foundation.util.timerAndImageLoader if equalizer contains images
-   */
-
-  var Equalizer = function () {
-    /**
-     * Creates a new instance of Equalizer.
-     * @class
-     * @fires Equalizer#init
-     * @param {Object} element - jQuery object to add the trigger to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function Equalizer(element, options) {
-      _classCallCheck(this, Equalizer);
-
-      this.$element = element;
-      this.options = $.extend({}, Equalizer.defaults, this.$element.data(), options);
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'Equalizer');
-    }
-
-    /**
-     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
-     * @private
-     */
-
-
-    _createClass(Equalizer, [{
-      key: '_init',
-      value: function _init() {
-        var eqId = this.$element.attr('data-equalizer') || '';
-        var $watched = this.$element.find('[data-equalizer-watch="' + eqId + '"]');
-
-        this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
-        this.$element.attr('data-resize', eqId || Foundation.GetYoDigits(6, 'eq'));
-        this.$element.attr('data-mutate', eqId || Foundation.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 (tooSmall !== undefined && tooSmall === false || tooSmall === undefined) {
-          if (imgs.length) {
-            Foundation.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() {
-        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',
-      value: function _checkMQ() {
-        var tooSmall = !Foundation.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');
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Equalizer;
-  }();
-
-  /**
-   * 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: ''
-  };
-
-  // Window exports
-  Foundation.plugin(Equalizer, 'Equalizer');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Interchange module.
-   * @module foundation.interchange
-   * @requires foundation.util.mediaQuery
-   * @requires foundation.util.timerAndImageLoader
-   */
-
-  var Interchange = function () {
-    /**
-     * Creates a new instance of Interchange.
-     * @class
-     * @fires Interchange#init
-     * @param {Object} element - jQuery object to add the trigger to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function Interchange(element, options) {
-      _classCallCheck(this, Interchange);
-
-      this.$element = element;
-      this.options = $.extend({}, Interchange.defaults, options);
-      this.rules = [];
-      this.currentPath = '';
-
-      this._init();
-      this._events();
-
-      Foundation.registerPlugin(this, 'Interchange');
-    }
-
-    /**
-     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
-     * @function
-     * @private
-     */
-
-
-    _createClass(Interchange, [{
-      key: '_init',
-      value: function _init() {
-        this._addBreakpoints();
-        this._generateRules();
-        this._reflow();
-      }
-
-      /**
-       * Initializes events for Interchange.
-       * @function
-       * @private
-       */
-
-    }, {
-      key: '_events',
-      value: function _events() {
-        var _this2 = this;
-
-        $(window).on('resize.zf.interchange', Foundation.util.throttle(function () {
-          _this2._reflow();
-        }, 50));
-      }
-
-      /**
-       * 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 Foundation.MediaQuery.queries) {
-          if (Foundation.MediaQuery.queries.hasOwnProperty(i)) {
-            var query = Foundation.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)) {
-            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() {
-        //TODO this.
-      }
-    }]);
-
-    return Interchange;
-  }();
-
-  /**
-   * 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)'
-  };
-
-  // Window exports
-  Foundation.plugin(Interchange, 'Interchange');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Magellan module.
-   * @module foundation.magellan
-   */
-
-  var Magellan = function () {
-    /**
-     * Creates a new instance of Magellan.
-     * @class
-     * @fires Magellan#init
-     * @param {Object} element - jQuery object to add the trigger to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function Magellan(element, options) {
-      _classCallCheck(this, Magellan);
-
-      this.$element = element;
-      this.options = $.extend({}, Magellan.defaults, this.$element.data(), options);
-
-      this._init();
-      this.calcPoints();
-
-      Foundation.registerPlugin(this, 'Magellan');
-    }
-
-    /**
-     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
-     * @private
-     */
-
-
-    _createClass(Magellan, [{
-      key: '_init',
-      value: function _init() {
-        var id = this.$element[0].id || Foundation.GetYoDigits(6, 'magellan');
-        var _this = this;
-        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.$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);
-        });
-        $(window).on('popstate', function (e) {
-          if (_this.options.deepLinking) {
-            _this.scrollToLoc(window.location.hash);
-          }
-        });
-      }
-
-      /**
-       * 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) {
-        // Do nothing if target does not exist to prevent errors
-        if (!$(loc).length) {
-          return false;
-        }
-        this._inTransition = true;
-        var _this = this,
-            scrollPos = Math.round($(loc).offset().top - this.options.threshold / 2 - this.options.barOffset);
-
-        $('html, body').stop(true).animate({ scrollTop: scrollPos }, this.options.animationDuration, this.options.animationEasing, function () {
-          _this._inTransition = false;_this._updateActive();
-        });
-      }
-
-      /**
-       * 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*/{
-        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.barOffset <= winPos : p - _this.options.barOffset - _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',
-      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, '');
-        }
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Magellan;
-  }();
-
-  /**
-   * 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 'active'
-     */
-    activeClass: '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
-     */
-    barOffset: 0
-
-    // Window exports
-  };Foundation.plugin(Magellan, 'Magellan');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * OffCanvas module.
-   * @module foundation.offcanvas
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.mediaQuery
-   * @requires foundation.util.triggers
-   * @requires foundation.util.motion
-   */
-
-  var OffCanvas = function () {
-    /**
-     * Creates a new instance of an off-canvas wrapper.
-     * @class
-     * @fires OffCanvas#init
-     * @param {Object} element - jQuery object to initialize.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function OffCanvas(element, options) {
-      _classCallCheck(this, OffCanvas);
-
-      this.$element = element;
-      this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);
-      this.$lastTrigger = $();
-      this.$triggers = $();
-
-      this._init();
-      this._events();
-
-      Foundation.registerPlugin(this, 'OffCanvas');
-      Foundation.Keyboard.register('OffCanvas', {
-        'ESCAPE': 'close'
-      });
-    }
-
-    /**
-     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
-     * @function
-     * @private
-     */
-
-
-    _createClass(OffCanvas, [{
-      key: '_init',
-      value: function _init() {
-        var id = this.$element.attr('id');
-
-        this.$element.attr('aria-hidden', 'true');
-
-        this.$element.addClass('is-transition-' + this.options.transition);
-
-        // 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);
-
-        // 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') {
-            $('body').append(this.$overlay);
-          } else {
-            this.$element.siblings('[data-off-canvas-content]').append(this.$overlay);
-          }
-        }
-
-        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();
-        }
-        if (!this.options.transitionTime === true) {
-          this.options.transitionTime = parseFloat(window.getComputedStyle($('[data-off-canvas]')[0]).transitionDuration) * 1000;
-        }
-      }
-
-      /**
-       * 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 : $('[data-off-canvas-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;
-
-        $(window).on('changed.zf.mediaquery', function () {
-          if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {
-            _this.reveal(true);
-          } else {
-            _this.reveal(false);
-          }
-        }).one('load.zf.offcanvas', function () {
-          if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {
-            _this.reveal(true);
-          }
-        });
-      }
-
-      /**
-       * 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) {
-        var $closer = this.$element.find('[data-close]');
-        if (isRevealed) {
-          this.close();
-          this.isRevealed = true;
-          this.$element.attr('aria-hidden', 'false');
-          this.$element.off('open.zf.trigger toggle.zf.trigger');
-          if ($closer.length) {
-            $closer.hide();
-          }
-        } else {
-          this.isRevealed = false;
-          this.$element.attr('aria-hidden', 'true');
-          this.$element.on({
-            'open.zf.trigger': this.open.bind(this),
-            'toggle.zf.trigger': this.toggle.bind(this)
-          });
-          if ($closer.length) {
-            $closer.show();
-          }
-        }
-      }
-
-      /**
-       * 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
-       */
-
-    }, {
-      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);
-        }
-
-        /**
-         * Fires when the off-canvas menu opens.
-         * @event OffCanvas#opened
-         */
-        _this.$element.addClass('is-open');
-
-        this.$triggers.attr('aria-expanded', 'true');
-        this.$element.attr('aria-hidden', 'false').trigger('opened.zf.offcanvas');
-
-        // 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(Foundation.transitionend(this.$element), function () {
-            _this.$element.find('a, button').eq(0).focus();
-          });
-        }
-
-        if (this.options.trapFocus === true) {
-          this.$element.siblings('[data-off-canvas-content]').attr('tabindex', '-1');
-          Foundation.Keyboard.trapFocus(this.$element);
-        }
-      }
-
-      /**
-       * 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');
-
-        // 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.$element.siblings('[data-off-canvas-content]').removeAttr('tabindex');
-          Foundation.Keyboard.releaseFocus(this.$element);
-        }
-      }
-
-      /**
-       * 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 _this2 = this;
-
-        Foundation.Keyboard.handleKey(e, 'OffCanvas', {
-          close: function close() {
-            _this2.close();
-            _this2.$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');
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return OffCanvas;
-  }();
-
-  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,
-
-    /**
-     * 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 0
-     */
-    transitionTime: 0,
-
-    /**
-     * 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
-
-    // Window exports
-  };Foundation.plugin(OffCanvas, 'OffCanvas');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Orbit module.
-   * @module foundation.orbit
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.motion
-   * @requires foundation.util.timerAndImageLoader
-   * @requires foundation.util.touch
-   */
-
-  var Orbit = function () {
-    /**
-    * Creates a new instance of an orbit carousel.
-    * @class
-    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
-    * @param {Object} options - Overrides to the default plugin settings.
-    */
-    function Orbit(element, options) {
-      _classCallCheck(this, Orbit);
-
-      this.$element = element;
-      this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'Orbit');
-      Foundation.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
-    */
-
-
-    _createClass(Orbit, [{
-      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);
-
-        var $images = this.$element.find('img'),
-            initActive = this.$slides.filter('.is-active'),
-            id = this.$element[0].id || Foundation.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) {
-          Foundation.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('.' + 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 Foundation.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() {
-        var _this = 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.
-      */
-
-    }, {
-      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);
-
-          if (_this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
-            //if not the active slide, set css position and display property
-            $(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.
-        }
-      }
-
-      /**
-      * 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('.' + 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
-              Foundation.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 - 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
-      */
-
-    }, {
-      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('.' + 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')) {
-            Foundation.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.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();
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Orbit;
-  }();
-
-  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
-  };
-
-  // Window exports
-  Foundation.plugin(Orbit, 'Orbit');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * ResponsiveMenu module.
-   * @module foundation.responsiveMenu
-   * @requires foundation.util.triggers
-   * @requires foundation.util.mediaQuery
-   */
-
-  var ResponsiveMenu = function () {
-    /**
-     * Creates a new instance of a responsive menu.
-     * @class
-     * @fires ResponsiveMenu#init
-     * @param {jQuery} element - jQuery object to make into a dropdown menu.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function ResponsiveMenu(element, options) {
-      _classCallCheck(this, ResponsiveMenu);
-
-      this.$element = $(element);
-      this.rules = this.$element.data('responsive-menu');
-      this.currentMq = null;
-      this.currentPlugin = null;
-
-      this._init();
-      this._events();
-
-      Foundation.registerPlugin(this, 'ResponsiveMenu');
-    }
-
-    /**
-     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
-     * @function
-     * @private
-     */
-
-
-    _createClass(ResponsiveMenu, [{
-      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;
-        }
-
-        if (!$.isEmptyObject(this.rules)) {
-          this._checkMediaQueries();
-        }
-        // Add data-mutate since children may need it.
-        this.$element.attr('data-mutate', this.$element.attr('data-mutate') || Foundation.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 (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) 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');
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return ResponsiveMenu;
-  }();
-
-  ResponsiveMenu.defaults = {};
-
-  // The plugin matches the plugin classes with these plugin instances.
-  var MenuPlugins = {
-    dropdown: {
-      cssClass: 'dropdown',
-      plugin: Foundation._plugins['dropdown-menu'] || null
-    },
-    drilldown: {
-      cssClass: 'drilldown',
-      plugin: Foundation._plugins['drilldown'] || null
-    },
-    accordion: {
-      cssClass: 'accordion-menu',
-      plugin: Foundation._plugins['accordion-menu'] || null
-    }
-  };
-
-  // Window exports
-  Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * ResponsiveToggle module.
-   * @module foundation.responsiveToggle
-   * @requires foundation.util.mediaQuery
-   */
-
-  var ResponsiveToggle = function () {
-    /**
-     * Creates a new instance of Tab Bar.
-     * @class
-     * @fires ResponsiveToggle#init
-     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function ResponsiveToggle(element, options) {
-      _classCallCheck(this, ResponsiveToggle);
-
-      this.$element = $(element);
-      this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
-
-      this._init();
-      this._events();
-
-      Foundation.registerPlugin(this, 'ResponsiveToggle');
-    }
-
-    /**
-     * Initializes the tab bar by finding the target element, toggling element, and running update().
-     * @function
-     * @private
-     */
-
-
-    _createClass(ResponsiveToggle, [{
-      key: '_init',
-      value: function _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) {
-          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() {
-        var _this = this;
-
-        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 (!Foundation.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 (!Foundation.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.Motion.animateIn(this.$targetMenu, this.animationIn, function () {
-                _this2.$element.trigger('toggled.zf.responsiveToggle');
-                _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
-              });
-            } else {
-              Foundation.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);
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return ResponsiveToggle;
-  }();
-
-  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
-  };
-
-  // Window exports
-  Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Reveal module.
-   * @module foundation.reveal
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.box
-   * @requires foundation.util.triggers
-   * @requires foundation.util.mediaQuery
-   * @requires foundation.util.motion if using animations
-   */
-
-  var Reveal = function () {
-    /**
-     * Creates a new instance of Reveal.
-     * @class
-     * @param {jQuery} element - jQuery object to use for the modal.
-     * @param {Object} options - optional parameters.
-     */
-    function Reveal(element, options) {
-      _classCallCheck(this, Reveal);
-
-      this.$element = element;
-      this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);
-      this._init();
-
-      Foundation.registerPlugin(this, 'Reveal');
-      Foundation.Keyboard.register('Reveal', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ESCAPE': 'close'
-      });
-    }
-
-    /**
-     * Initializes the modal by adding the overlay and close buttons, (if selected).
-     * @private
-     */
-
-
-    _createClass(Reveal, [{
-      key: '_init',
-      value: function _init() {
-        this.id = this.$element.attr('id');
-        this.isActive = false;
-        this.cached = { mq: Foundation.MediaQuery.current };
-        this.isMobile = mobileSniff();
-
-        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) {
-          $(window).one('load.zf.reveal', this.open.bind(this));
-        }
-      }
-
-      /**
-       * Creates an overlay div to display behind the modal.
-       * @private
-       */
-
-    }, {
-      key: '_makeOverlay',
-      value: function _makeOverlay() {
-        return $('<div></div>').addClass('reveal-overlay').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;
-        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' });
-        }
-      }
-
-      /**
-       * Adds event handlers for the modal.
-       * @private
-       */
-
-    }, {
-      key: '_events',
-      value: function _events() {
-        var _this2 = 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 _this2.close.apply(_this2);
-            }
-          },
-          'toggle.zf.trigger': this.toggle.bind(this),
-          'resizeme.zf.trigger': function resizemeZfTrigger() {
-            _this._updatePosition();
-          }
-        });
-
-        if (this.$anchor.length) {
-          this.$anchor.on('keydown.zf.reveal', function (e) {
-            if (e.which === 13 || e.which === 32) {
-              e.stopPropagation();
-              e.preventDefault();
-              _this.open();
-            }
-          });
-        }
-
-        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('popstate.zf.reveal:' + this.id, this._handleState.bind(this));
-        }
-      }
-
-      /**
-       * Handles modal methods on back/forward button clicks or any other event that triggers popstate.
-       * @private
-       */
-
-    }, {
-      key: '_handleState',
-      value: function _handleState(e) {
-        if (window.location.hash === '#' + this.id && !this.isActive) {
-          this.open();
-        } else {
-          this.close();
-        }
-      }
-
-      /**
-       * 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 _this3 = this;
-
-        if (this.options.deepLink) {
-          var hash = '#' + this.id;
-
-          if (window.history.pushState) {
-            window.history.pushState(null, null, hash);
-          } else {
-            window.location.hash = hash;
-          }
-        }
-
-        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);
-        }
-
-        var _this = this;
-
-        function addRevealOpenClasses() {
-          if (_this.isMobile) {
-            if (!_this.originalScrollPos) {
-              _this.originalScrollPos = window.pageYOffset;
-            }
-            $('html, body').addClass('is-reveal-open');
-          } else {
-            $('body').addClass('is-reveal-open');
-          }
-        }
-        // Motion UI method of reveal
-        if (this.options.animationIn) {
-          var afterAnimation = function afterAnimation() {
-            _this.$element.attr({
-              'aria-hidden': false,
-              'tabindex': -1
-            }).focus();
-            addRevealOpenClasses();
-            Foundation.Keyboard.trapFocus(_this.$element);
-          };
-
-          if (this.options.overlay) {
-            Foundation.Motion.animateIn(this.$overlay, 'fade-in');
-          }
-          Foundation.Motion.animateIn(this.$element, this.options.animationIn, function () {
-            if (_this3.$element) {
-              // protect against object having been removed
-              _this3.focusableElements = Foundation.Keyboard.findFocusable(_this3.$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();
-        Foundation.Keyboard.trapFocus(this.$element);
-
-        /**
-         * Fires when the modal has successfully opened.
-         * @event Reveal#open
-         */
-        this.$element.trigger('open.zf.reveal');
-
-        addRevealOpenClasses();
-
-        setTimeout(function () {
-          _this3._extraHandlers();
-        }, 0);
-      }
-
-      /**
-       * Adds extra event handlers for the body and window if necessary.
-       * @private
-       */
-
-    }, {
-      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 = Foundation.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) {
-            Foundation.Keyboard.handleKey(e, 'Reveal', {
-              close: function close() {
-                if (_this.options.closeOnEsc) {
-                  _this.close();
-                  _this.$anchor.focus();
-                }
-              }
-            });
-          });
-        }
-
-        // lock focus within modal while tabbing
-        this.$element.on('keydown.zf.reveal', function (e) {
-          var $target = $(this);
-          // handle keyboard event with keyboard util
-          Foundation.Keyboard.handleKey(e, 'Reveal', {
-            open: function open() {
-              if (_this.$element.find(':focus').is(_this.$element.find('[data-close]'))) {
-                setTimeout(function () {
-                  // set focus back to anchor if close button has been activated
-                  _this.$anchor.focus();
-                }, 1);
-              } else if ($target.is(_this.focusableElements)) {
-                // dont't trigger if acual element has focus (i.e. inputs, links, ...)
-                _this.open();
-              }
-            },
-            close: function close() {
-              if (_this.options.closeOnEsc) {
-                _this.close();
-                _this.$anchor.focus();
-              }
-            },
-            handled: function handled(preventDefault) {
-              if (preventDefault) {
-                e.preventDefault();
-              }
-            }
-          });
-        });
-      }
-
-      /**
-       * 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) {
-            Foundation.Motion.animateOut(this.$overlay, 'fade-out', finishUp);
-          } else {
-            finishUp();
-          }
-
-          Foundation.Motion.animateOut(this.$element, this.options.animationOut);
-        }
-        // jQuery method of hiding
-        else {
-            if (this.options.overlay) {
-              this.$overlay.hide(0, finishUp);
-            } else {
-              finishUp();
-            }
-
-            this.$element.hide(this.options.hideDelay);
-          }
-
-        // 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() {
-          if (_this.isMobile) {
-            $('html, body').removeClass('is-reveal-open');
-            if (_this.originalScrollPos) {
-              $('body').scrollTop(_this.originalScrollPos);
-              _this.originalScrollPos = null;
-            }
-          } else {
-            $('body').removeClass('is-reveal-open');
-          }
-
-          Foundation.Keyboard.releaseFocus(_this.$element);
-
-          _this.$element.attr('aria-hidden', true);
-
-          /**
-          * 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) {
-          if (window.history.replaceState) {
-            window.history.replaceState('', document.title, window.location.href.replace('#' + this.id, ''));
-          } else {
-            window.location.hash = '';
-          }
-        }
-      }
-
-      /**
-       * 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:' + this.id);
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return 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,
-    /**
-     * 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
-     * @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,
-    /**
-     * 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.
-     * @option
-     * @type {boolean}
-     * @default false
-     */
-    deepLink: false,
-    /**
-    * Allows the modal to append to custom div.
-    * @option
-    * @type {string}
-    * @default "body"
-    */
-    appendTo: "body"
-
-  };
-
-  // Window exports
-  Foundation.plugin(Reveal, 'Reveal');
-
-  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();
-  }
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Slider module.
-   * @module foundation.slider
-   * @requires foundation.util.motion
-   * @requires foundation.util.triggers
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.touch
-   */
-
-  var Slider = function () {
-    /**
-     * Creates a new instance of a slider control.
-     * @class
-     * @param {jQuery} element - jQuery object to make into a slider control.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function Slider(element, options) {
-      _classCallCheck(this, Slider);
-
-      this.$element = element;
-      this.options = $.extend({}, Slider.defaults, this.$element.data(), options);
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'Slider');
-      Foundation.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'
-        },
-        '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
-     */
-
-
-    _createClass(Slider, [{
-      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) : $('#' + 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 = $().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);
-          }
-          isDbl = true;
-
-          // this.$handle.triggerHandler('click.zf.slider');
-          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 + 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;
-
-        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;
-          }
-        }
-
-        //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;
-        }
-
-        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;
-
-        Foundation.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.
-       */
-
-    }, {
-      key: '_setInitAttr',
-      value: function _setInitAttr(idx) {
-        var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
-        var id = this.inputs.eq(idx).attr('id') || Foundation.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 (Foundation.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;
-        }
-        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.
-       */
-
-    }, {
-      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($(this));
-          _this._handleEvent(e, _this.handles.eq(idx), $(this).val());
-        });
-
-        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
-          Foundation.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;
-            },
-            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);
-
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return Slider;
-  }();
-
-  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);
-  }
-
-  // Window exports
-  Foundation.plugin(Slider, 'Slider');
-}(jQuery);
-'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 ($) {
-
-  /**
-   * Sticky module.
-   * @module foundation.sticky
-   * @requires foundation.util.triggers
-   * @requires foundation.util.mediaQuery
-   */
-
-  var Sticky = function () {
-    /**
-     * Creates a new instance of a sticky thing.
-     * @class
-     * @param {jQuery} element - jQuery object to make sticky.
-     * @param {Object} options - options object passed when creating the element programmatically.
-     */
-    function Sticky(element, options) {
-      _classCallCheck(this, Sticky);
-
-      this.$element = element;
-      this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);
-
-      this._init();
-
-      Foundation.registerPlugin(this, 'Sticky');
-    }
-
-    /**
-     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
-     * @function
-     * @private
-     */
 
+        if (!this.options.disableHover) {
+          this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
+            var $elem = $(this),
+                hasSub = $elem.hasClass(parClass);
 
-    _createClass(Sticky, [{
-      key: '_init',
-      value: function _init() {
-        var $parent = this.$element.parent('[data-sticky-container]'),
-            id = this.$element[0].id || Foundation.GetYoDigits(6, 'sticky'),
-            _this = this;
+            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 = $(this),
+                hasSub = $elem.hasClass(parClass);
+            if (hasSub && _this.options.autoclose) {
+              if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
+                return false;
+              }
 
-        if (!$parent.length) {
-          this.wasWrapped = true;
+              clearTimeout($elem.data('_delay'));
+              $elem.data('_delay', setTimeout(function () {
+                _this._hide($elem);
+              }, _this.options.closingTime));
+            }
+          });
         }
-        this.$container = $parent.length ? $parent : $(this.options.container).wrapInner(this.$element);
-        this.$container.addClass(this.options.containerClass);
-
-        this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id });
-
-        this.scrollCount = this.options.checkEvery;
-        this.isStuck = false;
-        $(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 = $('#' + _this.options.anchor);
-          } else {
-            _this._parsePoints();
-          }
+        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;
 
-          _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);
+          $elements.each(function (i) {
+            if ($(this).is($element)) {
+              $prevElement = $elements.eq(i - 1);
+              $nextElement = $elements.eq(i + 1);
+              return;
             }
           });
-          _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 = $('#' + place[0]);
-
-            pt = anchor.offset().top;
-            if (place[1] && place[1].toLowerCase() === 'bottom') {
-              pt += anchor[0].getBoundingClientRect().height;
+          var nextSibling = function nextSibling() {
+            if (!$element.is(':last-child')) {
+              $nextElement.children('a:first').focus();
+              e.preventDefault();
             }
-          }
-          breaks[i] = pt;
-        }
-
-        this.points = breaks;
-        return;
-      }
-
-      /**
-       * Adds event handlers for the scrolling element.
-       * @private
-       * @param {String} id - psuedo-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;
-          $(window).off(scrollListener).on(scrollListener, function (e) {
-            if (_this.scrollCount === 0) {
-              _this.scrollCount = _this.options.checkEvery;
-              _this._setSizes(function () {
-                _this._calc(false, window.pageYOffset);
-              });
+          },
+              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 {
-              _this.scrollCount--;
-              _this._calc(false, window.pageYOffset);
+              return;
             }
-          });
-        }
-
-        this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
-          _this._setSizes(function () {
-            _this._calc(false);
-            if (_this.canStick) {
-              if (!_this.isOn) {
-                _this._events(id);
-              }
-            } else if (_this.isOn) {
-              _this._pauseListeners(scrollListener);
+          },
+              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.find('a:first').focus(); // focus to first element
+              e.preventDefault();
+            },
+            handled: function handled() {
+              e.stopImmediatePropagation();
             }
-          });
-        });
-      }
-
-      /**
-       * 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();
+          if (isTab) {
+            if (_this._isVertical()) {
+              // vertical menu
+              if (Foundation.rtl()) {
+                // 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 (Foundation.rtl()) {
+                // 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 {
-            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] = 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();
+            // not tabs -> one sub
+            if (Foundation.rtl()) {
+              // 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
+              });
+            }
+          }
+          Foundation.Keyboard.handleKey(e, 'DropdownMenu', functions);
         });
       }
 
       /**
-       * 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
+       * Adds an event handler to the body to close any dropdowns on a click.
+       * @function
        * @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;
-        }
+      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.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);
+          _this._hide();
+          $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+        });
       }
 
       /**
-       * Sets the $element and $container sizes for plugin.
-       * Calls `_setBreakPoints`.
-       * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
+       * 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: '_setSizes',
-      value: function _setSizes(cb) {
-        this.canStick = Foundation.MediaQuery.is(this.options.stickyOn);
-        if (!this.canStick) {
-          if (cb && typeof cb === 'function') {
-            cb();
+      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 = Foundation.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 = Foundation.Box.ImNotTouchingYou($sub, null, true);
+          if (!clear) {
+            $parentLi.removeClass('opens-' + this.options.alignment).addClass('opens-inner');
           }
+          this.changed = 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();
-        }
-
-        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);
-          }
+        $sub.css('visibility', '');
+        if (this.options.closeOnClick) {
+          this._addBodyHandler();
         }
-
-        this._setBreakPoints(newContainerHeight, function () {
-          if (cb && typeof cb === 'function') {
-            cb();
-          }
-        });
+        /**
+         * Fires when the new dropdown pane is visible.
+         * @event DropdownMenu#show
+         */
+        this.$element.trigger('show.zf.dropdownmenu', [$sub]);
       }
 
       /**
-       * 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.
+       * 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: '_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;
+      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 {
-          //this would be the stickTo: both option... tricky
+          $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');
 
-        this.topPoint = topPoint;
-        this.bottomPoint = bottomPoint;
+          $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
 
-        if (cb && typeof cb === 'function') {
-          cb();
+          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 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.
+       * Destroys the plugin.
        * @function
        */
 
     }, {
       key: 'destroy',
       value: 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');
-        if (this.$anchor && this.$anchor.length) {
-          this.$anchor.off('change.zf.sticky');
-        }
-        $(window).off(this.scrollListener);
-
-        if (this.wasWrapped) {
-          this.$element.unwrap();
-        } else {
-          this.$container.removeClass(this.options.containerClass).css({
-            height: ''
-          });
-        }
+        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');
+        Foundation.Nest.Burn(this.$element, 'dropdown');
         Foundation.unregisterPlugin(this);
       }
     }]);
 
-    return Sticky;
+    return DropdownMenu;
   }();
 
-  Sticky.defaults = {
+  /**
+   * Default settings for plugin
+   */
+
+
+  DropdownMenu.defaults = {
     /**
-     * Customizable container template. Add your own classes for styling and sizing.
+     * Disallows hover events from opening submenus
      * @option
-     * @type {string}
-     * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
+     * @type {boolean}
+     * @default false
      */
-    container: '<div data-sticky-container></div>',
+    disableHover: false,
     /**
-     * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
+     * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
      * @option
-     * @type {string}
-     * @default 'top'
+     * @type {boolean}
+     * @default true
      */
-    stickTo: 'top',
+    autoclose: true,
     /**
-     * If anchored to a single element, the id of that element.
+     * Amount of time to delay opening a submenu on hover event.
      * @option
-     * @type {string}
-     * @default ''
+     * @type {number}
+     * @default 50
      */
-    anchor: '',
+    hoverDelay: 50,
     /**
-     * If using more than one element as anchor points, the id of the top anchor.
+     * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
      * @option
-     * @type {string}
-     * @default ''
+     * @type {boolean}
+     * @default false
      */
-    topAnchor: '',
+    clickOpen: false,
     /**
-     * If using more than one element as anchor points, the id of the bottom anchor.
+     * Amount of time to delay closing a submenu on a mouseleave event.
      * @option
-     * @type {string}
-     * @default ''
+     * @type {number}
+     * @default 500
      */
-    btmAnchor: '',
+
+    closingTime: 500,
     /**
-     * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
+     * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'left'` or `'right'`.
      * @option
-     * @type {number}
-     * @default 1
+     * @type {string}
+     * @default 'left'
      */
-    marginTop: 1,
+    alignment: 'left',
     /**
-     * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
+     * Allow clicks on the body to close any open submenus.
      * @option
-     * @type {number}
-     * @default 1
+     * @type {boolean}
+     * @default true
      */
-    marginBottom: 1,
+    closeOnClick: true,
     /**
-     * Breakpoint string that is the minimum screen size an element should become sticky.
+     * Allow clicks on leaf anchor links to close any open submenus.
      * @option
-     * @type {string}
-     * @default 'medium'
+     * @type {boolean}
+     * @default true
      */
-    stickyOn: 'medium',
+    closeOnClickInside: true,
     /**
-     * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
+     * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
      * @option
      * @type {string}
-     * @default 'sticky'
+     * @default 'vertical'
      */
-    stickyClass: 'sticky',
+    verticalClass: 'vertical',
     /**
-     * Class applied to sticky container. Foundation defaults to `sticky-container`.
+     * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
      * @option
      * @type {string}
-     * @default 'sticky-container'
+     * @default 'align-right'
      */
-    containerClass: 'sticky-container',
+    rightClass: 'align-right',
     /**
-     * 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.
+     * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
      * @option
-     * @type {number}
-     * @default -1
+     * @type {boolean}
+     * @default true
      */
-    checkEvery: -1
+    forceFollow: true
   };
 
-  /**
-   * 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;
-  }
-
   // Window exports
-  Foundation.plugin(Sticky, 'Sticky');
+  Foundation.plugin(DropdownMenu, 'DropdownMenu');
 }(jQuery);
 'use strict';
 
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
-
 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"); } }
@@ -7538,508 +1436,469 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 !function ($) {
 
   /**
-   * Tabs module.
-   * @module foundation.tabs
+   * OffCanvas module.
+   * @module foundation.offcanvas
    * @requires foundation.util.keyboard
-   * @requires foundation.util.timerAndImageLoader if tabs contain images
+   * @requires foundation.util.mediaQuery
+   * @requires foundation.util.triggers
+   * @requires foundation.util.motion
    */
 
-  var Tabs = function () {
+  var OffCanvas = function () {
     /**
-     * Creates a new instance of tabs.
+     * Creates a new instance of an off-canvas wrapper.
      * @class
-     * @fires Tabs#init
-     * @param {jQuery} element - jQuery object to make into tabs.
+     * @fires OffCanvas#init
+     * @param {Object} element - jQuery object to initialize.
      * @param {Object} options - Overrides to the default plugin settings.
      */
-    function Tabs(element, options) {
-      _classCallCheck(this, Tabs);
+    function OffCanvas(element, options) {
+      _classCallCheck(this, OffCanvas);
 
       this.$element = element;
-      this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);
+      this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);
+      this.$lastTrigger = $();
+      this.$triggers = $();
 
       this._init();
-      Foundation.registerPlugin(this, 'Tabs');
-      Foundation.Keyboard.register('Tabs', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ARROW_RIGHT': 'next',
-        'ARROW_UP': 'previous',
-        'ARROW_DOWN': 'next',
-        'ARROW_LEFT': 'previous'
-        // 'TAB': 'next',
-        // 'SHIFT_TAB': 'previous'
+      this._events();
+
+      Foundation.registerPlugin(this, 'OffCanvas');
+      Foundation.Keyboard.register('OffCanvas', {
+        'ESCAPE': 'close'
       });
     }
 
     /**
-     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+     * @function
      * @private
      */
 
 
-    _createClass(Tabs, [{
+    _createClass(OffCanvas, [{
       key: '_init',
       value: function _init() {
-        var _this2 = this;
-
-        var _this = this;
-
-        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[0].hash.slice(1),
-              linkId = $link[0].id ? $link[0].id : hash + '-label',
-              $tabContent = $('#' + hash);
-
-          $elem.attr({ 'role': 'presentation' });
+        var id = this.$element.attr('id');
 
-          $link.attr({
-            'role': 'tab',
-            'aria-controls': hash,
-            'aria-selected': isActive,
-            'id': linkId
-          });
+        this.$element.attr('aria-hidden', 'true');
 
-          $tabContent.attr({
-            'role': 'tabpanel',
-            'aria-hidden': !isActive,
-            'aria-labelledby': linkId
-          });
+        this.$element.addClass('is-transition-' + this.options.transition);
 
-          if (isActive && _this.options.autoFocus) {
-            $(window).load(function () {
-              $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, function () {
-                $link.focus();
-              });
-            });
-          }
-        });
-        if (this.options.matchHeight) {
-          var $images = this.$tabContent.find('img');
+        // 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);
 
-          if ($images.length) {
-            Foundation.onImagesLoaded($images, this._setHeight.bind(this));
+        // 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') {
+            $('body').append(this.$overlay);
           } else {
-            this._setHeight();
+            this.$element.siblings('[data-off-canvas-content]').append(this.$overlay);
           }
         }
 
-        //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 = _this2.$element.find('[href="' + anchor + '"]');
-            if ($link.length) {
-              _this2.selectTab($(anchor), true);
-
-              //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 zplugin has deeplinked at pageload
-                * @event Tabs#deeplink
-                */
-              _this2.$element.trigger('deeplink.zf.tabs', [$link, $(anchor)]);
-            }
-          }
-        };
+        this.options.isRevealed = this.options.isRevealed || new RegExp(this.options.revealClass, 'g').test(this.$element[0].className);
 
-        //use browser to open a tab, if it exists in this tabset
-        if (this.options.deepLink) {
-          this._checkDeepLink();
+        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 === true) {
+          this.options.transitionTime = parseFloat(window.getComputedStyle($('[data-off-canvas]')[0]).transitionDuration) * 1000;
         }
-
-        this._events();
       }
 
       /**
-       * Adds event handlers for items within the tabs.
+       * Adds event handlers to the off-canvas wrapper and the exit overlay.
+       * @function
        * @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);
-        }
+        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.deepLink) {
-          $(window).on('popstate', this._checkDeepLink);
+        if (this.options.closeOnClick === true) {
+          var $target = this.options.contentOverlay ? this.$overlay : $('[data-off-canvas-content]');
+          $target.on({ 'click.zf.offcanvas': this.close.bind(this) });
         }
       }
 
       /**
-       * Adds click handlers for items within the tabs.
+       * Applies event listener for elements that will reveal at certain breakpoints.
        * @private
        */
 
     }, {
-      key: '_addClickHandler',
-      value: function _addClickHandler() {
+      key: '_setMQChecker',
+      value: function _setMQChecker() {
         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));
+        $(window).on('changed.zf.mediaquery', function () {
+          if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {
+            _this.reveal(true);
+          } else {
+            _this.reveal(false);
+          }
+        }).one('load.zf.offcanvas', function () {
+          if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {
+            _this.reveal(true);
+          }
         });
       }
 
       /**
-       * Adds keyboard event handlers for items within the tabs.
+       * 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) {
+        var $closer = this.$element.find('[data-close]');
+        if (isRevealed) {
+          this.close();
+          this.isRevealed = true;
+          this.$element.attr('aria-hidden', 'false');
+          this.$element.off('open.zf.trigger toggle.zf.trigger');
+          if ($closer.length) {
+            $closer.hide();
+          }
+        } else {
+          this.isRevealed = false;
+          this.$element.attr('aria-hidden', 'true');
+          this.$element.on({
+            'open.zf.trigger': this.open.bind(this),
+            'toggle.zf.trigger': this.toggle.bind(this)
+          });
+          if ($closer.length) {
+            $closer.show();
+          }
+        }
+      }
+
+      /**
+       * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
        * @private
        */
 
     }, {
-      key: '_addKeyHandler',
-      value: function _addKeyHandler() {
-        var _this = this;
+      key: '_stopScrolling',
+      value: function _stopScrolling(event) {
+        return false;
+      }
 
-        this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
-          if (e.which === 9) return;
+      // 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 $element = $(this),
-              $elements = $element.parent('ul').children('li'),
-              $prevElement,
-              $nextElement;
+    }, {
+      key: '_recordScrollable',
+      value: function _recordScrollable(event) {
+        var elem = this; // called from event handler context with this as elem
 
-          $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;
-            }
-          });
+        // 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;
 
-          // handle keyboard event with keyboard util
-          Foundation.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();
-            }
-          });
-        });
+        if (up && elem.allowUp || down && elem.allowDown) {
+          event.stopPropagation();
+        } else {
+          event.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
+       * 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
        */
 
     }, {
-      key: '_handleTabChange',
-      value: function _handleTabChange($target, historyHandled) {
-
-        /**
-         * Check for active class on target. Collapse if exists.
-         */
-        if ($target.hasClass('' + 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]);
-          }
+      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);
+        }
 
-        var $oldTab = this.$element.find('.' + this.options.linkClass + '.' + this.options.linkActiveClass),
-            $tabLink = $target.find('[role="tab"]'),
-            hash = $tabLink[0].hash,
-            $targetContent = this.$tabContent.find(hash);
+        /**
+         * Fires when the off-canvas menu opens.
+         * @event OffCanvas#opened
+         */
+        _this.$element.addClass('is-open');
 
-        //close old tab
-        this._collapseTab($oldTab);
+        this.$triggers.attr('aria-expanded', 'true');
+        this.$element.attr('aria-hidden', 'false').trigger('opened.zf.offcanvas');
 
-        //open new tab
-        this._openTab($target);
+        // 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);
+        }
 
-        //either replace or update browser history
-        if (this.options.deepLink && !historyHandled) {
-          var anchor = $target.find('a').attr('href');
+        if (this.options.contentOverlay === true) {
+          this.$overlay.addClass('is-visible');
+        }
 
-          if (this.options.updateHistory) {
-            history.pushState({}, '', anchor);
-          } else {
-            history.replaceState({}, '', anchor);
-          }
+        if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+          this.$overlay.addClass('is-closable');
         }
 
-        /**
-         * Fires when the plugin has successfully changed tabs.
-         * @event Tabs#change
-         */
-        this.$element.trigger('change.zf.tabs', [$target, $targetContent]);
+        if (this.options.autoFocus === true) {
+          this.$element.one(Foundation.transitionend(this.$element), function () {
+            _this.$element.find('a, button').eq(0).focus();
+          });
+        }
 
-        //fire to children a mutation event
-        $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+        if (this.options.trapFocus === true) {
+          this.$element.siblings('[data-off-canvas-content]').attr('tabindex', '-1');
+          Foundation.Keyboard.trapFocus(this.$element);
+        }
       }
 
       /**
-       * Opens the tab `$targetContent` defined by `$target`.
-       * @param {jQuery} $target - Tab to Open.
+       * Closes the off-canvas menu.
        * @function
+       * @param {Function} cb - optional cb to fire after closure.
+       * @fires OffCanvas#closed
        */
 
     }, {
-      key: '_openTab',
-      value: function _openTab($target) {
-        var $tabLink = $target.find('[role="tab"]'),
-            hash = $tabLink[0].hash,
-            $targetContent = this.$tabContent.find(hash);
+      key: 'close',
+      value: function close(cb) {
+        if (!this.$element.hasClass('is-open') || this.isRevealed) {
+          return;
+        }
 
-        $target.addClass('' + this.options.linkActiveClass);
+        var _this = this;
 
-        $tabLink.attr({ 'aria-selected': 'true' });
+        _this.$element.removeClass('is-open');
 
-        $targetContent.addClass('' + this.options.panelActiveClass).attr({ 'aria-hidden': 'false' });
-      }
+        this.$element.attr('aria-hidden', 'true'
+        /**
+         * Fires when the off-canvas menu opens.
+         * @event OffCanvas#closed
+         */
+        ).trigger('closed.zf.offcanvas');
 
-      /**
-       * Collapses `$targetContent` defined by `$target`.
-       * @param {jQuery} $target - Tab to Open.
-       * @function
-       */
+        // 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);
+        }
 
-    }, {
-      key: '_collapseTab',
-      value: function _collapseTab($target) {
-        var $target_anchor = $target.removeClass('' + this.options.linkActiveClass).find('[role="tab"]').attr({ 'aria-selected': 'false' });
+        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');
 
-        $('#' + $target_anchor.attr('aria-controls')).removeClass('' + this.options.panelActiveClass).attr({ 'aria-hidden': 'true' });
+        if (this.options.trapFocus === true) {
+          this.$element.siblings('[data-off-canvas-content]').removeAttr('tabindex');
+          Foundation.Keyboard.releaseFocus(this.$element);
+        }
       }
 
       /**
-       * 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
+       * 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: 'selectTab',
-      value: function selectTab(elem, historyHandled) {
-        var idStr;
-
-        if ((typeof elem === 'undefined' ? 'undefined' : _typeof(elem)) === 'object') {
-          idStr = elem[0].id;
+      key: 'toggle',
+      value: function toggle(event, trigger) {
+        if (this.$element.hasClass('is-open')) {
+          this.close(event, trigger);
         } else {
-          idStr = elem;
-        }
-
-        if (idStr.indexOf('#') < 0) {
-          idStr = '#' + idStr;
+          this.open(event, trigger);
         }
-
-        var $target = this.$tabTitles.find('[href="' + idStr + '"]').parent('.' + this.options.linkClass);
-
-        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
+       * 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
        */
-      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 () {
 
-          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;
+    }, {
+      key: '_handleKeyboard',
+      value: function _handleKeyboard(e) {
+        var _this2 = this;
 
-          if (!isActive) {
-            panel.css({
-              'visibility': '',
-              'display': ''
-            });
+        Foundation.Keyboard.handleKey(e, 'OffCanvas', {
+          close: function close() {
+            _this2.close();
+            _this2.$lastTrigger.focus();
+            return true;
+          },
+          handled: function handled() {
+            e.stopPropagation();
+            e.preventDefault();
           }
-
-          max = temp > max ? temp : max;
-        }).css('height', max + 'px');
+        });
       }
 
       /**
-       * Destroys an instance of an tabs.
-       * @fires Tabs#destroyed
+       * Destroys the offcanvas plugin.
+       * @function
        */
 
     }, {
       key: 'destroy',
       value: function 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('popstate', this._checkDeepLink);
-        }
+        this.close();
+        this.$element.off('.zf.trigger .zf.offcanvas');
+        this.$overlay.off('.zf.offcanvas');
 
         Foundation.unregisterPlugin(this);
       }
     }]);
 
-    return Tabs;
+    return OffCanvas;
   }();
 
-  Tabs.defaults = {
+  OffCanvas.defaults = {
     /**
-     * Allows the window to scroll to content of pane specified by hash anchor
+     * Allow the user to click outside of the menu to close it.
      * @option
      * @type {boolean}
-     * @default false
+     * @default true
      */
-    deepLink: false,
+    closeOnClick: true,
 
     /**
-     * Adjust the deep link scroll to make sure the top of the tab panel is visible
+     * Adds an overlay on top of `[data-off-canvas-content]`.
      * @option
      * @type {boolean}
-     * @default false
-     */
-    deepLinkSmudge: false,
-
-    /**
-     * Animation time (ms) for the deep link adjustment
-     * @option
-     * @type {number}
-     * @default 300
+     * @default true
      */
-    deepLinkSmudgeDelay: 300,
+    contentOverlay: true,
 
     /**
-     * Update the browser history with the open tab
+     * Enable/disable scrolling of the main content when an off canvas panel is open.
      * @option
      * @type {boolean}
-     * @default false
+     * @default true
      */
-    updateHistory: false,
+    contentScroll: true,
 
     /**
-     * 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.
+     * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
      * @option
-     * @type {boolean}
-     * @default false
+     * @type {number}
+     * @default 0
      */
-    autoFocus: false,
+    transitionTime: 0,
 
     /**
-     * Allows keyboard input to 'wrap' around the tab links.
+     * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
      * @option
-     * @type {boolean}
-     * @default true
+     * @type {string}
+     * @default push
      */
-    wrapOnKeys: true,
+    transition: 'push',
 
     /**
-     * Allows the tab content panes to match heights if set to true.
+     * Force the page to scroll to top or bottom on open.
      * @option
-     * @type {boolean}
-     * @default false
+     * @type {?string}
+     * @default null
      */
-    matchHeight: false,
+    forceTo: null,
 
     /**
-     * Allows active tabs to collapse when clicked.
+     * Allow the offcanvas to remain open for certain breakpoints.
      * @option
      * @type {boolean}
      * @default false
      */
-    activeCollapse: false,
+    isRevealed: false,
 
     /**
-     * Class applied to `li`'s in tab link list.
+     * 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 'tabs-title'
+     * @type {?string}
+     * @default null
      */
-    linkClass: 'tabs-title',
+    revealOn: null,
 
     /**
-     * Class applied to the active `li` in tab link list.
+     * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
      * @option
-     * @type {string}
-     * @default 'is-active'
+     * @type {boolean}
+     * @default true
      */
-    linkActiveClass: 'is-active',
+    autoFocus: true,
 
     /**
-     * Class applied to the content containers.
+     * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
      * @option
      * @type {string}
-     * @default 'tabs-panel'
+     * @default reveal-for-
+     * @todo improve the regex testing for this.
      */
-    panelClass: 'tabs-panel',
+    revealClass: 'reveal-for-',
 
     /**
-     * Class applied to the active content container.
+     * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
      * @option
-     * @type {string}
-     * @default 'is-active'
+     * @type {boolean}
+     * @default false
      */
-    panelActiveClass: 'is-active'
-  };
+    trapFocus: false
 
-  // Window exports
-  Foundation.plugin(Tabs, 'Tabs');
+    // Window exports
+  };Foundation.plugin(OffCanvas, 'OffCanvas');
 }(jQuery);
 'use strict';
 
@@ -8050,67 +1909,74 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 !function ($) {
 
   /**
-   * Toggler module.
-   * @module foundation.toggler
-   * @requires foundation.util.motion
+   * ResponsiveMenu module.
+   * @module foundation.responsiveMenu
    * @requires foundation.util.triggers
+   * @requires foundation.util.mediaQuery
    */
 
-  var Toggler = function () {
+  var ResponsiveMenu = function () {
     /**
-     * Creates a new instance of Toggler.
+     * Creates a new instance of a responsive menu.
      * @class
-     * @fires Toggler#init
-     * @param {Object} element - jQuery object to add the trigger to.
+     * @fires ResponsiveMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
      * @param {Object} options - Overrides to the default plugin settings.
      */
-    function Toggler(element, options) {
-      _classCallCheck(this, Toggler);
+    function ResponsiveMenu(element, options) {
+      _classCallCheck(this, ResponsiveMenu);
 
-      this.$element = element;
-      this.options = $.extend({}, Toggler.defaults, element.data(), options);
-      this.className = '';
+      this.$element = $(element);
+      this.rules = this.$element.data('responsive-menu');
+      this.currentMq = null;
+      this.currentPlugin = null;
 
       this._init();
       this._events();
 
-      Foundation.registerPlugin(this, 'Toggler');
+      Foundation.registerPlugin(this, 'ResponsiveMenu');
     }
 
     /**
-     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
+     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
      * @function
      * @private
      */
 
 
-    _createClass(Toggler, [{
+    _createClass(ResponsiveMenu, [{
       key: '_init',
       value: function _init() {
-        var input;
-        // Parse animation classes if they were set
-        if (this.options.animate) {
-          input = this.options.animate.split(' ');
+        // 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 = {};
 
-          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;
+          // 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];
+            }
           }
 
-        // Add ARIA attributes to triggers
-        var id = this.$element[0].id;
-        $('[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);
+          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') || Foundation.GetYoDigits(6, 'responsive-menu'));
       }
 
       /**
-       * Initializes events for the toggle trigger.
+       * Initializes events for the Menu.
        * @function
        * @private
        */
@@ -8118,97 +1984,90 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
     }, {
       key: '_events',
       value: function _events() {
-        this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
+        var _this = this;
+
+        $(window).on('changed.zf.mediaquery', function () {
+          _this._checkMediaQueries();
+        });
+        // $(window).on('resize.zf.ResponsiveMenu', function() {
+        //   _this._checkMediaQueries();
+        // });
       }
 
       /**
-       * 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".
+       * 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
-       * @fires Toggler#on
-       * @fires Toggler#off
+       * @private
        */
 
     }, {
-      key: 'toggle',
-      value: function toggle() {
-        this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
-      }
-    }, {
-      key: '_toggleClass',
-      value: function _toggleClass() {
-        this.$element.toggleClass(this.className);
+      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;
+          }
+        });
 
-        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');
-        }
+        // No match? No dice
+        if (!matchedMq) return;
 
-        this._updateARIA(isOn);
-        this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
-      }
-    }, {
-      key: '_toggleAnimate',
-      value: function _toggleAnimate() {
-        var _this = this;
+        // Plugin already initialized? We good
+        if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
 
-        if (this.$element.is(':hidden')) {
-          Foundation.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.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) {
-        this.$element.attr('aria-expanded', isOn ? true : false);
+        // 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 Toggler on the 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.$element.off('.zf.toggler');
+        this.currentPlugin.destroy();
+        $(window).off('.zf.ResponsiveMenu');
         Foundation.unregisterPlugin(this);
       }
     }]);
 
-    return Toggler;
+    return ResponsiveMenu;
   }();
 
-  Toggler.defaults = {
-    /**
-     * Tells the plugin if the element should animated when toggled.
-     * @option
-     * @type {boolean}
-     * @default false
-     */
-    animate: false
+  ResponsiveMenu.defaults = {};
+
+  // The plugin matches the plugin classes with these plugin instances.
+  var MenuPlugins = {
+    dropdown: {
+      cssClass: 'dropdown',
+      plugin: Foundation._plugins['dropdown-menu'] || null
+    },
+    drilldown: {
+      cssClass: 'drilldown',
+      plugin: Foundation._plugins['drilldown'] || null
+    },
+    accordion: {
+      cssClass: 'accordion-menu',
+      plugin: Foundation._plugins['accordion-menu'] || null
+    }
   };
 
   // Window exports
-  Foundation.plugin(Toggler, 'Toggler');
+  Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu');
 }(jQuery);
 'use strict';
 
@@ -8219,256 +2078,67 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 !function ($) {
 
   /**
-   * Tooltip module.
-   * @module foundation.tooltip
-   * @requires foundation.util.box
+   * ResponsiveToggle module.
+   * @module foundation.responsiveToggle
    * @requires foundation.util.mediaQuery
-   * @requires foundation.util.triggers
    */
 
-  var Tooltip = function () {
+  var ResponsiveToggle = function () {
     /**
-     * Creates a new instance of a Tooltip.
+     * Creates a new instance of Tab Bar.
      * @class
-     * @fires Tooltip#init
-     * @param {jQuery} element - jQuery object to attach a tooltip to.
-     * @param {Object} options - object to extend the default configuration.
+     * @fires ResponsiveToggle#init
+     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
+     * @param {Object} options - Overrides to the default plugin settings.
      */
-    function Tooltip(element, options) {
-      _classCallCheck(this, Tooltip);
+    function ResponsiveToggle(element, options) {
+      _classCallCheck(this, ResponsiveToggle);
 
-      this.$element = element;
-      this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);
+      this.$element = $(element);
+      this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
 
-      this.isActive = false;
-      this.isClick = false;
       this._init();
+      this._events();
 
-      Foundation.registerPlugin(this, 'Tooltip');
+      Foundation.registerPlugin(this, 'ResponsiveToggle');
     }
 
     /**
-     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
+     * Initializes the tab bar by finding the target element, toggling element, and running update().
+     * @function
      * @private
      */
 
 
-    _createClass(Tooltip, [{
+    _createClass(ResponsiveToggle, [{
       key: '_init',
       value: function _init() {
-        var elemId = this.$element.attr('aria-describedby') || Foundation.GetYoDigits(6, 'tooltip');
-
-        this.options.positionClass = this.options.positionClass || this._getPositionClass(this.$element);
-        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);
-
-        //helper variables to track movement on collisions
-        this.usedPositions = [];
-        this.counter = 4;
-        this.classChanged = false;
-
-        this._events();
-      }
-
-      /**
-       * Grabs the current positioning class, if present, and returns the value or an empty string.
-       * @private
-       */
-
-    }, {
-      key: '_getPositionClass',
-      value: function _getPositionClass(element) {
-        if (!element) {
-          return '';
+        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.');
         }
-        // var position = element.attr('class').match(/top|left|right/g);
-        var position = element[0].className.match(/\b(top|left|right)\b/g);
-        position = position ? position[0] : '';
-        return position;
-      }
-    }, {
-      key: '_buildTemplate',
 
-      /**
-       * builds the tooltip element, adds attributes, and returns the template.
-       * @private
-       */
-      value: function _buildTemplate(id) {
-        var templateClasses = (this.options.tooltipClass + ' ' + this.options.positionClass + ' ' + 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
+        this.$targetMenu = $('#' + targetID);
+        this.$toggler = this.$element.find('[data-toggle]').filter(function () {
+          var target = $(this).data('toggle');
+          return target === targetID || target === "";
         });
-        return $template;
-      }
-
-      /**
-       * Function that gets called if a collision event is detected.
-       * @param {String} position - positioning class to try
-       * @private
-       */
-
-    }, {
-      key: '_reposition',
-      value: function _reposition(position) {
-        this.usedPositions.push(position ? position : 'bottom');
-
-        //default, try switching to opposite side
-        if (!position && this.usedPositions.indexOf('top') < 0) {
-          this.template.addClass('top');
-        } else if (position === 'top' && this.usedPositions.indexOf('bottom') < 0) {
-          this.template.removeClass(position);
-        } else if (position === 'left' && this.usedPositions.indexOf('right') < 0) {
-          this.template.removeClass(position).addClass('right');
-        } else if (position === 'right' && this.usedPositions.indexOf('left') < 0) {
-          this.template.removeClass(position).addClass('left');
-        }
-
-        //if default change didn't work, try bottom or left first
-        else if (!position && this.usedPositions.indexOf('top') > -1 && this.usedPositions.indexOf('left') < 0) {
-            this.template.addClass('left');
-          } else if (position === 'top' && this.usedPositions.indexOf('bottom') > -1 && this.usedPositions.indexOf('left') < 0) {
-            this.template.removeClass(position).addClass('left');
-          } else if (position === 'left' && this.usedPositions.indexOf('right') > -1 && this.usedPositions.indexOf('bottom') < 0) {
-            this.template.removeClass(position);
-          } else if (position === 'right' && this.usedPositions.indexOf('left') > -1 && this.usedPositions.indexOf('bottom') < 0) {
-            this.template.removeClass(position);
-          }
-          //if nothing cleared, set to bottom
-          else {
-              this.template.removeClass(position);
-            }
-        this.classChanged = true;
-        this.counter--;
-      }
-
-      /**
-       * 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() {
-        var position = this._getPositionClass(this.template),
-            $tipDims = Foundation.Box.GetDimensions(this.template),
-            $anchorDims = Foundation.Box.GetDimensions(this.$element),
-            direction = position === 'left' ? 'left' : position === 'right' ? 'left' : 'top',
-            param = direction === 'top' ? 'height' : 'width',
-            offset = param === 'height' ? this.options.vOffset : this.options.hOffset,
-            _this = this;
-
-        if ($tipDims.width >= $tipDims.windowDims.width || !this.counter && !Foundation.Box.ImNotTouchingYou(this.template)) {
-          this.template.offset(Foundation.Box.GetOffsets(this.template, this.$element, 'center bottom', this.options.vOffset, this.options.hOffset, true)).css({
-            // this.$element.offset(Foundation.GetOffsets(this.template, this.$element, 'center bottom', this.options.vOffset, this.options.hOffset, true)).css({
-            'width': $anchorDims.windowDims.width - this.options.hOffset * 2,
-            'height': 'auto'
-          });
-          return false;
-        }
-
-        this.template.offset(Foundation.Box.GetOffsets(this.template, this.$element, 'center ' + (position || 'bottom'), this.options.vOffset, this.options.hOffset));
-
-        while (!Foundation.Box.ImNotTouchingYou(this.template) && this.counter) {
-          this._reposition(position);
-          this._setPosition();
-        }
-      }
-
-      /**
-       * 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.MediaQuery.is(this.options.showOn)) {
-          // console.error('The screen is too small to display this tooltip');
-          return false;
-        }
+        this.options = $.extend({}, this.options, this.$targetMenu.data());
 
-        var _this = this;
-        this.template.css('visibility', 'hidden').show();
-        this._setPosition();
+        // If they were set, parse the animation classes
+        if (this.options.animate) {
+          var input = this.options.animate.split(' ');
 
-        /**
-         * Fires to close all other open tooltips on the page
-         * @event Closeme#tooltip
-         */
-        this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+          this.animationIn = input[0];
+          this.animationOut = input[1] || null;
+        }
 
-        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');
+        this._update();
       }
 
       /**
-       * Hides the current tooltip, and resets the positioning class if it was changed due to collision
-       * @fires Tooltip#hide
+       * Adds necessary event handlers for the tab bar to work.
        * @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;
-          if (_this.classChanged) {
-            _this.template.removeClass(_this._getPositionClass(_this.template)).addClass(_this.options.positionClass);
-
-            _this.usedPositions = [];
-            _this.counter = 4;
-            _this.classChanged = 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
        */
 
@@ -8476,231 +2146,105 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
       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) {
-            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._updateMqHandler = this._update.bind(this);
 
-        this.$element.on({
-          // 'toggle.zf.trigger': this.toggle.bind(this),
-          // 'close.zf.trigger': this.hide.bind(this)
-          'close.zf.trigger': this.hide.bind(this)
-        });
+        $(window).on('changed.zf.mediaquery', this._updateMqHandler);
 
-        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();
-          }
-        });
+        this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
       }
 
       /**
-       * adds a toggle method, in addition to the static show() & hide() functions
+       * Checks the current media query to determine if the tab bar should be visible or hidden.
        * @function
+       * @private
        */
 
     }, {
-      key: 'toggle',
-      value: function toggle() {
-        if (this.isActive) {
-          this.hide();
-        } else {
-          this.show();
+      key: '_update',
+      value: function _update() {
+        // Mobile
+        if (!Foundation.MediaQuery.atLeast(this.options.hideFor)) {
+          this.$element.show();
+          this.$targetMenu.hide();
         }
+
+        // Desktop
+        else {
+            this.$element.hide();
+            this.$targetMenu.show();
+          }
       }
 
       /**
-       * Destroys an instance of tooltip, removes template element from the view.
+       * 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 (!Foundation.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.Motion.animateIn(this.$targetMenu, this.animationIn, function () {
+                _this2.$element.trigger('toggled.zf.responsiveToggle');
+                _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+              });
+            } else {
+              Foundation.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.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.off('.zf.responsiveToggle');
+        this.$toggler.off('.zf.responsiveToggle');
 
-        this.template.remove();
+        $(window).off('changed.zf.mediaquery', this._updateMqHandler);
 
         Foundation.unregisterPlugin(this);
       }
     }]);
 
-    return Tooltip;
+    return ResponsiveToggle;
   }();
 
-  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: '',
+  ResponsiveToggle.defaults = {
     /**
-     * Text displayed in the tooltip template on open.
+     * The breakpoint after which the menu is always shown, and the tab bar is hidden.
      * @option
      * @type {string}
-     * @default ''
+     * @default 'medium'
      */
-    tipText: '',
-    touchCloseText: 'Tap to close.',
+    hideFor: 'medium',
+
     /**
-     * Allows the tooltip to remain open if triggered with a click or touch event.
+     * To decide if the toggle should be animated or not.
      * @option
      * @type {boolean}
-     * @default true
-     */
-    clickOpen: true,
-    /**
-     * Additional positioning classes, set by the JS
-     * @option
-     * @type {string}
-     * @default ''
-     */
-    positionClass: '',
-    /**
-     * Distance, in pixels, the template should push away from the anchor on the Y axis.
-     * @option
-     * @type {number}
-     * @default 10
-     */
-    vOffset: 10,
-    /**
-     * Distance, in pixels, the template should push away from the anchor on the X axis, if aligned to a side.
-     * @option
-     * @type {number}
-     * @default 12
+     * @default false
      */
-    hOffset: 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
+    animate: false
   };
 
-  /**
-   * TODO utilize resize event trigger
-   */
-
   // Window exports
-  Foundation.plugin(Tooltip, 'Tooltip');
+  Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle');
 }(jQuery);
 'use strict';
 
@@ -9228,459 +2772,15 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
       //     $item.removeClass('is-submenu-item ' + subItemClass);
       //   }
       //   if($sub.length){
-      //     $item.removeClass('has-submenu');
-      //     $sub.removeClass('submenu ' + subMenuClass).removeAttr('data-submenu');
-      //   }
-      // });
-    }
-  };
-
-  Foundation.Nest = Nest;
-}(jQuery);
-'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);
-'use strict';
-
-//**************************************************
-//**Work inspired by multiple jquery swipe plugins**
-//**Done by Yohai Ararat ***************************
-//**************************************************
-(function ($) {
-
-	$.spotSwipe = {
-		version: '1.0.0',
-		enabled: 'ontouchstart' in document.documentElement,
-		preventDefault: false,
-		moveThreshold: 75,
-		timeThreshold: 200
-	};
-
-	var startPosX,
-	    startPosY,
-	    startTime,
-	    elapsedTime,
-	    isMoving = false;
-
-	function onTouchEnd() {
-		//  alert(this);
-		this.removeEventListener('touchmove', onTouchMove);
-		this.removeEventListener('touchend', onTouchEnd);
-		isMoving = 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 dy = startPosY - y;
-			var dir;
-			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.call(this);
-				$(this).trigger('swipe', dir).trigger('swipe' + dir);
-			}
-		}
-	}
-
-	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);
-		}
-	}
-
-	function init() {
-		this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
-	}
-
-	function teardown() {
-		this.removeEventListener('touchstart', onTouchStart);
-	}
-
-	$.event.special.swipe = { setup: init };
-
-	$.each(['left', 'up', 'down', 'right'], function () {
-		$.event.special['swipe' + this] = { setup: function setup() {
-				$(this).on('swipe', $.noop);
-			} };
-	});
-})(jQuery);
-/****************************************************
- * Method for adding psuedo drag events to elements *
- ***************************************************/
-!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);
-			});
-		});
-
-		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);
-		};
-	};
-}(jQuery);
-
-//**********************************
-//**From the jQuery Mobile Library**
-//**need to recreate functionality**
-//**and try to improve if possible**
-//**********************************
-
-/* Removing the jQuery function ****
-************************************
-
-(function( $, window, undefined ) {
-
-	var $document = $( document ),
-		// supportTouch = $.mobile.support.touch,
-		touchStartEvent = 'touchstart'//supportTouch ? "touchstart" : "mousedown",
-		touchStopEvent = 'touchend'//supportTouch ? "touchend" : "mouseup",
-		touchMoveEvent = 'touchmove'//supportTouch ? "touchmove" : "mousemove";
-
-	// setup new event shortcuts
-	$.each( ( "touchstart touchmove touchend " +
-		"swipe swipeleft swiperight" ).split( " " ), function( i, name ) {
-
-		$.fn[ name ] = function( fn ) {
-			return fn ? this.bind( name, fn ) : this.trigger( name );
-		};
-
-		// jQuery < 1.8
-		if ( $.attrFn ) {
-			$.attrFn[ name ] = true;
-		}
-	});
-
-	function triggerCustomEvent( obj, eventType, event, bubble ) {
-		var originalType = event.type;
-		event.type = eventType;
-		if ( bubble ) {
-			$.event.trigger( event, undefined, obj );
-		} else {
-			$.event.dispatch.call( obj, event );
-		}
-		event.type = originalType;
-	}
-
-	// also handles taphold
-
-	// Also handles swipeleft, swiperight
-	$.event.special.swipe = {
-
-		// More than this horizontal displacement, and we will suppress scrolling.
-		scrollSupressionThreshold: 30,
-
-		// More time than this, and it isn't a swipe.
-		durationThreshold: 1000,
-
-		// Swipe horizontal displacement must be more than this.
-		horizontalDistanceThreshold: window.devicePixelRatio >= 2 ? 15 : 30,
-
-		// Swipe vertical displacement must be less than this.
-		verticalDistanceThreshold: window.devicePixelRatio >= 2 ? 15 : 30,
-
-		getLocation: function ( event ) {
-			var winPageX = window.pageXOffset,
-				winPageY = window.pageYOffset,
-				x = event.clientX,
-				y = event.clientY;
-
-			if ( event.pageY === 0 && Math.floor( y ) > Math.floor( event.pageY ) ||
-				event.pageX === 0 && Math.floor( x ) > Math.floor( event.pageX ) ) {
-
-				// iOS4 clientX/clientY have the value that should have been
-				// in pageX/pageY. While pageX/page/ have the value 0
-				x = x - winPageX;
-				y = y - winPageY;
-			} else if ( y < ( event.pageY - winPageY) || x < ( event.pageX - winPageX ) ) {
-
-				// Some Android browsers have totally bogus values for clientX/Y
-				// when scrolling/zooming a page. Detectable since clientX/clientY
-				// should never be smaller than pageX/pageY minus page scroll
-				x = event.pageX - winPageX;
-				y = event.pageY - winPageY;
-			}
-
-			return {
-				x: x,
-				y: y
-			};
-		},
-
-		start: function( event ) {
-			var data = event.originalEvent.touches ?
-					event.originalEvent.touches[ 0 ] : event,
-				location = $.event.special.swipe.getLocation( data );
-			return {
-						time: ( new Date() ).getTime(),
-						coords: [ location.x, location.y ],
-						origin: $( event.target )
-					};
-		},
-
-		stop: function( event ) {
-			var data = event.originalEvent.touches ?
-					event.originalEvent.touches[ 0 ] : event,
-				location = $.event.special.swipe.getLocation( data );
-			return {
-						time: ( new Date() ).getTime(),
-						coords: [ location.x, location.y ]
-					};
-		},
-
-		handleSwipe: function( start, stop, thisObject, origTarget ) {
-			if ( stop.time - start.time < $.event.special.swipe.durationThreshold &&
-				Math.abs( start.coords[ 0 ] - stop.coords[ 0 ] ) > $.event.special.swipe.horizontalDistanceThreshold &&
-				Math.abs( start.coords[ 1 ] - stop.coords[ 1 ] ) < $.event.special.swipe.verticalDistanceThreshold ) {
-				var direction = start.coords[0] > stop.coords[ 0 ] ? "swipeleft" : "swiperight";
-
-				triggerCustomEvent( thisObject, "swipe", $.Event( "swipe", { target: origTarget, swipestart: start, swipestop: stop }), true );
-				triggerCustomEvent( thisObject, direction,$.Event( direction, { target: origTarget, swipestart: start, swipestop: stop } ), true );
-				return true;
-			}
-			return false;
-
-		},
-
-		// This serves as a flag to ensure that at most one swipe event event is
-		// in work at any given time
-		eventInProgress: false,
-
-		setup: function() {
-			var events,
-				thisObject = this,
-				$this = $( thisObject ),
-				context = {};
-
-			// Retrieve the events data for this element and add the swipe context
-			events = $.data( this, "mobile-events" );
-			if ( !events ) {
-				events = { length: 0 };
-				$.data( this, "mobile-events", events );
-			}
-			events.length++;
-			events.swipe = context;
-
-			context.start = function( event ) {
-
-				// Bail if we're already working on a swipe event
-				if ( $.event.special.swipe.eventInProgress ) {
-					return;
-				}
-				$.event.special.swipe.eventInProgress = true;
-
-				var stop,
-					start = $.event.special.swipe.start( event ),
-					origTarget = event.target,
-					emitted = false;
-
-				context.move = function( event ) {
-					if ( !start || event.isDefaultPrevented() ) {
-						return;
-					}
-
-					stop = $.event.special.swipe.stop( event );
-					if ( !emitted ) {
-						emitted = $.event.special.swipe.handleSwipe( start, stop, thisObject, origTarget );
-						if ( emitted ) {
-
-							// Reset the context to make way for the next swipe event
-							$.event.special.swipe.eventInProgress = false;
-						}
-					}
-					// prevent scrolling
-					if ( Math.abs( start.coords[ 0 ] - stop.coords[ 0 ] ) > $.event.special.swipe.scrollSupressionThreshold ) {
-						event.preventDefault();
-					}
-				};
-
-				context.stop = function() {
-						emitted = true;
-
-						// Reset the context to make way for the next swipe event
-						$.event.special.swipe.eventInProgress = false;
-						$document.off( touchMoveEvent, context.move );
-						context.move = null;
-				};
-
-				$document.on( touchMoveEvent, context.move )
-					.one( touchStopEvent, context.stop );
-			};
-			$this.on( touchStartEvent, context.start );
-		},
-
-		teardown: function() {
-			var events, context;
-
-			events = $.data( this, "mobile-events" );
-			if ( events ) {
-				context = events.swipe;
-				delete events.swipe;
-				events.length--;
-				if ( events.length === 0 ) {
-					$.removeData( this, "mobile-events" );
-				}
-			}
+      //     $item.removeClass('has-submenu');
+      //     $sub.removeClass('submenu ' + subMenuClass).removeAttr('data-submenu');
+      //   }
+      // });
+    }
+  };
 
-			if ( context ) {
-				if ( context.start ) {
-					$( this ).off( touchStartEvent, context.start );
-				}
-				if ( context.move ) {
-					$document.off( touchMoveEvent, context.move );
-				}
-				if ( context.stop ) {
-					$document.off( touchStopEvent, context.stop );
-				}
-			}
-		}
-	};
-	$.each({
-		swipeleft: "swipe.left",
-		swiperight: "swipe.right"
-	}, function( event, sourceEvent ) {
-
-		$.event.special[ event ] = {
-			setup: function() {
-				$( this ).bind( sourceEvent, $.noop );
-			},
-			teardown: function() {
-				$( this ).unbind( sourceEvent );
-			}
-		};
-	});
-})( jQuery, this );
-*/
+  Foundation.Nest = Nest;
+}(jQuery);
 'use strict';
 
 var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
@@ -9946,268 +3046,6 @@ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol
 // }
 '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);
-'use strict';
-
 /**
  * File js-enabled.js
  *
@@ -10216,196 +3054,6 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
 document.body.className = document.body.className.replace('no-js', 'js');
 'use strict';
 
-/**
- * File modal.js
- *
- * Deal with multiple modals and their media.
- */
-window.wdsModal = {};
-
-(function (window, $, app) {
-
-	var $modalToggle = void 0,
-	    $focusableChildren = void 0,
-	    $player = void 0,
-	    $tag = document.createElement('script'),
-	    $firstScriptTag = document.getElementsByTagName('script')[0],
-	    YT = void 0;
-
-	// Constructor.
-	app.init = function () {
-		app.cache();
-
-		if (app.meetsRequirements()) {
-			$firstScriptTag.parentNode.insertBefore($tag, $firstScriptTag);
-			app.bindEvents();
-		}
-	};
-
-	// Cache all the things.
-	app.cache = function () {
-		app.$c = {
-			'body': $('body')
-		};
-	};
-
-	// Do we meet the requirements?
-	app.meetsRequirements = function () {
-		return $('.modal-trigger').length;
-	};
-
-	// Combine all events.
-	app.bindEvents = function () {
-
-		// Trigger a modal to open.
-		app.$c.body.on('click touchstart', '.modal-trigger', app.openModal);
-
-		// Trigger the close button to close the modal.
-		app.$c.body.on('click touchstart', '.close', app.closeModal);
-
-		// Allow the user to close the modal by hitting the esc key.
-		app.$c.body.on('keydown', app.escKeyClose);
-
-		// Allow the user to close the modal by clicking outside of the modal.
-		app.$c.body.on('click touchstart', 'div.modal-open', app.closeModalByClick);
-
-		// Listen to tabs, trap keyboard if we need to
-		app.$c.body.on('keydown', app.trapKeyboardMaybe);
-	};
-
-	// Open the modal.
-	app.openModal = function () {
-
-		// Store the modal toggle element
-		$modalToggle = $(this);
-
-		// Figure out which modal we're opening and store the object.
-		var $modal = $($(this).data('target'));
-
-		// Display the modal.
-		$modal.addClass('modal-open');
-
-		// Add body class.
-		app.$c.body.addClass('modal-open');
-
-		// Find the focusable children of the modal.
-		// This list may be incomplete, really wish jQuery had the :focusable pseudo like jQuery UI does.
-		// For more about :input see: https://api.jquery.com/input-selector/
-		$focusableChildren = $modal.find('a, :input, [tabindex]');
-
-		// Ideally, there is always one (the close button), but you never know.
-		if (0 < $focusableChildren.length) {
-
-			// Shift focus to the first focusable element.
-			$focusableChildren[0].focus();
-		}
-	};
-
-	// Close the modal.
-	app.closeModal = function () {
-
-		// Figure the opened modal we're closing and store the object.
-		var $modal = $($('div.modal-open .close').data('target')),
-
-
-		// Find the iframe in the $modal object.
-		$iframe = $modal.find('iframe');
-
-		// Only do this if there are any iframes.
-		if ($iframe.length) {
-
-			// Get the iframe src URL.
-			var url = $iframe.attr('src');
-
-			// Removing/Readding the URL will effectively break the YouTube API.
-			// So let's not do that when the iframe URL contains the enablejsapi parameter.
-			if (!url.includes('enablejsapi=1')) {
-
-				// Remove the source URL, then add it back, so the video can be played again later.
-				$iframe.attr('src', '').attr('src', url);
-			} else {
-
-				// Use the YouTube API to stop the video.
-				$player.stopVideo();
-			}
-		}
-
-		// Finally, hide the modal.
-		$modal.removeClass('modal-open');
-
-		// Remove the body class.
-		app.$c.body.removeClass('modal-open');
-
-		// Revert focus back to toggle element
-		$modalToggle.focus();
-	};
-
-	// Close if "esc" key is pressed.
-	app.escKeyClose = function (event) {
-		if (27 === event.keyCode) {
-			app.closeModal();
-		}
-	};
-
-	// Close if the user clicks outside of the modal
-	app.closeModalByClick = function (event) {
-
-		// If the parent container is NOT the modal dialog container, close the modal
-		if (!$(event.target).parents('div').hasClass('modal-dialog')) {
-			app.closeModal();
-		}
-	};
-
-	// Trap the keyboard into a modal when one is active.
-	app.trapKeyboardMaybe = function (event) {
-
-		// We only need to do stuff when the modal is open and tab is pressed.
-		if (9 === event.which && 0 < $('.modal-open').length) {
-			var $focused = $(':focus'),
-			    focusIndex = $focusableChildren.index($focused);
-
-			if (0 === focusIndex && event.shiftKey) {
-
-				// If this is the first focusable element, and shift is held when pressing tab, go back to last focusable element.
-				$focusableChildren[$focusableChildren.length - 1].focus();
-				event.preventDefault();
-			} else if (!event.shiftKey && focusIndex === $focusableChildren.length - 1) {
-
-				// If this is the last focusable element, and shift is not held, go back to the first focusable element.
-				$focusableChildren[0].focus();
-				event.preventDefault();
-			}
-		}
-	};
-
-	// Hook into YouTube <iframe>.
-	app.onYouTubeIframeAPIReady = function () {
-		var $modal = $('div.modal'),
-		    $iframeid = $modal.find('iframe').attr('id');
-
-		$player = new YT.Player($iframeid, {
-			events: {
-				'onReady': app.onPlayerReady,
-				'onStateChange': app.onPlayerStateChange
-			}
-		});
-	};
-
-	// Do something on player ready.
-	app.onPlayerReady = function () {};
-
-	// Do something on player state change.
-	app.onPlayerStateChange = function () {
-
-		// Set focus to the first focusable element inside of the modal the player is in.
-		$(event.target.a).parents('.modal').find('a, :input, [tabindex]').first().focus();
-	};
-
-	// Engage!
-	$(app.init);
-})(window, jQuery, window.wdsModal);
-'use strict';
-
 /**
  * File skip-link-focus-fix.js.
  *
@@ -10484,4 +3132,4 @@ window.wdsWindowReady = {};
 	// Engage!
 	$(app.init);
 })(window, jQuery, window.wdsWindowReady);
-//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["foundation.core.js","foundation.util.mediaQuery.js","foundation.abide.js","foundation.accordion.js","foundation.accordionMenu.js","foundation.drilldown.js","foundation.dropdown.js","foundation.dropdownMenu.js","foundation.equalizer.js","foundation.interchange.js","foundation.magellan.js","foundation.offcanvas.js","foundation.orbit.js","foundation.responsiveMenu.js","foundation.responsiveToggle.js","foundation.reveal.js","foundation.slider.js","foundation.sticky.js","foundation.tabs.js","foundation.toggler.js","foundation.tooltip.js","foundation.util.box.js","foundation.util.keyboard.js","foundation.util.motion.js","foundation.util.nest.js","foundation.util.timerAndImageLoader.js","foundation.util.touch.js","foundation.util.triggers.js","foundation.zf.responsiveAccordionTabs.js","js-enabled.js","modal.js","skip-link-focus-fix.js","wds-foundation.js","window-ready.js"],"names":["$","FOUNDATION_VERSION","Foundation","version","_plugins","_uuids","rtl","attr","plugin","name","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","GetYoDigits","$element","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","length","namespace","Math","round","pow","random","toString","slice","reflow","elem","i","$elem","find","addBack","$el","opts","warn","thing","split","e","opt","map","el","trim","parseValue","er","getFnName","transitionend","transitions","document","createElement","end","t","style","setTimeout","triggerHandler","util","throttle","func","delay","timer","context","args","arguments","apply","method","$meta","$noJS","appendTo","head","removeClass","MediaQuery","Array","prototype","call","plugClass","undefined","ReferenceError","TypeError","window","fn","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","callback","nextTime","max","clearTimeout","performance","start","Function","bind","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","str","isNaN","parseFloat","replace","jQuery","defaultQueries","landscape","portrait","retina","queries","current","self","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","value","_getCurrentSize","_watcher","atLeast","size","query","get","matchMedia","matches","is","matched","on","newSize","currentSize","styleMedia","media","script","getElementsByTagName","info","id","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","styleObject","reduce","ret","param","parts","val","decodeURIComponent","isArray","Abide","element","options","extend","defaults","$inputs","_events","off","resetForm","validateForm","validateOn","validateInput","target","liveValidate","validateOnBlur","isGood","checked","$error","siblings","formErrorSelector","parent","$label","closest","$els","labels","findLabel","$formError","findFormError","addClass","labelErrorClass","formErrorClass","inputErrorClass","groupName","$labels","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","not","removeErrorClasses","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","Accordion","Keyboard","register","$tabs","children","idx","$content","linkId","$initActive","down","$tabContent","preventDefault","toggle","handleKey","next","$a","focus","multiExpand","previous","prev","handled","stopPropagation","$target","hasClass","up","firstTime","$currentActive","slideDown","slideSpeed","$aunts","allowAllClosed","slideUp","stop","AccordionMenu","Nest","Feather","multiOpen","$menuLinks","$sub","subId","isActive","initPanes","$submenu","$elements","$prevElement","$nextElement","eq","first","min","parents","open","close","closeAll","hideAll","stopImmediatePropagation","parentsUntil","add","$menus","Burn","Drilldown","$submenuAnchors","$submenus","$menuItems","_prepareMenu","_registerEvents","_keyboardEvents","$link","parentLink","clone","prependTo","wrap","$menu","$back","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","_show","closeOnClick","$body","contains","_hideAll","_resize","scrollTop","_bindHandler","_scrollTop","$scrollTopElement","scrollTopElement","scrollPos","parseInt","offset","top","scrollTopOffset","animate","animationDuration","animationEasing","one","filter","_hide","height","parentSubMenu","blur","maxHeight","result","numOfElems","Box","GetDimensions","getBoundingClientRect","unwrap","remove","Dropdown","$id","$anchor","parentClass","$parent","positionClass","getPositionClass","counter","usedPositions","verticalPosition","match","horizontalPosition","position","classChanged","$eleDims","$anchorDims","direction","vOffset","hOffset","windowDims","ImNotTouchingYou","newWidth","parentHOffset","$parentDims","left","GetOffsets","_reposition","_setPosition","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","visibleFocusableElements","findFocusable","body","autoFocus","$focusable","_addBodyHandler","trapFocus","curPositionClass","releaseFocus","hide","DropdownMenu","subs","verticalClass","rightClass","alignment","changed","hasTouch","ontouchstart","parClass","handleClickFn","hasSub","hasClicked","clickOpen","forceFollow","closeOnClickInside","disableHover","autoclose","closingTime","isTab","index","nextSibling","prevSibling","openSub","closeSub","functions","_isVertical","$sibs","oldClass","$parentLi","$toClose","somethingToClose","Equalizer","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","onImagesLoaded","_reflow","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","cb","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","groupsILength","lenJ","Interchange","rules","currentPath","_addBreakpoints","_generateRules","rule","path","SPECIAL_QUERIES","rulesList","join","nodeName","response","html","Magellan","calcPoints","$targets","$links","$active","pageYOffset","documentElement","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","threshold","targetPoint","duration","easing","deepLinking","location","hash","scrollToLoc","_updateActive","arrival","getAttribute","loc","_inTransition","barOffset","winPos","curIdx","isDown","curVisible","activeClass","history","pushState","OffCanvas","$lastTrigger","$triggers","transition","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","isRevealed","revealClass","revealOn","_setMQChecker","transitionTime","transitionDuration","_handleKeyboard","reveal","$closer","show","event","allowUp","allowDown","lastY","originalEvent","pageY","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","Orbit","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","Timer","timerDelay","infinite","changeSlide","_setWrapperHeight","temp","swipe","pauseOnHover","pause","navButtons","$controls","nextClass","prevClass","ltr","$slide","restart","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","$newSlide","infiniteWrap","Motion","animateIn","animateOut","isPaused","$oldBullet","span","detach","$newBullet","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","ResponsiveMenu","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","MenuPlugins","isEmptyObject","_checkMediaQueries","matchedMq","cssClass","destroy","dropdown","drilldown","accordion","ResponsiveToggle","targetID","$targetMenu","$toggler","input","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","Reveal","cached","mq","isMobile","mobileSniff","fullScreen","_makeOverlay","deepLink","outerWidth","outerHeight","margin","_updatePosition","which","_handleState","multipleOpened","addRevealOpenClasses","originalScrollPos","afterAnimation","focusableElements","showDelay","_extraHandlers","closeOnEsc","finishUp","hideDelay","resetOnClose","replaceState","title","href","btmOffsetPct","iPhoneSniff","androidSniff","Slider","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","Move","changedDelay","initVal","initialEnd","hasVal","eventOffset","pageX","halfOfHandle","barDim","windowScroll","scrollLeft","elemOffset","clientY","eventFromBar","barXY","offsetPct","_value","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","prev_val","next_val","_eventsForHandle","curHandle","_handleEvent","clickSelect","draggable","addTouch","currentTarget","_$handle","oldValue","newValue","decrease","increase","decrease_fast","increase_fast","invertVertical","frac","num","dir","clickPos","abs","base","log","Sticky","wasWrapped","$container","container","wrapInner","stickyClass","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","anchor","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","topAnchor","btm","btmAnchor","pts","breaks","place","scrollListener","canStick","_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","load","deepLinkSmudgeDelay","matchHeight","_setHeight","_checkDeepLink","selectTab","deepLinkSmudge","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","wrapOnKeys","historyHandled","activeCollapse","_collapseTab","$oldTab","$tabLink","$targetContent","_openTab","updateHistory","panelActiveClass","$target_anchor","idStr","panelClass","panel","Toggler","toggleClass","_updateARIA","Tooltip","isClick","elemId","_getPositionClass","tipText","template","_buildTemplate","allowHtml","triggerClass","templateClasses","tooltipClass","$template","$tipDims","showOn","fadeIn","fadeInDuration","fadeOut","fadeOutDuration","isFocus","disableForTouch","touchCloseText","lrOnly","tbOnly","eleDims","right","parDims","allDirs","Error","rect","parRect","winRect","winY","winX","pageXOffset","parentDims","isOverflow","keyCodes","commands","getKeyCodes","parseKey","keyCode","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","component","commandList","cmds","command","returnValue","unhandled","componentName","$firstFocusable","$lastFocusable","kcs","k","kc","initClasses","activeClasses","animation","anim","prog","move","ts","isIn","initClass","reset","offsetWidth","finish","menu","items","subMenuClass","subItemClass","hasSubClass","$item","nameSpace","remain","images","unloaded","complete","readyState","singleImageLoaded","src","spotSwipe","enabled","moveThreshold","timeThreshold","startPosX","startPosY","startTime","elapsedTime","isMoving","onTouchEnd","removeEventListener","onTouchMove","x","touches","y","dx","dy","onTouchStart","addEventListener","init","teardown","special","setup","noop","handleTouch","changedTouches","eventTypes","touchstart","touchmove","touchend","simulatedEvent","MouseEvent","screenX","screenY","clientX","createEvent","initMouseEvent","dispatchEvent","MutationObserver","prefixes","triggers","checkListeners","eventsListener","resizeListener","mutateListener","closemeListener","yetiBoxes","plugNames","listeners","pluginId","debounce","$nodes","nodes","querySelectorAll","listeningElementsMutation","mutationRecordsList","attributeName","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","IHearYou","ResponsiveAccordionTabs","_getAllOptions","allOptions","obj","dummyPlugin","tmpPlugin","keyKey","objObj","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","tabsPanel","$liHeads","$liHeadsA","display","visibility","after","$tabsContent","$placeholder","insertAfter","tempValue","tabs","wdsModal","app","$modalToggle","$focusableChildren","$player","$tag","$firstScriptTag","YT","cache","meetsRequirements","bindEvents","$c","openModal","closeModal","escKeyClose","closeModalByClick","trapKeyboardMaybe","$modal","$iframe","includes","stopVideo","$focused","focusIndex","onYouTubeIframeAPIReady","$iframeid","Player","events","onPlayerReady","onPlayerStateChange","a","isWebkit","isOpera","isIe","getElementById","substring","tagName","tabIndex","wdsWindowReady","addBodyClass"],"mappings":"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","file":"project.js","sourcesContent":["!function($) {\n\n\"use strict\";\n\nvar FOUNDATION_VERSION = '6.3.1';\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   * Returns a boolean for RTL support\n   */\n  rtl: function(){\n    return $('html').attr('dir') === 'rtl';\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 = this.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   * 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  GetYoDigits: function(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   * 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  transitionend: function($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\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\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 */\nvar foundation = function(method) {\n  var type = typeof method,\n      $meta = $('meta.foundation-mq'),\n      $noJS = $('.no-js');\n\n  if(!$meta.length){\n    $('<meta class=\"foundation-mq\">').appendTo(document.head);\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    Foundation.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(plugClass !== undefined && 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\nwindow.Foundation = Foundation;\n$.fn.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 (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 (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\n}(jQuery);\n","'use strict';\n\n!function($) {\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\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 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).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\nFoundation.MediaQuery = MediaQuery;\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. Dual MIT/BSD license\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    script && script.parentNode && script.parentNode.insertBefore(style, script);\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(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\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 = 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\nFoundation.MediaQuery = MediaQuery;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide {\n  /**\n   * Creates a new instance of Abide.\n   * @class\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  constructor(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend({}, Abide.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Abide');\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 = this.$element.find('input, textarea, select');\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   * Based on $el, get the first element with selector in this order:\n   * 1. The element's direct sibling('s).\n   * 3. The element's parent's children.\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 $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\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('data-invalid', '');\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\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).removeAttr('data-invalid');\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).removeAttr('data-invalid');\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]').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    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('').removeAttr('data-invalid');\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).removeAttr('data-invalid');\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).removeAttr('data-invalid');\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    Foundation.unregisterPlugin(this);\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   * 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}|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    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})|[!\\$&'\\(\\)\\*\\+,;=]|:|@)|\\/|\\?)*)?$/,\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\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\n// Window exports\nFoundation.plugin(Abide, 'Abide');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n */\n\nclass Accordion {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Accordion');\n    Foundation.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.$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 || Foundation.GetYoDigits(6, 'accordion'),\n          linkId = el.id || `${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    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if($initActive.length){\n      this.down($initActive, true);\n    }\n    this._events();\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          Foundation.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  }\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.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @param {Boolean} firstTime - flag to determine if reflow should happen.\n   * @fires Accordion#down\n   * @function\n   */\n  down($target, firstTime) {\n    $target\n      .attr('aria-hidden', false)\n      .parent('[data-tab-content]')\n      .addBack()\n      .parent().addClass('is-active');\n\n    if (!this.options.multiExpand && !firstTime) {\n      var $currentActive = this.$element.children('.is-active').children('[data-tab-content]');\n      if ($currentActive.length) {\n        this.up($currentActive.not($target));\n      }\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    $(`#${$target.attr('aria-labelledby')}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\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   */\n  up($target) {\n    var $aunts = $target.parent().siblings(),\n        _this = this;\n\n    if((!this.options.allowAllClosed && !$aunts.hasClass('is-active')) || !$target.parent().hasClass('is-active')) {\n      return;\n    }\n\n    // Foundation.Move(this.options.slideSpeed, $target, function(){\n      $target.slideUp(_this.options.slideSpeed, function () {\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    $target.attr('aria-hidden', true)\n           .parent().removeClass('is-active');\n\n    $(`#${$target.attr('aria-labelledby')}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\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\n    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(Accordion, 'Accordion');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n\n    Foundation.Nest.Feather(this.$element, 'accordion');\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'AccordionMenu');\n    Foundation.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    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'menu',\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 || Foundation.GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || Foundation.GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n      $elem.attr({\n        'aria-controls': subId,\n        'aria-expanded': isActive,\n        'role': 'menuitem',\n        'id': linkId\n      });\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'menu',\n        'id': subId\n      });\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        $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n          e.preventDefault();\n\n          _this.toggle($submenu);\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      Foundation.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 ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\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    var _this = this;\n\n    if(!this.options.multiOpen) {\n      this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));\n    }\n\n    $target.addClass('is-active').attr({'aria-hidden': false})\n      .parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n\n      //Foundation.Move(this.options.slideSpeed, $target, function() {\n        $target.slideDown(_this.options.slideSpeed, function () {\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  /**\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    var _this = this;\n    //Foundation.Move(this.options.slideSpeed, $target, function(){\n      $target.slideUp(_this.options.slideSpeed, function () {\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    var $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);\n\n    $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\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\n    Foundation.Nest.Burn(this.$element, 'accordion');\n    Foundation.unregisterPlugin(this);\n  }\n}\n\nAccordionMenu.defaults = {\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   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\n// Window exports\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.nest\n */\n\nclass Drilldown {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n\n    Foundation.Nest.Feather(this.$element, 'drilldown');\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Drilldown');\n    Foundation.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    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'menuitem').find('a');\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || Foundation.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 class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menu-item\"></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': 'menu'\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\t  this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\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  }\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);\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      Foundation.Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(Foundation.transitionend($element), function(){\n              $element.parent('li').find('ul li a').filter(_this.$menuItems).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(Foundation.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 (!$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(Foundation.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            _this._show($element.parent('li'));\n            $element.parent('li').one(Foundation.transitionend($element), function(){\n              $element.parent('li').find('ul li a').filter(_this.$menuItems).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(Foundation.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   * 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    if(this.options.autoHeight) this.$wrapper.css({height:$elem.children('[data-submenu]').data('calcHeight')});\n    $elem.attr('aria-expanded', true);\n    $elem.children('[data-submenu]').addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\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).addClass('is-closing')\n    $elem.addClass('is-closing')\n         .one(Foundation.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    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Foundation.Box.GetDimensions(this).height;\n      maxHeight = height > maxHeight ? height : maxHeight;\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n        if (!$(this).hasClass('is-drilldown-submenu')) result['height'] = height;\n      }\n    });\n\n    if(!this.options.autoHeight) 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    Foundation.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.$submenus.removeClass('drilldown-submenu-cover-previous');\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    Foundation.unregisterPlugin(this);\n  };\n}\n\nDrilldown.defaults = {\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\n// Window exports\nFoundation.plugin(Drilldown, 'Drilldown');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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\nclass Dropdown {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this._init();\n\n    Foundation.registerPlugin(this, 'Dropdown');\n    Foundation.Keyboard.register('Dropdown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\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.$anchor = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchor.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\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n    this.options.positionClass = this.getPositionClass();\n    this.counter = 4;\n    this.usedPositions = [];\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n      'aria-labelledby': this.$anchor[0].id || Foundation.GetYoDigits(6, 'dd-anchor')\n    });\n    this._events();\n  }\n\n  /**\n   * Helper function to determine current orientation of dropdown pane.\n   * @function\n   * @returns {String} position - string value of a position class.\n   */\n  getPositionClass() {\n    var verticalPosition = this.$element[0].className.match(/(top|left|right|bottom)/g);\n        verticalPosition = verticalPosition ? verticalPosition[0] : '';\n    var horizontalPosition = /float-(\\S+)/.exec(this.$anchor[0].className);\n        horizontalPosition = horizontalPosition ? horizontalPosition[1] : '';\n    var position = horizontalPosition ? horizontalPosition + ' ' + verticalPosition : verticalPosition;\n\n    return position;\n  }\n\n  /**\n   * Adjusts the dropdown panes orientation by adding/removing positioning classes.\n   * @function\n   * @private\n   * @param {String} position - position class to remove.\n   */\n  _reposition(position) {\n    this.usedPositions.push(position ? position : 'bottom');\n    //default, try switching to opposite side\n    if(!position && (this.usedPositions.indexOf('top') < 0)){\n      this.$element.addClass('top');\n    }else if(position === 'top' && (this.usedPositions.indexOf('bottom') < 0)){\n      this.$element.removeClass(position);\n    }else if(position === 'left' && (this.usedPositions.indexOf('right') < 0)){\n      this.$element.removeClass(position)\n          .addClass('right');\n    }else if(position === 'right' && (this.usedPositions.indexOf('left') < 0)){\n      this.$element.removeClass(position)\n          .addClass('left');\n    }\n\n    //if default change didn't work, try bottom or left first\n    else if(!position && (this.usedPositions.indexOf('top') > -1) && (this.usedPositions.indexOf('left') < 0)){\n      this.$element.addClass('left');\n    }else if(position === 'top' && (this.usedPositions.indexOf('bottom') > -1) && (this.usedPositions.indexOf('left') < 0)){\n      this.$element.removeClass(position)\n          .addClass('left');\n    }else if(position === 'left' && (this.usedPositions.indexOf('right') > -1) && (this.usedPositions.indexOf('bottom') < 0)){\n      this.$element.removeClass(position);\n    }else if(position === 'right' && (this.usedPositions.indexOf('left') > -1) && (this.usedPositions.indexOf('bottom') < 0)){\n      this.$element.removeClass(position);\n    }\n    //if nothing cleared, set to bottom\n    else{\n      this.$element.removeClass(position);\n    }\n    this.classChanged = true;\n    this.counter--;\n  }\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    if(this.$anchor.attr('aria-expanded') === 'false'){ return false; }\n    var position = this.getPositionClass(),\n        $eleDims = Foundation.Box.GetDimensions(this.$element),\n        $anchorDims = Foundation.Box.GetDimensions(this.$anchor),\n        _this = this,\n        direction = (position === 'left' ? 'left' : ((position === 'right') ? 'left' : 'top')),\n        param = (direction === 'top') ? 'height' : 'width',\n        offset = (param === 'height') ? this.options.vOffset : this.options.hOffset;\n\n    if(($eleDims.width >= $eleDims.windowDims.width) || (!this.counter && !Foundation.Box.ImNotTouchingYou(this.$element, this.$parent))){\n      var newWidth = $eleDims.windowDims.width,\n          parentHOffset = 0;\n      if(this.$parent){\n        var $parentDims = Foundation.Box.GetDimensions(this.$parent),\n            parentHOffset = $parentDims.offset.left;\n        if ($parentDims.width < newWidth){\n          newWidth = $parentDims.width;\n        }\n      }\n\n      this.$element.offset(Foundation.Box.GetOffsets(this.$element, this.$anchor, 'center bottom', this.options.vOffset, this.options.hOffset + parentHOffset, true)).css({\n        'width': newWidth - (this.options.hOffset * 2),\n        'height': 'auto'\n      });\n      this.classChanged = true;\n      return false;\n    }\n\n    this.$element.offset(Foundation.Box.GetOffsets(this.$element, this.$anchor, position, this.options.vOffset, this.options.hOffset));\n\n    while(!Foundation.Box.ImNotTouchingYou(this.$element, this.$parent, true) && this.counter){\n      this._reposition(position);\n      this._setPosition();\n    }\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    if(this.options.hover){\n      this.$anchor.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\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.$anchor.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchor.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', function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchor.data('hover', false);\n              }, _this.options.hoverDelay);\n            });\n      }\n    }\n    this.$anchor.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Foundation.Keyboard.findFocusable(_this.$element);\n\n      Foundation.Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchor)) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchor.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.$anchor.is(e.target) || _this.$anchor.find(e.target).length) {\n              return;\n            }\n            if(_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.$anchor.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n    this._setPosition();\n    this.$element.addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Foundation.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      Foundation.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.$anchor.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    if(this.classChanged){\n      var curPositionClass = this.getPositionClass();\n      if(curPositionClass){\n        this.$element.removeClass(curPositionClass);\n      }\n      this.$element.addClass(this.options.positionClass)\n          /*.hide()*/.css({height: '', width: ''});\n      this.classChanged = false;\n      this.counter = 4;\n      this.usedPositions.length = 0;\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      Foundation.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.$anchor.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.$anchor.off('.zf.dropdown');\n\n    Foundation.unregisterPlugin(this);\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 1\n   */\n  vOffset: 1,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  hOffset: 1,\n  /**\n   * Class applied to adjust open position. JS will test and fill this in.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  positionClass: '',\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\n// Window exports\nFoundation.plugin(Dropdown, 'Dropdown');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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 {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n\n    Foundation.Nest.Feather(this.$element, 'dropdown');\n    this._init();\n\n    Foundation.registerPlugin(this, 'DropdownMenu');\n    Foundation.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    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.$element.hasClass(this.options.rightClass) || this.options.alignment === 'right' || Foundation.rtl() || this.$element.parents('.top-bar-right').is('*')) {\n      this.options.alignment = 'right';\n      subs.addClass('opens-left');\n    } else {\n      subs.addClass('opens-right');\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block';\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', 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        if (!$element.is(':last-child')) {\n          $nextElement.children('a:first').focus();\n          e.preventDefault();\n        }\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.find('a:first').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 (Foundation.rtl()) { // 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 (Foundation.rtl()) { // 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 (Foundation.rtl()) { // 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      Foundation.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 = Foundation.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 = Foundation.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 (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    Foundation.Nest.Burn(this.$element, 'dropdown');\n    Foundation.unregisterPlugin(this);\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 `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'left'\n   */\n  alignment: 'left',\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\n// Window exports\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.timerAndImageLoader if equalizer contains images\n */\n\nclass Equalizer {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\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  constructor(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Equalizer');\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    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || Foundation.GetYoDigits(6, 'eq')));\n\tthis.$element.attr('data-mutate', (eqId || Foundation.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((tooSmall !== undefined && tooSmall === false) || tooSmall === undefined){\n      if(imgs.length){\n        Foundation.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 = !Foundation.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    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(Equalizer, 'Equalizer');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.timerAndImageLoader\n */\n\nclass Interchange {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'Interchange');\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    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    $(window).on('resize.zf.interchange', Foundation.util.throttle(() => {\n      this._reflow();\n    }, 50));\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 Foundation.MediaQuery.queries) {\n      if (Foundation.MediaQuery.queries.hasOwnProperty(i)) {\n        var query = Foundation.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      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    //TODO this.\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\n// Window exports\nFoundation.plugin(Interchange, 'Interchange');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Magellan module.\n * @module foundation.magellan\n */\n\nclass Magellan {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n\n    this._init();\n    this.calcPoints();\n\n    Foundation.registerPlugin(this, 'Magellan');\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 || Foundation.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    $(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.$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        _this.scrollToLoc(arrival);\n      });\n    $(window).on('popstate', function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    });\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    // Do nothing if target does not exist to prevent errors\n    if (!$(loc).length) {return false;}\n    this._inTransition = true;\n    var _this = this,\n        scrollPos = Math.round($(loc).offset().top - this.options.threshold / 2 - this.options.barOffset);\n\n    $('html, body').stop(true).animate(\n      { scrollTop: scrollPos },\n      this.options.animationDuration,\n      this.options.animationEasing,\n      function() {_this._inTransition = false; _this._updateActive()}\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    var winPos = /*scrollPos ||*/ parseInt(window.pageYOffset, 10),\n        curIdx;\n\n    if(winPos + this.winHeight === this.docHeight){ curIdx = this.points.length - 1; }\n    else if(winPos < this.points[0]){ curIdx = undefined; }\n    else{\n      var isDown = this.scrollPos < winPos,\n          _this = this,\n          curVisible = this.points.filter(function(p, i){\n            return isDown ? p - _this.options.barOffset <= winPos : p - _this.options.barOffset - _this.options.threshold <= winPos;\n          });\n      curIdx = curVisible.length ? curVisible.length - 1 : 0;\n    }\n\n    this.$active.removeClass(this.options.activeClass);\n    this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(curIdx).data('magellan-target') + '\"]').addClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = \"\";\n      if(curIdx != undefined){\n        hash = this.$active[0].getAttribute('href');\n      }\n      if(hash !== window.location.hash) {\n        if(window.history.pushState){\n          window.history.pushState(null, null, hash);\n        }else{\n          window.location.hash = hash;\n        }\n      }\n    }\n\n    this.scrollPos = winPos;\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  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    Foundation.unregisterPlugin(this);\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 'active'\n   */\n  activeClass: '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  barOffset: 0\n}\n\n// Window exports\nFoundation.plugin(Magellan, 'Magellan');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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 * @requires foundation.util.motion\n */\n\nclass OffCanvas {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.$lastTrigger = $();\n    this.$triggers = $();\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'OffCanvas')\n    Foundation.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    this.$element.addClass(`is-transition-${this.options.transition}`);\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    // 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        $('body').append(this.$overlay);\n      } else {\n        this.$element.siblings('[data-off-canvas-content]').append(this.$overlay);\n      }\n    }\n\n    this.options.isRevealed = this.options.isRevealed || new RegExp(this.options.revealClass, 'g').test(this.$element[0].className);\n\n    if (this.options.isRevealed === true) {\n      this.options.revealOn = this.options.revealOn || this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split('-')[2];\n      this._setMQChecker();\n    }\n    if (!this.options.transitionTime === true) {\n      this.options.transitionTime = parseFloat(window.getComputedStyle($('[data-off-canvas]')[0]).transitionDuration) * 1000;\n    }\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 : $('[data-off-canvas-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    $(window).on('changed.zf.mediaquery', function() {\n      if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    }).one('load.zf.offcanvas', function() {\n      if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\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    var $closer = this.$element.find('[data-close]');\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      if ($closer.length) { $closer.hide(); }\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      if ($closer.length) {\n        $closer.show();\n      }\n    }\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   */\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    /**\n     * Fires when the off-canvas menu opens.\n     * @event OffCanvas#opened\n     */\n    _this.$element.addClass('is-open')\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false')\n        .trigger('opened.zf.offcanvas');\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(Foundation.transitionend(this.$element), function() {\n        _this.$element.find('a, button').eq(0).focus();\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$element.siblings('[data-off-canvas-content]').attr('tabindex', '-1');\n      Foundation.Keyboard.trapFocus(this.$element);\n    }\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    // 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.$element.siblings('[data-off-canvas-content]').removeAttr('tabindex');\n      Foundation.Keyboard.releaseFocus(this.$element);\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    Foundation.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\n    Foundation.unregisterPlugin(this);\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   * 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 0\n   */\n  transitionTime: 0,\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// Window exports\nFoundation.plugin(OffCanvas, 'OffCanvas');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timerAndImageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  constructor(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Orbit');\n    Foundation.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 || Foundation.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      Foundation.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 Foundation.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      if (_this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {//if not the active slide, set css position and display property\n        $(this).css({'position': 'relative', '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          Foundation.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 - flag if the slide should move 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        Foundation.Motion.animateIn(\n          $newSlide.addClass('is-active').css({'position': 'absolute', 'top': 0}),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'position': 'relative', 'display': 'block'})\n            .attr('aria-live', 'polite');\n        });\n\n        Foundation.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    Foundation.unregisterPlugin(this);\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 compatability.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\n// Window exports\nFoundation.plugin(Orbit, 'Orbit');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\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  constructor(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'ResponsiveMenu');\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    // 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') || Foundation.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 (Foundation.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    Foundation.unregisterPlugin(this);\n  }\n}\n\nResponsiveMenu.defaults = {};\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: Foundation._plugins['dropdown-menu'] || null\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Foundation._plugins['drilldown'] || null\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: Foundation._plugins['accordion-menu'] || null\n  }\n};\n\n// Window exports\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveToggle {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\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  constructor(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'ResponsiveToggle');\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    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 (!Foundation.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 (!Foundation.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.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          Foundation.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    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this._init();\n\n    Foundation.registerPlugin(this, 'Reveal');\n    Foundation.Keyboard.register('Reveal', {\n      'ENTER': 'open',\n      'SPACE': 'open',\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    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: Foundation.MediaQuery.current};\n    this.isMobile = mobileSniff();\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      $(window).one('load.zf.reveal', this.open.bind(this));\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    return $('<div></div>')\n      .addClass('reveal-overlay')\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;\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 {\n      top = parseInt(this.options.vOffset, 10);\n    }\n    this.$element.css({top: top + 'px'});\n    // only worry about left if we don't have an overlay or we havea  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.$anchor.length) {\n      this.$anchor.on('keydown.zf.reveal', function(e) {\n        if (e.which === 13 || e.which === 32) {\n          e.stopPropagation();\n          e.preventDefault();\n          _this.open();\n        }\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(`popstate.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 popstate.\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  /**\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    if (this.options.deepLink) {\n      var hash = `#${this.id}`;\n\n      if (window.history.pushState) {\n        window.history.pushState(null, null, hash);\n      } else {\n        window.location.hash = hash;\n      }\n    }\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    var _this = this;\n\n    function addRevealOpenClasses() {\n      if (_this.isMobile) {\n        if(!_this.originalScrollPos) {\n          _this.originalScrollPos = window.pageYOffset;\n        }\n        $('html, body').addClass('is-reveal-open');\n      }\n      else {\n        $('body').addClass('is-reveal-open');\n      }\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        addRevealOpenClasses();\n        Foundation.Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Foundation.Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Foundation.Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Foundation.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    Foundation.Keyboard.trapFocus(this.$element);\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n\n    addRevealOpenClasses();\n\n    setTimeout(() => {\n      this._extraHandlers();\n    }, 0);\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _extraHandlers() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Foundation.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        Foundation.Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n              _this.$anchor.focus();\n            }\n          }\n        });\n      });\n    }\n\n    // lock focus within modal while tabbing\n    this.$element.on('keydown.zf.reveal', function(e) {\n      var $target = $(this);\n      // handle keyboard event with keyboard util\n      Foundation.Keyboard.handleKey(e, 'Reveal', {\n        open: function() {\n          if (_this.$element.find(':focus').is(_this.$element.find('[data-close]'))) {\n            setTimeout(function() { // set focus back to anchor if close button has been activated\n              _this.$anchor.focus();\n            }, 1);\n          } else if ($target.is(_this.focusableElements)) { // dont't trigger if acual element has focus (i.e. inputs, links, ...)\n            _this.open();\n          }\n        },\n        close: function() {\n          if (_this.options.closeOnEsc) {\n            _this.close();\n            _this.$anchor.focus();\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\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        Foundation.Motion.animateOut(this.$overlay, 'fade-out', finishUp);\n      }\n      else {\n        finishUp();\n      }\n\n      Foundation.Motion.animateOut(this.$element, this.options.animationOut);\n    }\n    // jQuery method of hiding\n    else {\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n\n      this.$element.hide(this.options.hideDelay);\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      if (_this.isMobile) {\n        $('html, body').removeClass('is-reveal-open');\n        if(_this.originalScrollPos) {\n          $('body').scrollTop(_this.originalScrollPos);\n          _this.originalScrollPos = null;\n        }\n      }\n      else {\n        $('body').removeClass('is-reveal-open');\n      }\n\n\n      Foundation.Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\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 (_this.options.deepLink) {\n       if (window.history.replaceState) {\n         window.history.replaceState('', document.title, window.location.href.replace(`#${this.id}`, ''));\n       } else {\n         window.location.hash = '';\n       }\n     }\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\n    Foundation.unregisterPlugin(this);\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   * Percentage of screen height the modal should push up from the bottom of the view.\n   * @option\n   * @type {number}\n   * @default 10\n   */\n  btmOffsetPct: 10,\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   * 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.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: 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};\n\n// Window exports\nFoundation.plugin(Reveal, 'Reveal');\n\nfunction iPhoneSniff() {\n  return /iP(ad|hone|od).*OS/.test(window.navigator.userAgent);\n}\n\nfunction androidSniff() {\n  return /Android/.test(window.navigator.userAgent);\n}\n\nfunction mobileSniff() {\n  return iPhoneSniff() || androidSniff();\n}\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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\nclass Slider {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Slider');\n    Foundation.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      },\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 + 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    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    //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    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    Foundation.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') || Foundation.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 (Foundation.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    left = val % step;\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      this.inputs.off('change.zf.slider').on('change.zf.slider', function(e) {\n        var idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      });\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      Foundation.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        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    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(Slider, 'Slider');\n\n}(jQuery);\n\n","'use strict';\n\n!function($) {\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'Sticky');\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    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || Foundation.GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if (!$parent.length) {\n      this.wasWrapped = true;\n    }\n    this.$container = $parent.length ? $parent : $(this.options.container).wrapInner(this.$element);\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass)\n                 .attr({'data-resize': id});\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    $(window).one('load.zf.sticky', 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 - psuedo-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._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  /**\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 = Foundation.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    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    $(window).off(this.scrollListener);\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    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(Sticky, 'Sticky');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.timerAndImageLoader if tabs contain images\n */\n\nclass Tabs {\n  /**\n   * Creates a new instance of tabs.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n\n    this._init();\n    Foundation.registerPlugin(this, 'Tabs');\n    Foundation.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\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[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      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-hidden': !isActive,\n        'aria-labelledby': linkId\n      });\n\n      if(isActive && _this.options.autoFocus){\n        $(window).load(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        Foundation.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 popstate\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n      //need a hash and a relevant anchor in this tabset\n      if(anchor.length) {\n        var $link = this.$element.find('[href=\"'+anchor+'\"]');\n        if ($link.length) {\n          this.selectTab($(anchor), true);\n\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 zplugin has deeplinked at pageload\n            * @event Tabs#deeplink\n            */\n           this.$element.trigger('deeplink.zf.tabs', [$link, $(anchor)]);\n         }\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\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('popstate', 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      Foundation.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    /**\n     * Check for active class on target. Collapse if exists.\n     */\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapseTab($target);\n\n           /**\n            * Fires when the zplugin has successfully collapsed tabs.\n            * @event Tabs#collapse\n            */\n            this.$element.trigger('collapse.zf.tabs', [$target]);\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          hash = $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(hash);\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      var anchor = $target.find('a').attr('href');\n\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[0].hash,\n          $targetContent = this.$tabContent.find(hash);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({'aria-selected': 'true'});\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`)\n        .attr({'aria-hidden': 'false'});\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to Open.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({ 'aria-selected': 'false' });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' });\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.find(`[href=\"${idStr}\"]`).parent(`.${this.options.linkClass}`);\n\n    this._handleTabChange($target, historyHandled);\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 an 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('popstate', this._checkDeepLink);\n    }\n\n    Foundation.unregisterPlugin(this);\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Allows the window to scroll to content of pane specified by hash anchor\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * 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   * Animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * 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 if set to true.\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// Window exports\nFoundation.plugin(Tabs, 'Tabs');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'Toggler');\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    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr('aria-controls', id);\n    // If the target is hidden, add aria-hidden\n    this.$element.attr('aria-expanded', this.$element.is(':hidden') ? false : true);\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      Foundation.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      Foundation.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    this.$element.attr('aria-expanded', isOn ? true : false);\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  destroy() {\n    this.$element.off('.zf.toggler');\n    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(Toggler, 'Toggler');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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 {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n\n    this.isActive = false;\n    this.isClick = false;\n    this._init();\n\n    Foundation.registerPlugin(this, 'Tooltip');\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    var elemId = this.$element.attr('aria-describedby') || Foundation.GetYoDigits(6, 'tooltip');\n\n    this.options.positionClass = this.options.positionClass || this._getPositionClass(this.$element);\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    //helper variables to track movement on collisions\n    this.usedPositions = [];\n    this.counter = 4;\n    this.classChanged = false;\n\n    this._events();\n  }\n\n  /**\n   * Grabs the current positioning class, if present, and returns the value or an empty string.\n   * @private\n   */\n  _getPositionClass(element) {\n    if (!element) { return ''; }\n    // var position = element.attr('class').match(/top|left|right/g);\n    var position = element[0].className.match(/\\b(top|left|right)\\b/g);\n        position = position ? position[0] : '';\n    return position;\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.positionClass} ${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   * Function that gets called if a collision event is detected.\n   * @param {String} position - positioning class to try\n   * @private\n   */\n  _reposition(position) {\n    this.usedPositions.push(position ? position : 'bottom');\n\n    //default, try switching to opposite side\n    if (!position && (this.usedPositions.indexOf('top') < 0)) {\n      this.template.addClass('top');\n    } else if (position === 'top' && (this.usedPositions.indexOf('bottom') < 0)) {\n      this.template.removeClass(position);\n    } else if (position === 'left' && (this.usedPositions.indexOf('right') < 0)) {\n      this.template.removeClass(position)\n          .addClass('right');\n    } else if (position === 'right' && (this.usedPositions.indexOf('left') < 0)) {\n      this.template.removeClass(position)\n          .addClass('left');\n    }\n\n    //if default change didn't work, try bottom or left first\n    else if (!position && (this.usedPositions.indexOf('top') > -1) && (this.usedPositions.indexOf('left') < 0)) {\n      this.template.addClass('left');\n    } else if (position === 'top' && (this.usedPositions.indexOf('bottom') > -1) && (this.usedPositions.indexOf('left') < 0)) {\n      this.template.removeClass(position)\n          .addClass('left');\n    } else if (position === 'left' && (this.usedPositions.indexOf('right') > -1) && (this.usedPositions.indexOf('bottom') < 0)) {\n      this.template.removeClass(position);\n    } else if (position === 'right' && (this.usedPositions.indexOf('left') > -1) && (this.usedPositions.indexOf('bottom') < 0)) {\n      this.template.removeClass(position);\n    }\n    //if nothing cleared, set to bottom\n    else {\n      this.template.removeClass(position);\n    }\n    this.classChanged = true;\n    this.counter--;\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    var position = this._getPositionClass(this.template),\n        $tipDims = Foundation.Box.GetDimensions(this.template),\n        $anchorDims = Foundation.Box.GetDimensions(this.$element),\n        direction = (position === 'left' ? 'left' : ((position === 'right') ? 'left' : 'top')),\n        param = (direction === 'top') ? 'height' : 'width',\n        offset = (param === 'height') ? this.options.vOffset : this.options.hOffset,\n        _this = this;\n\n    if (($tipDims.width >= $tipDims.windowDims.width) || (!this.counter && !Foundation.Box.ImNotTouchingYou(this.template))) {\n      this.template.offset(Foundation.Box.GetOffsets(this.template, this.$element, 'center bottom', this.options.vOffset, this.options.hOffset, true)).css({\n      // this.$element.offset(Foundation.GetOffsets(this.template, this.$element, 'center bottom', this.options.vOffset, this.options.hOffset, true)).css({\n        'width': $anchorDims.windowDims.width - (this.options.hOffset * 2),\n        'height': 'auto'\n      });\n      return false;\n    }\n\n    this.template.offset(Foundation.Box.GetOffsets(this.template, this.$element,'center ' + (position || 'bottom'), this.options.vOffset, this.options.hOffset));\n\n    while(!Foundation.Box.ImNotTouchingYou(this.template) && this.counter) {\n      this._reposition(position);\n      this._setPosition();\n    }\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' && !Foundation.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\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      if (_this.classChanged) {\n        _this.template\n             .removeClass(_this._getPositionClass(_this.template))\n             .addClass(_this.options.positionClass);\n\n       _this.usedPositions = [];\n       _this.counter = 4;\n       _this.classChanged = false;\n      }\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', 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('has-tip top right left')\n                 .removeAttr('aria-describedby aria-haspopup data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n\n    Foundation.unregisterPlugin(this);\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   * Additional positioning classes, set by the JS\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  positionClass: '',\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 10\n   */\n  vOffset: 10,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis, if aligned to a side.\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  hOffset: 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\n// Window exports\nFoundation.plugin(Tooltip, 'Tooltip');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\nFoundation.Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets\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) {\n  var eleDims = GetDimensions(element),\n      top, bottom, left, right;\n\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottom = (eleDims.offset.top + eleDims.height <= parDims.height + parDims.offset.top);\n    top    = (eleDims.offset.top >= parDims.offset.top);\n    left   = (eleDims.offset.left >= parDims.offset.left);\n    right  = (eleDims.offset.left + eleDims.width <= parDims.width + parDims.offset.left);\n  }\n  else {\n    bottom = (eleDims.offset.top + eleDims.height <= eleDims.windowDims.height + eleDims.windowDims.offset.top);\n    top    = (eleDims.offset.top >= eleDims.windowDims.offset.top);\n    left   = (eleDims.offset.left >= eleDims.windowDims.offset.left);\n    right  = (eleDims.offset.left + eleDims.width <= eleDims.windowDims.width);\n  }\n\n  var allDirs = [bottom, top, left, right];\n\n  if (lrOnly) {\n    return left === right === true;\n  }\n\n  if (tbOnly) {\n    return top === bottom === true;\n  }\n\n  return allDirs.indexOf(false) === -1;\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, test){\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\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  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n  switch (position) {\n    case 'top':\n      return {\n        left: (Foundation.rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width : $anchorDims.offset.left),\n        top: $anchorDims.offset.top - ($eleDims.height + vOffset)\n      }\n      break;\n    case 'left':\n      return {\n        left: $anchorDims.offset.left - ($eleDims.width + hOffset),\n        top: $anchorDims.offset.top\n      }\n      break;\n    case 'right':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset,\n        top: $anchorDims.offset.top\n      }\n      break;\n    case 'center top':\n      return {\n        left: ($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2),\n        top: $anchorDims.offset.top - ($eleDims.height + vOffset)\n      }\n      break;\n    case 'center bottom':\n      return {\n        left: isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n      break;\n    case 'center left':\n      return {\n        left: $anchorDims.offset.left - ($eleDims.width + hOffset),\n        top: ($anchorDims.offset.top + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n      }\n      break;\n    case 'center right':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset + 1,\n        top: ($anchorDims.offset.top + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n      }\n      break;\n    case 'center':\n      return {\n        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)\n      }\n      break;\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2,\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    case 'left bottom':\n      return {\n        left: $anchorDims.offset.left,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n      break;\n    case 'right bottom':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset - $eleDims.width,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n      break;\n    default:\n      return {\n        left: (Foundation.rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width : $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n  }\n}\n\n}(jQuery);\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\n!function($) {\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\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(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\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 (Foundation.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  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\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   * 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 = Foundation.Keyboard.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] && Foundation.Keyboard.parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && Foundation.Keyboard.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\nFoundation.Keyboard = Keyboard;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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(Foundation.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\nFoundation.Move = Move;\nFoundation.Motion = Motion;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item\n          .addClass(hasSubClass)\n          .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': 'menu'\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, .menu, .menu > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n    // console.log(      menu.find('.' + subMenuClass + ', .' + subItemClass + ', .has-submenu, .is-submenu-item, .submenu, [data-submenu]')\n    //           .removeClass(subMenuClass + ' ' + subItemClass + ' has-submenu is-submenu-item submenu')\n    //           .removeAttr('data-submenu'));\n    // items.each(function(){\n    //   var $item = $(this),\n    //       $sub = $item.children('ul');\n    //   if($item.parent('[data-submenu]').length){\n    //     $item.removeClass('is-submenu-item ' + subItemClass);\n    //   }\n    //   if($sub.length){\n    //     $item.removeClass('has-submenu');\n    //     $sub.removeClass('submenu ' + subMenuClass).removeAttr('data-submenu');\n    //   }\n    // });\n  }\n}\n\nFoundation.Nest = Nest;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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\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 || (this.readyState === 4) || (this.readyState === 'complete')) {\n      singleImageLoaded();\n    }\n    // Force load the image\n    else {\n      // fix for IE. See https://css-tricks.com/snippets/jquery/fixing-load-in-ie-for-cached-images/\n      var src = $(this).attr('src');\n      $(this).attr('src', src + (src.indexOf('?') >= 0 ? '&' : '?') + (new Date().getTime()));\n      $(this).one('load', function() {\n        singleImageLoaded();\n      });\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nFoundation.Timer = Timer;\nFoundation.onImagesLoaded = onImagesLoaded;\n\n}(jQuery);\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n(function($) {\n\n  $.spotSwipe = {\n    version: '1.0.0',\n    enabled: 'ontouchstart' in document.documentElement,\n    preventDefault: false,\n    moveThreshold: 75,\n    timeThreshold: 200\n  };\n\n  var   startPosX,\n        startPosY,\n        startTime,\n        elapsedTime,\n        isMoving = false;\n\n  function onTouchEnd() {\n    //  alert(this);\n    this.removeEventListener('touchmove', onTouchMove);\n    this.removeEventListener('touchend', onTouchEnd);\n    isMoving = false;\n  }\n\n  function onTouchMove(e) {\n    if ($.spotSwipe.preventDefault) { e.preventDefault(); }\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      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.call(this);\n        $(this).trigger('swipe', dir).trigger(`swipe${dir}`);\n      }\n    }\n  }\n\n  function onTouchStart(e) {\n    if (e.touches.length == 1) {\n      startPosX = e.touches[0].pageX;\n      startPosY = e.touches[0].pageY;\n      isMoving = true;\n      startTime = new Date().getTime();\n      this.addEventListener('touchmove', onTouchMove, false);\n      this.addEventListener('touchend', onTouchEnd, false);\n    }\n  }\n\n  function init() {\n    this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n  }\n\n  function teardown() {\n    this.removeEventListener('touchstart', onTouchStart);\n  }\n\n  $.event.special.swipe = { 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})(jQuery);\n/****************************************************\n * Method for adding psuedo drag events to elements *\n ***************************************************/\n!function($){\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel',function(){\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}(jQuery);\n\n\n//**********************************\n//**From the jQuery Mobile Library**\n//**need to recreate functionality**\n//**and try to improve if possible**\n//**********************************\n\n/* Removing the jQuery function ****\n************************************\n\n(function( $, window, undefined ) {\n\n\tvar $document = $( document ),\n\t\t// supportTouch = $.mobile.support.touch,\n\t\ttouchStartEvent = 'touchstart'//supportTouch ? \"touchstart\" : \"mousedown\",\n\t\ttouchStopEvent = 'touchend'//supportTouch ? \"touchend\" : \"mouseup\",\n\t\ttouchMoveEvent = 'touchmove'//supportTouch ? \"touchmove\" : \"mousemove\";\n\n\t// setup new event shortcuts\n\t$.each( ( \"touchstart touchmove touchend \" +\n\t\t\"swipe swipeleft swiperight\" ).split( \" \" ), function( i, name ) {\n\n\t\t$.fn[ name ] = function( fn ) {\n\t\t\treturn fn ? this.bind( name, fn ) : this.trigger( name );\n\t\t};\n\n\t\t// jQuery < 1.8\n\t\tif ( $.attrFn ) {\n\t\t\t$.attrFn[ name ] = true;\n\t\t}\n\t});\n\n\tfunction triggerCustomEvent( obj, eventType, event, bubble ) {\n\t\tvar originalType = event.type;\n\t\tevent.type = eventType;\n\t\tif ( bubble ) {\n\t\t\t$.event.trigger( event, undefined, obj );\n\t\t} else {\n\t\t\t$.event.dispatch.call( obj, event );\n\t\t}\n\t\tevent.type = originalType;\n\t}\n\n\t// also handles taphold\n\n\t// Also handles swipeleft, swiperight\n\t$.event.special.swipe = {\n\n\t\t// More than this horizontal displacement, and we will suppress scrolling.\n\t\tscrollSupressionThreshold: 30,\n\n\t\t// More time than this, and it isn't a swipe.\n\t\tdurationThreshold: 1000,\n\n\t\t// Swipe horizontal displacement must be more than this.\n\t\thorizontalDistanceThreshold: window.devicePixelRatio >= 2 ? 15 : 30,\n\n\t\t// Swipe vertical displacement must be less than this.\n\t\tverticalDistanceThreshold: window.devicePixelRatio >= 2 ? 15 : 30,\n\n\t\tgetLocation: function ( event ) {\n\t\t\tvar winPageX = window.pageXOffset,\n\t\t\t\twinPageY = window.pageYOffset,\n\t\t\t\tx = event.clientX,\n\t\t\t\ty = event.clientY;\n\n\t\t\tif ( event.pageY === 0 && Math.floor( y ) > Math.floor( event.pageY ) ||\n\t\t\t\tevent.pageX === 0 && Math.floor( x ) > Math.floor( event.pageX ) ) {\n\n\t\t\t\t// iOS4 clientX/clientY have the value that should have been\n\t\t\t\t// in pageX/pageY. While pageX/page/ have the value 0\n\t\t\t\tx = x - winPageX;\n\t\t\t\ty = y - winPageY;\n\t\t\t} else if ( y < ( event.pageY - winPageY) || x < ( event.pageX - winPageX ) ) {\n\n\t\t\t\t// Some Android browsers have totally bogus values for clientX/Y\n\t\t\t\t// when scrolling/zooming a page. Detectable since clientX/clientY\n\t\t\t\t// should never be smaller than pageX/pageY minus page scroll\n\t\t\t\tx = event.pageX - winPageX;\n\t\t\t\ty = event.pageY - winPageY;\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\tx: x,\n\t\t\t\ty: y\n\t\t\t};\n\t\t},\n\n\t\tstart: function( event ) {\n\t\t\tvar data = event.originalEvent.touches ?\n\t\t\t\t\tevent.originalEvent.touches[ 0 ] : event,\n\t\t\t\tlocation = $.event.special.swipe.getLocation( data );\n\t\t\treturn {\n\t\t\t\t\t\ttime: ( new Date() ).getTime(),\n\t\t\t\t\t\tcoords: [ location.x, location.y ],\n\t\t\t\t\t\torigin: $( event.target )\n\t\t\t\t\t};\n\t\t},\n\n\t\tstop: function( event ) {\n\t\t\tvar data = event.originalEvent.touches ?\n\t\t\t\t\tevent.originalEvent.touches[ 0 ] : event,\n\t\t\t\tlocation = $.event.special.swipe.getLocation( data );\n\t\t\treturn {\n\t\t\t\t\t\ttime: ( new Date() ).getTime(),\n\t\t\t\t\t\tcoords: [ location.x, location.y ]\n\t\t\t\t\t};\n\t\t},\n\n\t\thandleSwipe: function( start, stop, thisObject, origTarget ) {\n\t\t\tif ( stop.time - start.time < $.event.special.swipe.durationThreshold &&\n\t\t\t\tMath.abs( start.coords[ 0 ] - stop.coords[ 0 ] ) > $.event.special.swipe.horizontalDistanceThreshold &&\n\t\t\t\tMath.abs( start.coords[ 1 ] - stop.coords[ 1 ] ) < $.event.special.swipe.verticalDistanceThreshold ) {\n\t\t\t\tvar direction = start.coords[0] > stop.coords[ 0 ] ? \"swipeleft\" : \"swiperight\";\n\n\t\t\t\ttriggerCustomEvent( thisObject, \"swipe\", $.Event( \"swipe\", { target: origTarget, swipestart: start, swipestop: stop }), true );\n\t\t\t\ttriggerCustomEvent( thisObject, direction,$.Event( direction, { target: origTarget, swipestart: start, swipestop: stop } ), true );\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn false;\n\n\t\t},\n\n\t\t// This serves as a flag to ensure that at most one swipe event event is\n\t\t// in work at any given time\n\t\teventInProgress: false,\n\n\t\tsetup: function() {\n\t\t\tvar events,\n\t\t\t\tthisObject = this,\n\t\t\t\t$this = $( thisObject ),\n\t\t\t\tcontext = {};\n\n\t\t\t// Retrieve the events data for this element and add the swipe context\n\t\t\tevents = $.data( this, \"mobile-events\" );\n\t\t\tif ( !events ) {\n\t\t\t\tevents = { length: 0 };\n\t\t\t\t$.data( this, \"mobile-events\", events );\n\t\t\t}\n\t\t\tevents.length++;\n\t\t\tevents.swipe = context;\n\n\t\t\tcontext.start = function( event ) {\n\n\t\t\t\t// Bail if we're already working on a swipe event\n\t\t\t\tif ( $.event.special.swipe.eventInProgress ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t$.event.special.swipe.eventInProgress = true;\n\n\t\t\t\tvar stop,\n\t\t\t\t\tstart = $.event.special.swipe.start( event ),\n\t\t\t\t\torigTarget = event.target,\n\t\t\t\t\temitted = false;\n\n\t\t\t\tcontext.move = function( event ) {\n\t\t\t\t\tif ( !start || event.isDefaultPrevented() ) {\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\n\t\t\t\t\tstop = $.event.special.swipe.stop( event );\n\t\t\t\t\tif ( !emitted ) {\n\t\t\t\t\t\temitted = $.event.special.swipe.handleSwipe( start, stop, thisObject, origTarget );\n\t\t\t\t\t\tif ( emitted ) {\n\n\t\t\t\t\t\t\t// Reset the context to make way for the next swipe event\n\t\t\t\t\t\t\t$.event.special.swipe.eventInProgress = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t// prevent scrolling\n\t\t\t\t\tif ( Math.abs( start.coords[ 0 ] - stop.coords[ 0 ] ) > $.event.special.swipe.scrollSupressionThreshold ) {\n\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t}\n\t\t\t\t};\n\n\t\t\t\tcontext.stop = function() {\n\t\t\t\t\t\temitted = true;\n\n\t\t\t\t\t\t// Reset the context to make way for the next swipe event\n\t\t\t\t\t\t$.event.special.swipe.eventInProgress = false;\n\t\t\t\t\t\t$document.off( touchMoveEvent, context.move );\n\t\t\t\t\t\tcontext.move = null;\n\t\t\t\t};\n\n\t\t\t\t$document.on( touchMoveEvent, context.move )\n\t\t\t\t\t.one( touchStopEvent, context.stop );\n\t\t\t};\n\t\t\t$this.on( touchStartEvent, context.start );\n\t\t},\n\n\t\tteardown: function() {\n\t\t\tvar events, context;\n\n\t\t\tevents = $.data( this, \"mobile-events\" );\n\t\t\tif ( events ) {\n\t\t\t\tcontext = events.swipe;\n\t\t\t\tdelete events.swipe;\n\t\t\t\tevents.length--;\n\t\t\t\tif ( events.length === 0 ) {\n\t\t\t\t\t$.removeData( this, \"mobile-events\" );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( context ) {\n\t\t\t\tif ( context.start ) {\n\t\t\t\t\t$( this ).off( touchStartEvent, context.start );\n\t\t\t\t}\n\t\t\t\tif ( context.move ) {\n\t\t\t\t\t$document.off( touchMoveEvent, context.move );\n\t\t\t\t}\n\t\t\t\tif ( context.stop ) {\n\t\t\t\t\t$document.off( touchStopEvent, context.stop );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n\t$.each({\n\t\tswipeleft: \"swipe.left\",\n\t\tswiperight: \"swipe.right\"\n\t}, function( event, sourceEvent ) {\n\n\t\t$.event.special[ event ] = {\n\t\t\tsetup: function() {\n\t\t\t\t$( this ).bind( sourceEvent, $.noop );\n\t\t\t},\n\t\t\tteardown: function() {\n\t\t\t\t$( this ).unbind( sourceEvent );\n\t\t\t}\n\t\t};\n\t});\n})( jQuery, this );\n*/\n","'use strict';\n\n!function($) {\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// Elements with [data-open] will reveal a plugin that supports it when clicked.\n$(document).on('click.zf.trigger', '[data-open]', function() {\n  triggers($(this), 'open');\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.\n$(document).on('click.zf.trigger', '[data-close]', 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\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n$(document).on('click.zf.trigger', '[data-toggle]', 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\n// Elements with [data-closable] will respond to close.zf.trigger events.\n$(document).on('close.zf.trigger', '[data-closable]', function(e){\n  e.stopPropagation();\n  let animation = $(this).data('closable');\n\n  if(animation !== ''){\n    Foundation.Motion.animateOut($(this), animation, function() {\n      $(this).trigger('closed.zf');\n    });\n  }else{\n    $(this).fadeOut().trigger('closed.zf');\n  }\n});\n\n$(document).on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', function() {\n  let id = $(this).data('toggle-focus');\n  $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n});\n\n/**\n* Fires once after all other scripts have loaded\n* @function\n* @private\n*/\n$(window).on('load', () => {\n  checkListeners();\n});\n\nfunction checkListeners() {\n  eventsListener();\n  resizeListener();\n  scrollListener();\n  mutateListener();\n  closemeListener();\n}\n\n//******** only fires this function once on load, if there's something to watch ********\nfunction closemeListener(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.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, 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\n        _this.triggerHandler('close.zf.trigger', [_this]);\n      });\n    });\n  }\n}\n\nfunction resizeListener(debounce){\n  let timer,\n      $nodes = $('[data-resize]');\n  if($nodes.length){\n    $(window).off('resize.zf.trigger')\n    .on('resize.zf.trigger', function(e) {\n      if (timer) { clearTimeout(timer); }\n\n      timer = setTimeout(function(){\n\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      }, debounce || 10);//default time to emit resize event\n    });\n  }\n}\n\nfunction scrollListener(debounce){\n  let timer,\n      $nodes = $('[data-scroll]');\n  if($nodes.length){\n    $(window).off('scroll.zf.trigger')\n    .on('scroll.zf.trigger', function(e){\n      if(timer){ clearTimeout(timer); }\n\n      timer = setTimeout(function(){\n\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      }, debounce || 10);//default time to emit scroll event\n    });\n  }\n}\n\nfunction mutateListener(debounce) {\n    let $nodes = $('[data-mutate]');\n    if ($nodes.length && MutationObserver){\n\t\t\t//trigger all listening elements and signal a mutate event\n      //no IE 9 or 10\n\t\t\t$nodes.each(function () {\n\t\t\t  $(this).triggerHandler('mutateme.zf.trigger');\n\t\t\t});\n    }\n }\n\nfunction eventsListener() {\n  if(!MutationObserver){ return false; }\n  let nodes = document.querySelectorAll('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n      var $target = $(mutationRecordsList[0].target);\n\n\t  //trigger the event handler for the element depending on type\n      switch (mutationRecordsList[0].type) {\n\n        case \"attributes\":\n          if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n\t\t  \t$target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n\t\t  }\n\t\t  if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n\t\t  \t$target.triggerHandler('resizeme.zf.trigger', [$target]);\n\t\t   }\n\t\t  if (mutationRecordsList[0].attributeName === \"style\") {\n\t\t\t  $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n\t\t\t  $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n\t\t  }\n\t\t  break;\n\n        case \"childList\":\n\t\t  $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n\t\t  $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\n// ------------------------------------\n\n// [PH]\n// Foundation.CheckWatchers = checkWatchers;\nFoundation.IHearYou = checkListeners;\n// Foundation.ISeeYou = scrollListener;\n// Foundation.IFeelYou = closemeListener;\n\n}(jQuery);\n\n// function domMutationObserver(debounce) {\n//   // !!! This is coming soon and needs more work; not active  !!! //\n//   var timer,\n//   nodes = document.querySelectorAll('[data-mutate]');\n//   //\n//   if (nodes.length) {\n//     // var 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//\n//\n//     //for the body, we need to listen for all changes effecting the style and class attributes\n//     var bodyObserver = new MutationObserver(bodyMutation);\n//     bodyObserver.observe(document.body, { attributes: true, childList: true, characterData: false, subtree:true, attributeFilter:[\"style\", \"class\"]});\n//\n//\n//     //body callback\n//     function bodyMutation(mutate) {\n//       //trigger all listening elements and signal a mutation event\n//       if (timer) { clearTimeout(timer); }\n//\n//       timer = setTimeout(function() {\n//         bodyObserver.disconnect();\n//         $('[data-mutate]').attr('data-events',\"mutate\");\n//       }, debounce || 150);\n//     }\n//   }\n// }\n","'use strict';\n\n!function($) {\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.timerAndImageLoader\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs {\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @fires ResponsiveAccordionTabs#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  constructor(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    if (!this.$element.attr('id')) {\n      this.$element.attr('id',Foundation.GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'ResponsiveAccordionTabs');\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    // 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    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', 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 (Foundation.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>').remove();\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') || Foundation.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('.zf.ResponsiveAccordionTabs');\n    Foundation.unregisterPlugin(this);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Foundation._plugins.tabs || null\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Foundation._plugins.accordion || null\n  }\n};\n\n// Window exports\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\n}(jQuery);\n","/**\n * File js-enabled.js\n *\n * If Javascript is enabled, replace the <body> class \"no-js\".\n */\ndocument.body.className = document.body.className.replace( 'no-js', 'js' );\n","/**\n * File modal.js\n *\n * Deal with multiple modals and their media.\n */\nwindow.wdsModal = {};\n\n( function( window, $, app ) {\n\n\tlet $modalToggle,\n\t\t$focusableChildren,\n\t\t$player,\n\t\t$tag = document.createElement( 'script' ),\n\t\t$firstScriptTag = document.getElementsByTagName( 'script' )[0],\n\t\tYT;\n\n\t// Constructor.\n\tapp.init = function() {\n\t\tapp.cache();\n\n\t\tif ( app.meetsRequirements() ) {\n\t\t\t$firstScriptTag.parentNode.insertBefore( $tag, $firstScriptTag );\n\t\t\tapp.bindEvents();\n\t\t}\n\t};\n\n\t// Cache all the things.\n\tapp.cache = function() {\n\t\tapp.$c = {\n\t\t\t'body': $( 'body' )\n\t\t};\n\t};\n\n\t// Do we meet the requirements?\n\tapp.meetsRequirements = function() {\n\t\treturn $( '.modal-trigger' ).length;\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function() {\n\n\t\t// Trigger a modal to open.\n\t\tapp.$c.body.on( 'click touchstart', '.modal-trigger', app.openModal );\n\n\t\t// Trigger the close button to close the modal.\n\t\tapp.$c.body.on( 'click touchstart', '.close', app.closeModal );\n\n\t\t// Allow the user to close the modal by hitting the esc key.\n\t\tapp.$c.body.on( 'keydown', app.escKeyClose );\n\n\t\t// Allow the user to close the modal by clicking outside of the modal.\n\t\tapp.$c.body.on( 'click touchstart', 'div.modal-open', app.closeModalByClick );\n\n\t\t// Listen to tabs, trap keyboard if we need to\n\t\tapp.$c.body.on( 'keydown', app.trapKeyboardMaybe );\n\n\t};\n\n\t// Open the modal.\n\tapp.openModal = function() {\n\n\t\t// Store the modal toggle element\n\t\t$modalToggle = $( this );\n\n\t\t// Figure out which modal we're opening and store the object.\n\t\tlet $modal = $( $( this ).data( 'target' ) );\n\n\t\t// Display the modal.\n\t\t$modal.addClass( 'modal-open' );\n\n\t\t// Add body class.\n\t\tapp.$c.body.addClass( 'modal-open' );\n\n\t\t// Find the focusable children of the modal.\n\t\t// This list may be incomplete, really wish jQuery had the :focusable pseudo like jQuery UI does.\n\t\t// For more about :input see: https://api.jquery.com/input-selector/\n\t\t$focusableChildren = $modal.find( 'a, :input, [tabindex]' );\n\n\t\t// Ideally, there is always one (the close button), but you never know.\n\t\tif ( 0 < $focusableChildren.length ) {\n\n\t\t\t// Shift focus to the first focusable element.\n\t\t\t$focusableChildren[0].focus();\n\t\t}\n\n\t};\n\n\t// Close the modal.\n\tapp.closeModal = function() {\n\n\t\t// Figure the opened modal we're closing and store the object.\n\t\tlet $modal = $( $( 'div.modal-open .close' ).data( 'target' ) ),\n\n\t\t\t// Find the iframe in the $modal object.\n\t\t\t$iframe = $modal.find( 'iframe' );\n\n\t\t// Only do this if there are any iframes.\n\t\tif ( $iframe.length ) {\n\n\t\t\t// Get the iframe src URL.\n\t\t\tlet url = $iframe.attr( 'src' );\n\n\t\t\t// Removing/Readding the URL will effectively break the YouTube API.\n\t\t\t// So let's not do that when the iframe URL contains the enablejsapi parameter.\n\t\t\tif ( ! url.includes( 'enablejsapi=1' ) ) {\n\n\t\t\t\t// Remove the source URL, then add it back, so the video can be played again later.\n\t\t\t\t$iframe.attr( 'src', '' ).attr( 'src', url );\n\t\t\t} else {\n\n\t\t\t\t// Use the YouTube API to stop the video.\n\t\t\t\t$player.stopVideo();\n\t\t\t}\n\t\t}\n\n\t\t// Finally, hide the modal.\n\t\t$modal.removeClass( 'modal-open' );\n\n\t\t// Remove the body class.\n\t\tapp.$c.body.removeClass( 'modal-open' );\n\n\t\t// Revert focus back to toggle element\n\t\t$modalToggle.focus();\n\n\t};\n\n\t// Close if \"esc\" key is pressed.\n\tapp.escKeyClose = function( event ) {\n\t\tif ( 27 === event.keyCode ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Close if the user clicks outside of the modal\n\tapp.closeModalByClick = function( event ) {\n\n\t\t// If the parent container is NOT the modal dialog container, close the modal\n\t\tif ( ! $( event.target ).parents( 'div' ).hasClass( 'modal-dialog' ) ) {\n\t\t\tapp.closeModal();\n\t\t}\n\t};\n\n\t// Trap the keyboard into a modal when one is active.\n\tapp.trapKeyboardMaybe = function( event ) {\n\n\t\t// We only need to do stuff when the modal is open and tab is pressed.\n\t\tif ( 9 === event.which && 0 < $( '.modal-open' ).length ) {\n\t\t\tlet $focused = $( ':focus' ),\n\t\t\t\tfocusIndex = $focusableChildren.index( $focused );\n\n\t\t\tif ( 0 === focusIndex && event.shiftKey ) {\n\n\t\t\t\t// If this is the first focusable element, and shift is held when pressing tab, go back to last focusable element.\n\t\t\t\t$focusableChildren[ $focusableChildren.length - 1 ].focus();\n\t\t\t\tevent.preventDefault();\n\t\t\t} else if ( ! event.shiftKey && focusIndex === $focusableChildren.length - 1 ) {\n\n\t\t\t\t// If this is the last focusable element, and shift is not held, go back to the first focusable element.\n\t\t\t\t$focusableChildren[0].focus();\n\t\t\t\tevent.preventDefault();\n\t\t\t}\n\t\t}\n\t};\n\n\t// Hook into YouTube <iframe>.\n\tapp.onYouTubeIframeAPIReady = function() {\n\t\tlet $modal = $( 'div.modal' ),\n\t\t\t$iframeid = $modal.find( 'iframe' ).attr( 'id' );\n\n\t\t$player = new YT.Player( $iframeid, {\n\t\t\tevents: {\n\t\t\t\t'onReady': app.onPlayerReady,\n\t\t\t\t'onStateChange': app.onPlayerStateChange\n\t\t\t}\n\t\t});\n\t};\n\n\t// Do something on player ready.\n\tapp.onPlayerReady = function() {\n\t};\n\n\t// Do something on player state change.\n\tapp.onPlayerStateChange = function() {\n\n\t\t// Set focus to the first focusable element inside of the modal the player is in.\n\t\t$( event.target.a ).parents( '.modal' ).find( 'a, :input, [tabindex]' ).first().focus();\n\t};\n\n\n\t// Engage!\n\t$( app.init );\n})( window, jQuery, window.wdsModal );\n","/**\n * File skip-link-focus-fix.js.\n *\n * Helps with accessibility for keyboard only users.\n *\n * Learn more: https://git.io/vWdr2\n */\n( function() {\n\tvar isWebkit = -1 < navigator.userAgent.toLowerCase().indexOf( 'webkit' ),\n\t\tisOpera = -1 < navigator.userAgent.toLowerCase().indexOf( 'opera' ),\n\t\tisIe = -1 < navigator.userAgent.toLowerCase().indexOf( 'msie' );\n\n\tif ( ( isWebkit || isOpera || isIe ) && document.getElementById && window.addEventListener ) {\n\t\twindow.addEventListener( 'hashchange', function() {\n\t\t\tvar id = location.hash.substring( 1 ),\n\t\t\t\telement;\n\n\t\t\tif ( ! ( /^[A-z0-9_-]+$/ ).test( id ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\telement = document.getElementById( id );\n\n\t\t\tif ( element ) {\n\t\t\t\tif ( ! ( /^(?:a|select|input|button|textarea)$/i ).test( element.tagName ) ) {\n\t\t\t\t\telement.tabIndex = -1;\n\t\t\t\t}\n\n\t\t\t\telement.focus();\n\t\t\t}\n\t\t}, false );\n\t}\n})();\n","/**\n * File: wds-foundation.js\n *\n * We must simply initialize Foundation for Foundation JS to do its thing.\n */\njQuery( document ).foundation();\n","/**\n * File window-ready.js\n *\n * Add a \"ready\" class to <body> when window is ready.\n */\nwindow.wdsWindowReady = {};\n( function( window, $, app ) {\n\n\t// Constructor.\n\tapp.init = function() {\n\t\tapp.cache();\n\t\tapp.bindEvents();\n\t};\n\n\t// Cache document elements.\n\tapp.cache = function() {\n\t\tapp.$c = {\n\t\t\t'window': $( window ),\n\t\t\t'body': $( document.body )\n\t\t};\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function() {\n\t\tapp.$c.window.load( app.addBodyClass );\n\t};\n\n\t// Add a class to <body>.\n\tapp.addBodyClass = function() {\n\t\tapp.$c.body.addClass( 'ready' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n})( window, jQuery, window.wdsWindowReady );\n"]}
+//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["foundation.core.js","foundation.util.mediaQuery.js","foundation.accordionMenu.js","foundation.dropdownMenu.js","foundation.offcanvas.js","foundation.responsiveMenu.js","foundation.responsiveToggle.js","foundation.util.box.js","foundation.util.keyboard.js","foundation.util.motion.js","foundation.util.nest.js","foundation.util.triggers.js","js-enabled.js","skip-link-focus-fix.js","wds-foundation.js","window-ready.js"],"names":["$","FOUNDATION_VERSION","Foundation","version","_plugins","_uuids","rtl","attr","plugin","name","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","GetYoDigits","$element","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","length","namespace","Math","round","pow","random","toString","slice","reflow","elem","i","$elem","find","addBack","$el","opts","warn","thing","split","e","opt","map","el","trim","parseValue","er","getFnName","transitionend","transitions","document","createElement","end","t","style","setTimeout","triggerHandler","util","throttle","func","delay","timer","context","args","arguments","apply","method","$meta","$noJS","appendTo","head","removeClass","MediaQuery","Array","prototype","call","plugClass","undefined","ReferenceError","TypeError","window","fn","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","callback","nextTime","max","clearTimeout","performance","start","Function","bind","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","str","isNaN","parseFloat","replace","jQuery","defaultQueries","landscape","portrait","retina","queries","current","self","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","value","_getCurrentSize","_watcher","atLeast","size","query","get","matchMedia","matches","is","matched","on","newSize","currentSize","styleMedia","media","script","getElementsByTagName","info","id","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","styleObject","reduce","ret","param","parts","val","decodeURIComponent","isArray","AccordionMenu","element","options","extend","defaults","Nest","Feather","Keyboard","register","not","slideUp","multiOpen","$menuLinks","linkId","$sub","children","subId","isActive","hasClass","initPanes","down","_events","$submenu","off","preventDefault","toggle","$elements","parent","$prevElement","$nextElement","$target","eq","first","min","parents","next","handleKey","open","focus","close","up","closeAll","hideAll","handled","stopImmediatePropagation","parentsUntil","add","addClass","slideDown","slideSpeed","$menus","Burn","DropdownMenu","subs","$menuItems","$tabs","verticalClass","rightClass","alignment","changed","hasTouch","ontouchstart","parClass","handleClickFn","target","hasSub","hasClicked","closeOnClick","clickOpen","forceFollow","_hide","_show","closeOnClickInside","disableHover","hoverDelay","autoclose","closingTime","isTab","index","siblings","nextSibling","prevSibling","openSub","closeSub","functions","_isVertical","previous","$body","body","$link","idx","filter","$sibs","clear","Box","ImNotTouchingYou","oldClass","$parentLi","_addBodyHandler","$toClose","somethingToClose","OffCanvas","$lastTrigger","$triggers","transition","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","append","isRevealed","RegExp","revealClass","revealOn","match","_setMQChecker","transitionTime","transitionDuration","_handleKeyboard","reveal","one","$closer","hide","show","event","scrollHeight","clientHeight","scrollTop","allowUp","allowDown","lastY","originalEvent","pageY","stopPropagation","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","autoFocus","trapFocus","cb","releaseFocus","ResponsiveMenu","rules","currentMq","currentPlugin","rulesTree","rule","ruleSize","rulePlugin","MenuPlugins","isEmptyObject","_checkMediaQueries","matchedMq","cssClass","destroy","dropdown","drilldown","accordion","ResponsiveToggle","targetID","$targetMenu","$toggler","animate","input","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","Motion","animateIn","animateOut","GetDimensions","GetOffsets","lrOnly","tbOnly","eleDims","top","bottom","left","right","parDims","offset","height","windowDims","allDirs","Error","rect","getBoundingClientRect","parRect","winRect","winY","pageYOffset","winX","pageXOffset","parentDims","anchor","position","vOffset","hOffset","isOverflow","$eleDims","$anchorDims","keyCodes","commands","getKeyCodes","parseKey","which","keyCode","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","component","commandList","cmds","command","ltr","returnValue","unhandled","findFocusable","componentName","$focusable","$firstFocusable","$lastFocusable","kcs","k","kc","initClasses","activeClasses","animation","Move","duration","anim","prog","move","ts","isIn","initClass","activeClass","reset","offsetWidth","finish","menu","items","subMenuClass","subItemClass","hasSubClass","$item","MutationObserver","prefixes","triggers","fadeOut","checkListeners","eventsListener","resizeListener","scrollListener","mutateListener","closemeListener","yetiBoxes","plugNames","listeners","join","pluginId","debounce","$nodes","nodes","querySelectorAll","listeningElementsMutation","mutationRecordsList","attributeName","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","IHearYou","isWebkit","isOpera","isIe","getElementById","addEventListener","location","hash","substring","tagName","tabIndex","wdsWindowReady","app","init","cache","bindEvents","$c","load","addBodyClass"],"mappings":"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","file":"project.js","sourcesContent":["!function($) {\n\n\"use strict\";\n\nvar FOUNDATION_VERSION = '6.3.1';\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   * Returns a boolean for RTL support\n   */\n  rtl: function(){\n    return $('html').attr('dir') === 'rtl';\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 = this.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   * 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  GetYoDigits: function(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   * 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  transitionend: function($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\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\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 */\nvar foundation = function(method) {\n  var type = typeof method,\n      $meta = $('meta.foundation-mq'),\n      $noJS = $('.no-js');\n\n  if(!$meta.length){\n    $('<meta class=\"foundation-mq\">').appendTo(document.head);\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    Foundation.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(plugClass !== undefined && 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\nwindow.Foundation = Foundation;\n$.fn.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 (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 (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\n}(jQuery);\n","'use strict';\n\n!function($) {\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\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 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).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\nFoundation.MediaQuery = MediaQuery;\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. Dual MIT/BSD license\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    script && script.parentNode && script.parentNode.insertBefore(style, script);\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(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\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 = 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\nFoundation.MediaQuery = MediaQuery;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n\n    Foundation.Nest.Feather(this.$element, 'accordion');\n\n    this._init();\n\n    Foundation.registerPlugin(this, 'AccordionMenu');\n    Foundation.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    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'menu',\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 || Foundation.GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || Foundation.GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n      $elem.attr({\n        'aria-controls': subId,\n        'aria-expanded': isActive,\n        'role': 'menuitem',\n        'id': linkId\n      });\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'menu',\n        'id': subId\n      });\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        $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n          e.preventDefault();\n\n          _this.toggle($submenu);\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      Foundation.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 ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\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    var _this = this;\n\n    if(!this.options.multiOpen) {\n      this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));\n    }\n\n    $target.addClass('is-active').attr({'aria-hidden': false})\n      .parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n\n      //Foundation.Move(this.options.slideSpeed, $target, function() {\n        $target.slideDown(_this.options.slideSpeed, function () {\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  /**\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    var _this = this;\n    //Foundation.Move(this.options.slideSpeed, $target, function(){\n      $target.slideUp(_this.options.slideSpeed, function () {\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    var $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);\n\n    $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\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\n    Foundation.Nest.Burn(this.$element, 'accordion');\n    Foundation.unregisterPlugin(this);\n  }\n}\n\nAccordionMenu.defaults = {\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   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\n// Window exports\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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 {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\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  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n\n    Foundation.Nest.Feather(this.$element, 'dropdown');\n    this._init();\n\n    Foundation.registerPlugin(this, 'DropdownMenu');\n    Foundation.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    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.$element.hasClass(this.options.rightClass) || this.options.alignment === 'right' || Foundation.rtl() || this.$element.parents('.top-bar-right').is('*')) {\n      this.options.alignment = 'right';\n      subs.addClass('opens-left');\n    } else {\n      subs.addClass('opens-right');\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block';\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', 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        if (!$element.is(':last-child')) {\n          $nextElement.children('a:first').focus();\n          e.preventDefault();\n        }\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.find('a:first').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 (Foundation.rtl()) { // 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 (Foundation.rtl()) { // 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 (Foundation.rtl()) { // 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      Foundation.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 = Foundation.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 = Foundation.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 (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    Foundation.Nest.Burn(this.$element, 'dropdown');\n    Foundation.unregisterPlugin(this);\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 `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'left'\n   */\n  alignment: 'left',\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\n// Window exports\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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 * @requires foundation.util.motion\n */\n\nclass OffCanvas {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  constructor(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.$lastTrigger = $();\n    this.$triggers = $();\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'OffCanvas')\n    Foundation.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    this.$element.addClass(`is-transition-${this.options.transition}`);\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    // 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        $('body').append(this.$overlay);\n      } else {\n        this.$element.siblings('[data-off-canvas-content]').append(this.$overlay);\n      }\n    }\n\n    this.options.isRevealed = this.options.isRevealed || new RegExp(this.options.revealClass, 'g').test(this.$element[0].className);\n\n    if (this.options.isRevealed === true) {\n      this.options.revealOn = this.options.revealOn || this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split('-')[2];\n      this._setMQChecker();\n    }\n    if (!this.options.transitionTime === true) {\n      this.options.transitionTime = parseFloat(window.getComputedStyle($('[data-off-canvas]')[0]).transitionDuration) * 1000;\n    }\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 : $('[data-off-canvas-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    $(window).on('changed.zf.mediaquery', function() {\n      if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    }).one('load.zf.offcanvas', function() {\n      if (Foundation.MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\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    var $closer = this.$element.find('[data-close]');\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      if ($closer.length) { $closer.hide(); }\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      if ($closer.length) {\n        $closer.show();\n      }\n    }\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   */\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    /**\n     * Fires when the off-canvas menu opens.\n     * @event OffCanvas#opened\n     */\n    _this.$element.addClass('is-open')\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false')\n        .trigger('opened.zf.offcanvas');\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(Foundation.transitionend(this.$element), function() {\n        _this.$element.find('a, button').eq(0).focus();\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$element.siblings('[data-off-canvas-content]').attr('tabindex', '-1');\n      Foundation.Keyboard.trapFocus(this.$element);\n    }\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    // 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.$element.siblings('[data-off-canvas-content]').removeAttr('tabindex');\n      Foundation.Keyboard.releaseFocus(this.$element);\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    Foundation.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\n    Foundation.unregisterPlugin(this);\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   * 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 0\n   */\n  transitionTime: 0,\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// Window exports\nFoundation.plugin(OffCanvas, 'OffCanvas');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\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  constructor(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'ResponsiveMenu');\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    // 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') || Foundation.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 (Foundation.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    Foundation.unregisterPlugin(this);\n  }\n}\n\nResponsiveMenu.defaults = {};\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: Foundation._plugins['dropdown-menu'] || null\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Foundation._plugins['drilldown'] || null\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: Foundation._plugins['accordion-menu'] || null\n  }\n};\n\n// Window exports\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveToggle {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\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  constructor(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n\n    this._init();\n    this._events();\n\n    Foundation.registerPlugin(this, 'ResponsiveToggle');\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    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 (!Foundation.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 (!Foundation.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.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          Foundation.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    Foundation.unregisterPlugin(this);\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\n// Window exports\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\n\n}(jQuery);\n","'use strict';\n\n!function($) {\n\nFoundation.Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets\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) {\n  var eleDims = GetDimensions(element),\n      top, bottom, left, right;\n\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottom = (eleDims.offset.top + eleDims.height <= parDims.height + parDims.offset.top);\n    top    = (eleDims.offset.top >= parDims.offset.top);\n    left   = (eleDims.offset.left >= parDims.offset.left);\n    right  = (eleDims.offset.left + eleDims.width <= parDims.width + parDims.offset.left);\n  }\n  else {\n    bottom = (eleDims.offset.top + eleDims.height <= eleDims.windowDims.height + eleDims.windowDims.offset.top);\n    top    = (eleDims.offset.top >= eleDims.windowDims.offset.top);\n    left   = (eleDims.offset.left >= eleDims.windowDims.offset.left);\n    right  = (eleDims.offset.left + eleDims.width <= eleDims.windowDims.width);\n  }\n\n  var allDirs = [bottom, top, left, right];\n\n  if (lrOnly) {\n    return left === right === true;\n  }\n\n  if (tbOnly) {\n    return top === bottom === true;\n  }\n\n  return allDirs.indexOf(false) === -1;\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, test){\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\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  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n  switch (position) {\n    case 'top':\n      return {\n        left: (Foundation.rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width : $anchorDims.offset.left),\n        top: $anchorDims.offset.top - ($eleDims.height + vOffset)\n      }\n      break;\n    case 'left':\n      return {\n        left: $anchorDims.offset.left - ($eleDims.width + hOffset),\n        top: $anchorDims.offset.top\n      }\n      break;\n    case 'right':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset,\n        top: $anchorDims.offset.top\n      }\n      break;\n    case 'center top':\n      return {\n        left: ($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2),\n        top: $anchorDims.offset.top - ($eleDims.height + vOffset)\n      }\n      break;\n    case 'center bottom':\n      return {\n        left: isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n      break;\n    case 'center left':\n      return {\n        left: $anchorDims.offset.left - ($eleDims.width + hOffset),\n        top: ($anchorDims.offset.top + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n      }\n      break;\n    case 'center right':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset + 1,\n        top: ($anchorDims.offset.top + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n      }\n      break;\n    case 'center':\n      return {\n        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)\n      }\n      break;\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2,\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    case 'left bottom':\n      return {\n        left: $anchorDims.offset.left,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n      break;\n    case 'right bottom':\n      return {\n        left: $anchorDims.offset.left + $anchorDims.width + hOffset - $eleDims.width,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n      break;\n    default:\n      return {\n        left: (Foundation.rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width : $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n  }\n}\n\n}(jQuery);\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\n!function($) {\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\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(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\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 (Foundation.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  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\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   * 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 = Foundation.Keyboard.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] && Foundation.Keyboard.parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && Foundation.Keyboard.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\nFoundation.Keyboard = Keyboard;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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(Foundation.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\nFoundation.Move = Move;\nFoundation.Motion = Motion;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item\n          .addClass(hasSubClass)\n          .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': 'menu'\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, .menu, .menu > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n    // console.log(      menu.find('.' + subMenuClass + ', .' + subItemClass + ', .has-submenu, .is-submenu-item, .submenu, [data-submenu]')\n    //           .removeClass(subMenuClass + ' ' + subItemClass + ' has-submenu is-submenu-item submenu')\n    //           .removeAttr('data-submenu'));\n    // items.each(function(){\n    //   var $item = $(this),\n    //       $sub = $item.children('ul');\n    //   if($item.parent('[data-submenu]').length){\n    //     $item.removeClass('is-submenu-item ' + subItemClass);\n    //   }\n    //   if($sub.length){\n    //     $item.removeClass('has-submenu');\n    //     $sub.removeClass('submenu ' + subMenuClass).removeAttr('data-submenu');\n    //   }\n    // });\n  }\n}\n\nFoundation.Nest = Nest;\n\n}(jQuery);\n","'use strict';\n\n!function($) {\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// Elements with [data-open] will reveal a plugin that supports it when clicked.\n$(document).on('click.zf.trigger', '[data-open]', function() {\n  triggers($(this), 'open');\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.\n$(document).on('click.zf.trigger', '[data-close]', 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\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n$(document).on('click.zf.trigger', '[data-toggle]', 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\n// Elements with [data-closable] will respond to close.zf.trigger events.\n$(document).on('close.zf.trigger', '[data-closable]', function(e){\n  e.stopPropagation();\n  let animation = $(this).data('closable');\n\n  if(animation !== ''){\n    Foundation.Motion.animateOut($(this), animation, function() {\n      $(this).trigger('closed.zf');\n    });\n  }else{\n    $(this).fadeOut().trigger('closed.zf');\n  }\n});\n\n$(document).on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', function() {\n  let id = $(this).data('toggle-focus');\n  $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n});\n\n/**\n* Fires once after all other scripts have loaded\n* @function\n* @private\n*/\n$(window).on('load', () => {\n  checkListeners();\n});\n\nfunction checkListeners() {\n  eventsListener();\n  resizeListener();\n  scrollListener();\n  mutateListener();\n  closemeListener();\n}\n\n//******** only fires this function once on load, if there's something to watch ********\nfunction closemeListener(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.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, 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\n        _this.triggerHandler('close.zf.trigger', [_this]);\n      });\n    });\n  }\n}\n\nfunction resizeListener(debounce){\n  let timer,\n      $nodes = $('[data-resize]');\n  if($nodes.length){\n    $(window).off('resize.zf.trigger')\n    .on('resize.zf.trigger', function(e) {\n      if (timer) { clearTimeout(timer); }\n\n      timer = setTimeout(function(){\n\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      }, debounce || 10);//default time to emit resize event\n    });\n  }\n}\n\nfunction scrollListener(debounce){\n  let timer,\n      $nodes = $('[data-scroll]');\n  if($nodes.length){\n    $(window).off('scroll.zf.trigger')\n    .on('scroll.zf.trigger', function(e){\n      if(timer){ clearTimeout(timer); }\n\n      timer = setTimeout(function(){\n\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      }, debounce || 10);//default time to emit scroll event\n    });\n  }\n}\n\nfunction mutateListener(debounce) {\n    let $nodes = $('[data-mutate]');\n    if ($nodes.length && MutationObserver){\n\t\t\t//trigger all listening elements and signal a mutate event\n      //no IE 9 or 10\n\t\t\t$nodes.each(function () {\n\t\t\t  $(this).triggerHandler('mutateme.zf.trigger');\n\t\t\t});\n    }\n }\n\nfunction eventsListener() {\n  if(!MutationObserver){ return false; }\n  let nodes = document.querySelectorAll('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n      var $target = $(mutationRecordsList[0].target);\n\n\t  //trigger the event handler for the element depending on type\n      switch (mutationRecordsList[0].type) {\n\n        case \"attributes\":\n          if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n\t\t  \t$target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n\t\t  }\n\t\t  if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n\t\t  \t$target.triggerHandler('resizeme.zf.trigger', [$target]);\n\t\t   }\n\t\t  if (mutationRecordsList[0].attributeName === \"style\") {\n\t\t\t  $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n\t\t\t  $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n\t\t  }\n\t\t  break;\n\n        case \"childList\":\n\t\t  $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n\t\t  $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\n// ------------------------------------\n\n// [PH]\n// Foundation.CheckWatchers = checkWatchers;\nFoundation.IHearYou = checkListeners;\n// Foundation.ISeeYou = scrollListener;\n// Foundation.IFeelYou = closemeListener;\n\n}(jQuery);\n\n// function domMutationObserver(debounce) {\n//   // !!! This is coming soon and needs more work; not active  !!! //\n//   var timer,\n//   nodes = document.querySelectorAll('[data-mutate]');\n//   //\n//   if (nodes.length) {\n//     // var 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//\n//\n//     //for the body, we need to listen for all changes effecting the style and class attributes\n//     var bodyObserver = new MutationObserver(bodyMutation);\n//     bodyObserver.observe(document.body, { attributes: true, childList: true, characterData: false, subtree:true, attributeFilter:[\"style\", \"class\"]});\n//\n//\n//     //body callback\n//     function bodyMutation(mutate) {\n//       //trigger all listening elements and signal a mutation event\n//       if (timer) { clearTimeout(timer); }\n//\n//       timer = setTimeout(function() {\n//         bodyObserver.disconnect();\n//         $('[data-mutate]').attr('data-events',\"mutate\");\n//       }, debounce || 150);\n//     }\n//   }\n// }\n","/**\n * File js-enabled.js\n *\n * If Javascript is enabled, replace the <body> class \"no-js\".\n */\ndocument.body.className = document.body.className.replace( 'no-js', 'js' );\n","/**\n * File skip-link-focus-fix.js.\n *\n * Helps with accessibility for keyboard only users.\n *\n * Learn more: https://git.io/vWdr2\n */\n( function() {\n\tvar isWebkit = -1 < navigator.userAgent.toLowerCase().indexOf( 'webkit' ),\n\t\tisOpera = -1 < navigator.userAgent.toLowerCase().indexOf( 'opera' ),\n\t\tisIe = -1 < navigator.userAgent.toLowerCase().indexOf( 'msie' );\n\n\tif ( ( isWebkit || isOpera || isIe ) && document.getElementById && window.addEventListener ) {\n\t\twindow.addEventListener( 'hashchange', function() {\n\t\t\tvar id = location.hash.substring( 1 ),\n\t\t\t\telement;\n\n\t\t\tif ( ! ( /^[A-z0-9_-]+$/ ).test( id ) ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\telement = document.getElementById( id );\n\n\t\t\tif ( element ) {\n\t\t\t\tif ( ! ( /^(?:a|select|input|button|textarea)$/i ).test( element.tagName ) ) {\n\t\t\t\t\telement.tabIndex = -1;\n\t\t\t\t}\n\n\t\t\t\telement.focus();\n\t\t\t}\n\t\t}, false );\n\t}\n})();\n","/**\n * File: wds-foundation.js\n *\n * We must simply initialize Foundation for Foundation JS to do its thing.\n */\njQuery( document ).foundation();\n","/**\n * File window-ready.js\n *\n * Add a \"ready\" class to <body> when window is ready.\n */\nwindow.wdsWindowReady = {};\n( function( window, $, app ) {\n\n\t// Constructor.\n\tapp.init = function() {\n\t\tapp.cache();\n\t\tapp.bindEvents();\n\t};\n\n\t// Cache document elements.\n\tapp.cache = function() {\n\t\tapp.$c = {\n\t\t\t'window': $( window ),\n\t\t\t'body': $( document.body )\n\t\t};\n\t};\n\n\t// Combine all events.\n\tapp.bindEvents = function() {\n\t\tapp.$c.window.load( app.addBodyClass );\n\t};\n\n\t// Add a class to <body>.\n\tapp.addBodyClass = function() {\n\t\tapp.$c.body.addClass( 'ready' );\n\t};\n\n\t// Engage!\n\t$( app.init );\n})( window, jQuery, window.wdsWindowReady );\n"]}
diff --git a/assets/scripts/project.min.js b/assets/scripts/project.min.js
index e5b2bedf5..8482811bf 100644
--- a/assets/scripts/project.min.js
+++ b/assets/scripts/project.min.js
@@ -1,5 +1,2 @@
-"use strict";function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function functionName(fn){if(void 0===Function.prototype.name){var funcNameRegex=/function\s([^(]{1,})\(/,results=funcNameRegex.exec(fn.toString());return results&&results.length>1?results[1].trim():""}return void 0===fn.prototype?fn.constructor.name:fn.prototype.constructor.name}function parseValue(str){return"true"===str||"false"!==str&&(isNaN(1*str)?str:parseFloat(str))}function hyphenate(str){return str.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}var Foundation={version:"6.3.1",_plugins:{},_uuids:[],rtl:function(){return"rtl"===$("html").attr("dir")},plugin:function(_plugin,name){var className=name||functionName(_plugin),attrName=hyphenate(className);this._plugins[attrName]=this[className]=_plugin},registerPlugin:function(plugin,name){var pluginName=name?hyphenate(name):functionName(plugin.constructor).toLowerCase();plugin.uuid=this.GetYoDigits(6,pluginName),plugin.$element.attr("data-"+pluginName)||plugin.$element.attr("data-"+pluginName,plugin.uuid),plugin.$element.data("zfPlugin")||plugin.$element.data("zfPlugin",plugin),plugin.$element.trigger("init.zf."+pluginName),this._uuids.push(plugin.uuid)},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").trigger("destroyed.zf."+pluginName);for(var prop in plugin)plugin[prop]=null},reInit:function(plugins){var isJQ=plugins instanceof $;try{if(isJQ)plugins.each(function(){$(this).data("zfPlugin")._init()});else{var type=void 0===plugins?"undefined":_typeof(plugins),_this=this;({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))}})[type](plugins)}}catch(err){console.error(err)}finally{return plugins}},GetYoDigits:function(length,namespace){return length=length||6,Math.round(Math.pow(36,length+1)-Math.random()*Math.pow(36,length)).toString(36).slice(1)+(namespace?"-"+namespace:"")},reflow:function(elem,plugins){void 0===plugins?plugins=Object.keys(this._plugins):"string"==typeof plugins&&(plugins=[plugins]);var _this=this;$.each(plugins,function(i,name){var plugin=_this._plugins[name];$(elem).find("[data-"+name+"]").addBack("[data-"+name+"]").each(function(){var $el=$(this),opts={};if($el.data("zfPlugin"))return void console.warn("Tried to initialize "+name+" on an element that already has a Foundation plugin.");$el.attr("data-options")&&$el.attr("data-options").split(";").forEach(function(e,i){var opt=e.split(":").map(function(el){return el.trim()});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,transitionend:function($elem){var end,transitions={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},elem=document.createElement("div");for(var t in transitions)void 0!==elem.style[t]&&(end=transitions[t]);return end||(end=setTimeout(function(){$elem.triggerHandler("transitionend",[$elem])},1),"transitionend")}};Foundation.util={throttle:function(func,delay){var timer=null;return function(){var context=this,args=arguments;null===timer&&(timer=setTimeout(function(){func.apply(context,args),timer=null},delay))}}};var foundation=function(method){var type=void 0===method?"undefined":_typeof(method),$meta=$("meta.foundation-mq"),$noJS=$(".no-js");if($meta.length||$('<meta class="foundation-mq">').appendTo(document.head),$noJS.length&&$noJS.removeClass("no-js"),"undefined"===type)Foundation.MediaQuery._init(),Foundation.reflow(this);else{if("string"!==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.");var args=Array.prototype.slice.call(arguments,1),plugClass=this.data("zfPlugin");if(void 0===plugClass||void 0===plugClass[method])throw new ReferenceError("We're sorry, '"+method+"' is not an available method for "+(plugClass?functionName(plugClass):"this element")+".");1===this.length?plugClass[method].apply(plugClass,args):this.each(function(i,el){plugClass[method].apply($(el).data("zfPlugin"),args)})}return this};window.Foundation=Foundation,$.fn.foundation=foundation,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var vendors=["webkit","moz"],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(),nextTime=Math.max(lastTime+16,now);return setTimeout(function(){callback(lastTime=nextTime)},nextTime-now)},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(oThis){if("function"!=typeof this)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)))};return this.prototype&&(fNOP.prototype=this.prototype),fBound.prototype=new fNOP,fBound})}(jQuery);var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function parseStyleToObject(str){var styleObject={};return"string"!=typeof str?styleObject:(str=str.trim().slice(1,-1))?styleObject=str.split("&").reduce(function(ret,param){var parts=param.replace(/\+/g," ").split("="),key=parts[0],val=parts[1];return key=decodeURIComponent(key),val=void 0===val?null:decodeURIComponent(val),ret.hasOwnProperty(key)?Array.isArray(ret[key])?ret[key].push(val):ret[key]=[ret[key],val]:ret[key]=val,ret},{}):styleObject}var MediaQuery={queries:[],current:"",_init:function(){var namedQueries,self=this,extractedStyles=$(".foundation-mq").css("font-family");namedQueries=parseStyleToObject(extractedStyles);for(var key in namedQueries)namedQueries.hasOwnProperty(key)&&self.queries.push({name:key,value:"only screen and (min-width: "+namedQueries[key]+")"});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(size){var query=this.get(size);return!!query&&window.matchMedia(query).matches},is:function(size){return size=size.trim().split(" "),size.length>1&&"only"===size[1]?size[0]===this._getCurrentSize():this.atLeast(size[0])},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}return null},_getCurrentSize:function(){for(var matched,i=0;i<this.queries.length;i++){var query=this.queries[i];window.matchMedia(query.value).matches&&(matched=query)}return"object"===(void 0===matched?"undefined":_typeof(matched))?matched.name:matched},_watcher:function(){var _this=this;$(window).on("resize.zf.mediaquery",function(){var newSize=_this._getCurrentSize(),currentSize=_this.current;newSize!==currentSize&&(_this.current=newSize,$(window).trigger("changed.zf.mediaquery",[newSize,currentSize]))})}};Foundation.MediaQuery=MediaQuery,window.matchMedia||(window.matchMedia=function(){var styleMedia=window.styleMedia||window.media;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),info="getComputedStyle"in window&&window.getComputedStyle(style,null)||style.currentStyle,styleMedia={matchMedium:function(media){var text="@media "+media+"{ #matchmediajs-test { width: 1px; } }";return style.styleSheet?style.styleSheet.cssText=text:style.textContent=text,"1px"===info.width}}}return function(media){return{matches:styleMedia.matchMedium(media||"all"),media:media||"all"}}}()),Foundation.MediaQuery=MediaQuery}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Abide=function(){function Abide(element){var options=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};_classCallCheck(this,Abide),this.$element=element,this.options=$.extend({},Abide.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Abide")}return _createClass(Abide,[{key:"_init",value:function(){this.$inputs=this.$element.find("input, textarea, select"),this._events()}},{key:"_events",value:function(){var _this2=this;this.$element.off(".abide").on("reset.zf.abide",function(){_this2.resetForm()}).on("submit.zf.abide",function(){return _this2.validateForm()}),"fieldChange"===this.options.validateOn&&this.$inputs.off("change.zf.abide").on("change.zf.abide",function(e){_this2.validateInput($(e.target))}),this.options.liveValidate&&this.$inputs.off("input.zf.abide").on("input.zf.abide",function(e){_this2.validateInput($(e.target))}),this.options.validateOnBlur&&this.$inputs.off("blur.zf.abide").on("blur.zf.abide",function(e){_this2.validateInput($(e.target))})}},{key:"_reflow",value:function(){this._init()}},{key:"requiredCheck",value:function($el){if(!$el.attr("required"))return!0;var isGood=!0;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");opt.length&&opt.val()||(isGood=!1);break;default:$el.val()&&$el.val().length||(isGood=!1)}return isGood}},{key:"findFormError",value:function($el){var $error=$el.siblings(this.options.formErrorSelector);return $error.length||($error=$el.parent().find(this.options.formErrorSelector)),$error}},{key:"findLabel",value:function($el){var id=$el[0].id,$label=this.$element.find('label[for="'+id+'"]');return $label.length?$label:$el.closest("label")}},{key:"findRadioLabels",value:function($els){var _this3=this,labels=$els.map(function(i,el){var id=el.id,$label=_this3.$element.find('label[for="'+id+'"]');return $label.length||($label=$(el).closest("label")),$label[0]});return $(labels)}},{key:"addErrorClasses",value:function($el){var $label=this.findLabel($el),$formError=this.findFormError($el);$label.length&&$label.addClass(this.options.labelErrorClass),$formError.length&&$formError.addClass(this.options.formErrorClass),$el.addClass(this.options.inputErrorClass).attr("data-invalid","")}},{key:"removeRadioErrorClasses",value:function(groupName){var $els=this.$element.find(':radio[name="'+groupName+'"]'),$labels=this.findRadioLabels($els),$formErrors=this.findFormError($els);$labels.length&&$labels.removeClass(this.options.labelErrorClass),$formErrors.length&&$formErrors.removeClass(this.options.formErrorClass),$els.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"removeErrorClasses",value:function($el){if("radio"==$el[0].type)return this.removeRadioErrorClasses($el.attr("name"));var $label=this.findLabel($el),$formError=this.findFormError($el);$label.length&&$label.removeClass(this.options.labelErrorClass),$formError.length&&$formError.removeClass(this.options.formErrorClass),$el.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"validateInput",value:function($el){var clearRequire=this.requiredCheck($el),validated=!1,customValidator=!0,validator=$el.attr("data-validator"),equalTo=!0;if($el.is("[data-abide-ignore]")||$el.is('[type="hidden"]')||$el.is("[disabled]"))return!0;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)}validator&&(customValidator=this.matchValidation($el,validator,$el.attr("required"))),$el.attr("data-equalto")&&(equalTo=this.options.validators.equalTo($el));var goodToGo=-1===[clearRequire,validated,customValidator,equalTo].indexOf(!1),message=(goodToGo?"valid":"invalid")+".zf.abide";if(goodToGo){var dependentElements=this.$element.find('[data-equalto="'+$el.attr("id")+'"]');if(dependentElements.length){var _this=this;dependentElements.each(function(){$(this).val()&&_this.validateInput($(this))})}}return this[goodToGo?"removeErrorClasses":"addErrorClasses"]($el),$el.trigger(message,[$el]),goodToGo}},{key:"validateForm",value:function(){var acc=[],_this=this;this.$inputs.each(function(){acc.push(_this.validateInput($(this)))});var noError=-1===acc.indexOf(!1);return this.$element.find("[data-abide-error]").css("display",noError?"none":"block"),this.$element.trigger((noError?"formvalid":"forminvalid")+".zf.abide",[this.$element]),noError}},{key:"validateText",value:function($el,pattern){pattern=pattern||$el.attr("pattern")||$el.attr("type");var inputText=$el.val(),valid=!1;return inputText.length?valid=this.options.patterns.hasOwnProperty(pattern)?this.options.patterns[pattern].test(inputText):pattern===$el.attr("type")||new RegExp(pattern).test(inputText):$el.prop("required")||(valid=!0),valid}},{key:"validateRadio",value:function(groupName){var $group=this.$element.find(':radio[name="'+groupName+'"]'),valid=!1,required=!1;return $group.each(function(i,e){$(e).attr("required")&&(required=!0)}),required||(valid=!0),valid||$group.each(function(i,e){$(e).prop("checked")&&(valid=!0)}),valid}},{key:"matchValidation",value:function($el,validators,required){var _this4=this;return required=!!required,-1===validators.split(" ").map(function(v){return _this4.options.validators[v]($el,required,$el.parent())}).indexOf(!1)}},{key:"resetForm",value:function(){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("").removeAttr("data-invalid"),$(":input:radio",$form).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),$(":input:checkbox",$form).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),$form.trigger("formreset.zf.abide",[$form])}},{key:"destroy",value:function(){var _this=this;this.$element.off(".abide").find("[data-abide-error]").css("display","none"),this.$inputs.off(".abide").each(function(){_this.removeErrorClasses($(this))}),Foundation.unregisterPlugin(this)}}]),Abide}();Abide.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}|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})$/},validators:{equalTo:function(el,required,parent){return $("#"+el.attr("data-equalto")).val()===el.val()}}},Foundation.plugin(Abide,"Abide")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Accordion=function(){function Accordion(element,options){_classCallCheck(this,Accordion),this.$element=element,this.options=$.extend({},Accordion.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Accordion"),Foundation.Keyboard.register("Accordion",{ENTER:"toggle",SPACE:"toggle",ARROW_DOWN:"next",ARROW_UP:"previous"})}return _createClass(Accordion,[{key:"_init",value:function(){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||Foundation.GetYoDigits(6,"accordion"),linkId=el.id||id+"-label";$el.find("a:first").attr({"aria-controls":id,role:"tab",id:linkId,"aria-expanded":!1,"aria-selected":!1}),$content.attr({role:"tabpanel","aria-labelledby":linkId,"aria-hidden":!0,id:id})});var $initActive=this.$element.find(".is-active").children("[data-tab-content]");$initActive.length&&this.down($initActive,!0),this._events()}},{key:"_events",value:function(){var _this=this;this.$tabs.each(function(){var $elem=$(this),$tabContent=$elem.children("[data-tab-content]");$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){Foundation.Keyboard.handleKey(e,"Accordion",{toggle:function(){_this.toggle($tabContent)},next:function(){var $a=$elem.next().find("a").focus();_this.options.multiExpand||$a.trigger("click.zf.accordion")},previous:function(){var $a=$elem.prev().find("a").focus();_this.options.multiExpand||$a.trigger("click.zf.accordion")},handled:function(){e.preventDefault(),e.stopPropagation()}})})})}},{key:"toggle",value:function($target){$target.parent().hasClass("is-active")?this.up($target):this.down($target)}},{key:"down",value:function($target,firstTime){var _this2=this;if($target.attr("aria-hidden",!1).parent("[data-tab-content]").addBack().parent().addClass("is-active"),!this.options.multiExpand&&!firstTime){var $currentActive=this.$element.children(".is-active").children("[data-tab-content]");$currentActive.length&&this.up($currentActive.not($target))}$target.slideDown(this.options.slideSpeed,function(){_this2.$element.trigger("down.zf.accordion",[$target])}),$("#"+$target.attr("aria-labelledby")).attr({"aria-expanded":!0,"aria-selected":!0})}},{key:"up",value:function($target){var $aunts=$target.parent().siblings(),_this=this;(this.options.allowAllClosed||$aunts.hasClass("is-active"))&&$target.parent().hasClass("is-active")&&($target.slideUp(_this.options.slideSpeed,function(){_this.$element.trigger("up.zf.accordion",[$target])}),$target.attr("aria-hidden",!0).parent().removeClass("is-active"),$("#"+$target.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"),Foundation.unregisterPlugin(this)}}]),Accordion}();Accordion.defaults={slideSpeed:250,multiExpand:!1,allowAllClosed:!1},Foundation.plugin(Accordion,"Accordion")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var AccordionMenu=function(){function AccordionMenu(element,options){_classCallCheck(this,AccordionMenu),this.$element=element,this.options=$.extend({},AccordionMenu.defaults,this.$element.data(),options),Foundation.Nest.Feather(this.$element,"accordion"),this._init(),Foundation.registerPlugin(this,"AccordionMenu"),Foundation.Keyboard.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}return _createClass(AccordionMenu,[{key:"_init",value:function(){this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"menu","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var linkId=this.id||Foundation.GetYoDigits(6,"acc-menu-link"),$elem=$(this),$sub=$elem.children("[data-submenu]"),subId=$sub[0].id||Foundation.GetYoDigits(6,"acc-menu"),isActive=$sub.hasClass("is-active");$elem.attr({"aria-controls":subId,"aria-expanded":isActive,role:"menuitem",id:linkId}),$sub.attr({"aria-labelledby":linkId,"aria-hidden":!isActive,role:"menu",id:subId})});var initPanes=this.$element.find(".is-active");if(initPanes.length){var _this=this;initPanes.each(function(){_this.down($(this))})}this._events()}},{key:"_events",value:function(){var _this=this;this.$element.find("li").each(function(){var $submenu=$(this).children("[data-submenu]");$submenu.length&&$(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 $prevElement,$nextElement,$element=$(this),$elements=$element.parent("ul").children("li"),$target=$element.children("[data-submenu]");$elements.each(function(i){if($(this).is($element))return $prevElement=$elements.eq(Math.max(0,i-1)).find("a").first(),$nextElement=$elements.eq(Math.min(i+1,$elements.length-1)).find("a").first(),$(this).children("[data-submenu]:visible").length&&($nextElement=$element.find("li:first-child").find("a").first()),$(this).is(":first-child")?$prevElement=$element.parents("li").first().find("a").first():$prevElement.parents("li").first().children("[data-submenu]:visible").length&&($prevElement=$prevElement.parents("li").find("li:last-child").find("a").first()),void($(this).is(":last-child")&&($nextElement=$element.parents("li").first().next("li").find("a").first()))}),Foundation.Keyboard.handleKey(e,"AccordionMenu",{open:function(){$target.is(":hidden")&&(_this.down($target),$target.find("li").first().find("a").first().focus())},close:function(){$target.length&&!$target.is(":hidden")?_this.up($target):$element.parent("[data-submenu]").length&&(_this.up($element.parent("[data-submenu]")),$element.parents("li").first().find("a").first().focus())},up:function(){return $prevElement.focus(),!0},down:function(){return $nextElement.focus(),!0},toggle:function(){$element.children("[data-submenu]").length&&_this.toggle($element.children("[data-submenu]"))},closeAll:function(){_this.hideAll()},handled:function(preventDefault){preventDefault&&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($target){$target.is(":animated")||($target.is(":hidden")?this.down($target):this.up($target))}},{key:"down",value:function($target){var _this=this;this.options.multiOpen||this.up(this.$element.find(".is-active").not($target.parentsUntil(this.$element).add($target))),$target.addClass("is-active").attr({"aria-hidden":!1}).parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),$target.slideDown(_this.options.slideSpeed,function(){_this.$element.trigger("down.zf.accordionMenu",[$target])})}},{key:"up",value:function($target){var _this=this;$target.slideUp(_this.options.slideSpeed,function(){_this.$element.trigger("up.zf.accordionMenu",[$target])}),$target.find("[data-submenu]").slideUp(0).addBack().attr("aria-hidden",!0).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"),Foundation.Nest.Burn(this.$element,"accordion"),Foundation.unregisterPlugin(this)}}]),AccordionMenu}();AccordionMenu.defaults={slideSpeed:250,multiOpen:!0},Foundation.plugin(AccordionMenu,"AccordionMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Drilldown=function(){function Drilldown(element,options){_classCallCheck(this,Drilldown),this.$element=element,this.options=$.extend({},Drilldown.defaults,this.$element.data(),options),Foundation.Nest.Feather(this.$element,"drilldown"),this._init(),Foundation.registerPlugin(this,"Drilldown"),Foundation.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"})}return _createClass(Drilldown,[{key:"_init",value:function(){this.$submenuAnchors=this.$element.find("li.is-drilldown-submenu-parent").children("a"),this.$submenus=this.$submenuAnchors.parent("li").children("[data-submenu]"),this.$menuItems=this.$element.find("li").not(".js-drilldown-back").attr("role","menuitem").find("a"),this.$element.attr("data-mutate",this.$element.attr("data-drilldown")||Foundation.GetYoDigits(6,"drilldown")),this._prepareMenu(),this._registerEvents(),this._keyboardEvents()}},{key:"_prepareMenu",value:function(){var _this=this;this.$submenuAnchors.each(function(){var $link=$(this),$sub=$link.parent();_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="menu-item"></li>'),$link.data("savedHref",$link.attr("href")).removeAttr("href").attr("tabindex",0),
-$link.children("[data-submenu]").attr({"aria-hidden":!0,tabindex:0,role:"menu"}),_this._events($link)}),this.$submenus.each(function(){var $menu=$(this);if(!$menu.find(".js-drilldown-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"),this.options.autoHeight||this.$submenus.addClass("drilldown-submenu-cover-previous"),this.$element.parent().hasClass("is-drilldown")||(this.$wrapper=$(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($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()),_this._show($elem.parent("li")),_this.options.closeOnClick){var $body=$("body");$body.off(".zf.drilldown").on("click.zf.drilldown",function(e){e.target===_this.$element[0]||$.contains(_this.$element[0],e.target)||(e.preventDefault(),_this._hideAll(),$body.off(".zf.drilldown"))})}}),this.$element.on("mutateme.zf.trigger",this._resize.bind(this))}},{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))}},{key:"_scrollTop",value:function(){var _this=this,$scrollTopElement=""!=_this.options.scrollTopElement?$(_this.options.scrollTopElement):_this.$element,scrollPos=parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset);$("html, body").stop(!0).animate({scrollTop:scrollPos},_this.options.animationDuration,_this.options.animationEasing,function(){this===$("html")[0]&&_this.$element.trigger("scrollme.zf.drilldown")})}},{key:"_keyboardEvents",value:function(){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 $prevElement,$nextElement,$element=$(this),$elements=$element.parent("li").parent("ul").children("li").children("a");$elements.each(function(i){if($(this).is($element))return $prevElement=$elements.eq(Math.max(0,i-1)),void($nextElement=$elements.eq(Math.min(i+1,$elements.length-1)))}),Foundation.Keyboard.handleKey(e,"Drilldown",{next:function(){if($element.is(_this.$submenuAnchors))return _this._show($element.parent("li")),$element.parent("li").one(Foundation.transitionend($element),function(){$element.parent("li").find("ul li a").filter(_this.$menuItems).first().focus()}),!0},previous:function(){return _this._hide($element.parent("li").parent("ul")),$element.parent("li").parent("ul").one(Foundation.transitionend($element),function(){setTimeout(function(){$element.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0},up:function(){return $prevElement.focus(),!$element.is(_this.$element.find("> li:first-child > a"))},down:function(){return $nextElement.focus(),!$element.is(_this.$element.find("> li:last-child > a"))},close:function(){$element.is(_this.$element.find("> li > a"))||(_this._hide($element.parent().parent()),$element.parent().parent().siblings("a").focus())},open:function(){return $element.is(_this.$menuItems)?$element.is(_this.$submenuAnchors)?(_this._show($element.parent("li")),$element.parent("li").one(Foundation.transitionend($element),function(){$element.parent("li").find("ul li a").filter(_this.$menuItems).first().focus()}),!0):void 0:(_this._hide($element.parent("li").parent("ul")),$element.parent("li").parent("ul").one(Foundation.transitionend($element),function(){setTimeout(function(){$element.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0)},handled:function(preventDefault){preventDefault&&e.preventDefault(),e.stopImmediatePropagation()}})})}},{key:"_hideAll",value:function(){var $elem=this.$element.find(".is-drilldown-submenu.is-active").addClass("is-closing");this.options.autoHeight&&this.$wrapper.css({height:$elem.parent().closest("ul").data("calcHeight")}),$elem.one(Foundation.transitionend($elem),function(e){$elem.removeClass("is-active is-closing")}),this.$element.trigger("closed.zf.drilldown")}},{key:"_back",value:function($elem){var _this=this;$elem.off("click.zf.drilldown"),$elem.children(".js-drilldown-back").on("click.zf.drilldown",function(e){e.stopImmediatePropagation(),_this._hide($elem);var parentSubMenu=$elem.parent("li").parent("ul").parent("li");parentSubMenu.length&&_this._show(parentSubMenu)})}},{key:"_menuLinkEvents",value:function(){var _this=this;this.$menuItems.not(".is-drilldown-submenu-parent").off("click.zf.drilldown").on("click.zf.drilldown",function(e){setTimeout(function(){_this._hideAll()},0)})}},{key:"_show",value:function($elem){this.options.autoHeight&&this.$wrapper.css({height:$elem.children("[data-submenu]").data("calcHeight")}),$elem.attr("aria-expanded",!0),$elem.children("[data-submenu]").addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),this.$element.trigger("open.zf.drilldown",[$elem])}},{key:"_hide",value:function($elem){this.options.autoHeight&&this.$wrapper.css({height:$elem.parent().closest("ul").data("calcHeight")});$elem.parent("li").attr("aria-expanded",!1),$elem.attr("aria-hidden",!0).addClass("is-closing"),$elem.addClass("is-closing").one(Foundation.transitionend($elem),function(){$elem.removeClass("is-active is-closing"),$elem.blur().addClass("invisible")}),$elem.trigger("hide.zf.drilldown",[$elem])}},{key:"_getMaxDims",value:function(){var maxHeight=0,result={},_this=this;return this.$submenus.add(this.$element).each(function(){var height=($(this).children("li").length,Foundation.Box.GetDimensions(this).height);maxHeight=height>maxHeight?height:maxHeight,_this.options.autoHeight&&($(this).data("calcHeight",height),$(this).hasClass("is-drilldown-submenu")||(result.height=height))}),this.options.autoHeight||(result["min-height"]=maxHeight+"px"),result["max-width"]=this.$element[0].getBoundingClientRect().width+"px",result}},{key:"destroy",value:function(){this.options.scrollTop&&this.$element.off(".zf.drilldown",this._bindHandler),this._hideAll(),this.$element.off("mutateme.zf.trigger"),Foundation.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.$submenus.removeClass("drilldown-submenu-cover-previous"),this.$element.find("a").each(function(){var $link=$(this);$link.removeAttr("tabindex"),$link.data("savedHref")&&$link.attr("href",$link.data("savedHref")).removeData("savedHref")}),Foundation.unregisterPlugin(this)}}]),Drilldown}();Drilldown.defaults={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"},Foundation.plugin(Drilldown,"Drilldown")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Dropdown=function(){function Dropdown(element,options){_classCallCheck(this,Dropdown),this.$element=element,this.options=$.extend({},Dropdown.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Dropdown"),Foundation.Keyboard.register("Dropdown",{ENTER:"open",SPACE:"open",ESCAPE:"close"})}return _createClass(Dropdown,[{key:"_init",value:function(){var $id=this.$element.attr("id");this.$anchor=$($('[data-toggle="'+$id+'"]').length?'[data-toggle="'+$id+'"]':'[data-open="'+$id+'"]'),this.$anchor.attr({"aria-controls":$id,"data-is-focus":!1,"data-yeti-box":$id,"aria-haspopup":!0,"aria-expanded":!1}),this.options.parentClass?this.$parent=this.$element.parents("."+this.options.parentClass):this.$parent=null,this.options.positionClass=this.getPositionClass(),this.counter=4,this.usedPositions=[],this.$element.attr({"aria-hidden":"true","data-yeti-box":$id,"data-resize":$id,"aria-labelledby":this.$anchor[0].id||Foundation.GetYoDigits(6,"dd-anchor")}),this._events()}},{key:"getPositionClass",value:function(){var verticalPosition=this.$element[0].className.match(/(top|left|right|bottom)/g);verticalPosition=verticalPosition?verticalPosition[0]:"";var horizontalPosition=/float-(\S+)/.exec(this.$anchor[0].className);return horizontalPosition=horizontalPosition?horizontalPosition[1]:"",horizontalPosition?horizontalPosition+" "+verticalPosition:verticalPosition}},{key:"_reposition",value:function(position){this.usedPositions.push(position||"bottom"),!position&&this.usedPositions.indexOf("top")<0?this.$element.addClass("top"):"top"===position&&this.usedPositions.indexOf("bottom")<0?this.$element.removeClass(position):"left"===position&&this.usedPositions.indexOf("right")<0?this.$element.removeClass(position).addClass("right"):"right"===position&&this.usedPositions.indexOf("left")<0?this.$element.removeClass(position).addClass("left"):!position&&this.usedPositions.indexOf("top")>-1&&this.usedPositions.indexOf("left")<0?this.$element.addClass("left"):"top"===position&&this.usedPositions.indexOf("bottom")>-1&&this.usedPositions.indexOf("left")<0?this.$element.removeClass(position).addClass("left"):"left"===position&&this.usedPositions.indexOf("right")>-1&&this.usedPositions.indexOf("bottom")<0?this.$element.removeClass(position):("right"===position&&this.usedPositions.indexOf("left")>-1&&this.usedPositions.indexOf("bottom"),this.$element.removeClass(position)),this.classChanged=!0,this.counter--}},{key:"_setPosition",value:function(){if("false"===this.$anchor.attr("aria-expanded"))return!1;var position=this.getPositionClass(),$eleDims=Foundation.Box.GetDimensions(this.$element),direction=(Foundation.Box.GetDimensions(this.$anchor),"left"===position?"left":"right"===position?"left":"top"),param="top"===direction?"height":"width";"height"===param?this.options.vOffset:this.options.hOffset;if($eleDims.width>=$eleDims.windowDims.width||!this.counter&&!Foundation.Box.ImNotTouchingYou(this.$element,this.$parent)){var newWidth=$eleDims.windowDims.width,parentHOffset=0;if(this.$parent){var $parentDims=Foundation.Box.GetDimensions(this.$parent),parentHOffset=$parentDims.offset.left;$parentDims.width<newWidth&&(newWidth=$parentDims.width)}return this.$element.offset(Foundation.Box.GetOffsets(this.$element,this.$anchor,"center bottom",this.options.vOffset,this.options.hOffset+parentHOffset,!0)).css({width:newWidth-2*this.options.hOffset,height:"auto"}),this.classChanged=!0,!1}for(this.$element.offset(Foundation.Box.GetOffsets(this.$element,this.$anchor,position,this.options.vOffset,this.options.hOffset));!Foundation.Box.ImNotTouchingYou(this.$element,this.$parent,!0)&&this.counter;)this._reposition(position),this._setPosition()}},{key:"_events",value:function(){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.options.hover&&(this.$anchor.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){var bodyData=$("body").data();void 0!==bodyData.whatinput&&"mouse"!==bodyData.whatinput||(clearTimeout(_this.timeout),_this.timeout=setTimeout(function(){_this.open(),_this.$anchor.data("hover",!0)},_this.options.hoverDelay))}).on("mouseleave.zf.dropdown",function(){clearTimeout(_this.timeout),_this.timeout=setTimeout(function(){_this.close(),_this.$anchor.data("hover",!1)},_this.options.hoverDelay)}),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.$anchor.data("hover",!1)},_this.options.hoverDelay)})),this.$anchor.add(this.$element).on("keydown.zf.dropdown",function(e){var $target=$(this);Foundation.Keyboard.findFocusable(_this.$element);Foundation.Keyboard.handleKey(e,"Dropdown",{open:function(){$target.is(_this.$anchor)&&(_this.open(),_this.$element.attr("tabindex",-1).focus(),e.preventDefault())},close:function(){_this.close(),_this.$anchor.focus()}})})}},{key:"_addBodyHandler",value:function(){var $body=$(document.body).not(this.$element),_this=this;$body.off("click.zf.dropdown").on("click.zf.dropdown",function(e){_this.$anchor.is(e.target)||_this.$anchor.find(e.target).length||_this.$element.find(e.target).length||(_this.close(),$body.off("click.zf.dropdown"))})}},{key:"open",value:function(){if(this.$element.trigger("closeme.zf.dropdown",this.$element.attr("id")),this.$anchor.addClass("hover").attr({"aria-expanded":!0}),this._setPosition(),this.$element.addClass("is-open").attr({"aria-hidden":!1}),this.options.autoFocus){var $focusable=Foundation.Keyboard.findFocusable(this.$element);$focusable.length&&$focusable.eq(0).focus()}this.options.closeOnClick&&this._addBodyHandler(),this.options.trapFocus&&Foundation.Keyboard.trapFocus(this.$element),this.$element.trigger("show.zf.dropdown",[this.$element])}},{key:"close",value:function(){if(!this.$element.hasClass("is-open"))return!1;if(this.$element.removeClass("is-open").attr({"aria-hidden":!0}),this.$anchor.removeClass("hover").attr("aria-expanded",!1),this.classChanged){var curPositionClass=this.getPositionClass();curPositionClass&&this.$element.removeClass(curPositionClass),this.$element.addClass(this.options.positionClass).css({height:"",width:""}),this.classChanged=!1,this.counter=4,this.usedPositions.length=0}this.$element.trigger("hide.zf.dropdown",[this.$element]),this.options.trapFocus&&Foundation.Keyboard.releaseFocus(this.$element)}},{key:"toggle",value:function(){if(this.$element.hasClass("is-open")){if(this.$anchor.data("hover"))return;this.close()}else this.open()}},{key:"destroy",value:function(){this.$element.off(".zf.trigger").hide(),this.$anchor.off(".zf.dropdown"),Foundation.unregisterPlugin(this)}}]),Dropdown}();Dropdown.defaults={parentClass:null,hoverDelay:250,hover:!1,hoverPane:!1,vOffset:1,hOffset:1,positionClass:"",trapFocus:!1,autoFocus:!1,closeOnClick:!1},Foundation.plugin(Dropdown,"Dropdown")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var DropdownMenu=function(){function DropdownMenu(element,options){_classCallCheck(this,DropdownMenu),this.$element=element,this.options=$.extend({},DropdownMenu.defaults,this.$element.data(),options),Foundation.Nest.Feather(this.$element,"dropdown"),this._init(),Foundation.registerPlugin(this,"DropdownMenu"),Foundation.Keyboard.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}return _createClass(DropdownMenu,[{key:"_init",value:function(){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),this.$element.hasClass(this.options.rightClass)||"right"===this.options.alignment||Foundation.rtl()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",subs.addClass("opens-left")):subs.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")}},{key:"_events",value:function(){var _this=this,hasTouch="ontouchstart"in window||void 0!==window.ontouchstart,parClass="is-dropdown-submenu-parent",handleClickFn=function(e){var $elem=$(e.target).parentsUntil("ul","."+parClass),hasSub=$elem.hasClass(parClass),hasClicked="true"===$elem.attr("data-is-click"),$sub=$elem.children(".is-dropdown-submenu");if(hasSub)if(hasClicked){if(!_this.options.closeOnClick||!_this.options.clickOpen&&!hasTouch||_this.options.forceFollow&&hasTouch)return;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",!0)};(this.options.clickOpen||hasTouch)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",handleClickFn),_this.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(e){$(this).hasClass(parClass)||_this._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(e){var $elem=$(this);$elem.hasClass(parClass)&&(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=$(this);if($elem.hasClass(parClass)&&_this.options.autoclose){if("true"===$elem.attr("data-is-click")&&_this.options.clickOpen)return!1;clearTimeout($elem.data("_delay")),$elem.data("_delay",setTimeout(function(){_this._hide($elem)},_this.options.closingTime))}}),this.$menuItems.on("keydown.zf.dropdownmenu",function(e){var $prevElement,$nextElement,$element=$(e.target).parentsUntil("ul",'[role="menuitem"]'),isTab=_this.$tabs.index($element)>-1,$elements=isTab?_this.$tabs:$element.siblings("li").add($element);$elements.each(function(i){if($(this).is($element))return $prevElement=$elements.eq(i-1),void($nextElement=$elements.eq(i+1))});var nextSibling=function(){$element.is(":last-child")||($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");$sub.length&&(_this._show($sub),$element.find("li > a:first").focus(),e.preventDefault())},closeSub=function(){var close=$element.parent("ul").parent("li");close.children("a:first").focus(),_this._hide(close),e.preventDefault()},functions={open:openSub,close:function(){_this._hide(_this.$element),_this.$menuItems.find("a:first").focus(),e.preventDefault()},handled:function(){e.stopImmediatePropagation()}};isTab?_this._isVertical()?Foundation.rtl()?$.extend(functions,{down:nextSibling,up:prevSibling,next:closeSub,previous:openSub}):$.extend(functions,{down:nextSibling,up:prevSibling,next:openSub,previous:closeSub}):Foundation.rtl()?$.extend(functions,{next:prevSibling,previous:nextSibling,down:openSub,up:closeSub}):$.extend(functions,{next:nextSibling,previous:prevSibling,down:openSub,up:closeSub}):Foundation.rtl()?$.extend(functions,{next:closeSub,previous:openSub,down:nextSibling,up:prevSibling}):$.extend(functions,{next:openSub,previous:closeSub,down:nextSibling,up:prevSibling}),Foundation.Keyboard.handleKey(e,"DropdownMenu",functions)})}},{key:"_addBodyHandler",value:function(){var $body=$(document.body),_this=this;$body.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(e){_this.$element.find(e.target).length||(_this._hide(),$body.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function($sub){var idx=this.$tabs.index(this.$tabs.filter(function(i,el){return $(el).find($sub).length>0})),$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.Box.ImNotTouchingYou($sub,null,!0);if(!clear){var oldClass="left"===this.options.alignment?"-right":"-left",$parentLi=$sub.parent(".is-dropdown-submenu-parent");$parentLi.removeClass("opens"+oldClass).addClass("opens-"+this.options.alignment),clear=Foundation.Box.ImNotTouchingYou($sub,null,!0),clear||$parentLi.removeClass("opens-"+this.options.alignment).addClass("opens-inner"),this.changed=!0}$sub.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[$sub])}},{key:"_hide",value:function($elem,idx){var $toClose;if($toClose=$elem&&$elem.length?$elem:void 0!==idx?this.$tabs.not(function(i,el){return i===idx}):this.$element,$toClose.hasClass("is-active")||$toClose.find(".is-active").length>0){if($toClose.find("li.is-active").add($toClose).attr({"data-is-click":!1}).removeClass("is-active"),$toClose.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||$toClose.find("opens-inner").length){var oldClass="left"===this.options.alignment?"right":"left";$toClose.find("li.is-dropdown-submenu-parent").add($toClose).removeClass("opens-inner opens-"+this.options.alignment).addClass("opens-"+oldClass),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[$toClose])}}},{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"),$(document.body).off(".zf.dropdownmenu"),Foundation.Nest.Burn(this.$element,"dropdown"),Foundation.unregisterPlugin(this)}}]),DropdownMenu}();DropdownMenu.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"left",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0},Foundation.plugin(DropdownMenu,"DropdownMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Equalizer=function(){function Equalizer(element,options){_classCallCheck(this,Equalizer),this.$element=element,this.options=$.extend({},Equalizer.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Equalizer")}return _createClass(Equalizer,[{key:"_init",value:function(){var eqId=this.$element.attr("data-equalizer")||"",$watched=this.$element.find('[data-equalizer-watch="'+eqId+'"]');this.$watched=$watched.length?$watched:this.$element.find("[data-equalizer-watch]"),this.$element.attr("data-resize",eqId||Foundation.GetYoDigits(6,"eq")),this.$element.attr("data-mutate",eqId||Foundation.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 tooSmall,imgs=this.$element.find("img");this.options.equalizeOn?(tooSmall=this._checkMQ(),$(window).on("changed.zf.mediaquery",this._checkMQ.bind(this))):this._events(),(void 0!==tooSmall&&!1===tooSmall||void 0===tooSmall)&&(imgs.length?Foundation.onImagesLoaded(imgs,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 tooSmall=!Foundation.MediaQuery.is(this.options.equalizeOn);return tooSmall?this.isOn&&(this._pauseEvents(),this.$watched.css("height","auto")):this.isOn||this._events(),tooSmall}},{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(cb){for(var heights=[],i=0,len=this.$watched.length;i<len;i++)this.$watched[i].style.height="auto",heights.push(this.$watched[i].offsetHeight);cb(heights)}},{key:"getHeightsByRow",value:function(cb){var lastElTopOffset=this.$watched.length?this.$watched.first().offset().top:0,groups=[],group=0;groups[group]=[];for(var i=0,len=this.$watched.length;i<len;i++){this.$watched[i].style.height="auto";var elOffsetTop=$(this.$watched[i]).offset().top;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(),max=Math.max.apply(null,heights);groups[j].push(max)}cb(groups)}},{key:"applyHeight",value:function(heights){var max=Math.max.apply(null,heights);this.$element.trigger("preequalized.zf.equalizer"),this.$watched.css("height",max),this.$element.trigger("postequalized.zf.equalizer")}},{key:"applyHeightByRow",value:function(groups){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"});else{this.$element.trigger("preequalizedrow.zf.equalizer");for(var j=0,lenJ=groupsILength-1;j<lenJ;j++)$(groups[i][j][0]).css({height:max});this.$element.trigger("postequalizedrow.zf.equalizer")}}this.$element.trigger("postequalized.zf.equalizer")}},{key:"destroy",value:function(){this._pauseEvents(),this.$watched.css("height","auto"),Foundation.unregisterPlugin(this)}}]),Equalizer}();Equalizer.defaults={equalizeOnStack:!1,equalizeByRow:!1,equalizeOn:""},Foundation.plugin(Equalizer,"Equalizer")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Interchange=function(){function Interchange(element,options){_classCallCheck(this,Interchange),this.$element=element,this.options=$.extend({},Interchange.defaults,options),this.rules=[],this.currentPath="",this._init(),this._events(),Foundation.registerPlugin(this,"Interchange")}return _createClass(Interchange,[{key:"_init",value:function(){this._addBreakpoints(),this._generateRules(),this._reflow()}},{key:"_events",value:function(){var _this2=this;$(window).on("resize.zf.interchange",Foundation.util.throttle(function(){_this2._reflow()},50))}},{key:"_reflow",value:function(){var match;for(var i in this.rules)if(this.rules.hasOwnProperty(i)){var rule=this.rules[i];window.matchMedia(rule.query).matches&&(match=rule)}match&&this.replace(match.path)}},{key:"_addBreakpoints",value:function(){for(var i in Foundation.MediaQuery.queries)if(Foundation.MediaQuery.queries.hasOwnProperty(i)){var query=Foundation.MediaQuery.queries[i];Interchange.SPECIAL_QUERIES[query.name]=query.value}}},{key:"_generateRules",value:function(element){var rules,rulesList=[];rules=this.options.rules?this.options.rules:this.$element.data("interchange"),rules="string"==typeof rules?rules.match(/\[.*?\]/g):rules;for(var i in rules)if(rules.hasOwnProperty(i)){var rule=rules[i].slice(1,-1).split(", "),path=rule.slice(0,-1).join(""),query=rule[rule.length-1];Interchange.SPECIAL_QUERIES[query]&&(query=Interchange.SPECIAL_QUERIES[query]),rulesList.push({path:path,query:query})}this.rules=rulesList}},{key:"replace",value:function(path){if(this.currentPath!==path){var _this=this,trigger="replaced.zf.interchange";"IMG"===this.$element[0].nodeName?this.$element.attr("src",path).on("load",function(){_this.currentPath=path}).trigger(trigger):path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)?this.$element.css({"background-image":"url("+path+")"}).trigger(trigger):$.get(path,function(response){_this.$element.html(response).trigger(trigger),$(response).foundation(),_this.currentPath=path})}}},{key:"destroy",value:function(){}}]),Interchange}();Interchange.defaults={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)"},Foundation.plugin(Interchange,"Interchange")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Magellan=function(){function Magellan(element,options){_classCallCheck(this,Magellan),this.$element=element,this.options=$.extend({},Magellan.defaults,this.$element.data(),options),this._init(),this.calcPoints(),Foundation.registerPlugin(this,"Magellan")}return _createClass(Magellan,[{key:"_init",value:function(){var id=this.$element[0].id||Foundation.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()}},{key:"calcPoints",value:function(){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)})}},{key:"_events",value:function(){var _this=this;$("html, body"),_this.options.animationDuration,_this.options.animationEasing;$(window).one("load",function(){_this.options.deepLinking&&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)}),$(window).on("popstate",function(e){_this.options.deepLinking&&_this.scrollToLoc(window.location.hash)})}},{key:"scrollToLoc",value:function(loc){if(!$(loc).length)return!1;this._inTransition=!0;var _this=this,scrollPos=Math.round($(loc).offset().top-this.options.threshold/2-this.options.barOffset);$("html, body").stop(!0).animate({scrollTop:scrollPos},this.options.animationDuration,this.options.animationEasing,function(){_this._inTransition=!1,_this._updateActive()})}},{key:"reflow",value:function(){this.calcPoints(),this._updateActive()}},{key:"_updateActive",value:function(){if(!this._inTransition){var curIdx,winPos=parseInt(window.pageYOffset,10);if(winPos+this.winHeight===this.docHeight)curIdx=this.points.length-1;else if(winPos<this.points[0])curIdx=void 0;else{var isDown=this.scrollPos<winPos,_this=this,curVisible=this.points.filter(function(p,i){return isDown?p-_this.options.barOffset<=winPos:p-_this.options.barOffset-_this.options.threshold<=winPos});curIdx=curVisible.length?curVisible.length-1:0}if(this.$active.removeClass(this.options.activeClass),this.$active=this.$links.filter('[href="#'+this.$targets.eq(curIdx).data("magellan-target")+'"]').addClass(this.options.activeClass),this.options.deepLinking){var hash="";void 0!=curIdx&&(hash=this.$active[0].getAttribute("href")),hash!==window.location.hash&&(window.history.pushState?window.history.pushState(null,null,hash):window.location.hash=hash)}this.scrollPos=winPos,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 hash=this.$active[0].getAttribute("href");window.location.hash.replace(hash,"")}Foundation.unregisterPlugin(this)}}]),Magellan}();Magellan.defaults={animationDuration:500,animationEasing:"linear",threshold:50,activeClass:"active",deepLinking:!1,barOffset:0},Foundation.plugin(Magellan,"Magellan")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var OffCanvas=function(){function OffCanvas(element,options){_classCallCheck(this,OffCanvas),this.$element=element,this.options=$.extend({},OffCanvas.defaults,this.$element.data(),options),this.$lastTrigger=$(),this.$triggers=$(),this._init(),this._events(),Foundation.registerPlugin(this,"OffCanvas"),Foundation.Keyboard.register("OffCanvas",{ESCAPE:"close"})}return _createClass(OffCanvas,[{key:"_init",value:function(){var id=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.$element.addClass("is-transition-"+this.options.transition),this.$triggers=$(document).find('[data-open="'+id+'"], [data-close="'+id+'"], [data-toggle="'+id+'"]').attr("aria-expanded","false").attr("aria-controls",id),!0===this.options.contentOverlay){var overlay=document.createElement("div"),overlayPosition="fixed"===$(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";overlay.setAttribute("class","js-off-canvas-overlay "+overlayPosition),this.$overlay=$(overlay),"is-overlay-fixed"===overlayPosition?$("body").append(this.$overlay):this.$element.siblings("[data-off-canvas-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()),!0==!this.options.transitionTime&&(this.options.transitionTime=1e3*parseFloat(window.getComputedStyle($("[data-off-canvas]")[0]).transitionDuration))}},{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:$("[data-off-canvas-content]")).on({"click.zf.offcanvas":this.close.bind(this)})}}},{key:"_setMQChecker",value:function(){var _this=this;$(window).on("changed.zf.mediaquery",function(){Foundation.MediaQuery.atLeast(_this.options.revealOn)?_this.reveal(!0):_this.reveal(!1)}).one("load.zf.offcanvas",function(){Foundation.MediaQuery.atLeast(_this.options.revealOn)&&_this.reveal(!0)})}},{key:"reveal",value:function(isRevealed){var $closer=this.$element.find("[data-close]");isRevealed?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),$closer.length&&$closer.hide()):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),$closer.length&&$closer.show())}},{key:"_stopScrolling",value:function(event){return!1}},{key:"_recordScrollable",value:function(event){var elem=this;elem.scrollHeight!==elem.clientHeight&&(0===elem.scrollTop&&(elem.scrollTop=1),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(event){var elem=this,up=event.pageY<elem.lastY,down=!up;elem.lastY=event.pageY,up&&elem.allowUp||down&&elem.allowDown?event.stopPropagation():event.preventDefault()}},{key:"open",value:function(event,trigger){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var _this=this;trigger&&(this.$lastTrigger=trigger),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),_this.$element.addClass("is-open"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false").trigger("opened.zf.offcanvas"),!1===this.options.contentScroll&&($("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(Foundation.transitionend(this.$element),function(){_this.$element.find("a, button").eq(0).focus()}),!0===this.options.trapFocus&&(this.$element.siblings("[data-off-canvas-content]").attr("tabindex","-1"),Foundation.Keyboard.trapFocus(this.$element))}}},{key:"close",value:function(cb){if(this.$element.hasClass("is-open")&&!this.isRevealed){this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),!1===this.options.contentScroll&&($("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.$element.siblings("[data-off-canvas-content]").removeAttr("tabindex"),Foundation.Keyboard.releaseFocus(this.$element))}}},{key:"toggle",value:function(event,trigger){this.$element.hasClass("is-open")?this.close(event,trigger):this.open(event,trigger)}},{key:"_handleKeyboard",value:function(e){var _this2=this;Foundation.Keyboard.handleKey(e,"OffCanvas",{close:function(){return _this2.close(),_this2.$lastTrigger.focus(),!0},handled:function(){e.stopPropagation(),e.preventDefault()}})}},{key:"destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas"),Foundation.unregisterPlugin(this)}}]),OffCanvas}();OffCanvas.defaults={closeOnClick:!0,contentOverlay:!0,contentScroll:!0,transitionTime:0,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1},Foundation.plugin(OffCanvas,"OffCanvas")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Orbit=function(){function Orbit(element,options){_classCallCheck(this,Orbit),this.$element=element,this.options=$.extend({},Orbit.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Orbit"),Foundation.Keyboard.register("Orbit",{ltr:{ARROW_RIGHT:"next",ARROW_LEFT:"previous"},rtl:{ARROW_LEFT:"next",ARROW_RIGHT:"previous"}})}return _createClass(Orbit,[{key:"_init",value:function(){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||Foundation.GetYoDigits(6,"orbit");this.$element.attr({"data-resize":id,id:id}),initActive.length||this.$slides.eq(0).addClass("is-active"),this.options.useMUI||this.$slides.addClass("no-motionui"),$images.length?Foundation.onImagesLoaded($images,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 _this=this;this.timer=new Foundation.Timer(this.$element,{duration:this.options.timerDelay,infinite:!1},function(){_this.changeSlide(!0)}),this.timer.start()}},{key:"_prepareForOrbit",value:function(){this._setWrapperHeight()}},{key:"_setWrapperHeight",value:function(cb){var temp,max=0,counter=0,_this=this;this.$slides.each(function(){temp=this.getBoundingClientRect().height,$(this).attr("data-slide",counter),_this.$slides.filter(".is-active")[0]!==_this.$slides.eq(counter)[0]&&$(this).css({position:"relative",display:"none"}),max=temp>max?temp:max,counter++}),counter===this.$slides.length&&(this.$wrapper.css({height:max}),cb&&cb(max))}},{key:"_setSlideHeight",value:function(height){this.$slides.each(function(){$(this).css("max-height",height)})}},{key:"_events",value:function(){var _this=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(),_this.changeSlide(!0)}).on("swiperight.zf.orbit",function(e){e.preventDefault(),_this.changeSlide(!1)}),this.options.autoPlay&&(this.$slides.on("click.zf.orbit",function(){_this.$element.data("clickedOn",!_this.$element.data("clickedOn")),_this.timer[_this.$element.data("clickedOn")?"pause":"start"]()}),this.options.pauseOnHover&&this.$element.on("mouseenter.zf.orbit",function(){_this.timer.pause()}).on("mouseleave.zf.orbit",function(){_this.$element.data("clickedOn")||_this.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(),_this.changeSlide($(this).hasClass(_this.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 idx=$(this).data("slide"),ltr=idx>_this.$slides.filter(".is-active").data("slide"),$slide=_this.$slides.eq(idx);_this.changeSlide(ltr,$slide,idx)}),this.options.accessible&&this.$wrapper.add(this.$bullets).on("keydown.zf.orbit",function(e){Foundation.Keyboard.handleKey(e,"Orbit",{next:function(){_this.changeSlide(!0)},previous:function(){_this.changeSlide(!1)},handled:function(){$(e.target).is(_this.$bullets)&&_this.$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(el){$(el).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(isLTR,chosenSlide,idx){if(this.$slides){var $curSlide=this.$slides.filter(".is-active").eq(0);if(/mui/g.test($curSlide[0].className))return!1;var $newSlide,$firstSlide=this.$slides.first(),$lastSlide=this.$slides.last(),dirIn=isLTR?"Right":"Left",dirOut=isLTR?"Left":"Right",_this=this;$newSlide=chosenSlide||(isLTR?this.options.infiniteWrap?$curSlide.next("."+this.options.slideClass).length?$curSlide.next("."+this.options.slideClass):$firstSlide:$curSlide.next("."+this.options.slideClass):this.options.infiniteWrap?$curSlide.prev("."+this.options.slideClass).length?$curSlide.prev("."+this.options.slideClass):$lastSlide:$curSlide.prev("."+this.options.slideClass)),$newSlide.length&&(this.$element.trigger("beforeslidechange.zf.orbit",[$curSlide,$newSlide]),this.options.bullets&&(idx=idx||this.$slides.index($newSlide),this._updateBullets(idx)),this.options.useMUI&&!this.$element.is(":hidden")?(Foundation.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.Motion.animateOut($curSlide.removeClass("is-active"),this.options["animOutTo"+dirOut],function(){$curSlide.removeAttr("aria-live"),_this.options.autoPlay&&!_this.timer.isPaused&&_this.timer.restart()})):($curSlide.removeClass("is-active is-in").removeAttr("aria-live").hide(),$newSlide.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",[$newSlide]))}}},{key:"_updateBullets",value:function(idx){var $oldBullet=this.$element.find("."+this.options.boxOfBullets).find(".is-active").removeClass("is-active").blur(),span=$oldBullet.find("span:last").detach();this.$bullets.eq(idx).addClass("is-active").append(span)}},{key:"destroy",value:function(){this.$element.off(".zf.orbit").find("*").off(".zf.orbit").end().hide(),Foundation.unregisterPlugin(this)}}]),Orbit}();Orbit.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},Foundation.plugin(Orbit,"Orbit")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var ResponsiveMenu=function(){function ResponsiveMenu(element,options){_classCallCheck(this,ResponsiveMenu),this.$element=$(element),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveMenu")}return _createClass(ResponsiveMenu,[{key:"_init",value:function(){if("string"==typeof this.rules){for(var rulesTree={},rules=this.rules.split(" "),i=0;i<rules.length;i++){var rule=rules[i].split("-"),ruleSize=rule.length>1?rule[0]:"small",rulePlugin=rule.length>1?rule[1]:rule[0];null!==MenuPlugins[rulePlugin]&&(rulesTree[ruleSize]=MenuPlugins[rulePlugin])}this.rules=rulesTree}$.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||Foundation.GetYoDigits(6,"responsive-menu"))}},{key:"_events",value:function(){var _this=this;$(window).on("changed.zf.mediaquery",function(){_this._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var matchedMq,_this=this;$.each(this.rules,function(key){Foundation.MediaQuery.atLeast(key)&&(matchedMq=key)}),matchedMq&&(this.currentPlugin instanceof this.rules[matchedMq].plugin||($.each(MenuPlugins,function(key,value){_this.$element.removeClass(value.cssClass)}),this.$element.addClass(this.rules[matchedMq].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[matchedMq].plugin(this.$element,{})))}},{key:"destroy",value:function(){this.currentPlugin.destroy(),$(window).off(".zf.ResponsiveMenu"),Foundation.unregisterPlugin(this)}}]),ResponsiveMenu}();ResponsiveMenu.defaults={};var MenuPlugins={dropdown:{cssClass:"dropdown",plugin:Foundation._plugins["dropdown-menu"]||null},drilldown:{cssClass:"drilldown",plugin:Foundation._plugins.drilldown||null},accordion:{cssClass:"accordion-menu",plugin:Foundation._plugins["accordion-menu"]||null}};Foundation.plugin(ResponsiveMenu,"ResponsiveMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var ResponsiveToggle=function(){function ResponsiveToggle(element,options){_classCallCheck(this,ResponsiveToggle),this.$element=$(element),this.options=$.extend({},ResponsiveToggle.defaults,this.$element.data(),options),this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveToggle")}return _createClass(ResponsiveToggle,[{key:"_init",value:function(){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()),this.options.animate){var input=this.options.animate.split(" ");this.animationIn=input[0],this.animationOut=input[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),$(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){Foundation.MediaQuery.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var _this2=this;Foundation.MediaQuery.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?Foundation.Motion.animateIn(this.$targetMenu,this.animationIn,function(){_this2.$element.trigger("toggled.zf.responsiveToggle"),_this2.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):Foundation.Motion.animateOut(this.$targetMenu,this.animationOut,function(){_this2.$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"),$(window).off("changed.zf.mediaquery",this._updateMqHandler),Foundation.unregisterPlugin(this)}}]),ResponsiveToggle}();ResponsiveToggle.defaults={hideFor:"medium",animate:!1},Foundation.plugin(ResponsiveToggle,"ResponsiveToggle")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){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()}var Reveal=function(){function Reveal(element,options){_classCallCheck(this,Reveal),this.$element=element,this.options=$.extend({},Reveal.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Reveal"),Foundation.Keyboard.register("Reveal",{ENTER:"open",SPACE:"open",ESCAPE:"close"})}return _createClass(Reveal,[{key:"_init",value:function(){this.id=this.$element.attr("id"),this.isActive=!1,this.cached={mq:Foundation.MediaQuery.current},this.isMobile=mobileSniff(),this.$anchor=$($('[data-open="'+this.id+'"]').length?'[data-open="'+this.id+'"]':'[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($(this.options.appendTo)),this.$element.addClass("without-overlay")),this._events(),this.options.deepLink&&window.location.hash==="#"+this.id&&$(window).one("load.zf.reveal",this.open.bind(this))}},{key:"_makeOverlay",value:function(){return $("<div></div>").addClass("reveal-overlay").appendTo(this.options.appendTo)}},{key:"_updatePosition",value:function(){var left,top,width=this.$element.outerWidth(),outerWidth=$(window).width(),height=this.$element.outerHeight(),outerHeight=$(window).height();left="auto"===this.options.hOffset?parseInt((outerWidth-width)/2,10):parseInt(this.options.hOffset,10),top="auto"===this.options.vOffset?height>outerHeight?parseInt(Math.min(100,outerHeight/10),10):parseInt((outerHeight-height)/4,10):parseInt(this.options.vOffset,10),this.$element.css({top:top+"px"}),this.$overlay&&"auto"===this.options.hOffset||(this.$element.css({left:left+"px"}),this.$element.css({margin:"0px"}))}},{key:"_events",value:function(){var _this2=this,_this=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":function(event,$element){if(event.target===_this.$element[0]||$(event.target).parents("[data-closable]")[0]===$element)return _this2.close.apply(_this2)},"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":function(){_this._updatePosition()}}),this.$anchor.length&&this.$anchor.on("keydown.zf.reveal",function(e){13!==e.which&&32!==e.which||(e.stopPropagation(),e.preventDefault(),_this.open())}),this.options.closeOnClick&&this.options.overlay&&this.$overlay.off(".zf.reveal").on("click.zf.reveal",function(e){e.target!==_this.$element[0]&&!$.contains(_this.$element[0],e.target)&&$.contains(document,e.target)&&_this.close()}),this.options.deepLink&&$(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 addRevealOpenClasses(){_this.isMobile?(_this.originalScrollPos||(_this.originalScrollPos=window.pageYOffset),$("html, body").addClass("is-reveal-open")):$("body").addClass("is-reveal-open")}var _this3=this;if(this.options.deepLink){var hash="#"+this.id;window.history.pushState?window.history.pushState(null,null,hash):window.location.hash=hash}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 _this=this;if(this.options.animationIn){var afterAnimation=function(){_this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),addRevealOpenClasses(),Foundation.Keyboard.trapFocus(_this.$element)};this.options.overlay&&Foundation.Motion.animateIn(this.$overlay,"fade-in"),Foundation.Motion.animateIn(this.$element,this.options.animationIn,function(){_this3.$element&&(_this3.focusableElements=Foundation.Keyboard.findFocusable(_this3.$element),afterAnimation())})}else this.options.overlay&&this.$overlay.show(0),this.$element.show(this.options.showDelay);this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),Foundation.Keyboard.trapFocus(this.$element),this.$element.trigger("open.zf.reveal"),addRevealOpenClasses(),setTimeout(function(){_this3._extraHandlers()},0)}},{key:"_extraHandlers",value:function(){var _this=this;this.$element&&(this.focusableElements=Foundation.Keyboard.findFocusable(this.$element),this.options.overlay||!this.options.closeOnClick||this.options.fullScreen||$("body").on("click.zf.reveal",function(e){e.target!==_this.$element[0]&&!$.contains(_this.$element[0],e.target)&&$.contains(document,e.target)&&_this.close()}),this.options.closeOnEsc&&$(window).on("keydown.zf.reveal",function(e){Foundation.Keyboard.handleKey(e,"Reveal",{close:function(){_this.options.closeOnEsc&&(_this.close(),_this.$anchor.focus())}})}),this.$element.on("keydown.zf.reveal",function(e){var $target=$(this);Foundation.Keyboard.handleKey(e,"Reveal",{open:function(){_this.$element.find(":focus").is(_this.$element.find("[data-close]"))?setTimeout(function(){_this.$anchor.focus()},1):$target.is(_this.focusableElements)&&_this.open()},close:function(){_this.options.closeOnEsc&&(_this.close(),_this.$anchor.focus())},handled:function(preventDefault){preventDefault&&e.preventDefault()}})}))}},{key:"close",value:function(){function finishUp(){_this.isMobile?($("html, body").removeClass("is-reveal-open"),_this.originalScrollPos&&($("body").scrollTop(_this.originalScrollPos),_this.originalScrollPos=null)):$("body").removeClass("is-reveal-open"),Foundation.Keyboard.releaseFocus(_this.$element),_this.$element.attr("aria-hidden",!0),_this.$element.trigger("closed.zf.reveal")}if(!this.isActive||!this.$element.is(":visible"))return!1;var _this=this;this.options.animationOut?(this.options.overlay?Foundation.Motion.animateOut(this.$overlay,"fade-out",finishUp):finishUp(),Foundation.Motion.animateOut(this.$element,this.options.animationOut)):(this.options.overlay?this.$overlay.hide(0,finishUp):finishUp(),this.$element.hide(this.options.hideDelay)),this.options.closeOnEsc&&$(window).off("keydown.zf.reveal"),!this.options.overlay&&this.options.closeOnClick&&$("body").off("click.zf.reveal"),this.$element.off("keydown.zf.reveal"),this.options.resetOnClose&&this.$element.html(this.$element.html()),this.isActive=!1,_this.options.deepLink&&(window.history.replaceState?window.history.replaceState("",document.title,window.location.href.replace("#"+this.id,"")):window.location.hash="")}},{key:"toggle",value:function(){this.isActive?this.close():this.open()}},{key:"destroy",value:function(){this.options.overlay&&(this.$element.appendTo($(this.options.appendTo)),this.$overlay.hide().off().remove()),this.$element.hide().off(),this.$anchor.off(".zf"),$(window).off(".zf.reveal:"+this.id),Foundation.unregisterPlugin(this)}}]),Reveal}();Reveal.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,appendTo:"body"},Foundation.plugin(Reveal,"Reveal")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){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)}var Slider=function(){function Slider(element,options){_classCallCheck(this,Slider),this.$element=element,this.options=$.extend({},Slider.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Slider"),Foundation.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"},rtl:{ARROW_LEFT:"increase",ARROW_RIGHT:"decrease",SHIFT_ARROW_LEFT:"increase_fast",SHIFT_ARROW_RIGHT:"decrease_fast"}})}return _createClass(Slider,[{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):$("#"+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=$().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):$("#"+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 _this2=this;this.handles[1]?this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0,function(){_this2._setHandlePos(_this2.$handle2,_this2.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(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)}return pctOfBar.toFixed(2)}},{key:"_value",value:function(pctOfBar){switch(this.options.positionValueFunction){case"pow":pctOfBar=this._powTransform(pctOfBar);break;case"log":pctOfBar=this._logTransform(pctOfBar)}return(this.options.end-this.options.start)*pctOfBar+this.options.start}},{key:"_logTransform",value:function(value){return baseLog(this.options.nonLinearBase,value*(this.options.nonLinearBase-1)+1)}},{key:"_powTransform",value:function(value){return(Math.pow(this.options.nonLinearBase,value)-1)/(this.options.nonLinearBase-1)}},{key:"_setHandlePos",value:function($hndl,location,noInvert,cb){if(!this.$element.hasClass(this.options.disabledClass)){location=parseFloat(location),location<this.options.start?location=this.options.start:location>this.options.end&&(location=this.options.end);var isDbl=this.options.doubleSided;if(isDbl)if(0===this.handles.index($hndl)){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}this.options.vertical&&!noInvert&&(location=this.options.end-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],pctOfBar=this._pctOfBar(location),pxToMove=(elemDim-handleDim)*pctOfBar,movement=(100*percent(pxToMove,elemDim)).toFixed(this.options.decimal);location=parseFloat(location.toFixed(this.options.decimal));var css={};if(this._setValues($hndl,location),isDbl){var dim,isLeftHndl=0===this.handles.index($hndl),handlePct=~~(100*percent(handleDim,elemDim));if(isLeftHndl)css[lOrT]=movement+"%",dim=parseFloat(this.$handle2[0].style[lOrT])-movement+handlePct,cb&&"function"==typeof cb&&cb();else{var handlePos=parseFloat(this.$handle[0].style[lOrT]);dim=movement-(isNaN(handlePos)?(this.options.initialStart-this.options.start)/((this.options.end-this.options.start)/100):handlePos)+handlePct}css["min-"+hOrW]=dim+"%"}this.$element.one("finished.zf.animate",function(){_this.$element.trigger("moved.zf.slider",[$hndl])});var moveTime=this.$element.data("dragging")?1e3/60:this.options.moveTime;Foundation.Move(moveTime,$hndl,function(){isNaN(movement)?$hndl.css(lOrT,100*pctOfBar+"%"):$hndl.css(lOrT,movement+"%"),_this.options.doubleSided?_this.$fill.css(css):_this.$fill.css(hOrW,100*pctOfBar+"%")}),clearTimeout(_this.timeout),_this.timeout=setTimeout(function(){_this.$element.trigger("changed.zf.slider",[$hndl])},_this.options.changedDelay)}}},{key:"_setInitAttr",value:function(idx){var initVal=0===idx?this.options.initialStart:this.options.initialEnd,id=this.inputs.eq(idx).attr("id")||Foundation.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})}},{key:"_setValues",value:function($handle,val){var idx=this.options.doubleSided?this.handles.index($handle):0;this.inputs.eq(idx).val(val),$handle.attr("aria-valuenow",val)}},{key:"_handleEvent",value:function(e,$handle,val){var value,hasVal;if(val)value=this._adjustValue(null,val),hasVal=!0;else{e.preventDefault();var _this=this,vertical=this.options.vertical,param=vertical?"height":"width",direction=vertical?"top":"left",eventOffset=vertical?e.pageY:e.pageX,barDim=(this.$handle[0].getBoundingClientRect()[param],this.$element[0].getBoundingClientRect()[param]),windowScroll=vertical?$(window).scrollTop():$(window).scrollLeft(),elemOffset=this.$element.offset()[direction];e.clientY===e.pageY&&(eventOffset+=windowScroll);var barXY,eventFromBar=eventOffset-elemOffset;barXY=eventFromBar<0?0:eventFromBar>barDim?barDim:eventFromBar;var offsetPct=percent(barXY,barDim);if(value=this._value(offsetPct),Foundation.rtl()&&!this.options.vertical&&(value=this.options.end-value),value=_this._adjustValue(null,value),hasVal=!1,!$handle){$handle=absPosition(this.$handle,direction,barXY,param)<=absPosition(this.$handle2,direction,barXY,param)?this.$handle:this.$handle2}}this._setHandlePos($handle,value,hasVal)}},{key:"_adjustValue",value:function($handle,value){var val,left,prev_val,next_val,step=this.options.step,div=parseFloat(step/2);return val=$handle?parseFloat($handle.attr("aria-valuenow")):value,left=val%step,prev_val=val-left,next_val=prev_val+step,0===left?val:val=val>=prev_val+div?next_val:prev_val}},{key:"_events",value:function(){this._eventsForHandle(this.$handle),this.handles[1]&&this._eventsForHandle(this.$handle2)}},{key:"_eventsForHandle",value:function($handle){var curHandle,_this=this;if(this.inputs.off("change.zf.slider").on("change.zf.slider",function(e){var idx=_this.inputs.index($(this));_this._handleEvent(e,_this.handles.eq(idx),$(this).val())}),this.options.clickSelect&&this.$element.off("click.zf.slider").on("click.zf.slider",function(e){if(_this.$element.data("dragging"))return!1;$(e.target).is("[data-slider-handle]")||(_this.options.doubleSided?_this._handleEvent(e):_this._handleEvent(e,_this.$handle))}),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",!0),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",!1),$body.off("mousemove.zf.slider mouseup.zf.slider")})}).on("selectstart.zf.slider touchmove.zf.slider",function(e){e.preventDefault()})}$handle.off("keydown.zf.slider").on("keydown.zf.slider",function(e){var newValue,_$handle=$(this),idx=_this.options.doubleSided?_this.handles.index(_$handle):0,oldValue=parseFloat(_this.inputs.eq(idx).val());Foundation.Keyboard.handleKey(e,"Slider",{decrease:function(){newValue=oldValue-_this.options.step},increase:function(){newValue=oldValue+_this.options.step},decrease_fast:function(){newValue=oldValue-10*_this.options.step},increase_fast:function(){newValue=oldValue+10*_this.options.step},handled:function(){e.preventDefault(),_this._setHandlePos(_$handle,newValue,!0)}})})}},{key:"destroy",value:function(){this.handles.off(".zf.slider"),this.inputs.off(".zf.slider"),this.$element.off(".zf.slider"),clearTimeout(this.timeout),Foundation.unregisterPlugin(this)}}]),Slider}();Slider.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"},Foundation.plugin(Slider,"Slider")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){function emCalc(em){return parseInt(window.getComputedStyle(document.body,null).fontSize,10)*em}var Sticky=function(){function Sticky(element,options){_classCallCheck(this,Sticky),this.$element=element,this.options=$.extend({},Sticky.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Sticky")}return _createClass(Sticky,[{key:"_init",value:function(){var $parent=this.$element.parent("[data-sticky-container]"),id=this.$element[0].id||Foundation.GetYoDigits(6,"sticky"),_this=this;$parent.length||(this.wasWrapped=!0),this.$container=$parent.length?$parent:$(this.options.container).wrapInner(this.$element),this.$container.addClass(this.options.containerClass),this.$element.addClass(this.options.stickyClass).attr({"data-resize":id}),this.scrollCount=this.options.checkEvery,this.isStuck=!1,$(window).one("load.zf.sticky",function(){_this.containerHeight="none"==_this.$element.css("display")?0:_this.$element[0].getBoundingClientRect().height,_this.$container.css("height",_this.containerHeight),_this.elemHeight=_this.containerHeight,""!==_this.options.anchor?_this.$anchor=$("#"+_this.options.anchor):_this._parsePoints(),_this._setSizes(function(){var scroll=window.pageYOffset;_this._calc(!1,scroll),_this.isStuck||_this._removeSticky(!(scroll>=_this.topPoint))}),_this._events(id.split("-").reverse().join("-"))})}},{key:"_parsePoints",value:function(){for(var top=""==this.options.topAnchor?1:this.options.topAnchor,btm=""==this.options.btmAnchor?document.documentElement.scrollHeight:this.options.btmAnchor,pts=[top,btm],breaks={},i=0,len=pts.length;i<len&&pts[i];i++){var pt;if("number"==typeof pts[i])pt=pts[i];else{var place=pts[i].split(":"),anchor=$("#"+place[0]);pt=anchor.offset().top,place[1]&&"bottom"===place[1].toLowerCase()&&(pt+=anchor[0].getBoundingClientRect().height)}breaks[i]=pt}this.points=breaks}},{key:"_events",value:function(id){var _this=this,scrollListener=this.scrollListener="scroll.zf."+id;this.isOn||(this.canStick&&(this.isOn=!0,$(window).off(scrollListener).on(scrollListener,function(e){0===_this.scrollCount?(_this.scrollCount=_this.options.checkEvery,_this._setSizes(function(){_this._calc(!1,window.pageYOffset)})):(_this.scrollCount--,_this._calc(!1,window.pageYOffset))})),this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(e,el){_this._setSizes(function(){_this._calc(!1),_this.canStick?_this.isOn||_this._events(id):_this.isOn&&_this._pauseListeners(scrollListener)})}))}},{key:"_pauseListeners",value:function(scrollListener){this.isOn=!1,$(window).off(scrollListener),this.$element.trigger("pause.zf.sticky")}},{key:"_calc",value:function(checkSizes,scroll){if(checkSizes&&this._setSizes(),!this.canStick)return this.isStuck&&this._removeSticky(!0),!1;scroll||(scroll=window.pageYOffset),scroll>=this.topPoint?scroll<=this.bottomPoint?this.isStuck||this._setSticky():this.isStuck&&this._removeSticky(!1):this.isStuck&&this._removeSticky(!0)}},{key:"_setSticky",value:function(){var _this=this,stickTo=this.options.stickTo,mrgn="top"===stickTo?"marginTop":"marginBottom",notStuckTo="top"===stickTo?"bottom":"top",css={};css[mrgn]=this.options[mrgn]+"em",css[stickTo]=0,css[notStuckTo]="auto",this.isStuck=!0,this.$element.removeClass("is-anchored is-at-"+notStuckTo).addClass("is-stuck is-at-"+stickTo).css(css).trigger("sticky.zf.stuckto:"+stickTo),this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){_this._setSizes()})}},{key:"_removeSticky",value:function(isTop){var stickTo=this.options.stickTo,stickToTop="top"===stickTo,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",css.top=isTop?0:anchorPt,this.isStuck=!1,this.$element.removeClass("is-stuck is-at-"+stickTo).addClass("is-anchored is-at-"+topOrBottom).css(css).trigger("sticky.zf.unstuckfrom:"+topOrBottom)}},{key:"_setSizes",value:function(cb){this.canStick=Foundation.MediaQuery.is(this.options.stickyOn),this.canStick||cb&&"function"==typeof cb&&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);this.$anchor&&this.$anchor.length?this.anchorHeight=this.$anchor[0].getBoundingClientRect().height:this._parsePoints(),this.$element.css({"max-width":newElemWidth-pdngl-pdngr+"px"});var newContainerHeight=this.$element[0].getBoundingClientRect().height||this.containerHeight;if("none"==this.$element.css("display")&&(newContainerHeight=0),this.containerHeight=newContainerHeight,this.$container.css({height:newContainerHeight}),this.elemHeight=newContainerHeight,!this.isStuck&&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(){cb&&"function"==typeof cb&&cb()})}},{key:"_setBreakPoints",value:function(elemHeight,cb){if(!this.canStick){if(!cb||"function"!=typeof cb)return!1;cb()}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,winHeight=window.innerHeight;"top"===this.options.stickTo?(topPoint-=mTop,bottomPoint-=elemHeight+mTop):"bottom"===this.options.stickTo&&(topPoint-=winHeight-(elemHeight+mBtm),bottomPoint-=winHeight-mBtm),this.topPoint=topPoint,this.bottomPoint=bottomPoint,cb&&"function"==typeof cb&&cb()}},{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"),this.$anchor&&this.$anchor.length&&this.$anchor.off("change.zf.sticky"),$(window).off(this.scrollListener),this.wasWrapped?this.$element.unwrap():this.$container.removeClass(this.options.containerClass).css({height:""}),Foundation.unregisterPlugin(this)}}]),Sticky}();Sticky.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},Foundation.plugin(Sticky,"Sticky")}(jQuery);var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj},_createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Tabs=function(){function Tabs(element,options){_classCallCheck(this,Tabs),this.$element=element,this.options=$.extend({},Tabs.defaults,this.$element.data(),options),this._init(),Foundation.registerPlugin(this,"Tabs"),Foundation.Keyboard.register("Tabs",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"previous",ARROW_DOWN:"next",ARROW_LEFT:"previous"})}return _createClass(Tabs,[{key:"_init",value:function(){var _this2=this,_this=this;if(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[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}),$tabContent.attr({role:"tabpanel","aria-hidden":!isActive,"aria-labelledby":linkId}),isActive&&_this.options.autoFocus&&$(window).load(function(){$("html, body").animate({scrollTop:$elem.offset().top},_this.options.deepLinkSmudgeDelay,function(){$link.focus()})})}),this.options.matchHeight){var $images=this.$tabContent.find("img");$images.length?Foundation.onImagesLoaded($images,this._setHeight.bind(this)):this._setHeight()}this._checkDeepLink=function(){var anchor=window.location.hash;if(anchor.length){var $link=_this2.$element.find('[href="'+anchor+'"]');if($link.length){if(_this2.selectTab($(anchor),!0),_this2.options.deepLinkSmudge){var offset=_this2.$element.offset();$("html, body").animate({scrollTop:offset.top},_this2.options.deepLinkSmudgeDelay)}_this2.$element.trigger("deeplink.zf.tabs",[$link,$(anchor)])}}},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),$(window).on("changed.zf.mediaquery",this._setHeightMqHandler)),this.options.deepLink&&$(window).on("popstate",this._checkDeepLink)}},{key:"_addClickHandler",value:function(){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))})}},{key:"_addKeyHandler",value:function(){var _this=this;this.$tabTitles.off("keydown.zf.tabs").on("keydown.zf.tabs",function(e){if(9!==e.which){var $prevElement,$nextElement,$element=$(this),$elements=$element.parent("ul").children("li");$elements.each(function(i){if($(this).is($element))return void(_this.options.wrapOnKeys?($prevElement=0===i?$elements.last():$elements.eq(i-1),$nextElement=i===$elements.length-1?$elements.first():$elements.eq(i+1)):($prevElement=$elements.eq(Math.max(0,i-1)),$nextElement=$elements.eq(Math.min(i+1,$elements.length-1))))}),Foundation.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()}})}})}},{key:"_handleTabChange",value:function($target,historyHandled){if($target.hasClass(""+this.options.linkActiveClass))return void(this.options.activeCollapse&&(this._collapseTab($target),this.$element.trigger("collapse.zf.tabs",[$target])));var $oldTab=this.$element.find("."+this.options.linkClass+"."+this.options.linkActiveClass),$tabLink=$target.find('[role="tab"]'),hash=$tabLink[0].hash,$targetContent=this.$tabContent.find(hash);if(this._collapseTab($oldTab),this._openTab($target),this.options.deepLink&&!historyHandled){var anchor=$target.find("a").attr("href");this.options.updateHistory?history.pushState({},"",anchor):history.replaceState({},"",anchor)}this.$element.trigger("change.zf.tabs",[$target,$targetContent]),$targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_openTab",value:function($target){var $tabLink=$target.find('[role="tab"]'),hash=$tabLink[0].hash,$targetContent=this.$tabContent.find(hash);$target.addClass(""+this.options.linkActiveClass),$tabLink.attr({"aria-selected":"true"}),$targetContent.addClass(""+this.options.panelActiveClass).attr({"aria-hidden":"false"})}},{key:"_collapseTab",value:function($target){var $target_anchor=$target.removeClass(""+this.options.linkActiveClass).find('[role="tab"]').attr({"aria-selected":"false"});$("#"+$target_anchor.attr("aria-controls")).removeClass(""+this.options.panelActiveClass).attr({"aria-hidden":"true"})}},{key:"selectTab",value:function(elem,historyHandled){var idStr;idStr="object"===(void 0===elem?"undefined":_typeof(elem))?elem[0].id:elem,idStr.indexOf("#")<0&&(idStr="#"+idStr);var $target=this.$tabTitles.find('[href="'+idStr+'"]').parent("."+this.options.linkClass);this._handleTabChange($target,historyHandled)}},{key:"_setHeight",value:function(){var max=0,_this=this;this.$tabContent.find("."+this.options.panelClass).css("height","").each(function(){var panel=$(this),isActive=panel.hasClass(""+_this.options.panelActiveClass);isActive||panel.css({visibility:"hidden",display:"block"});var temp=this.getBoundingClientRect().height;isActive||panel.css({visibility:"",display:""}),max=temp>max?temp:max}).css("height",max+"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&&$(window).off("changed.zf.mediaquery",this._setHeightMqHandler),this.options.deepLink&&$(window).off("popstate",this._checkDeepLink),Foundation.unregisterPlugin(this)}}]),Tabs}();Tabs.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"},Foundation.plugin(Tabs,"Tabs")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Toggler=function(){function Toggler(element,options){_classCallCheck(this,Toggler),this.$element=element,this.options=$.extend({},Toggler.defaults,element.data(),options),this.className="",this._init(),this._events(),Foundation.registerPlugin(this,"Toggler")}return _createClass(Toggler,[{key:"_init",value:function(){var input;this.options.animate?(input=this.options.animate.split(" "),this.animationIn=input[0],this.animationOut=input[1]||null):(input=this.$element.data("toggler"),this.className="."===input[0]?input.slice(1):input);var id=this.$element[0].id;$('[data-open="'+id+'"], [data-close="'+id+'"], [data-toggle="'+id+'"]').attr("aria-controls",id),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 isOn=this.$element.hasClass(this.className);isOn?this.$element.trigger("on.zf.toggler"):this.$element.trigger("off.zf.toggler"),this._updateARIA(isOn),this.$element.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_toggleAnimate",value:function(){var _this=this;this.$element.is(":hidden")?Foundation.Motion.animateIn(this.$element,this.animationIn,function(){_this._updateARIA(!0),this.trigger("on.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")}):Foundation.Motion.animateOut(this.$element,this.animationOut,function(){_this._updateARIA(!1),this.trigger("off.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")})}},{key:"_updateARIA",value:function(isOn){this.$element.attr("aria-expanded",!!isOn)}},{key:"destroy",value:function(){this.$element.off(".zf.toggler"),Foundation.unregisterPlugin(this)}}]),Toggler}();Toggler.defaults={animate:!1},Foundation.plugin(Toggler,"Toggler")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var Tooltip=function(){function Tooltip(element,options){_classCallCheck(this,Tooltip),this.$element=element,this.options=$.extend({},Tooltip.defaults,this.$element.data(),options),this.isActive=!1,this.isClick=!1,this._init(),Foundation.registerPlugin(this,"Tooltip")}return _createClass(Tooltip,[{key:"_init",value:function(){var elemId=this.$element.attr("aria-describedby")||Foundation.GetYoDigits(6,"tooltip");this.options.positionClass=this.options.positionClass||this._getPositionClass(this.$element),this.options.tipText=this.options.tipText||this.$element.attr("title"),this.template=this.options.template?$(this.options.template):this._buildTemplate(elemId),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":elemId,"data-yeti-box":elemId,"data-toggle":elemId,"data-resize":elemId}).addClass(this.options.triggerClass),this.usedPositions=[],this.counter=4,this.classChanged=!1,this._events()}},{key:"_getPositionClass",value:function(element){if(!element)return"";var position=element[0].className.match(/\b(top|left|right)\b/g);return position=position?position[0]:""}},{key:"_buildTemplate",value:function(id){var templateClasses=(this.options.tooltipClass+" "+this.options.positionClass+" "+this.options.templateClasses).trim();return $("<div></div>").addClass(templateClasses).attr({role:"tooltip","aria-hidden":!0,"data-is-active":!1,"data-is-focus":!1,id:id})}},{key:"_reposition",value:function(position){this.usedPositions.push(position||"bottom"),!position&&this.usedPositions.indexOf("top")<0?this.template.addClass("top"):"top"===position&&this.usedPositions.indexOf("bottom")<0?this.template.removeClass(position):"left"===position&&this.usedPositions.indexOf("right")<0?this.template.removeClass(position).addClass("right"):"right"===position&&this.usedPositions.indexOf("left")<0?this.template.removeClass(position).addClass("left"):!position&&this.usedPositions.indexOf("top")>-1&&this.usedPositions.indexOf("left")<0?this.template.addClass("left"):"top"===position&&this.usedPositions.indexOf("bottom")>-1&&this.usedPositions.indexOf("left")<0?this.template.removeClass(position).addClass("left"):"left"===position&&this.usedPositions.indexOf("right")>-1&&this.usedPositions.indexOf("bottom")<0?this.template.removeClass(position):("right"===position&&this.usedPositions.indexOf("left")>-1&&this.usedPositions.indexOf("bottom"),this.template.removeClass(position)),this.classChanged=!0,this.counter--}},{key:"_setPosition",value:function(){var position=this._getPositionClass(this.template),$tipDims=Foundation.Box.GetDimensions(this.template),$anchorDims=Foundation.Box.GetDimensions(this.$element),direction="left"===position?"left":"right"===position?"left":"top",param="top"===direction?"height":"width";"height"===param?this.options.vOffset:this.options.hOffset;if($tipDims.width>=$tipDims.windowDims.width||!this.counter&&!Foundation.Box.ImNotTouchingYou(this.template))return this.template.offset(Foundation.Box.GetOffsets(this.template,this.$element,"center bottom",this.options.vOffset,this.options.hOffset,!0)).css({width:$anchorDims.windowDims.width-2*this.options.hOffset,height:"auto"}),!1;for(this.template.offset(Foundation.Box.GetOffsets(this.template,this.$element,"center "+(position||"bottom"),this.options.vOffset,this.options.hOffset));!Foundation.Box.ImNotTouchingYou(this.template)&&this.counter;)this._reposition(position),this._setPosition()}},{key:"show",value:function(){if("all"!==this.options.showOn&&!Foundation.MediaQuery.is(this.options.showOn))return!1;var _this=this;this.template.css("visibility","hidden").show(),this._setPosition(),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 _this=this;this.template.stop().attr({"aria-hidden":!0,"data-is-active":!1}).fadeOut(this.options.fadeOutDuration,function(){_this.isActive=!1,_this.isClick=!1,_this.classChanged&&(_this.template.removeClass(_this._getPositionClass(_this.template)).addClass(_this.options.positionClass),_this.usedPositions=[],_this.counter=4,_this.classChanged=!1)}),this.$element.trigger("hide.zf.tooltip")}},{key:"_events",value:function(){var _this=this,isFocus=(this.template,!1);this.options.disableHover||this.$element.on("mouseenter.zf.tooltip",function(e){_this.isActive||(_this.timeout=setTimeout(function(){_this.show()},_this.options.hoverDelay))}).on("mouseleave.zf.tooltip",function(e){clearTimeout(_this.timeout),(!isFocus||_this.isClick&&!_this.options.clickOpen)&&_this.hide()}),this.options.clickOpen?this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),_this.isClick||(_this.isClick=!0,!_this.options.disableHover&&_this.$element.attr("tabindex")||_this.isActive||_this.show())}):this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),_this.isClick=!0}),this.options.disableForTouch||this.$element.on("tap.zf.tooltip touchend.zf.tooltip",function(e){_this.isActive?_this.hide():_this.show()}),this.$element.on({"close.zf.trigger":this.hide.bind(this)}),this.$element.on("focus.zf.tooltip",function(e){if(isFocus=!0,_this.isClick)return _this.options.clickOpen||(isFocus=!1),!1;_this.show()}).on("focusout.zf.tooltip",function(e){isFocus=!1,_this.isClick=!1,_this.hide()}).on("resizeme.zf.trigger",function(){_this.isActive&&_this._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(),Foundation.unregisterPlugin(this)}}]),Tooltip}();Tooltip.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:"",vOffset:10,hOffset:12,allowHtml:!1},Foundation.plugin(Tooltip,"Tooltip")}(jQuery),function($){function ImNotTouchingYou(element,parent,lrOnly,tbOnly){var top,bottom,left,right,eleDims=GetDimensions(element);if(parent){var parDims=GetDimensions(parent);bottom=eleDims.offset.top+eleDims.height<=parDims.height+parDims.offset.top,
-top=eleDims.offset.top>=parDims.offset.top,left=eleDims.offset.left>=parDims.offset.left,right=eleDims.offset.left+eleDims.width<=parDims.width+parDims.offset.left}else bottom=eleDims.offset.top+eleDims.height<=eleDims.windowDims.height+eleDims.windowDims.offset.top,top=eleDims.offset.top>=eleDims.windowDims.offset.top,left=eleDims.offset.left>=eleDims.windowDims.offset.left,right=eleDims.offset.left+eleDims.width<=eleDims.windowDims.width;var allDirs=[bottom,top,left,right];return lrOnly?left===right==!0:tbOnly?top===bottom==!0:-1===allDirs.indexOf(!1)}function GetDimensions(elem,test){if((elem=elem.length?elem[0]: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}}}}function GetOffsets(element,anchor,position,vOffset,hOffset,isOverflow){var $eleDims=GetDimensions(element),$anchorDims=anchor?GetDimensions(anchor):null;switch(position){case"top":return{left:Foundation.rtl()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width:$anchorDims.offset.left,top:$anchorDims.offset.top-($eleDims.height+vOffset)};case"left":return{left:$anchorDims.offset.left-($eleDims.width+hOffset),top:$anchorDims.offset.top};case"right":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset,top:$anchorDims.offset.top};case"center top":return{left:$anchorDims.offset.left+$anchorDims.width/2-$eleDims.width/2,top:$anchorDims.offset.top-($eleDims.height+vOffset)};case"center bottom":return{left:isOverflow?hOffset:$anchorDims.offset.left+$anchorDims.width/2-$eleDims.width/2,top:$anchorDims.offset.top+$anchorDims.height+vOffset};case"center left":return{left:$anchorDims.offset.left-($eleDims.width+hOffset),top:$anchorDims.offset.top+$anchorDims.height/2-$eleDims.height/2};case"center right":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset+1,top:$anchorDims.offset.top+$anchorDims.height/2-$eleDims.height/2};case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-$eleDims.height/2};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2,top:$eleDims.windowDims.offset.top+vOffset};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};case"left bottom":return{left:$anchorDims.offset.left,top:$anchorDims.offset.top+$anchorDims.height+vOffset};case"right bottom":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset-$eleDims.width,top:$anchorDims.offset.top+$anchorDims.height+vOffset};default:return{left:Foundation.rtl()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width:$anchorDims.offset.left+hOffset,top:$anchorDims.offset.top+$anchorDims.height+vOffset}}}Foundation.Box={ImNotTouchingYou:ImNotTouchingYou,GetDimensions:GetDimensions,GetOffsets:GetOffsets}}(jQuery),function($){var keyCodes={9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"},commands={},Keyboard={keys:function(kcs){var k={};for(var kc in kcs)k[kcs[kc]]=kcs[kc];return k}(keyCodes),parseKey:function(event){var key=keyCodes[event.which||event.keyCode]||String.fromCharCode(event.which).toUpperCase();return key=key.replace(/\W+/,""),event.shiftKey&&(key="SHIFT_"+key),event.ctrlKey&&(key="CTRL_"+key),event.altKey&&(key="ALT_"+key),key=key.replace(/_$/,"")},handleKey:function(event,component,functions){var cmds,command,fn,commandList=commands[component],keyCode=this.parseKey(event);if(!commandList)return console.warn("Component not defined!");if(cmds=void 0===commandList.ltr?commandList:Foundation.rtl()?$.extend({},commandList.ltr,commandList.rtl):$.extend({},commandList.rtl,commandList.ltr),command=cmds[keyCode],(fn=functions[command])&&"function"==typeof fn){var returnValue=fn.apply();(functions.handled||"function"==typeof functions.handled)&&functions.handled(returnValue)}else(functions.unhandled||"function"==typeof functions.unhandled)&&functions.unhandled()},findFocusable:function($element){return!!$element&&$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(){return!(!$(this).is(":visible")||$(this).attr("tabindex")<0)})},register:function(componentName,cmds){commands[componentName]=cmds},trapFocus:function($element){var $focusable=Foundation.Keyboard.findFocusable($element),$firstFocusable=$focusable.eq(0),$lastFocusable=$focusable.eq(-1);$element.on("keydown.zf.trapfocus",function(event){event.target===$lastFocusable[0]&&"TAB"===Foundation.Keyboard.parseKey(event)?(event.preventDefault(),$firstFocusable.focus()):event.target===$firstFocusable[0]&&"SHIFT_TAB"===Foundation.Keyboard.parseKey(event)&&(event.preventDefault(),$lastFocusable.focus())})},releaseFocus:function($element){$element.off("keydown.zf.trapfocus")}};Foundation.Keyboard=Keyboard}(jQuery),function($){function Move(duration,elem,fn){function move(ts){start||(start=ts),prog=ts-start,fn.apply(elem),prog<duration?anim=window.requestAnimationFrame(move,elem):(window.cancelAnimationFrame(anim),elem.trigger("finished.zf.animate",[elem]).triggerHandler("finished.zf.animate",[elem]))}var anim,prog,start=null;if(0===duration)return fn.apply(elem),void elem.trigger("finished.zf.animate",[elem]).triggerHandler("finished.zf.animate",[elem]);anim=window.requestAnimationFrame(move)}function animate(isIn,element,animation,cb){function finish(){isIn||element.hide(),reset(),cb&&cb.apply(element)}function reset(){element[0].style.transitionDuration=0,element.removeClass(initClass+" "+activeClass+" "+animation)}if(element=$(element).eq(0),element.length){var initClass=isIn?initClasses[0]:initClasses[1],activeClass=isIn?activeClasses[0]:activeClasses[1];reset(),element.addClass(animation).css("transition","none"),requestAnimationFrame(function(){element.addClass(initClass),isIn&&element.show()}),requestAnimationFrame(function(){element[0].offsetWidth,element.css("transition","").addClass(activeClass)}),element.one(Foundation.transitionend(element),finish)}}var initClasses=["mui-enter","mui-leave"],activeClasses=["mui-enter-active","mui-leave-active"],Motion={animateIn:function(element,animation,cb){animate(!0,element,animation,cb)},animateOut:function(element,animation,cb){animate(!1,element,animation,cb)}};Foundation.Move=Move,Foundation.Motion=Motion}(jQuery),function($){var Nest={Feather:function(menu){var type=arguments.length>1&&void 0!==arguments[1]?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";items.each(function(){var $item=$(this),$sub=$item.children("ul");$sub.length&&($item.addClass(hasSubClass).attr({"aria-haspopup":!0,"aria-label":$item.children("a:first").text()}),"drilldown"===type&&$item.attr({"aria-expanded":!1}),$sub.addClass("submenu "+subMenuClass).attr({"data-submenu":"",role:"menu"}),"drilldown"===type&&$sub.attr({"aria-hidden":!0})),$item.parent("[data-submenu]").length&&$item.addClass("is-submenu-item "+subItemClass)})},Burn:function(menu,type){var 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","")}};Foundation.Nest=Nest}(jQuery),function($){function Timer(elem,options,cb){var start,timer,_this=this,duration=options.duration,nameSpace=Object.keys(elem.data())[0]||"timer",remain=-1;this.isPaused=!1,this.restart=function(){remain=-1,clearTimeout(timer),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(timer),remain=remain<=0?duration:remain,elem.data("paused",!1),start=Date.now(),timer=setTimeout(function(){options.infinite&&_this.restart(),cb&&"function"==typeof cb&&cb()},remain),elem.trigger("timerstart.zf."+nameSpace)},this.pause=function(){this.isPaused=!0,clearTimeout(timer),elem.data("paused",!0);var end=Date.now();remain-=end-start,elem.trigger("timerpaused.zf."+nameSpace)}}function onImagesLoaded(images,callback){function singleImageLoaded(){0===--unloaded&&callback()}var unloaded=images.length;0===unloaded&&callback(),images.each(function(){if(this.complete||4===this.readyState||"complete"===this.readyState)singleImageLoaded();else{var src=$(this).attr("src");$(this).attr("src",src+(src.indexOf("?")>=0?"&":"?")+(new Date).getTime()),$(this).one("load",function(){singleImageLoaded()})}})}Foundation.Timer=Timer,Foundation.onImagesLoaded=onImagesLoaded}(jQuery),function($){function onTouchEnd(){this.removeEventListener("touchmove",onTouchMove),this.removeEventListener("touchend",onTouchEnd),isMoving=!1}function onTouchMove(e){if($.spotSwipe.preventDefault&&e.preventDefault(),isMoving){var dir,x=e.touches[0].pageX,dx=(e.touches[0].pageY,startPosX-x);elapsedTime=(new Date).getTime()-startTime,Math.abs(dx)>=$.spotSwipe.moveThreshold&&elapsedTime<=$.spotSwipe.timeThreshold&&(dir=dx>0?"left":"right"),dir&&(e.preventDefault(),onTouchEnd.call(this),$(this).trigger("swipe",dir).trigger("swipe"+dir))}}function onTouchStart(e){1==e.touches.length&&(startPosX=e.touches[0].pageX,startPosY=e.touches[0].pageY,isMoving=!0,startTime=(new Date).getTime(),this.addEventListener("touchmove",onTouchMove,!1),this.addEventListener("touchend",onTouchEnd,!1))}function init(){this.addEventListener&&this.addEventListener("touchstart",onTouchStart,!1)}$.spotSwipe={version:"1.0.0",enabled:"ontouchstart"in document.documentElement,preventDefault:!1,moveThreshold:75,timeThreshold:200};var startPosX,startPosY,startTime,elapsedTime,isMoving=!1;$.event.special.swipe={setup:init},$.each(["left","up","down","right"],function(){$.event.special["swipe"+this]={setup:function(){$(this).on("swipe",$.noop)}}})}(jQuery),function($){$.fn.addTouch=function(){this.each(function(i,el){$(el).bind("touchstart touchmove touchend touchcancel",function(){handleTouch(event)})});var handleTouch=function(event){var simulatedEvent,touches=event.changedTouches,first=touches[0],eventTypes={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup"},type=eventTypes[event.type];"MouseEvent"in window&&"function"==typeof window.MouseEvent?simulatedEvent=new window.MouseEvent(type,{bubbles:!0,cancelable:!0,screenX:first.screenX,screenY:first.screenY,clientX:first.clientX,clientY:first.clientY}):(simulatedEvent=document.createEvent("MouseEvent"),simulatedEvent.initMouseEvent(type,!0,!0,window,1,first.screenX,first.screenY,first.clientX,first.clientY,!1,!1,!1,!1,0,null)),first.target.dispatchEvent(simulatedEvent)}}}(jQuery);var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function checkListeners(){eventsListener(),resizeListener(),scrollListener(),mutateListener(),closemeListener()}function closemeListener(pluginName){var yetiBoxes=$("[data-yeti-box]"),plugNames=["dropdown","tooltip","reveal"];if(pluginName&&("string"==typeof pluginName?plugNames.push(pluginName):"object"===(void 0===pluginName?"undefined":_typeof(pluginName))&&"string"==typeof pluginName[0]?plugNames.concat(pluginName):console.error("Plugin names must be strings")),yetiBoxes.length){var listeners=plugNames.map(function(name){return"closeme.zf."+name}).join(" ");$(window).off(listeners).on(listeners,function(e,pluginId){var plugin=e.namespace.split(".")[0];$("[data-"+plugin+"]").not('[data-yeti-box="'+pluginId+'"]').each(function(){var _this=$(this);_this.triggerHandler("close.zf.trigger",[_this])})})}}function resizeListener(debounce){var timer=void 0,$nodes=$("[data-resize]");$nodes.length&&$(window).off("resize.zf.trigger").on("resize.zf.trigger",function(e){timer&&clearTimeout(timer),timer=setTimeout(function(){MutationObserver||$nodes.each(function(){$(this).triggerHandler("resizeme.zf.trigger")}),$nodes.attr("data-events","resize")},debounce||10)})}function scrollListener(debounce){var timer=void 0,$nodes=$("[data-scroll]");$nodes.length&&$(window).off("scroll.zf.trigger").on("scroll.zf.trigger",function(e){timer&&clearTimeout(timer),timer=setTimeout(function(){MutationObserver||$nodes.each(function(){$(this).triggerHandler("scrollme.zf.trigger")}),$nodes.attr("data-events","scroll")},debounce||10)})}function mutateListener(debounce){var $nodes=$("[data-mutate]");$nodes.length&&MutationObserver&&$nodes.each(function(){$(this).triggerHandler("mutateme.zf.trigger")})}function eventsListener(){if(!MutationObserver)return!1;var nodes=document.querySelectorAll("[data-resize], [data-scroll], [data-mutate]"),listeningElementsMutation=function(mutationRecordsList){var $target=$(mutationRecordsList[0].target);switch(mutationRecordsList[0].type){case"attributes":"scroll"===$target.attr("data-events")&&"data-events"===mutationRecordsList[0].attributeName&&$target.triggerHandler("scrollme.zf.trigger",[$target,window.pageYOffset]),"resize"===$target.attr("data-events")&&"data-events"===mutationRecordsList[0].attributeName&&$target.triggerHandler("resizeme.zf.trigger",[$target]),"style"===mutationRecordsList[0].attributeName&&($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!1}};if(nodes.length)for(var i=0;i<=nodes.length-1;i++){var elementObserver=new MutationObserver(listeningElementsMutation);elementObserver.observe(nodes[i],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}}var MutationObserver=function(){for(var prefixes=["WebKit","Moz","O","Ms",""],i=0;i<prefixes.length;i++)if(prefixes[i]+"MutationObserver"in window)return window[prefixes[i]+"MutationObserver"];return!1}(),triggers=function(el,type){el.data(type).split(" ").forEach(function(id){$("#"+id)["close"===type?"trigger":"triggerHandler"](type+".zf.trigger",[el])})};$(document).on("click.zf.trigger","[data-open]",function(){triggers($(this),"open")}),$(document).on("click.zf.trigger","[data-close]",function(){$(this).data("close")?triggers($(this),"close"):$(this).trigger("close.zf.trigger")}),$(document).on("click.zf.trigger","[data-toggle]",function(){$(this).data("toggle")?triggers($(this),"toggle"):$(this).trigger("toggle.zf.trigger")}),$(document).on("close.zf.trigger","[data-closable]",function(e){e.stopPropagation();var animation=$(this).data("closable");""!==animation?Foundation.Motion.animateOut($(this),animation,function(){$(this).trigger("closed.zf")}):$(this).fadeOut().trigger("closed.zf")}),$(document).on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",function(){var id=$(this).data("toggle-focus");$("#"+id).triggerHandler("toggle.zf.trigger",[$(this)])}),$(window).on("load",function(){checkListeners()}),Foundation.IHearYou=checkListeners}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var ResponsiveAccordionTabs=function(){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,this.$element.attr("id")||this.$element.attr("id",Foundation.GetYoDigits(6,"responsiveaccordiontabs")),this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveAccordionTabs")}return _createClass(ResponsiveAccordionTabs,[{key:"_init",value:function(){if("string"==typeof this.rules){for(var rulesTree={},rules=this.rules.split(" "),i=0;i<rules.length;i++){var rule=rules[i].split("-"),ruleSize=rule.length>1?rule[0]:"small",rulePlugin=rule.length>1?rule[1]:rule[0];null!==MenuPlugins[rulePlugin]&&(rulesTree[ruleSize]=MenuPlugins[rulePlugin])}this.rules=rulesTree}this._getAllOptions(),$.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){var _this=this;_this.allOptions={};for(var key in MenuPlugins)if(MenuPlugins.hasOwnProperty(key)){var obj=MenuPlugins[key];try{var dummyPlugin=$("<ul></ul>"),tmpPlugin=new obj.plugin(dummyPlugin,_this.options);for(var keyKey in tmpPlugin.options)if(tmpPlugin.options.hasOwnProperty(keyKey)&&"zfPlugin"!==keyKey){var objObj=tmpPlugin.options[keyKey];_this.allOptions[keyKey]=objObj}tmpPlugin.destroy()}catch(e){}}}},{key:"_events",value:function(){var _this=this;$(window).on("changed.zf.mediaquery",function(){_this._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var matchedMq,_this=this;$.each(this.rules,function(key){Foundation.MediaQuery.atLeast(key)&&(matchedMq=key)}),matchedMq&&(this.currentPlugin instanceof this.rules[matchedMq].plugin||($.each(MenuPlugins,function(key,value){_this.$element.removeClass(value.cssClass)}),this.$element.addClass(this.rules[matchedMq].cssClass),this.currentPlugin&&(!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(toSet){var _this=this,fromString="accordion",$panels=$("[data-tabs-content="+this.$element.attr("id")+"]");if($panels.length&&(fromString="tabs"),fromString!==toSet){var tabsTitle=_this.allOptions.linkClass?_this.allOptions.linkClass:"tabs-title",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"),$liHeadsA=$liHeads.children("a").removeClass("accordion-title");if("tabs"===fromString?($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")):$panels=$liHeads.children("[data-tab-content]").removeClass("accordion-content"),$panels.css({display:"",visibility:""}),$liHeads.css({display:"",visibility:""}),"accordion"===toSet)$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("tabs"===toSet){var $tabsContent=$("[data-tabs-content="+_this.$element.attr("id")+"]"),$placeholder=$("#tabs-placeholder-"+_this.$element.attr("id"));$placeholder.length?($tabsContent=$('<div class="tabs-content"></div>').insertAfter($placeholder).attr("data-tabs-content",_this.$element.attr("id")),$placeholder.remove()):$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),hash=$liHeadsA.get(key).hash.slice(1),id=$(value).attr("id")||Foundation.GetYoDigits(6,"accordion");hash!==id&&(""!==hash?$(value).attr("id",hash):(hash=id,$(value).attr("id",hash),$($liHeadsA.get(key)).attr("href",$($liHeadsA.get(key)).attr("href").replace("#","")+"#"+hash))),$($liHeads.get(key)).hasClass("is-active")&&tempValue.addClass("is-active")}),$liHeads.addClass(tabsTitle)}}}},{key:"destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),$(window).off(".zf.ResponsiveAccordionTabs"),Foundation.unregisterPlugin(this)}}]),ResponsiveAccordionTabs}();ResponsiveAccordionTabs.defaults={};var MenuPlugins={tabs:{cssClass:"tabs",plugin:Foundation._plugins.tabs||null},accordion:{cssClass:"accordion",plugin:Foundation._plugins.accordion||null}};Foundation.plugin(ResponsiveAccordionTabs,"ResponsiveAccordionTabs")}(jQuery),document.body.className=document.body.className.replace("no-js","js"),window.wdsModal={},function(window,$,app){var $modalToggle=void 0,$focusableChildren=void 0,$player=void 0,$tag=document.createElement("script"),$firstScriptTag=document.getElementsByTagName("script")[0];app.init=function(){app.cache(),app.meetsRequirements()&&($firstScriptTag.parentNode.insertBefore($tag,$firstScriptTag),app.bindEvents())},app.cache=function(){app.$c={body:$("body")}},app.meetsRequirements=function(){return $(".modal-trigger").length},app.bindEvents=function(){app.$c.body.on("click touchstart",".modal-trigger",app.openModal),app.$c.body.on("click touchstart",".close",app.closeModal),app.$c.body.on("keydown",app.escKeyClose),app.$c.body.on("click touchstart","div.modal-open",app.closeModalByClick),app.$c.body.on("keydown",app.trapKeyboardMaybe)},app.openModal=function(){$modalToggle=$(this);var $modal=$($(this).data("target"));$modal.addClass("modal-open"),app.$c.body.addClass("modal-open"),$focusableChildren=$modal.find("a, :input, [tabindex]"),0<$focusableChildren.length&&$focusableChildren[0].focus()},app.closeModal=function(){var $modal=$($("div.modal-open .close").data("target")),$iframe=$modal.find("iframe");if($iframe.length){var url=$iframe.attr("src");url.includes("enablejsapi=1")?$player.stopVideo():$iframe.attr("src","").attr("src",url)}$modal.removeClass("modal-open"),app.$c.body.removeClass("modal-open"),$modalToggle.focus()},app.escKeyClose=function(event){27===event.keyCode&&app.closeModal()},app.closeModalByClick=function(event){$(event.target).parents("div").hasClass("modal-dialog")||app.closeModal()},app.trapKeyboardMaybe=function(event){if(9===event.which&&0<$(".modal-open").length){var $focused=$(":focus"),focusIndex=$focusableChildren.index($focused);0===focusIndex&&event.shiftKey?($focusableChildren[$focusableChildren.length-1].focus(),event.preventDefault()):event.shiftKey||focusIndex!==$focusableChildren.length-1||($focusableChildren[0].focus(),event.preventDefault())}},app.onYouTubeIframeAPIReady=function(){var $modal=$("div.modal"),$iframeid=$modal.find("iframe").attr("id");$player=new(void 0).Player($iframeid,{events:{onReady:app.onPlayerReady,onStateChange:app.onPlayerStateChange}})},app.onPlayerReady=function(){},app.onPlayerStateChange=function(){$(event.target.a).parents(".modal").find("a, :input, [tabindex]").first().focus()},$(app.init)}(window,jQuery,window.wdsModal),function(){var isWebkit=-1<navigator.userAgent.toLowerCase().indexOf("webkit"),isOpera=-1<navigator.userAgent.toLowerCase().indexOf("opera"),isIe=-1<navigator.userAgent.toLowerCase().indexOf("msie");(isWebkit||isOpera||isIe)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var element,id=location.hash.substring(1);/^[A-z0-9_-]+$/.test(id)&&(element=document.getElementById(id))&&(/^(?:a|select|input|button|textarea)$/i.test(element.tagName)||(element.tabIndex=-1),element.focus())},!1)}(),jQuery(document).foundation(),window.wdsWindowReady={},function(window,$,app){app.init=function(){app.cache(),app.bindEvents()},app.cache=function(){app.$c={window:$(window),body:$(document.body)}},app.bindEvents=function(){app.$c.window.load(app.addBodyClass)},app.addBodyClass=function(){app.$c.body.addClass("ready")},$(app.init)}(window,jQuery,window.wdsWindowReady);
\ No newline at end of file
+"use strict";function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor))throw new TypeError("Cannot call a class as a function")}var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function functionName(fn){if(void 0===Function.prototype.name){var funcNameRegex=/function\s([^(]{1,})\(/,results=funcNameRegex.exec(fn.toString());return results&&results.length>1?results[1].trim():""}return void 0===fn.prototype?fn.constructor.name:fn.prototype.constructor.name}function parseValue(str){return"true"===str||"false"!==str&&(isNaN(1*str)?str:parseFloat(str))}function hyphenate(str){return str.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}var Foundation={version:"6.3.1",_plugins:{},_uuids:[],rtl:function(){return"rtl"===$("html").attr("dir")},plugin:function(_plugin,name){var className=name||functionName(_plugin),attrName=hyphenate(className);this._plugins[attrName]=this[className]=_plugin},registerPlugin:function(plugin,name){var pluginName=name?hyphenate(name):functionName(plugin.constructor).toLowerCase();plugin.uuid=this.GetYoDigits(6,pluginName),plugin.$element.attr("data-"+pluginName)||plugin.$element.attr("data-"+pluginName,plugin.uuid),plugin.$element.data("zfPlugin")||plugin.$element.data("zfPlugin",plugin),plugin.$element.trigger("init.zf."+pluginName),this._uuids.push(plugin.uuid)},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").trigger("destroyed.zf."+pluginName);for(var prop in plugin)plugin[prop]=null},reInit:function(plugins){var isJQ=plugins instanceof $;try{if(isJQ)plugins.each(function(){$(this).data("zfPlugin")._init()});else{var type=void 0===plugins?"undefined":_typeof(plugins),_this=this;({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))}})[type](plugins)}}catch(err){console.error(err)}finally{return plugins}},GetYoDigits:function(length,namespace){return length=length||6,Math.round(Math.pow(36,length+1)-Math.random()*Math.pow(36,length)).toString(36).slice(1)+(namespace?"-"+namespace:"")},reflow:function(elem,plugins){void 0===plugins?plugins=Object.keys(this._plugins):"string"==typeof plugins&&(plugins=[plugins]);var _this=this;$.each(plugins,function(i,name){var plugin=_this._plugins[name];$(elem).find("[data-"+name+"]").addBack("[data-"+name+"]").each(function(){var $el=$(this),opts={};if($el.data("zfPlugin"))return void console.warn("Tried to initialize "+name+" on an element that already has a Foundation plugin.");$el.attr("data-options")&&$el.attr("data-options").split(";").forEach(function(e,i){var opt=e.split(":").map(function(el){return el.trim()});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,transitionend:function($elem){var end,transitions={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},elem=document.createElement("div");for(var t in transitions)void 0!==elem.style[t]&&(end=transitions[t]);return end||(end=setTimeout(function(){$elem.triggerHandler("transitionend",[$elem])},1),"transitionend")}};Foundation.util={throttle:function(func,delay){var timer=null;return function(){var context=this,args=arguments;null===timer&&(timer=setTimeout(function(){func.apply(context,args),timer=null},delay))}}};var foundation=function(method){var type=void 0===method?"undefined":_typeof(method),$meta=$("meta.foundation-mq"),$noJS=$(".no-js");if($meta.length||$('<meta class="foundation-mq">').appendTo(document.head),$noJS.length&&$noJS.removeClass("no-js"),"undefined"===type)Foundation.MediaQuery._init(),Foundation.reflow(this);else{if("string"!==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.");var args=Array.prototype.slice.call(arguments,1),plugClass=this.data("zfPlugin");if(void 0===plugClass||void 0===plugClass[method])throw new ReferenceError("We're sorry, '"+method+"' is not an available method for "+(plugClass?functionName(plugClass):"this element")+".");1===this.length?plugClass[method].apply(plugClass,args):this.each(function(i,el){plugClass[method].apply($(el).data("zfPlugin"),args)})}return this};window.Foundation=Foundation,$.fn.foundation=foundation,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var vendors=["webkit","moz"],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(),nextTime=Math.max(lastTime+16,now);return setTimeout(function(){callback(lastTime=nextTime)},nextTime-now)},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(oThis){if("function"!=typeof this)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)))};return this.prototype&&(fNOP.prototype=this.prototype),fBound.prototype=new fNOP,fBound})}(jQuery);var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function parseStyleToObject(str){var styleObject={};return"string"!=typeof str?styleObject:(str=str.trim().slice(1,-1))?styleObject=str.split("&").reduce(function(ret,param){var parts=param.replace(/\+/g," ").split("="),key=parts[0],val=parts[1];return key=decodeURIComponent(key),val=void 0===val?null:decodeURIComponent(val),ret.hasOwnProperty(key)?Array.isArray(ret[key])?ret[key].push(val):ret[key]=[ret[key],val]:ret[key]=val,ret},{}):styleObject}var MediaQuery={queries:[],current:"",_init:function(){var namedQueries,self=this,extractedStyles=$(".foundation-mq").css("font-family");namedQueries=parseStyleToObject(extractedStyles);for(var key in namedQueries)namedQueries.hasOwnProperty(key)&&self.queries.push({name:key,value:"only screen and (min-width: "+namedQueries[key]+")"});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(size){var query=this.get(size);return!!query&&window.matchMedia(query).matches},is:function(size){return size=size.trim().split(" "),size.length>1&&"only"===size[1]?size[0]===this._getCurrentSize():this.atLeast(size[0])},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}return null},_getCurrentSize:function(){for(var matched,i=0;i<this.queries.length;i++){var query=this.queries[i];window.matchMedia(query.value).matches&&(matched=query)}return"object"===(void 0===matched?"undefined":_typeof(matched))?matched.name:matched},_watcher:function(){var _this=this;$(window).on("resize.zf.mediaquery",function(){var newSize=_this._getCurrentSize(),currentSize=_this.current;newSize!==currentSize&&(_this.current=newSize,$(window).trigger("changed.zf.mediaquery",[newSize,currentSize]))})}};Foundation.MediaQuery=MediaQuery,window.matchMedia||(window.matchMedia=function(){var styleMedia=window.styleMedia||window.media;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),info="getComputedStyle"in window&&window.getComputedStyle(style,null)||style.currentStyle,styleMedia={matchMedium:function(media){var text="@media "+media+"{ #matchmediajs-test { width: 1px; } }";return style.styleSheet?style.styleSheet.cssText=text:style.textContent=text,"1px"===info.width}}}return function(media){return{matches:styleMedia.matchMedium(media||"all"),media:media||"all"}}}()),Foundation.MediaQuery=MediaQuery}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var AccordionMenu=function(){function AccordionMenu(element,options){_classCallCheck(this,AccordionMenu),this.$element=element,this.options=$.extend({},AccordionMenu.defaults,this.$element.data(),options),Foundation.Nest.Feather(this.$element,"accordion"),this._init(),Foundation.registerPlugin(this,"AccordionMenu"),Foundation.Keyboard.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}return _createClass(AccordionMenu,[{key:"_init",value:function(){this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"menu","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var linkId=this.id||Foundation.GetYoDigits(6,"acc-menu-link"),$elem=$(this),$sub=$elem.children("[data-submenu]"),subId=$sub[0].id||Foundation.GetYoDigits(6,"acc-menu"),isActive=$sub.hasClass("is-active");$elem.attr({"aria-controls":subId,"aria-expanded":isActive,role:"menuitem",id:linkId}),$sub.attr({"aria-labelledby":linkId,"aria-hidden":!isActive,role:"menu",id:subId})});var initPanes=this.$element.find(".is-active");if(initPanes.length){var _this=this;initPanes.each(function(){_this.down($(this))})}this._events()}},{key:"_events",value:function(){var _this=this;this.$element.find("li").each(function(){var $submenu=$(this).children("[data-submenu]");$submenu.length&&$(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 $prevElement,$nextElement,$element=$(this),$elements=$element.parent("ul").children("li"),$target=$element.children("[data-submenu]");$elements.each(function(i){if($(this).is($element))return $prevElement=$elements.eq(Math.max(0,i-1)).find("a").first(),$nextElement=$elements.eq(Math.min(i+1,$elements.length-1)).find("a").first(),$(this).children("[data-submenu]:visible").length&&($nextElement=$element.find("li:first-child").find("a").first()),$(this).is(":first-child")?$prevElement=$element.parents("li").first().find("a").first():$prevElement.parents("li").first().children("[data-submenu]:visible").length&&($prevElement=$prevElement.parents("li").find("li:last-child").find("a").first()),void($(this).is(":last-child")&&($nextElement=$element.parents("li").first().next("li").find("a").first()))}),Foundation.Keyboard.handleKey(e,"AccordionMenu",{open:function(){$target.is(":hidden")&&(_this.down($target),$target.find("li").first().find("a").first().focus())},close:function(){$target.length&&!$target.is(":hidden")?_this.up($target):$element.parent("[data-submenu]").length&&(_this.up($element.parent("[data-submenu]")),$element.parents("li").first().find("a").first().focus())},up:function(){return $prevElement.focus(),!0},down:function(){return $nextElement.focus(),!0},toggle:function(){$element.children("[data-submenu]").length&&_this.toggle($element.children("[data-submenu]"))},closeAll:function(){_this.hideAll()},handled:function(preventDefault){preventDefault&&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($target){$target.is(":animated")||($target.is(":hidden")?this.down($target):this.up($target))}},{key:"down",value:function($target){var _this=this;this.options.multiOpen||this.up(this.$element.find(".is-active").not($target.parentsUntil(this.$element).add($target))),$target.addClass("is-active").attr({"aria-hidden":!1}).parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),$target.slideDown(_this.options.slideSpeed,function(){_this.$element.trigger("down.zf.accordionMenu",[$target])})}},{key:"up",value:function($target){var _this=this;$target.slideUp(_this.options.slideSpeed,function(){_this.$element.trigger("up.zf.accordionMenu",[$target])}),$target.find("[data-submenu]").slideUp(0).addBack().attr("aria-hidden",!0).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"),Foundation.Nest.Burn(this.$element,"accordion"),Foundation.unregisterPlugin(this)}}]),AccordionMenu}();AccordionMenu.defaults={slideSpeed:250,multiOpen:!0},Foundation.plugin(AccordionMenu,"AccordionMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var DropdownMenu=function(){function DropdownMenu(element,options){_classCallCheck(this,DropdownMenu),this.$element=element,this.options=$.extend({},DropdownMenu.defaults,this.$element.data(),options),Foundation.Nest.Feather(this.$element,"dropdown"),this._init(),Foundation.registerPlugin(this,"DropdownMenu"),Foundation.Keyboard.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}return _createClass(DropdownMenu,[{key:"_init",value:function(){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),this.$element.hasClass(this.options.rightClass)||"right"===this.options.alignment||Foundation.rtl()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",subs.addClass("opens-left")):subs.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")}},{key:"_events",value:function(){var _this=this,hasTouch="ontouchstart"in window||void 0!==window.ontouchstart,parClass="is-dropdown-submenu-parent",handleClickFn=function(e){var $elem=$(e.target).parentsUntil("ul","."+parClass),hasSub=$elem.hasClass(parClass),hasClicked="true"===$elem.attr("data-is-click"),$sub=$elem.children(".is-dropdown-submenu");if(hasSub)if(hasClicked){if(!_this.options.closeOnClick||!_this.options.clickOpen&&!hasTouch||_this.options.forceFollow&&hasTouch)return;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",!0)};(this.options.clickOpen||hasTouch)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",handleClickFn),_this.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(e){$(this).hasClass(parClass)||_this._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(e){var $elem=$(this);$elem.hasClass(parClass)&&(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=$(this);if($elem.hasClass(parClass)&&_this.options.autoclose){if("true"===$elem.attr("data-is-click")&&_this.options.clickOpen)return!1;clearTimeout($elem.data("_delay")),$elem.data("_delay",setTimeout(function(){_this._hide($elem)},_this.options.closingTime))}}),this.$menuItems.on("keydown.zf.dropdownmenu",function(e){var $prevElement,$nextElement,$element=$(e.target).parentsUntil("ul",'[role="menuitem"]'),isTab=_this.$tabs.index($element)>-1,$elements=isTab?_this.$tabs:$element.siblings("li").add($element);$elements.each(function(i){if($(this).is($element))return $prevElement=$elements.eq(i-1),void($nextElement=$elements.eq(i+1))});var nextSibling=function(){$element.is(":last-child")||($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");$sub.length&&(_this._show($sub),$element.find("li > a:first").focus(),e.preventDefault())},closeSub=function(){var close=$element.parent("ul").parent("li");close.children("a:first").focus(),_this._hide(close),e.preventDefault()},functions={open:openSub,close:function(){_this._hide(_this.$element),_this.$menuItems.find("a:first").focus(),e.preventDefault()},handled:function(){e.stopImmediatePropagation()}};isTab?_this._isVertical()?Foundation.rtl()?$.extend(functions,{down:nextSibling,up:prevSibling,next:closeSub,previous:openSub}):$.extend(functions,{down:nextSibling,up:prevSibling,next:openSub,previous:closeSub}):Foundation.rtl()?$.extend(functions,{next:prevSibling,previous:nextSibling,down:openSub,up:closeSub}):$.extend(functions,{next:nextSibling,previous:prevSibling,down:openSub,up:closeSub}):Foundation.rtl()?$.extend(functions,{next:closeSub,previous:openSub,down:nextSibling,up:prevSibling}):$.extend(functions,{next:openSub,previous:closeSub,down:nextSibling,up:prevSibling}),Foundation.Keyboard.handleKey(e,"DropdownMenu",functions)})}},{key:"_addBodyHandler",value:function(){var $body=$(document.body),_this=this;$body.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(e){_this.$element.find(e.target).length||(_this._hide(),$body.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function($sub){var idx=this.$tabs.index(this.$tabs.filter(function(i,el){return $(el).find($sub).length>0})),$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.Box.ImNotTouchingYou($sub,null,!0);if(!clear){var oldClass="left"===this.options.alignment?"-right":"-left",$parentLi=$sub.parent(".is-dropdown-submenu-parent");$parentLi.removeClass("opens"+oldClass).addClass("opens-"+this.options.alignment),clear=Foundation.Box.ImNotTouchingYou($sub,null,!0),clear||$parentLi.removeClass("opens-"+this.options.alignment).addClass("opens-inner"),this.changed=!0}$sub.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[$sub])}},{key:"_hide",value:function($elem,idx){var $toClose;if($toClose=$elem&&$elem.length?$elem:void 0!==idx?this.$tabs.not(function(i,el){return i===idx}):this.$element,$toClose.hasClass("is-active")||$toClose.find(".is-active").length>0){if($toClose.find("li.is-active").add($toClose).attr({"data-is-click":!1}).removeClass("is-active"),$toClose.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||$toClose.find("opens-inner").length){var oldClass="left"===this.options.alignment?"right":"left";$toClose.find("li.is-dropdown-submenu-parent").add($toClose).removeClass("opens-inner opens-"+this.options.alignment).addClass("opens-"+oldClass),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[$toClose])}}},{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"),$(document.body).off(".zf.dropdownmenu"),Foundation.Nest.Burn(this.$element,"dropdown"),Foundation.unregisterPlugin(this)}}]),DropdownMenu}();DropdownMenu.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"left",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0},Foundation.plugin(DropdownMenu,"DropdownMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var OffCanvas=function(){function OffCanvas(element,options){_classCallCheck(this,OffCanvas),this.$element=element,this.options=$.extend({},OffCanvas.defaults,this.$element.data(),options),this.$lastTrigger=$(),this.$triggers=$(),this._init(),this._events(),Foundation.registerPlugin(this,"OffCanvas"),Foundation.Keyboard.register("OffCanvas",{ESCAPE:"close"})}return _createClass(OffCanvas,[{key:"_init",value:function(){var id=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.$element.addClass("is-transition-"+this.options.transition),this.$triggers=$(document).find('[data-open="'+id+'"], [data-close="'+id+'"], [data-toggle="'+id+'"]').attr("aria-expanded","false").attr("aria-controls",id),!0===this.options.contentOverlay){var overlay=document.createElement("div"),overlayPosition="fixed"===$(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";overlay.setAttribute("class","js-off-canvas-overlay "+overlayPosition),this.$overlay=$(overlay),"is-overlay-fixed"===overlayPosition?$("body").append(this.$overlay):this.$element.siblings("[data-off-canvas-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()),!0==!this.options.transitionTime&&(this.options.transitionTime=1e3*parseFloat(window.getComputedStyle($("[data-off-canvas]")[0]).transitionDuration))}},{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:$("[data-off-canvas-content]")).on({"click.zf.offcanvas":this.close.bind(this)})}}},{key:"_setMQChecker",value:function(){var _this=this;$(window).on("changed.zf.mediaquery",function(){Foundation.MediaQuery.atLeast(_this.options.revealOn)?_this.reveal(!0):_this.reveal(!1)}).one("load.zf.offcanvas",function(){Foundation.MediaQuery.atLeast(_this.options.revealOn)&&_this.reveal(!0)})}},{key:"reveal",value:function(isRevealed){var $closer=this.$element.find("[data-close]");isRevealed?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),$closer.length&&$closer.hide()):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),$closer.length&&$closer.show())}},{key:"_stopScrolling",value:function(event){return!1}},{key:"_recordScrollable",value:function(event){var elem=this;elem.scrollHeight!==elem.clientHeight&&(0===elem.scrollTop&&(elem.scrollTop=1),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(event){var elem=this,up=event.pageY<elem.lastY,down=!up;elem.lastY=event.pageY,up&&elem.allowUp||down&&elem.allowDown?event.stopPropagation():event.preventDefault()}},{key:"open",value:function(event,trigger){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var _this=this;trigger&&(this.$lastTrigger=trigger),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),_this.$element.addClass("is-open"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false").trigger("opened.zf.offcanvas"),!1===this.options.contentScroll&&($("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(Foundation.transitionend(this.$element),function(){_this.$element.find("a, button").eq(0).focus()}),!0===this.options.trapFocus&&(this.$element.siblings("[data-off-canvas-content]").attr("tabindex","-1"),Foundation.Keyboard.trapFocus(this.$element))}}},{key:"close",value:function(cb){if(this.$element.hasClass("is-open")&&!this.isRevealed){this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),!1===this.options.contentScroll&&($("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.$element.siblings("[data-off-canvas-content]").removeAttr("tabindex"),Foundation.Keyboard.releaseFocus(this.$element))}}},{key:"toggle",value:function(event,trigger){this.$element.hasClass("is-open")?this.close(event,trigger):this.open(event,trigger)}},{key:"_handleKeyboard",value:function(e){var _this2=this;Foundation.Keyboard.handleKey(e,"OffCanvas",{close:function(){return _this2.close(),_this2.$lastTrigger.focus(),!0},handled:function(){e.stopPropagation(),e.preventDefault()}})}},{key:"destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas"),Foundation.unregisterPlugin(this)}}]),OffCanvas}();OffCanvas.defaults={closeOnClick:!0,contentOverlay:!0,contentScroll:!0,transitionTime:0,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1},Foundation.plugin(OffCanvas,"OffCanvas")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var ResponsiveMenu=function(){function ResponsiveMenu(element,options){_classCallCheck(this,ResponsiveMenu),this.$element=$(element),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveMenu")}return _createClass(ResponsiveMenu,[{key:"_init",value:function(){if("string"==typeof this.rules){for(var rulesTree={},rules=this.rules.split(" "),i=0;i<rules.length;i++){var rule=rules[i].split("-"),ruleSize=rule.length>1?rule[0]:"small",rulePlugin=rule.length>1?rule[1]:rule[0];null!==MenuPlugins[rulePlugin]&&(rulesTree[ruleSize]=MenuPlugins[rulePlugin])}this.rules=rulesTree}$.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||Foundation.GetYoDigits(6,"responsive-menu"))}},{key:"_events",value:function(){var _this=this;$(window).on("changed.zf.mediaquery",function(){_this._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var matchedMq,_this=this;$.each(this.rules,function(key){Foundation.MediaQuery.atLeast(key)&&(matchedMq=key)}),matchedMq&&(this.currentPlugin instanceof this.rules[matchedMq].plugin||($.each(MenuPlugins,function(key,value){_this.$element.removeClass(value.cssClass)}),this.$element.addClass(this.rules[matchedMq].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[matchedMq].plugin(this.$element,{})))}},{key:"destroy",value:function(){this.currentPlugin.destroy(),$(window).off(".zf.ResponsiveMenu"),Foundation.unregisterPlugin(this)}}]),ResponsiveMenu}();ResponsiveMenu.defaults={};var MenuPlugins={dropdown:{cssClass:"dropdown",plugin:Foundation._plugins["dropdown-menu"]||null},drilldown:{cssClass:"drilldown",plugin:Foundation._plugins.drilldown||null},accordion:{cssClass:"accordion-menu",plugin:Foundation._plugins["accordion-menu"]||null}};Foundation.plugin(ResponsiveMenu,"ResponsiveMenu")}(jQuery);var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||!1,descriptor.configurable=!0,"value"in descriptor&&(descriptor.writable=!0),Object.defineProperty(target,descriptor.key,descriptor)}}return function(Constructor,protoProps,staticProps){return protoProps&&defineProperties(Constructor.prototype,protoProps),staticProps&&defineProperties(Constructor,staticProps),Constructor}}();!function($){var ResponsiveToggle=function(){
+function ResponsiveToggle(element,options){_classCallCheck(this,ResponsiveToggle),this.$element=$(element),this.options=$.extend({},ResponsiveToggle.defaults,this.$element.data(),options),this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveToggle")}return _createClass(ResponsiveToggle,[{key:"_init",value:function(){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()),this.options.animate){var input=this.options.animate.split(" ");this.animationIn=input[0],this.animationOut=input[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),$(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){Foundation.MediaQuery.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var _this2=this;Foundation.MediaQuery.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?Foundation.Motion.animateIn(this.$targetMenu,this.animationIn,function(){_this2.$element.trigger("toggled.zf.responsiveToggle"),_this2.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):Foundation.Motion.animateOut(this.$targetMenu,this.animationOut,function(){_this2.$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"),$(window).off("changed.zf.mediaquery",this._updateMqHandler),Foundation.unregisterPlugin(this)}}]),ResponsiveToggle}();ResponsiveToggle.defaults={hideFor:"medium",animate:!1},Foundation.plugin(ResponsiveToggle,"ResponsiveToggle")}(jQuery),function($){function ImNotTouchingYou(element,parent,lrOnly,tbOnly){var top,bottom,left,right,eleDims=GetDimensions(element);if(parent){var parDims=GetDimensions(parent);bottom=eleDims.offset.top+eleDims.height<=parDims.height+parDims.offset.top,top=eleDims.offset.top>=parDims.offset.top,left=eleDims.offset.left>=parDims.offset.left,right=eleDims.offset.left+eleDims.width<=parDims.width+parDims.offset.left}else bottom=eleDims.offset.top+eleDims.height<=eleDims.windowDims.height+eleDims.windowDims.offset.top,top=eleDims.offset.top>=eleDims.windowDims.offset.top,left=eleDims.offset.left>=eleDims.windowDims.offset.left,right=eleDims.offset.left+eleDims.width<=eleDims.windowDims.width;var allDirs=[bottom,top,left,right];return lrOnly?left===right==!0:tbOnly?top===bottom==!0:-1===allDirs.indexOf(!1)}function GetDimensions(elem,test){if((elem=elem.length?elem[0]: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}}}}function GetOffsets(element,anchor,position,vOffset,hOffset,isOverflow){var $eleDims=GetDimensions(element),$anchorDims=anchor?GetDimensions(anchor):null;switch(position){case"top":return{left:Foundation.rtl()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width:$anchorDims.offset.left,top:$anchorDims.offset.top-($eleDims.height+vOffset)};case"left":return{left:$anchorDims.offset.left-($eleDims.width+hOffset),top:$anchorDims.offset.top};case"right":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset,top:$anchorDims.offset.top};case"center top":return{left:$anchorDims.offset.left+$anchorDims.width/2-$eleDims.width/2,top:$anchorDims.offset.top-($eleDims.height+vOffset)};case"center bottom":return{left:isOverflow?hOffset:$anchorDims.offset.left+$anchorDims.width/2-$eleDims.width/2,top:$anchorDims.offset.top+$anchorDims.height+vOffset};case"center left":return{left:$anchorDims.offset.left-($eleDims.width+hOffset),top:$anchorDims.offset.top+$anchorDims.height/2-$eleDims.height/2};case"center right":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset+1,top:$anchorDims.offset.top+$anchorDims.height/2-$eleDims.height/2};case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-$eleDims.height/2};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2,top:$eleDims.windowDims.offset.top+vOffset};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};case"left bottom":return{left:$anchorDims.offset.left,top:$anchorDims.offset.top+$anchorDims.height+vOffset};case"right bottom":return{left:$anchorDims.offset.left+$anchorDims.width+hOffset-$eleDims.width,top:$anchorDims.offset.top+$anchorDims.height+vOffset};default:return{left:Foundation.rtl()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width:$anchorDims.offset.left+hOffset,top:$anchorDims.offset.top+$anchorDims.height+vOffset}}}Foundation.Box={ImNotTouchingYou:ImNotTouchingYou,GetDimensions:GetDimensions,GetOffsets:GetOffsets}}(jQuery),function($){var keyCodes={9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"},commands={},Keyboard={keys:function(kcs){var k={};for(var kc in kcs)k[kcs[kc]]=kcs[kc];return k}(keyCodes),parseKey:function(event){var key=keyCodes[event.which||event.keyCode]||String.fromCharCode(event.which).toUpperCase();return key=key.replace(/\W+/,""),event.shiftKey&&(key="SHIFT_"+key),event.ctrlKey&&(key="CTRL_"+key),event.altKey&&(key="ALT_"+key),key=key.replace(/_$/,"")},handleKey:function(event,component,functions){var cmds,command,fn,commandList=commands[component],keyCode=this.parseKey(event);if(!commandList)return console.warn("Component not defined!");if(cmds=void 0===commandList.ltr?commandList:Foundation.rtl()?$.extend({},commandList.ltr,commandList.rtl):$.extend({},commandList.rtl,commandList.ltr),command=cmds[keyCode],(fn=functions[command])&&"function"==typeof fn){var returnValue=fn.apply();(functions.handled||"function"==typeof functions.handled)&&functions.handled(returnValue)}else(functions.unhandled||"function"==typeof functions.unhandled)&&functions.unhandled()},findFocusable:function($element){return!!$element&&$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(){return!(!$(this).is(":visible")||$(this).attr("tabindex")<0)})},register:function(componentName,cmds){commands[componentName]=cmds},trapFocus:function($element){var $focusable=Foundation.Keyboard.findFocusable($element),$firstFocusable=$focusable.eq(0),$lastFocusable=$focusable.eq(-1);$element.on("keydown.zf.trapfocus",function(event){event.target===$lastFocusable[0]&&"TAB"===Foundation.Keyboard.parseKey(event)?(event.preventDefault(),$firstFocusable.focus()):event.target===$firstFocusable[0]&&"SHIFT_TAB"===Foundation.Keyboard.parseKey(event)&&(event.preventDefault(),$lastFocusable.focus())})},releaseFocus:function($element){$element.off("keydown.zf.trapfocus")}};Foundation.Keyboard=Keyboard}(jQuery),function($){function Move(duration,elem,fn){function move(ts){start||(start=ts),prog=ts-start,fn.apply(elem),prog<duration?anim=window.requestAnimationFrame(move,elem):(window.cancelAnimationFrame(anim),elem.trigger("finished.zf.animate",[elem]).triggerHandler("finished.zf.animate",[elem]))}var anim,prog,start=null;if(0===duration)return fn.apply(elem),void elem.trigger("finished.zf.animate",[elem]).triggerHandler("finished.zf.animate",[elem]);anim=window.requestAnimationFrame(move)}function animate(isIn,element,animation,cb){function finish(){isIn||element.hide(),reset(),cb&&cb.apply(element)}function reset(){element[0].style.transitionDuration=0,element.removeClass(initClass+" "+activeClass+" "+animation)}if(element=$(element).eq(0),element.length){var initClass=isIn?initClasses[0]:initClasses[1],activeClass=isIn?activeClasses[0]:activeClasses[1];reset(),element.addClass(animation).css("transition","none"),requestAnimationFrame(function(){element.addClass(initClass),isIn&&element.show()}),requestAnimationFrame(function(){element[0].offsetWidth,element.css("transition","").addClass(activeClass)}),element.one(Foundation.transitionend(element),finish)}}var initClasses=["mui-enter","mui-leave"],activeClasses=["mui-enter-active","mui-leave-active"],Motion={animateIn:function(element,animation,cb){animate(!0,element,animation,cb)},animateOut:function(element,animation,cb){animate(!1,element,animation,cb)}};Foundation.Move=Move,Foundation.Motion=Motion}(jQuery),function($){var Nest={Feather:function(menu){var type=arguments.length>1&&void 0!==arguments[1]?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";items.each(function(){var $item=$(this),$sub=$item.children("ul");$sub.length&&($item.addClass(hasSubClass).attr({"aria-haspopup":!0,"aria-label":$item.children("a:first").text()}),"drilldown"===type&&$item.attr({"aria-expanded":!1}),$sub.addClass("submenu "+subMenuClass).attr({"data-submenu":"",role:"menu"}),"drilldown"===type&&$sub.attr({"aria-hidden":!0})),$item.parent("[data-submenu]").length&&$item.addClass("is-submenu-item "+subItemClass)})},Burn:function(menu,type){var 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","")}};Foundation.Nest=Nest}(jQuery);var _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(obj){return typeof obj}:function(obj){return obj&&"function"==typeof Symbol&&obj.constructor===Symbol&&obj!==Symbol.prototype?"symbol":typeof obj};!function($){function checkListeners(){eventsListener(),resizeListener(),scrollListener(),mutateListener(),closemeListener()}function closemeListener(pluginName){var yetiBoxes=$("[data-yeti-box]"),plugNames=["dropdown","tooltip","reveal"];if(pluginName&&("string"==typeof pluginName?plugNames.push(pluginName):"object"===(void 0===pluginName?"undefined":_typeof(pluginName))&&"string"==typeof pluginName[0]?plugNames.concat(pluginName):console.error("Plugin names must be strings")),yetiBoxes.length){var listeners=plugNames.map(function(name){return"closeme.zf."+name}).join(" ");$(window).off(listeners).on(listeners,function(e,pluginId){var plugin=e.namespace.split(".")[0];$("[data-"+plugin+"]").not('[data-yeti-box="'+pluginId+'"]').each(function(){var _this=$(this);_this.triggerHandler("close.zf.trigger",[_this])})})}}function resizeListener(debounce){var timer=void 0,$nodes=$("[data-resize]");$nodes.length&&$(window).off("resize.zf.trigger").on("resize.zf.trigger",function(e){timer&&clearTimeout(timer),timer=setTimeout(function(){MutationObserver||$nodes.each(function(){$(this).triggerHandler("resizeme.zf.trigger")}),$nodes.attr("data-events","resize")},debounce||10)})}function scrollListener(debounce){var timer=void 0,$nodes=$("[data-scroll]");$nodes.length&&$(window).off("scroll.zf.trigger").on("scroll.zf.trigger",function(e){timer&&clearTimeout(timer),timer=setTimeout(function(){MutationObserver||$nodes.each(function(){$(this).triggerHandler("scrollme.zf.trigger")}),$nodes.attr("data-events","scroll")},debounce||10)})}function mutateListener(debounce){var $nodes=$("[data-mutate]");$nodes.length&&MutationObserver&&$nodes.each(function(){$(this).triggerHandler("mutateme.zf.trigger")})}function eventsListener(){if(!MutationObserver)return!1;var nodes=document.querySelectorAll("[data-resize], [data-scroll], [data-mutate]"),listeningElementsMutation=function(mutationRecordsList){var $target=$(mutationRecordsList[0].target);switch(mutationRecordsList[0].type){case"attributes":"scroll"===$target.attr("data-events")&&"data-events"===mutationRecordsList[0].attributeName&&$target.triggerHandler("scrollme.zf.trigger",[$target,window.pageYOffset]),"resize"===$target.attr("data-events")&&"data-events"===mutationRecordsList[0].attributeName&&$target.triggerHandler("resizeme.zf.trigger",[$target]),"style"===mutationRecordsList[0].attributeName&&($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!1}};if(nodes.length)for(var i=0;i<=nodes.length-1;i++){var elementObserver=new MutationObserver(listeningElementsMutation);elementObserver.observe(nodes[i],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}}var MutationObserver=function(){for(var prefixes=["WebKit","Moz","O","Ms",""],i=0;i<prefixes.length;i++)if(prefixes[i]+"MutationObserver"in window)return window[prefixes[i]+"MutationObserver"];return!1}(),triggers=function(el,type){el.data(type).split(" ").forEach(function(id){$("#"+id)["close"===type?"trigger":"triggerHandler"](type+".zf.trigger",[el])})};$(document).on("click.zf.trigger","[data-open]",function(){triggers($(this),"open")}),$(document).on("click.zf.trigger","[data-close]",function(){$(this).data("close")?triggers($(this),"close"):$(this).trigger("close.zf.trigger")}),$(document).on("click.zf.trigger","[data-toggle]",function(){$(this).data("toggle")?triggers($(this),"toggle"):$(this).trigger("toggle.zf.trigger")}),$(document).on("close.zf.trigger","[data-closable]",function(e){e.stopPropagation();var animation=$(this).data("closable");""!==animation?Foundation.Motion.animateOut($(this),animation,function(){$(this).trigger("closed.zf")}):$(this).fadeOut().trigger("closed.zf")}),$(document).on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",function(){var id=$(this).data("toggle-focus");$("#"+id).triggerHandler("toggle.zf.trigger",[$(this)])}),$(window).on("load",function(){checkListeners()}),Foundation.IHearYou=checkListeners}(jQuery),document.body.className=document.body.className.replace("no-js","js"),function(){var isWebkit=-1<navigator.userAgent.toLowerCase().indexOf("webkit"),isOpera=-1<navigator.userAgent.toLowerCase().indexOf("opera"),isIe=-1<navigator.userAgent.toLowerCase().indexOf("msie");(isWebkit||isOpera||isIe)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var element,id=location.hash.substring(1);/^[A-z0-9_-]+$/.test(id)&&(element=document.getElementById(id))&&(/^(?:a|select|input|button|textarea)$/i.test(element.tagName)||(element.tabIndex=-1),element.focus())},!1)}(),jQuery(document).foundation(),window.wdsWindowReady={},function(window,$,app){app.init=function(){app.cache(),app.bindEvents()},app.cache=function(){app.$c={window:$(window),body:$(document.body)}},app.bindEvents=function(){app.$c.window.load(app.addBodyClass)},app.addBodyClass=function(){app.$c.body.addClass("ready")},$(app.init)}(window,jQuery,window.wdsWindowReady);
\ No newline at end of file
diff --git a/comments.php b/comments.php
index b96003a78..c1cab1060 100644
--- a/comments.php
+++ b/comments.php
@@ -37,7 +37,7 @@
 
 		<?php if ( get_comment_pages_count() > 1 && get_option( 'page_comments' ) ) : // Are there comments to navigate through? ?>
 			<nav id="comment-nav-above" class="navigation comment-navigation" role="navigation">
-				<h2 class="screen-reader-text"><?php esc_html_e( 'Comment navigation', '_s' ); ?></h2>
+				<h2 class="show-for-sr"><?php esc_html_e( 'Comment navigation', '_s' ); ?></h2>
 
 				<div class="nav-links">
 					<div class="nav-previous"><?php previous_comments_link( esc_html__( 'Older Comments', '_s' ) ); ?></div>
@@ -58,7 +58,7 @@
 
 		<?php if ( get_comment_pages_count() > 1 && get_option( 'page_comments' ) ) : // Are there comments to navigate through? ?>
 			<nav id="comment-nav-below" class="navigation comment-navigation" role="navigation">
-				<h2 class="screen-reader-text"><?php esc_html_e( 'Comment navigation', '_s' ); ?></h2>
+				<h2 class="show-for-sr"><?php esc_html_e( 'Comment navigation', '_s' ); ?></h2>
 
 				<div class="nav-links">
 					<div class="nav-previous"><?php previous_comments_link( esc_html__( 'Older Comments', '_s' ) ); ?></div>
diff --git a/footer.php b/footer.php
index 7400fd6b8..b90dec95a 100644
--- a/footer.php
+++ b/footer.php
@@ -15,26 +15,26 @@
 	</main><!-- #main -->
 
 	<footer class="site-footer">
-		<div class="row">
-			<div class="medium-3 columns">
+		<div class="row small-up-1 medium-up-2 large-up-4">
+			<div class="column">
 				<?php dynamic_sidebar( 'footer-1' ); ?>
 			</div>
 
-			<div class="medium-3 columns">
+			<div class="column">
 				<?php dynamic_sidebar( 'footer-2' ); ?>
 			</div>
 
-			<div class="medium-3 columns">
+			<div class="column">
 				<?php dynamic_sidebar( 'footer-3' ); ?>
 			</div>
 
-			<div class="medium-3 columns">
+			<div class="column">
 				<?php dynamic_sidebar( 'footer-4' ); ?>
 			</div>
 		</div>
 
 		<div class="row">
-			<div class="site-info">
+			<div class="small-12 site-info text-center">
 				<?php _s_display_copyright_text(); ?>
 			</div>
 		</div><!-- .row -->
diff --git a/functions.php b/functions.php
index 85e31a0ee..56ed6a5e7 100644
--- a/functions.php
+++ b/functions.php
@@ -43,6 +43,7 @@ function _s_setup() {
 		 * @link https://developer.wordpress.org/themes/functionality/featured-images-post-thumbnails/
 		 */
 		add_theme_support( 'post-thumbnails' );
+		add_image_size( 'full-width', 1920, 1080, false );
 
 		// This theme uses wp_nav_menu() in one location.
 		register_nav_menus( array(
diff --git a/header.php b/header.php
index 6b41521a8..5e02924de 100644
--- a/header.php
+++ b/header.php
@@ -24,11 +24,12 @@
 <body <?php body_class(); ?>>
 
 <div id="page" class="site">
-	<a class="skip-link screen-reader-text" href="#main"><?php esc_html_e( 'Skip to content', '_s' ); ?></a>
+	<a class="skip-link show-for-sr" href="#main"><?php esc_html_e( 'Skip to content', '_s' ); ?></a>
+
+	<header class="align-middle site-header">
 
-	<header class="site-header">
 		<div class="row">
-			<div class="site-branding column small-12 large-2 text-center large-text-left">
+			<div class="column small-6 medium-2 site-branding">
 				<?php the_custom_logo(); ?>
 
 				<?php if ( is_front_page() && is_home() ) : ?>
@@ -36,29 +37,35 @@
 				<?php else : ?>
 					<p class="site-title"><a href="<?php echo esc_url( home_url( '/' ) ); ?>" rel="home"><?php bloginfo( 'name' ); ?></a></p>
 				<?php endif; ?>
-			</div><!-- .site-branding -->
 
-			<div class="title-bar column small-12 text-center" data-responsive-toggle="main-site-navigation" data-hide-for="large">
-				<button class="menu-icon" type="button" data-toggle="off-canvas-menu"></button>
-				<div class="title-bar-title"><?php esc_html_e( 'Menu', '_s' ); ?></div>
-			</div><!-- .title-bar -->
+				<?php
+				$description = get_bloginfo( 'description', 'display' );
+				if ( $description || is_customize_preview() ) :
+				?>
+					<p class="site-description"><?php echo esc_html( $description ); ?></p>
+				<?php endif; ?>
+			</div><!-- . site-branding -->
+
+			<span class="column small-6 medium-10 hamburger text-right" data-responsive-toggle="main-site-navigation" data-hide-for="large">
+				<button class="hamburger-icon" type="button" data-toggle="off-canvas-menu"></button>
+				<div class="title-bar-title show-for-sr"><?php esc_html_e( 'Menu', '_s' ); ?></div>
+			</span>
+
+			<nav id="main-site-navigation" class="column small-6 medium-7">
+				<?php
+				wp_nav_menu( array(
+					'theme_location' => 'primary',
+					'menu_id'        => 'primary-menu',
+					'menu_class'     => 'dropdown menu',
+					'items_wrap'     => '<ul id="%1$s" class="%2$s" data-dropdown-menu>%3$s</ul>',
+					'walker'         => new WDS_Submenu_Classes(),
+				) );
+				?>
+			</nav><!-- #main-site-navigation -->
 
-			<div class="column large-10 align-middle" id="main-site-navigation">
-				<div class="top-bar-left medium-8">
-					<?php
-					wp_nav_menu( array(
-						'theme_location' => 'primary',
-						'menu_id'        => 'primary-menu',
-						'menu_class'     => 'dropdown menu',
-						'items_wrap'     => '<ul id="%1$s" class="%2$s" data-dropdown-menu>%3$s</ul>',
-						'walker'         => new WDS_Submenu_Classes(),
-					) );
-					?>
-				</div><!-- .top-bar-left -->
-				<div class="top-bar-right medium-4">
-					<?php get_search_form(); ?>
-				</div><!-- .top-bar-right -->
-			</div><!-- #main-site-navigation -->
+			<div class="column hide-for-small-only hide-for-medium-only medium-3 align-right">
+				<?php get_search_form(); ?>
+			</div>
 		</div><!-- .row -->
 	</header><!-- .site-header -->
 
diff --git a/inc/acf.php b/inc/acf.php
index 5a804a03c..5ba05eda9 100644
--- a/inc/acf.php
+++ b/inc/acf.php
@@ -18,3 +18,60 @@ function _s_display_content_blocks() {
 		wp_reset_postdata();
 	endif;
 }
+
+/**
+ * Associate the possible block options with the appropriate section.
+ *
+ * @param  array $args Possible arguments.
+ */
+function _s_display_block_options( $args = array() ) {
+
+	// Setup defaults.
+	$defaults = array(
+		'background_type'  => get_sub_field( 'background_type' ),
+		'font_color'       => get_sub_field( 'font_color' ),
+		'container'        => 'section',
+		'class'            => 'content-block',
+		'custom_css_class' => get_sub_field( 'custom_css_class' ),
+	);
+
+	// Parse args.
+	$args = wp_parse_args( $args, $defaults );
+
+	$inline_style = '';
+
+	if ( '' !== $args['font_color'] ) {
+		$inline_style .= 'color: ' . $args['font_color'] . ';';
+	}
+
+	// Deal with the background settings, if available.
+	if ( $args['background_type'] ) {
+		if ( 'color' === $args['background_type']['value'] ) {
+			$background_color = get_sub_field( 'background_color' );
+			$inline_style .= 'background-color: ' . $background_color . ';';
+		}
+
+		if ( 'image' === $args['background_type']['value'] ) {
+			$background_image = get_sub_field( 'background_image' );
+			$inline_style .= 'background-image: url(' . esc_url( $background_image['sizes']['full-width'] ) . ');';
+			$args['class'] .= ' image-as-background';
+		}
+
+		if ( 'video' === $args['background_type']['value'] ) {
+			$background_video = get_sub_field( 'background_video' );
+			$background_video_markup = '<video class="video-as-background" autoplay muted loop preload="auto"><source src="' . esc_url( $background_video['url'] ) . '" type="video/mp4"></video>';
+		}
+
+		if ( 'none' === $args['background_type']['value'] ) {
+			$args['class'] .= ' no-background';
+		}
+	}
+
+	// Print the opening container and any inline styles.
+	printf( '<%s class="%s %s" style="%s">', esc_html( $args['container'] ), esc_attr( $args['class'] ), esc_attr( $args['custom_css_class'] ), esc_attr( $inline_style ) );
+
+	// If video is chosen, add the video markup immediately below opening container.
+	if ( 'video' === $args['background_type']['value'] ) {
+		echo $background_video_markup; // WPCS XSS OK.
+	}
+}
diff --git a/inc/template-tags.php b/inc/template-tags.php
index 5cc9cfe6c..6aee95618 100755
--- a/inc/template-tags.php
+++ b/inc/template-tags.php
@@ -27,7 +27,7 @@ function _s_posted_on() {
 		$posted_on = sprintf(
 			/* translators: the date the post was published */
 			esc_html_x( 'Posted on %s', 'post date', '_s' ),
-			'<a href="' . esc_url( get_permalink() ) . '" rel="bookmark">' . $time_string . '</a>'
+			$time_string
 		);
 
 		$byline = sprintf(
@@ -73,7 +73,7 @@ function _s_entry_footer() {
 			sprintf(
 				/* translators: %s: Name of current post */
 				esc_html__( 'Edit %s', '_s' ),
-				the_title( '<span class="screen-reader-text">"', '"</span>', false )
+				the_title( '<span class="show-for-sr">"', '"</span>', false )
 			),
 			'<span class="edit-link">',
 			'</span>'
@@ -296,7 +296,7 @@ function _s_display_social_icons() {
 						'title' => 'Twitter',
 						'desc'  => esc_html__( 'Share on Twitter', '_s' ),
 					) ); ?>
-					<span class="screen-reader-text"><?php esc_html_e( 'Share on Twitter', '_s' ); ?></span>
+					<span class="show-for-sr"><?php esc_html_e( 'Share on Twitter', '_s' ); ?></span>
 				</a>
 			</li>
 			<li class="social-icon">
@@ -306,7 +306,7 @@ function _s_display_social_icons() {
 						'title' => 'Facebook',
 						'desc'  => esc_html__( 'Share on Facebook', '_s' ),
 					) ); ?>
-					<span class="screen-reader-text"><?php esc_html_e( 'Share on Facebook', '_s' ); ?></span>
+					<span class="show-for-sr"><?php esc_html_e( 'Share on Facebook', '_s' ); ?></span>
 				</a>
 			</li>
 			<li class="social-icon">
@@ -316,7 +316,7 @@ function _s_display_social_icons() {
 						'title' => 'LinkedIn',
 						'desc'  => esc_html__( 'Share on LinkedIn', '_s' ),
 					) ); ?>
-					<span class="screen-reader-text"><?php esc_html_e( 'Share on LinkedIn', '_s' ); ?></span>
+					<span class="show-for-sr"><?php esc_html_e( 'Share on LinkedIn', '_s' ); ?></span>
 				</a>
 			</li>
 		</ul>
@@ -350,7 +350,7 @@ function _s_display_social_network_links() {
 							'icon'  => $network . '-square',
 							'title' => /* translators: the social network name */ sprintf( esc_html_e( 'Link to %s', '_s' ), ucwords( esc_html( $network ) ) ),
 						) ); ?>
-						<span class="screen-reader-text"><?php echo /* translators: the social network name */ sprintf( esc_html_e( 'Link to %s', '_s' ), ucwords( esc_html( $network ) ) ); // WPCS: XSS ok. ?></span>
+						<span class="show-for-sr"><?php echo /* translators: the social network name */ sprintf( esc_html_e( 'Link to %s', '_s' ), ucwords( esc_html( $network ) ) ); // WPCS: XSS ok. ?></span>
 					</a>
 				</li><!-- .social-icon -->
 			<?php endif;
@@ -358,3 +358,34 @@ function _s_display_social_network_links() {
 	</ul><!-- .social-icons -->
 	<?php
 }
+
+/**
+ * Display cards.
+ *
+ * @link http://foundation.zurb.com/sites/docs/card.html
+ */
+function _s_display_card( $args = array() ) {
+
+	// Setup defaults.
+	$defaults = array(
+		'title' => '',
+		'image' => '',
+		'text'  => '',
+	);
+
+	// Parse args.
+	$args = wp_parse_args( $args, $defaults );
+	?>
+
+	<div class="card">
+		<img src="<?php echo esc_url( $args['image'] ); ?>">
+		<div class="card-divider">
+			<h4><?php echo esc_html( $args['title'] ); ?></h4>
+		</div>
+		<div class="card-section">
+			<p><?php echo force_balance_tags( $args['text'] ); ?></p>
+		</div>
+	</div><!-- .card -->
+
+<?php
+}
diff --git a/page-acf.php b/page-acf.php
index a5f77cb7b..a6517a964 100644
--- a/page-acf.php
+++ b/page-acf.php
@@ -11,10 +11,8 @@
 
 get_header(); ?>
 
-<div class="row">
-	<div class="medium-12 columns primary content-area">
-		<?php _s_display_content_blocks(); ?>
-	</div><!-- .primary -->
-</div><!-- .row -->
+<div class="small-12 primary content-area">
+	<?php _s_display_content_blocks(); ?>
+</div><!-- .primary -->
 
 <?php get_footer(); ?>
diff --git a/searchform.php b/searchform.php
index 74aba141d..c57545be9 100644
--- a/searchform.php
+++ b/searchform.php
@@ -6,9 +6,10 @@
  */
 
 ?>
-
-<form method="get" class="search-form" action="<?php echo esc_url( home_url( '/' ) ); ?>">
-	<label for="search-field"><span class="screen-reader-text"><?php esc_html_e( 'To search this site, enter a search term', '_s' ) ?></span></label>
-	<input class="search-field" id="search-field" type="text" name="s" value="<?php echo get_search_query() ?>" aria-required="false" autocomplete="off" placeholder="<?php echo esc_attr_x( 'Search', '_s' ) ?>" />
-	<button><?php esc_html_e( 'Submit', '_s' ); ?></button>
-</form>
+<form method="get" class="input-group search-form" action="<?php echo esc_url( home_url( '/' ) ); ?>">
+  <span class="input-group-label show-for-sr"><?php esc_html_e( 'To search this site, enter a search term', '_s' ) ?></span>
+  <input class="input-group-field"id="search-field" type="text" name="s" value="<?php echo get_search_query() ?>" aria-required="false" autocomplete="off" placeholder="<?php echo esc_attr_x( 'Search', '_s' ) ?>" />
+  <div class="input-group-button">
+    <input type="submit" class="button" value="<?php echo esc_attr_x( 'Submit', '_s' ); ?>">
+  </div>
+</form>
\ No newline at end of file
diff --git a/style.css b/style.css
index cacba9e51..b2887c199 100644
--- a/style.css
+++ b/style.css
@@ -574,7 +574,7 @@ pre {
 }
 
 .row {
-  max-width: 75rem;
+  max-width: 60rem;
   margin-right: auto;
   margin-left: auto;
   display: -ms-flexbox;
@@ -1166,7 +1166,7 @@ a img {
 
 hr {
   clear: both;
-  max-width: 75rem;
+  max-width: 60rem;
   height: 0;
   margin: 1.25rem auto;
   border-top: 0;
@@ -1842,169 +1842,6 @@ select[multiple] {
   margin-left: 0;
 }
 
-.accordion {
-  margin-left: 0;
-  background: #fefefe;
-  list-style-type: 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;
-}
-
-.is-accordion-submenu-parent > a {
-  position: relative;
-}
-
-.is-accordion-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;
-  position: absolute;
-  top: 50%;
-  margin-top: -3px;
-  right: 1rem;
-}
-
-.is-accordion-submenu-parent[aria-expanded='true'] > a::after {
-  transform: rotate(180deg);
-  transform-origin: 50% 50%;
-}
-
-.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;
-  top: 1px;
-  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;
-}
-
 .button-group {
   margin-bottom: 1rem;
   font-size: 0;
@@ -2162,122 +1999,6 @@ select[multiple] {
   margin-bottom: 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 {
-  margin-bottom: 1rem;
-  border: 1px solid #e6e6e6;
-  border-radius: 0;
-  background: #fefefe;
-  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;
-}
-
-.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;
-}
-
 .menu {
   margin: 0;
   list-style-type: none;
@@ -2433,174 +2154,50 @@ select[multiple] {
   display: none;
 }
 
-.menu-icon {
-  position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer;
-}
-
-.menu-icon::after {
+.dropdown-pane {
   position: absolute;
-  top: 0;
-  left: 0;
+  z-index: 10;
   display: block;
-  width: 100%;
-  height: 2px;
-  background: #fefefe;
-  box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-  content: '';
+  width: 300px;
+  padding: 1rem;
+  visibility: hidden;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-size: 1rem;
 }
 
-.menu-icon:hover::after {
-  background: #cacaca;
-  box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
+.dropdown-pane.is-open {
+  visibility: visible;
 }
 
-.menu-icon.dark {
-  position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer;
+.dropdown-pane.tiny {
+  width: 100px;
 }
 
-.menu-icon.dark::after {
-  position: absolute;
-  top: 0;
-  left: 0;
-  display: block;
-  width: 100%;
-  height: 2px;
-  background: #0a0a0a;
-  box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-  content: '';
+.dropdown-pane.small {
+  width: 200px;
 }
 
-.menu-icon.dark:hover::after {
-  background: #8a8a8a;
-  box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
+.dropdown-pane.large {
+  width: 400px;
 }
 
-.is-drilldown {
-  position: relative;
-  overflow: hidden;
+.dropdown.menu > li.opens-left > .is-dropdown-submenu {
+  top: 100%;
+  right: 0;
+  left: auto;
 }
 
-.is-drilldown li {
-  display: block;
+.dropdown.menu > li.opens-right > .is-dropdown-submenu {
+  top: 100%;
+  right: auto;
+  left: 0;
 }
 
-.is-drilldown.animate-height {
-  transition: height 0.5s;
-}
-
-.is-drilldown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: -1;
-  width: 100%;
-  background: #fefefe;
-  transition: transform 0.15s linear;
-}
-
-.is-drilldown-submenu.is-active {
-  z-index: 1;
-  display: block;
-  transform: translateX(-100%);
-}
-
-.is-drilldown-submenu.is-closing {
-  transform: translateX(100%);
-}
-
-.drilldown-submenu-cover-previous {
-  min-height: 100%;
-}
-
-.is-drilldown-submenu-parent > a {
-  position: relative;
-}
-
-.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;
-}
-
-.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;
-  display: block;
-  width: 300px;
-  padding: 1rem;
-  visibility: hidden;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-size: 1rem;
-}
-
-.dropdown-pane.is-open {
-  visibility: visible;
-}
-
-.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 {
+  position: relative;
+  padding-right: 1.5rem;
 }
 
 .dropdown.menu > li.is-dropdown-submenu-parent > a::after {
@@ -2753,106 +2350,6 @@ select[multiple] {
   display: block;
 }
 
-.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%;
-}
-
-.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;
-}
-
-.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-object-section.middle {
-  vertical-align: middle;
-}
-
-.media-object-section.bottom {
-  vertical-align: bottom;
-}
-
 .is-off-canvas-open {
   overflow: hidden;
 }
@@ -3056,991 +2553,613 @@ select[multiple] {
           backface-visibility: hidden;
 }
 
-.orbit {
-  position: relative;
+.hide {
+  display: none !important;
 }
 
-.orbit-container {
-  position: relative;
-  height: 0;
-  margin: 0;
-  list-style: none;
-  overflow: hidden;
+.invisible {
+  visibility: hidden;
 }
 
-.orbit-slide {
-  width: 100%;
+.show-for-sr,
+.show-on-focus {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
 }
 
-.orbit-slide.no-motionui.is-active {
-  top: 0;
-  left: 0;
+.show-on-focus:active, .show-on-focus:focus {
+  position: static !important;
+  width: auto;
+  height: auto;
+  overflow: visible;
+  clip: auto;
 }
 
-.orbit-figure {
-  margin: 0;
+.show-for-landscape,
+.hide-for-portrait {
+  display: block !important;
 }
 
-.orbit-image {
-  width: 100%;
-  max-width: 100%;
-  margin: 0;
+.hide-for-landscape,
+.show-for-portrait {
+  display: none !important;
 }
 
-.orbit-caption {
-  position: absolute;
-  bottom: 0;
-  width: 100%;
-  margin-bottom: 0;
-  padding: 1rem;
-  background-color: rgba(10, 10, 10, 0.5);
-  color: #fefefe;
+.float-left {
+  float: left !important;
 }
 
-.orbit-previous, .orbit-next {
-  position: absolute;
-  top: 50%;
-  transform: translateY(-50%);
-  z-index: 10;
-  padding: 1rem;
-  color: #fefefe;
+.float-right {
+  float: right !important;
 }
 
-[data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
-  outline: 0;
+.float-center {
+  display: block;
+  margin-right: auto;
+  margin-left: auto;
 }
 
-.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);
+.clearfix::before, .clearfix::after {
+  display: table;
+  content: ' ';
 }
 
-.orbit-previous {
-  left: 0;
+.clearfix::after {
+  clear: both;
 }
 
-.orbit-next {
-  left: auto;
-  right: 0;
+.full-width {
+  margin-left: -2.1875rem;
+  max-width: calc(100% + 70px);
+  width: calc(100% + 70px);
 }
 
-.orbit-bullets {
-  position: relative;
-  margin-top: 0.8rem;
-  margin-bottom: 0.8rem;
-  text-align: center;
+.image-as-background {
+  background-position: center center;
+  background-repeat: no-repeat;
+  background-size: cover;
 }
 
-[data-whatinput='mouse'] .orbit-bullets {
-  outline: 0;
+.video-as-background {
+  height: 100%;
+  width: 100%;
+  display: block;
+  object-fit: cover;
+  object-position: center top;
+  position: absolute;
+  z-index: 1;
 }
 
-.orbit-bullets button {
-  width: 1.2rem;
-  height: 1.2rem;
-  margin: 0.1rem;
-  border-radius: 50%;
-  background-color: #cacaca;
+.svg-defs {
+  display: none;
 }
 
-.orbit-bullets button:hover {
-  background-color: #8a8a8a;
+.alignleft {
+  display: inline;
+  float: left;
+  margin: 0 1rem 0 0;
 }
 
-.orbit-bullets button.is-active {
-  background-color: #8a8a8a;
+.alignright {
+  display: inline;
+  float: right;
+  margin: 0 0 0 1rem;
 }
 
-.pagination {
-  margin-left: 0;
-  margin-bottom: 1rem;
+.aligncenter {
+  display: block;
+  margin-left: auto;
+  margin-right: auto;
 }
 
-.pagination::before, .pagination::after {
-  display: table;
-  content: ' ';
+pre {
+  background-color: #e6e6e6;
+  color: #0a0a0a;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-size: em(15);
+  font-weight: normal;
+  line-height: 1.5;
+  margin: 1rem 0 1rem;
+  overflow: auto;
+  padding: 0.125rem 0.3125rem 0.0625rem;
+  white-space: pre;
+  word-break: normal;
+  word-wrap: normal;
 }
 
-.pagination::after {
-  clear: both;
+code,
+kbd,
+tt,
+var {
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-size: em(15);
 }
 
-.pagination li {
-  margin-right: 0.0625rem;
-  border-radius: 0;
-  font-size: 0.875rem;
-  display: none;
+abbr,
+acronym {
+  border-bottom: 1px solid #cacaca;
+  cursor: help;
 }
 
-.pagination li:last-child, .pagination li:first-child {
-  display: inline-block;
+mark,
+ins {
+  text-decoration: none;
 }
 
-.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';
+sup,
+sub {
+  font-size: 75%;
+  height: 0;
+  line-height: 0;
+  position: relative;
+  vertical-align: baseline;
 }
 
-.progress {
-  height: 1rem;
-  margin-bottom: 1rem;
-  border-radius: 0;
-  background-color: #cacaca;
+sup {
+  bottom: 1ex;
 }
 
-.progress.primary .progress-meter {
-  background-color: #1779ba;
+sub {
+  top: 0.5ex;
 }
 
-.progress.secondary .progress-meter {
-  background-color: #767676;
+small {
+  font-size: 75%;
 }
 
-.progress.success .progress-meter {
-  background-color: #3adb76;
+big {
+  font-size: 125%;
 }
 
-.progress.warning .progress-meter {
-  background-color: #ffae00;
+.screen-reader-text {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
 }
 
-.progress.alert .progress-meter {
-  background-color: #cc4b37;
+.wp-caption {
+  margin: 0 0 1rem 0;
+  max-width: 100%;
 }
 
-.progress-meter {
-  position: relative;
+.wp-caption img[class*='wp-image-'] {
   display: block;
-  width: 0%;
-  height: 100%;
-  background-color: #1779ba;
+  margin: 0 auto;
 }
 
-.progress-meter-text {
-  position: absolute;
-  top: 50%;
-  left: 50%;
-  transform: translate(-50%, -50%);
-  position: absolute;
-  margin: 0;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #fefefe;
-  white-space: nowrap;
+.wp-caption.aligncenter {
+  margin: 0 auto 1rem auto;
 }
 
-.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;
-}
-
-.slider-fill {
-  position: absolute;
-  top: 0;
-  left: 0;
-  display: inline-block;
-  max-width: 100%;
-  height: 0.5rem;
-  background-color: #cacaca;
-  transition: all 0.2s ease-in-out;
-}
-
-.slider-fill.is-dragging {
-  transition: all 0s linear;
+.wp-caption.alignleft {
+  margin-right: 1rem;
 }
 
-.slider-handle {
-  position: absolute;
-  top: 50%;
-  transform: translateY(-50%);
-  position: absolute;
-  left: 0;
-  z-index: 1;
-  display: inline-block;
-  width: 1.4rem;
-  height: 1.4rem;
-  border-radius: 0;
-  background-color: #1779ba;
-  transition: all 0.2s ease-in-out;
-  -ms-touch-action: manipulation;
-      touch-action: manipulation;
+.wp-caption.alignright {
+  margin-left: 1rem;
 }
 
-[data-whatinput='mouse'] .slider-handle {
-  outline: 0;
+.wp-caption .wp-caption-text {
+  margin: 1rem 0;
 }
 
-.slider-handle:hover {
-  background-color: #14679e;
+.wp-caption-text {
+  text-align: center;
 }
 
-.slider-handle.is-dragging {
-  transition: all 0s linear;
+.gallery {
+  margin: 0 0 1rem 0;
 }
 
-.slider.disabled,
-.slider[disabled] {
-  opacity: 0.25;
-  cursor: not-allowed;
+.gallery-caption {
+  display: block;
 }
 
-.slider.vertical {
+.gallery-item {
+  height: 100% auto;
+  width: 100% auto;
   display: inline-block;
-  width: 0.5rem;
-  height: 12.5rem;
-  margin: 0 1.25rem;
-  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;
-  transform: translateX(-50%);
-}
-
-.sticky-container {
-  position: relative;
-}
-
-.sticky {
-  position: relative;
-  z-index: 0;
-  transform: translate3d(0, 0, 0);
-}
-
-.sticky.is-stuck {
-  position: fixed;
-  z-index: 5;
-}
-
-.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;
+  text-align: center;
+  vertical-align: top;
 }
 
-.sticky.is-anchored.is-at-bottom {
-  bottom: 0;
+.gallery-columns-2 .gallery-item {
+  max-width: 50%;
 }
 
-body.is-reveal-open {
-  overflow: hidden;
+.gallery-columns-3 .gallery-item {
+  max-width: 33.33%;
 }
 
-html.is-reveal-open,
-html.is-reveal-open body {
-  min-height: 100%;
-  overflow: hidden;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none;
+.gallery-columns-4 .gallery-item {
+  max-width: 25%;
 }
 
-.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: scroll;
+.gallery-columns-5 .gallery-item {
+  max-width: 20%;
 }
 
-.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;
+.gallery-columns-6 .gallery-item {
+  max-width: 16.66%;
 }
 
-[data-whatinput='mouse'] .reveal {
-  outline: 0;
+.gallery-columns-7 .gallery-item {
+  max-width: 14.28%;
 }
 
-.reveal .column, .reveal .columns,
-.reveal .columns {
-  min-width: 0;
+.gallery-columns-8 .gallery-item {
+  max-width: 12.5%;
 }
 
-.reveal > :last-child {
-  margin-bottom: 0;
+.gallery-columns-9 .gallery-item {
+  max-width: 11.11%;
 }
 
-.reveal.collapse {
+.wp-smiley {
+  margin: 0;
   padding: 0;
+  border: none;
 }
 
-.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;
-}
-
-.reveal.without-overlay {
-  position: fixed;
-}
-
-.switch {
-  height: 2rem;
+.hamburger-icon {
   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;
-  transition: all 0.25s ease-out;
-  font-weight: inherit;
-  color: inherit;
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
   cursor: pointer;
 }
 
-input + .switch-paddle {
-  margin: 0;
-}
-
-.switch-paddle::after {
+.hamburger-icon::after {
   position: absolute;
-  top: 0.25rem;
-  left: 0.25rem;
+  top: 0;
+  left: 0;
   display: block;
-  width: 1.5rem;
-  height: 1.5rem;
-  transform: translate3d(0, 0, 0);
-  border-radius: 0;
-  background: #fefefe;
-  transition: all 0.25s ease-out;
+  width: 100%;
+  height: 2px;
+  background: #0a0a0a;
+  box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
   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%;
-  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;
+.hamburger-icon:hover::after {
+  background: #cacaca;
+  box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
 }
 
-.switch.small .switch-paddle {
-  width: 3.5rem;
-  height: 1.75rem;
-  font-size: 0.75rem;
+.admin-bar .off-canvas {
+  padding-top: 3.5rem;
 }
 
-.switch.small .switch-paddle::after {
-  top: 0.25rem;
-  left: 0.25rem;
-  width: 1.25rem;
-  height: 1.25rem;
+.off-canvas .is-accordion-submenu {
+  padding-left: 1rem;
 }
 
-.switch.small input:checked ~ .switch-paddle::after {
-  left: 2rem;
+.content-block {
+  padding: 1rem;
 }
 
-.switch.large {
-  height: 2.5rem;
+.comments-area {
+  border-top: 1px solid #cacaca;
+  margin: 1rem 0;
 }
 
-.switch.large .switch-paddle {
-  width: 5rem;
-  height: 2.5rem;
-  font-size: 1rem;
+.comments-area .comment-reply-title {
+  margin-top: 1rem;
 }
 
-.switch.large .switch-paddle::after {
-  top: 0.25rem;
-  left: 0.25rem;
-  width: 2rem;
-  height: 2rem;
+.comments-area .comments-title {
+  font-size: em(24);
+  margin-top: 1rem;
 }
 
-.switch.large input:checked ~ .switch-paddle::after {
-  left: 2.75rem;
+.comments-area .comment-notes {
+  font-size: em(16);
+  margin-top: 1rem;
 }
 
-table {
+.comment-form-comment label,
+.comment-form-author label,
+.comment-form-email label,
+.comment-form-url label {
+  float: left;
+  font-size: em(16);
+  text-transform: uppercase;
   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;
-}
-
-table.scroll {
-  display: block;
+.comment-form {
   width: 100%;
-  overflow-x: auto;
 }
 
-table.hover thead tr:hover {
-  background-color: #f3f3f3;
+.comment-form::before, .comment-form::after {
+  display: table;
+  content: ' ';
 }
 
-table.hover tfoot tr:hover {
-  background-color: #ececec;
+.comment-form::after {
+  clear: both;
 }
 
-table.hover tbody tr:hover {
-  background-color: #f9f9f9;
+.comment-form input:not(.submit) {
+  clear: both;
+  transition: border 0.2s ease-in-out;
+  width: 100%;
 }
 
-table.hover:not(.unstriped) tr:nth-of-type(even):hover {
-  background-color: #ececec;
+.comment-form textarea {
+  max-width: 54.375rem;
+  transition: border 0.2s ease-in-out;
 }
 
-.table-scroll {
-  overflow-x: auto;
+.comment-form .form-submit {
+  margin: 0;
 }
 
-.table-scroll table {
-  width: auto;
+.comment-form input[type='submit'] {
+  width: 12.25rem;
 }
 
-.tabs {
+.comment-list {
+  margin: 0;
+  padding: 0;
+  list-style: none;
   margin: 0;
-  border: 1px solid #e6e6e6;
-  background: #fefefe;
-  list-style-type: none;
 }
 
-.tabs::before, .tabs::after {
+.comment-list::before, .comment-list::after {
   display: table;
   content: ' ';
 }
 
-.tabs::after {
+.comment-list::after {
   clear: both;
 }
 
-.tabs.vertical > li {
-  display: block;
-  float: none;
-  width: auto;
-}
-
-.tabs.simple > li > a {
-  padding: 0;
+.comment-list .even:not(.bypostauthor) > .comment-body {
+  background-color: #cacaca;
 }
 
-.tabs.simple > li > a:hover {
-  background: transparent;
+.comment-list .comment-body {
+  margin: 1rem 0;
+  padding: 1rem;
 }
 
-.tabs.primary {
-  background: #1779ba;
+.comment-list .comment-content {
+  margin: 1rem 0;
+  max-width: 58.5rem;
 }
 
-.tabs.primary > li > a {
-  color: #fefefe;
+.comment-list .comment-meta {
+  margin: 0 0 1rem 0;
 }
 
-.tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
-  background: #1673b1;
+.comment-list .comment-meta::before, .comment-list .comment-meta::after {
+  display: table;
+  content: ' ';
 }
 
-.tabs-title {
-  float: left;
+.comment-list .comment-meta::after {
+  clear: both;
 }
 
-.tabs-title > a {
-  display: block;
-  padding: 1.25rem 1.5rem;
-  font-size: 0.75rem;
+.comment-list .comment-author {
   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;
-  transition: all 0.5s ease;
-}
-
-.tabs-content.vertical {
-  border: 1px solid #e6e6e6;
-  border-left: 0;
-}
-
-.tabs-panel {
-  display: none;
-  padding: 1rem;
-}
-
-.tabs-panel[aria-hidden="false"] {
-  display: block;
-}
-
-.thumbnail {
-  display: inline-block;
-  max-width: 100%;
-  margin-bottom: 1rem;
-  border: solid 4px #fefefe;
-  border-radius: 0;
-  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-  line-height: 0;
+.comment-list .comment-metadata {
+  line-height: 1;
+  margin-top: 0.3125rem;
 }
 
-a.thumbnail {
-  transition: box-shadow 200ms ease-out;
+.comment-list .comment-metadata a {
+  color: #0a0a0a;
+  text-decoration: none;
 }
 
-a.thumbnail:hover, a.thumbnail:focus {
-  box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
+.comment-list .comment-metadata time,
+.comment-list .comment-metadata .comment-edit-link {
+  font-size: em(12);
 }
 
-a.thumbnail image {
-  box-shadow: none;
+.comment-list .avatar {
+  border-radius: 50%;
+  float: left;
+  margin: 0 1rem 0 0;
 }
 
-.title-bar {
-  padding: 0.5rem;
-  background: #0a0a0a;
-  color: #fefefe;
+.comment-list .bypostauthor {
+  background-color: #767676;
+  display: block;
 }
 
-.title-bar::before, .title-bar::after {
-  display: table;
-  content: ' ';
+.comment-list .comment-reply-link {
+  font-weight: 700;
 }
 
-.title-bar::after {
-  clear: both;
+.comment-list pre,
+.comment-list code {
+  margin: 0;
+  width: 100%;
 }
 
-.title-bar .menu-icon {
-  margin-left: 0.25rem;
-  margin-right: 0.25rem;
+.comment-list .children {
+  list-style: none;
+  margin: 2rem 0;
+  padding-left: 1rem;
 }
 
-.title-bar-left {
-  float: left;
+.comment-list .children .depth-4 .comment-author,
+.comment-list .children .depth-5 .comment-author,
+.comment-list .children .depth-6 .comment-author,
+.comment-list .children .depth-7 .comment-author,
+.comment-list .children .depth-8 .comment-author,
+.comment-list .children .depth-9 .comment-author,
+.comment-list .children .depth-10 .comment-author {
+  line-height: 1.25;
 }
 
-.title-bar-right {
-  float: right;
-  text-align: right;
+.comment-list .comment-respond {
+  background-color: #fefefe;
+  padding: 1rem 0;
 }
 
-.title-bar-title {
+.comment-list .comment-respond .comment-reply-title a {
   display: inline-block;
-  vertical-align: middle;
-  font-weight: bold;
+  text-transform: lowercase;
 }
 
-.has-tip {
-  position: relative;
-  display: inline-block;
-  border-bottom: dotted 1px #8a8a8a;
-  font-weight: bold;
-  cursor: help;
+.comment-list .comment-respond .comment-reply-title a::before {
+  content: '(';
 }
 
-.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;
+.comment-list .comment-respond .comment-reply-title a::after {
+  content: ')';
 }
 
-.tooltip::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;
-  position: absolute;
-  bottom: 100%;
-  left: 50%;
-  transform: translateX(-50%);
+.comment-list .comment-respond .form-submit {
+  margin: 0;
 }
 
-.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;
+.comment-list .comment-respond .form-submit input[type='submit'] {
+  margin-top: 0.3125rem;
 }
 
-.tooltip.left::before {
+.sticky,
+.comments-link {
   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;
-  top: 50%;
-  bottom: auto;
-  left: 100%;
-  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;
-  top: 50%;
-  right: 100%;
-  bottom: auto;
-  left: auto;
-  transform: translateY(-50%);
+.hentry {
+  margin: 0 0 2rem 0;
 }
 
-.top-bar {
-  padding: 0.5rem;
+.byline,
+.updated:not(.published) {
+  display: none;
 }
 
-.top-bar::before, .top-bar::after {
-  display: table;
-  content: ' ';
+.single .byline,
+.group-blog .byline {
+  display: inline;
 }
 
-.top-bar::after {
-  clear: both;
+.page-content,
+.entry-content,
+.entry-summary {
+  margin: 2rem 0 0;
 }
 
-.top-bar,
-.top-bar ul {
-  background-color: #e6e6e6;
+.page-links {
+  clear: both;
+  margin: 0 0 2rem 0;
 }
 
-.top-bar input {
-  max-width: 200px;
-  margin-right: 1rem;
+.tags-links {
+  margin-left: 2rem;
 }
 
-.top-bar .input-group-field {
-  width: 100%;
-  margin-right: 0;
+.edit-link a {
+  font-size: em(12);
+  text-transform: lowercase;
 }
 
-.top-bar input.button {
-  width: auto;
+.edit-link a::before {
+  content: '(';
 }
 
-.top-bar .top-bar-left,
-.top-bar .top-bar-right {
-  width: 100%;
+.edit-link a::after {
+  content: ')';
 }
 
-.top-bar-title {
-  display: inline-block;
-  float: left;
-  padding: 0.5rem 1rem 0.5rem 0;
+.blog .format-aside .entry-title,
+.archive .format-aside .entry-title {
+  display: none;
 }
 
-.top-bar-title .menu-icon {
-  bottom: 2px;
+.site-main .comment-navigation, .site-main
+.posts-navigation, .site-main
+.post-navigation {
+  margin: 0 0 1rem 0;
+  overflow: hidden;
 }
 
-.top-bar-left {
+.comment-navigation .nav-previous,
+.posts-navigation .nav-previous,
+.post-navigation .nav-previous {
+  height: 50% auto;
+  width: 50% auto;
   float: left;
 }
 
-.top-bar-right {
+.comment-navigation .nav-next,
+.posts-navigation .nav-next,
+.post-navigation .nav-next {
+  height: 50% auto;
+  width: 50% auto;
   float: right;
+  text-align: right;
 }
 
-.hide {
-  display: none !important;
-}
-
-.invisible {
-  visibility: hidden;
-}
-
-.show-for-sr,
-.show-on-focus {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-}
-
-.show-on-focus:active, .show-on-focus:focus {
-  position: static !important;
-  width: auto;
-  height: auto;
-  overflow: visible;
-  clip: auto;
+.entry-title,
+.entry-content,
+.comments-title,
+.comment-content,
+.widget-title,
+.widget {
+  word-break: keep-all;
+  word-wrap: break-word;
 }
 
-.show-for-landscape,
-.hide-for-portrait {
-  display: block !important;
+.site-footer {
+  margin: 2rem auto;
 }
 
-.hide-for-landscape,
-.show-for-portrait {
-  display: none !important;
+.site-header {
+  margin: 2rem auto;
 }
 
-.float-left {
-  float: left !important;
+.hero {
+  overflow-y: hidden;
+  position: relative;
+  z-index: 1;
 }
 
-.float-right {
-  float: right !important;
+.hero::after {
+  height: 100%;
+  width: 100%;
+  position: absolute;
+  top: 0;
+  right: 0;
+  background-color: rgba(10, 10, 10, 0.7);
+  content: '';
+  z-index: 2;
 }
 
-.float-center {
-  display: block;
-  margin-right: auto;
-  margin-left: auto;
+.hero-content {
+  padding: 4rem 0;
+  position: relative;
+  z-index: 3;
+  padding: 8rem 0;
 }
 
-.clearfix::before, .clearfix::after {
-  display: table;
-  content: ' ';
+.hero-headline {
+  font-size: 3rem;
+  line-height: 1.2;
+  margin-bottom: 2rem;
 }
 
-.clearfix::after {
-  clear: both;
+.hero-text {
+  font-size: 1.125rem;
 }
 
-.off-canvas .is-accordion-submenu {
-  padding-left: 1rem;
+.hero-button {
+  margin-top: 0.625rem;
 }
 
 @media print, screen and (min-width: 40em){
@@ -4450,46 +3569,49 @@ a.thumbnail image {
   .position-bottom.reveal-for-medium ~ .off-canvas-content{
     margin-bottom: 250px;
   }
-  .pagination li{
-    display: inline-block;
-  }
-  .reveal{
-    min-height: 0;
+  .hide-for-medium{
+    display: none !important;
   }
-  .reveal{
-    width: 600px;
-    max-width: 75rem;
+  .hero-headline{
+    margin-bottom: 1rem;
   }
-  .reveal .reveal{
-    right: auto;
-    left: auto;
-    margin: 0 auto;
+  .hero-text{
+    font-size: 1.5rem;
   }
-  .reveal.tiny{
-    width: 30%;
-    max-width: 75rem;
+}
+
+@media print, screen and (min-width: 40em) and (min-width: 40em){
+  .medium-expand{
+    -ms-flex: 1 1 0px;
+    flex: 1 1 0px;
   }
-  .reveal.small{
-    width: 50%;
-    max-width: 75rem;
+}
+
+@media screen and (min-width: 40em){
+  .comment-form input:not(.submit){
+    max-width: 15.625rem;
   }
-  .reveal.large{
-    width: 90%;
-    max-width: 75rem;
+  .comment-list .children{
+    padding-left: 2rem;
   }
-  .top-bar .top-bar-left,
-  .top-bar .top-bar-right{
-    width: auto;
+  .comment-list .children .depth-4 .comment-author,
+  .comment-list .children .depth-5 .comment-author,
+  .comment-list .children .depth-6 .comment-author,
+  .comment-list .children .depth-7 .comment-author,
+  .comment-list .children .depth-8 .comment-author,
+  .comment-list .children .depth-9 .comment-author,
+  .comment-list .children .depth-10 .comment-author{
+    line-height: 1;
   }
-  .hide-for-medium{
-    display: none !important;
+  .comment-list .comment-respond{
+    padding-left: 2rem;
+    padding-right: 2rem;
   }
 }
 
-@media print, screen and (min-width: 40em) and (min-width: 40em){
-  .medium-expand{
-    -ms-flex: 1 1 0px;
-    flex: 1 1 0px;
+@media screen and (min-width: 40em) and (max-width: 63.9375em){
+  .hide-for-medium-only{
+    display: none !important;
   }
 }
 
@@ -4499,8 +3621,14 @@ a.thumbnail image {
   }
 }
 
-@media screen and (min-width: 40em) and (max-width: 63.9375em){
-  .hide-for-medium-only{
+@media screen and (min-width: 48em){
+  .comment-list .children{
+    padding-left: 4rem;
+  }
+}
+
+@media screen and (max-width: 39.9375em), screen and (min-width: 64em){
+  .show-for-medium-only{
     display: none !important;
   }
 }
@@ -4896,9 +4024,11 @@ a.thumbnail image {
   }
 }
 
-@media screen and (max-width: 39.9375em), screen and (min-width: 64em){
-  .show-for-medium-only{
-    display: none !important;
+@media screen and (min-width: 64em){
+  .full-width{
+    margin-left: -7.1875rem;
+    max-width: calc(100% + 230px);
+    width: calc(100% + 230px);
   }
 }
 
@@ -4914,6 +4044,47 @@ a.thumbnail image {
   }
 }
 
+@media screen and (min-width: 85.375em){
+  .comments-area{
+    margin-left: auto;
+    margin-right: auto;
+  }
+}
+
+@media screen and (min-width: 0\0){
+  select{
+    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==");
+  }
+}
+
+@media screen and (orientation: landscape){
+  .show-for-landscape,
+  .hide-for-portrait{
+    display: block !important;
+  }
+  .hide-for-landscape,
+  .show-for-portrait{
+    display: none !important;
+  }
+}
+
+@media screen and (orientation: portrait){
+  .show-for-landscape,
+  .hide-for-portrait{
+    display: none !important;
+  }
+  .hide-for-landscape,
+  .show-for-portrait{
+    display: block !important;
+  }
+}
+
+@media screen and (max-width: 63.9375em){
+  .show-for-large{
+    display: none !important;
+  }
+}
+
 @media print{
   *{
     background: transparent !important;
@@ -4990,12 +4161,6 @@ a.thumbnail image {
   }
 }
 
-@media screen and (min-width: 0\0){
-  select{
-    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==");
-  }
-}
-
 @media screen and (max-width: 39.9375em){
   .button-group.stacked-for-small.expanded{
     display: block;
@@ -5004,26 +4169,6 @@ a.thumbnail image {
     display: block;
     margin-right: 0;
   }
-  .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%;
-  }
-  .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;
-  }
   .hide-for-small-only{
     display: none !important;
   }
@@ -5032,57 +4177,4 @@ a.thumbnail image {
   }
 }
 
-@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;
-  }
-  .top-bar.stacked-for-medium .top-bar-left,
-  .top-bar.stacked-for-medium .top-bar-right{
-    width: 100%;
-  }
-  .show-for-large{
-    display: none !important;
-  }
-}
-
-@media screen and (orientation: portrait){
-  .show-for-landscape,
-  .hide-for-portrait{
-    display: none !important;
-  }
-  .hide-for-landscape,
-  .show-for-portrait{
-    display: block !important;
-  }
-}
-
-@media screen and (orientation: landscape){
-  .show-for-landscape,
-  .hide-for-portrait{
-    display: block !important;
-  }
-  .hide-for-landscape,
-  .show-for-portrait{
-    display: none !important;
-  }
-}
-
-@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%;
-  }
-}
-
-/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["style.css","style.scss","../../node_modules/foundation-sites/scss/foundation.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_normalize-mixin.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_variables.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_vertical-rhythm.scss","../../node_modules/foundation-sites/scss/_global.scss","foundation/_settings.scss","../../node_modules/foundation-sites/scss/util/_mixins.scss","../../node_modules/foundation-sites/scss/grid/_flex-grid.scss","../../node_modules/foundation-sites/scss/grid/_row.scss","../../node_modules/foundation-sites/scss/util/_unit.scss","../../node_modules/foundation-sites/scss/grid/_gutter.scss","../../node_modules/foundation-sites/scss/util/_flex.scss","../../node_modules/foundation-sites/scss/grid/_column.scss","../../node_modules/foundation-sites/scss/grid/_position.scss","../../node_modules/foundation-sites/scss/components/_flex.scss","../../node_modules/foundation-sites/scss/typography/_base.scss","../../node_modules/foundation-sites/scss/typography/_helpers.scss","../../node_modules/foundation-sites/scss/typography/_alignment.scss","../../node_modules/foundation-sites/scss/typography/_print.scss","../../node_modules/foundation-sites/scss/forms/_text.scss","../../node_modules/foundation-sites/scss/forms/_checkbox.scss","../../node_modules/foundation-sites/scss/forms/_label.scss","../../node_modules/foundation-sites/scss/forms/_help-text.scss","../../node_modules/foundation-sites/scss/forms/_input-group.scss","../../node_modules/foundation-sites/scss/forms/_fieldset.scss","../../node_modules/foundation-sites/scss/forms/_select.scss","../../node_modules/foundation-sites/scss/forms/_error.scss","../../node_modules/foundation-sites/scss/components/_button.scss","../../node_modules/foundation-sites/scss/components/_accordion.scss","../../node_modules/foundation-sites/scss/components/_accordion-menu.scss","../../node_modules/foundation-sites/scss/components/_badge.scss","../../node_modules/foundation-sites/scss/components/_breadcrumbs.scss","../../node_modules/foundation-sites/scss/components/_button-group.scss","../../node_modules/foundation-sites/scss/components/_callout.scss","../../node_modules/foundation-sites/scss/components/_card.scss","../../node_modules/foundation-sites/scss/components/_close-button.scss","../../node_modules/foundation-sites/scss/components/_menu.scss","../../node_modules/foundation-sites/scss/components/_menu-icon.scss","../../node_modules/foundation-sites/scss/components/_drilldown.scss","../../node_modules/foundation-sites/scss/components/_dropdown.scss","../../node_modules/foundation-sites/scss/components/_dropdown-menu.scss","../../node_modules/foundation-sites/scss/components/_responsive-embed.scss","../../node_modules/foundation-sites/scss/util/_math.scss","../../node_modules/foundation-sites/scss/components/_label.scss","../../node_modules/foundation-sites/scss/components/_media-object.scss","../../node_modules/foundation-sites/scss/components/_off-canvas.scss","../../node_modules/foundation-sites/scss/components/_orbit.scss","../../node_modules/foundation-sites/scss/components/_pagination.scss","../../node_modules/foundation-sites/scss/components/_progress-bar.scss","../../node_modules/foundation-sites/scss/components/_slider.scss","../../node_modules/foundation-sites/scss/components/_sticky.scss","../../node_modules/foundation-sites/scss/components/_reveal.scss","../../node_modules/foundation-sites/scss/components/_switch.scss","../../node_modules/foundation-sites/scss/components/_table.scss","../../node_modules/foundation-sites/scss/util/_color.scss","../../node_modules/foundation-sites/scss/components/_tabs.scss","../../node_modules/foundation-sites/scss/components/_thumbnail.scss","../../node_modules/foundation-sites/scss/components/_title-bar.scss","../../node_modules/foundation-sites/scss/components/_tooltip.scss","../../node_modules/foundation-sites/scss/components/_top-bar.scss","../../node_modules/foundation-sites/scss/components/_visibility.scss","../../node_modules/foundation-sites/scss/components/_float.scss","components/_navigation.scss","../../node_modules/foundation-sites/scss/util/_breakpoint.scss"],"names":[],"mappings":"AAAA,iBAAiB;ACAjB;;;;;;;;;;;;;;;;GAgBG;AChBH;;;;;GAKG;ACwCD,iEAAiE;AAG/D;oFACgF;AAEhF;;;;;OAKG;AAEH;EACE,wBC1CuB;ED0CS,OAAO;EAQrC,kBAAiB;EAAG,OAAO;EAE7B,2BAA0B;EAAG,OAAO;EACpC,+BAA8B;EAAG,OAAO;CACzC;;AAID;oFACgF;AAEhF;;OAEG;AAEH;EACE,UAAS;CACV;;AAED;;OAEG;AAEH;;;;;;EAME,eAAc;CACf;;AAED;;;OAGG;AAEH;EE9EF,eAXuC;EFoGjC,iBAAgB;CAEnB;;AAoCD;oFACgF;AAuChF;;OAEG;AAEH;;EAEE,eAAc;CACf;;AAED;;OAEG;AAEH;EAKI,iBCvLY;CDyLf;;AAED;;;OAGG;AAEH;EACE,wBAAuB;EAAG,OAAO;EACjC,UAAS;EAAG,OAAO;EACnB,kBAAiB;EAAG,OAAO;CAC5B;;AAED;;OAEG;AAEH;EACE,eAAc;CACf;;AAaD;;;OAGG;AAEH;EACE,kCAAiC;EAAG,OAAO;EAC3C,eAAc;EAAG,OAAO;CACzB;;AAID;oFACgF;AAEhF;;;OAGG;AAEH;EACE,8BAA6B;EAAG,OAAO;EACvC,sCAAqC;EAAG,OAAO;CAChD;;AAED;;;OAGG;AAEH;;EAEE,iBAAgB;CACjB;;AAID;oFACgF;AAEhF;;;OAGG;AAEH;EACE,oBAAmB;EAAG,OAAO;EAC7B,2BAA0B;EAAG,OAAO;EACpC,kCAAiC;EAAG,OAAO;CAC5C;;AAED;;OAEG;AAEH;;EAEE,qBAAoB;CACrB;;AAED;;OAEG;AAEH;;EAEE,oBAAmB;CACpB;;AAED;;;OAGG;AAEH;;;EAGE,kCAAiC;EAAG,OAAO;EAC3C,eAAc;EAAG,OAAO;CACzB;;AAED;;OAEG;AAEH;EACE,mBAAkB;CACnB;;AAED;;OAEG;AAEH;EACE,uBAAsB;EACtB,YAAW;CACZ;;AAED;;OAEG;AAEH;EACE,eAAc;CACf;;AAED;;;OAGG;AAEH;;EAEE,eAAc;EACd,eAAc;EACd,mBAAkB;EAClB,yBAAwB;CACzB;;AAED;EACE,gBAAe;CAChB;;AAED;EACE,YAAW;CACZ;;AAID;oFACgF;AAEhF;;OAEG;AAEH;;EAEE,sBAAqB;CACtB;;AAED;;OAEG;AAEH;EACE,cAAa;EACb,UAAS;CACV;;AAED;;OAEG;AAEH;EACE,mBAAkB;CACnB;;AAED;;OAEG;AAEH;EACE,iBAAgB;CACjB;;AAID;oFACgF;AAEhF;;;OAGG;AAEH;;;;;EAKE,wBCzZuB;EDyZS,OAAO;EACvC,gBAAe;EAAG,OAAO;EAKvB,kBAAiB;EAAG,OAAO;EAE7B,UAAS;EAAG,OAAO;CACpB;;AAED;;OAEG;AAEH;EACE,kBAAiB;CAClB;;AAED;;;OAGG;AAEH;;EACS,OAAO;EACd,qBAAoB;CACrB;;AAED;;;;OAIG;AAEH;;;;EAIE,2BAA0B;EAAG,OAAO;CACrC;;AAED;;;;EAKE;;SAEG;EAOH;;SAEG;CAKJ;;AArBD;;;;EAUI,mBAAkB;EAClB,WAAU;CACX;;AAZH;;;;EAmBI,+BAA8B;CAC/B;;AAGH;;OAEG;AAEH;EACE,kBAAiB;CAClB;;AAED;;;OAGG;AHvJP;;EG2JM,uBAAsB;EAAG,OAAO;EAChC,WAAU;EAAG,OAAO;CACrB;;AAED;;OAEG;AHtJP;;EG0JM,aAAY;CACb;;AAED;;;OAGG;AHvJP;EG0JM,8BAA6B;EAAG,OAAO;EACvC,qBAAoB;EAAG,OAAO;EAE9B;;SAEG;CAMJ;;AH3JL;EGyJQ,yBAAwB;CACzB;;AAGH;;;OAGG;AAEH;EACE,2BAA0B;EAAG,OAAO;EACpC,cAAa;EAAG,OAAO;CACxB;;AAED;;OAEG;AAEH;EACE,0BAAyB;EACzB,cAAa;EACb,+BAA8B;CAC/B;;AAED;;;;;OAKG;AAEH;EACE,uBAAsB;EAAG,OAAO;EAChC,eAAc;EAAG,OAAO;EACxB,gBAAe;EAAG,OAAO;EACzB,WAAU;EAAG,OAAO;EACpB,eAAc;EAAG,OAAO;EACxB,oBAAmB;EAAG,OAAO;CAC9B;;AAED;;;OAGG;AAEH;EACE,sBAAqB;EAAG,OAAO;EAC/B,yBAAwB;EAAG,OAAO;CACnC;;AAED;;OAEG;AAEH;EACE,eAAc;CACf;;AAID;oFACgF;AAEhF;;OAEG;AAEH;EACE,eAAc;CACf;;AAED;;OAEG;AAEH;EACE,mBAAkB;CACnB;;AAED;;OAEG;AAEH;EACE,eAAc;CAqBf;;AAID;oFACgF;AAEhF;;OAEG;AAEH;EACE,sBAAqB;CACtB;;AAED;;OAEG;AAEH;EACE,cAAa;CACd;;AAID;oFACgF;AAEhF;;OAEG;AHrLP;EGwLM,cAAa;CACd;;AG9iBH;EACE,yEAAgD;CACjD;;AAED;EACE,uBAAsB;EACtB,gBCxEmB;CDyEpB;;AAGD;;;EAGE,oBAAmB;CACpB;;AAGD;EACE,UAAS;EACT,WAAU;EAEV,oBCzEW;ED2EX,oECxEqE;EDyErE,oBCrEyB;EDsEzB,iBCzFmB;ED0FnB,eC/EW;EDkFT,oCAAmC;EACnC,mCAAkC;CAErC;;AAED;EAEE,sBAAqB;EACrB,uBAAsB;EAGtB,gBAAe;EACf,aAAY;EACZ,gCAA+B;CAChC;;AAGD;EACE,aAAY;EACZ,iBAAgB;EAChB,iBC5Fa;CD6Fd;;AAGD;EACE,uBAAsB;EACtB,YAAW;EACX,iBCnGa;CDoGd;;AAID;;;;;;EAKI,2BAA0B;CAC3B;;AAIH;EAGE,WAAU;EAEV,yBAAgB;KAAhB,sBAAgB;UAAhB,iBAAgB;EAChB,UAAS;EACT,iBCzHa;ED0Hb,wBAAuB;EAEvB,eAAc;CACf;;ANwWH;EQ3XI,WAAU;CACX;;AFqBD;EACE,eAAc;CACf;;AAGD;EACE,0BAAyB;CAC1B;;AAED;EACE,yBAAwB;CACzB;;AGjFD;ECjCA,iBCTuD;EFnDrD,mBAAkB;EAClB,kBAAiB;EAIjB,qBAAa;EAAb,cAAa;EACb,wBAlBmB;MAkBnB,oBAlBmB;CA4IpB;;AAnCD;EC9CE,wBAF+D;EAG/D,uBAH+D;CD2D9D;;AAXH;EAQM,gBAAe;EACf,eAAc;CACf;;AAVL;ECjCA,gBAHa;CDoDV;;AAhBH;ECjCA,gBAHa;CDwDV;;AApBH;EG5GE,iBAFqC;EAGrC,gBAHqC;CHuIlC;;AAzBL;;;EAgCI,gBAAe;EACf,eAAc;CACf;;AAIH;EAjDA,kBA5Dc;MA4Dd,cA5Dc;EGrCZ,wBAFqC;EAGrC,uBAHqC;EHoErC,mBAAkB;CAkFnB;;AAID;EACE,YAAW;EACX,eAAc;CACf;;AAGD;EACE,gBAAe;EACf,eAAc;EACd,iBAAgB;EAChB,gBAAe;CAChB;;AAGD;EIpKA,qBAAa;EAAb,cAAa;CJsKZ;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAGC;EI1HF,wBAnEU;MAmEV,oBAnEU;CJ+LP;;AAFD;EI1HF,gCAlE0B;MAkE1B,4BAlE0B;CJ8LvB;;AAFD;EI1HF,2BAjEgB;MAiEhB,uBAjEgB;CJ6Lb;;AAFD;EI1HF,mCAhEgC;MAgEhC,+BAhEgC;CJ4L7B;;AAMC;EACE,uBKzL+C;MLyL/C,mBKzL+C;EL0L/C,oBK1L+C;CL2LhD;;AAKD;EMnLJ,gBDhBgC;CLqM3B;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,sBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/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AaI,eAAc;EACd,eVtQe;CUuQhB;;AAQG;EAII,kBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,mBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,qBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,oBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,qBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,gBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAMP;EACE,qBAAoB;EACpB,eV/Tc;EUgUd,sBVnOyB;EUqOzB,gBAAe;CAahB;;AAlBD;EASI,eV1O2D;CU8O5D;;AAbH;EAgBI,UAAS;CACV;;AAIH;EACE,YAAW;EAEX,iBNlTqD;EMmTrD,UAAS;EACT,qBVtPyB;EUwPzB,cAAa;EACb,gBAAe;EACf,iCVpViB;EUqVjB,eAAc;CACf;;AAGD;;;EAGE,oBVhR0B;EUiR1B,6BV/PyB;EUgQzB,iBVnRsB;CUoRvB;;AAGD;EACE,mBAAkB;CACnB;;AAGD;EACE,qBVzQsB;EU0QtB,sBV5QkB;CU6QnB;;AAGD;EACE,qBV/QsB;CUgRvB;;AAGD;EAEI,qBVpR2B;EUqR3B,iBAAgB;CACjB;;AAIH;EACE,oBV1RyB;CUgS1B;;AAPD;EAII,sBV3R8B;EU4R9B,kBVpXmB;CUqXpB;;AAIH;EACE,iBVzT0B;EU0T1B,uCN1WqD;EM2WrD,+BVvYiB;CU6YlB;;AATD;EAMI,iBV/ToB;EUgUpB,eV1Ya;CU2Yd;;AAIH;EACE,eAAc;EACd,qBNtXqD;EMuXrD,eVlZe;CUuZhB;;AARD;EAMI,cV7SgB;CU8SjB;;AAIH;EACE,kCV1ZW;EU2ZX,eV3ZW;EU4ZX,aAAY;CACb;;AAGD;EACE,UAAS;CACV;;AAGD;EACE,sCN5YqD;EM8YrD,0BV1aiB;EU2ajB,0BV5agB;EU8ahB,6DV3XmE;EU4XnE,oBVpa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,aAAY;CAMb;;AAED;EACE,YAAW;CACZ;;AwDvJH;EAIE,mBAAkB;CAClB;;AC+II;ExDzBJ;IC9CE,yBAF+D;IAG/D,wBAH+D;GD2D9D;EA2BH;IGlJE,yBAFqC;IAGrC,wBAHqC;GHsJtC;EA2CG;IACE,uBKzL+C;ILyL/C,mBKzL+C;IL0L/C,oBK1L+C;GL2LhD;EAKD;IMnLJ,gBDhBgC;GLqM3B;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,sBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,mBKzL+C;ILyL/C,eKzL+C;IL0L/C,gBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAKD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB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c;GmCLf;EKqQK;IA5CN,gBAAe;IACf,WxC8KyB;GwCjIlB;EAvCH;IACF,mBxCiKkB;GwChKnB;EAuCK;IAhDN,gBAAe;IACf,WxC8KyB;GwC7HlB;EA3CH;IACF,oBxCiKkB;GwChKnB;EA2CK;IApDN,gBAAe;IACf,WxC8KyB;GwCzHlB;EA/CH;IACF,kBxCiKkB;GwChKnB;EA+CK;IAxDN,gBAAe;IACf,WxC8KyB;GwCrHlB;EAnDH;IACF,qBxCiKkB;GwChKnB;EEhMD;IAuBM,sBAAqB;GAG1B;EI2BD;IAjEE,cAAa;GA0Gd;EAzCD;IAzCE,a9CwZgB;I8CvZhB,iB1CPqD;G0CwFtD;EAzCD;IAaM,YAAW;IACX,WAAU;IACV,eAAc;GACf;EAhBL;IAzCE,WAkEyC;IAjEzC,iB1CPqD;G0CwEP;EAzBhD;IAzCE,WAmEyC;IAlEzC,iB1CPqD;G0CyEP;EA1BhD;IAzCE,WAoEyC;IAnEzC,iB1CPqD;G0C0EP;EQpD9C;;IAEE,YAAW;GACZ;ECzCC;IAzBF,yBAAwB;GA2BrB;C9DqgBN;;AiEpbK;ExDwFE;IACE,kBAzLM;IAyLN,cAzLM;GA0LP;CTizBR;;A8DlgCG;EAiDA;IAhDE,yBAAwB;GAkDzB;C9DgrJJ;;AiEvmJK;EH/EF;IA1BA,yBAAwB;GA4BvB;C9DssJJ;;AiE9nJK;ExDwFE;IACE,kBAzLM;IAyLN,cAzLM;GA0LP;CTqgCR;;AiE/lCK;ExDzBJ;IC9CE,yBAF+D;IAG/D,wBAH+D;GD2D9D;EAwEC;IACE,uBKzL+C;ILyL/C,mBKzL+C;IL0L/C,oBK1L+C;GL2LhD;EAKD;IMnLJ,gBDhBgC;GLqM3B;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,sBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;G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","file":"style.css","sourcesContent":["@charset \"UTF-8\";\n/**\r\n * Theme Name: _s\r\n * Theme URI: http://underscores.me/\r\n * Author: Automattic\r\n * Author URI: http://automattic.com/\r\n * Description: Hi. I'm a starter theme called <code>_s</code>, or <em>underscores</em>, if you like. I'm a theme meant for hacking so don't use me as a <em>Parent Theme</em>. Instead try turning me into the next, most awesome, WordPress theme out there. That's what I'm here for.\r\n * Version: 1.0.0\r\n * License: GNU General Public License v2 or later\r\n * License URI: http://www.gnu.org/licenses/gpl-2.0.html\r\n * Text Domain: _s\r\n * Tags: custom\r\n *\r\n * This theme, like WordPress, is licensed under the GPL.\r\n *\r\n * Based on Underscores http://underscores.me/, (C) 2012-2017 Automattic, Inc.\r\n *\r\n */\n/**\n * Foundation for Sites by ZURB\n * Version 6.3.1\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */\n/* Document\n       ========================================================================== */\n/**\n     * 1. Change the default font family in all browsers (opinionated).\n     * 2. Correct the line height in all browsers.\n     * 3. Prevent adjustments of font size after orientation changes in\n     *    IE on Windows Phone and in iOS.\n     */\nhtml {\n  font-family: sans-serif;\n  /* 1 */\n  line-height: 1.15;\n  /* 2 */\n  -ms-text-size-adjust: 100%;\n  /* 3 */\n  -webkit-text-size-adjust: 100%;\n  /* 3 */\n}\n\n/* Sections\n       ========================================================================== */\n/**\n     * Remove the margin in all browsers (opinionated).\n     */\nbody {\n  margin: 0;\n}\n\n/**\n     * Add the correct display in IE 9-.\n     */\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n     * Correct the font size and margin on `h1` elements within `section` and\n     * `article` contexts in Chrome, Firefox, and Safari.\n     */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\nfigcaption,\nfigure {\n  display: block;\n}\n\n/**\n     * Add the correct margin in IE 8.\n     */\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n     * 1. Add the correct box sizing in Firefox.\n     * 2. Show the overflow in Edge and IE.\n     */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n     * Add the correct display in IE.\n     */\nmain {\n  display: block;\n}\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     */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Links\n       ========================================================================== */\n/**\n     * 1. Remove the gray background on active links in IE 10.\n     * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n     */\na {\n  background-color: transparent;\n  /* 1 */\n  -webkit-text-decoration-skip: objects;\n  /* 2 */\n}\n\n/**\n     * Remove the outline on focused links when they are also active or hovered\n     * in all browsers (opinionated).\n     */\na:active,\na:hover {\n  outline-width: 0;\n}\n\n/* Text-level semantics\n       ========================================================================== */\n/**\n     * 1. Remove the bottom border in Firefox 39-.\n     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n     */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n     * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n     */\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n     * Add the correct font weight in Chrome, Edge, and Safari.\n     */\nb,\nstrong {\n  font-weight: bolder;\n}\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     */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n     * Add the correct font style in Android 4.3-.\n     */\ndfn {\n  font-style: italic;\n}\n\n/**\n     * Add the correct background and color in IE 9-.\n     */\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n     * Add the correct font size in all browsers.\n     */\nsmall {\n  font-size: 80%;\n}\n\n/**\n     * Prevent `sub` and `sup` elements from affecting the line height in\n     * all browsers.\n     */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n     * Add the correct display in iOS 4-7.\n     */\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n     * Remove the border on images inside links in IE 10-.\n     */\nimg {\n  border-style: none;\n}\n\n/**\n     * Hide the overflow in IE.\n     */\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n       ========================================================================== */\n/**\n     * 1. Change the font styles in all browsers (opinionated).\n     * 2. Remove the margin in Firefox and Safari.\n     */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n     * Show the overflow in IE.\n     */\nbutton {\n  overflow: visible;\n}\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     */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n     * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n     *    controls in Android 4.\n     * 2. Correct the inability to style clickable types in iOS and Safari.\n     */\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n  /* 2 */\n}\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  /**\n       * Remove the inner border and padding in Firefox.\n       */\n  /**\n       * Restore the focus styles unset by the previous rule.\n       */\n}\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}\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}\n\n/**\n     * Show the overflow in Edge.\n     */\ninput {\n  overflow: visible;\n}\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;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\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/**\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;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n  /**\n       * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n       */\n}\n\n[type=\"search\"]::-webkit-search-cancel-button, [type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\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;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/**\n     * Change the border, margin, and padding in all browsers (opinionated).\n     */\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\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     */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  color: inherit;\n  /* 2 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n     * 1. Add the correct display in IE 9-.\n     * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n     */\nprogress {\n  display: inline-block;\n  /* 1 */\n  vertical-align: baseline;\n  /* 2 */\n}\n\n/**\n     * Remove the default vertical scrollbar in IE.\n     */\ntextarea {\n  overflow: auto;\n}\n\n/* Interactive\n       ========================================================================== */\n/*\n     * Add the correct display in Edge, IE, and Firefox.\n     */\ndetails {\n  display: block;\n}\n\n/*\n     * Add the correct display in all browsers.\n     */\nsummary {\n  display: list-item;\n}\n\n/*\n     * Add the correct display in IE 9-.\n     */\nmenu {\n  display: block;\n}\n\n/* Scripting\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\ncanvas {\n  display: inline-block;\n}\n\n/**\n     * Add the correct display in IE.\n     */\ntemplate {\n  display: none;\n}\n\n/* Hidden\n       ========================================================================== */\n/**\n     * Add the correct display in IE 10-.\n     */\n[hidden] {\n  display: none;\n}\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\";\n}\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%;\n}\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit;\n}\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}\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic;\n}\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0;\n}\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0;\n}\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}\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n}\n\n[data-whatinput='mouse'] button {\n  outline: 0;\n}\n\npre {\n  overflow: auto;\n}\n\n.is-visible {\n  display: block !important;\n}\n\n.is-hidden {\n  display: none !important;\n}\n\n.row {\n  max-width: 75rem;\n  margin-right: auto;\n  margin-left: auto;\n  display: flex;\n  flex-flow: row wrap;\n}\n\n.row .row {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .row .row {\n    margin-right: -0.9375rem;\n    margin-left: -0.9375rem;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .row .row {\n    margin-right: -0.9375rem;\n    margin-left: -0.9375rem;\n  }\n}\n\n.row .row.collapse {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.row.expanded {\n  max-width: none;\n}\n\n.row:not(.expanded) .row {\n  max-width: none;\n}\n\n.row.collapse > .column, .row.collapse > .columns {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.row.is-collapse-child,\n.row.collapse > .column > .row,\n.row.collapse > .columns > .row {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.column, .columns {\n  flex: 1 1 0px;\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  min-width: initial;\n}\n\n@media print, screen and (min-width: 40em) {\n  .column, .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n.column.row.row, .row.row.columns {\n  float: none;\n  display: block;\n}\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\n.flex-container {\n  display: 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.flex-dir-row {\n  flex-direction: row;\n}\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse;\n}\n\n.flex-dir-column {\n  flex-direction: column;\n}\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse;\n}\n\n.small-1 {\n  flex: 0 0 8.33333%;\n  max-width: 8.33333%;\n}\n\n.small-offset-0 {\n  margin-left: 0%;\n}\n\n.small-2 {\n  flex: 0 0 16.66667%;\n  max-width: 16.66667%;\n}\n\n.small-offset-1 {\n  margin-left: 8.33333%;\n}\n\n.small-3 {\n  flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.small-offset-2 {\n  margin-left: 16.66667%;\n}\n\n.small-4 {\n  flex: 0 0 33.33333%;\n  max-width: 33.33333%;\n}\n\n.small-offset-3 {\n  margin-left: 25%;\n}\n\n.small-5 {\n  flex: 0 0 41.66667%;\n  max-width: 41.66667%;\n}\n\n.small-offset-4 {\n  margin-left: 33.33333%;\n}\n\n.small-6 {\n  flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.small-offset-5 {\n  margin-left: 41.66667%;\n}\n\n.small-7 {\n  flex: 0 0 58.33333%;\n  max-width: 58.33333%;\n}\n\n.small-offset-6 {\n  margin-left: 50%;\n}\n\n.small-8 {\n  flex: 0 0 66.66667%;\n  max-width: 66.66667%;\n}\n\n.small-offset-7 {\n  margin-left: 58.33333%;\n}\n\n.small-9 {\n  flex: 0 0 75%;\n  max-width: 75%;\n}\n\n.small-offset-8 {\n  margin-left: 66.66667%;\n}\n\n.small-10 {\n  flex: 0 0 83.33333%;\n  max-width: 83.33333%;\n}\n\n.small-offset-9 {\n  margin-left: 75%;\n}\n\n.small-11 {\n  flex: 0 0 91.66667%;\n  max-width: 91.66667%;\n}\n\n.small-offset-10 {\n  margin-left: 83.33333%;\n}\n\n.small-12 {\n  flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.small-offset-11 {\n  margin-left: 91.66667%;\n}\n\n.small-order-1 {\n  order: 1;\n}\n\n.small-order-2 {\n  order: 2;\n}\n\n.small-order-3 {\n  order: 3;\n}\n\n.small-order-4 {\n  order: 4;\n}\n\n.small-order-5 {\n  order: 5;\n}\n\n.small-order-6 {\n  order: 6;\n}\n\n.small-up-1 {\n  flex-wrap: wrap;\n}\n\n.small-up-1 > .column, .small-up-1 > .columns {\n  flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.small-up-2 {\n  flex-wrap: wrap;\n}\n\n.small-up-2 > .column, .small-up-2 > .columns {\n  flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.small-up-3 {\n  flex-wrap: wrap;\n}\n\n.small-up-3 > .column, .small-up-3 > .columns {\n  flex: 0 0 33.33333%;\n  max-width: 33.33333%;\n}\n\n.small-up-4 {\n  flex-wrap: wrap;\n}\n\n.small-up-4 > .column, .small-up-4 > .columns {\n  flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.small-up-5 {\n  flex-wrap: wrap;\n}\n\n.small-up-5 > .column, .small-up-5 > .columns {\n  flex: 0 0 20%;\n  max-width: 20%;\n}\n\n.small-up-6 {\n  flex-wrap: wrap;\n}\n\n.small-up-6 > .column, .small-up-6 > .columns {\n  flex: 0 0 16.66667%;\n  max-width: 16.66667%;\n}\n\n.small-up-7 {\n  flex-wrap: wrap;\n}\n\n.small-up-7 > .column, .small-up-7 > .columns {\n  flex: 0 0 14.28571%;\n  max-width: 14.28571%;\n}\n\n.small-up-8 {\n  flex-wrap: wrap;\n}\n\n.small-up-8 > .column, .small-up-8 > .columns {\n  flex: 0 0 12.5%;\n  max-width: 12.5%;\n}\n\n.small-collapse > .column, .small-collapse > .columns {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.small-uncollapse > .column, .small-uncollapse > .columns {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-1 {\n    flex: 0 0 8.33333%;\n    max-width: 8.33333%;\n  }\n  .medium-offset-0 {\n    margin-left: 0%;\n  }\n  .medium-2 {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .medium-offset-1 {\n    margin-left: 8.33333%;\n  }\n  .medium-3 {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .medium-offset-2 {\n    margin-left: 16.66667%;\n  }\n  .medium-4 {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .medium-offset-3 {\n    margin-left: 25%;\n  }\n  .medium-5 {\n    flex: 0 0 41.66667%;\n    max-width: 41.66667%;\n  }\n  .medium-offset-4 {\n    margin-left: 33.33333%;\n  }\n  .medium-6 {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .medium-offset-5 {\n    margin-left: 41.66667%;\n  }\n  .medium-7 {\n    flex: 0 0 58.33333%;\n    max-width: 58.33333%;\n  }\n  .medium-offset-6 {\n    margin-left: 50%;\n  }\n  .medium-8 {\n    flex: 0 0 66.66667%;\n    max-width: 66.66667%;\n  }\n  .medium-offset-7 {\n    margin-left: 58.33333%;\n  }\n  .medium-9 {\n    flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .medium-offset-8 {\n    margin-left: 66.66667%;\n  }\n  .medium-10 {\n    flex: 0 0 83.33333%;\n    max-width: 83.33333%;\n  }\n  .medium-offset-9 {\n    margin-left: 75%;\n  }\n  .medium-11 {\n    flex: 0 0 91.66667%;\n    max-width: 91.66667%;\n  }\n  .medium-offset-10 {\n    margin-left: 83.33333%;\n  }\n  .medium-12 {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .medium-offset-11 {\n    margin-left: 91.66667%;\n  }\n  .medium-order-1 {\n    order: 1;\n  }\n  .medium-order-2 {\n    order: 2;\n  }\n  .medium-order-3 {\n    order: 3;\n  }\n  .medium-order-4 {\n    order: 4;\n  }\n  .medium-order-5 {\n    order: 5;\n  }\n  .medium-order-6 {\n    order: 6;\n  }\n  .medium-up-1 {\n    flex-wrap: wrap;\n  }\n  .medium-up-1 > .column, .medium-up-1 > .columns {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .medium-up-2 {\n    flex-wrap: wrap;\n  }\n  .medium-up-2 > .column, .medium-up-2 > .columns {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .medium-up-3 {\n    flex-wrap: wrap;\n  }\n  .medium-up-3 > .column, .medium-up-3 > .columns {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .medium-up-4 {\n    flex-wrap: wrap;\n  }\n  .medium-up-4 > .column, .medium-up-4 > .columns {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .medium-up-5 {\n    flex-wrap: wrap;\n  }\n  .medium-up-5 > .column, .medium-up-5 > .columns {\n    flex: 0 0 20%;\n    max-width: 20%;\n  }\n  .medium-up-6 {\n    flex-wrap: wrap;\n  }\n  .medium-up-6 > .column, .medium-up-6 > .columns {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .medium-up-7 {\n    flex-wrap: wrap;\n  }\n  .medium-up-7 > .column, .medium-up-7 > .columns {\n    flex: 0 0 14.28571%;\n    max-width: 14.28571%;\n  }\n  .medium-up-8 {\n    flex-wrap: wrap;\n  }\n  .medium-up-8 > .column, .medium-up-8 > .columns {\n    flex: 0 0 12.5%;\n    max-width: 12.5%;\n  }\n}\n\n@media print, screen and (min-width: 40em) and (min-width: 40em) {\n  .medium-expand {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-dir-row {\n    flex-direction: row;\n  }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse;\n  }\n  .medium-flex-dir-column {\n    flex-direction: column;\n  }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse;\n  }\n  .medium-flex-child-auto {\n    flex: 1 1 auto;\n  }\n  .medium-flex-child-grow {\n    flex: 1 0 auto;\n  }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto;\n  }\n}\n\n.row.medium-unstack > .column, .row.medium-unstack > .columns {\n  flex: 0 0 100%;\n}\n\n@media print, screen and (min-width: 40em) {\n  .row.medium-unstack > .column, .row.medium-unstack > .columns {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-collapse > .column, .medium-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0;\n  }\n  .medium-uncollapse > .column, .medium-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-1 {\n    flex: 0 0 8.33333%;\n    max-width: 8.33333%;\n  }\n  .large-offset-0 {\n    margin-left: 0%;\n  }\n  .large-2 {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .large-offset-1 {\n    margin-left: 8.33333%;\n  }\n  .large-3 {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .large-offset-2 {\n    margin-left: 16.66667%;\n  }\n  .large-4 {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .large-offset-3 {\n    margin-left: 25%;\n  }\n  .large-5 {\n    flex: 0 0 41.66667%;\n    max-width: 41.66667%;\n  }\n  .large-offset-4 {\n    margin-left: 33.33333%;\n  }\n  .large-6 {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .large-offset-5 {\n    margin-left: 41.66667%;\n  }\n  .large-7 {\n    flex: 0 0 58.33333%;\n    max-width: 58.33333%;\n  }\n  .large-offset-6 {\n    margin-left: 50%;\n  }\n  .large-8 {\n    flex: 0 0 66.66667%;\n    max-width: 66.66667%;\n  }\n  .large-offset-7 {\n    margin-left: 58.33333%;\n  }\n  .large-9 {\n    flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .large-offset-8 {\n    margin-left: 66.66667%;\n  }\n  .large-10 {\n    flex: 0 0 83.33333%;\n    max-width: 83.33333%;\n  }\n  .large-offset-9 {\n    margin-left: 75%;\n  }\n  .large-11 {\n    flex: 0 0 91.66667%;\n    max-width: 91.66667%;\n  }\n  .large-offset-10 {\n    margin-left: 83.33333%;\n  }\n  .large-12 {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .large-offset-11 {\n    margin-left: 91.66667%;\n  }\n  .large-order-1 {\n    order: 1;\n  }\n  .large-order-2 {\n    order: 2;\n  }\n  .large-order-3 {\n    order: 3;\n  }\n  .large-order-4 {\n    order: 4;\n  }\n  .large-order-5 {\n    order: 5;\n  }\n  .large-order-6 {\n    order: 6;\n  }\n  .large-up-1 {\n    flex-wrap: wrap;\n  }\n  .large-up-1 > .column, .large-up-1 > .columns {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .large-up-2 {\n    flex-wrap: wrap;\n  }\n  .large-up-2 > .column, .large-up-2 > .columns {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .large-up-3 {\n    flex-wrap: wrap;\n  }\n  .large-up-3 > .column, .large-up-3 > .columns {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .large-up-4 {\n    flex-wrap: wrap;\n  }\n  .large-up-4 > .column, .large-up-4 > .columns {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .large-up-5 {\n    flex-wrap: wrap;\n  }\n  .large-up-5 > .column, .large-up-5 > .columns {\n    flex: 0 0 20%;\n    max-width: 20%;\n  }\n  .large-up-6 {\n    flex-wrap: wrap;\n  }\n  .large-up-6 > .column, .large-up-6 > .columns {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .large-up-7 {\n    flex-wrap: wrap;\n  }\n  .large-up-7 > .column, .large-up-7 > .columns {\n    flex: 0 0 14.28571%;\n    max-width: 14.28571%;\n  }\n  .large-up-8 {\n    flex-wrap: wrap;\n  }\n  .large-up-8 > .column, .large-up-8 > .columns {\n    flex: 0 0 12.5%;\n    max-width: 12.5%;\n  }\n}\n\n@media print, screen and (min-width: 64em) and (min-width: 64em) {\n  .large-expand {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-dir-row {\n    flex-direction: row;\n  }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse;\n  }\n  .large-flex-dir-column {\n    flex-direction: column;\n  }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse;\n  }\n  .large-flex-child-auto {\n    flex: 1 1 auto;\n  }\n  .large-flex-child-grow {\n    flex: 1 0 auto;\n  }\n  .large-flex-child-shrink {\n    flex: 0 1 auto;\n  }\n}\n\n.row.large-unstack > .column, .row.large-unstack > .columns {\n  flex: 0 0 100%;\n}\n\n@media print, screen and (min-width: 64em) {\n  .row.large-unstack > .column, .row.large-unstack > .columns {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-collapse > .column, .large-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0;\n  }\n  .large-uncollapse > .column, .large-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n.shrink {\n  flex: 0 0 auto;\n  max-width: 100%;\n}\n\n.column-block {\n  margin-bottom: 1.25rem;\n}\n\n.column-block > :last-child {\n  margin-bottom: 0;\n}\n\n@media print, screen and (min-width: 40em) {\n  .column-block {\n    margin-bottom: 1.875rem;\n  }\n  .column-block > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n.align-right {\n  justify-content: flex-end;\n}\n\n.align-center {\n  justify-content: center;\n}\n\n.align-justify {\n  justify-content: space-between;\n}\n\n.align-spaced {\n  justify-content: space-around;\n}\n\n.align-top {\n  align-items: flex-start;\n}\n\n.align-self-top {\n  align-self: flex-start;\n}\n\n.align-bottom {\n  align-items: flex-end;\n}\n\n.align-self-bottom {\n  align-self: flex-end;\n}\n\n.align-middle {\n  align-items: center;\n}\n\n.align-self-middle {\n  align-self: center;\n}\n\n.align-stretch {\n  align-items: stretch;\n}\n\n.align-self-stretch {\n  align-self: stretch;\n}\n\n.small-order-1 {\n  order: 1;\n}\n\n.small-order-2 {\n  order: 2;\n}\n\n.small-order-3 {\n  order: 3;\n}\n\n.small-order-4 {\n  order: 4;\n}\n\n.small-order-5 {\n  order: 5;\n}\n\n.small-order-6 {\n  order: 6;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1;\n  }\n  .medium-order-2 {\n    order: 2;\n  }\n  .medium-order-3 {\n    order: 3;\n  }\n  .medium-order-4 {\n    order: 4;\n  }\n  .medium-order-5 {\n    order: 5;\n  }\n  .medium-order-6 {\n    order: 6;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1;\n  }\n  .large-order-2 {\n    order: 2;\n  }\n  .large-order-3 {\n    order: 3;\n  }\n  .large-order-4 {\n    order: 4;\n  }\n  .large-order-5 {\n    order: 5;\n  }\n  .large-order-6 {\n    order: 6;\n  }\n}\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}\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility;\n}\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit;\n}\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit;\n}\n\nsmall {\n  font-size: 80%;\n  line-height: inherit;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\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}\n\nh1 small,\nh2 small,\nh3 small,\nh4 small,\nh5 small,\nh6 small {\n  line-height: 0;\n  color: #cacaca;\n}\n\nh1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  h1 {\n    font-size: 3rem;\n  }\n  h2 {\n    font-size: 2.5rem;\n  }\n  h3 {\n    font-size: 1.9375rem;\n  }\n  h4 {\n    font-size: 1.5625rem;\n  }\n  h5 {\n    font-size: 1.25rem;\n  }\n  h6 {\n    font-size: 1rem;\n  }\n}\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer;\n}\n\na:hover, a:focus {\n  color: #1468a0;\n}\n\na img {\n  border: 0;\n}\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}\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6;\n}\n\nli {\n  font-size: inherit;\n}\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc;\n}\n\nol {\n  margin-left: 1.25rem;\n}\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0;\n}\n\ndl {\n  margin-bottom: 1rem;\n}\n\ndl dt {\n  margin-bottom: 0.3rem;\n  font-weight: bold;\n}\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca;\n}\n\nblockquote, blockquote p {\n  line-height: 1.6;\n  color: #8a8a8a;\n}\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a;\n}\n\ncite:before {\n  content: \"— \";\n}\n\nabbr {\n  border-bottom: 1px dotted #0a0a0a;\n  color: #0a0a0a;\n  cursor: help;\n}\n\nfigure {\n  margin: 0;\n}\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}\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\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\n.lead {\n  font-size: 125%;\n  line-height: 1.6;\n}\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1;\n}\n\np + .stat {\n  margin-top: -1rem;\n}\n\n.no-bullet {\n  margin-left: 0;\n  list-style: none;\n}\n\n.text-left {\n  text-align: left;\n}\n\n.text-right {\n  text-align: right;\n}\n\n.text-center {\n  text-align: center;\n}\n\n.text-justify {\n  text-align: justify;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left;\n  }\n  .medium-text-right {\n    text-align: right;\n  }\n  .medium-text-center {\n    text-align: center;\n  }\n  .medium-text-justify {\n    text-align: justify;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left;\n  }\n  .large-text-right {\n    text-align: right;\n  }\n  .large-text-center {\n    text-align: center;\n  }\n  .large-text-justify {\n    text-align: justify;\n  }\n}\n\n.show-for-print {\n  display: none !important;\n}\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important;\n  }\n  .show-for-print {\n    display: block !important;\n  }\n  .hide-for-print {\n    display: none !important;\n  }\n  table.show-for-print {\n    display: table !important;\n  }\n  thead.show-for-print {\n    display: table-header-group !important;\n  }\n  tbody.show-for-print {\n    display: table-row-group !important;\n  }\n  tr.show-for-print {\n    display: table-row !important;\n  }\n  td.show-for-print {\n    display: table-cell !important;\n  }\n  th.show-for-print {\n    display: table-cell !important;\n  }\n  a,\n  a:visited {\n    text-decoration: underline;\n  }\n  a[href]:after {\n    content: \" (\" attr(href) \")\";\n  }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: '';\n  }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\";\n  }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid;\n  }\n  thead {\n    display: table-header-group;\n  }\n  tr,\n  img {\n    page-break-inside: avoid;\n  }\n  img {\n    max-width: 100% !important;\n  }\n  @page {\n    margin: 0.5cm;\n  }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3;\n  }\n  h2,\n  h3 {\n    page-break-after: avoid;\n  }\n}\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  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none;\n}\n\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,\ntextarea: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}\n\ntextarea {\n  max-width: 100%;\n}\n\ntextarea[rows] {\n  height: auto;\n}\n\ninput::placeholder,\ntextarea::placeholder {\n  color: #cacaca;\n}\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed;\n}\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0;\n}\n\ninput[type='search'] {\n  box-sizing: border-box;\n}\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem;\n}\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}\n\n[type='checkbox'] + label[for],\n[type='radio'] + label[for] {\n  cursor: pointer;\n}\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem;\n}\n\n[type='file'] {\n  width: 100%;\n}\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}\n\nlabel.middle {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 0;\n}\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a;\n}\n\n.input-group {\n  display: table;\n  width: 100%;\n  margin-bottom: 1rem;\n}\n\n.input-group > :first-child {\n  border-radius: 0 0 0 0;\n}\n\n.input-group > :last-child > * {\n  border-radius: 0 0 0 0;\n}\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\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}\n\n.input-group-label:first-child {\n  border-right: 0;\n}\n\n.input-group-label:last-child {\n  border-left: 0;\n}\n\n.input-group-field {\n  border-radius: 0;\n  height: 2.5rem;\n}\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  width: 1%;\n  height: 100%;\n}\n\n.input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  height: 2.5rem;\n  padding-top: 0;\n  padding-bottom: 0;\n  font-size: 1rem;\n}\n\n.input-group .input-group-button {\n  display: table-cell;\n}\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem;\n}\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca;\n}\n\n.fieldset legend {\n  margin: 0;\n  margin-left: -0.1875rem;\n  padding: 0 0.1875rem;\n  background: #fefefe;\n}\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  line-height: normal;\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}\n\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  }\n}\n\nselect: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}\n\nselect:disabled {\n  background-color: #e6e6e6;\n  cursor: not-allowed;\n}\n\nselect::-ms-expand {\n  display: none;\n}\n\nselect[multiple] {\n  height: auto;\n  background-image: none;\n}\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea;\n}\n\n.is-invalid-input:not(:focus)::placeholder {\n  color: #cc4b37;\n}\n\n.is-invalid-label {\n  color: #cc4b37;\n}\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}\n\n.form-error.is-visible {\n  display: block;\n}\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  -webkit-appearance: none;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-size: 0.9rem;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n[data-whatinput='mouse'] .button {\n  outline: 0;\n}\n\n.button:hover, .button:focus {\n  background-color: #14679e;\n  color: #fefefe;\n}\n\n.button.tiny {\n  font-size: 0.6rem;\n}\n\n.button.small {\n  font-size: 0.75rem;\n}\n\n.button.large {\n  font-size: 1.25rem;\n}\n\n.button.expanded {\n  display: block;\n  width: 100%;\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.button.primary {\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n.button.primary:hover, .button.primary:focus {\n  background-color: #126195;\n  color: #fefefe;\n}\n\n.button.secondary {\n  background-color: #767676;\n  color: #fefefe;\n}\n\n.button.secondary:hover, .button.secondary:focus {\n  background-color: #5e5e5e;\n  color: #fefefe;\n}\n\n.button.success {\n  background-color: #3adb76;\n  color: #0a0a0a;\n}\n\n.button.success:hover, .button.success:focus {\n  background-color: #22bb5b;\n  color: #0a0a0a;\n}\n\n.button.warning {\n  background-color: #ffae00;\n  color: #0a0a0a;\n}\n\n.button.warning:hover, .button.warning:focus {\n  background-color: #cc8b00;\n  color: #0a0a0a;\n}\n\n.button.alert {\n  background-color: #cc4b37;\n  color: #fefefe;\n}\n\n.button.alert:hover, .button.alert:focus {\n  background-color: #a53b2a;\n  color: #fefefe;\n}\n\n.button.hollow {\n  border: 1px solid #1779ba;\n  color: #1779ba;\n}\n\n.button.hollow, .button.hollow:hover, .button.hollow:focus {\n  background-color: transparent;\n}\n\n.button.hollow:hover, .button.hollow:focus {\n  border-color: #0c3d5d;\n  color: #0c3d5d;\n}\n\n.button.hollow.primary {\n  border: 1px solid #1779ba;\n  color: #1779ba;\n}\n\n.button.hollow.primary:hover, .button.hollow.primary:focus {\n  border-color: #0c3d5d;\n  color: #0c3d5d;\n}\n\n.button.hollow.secondary {\n  border: 1px solid #767676;\n  color: #767676;\n}\n\n.button.hollow.secondary:hover, .button.hollow.secondary:focus {\n  border-color: #3b3b3b;\n  color: #3b3b3b;\n}\n\n.button.hollow.success {\n  border: 1px solid #3adb76;\n  color: #3adb76;\n}\n\n.button.hollow.success:hover, .button.hollow.success:focus {\n  border-color: #157539;\n  color: #157539;\n}\n\n.button.hollow.warning {\n  border: 1px solid #ffae00;\n  color: #ffae00;\n}\n\n.button.hollow.warning:hover, .button.hollow.warning:focus {\n  border-color: #805700;\n  color: #805700;\n}\n\n.button.hollow.alert {\n  border: 1px solid #cc4b37;\n  color: #cc4b37;\n}\n\n.button.hollow.alert:hover, .button.hollow.alert:focus {\n  border-color: #67251a;\n  color: #67251a;\n}\n\n.button.disabled, .button[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.primary, .button[disabled].primary {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.secondary, .button[disabled].secondary {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.success, .button[disabled].success {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.warning, .button[disabled].warning {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.alert, .button[disabled].alert {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\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}\n\n.button.arrow-only::after {\n  top: -0.1em;\n  float: none;\n  margin-left: 0;\n}\n\n.accordion {\n  margin-left: 0;\n  background: #fefefe;\n  list-style-type: none;\n}\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0;\n}\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0;\n}\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}\n\n:last-child:not(.is-active) > .accordion-title {\n  border-bottom: 1px solid #e6e6e6;\n  border-radius: 0 0 0 0;\n}\n\n.accordion-title:hover, .accordion-title:focus {\n  background-color: #e6e6e6;\n}\n\n.accordion-title::before {\n  position: absolute;\n  top: 50%;\n  right: 1rem;\n  margin-top: -0.5rem;\n  content: '+';\n}\n\n.is-active > .accordion-title::before {\n  content: '\\2013';\n}\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}\n\n:last-child > .accordion-content:last-child {\n  border-bottom: 1px solid #e6e6e6;\n}\n\n.is-accordion-submenu-parent > a {\n  position: relative;\n}\n\n.is-accordion-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  position: absolute;\n  top: 50%;\n  margin-top: -3px;\n  right: 1rem;\n}\n\n.is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%;\n}\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}\n\n.badge.primary {\n  background: #1779ba;\n  color: #fefefe;\n}\n\n.badge.secondary {\n  background: #767676;\n  color: #fefefe;\n}\n\n.badge.success {\n  background: #3adb76;\n  color: #0a0a0a;\n}\n\n.badge.warning {\n  background: #ffae00;\n  color: #0a0a0a;\n}\n\n.badge.alert {\n  background: #cc4b37;\n  color: #fefefe;\n}\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none;\n}\n\n.breadcrumbs::before, .breadcrumbs::after {\n  display: table;\n  content: ' ';\n}\n\n.breadcrumbs::after {\n  clear: both;\n}\n\n.breadcrumbs li {\n  float: left;\n  font-size: 0.6875rem;\n  color: #0a0a0a;\n  cursor: default;\n  text-transform: uppercase;\n}\n\n.breadcrumbs li:not(:last-child)::after {\n  position: relative;\n  top: 1px;\n  margin: 0 0.75rem;\n  opacity: 1;\n  content: \"/\";\n  color: #cacaca;\n}\n\n.breadcrumbs a {\n  color: #1779ba;\n}\n\n.breadcrumbs a:hover {\n  text-decoration: underline;\n}\n\n.breadcrumbs .disabled {\n  color: #cacaca;\n  cursor: not-allowed;\n}\n\n.button-group {\n  margin-bottom: 1rem;\n  font-size: 0;\n}\n\n.button-group::before, .button-group::after {\n  display: table;\n  content: ' ';\n}\n\n.button-group::after {\n  clear: both;\n}\n\n.button-group .button {\n  margin: 0;\n  margin-right: 1px;\n  margin-bottom: 1px;\n  font-size: 0.9rem;\n}\n\n.button-group .button:last-child {\n  margin-right: 0;\n}\n\n.button-group.tiny .button {\n  font-size: 0.6rem;\n}\n\n.button-group.small .button {\n  font-size: 0.75rem;\n}\n\n.button-group.large .button {\n  font-size: 1.25rem;\n}\n\n.button-group.expanded {\n  margin-right: -1px;\n}\n\n.button-group.expanded::before, .button-group.expanded::after {\n  display: none;\n}\n\n.button-group.expanded .button:first-child:last-child {\n  width: 100%;\n}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\n.button-group.primary .button {\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n.button-group.primary .button:hover, .button-group.primary .button:focus {\n  background-color: #126195;\n  color: #fefefe;\n}\n\n.button-group.secondary .button {\n  background-color: #767676;\n  color: #fefefe;\n}\n\n.button-group.secondary .button:hover, .button-group.secondary .button:focus {\n  background-color: #5e5e5e;\n  color: #fefefe;\n}\n\n.button-group.success .button {\n  background-color: #3adb76;\n  color: #0a0a0a;\n}\n\n.button-group.success .button:hover, .button-group.success .button:focus {\n  background-color: #22bb5b;\n  color: #0a0a0a;\n}\n\n.button-group.warning .button {\n  background-color: #ffae00;\n  color: #0a0a0a;\n}\n\n.button-group.warning .button:hover, .button-group.warning .button:focus {\n  background-color: #cc8b00;\n  color: #0a0a0a;\n}\n\n.button-group.alert .button {\n  background-color: #cc4b37;\n  color: #fefefe;\n}\n\n.button-group.alert .button:hover, .button-group.alert .button:focus {\n  background-color: #a53b2a;\n  color: #fefefe;\n}\n\n.button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n  width: 100%;\n}\n\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}\n\n@media print, screen and (min-width: 40em) {\n  .button-group.stacked-for-small .button {\n    width: auto;\n    margin-bottom: 0;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .button-group.stacked-for-medium .button {\n    width: auto;\n    margin-bottom: 0;\n  }\n}\n\n@media screen and (max-width: 39.9375em) {\n  .button-group.stacked-for-small.expanded {\n    display: block;\n  }\n  .button-group.stacked-for-small.expanded .button {\n    display: block;\n    margin-right: 0;\n  }\n}\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}\n\n.callout > :first-child {\n  margin-top: 0;\n}\n\n.callout > :last-child {\n  margin-bottom: 0;\n}\n\n.callout.primary {\n  background-color: #d7ecfa;\n  color: #0a0a0a;\n}\n\n.callout.secondary {\n  background-color: #eaeaea;\n  color: #0a0a0a;\n}\n\n.callout.success {\n  background-color: #e1faea;\n  color: #0a0a0a;\n}\n\n.callout.warning {\n  background-color: #fff3d9;\n  color: #0a0a0a;\n}\n\n.callout.alert {\n  background-color: #f7e4e1;\n  color: #0a0a0a;\n}\n\n.callout.small {\n  padding-top: 0.5rem;\n  padding-right: 0.5rem;\n  padding-bottom: 0.5rem;\n  padding-left: 0.5rem;\n}\n\n.callout.large {\n  padding-top: 3rem;\n  padding-right: 3rem;\n  padding-bottom: 3rem;\n  padding-left: 3rem;\n}\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}\n\n.card > :last-child {\n  margin-bottom: 0;\n}\n\n.card-divider {\n  padding: 1rem;\n  background: #e6e6e6;\n}\n\n.card-divider > :last-child {\n  margin-bottom: 0;\n}\n\n.card-section {\n  padding: 1rem;\n}\n\n.card-section > :last-child {\n  margin-bottom: 0;\n}\n\n.close-button {\n  position: absolute;\n  color: #8a8a8a;\n  cursor: pointer;\n}\n\n[data-whatinput='mouse'] .close-button {\n  outline: 0;\n}\n\n.close-button:hover, .close-button:focus {\n  color: #0a0a0a;\n}\n\n.close-button.small {\n  right: 0.66rem;\n  top: 0.33em;\n  font-size: 1.5em;\n  line-height: 1;\n}\n\n.close-button, .close-button.medium {\n  right: 1rem;\n  top: 0.5rem;\n  font-size: 2em;\n  line-height: 1;\n}\n\n.menu {\n  margin: 0;\n  list-style-type: none;\n}\n\n.menu > li {\n  display: table-cell;\n  vertical-align: middle;\n}\n\n[data-whatinput='mouse'] .menu > li {\n  outline: 0;\n}\n\n.menu > li > a {\n  display: block;\n  padding: 0.7rem 1rem;\n  line-height: 1;\n}\n\n.menu input,\n.menu select,\n.menu a,\n.menu button {\n  margin-bottom: 0;\n}\n\n.menu > li > a img,\n.menu > li > a i,\n.menu > li > a svg {\n  vertical-align: middle;\n}\n\n.menu > li > a img + span,\n.menu > li > a i + span,\n.menu > li > a svg + span {\n  vertical-align: middle;\n}\n\n.menu > li > a img,\n.menu > li > a i,\n.menu > li > a svg {\n  margin-right: 0.25rem;\n  display: inline-block;\n}\n\n.menu > li, .menu.horizontal > li {\n  display: table-cell;\n}\n\n.menu.expanded {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n}\n\n.menu.expanded > li:first-child:last-child {\n  width: 100%;\n}\n\n.menu.vertical > li {\n  display: block;\n}\n\n@media print, screen and (min-width: 40em) {\n  .menu.medium-horizontal > li {\n    display: table-cell;\n  }\n  .menu.medium-expanded {\n    display: table;\n    width: 100%;\n    table-layout: fixed;\n  }\n  .menu.medium-expanded > li:first-child:last-child {\n    width: 100%;\n  }\n  .menu.medium-vertical > li {\n    display: block;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .menu.large-horizontal > li {\n    display: table-cell;\n  }\n  .menu.large-expanded {\n    display: table;\n    width: 100%;\n    table-layout: fixed;\n  }\n  .menu.large-expanded > li:first-child:last-child {\n    width: 100%;\n  }\n  .menu.large-vertical > li {\n    display: block;\n  }\n}\n\n.menu.simple li {\n  display: inline-block;\n  vertical-align: top;\n  line-height: 1;\n}\n\n.menu.simple a {\n  padding: 0;\n}\n\n.menu.simple li {\n  margin-left: 0;\n  margin-right: 1rem;\n}\n\n.menu.simple.align-right li {\n  margin-right: 0;\n  margin-left: 1rem;\n}\n\n.menu.align-right::before, .menu.align-right::after {\n  display: table;\n  content: ' ';\n}\n\n.menu.align-right::after {\n  clear: both;\n}\n\n.menu.align-right > li {\n  float: right;\n}\n\n.menu.icon-top > li > a {\n  text-align: center;\n}\n\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}\n\n.menu.icon-top.vertical a > span {\n  margin: auto;\n}\n\n.menu.nested {\n  margin-left: 1rem;\n}\n\n.menu .active > a {\n  background: #1779ba;\n  color: #fefefe;\n}\n\n.menu.menu-bordered li {\n  border: 1px solid #e6e6e6;\n}\n\n.menu.menu-bordered li:not(:first-child) {\n  border-top: 0;\n}\n\n.menu.menu-hover li:hover {\n  background-color: #e6e6e6;\n}\n\n.menu-text {\n  padding-top: 0;\n  padding-bottom: 0;\n  padding: 0.7rem 1rem;\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n.menu-centered {\n  text-align: center;\n}\n\n.menu-centered > .menu {\n  display: inline-block;\n  vertical-align: top;\n}\n\n.no-js [data-responsive-menu] ul {\n  display: none;\n}\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}\n\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}\n\n.menu-icon:hover::after {\n  background: #cacaca;\n  box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;\n}\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}\n\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}\n\n.menu-icon.dark:hover::after {\n  background: #8a8a8a;\n  box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;\n}\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden;\n}\n\n.is-drilldown li {\n  display: block;\n}\n\n.is-drilldown.animate-height {\n  transition: height 0.5s;\n}\n\n.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}\n\n.is-drilldown-submenu.is-active {\n  z-index: 1;\n  display: block;\n  transform: translateX(-100%);\n}\n\n.is-drilldown-submenu.is-closing {\n  transform: translateX(100%);\n}\n\n.drilldown-submenu-cover-previous {\n  min-height: 100%;\n}\n\n.is-drilldown-submenu-parent > a {\n  position: relative;\n}\n\n.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\n.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  border-left-width: 0;\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 0.75rem;\n  border-left-width: 0;\n}\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: block;\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}\n\n.dropdown-pane.is-open {\n  visibility: visible;\n}\n\n.dropdown-pane.tiny {\n  width: 100px;\n}\n\n.dropdown-pane.small {\n  width: 200px;\n}\n\n.dropdown-pane.large {\n  width: 400px;\n}\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto;\n}\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0;\n}\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem;\n}\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  margin-top: -3px;\n}\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0;\n}\n\n.no-js .dropdown.menu ul {\n  display: none;\n}\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0;\n}\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  right: 100%;\n  left: auto;\n}\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%;\n}\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px;\n}\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}\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\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  }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0;\n  }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem;\n  }\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    margin-top: -3px;\n  }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0;\n  }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto;\n  }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%;\n  }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px;\n  }\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  }\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}\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  }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0;\n  }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem;\n  }\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    margin-top: -3px;\n  }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0;\n  }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto;\n  }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%;\n  }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px;\n  }\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  }\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}\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto;\n}\n\n.is-dropdown-menu.vertical {\n  width: 100px;\n}\n\n.is-dropdown-menu.vertical.align-right {\n  float: right;\n}\n\n.is-dropdown-submenu-parent {\n  position: relative;\n}\n\n.is-dropdown-submenu-parent a::after {\n  position: absolute;\n  top: 50%;\n  right: 5px;\n  margin-top: -6px;\n}\n\n.is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n  top: 100%;\n  left: auto;\n}\n\n.is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n  right: 100%;\n  left: auto;\n}\n\n.is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%;\n}\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}\n\n.is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n  right: 14px;\n}\n\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}\n\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}\n\n.is-dropdown-submenu .is-dropdown-submenu {\n  margin-top: -1px;\n}\n\n.is-dropdown-submenu > li {\n  width: 100%;\n}\n\n.is-dropdown-submenu.js-dropdown-active {\n  display: block;\n}\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}\n\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}\n\n.responsive-embed.widescreen,\n.flex-video.widescreen {\n  padding-bottom: 56.25%;\n}\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}\n\n.label.primary {\n  background: #1779ba;\n  color: #fefefe;\n}\n\n.label.secondary {\n  background: #767676;\n  color: #fefefe;\n}\n\n.label.success {\n  background: #3adb76;\n  color: #0a0a0a;\n}\n\n.label.warning {\n  background: #ffae00;\n  color: #0a0a0a;\n}\n\n.label.alert {\n  background: #cc4b37;\n  color: #fefefe;\n}\n\n.media-object {\n  display: block;\n  margin-bottom: 1rem;\n}\n\n.media-object img {\n  max-width: none;\n}\n\n@media screen and (max-width: 39.9375em) {\n  .media-object.stack-for-small .media-object-section {\n    padding: 0;\n    padding-bottom: 1rem;\n    display: block;\n  }\n  .media-object.stack-for-small .media-object-section img {\n    width: 100%;\n  }\n}\n\n.media-object-section {\n  display: table-cell;\n  vertical-align: top;\n}\n\n.media-object-section:first-child {\n  padding-right: 1rem;\n}\n\n.media-object-section:last-child:not(:nth-child(2)) {\n  padding-left: 1rem;\n}\n\n.media-object-section > :last-child {\n  margin-bottom: 0;\n}\n\n.media-object-section.middle {\n  vertical-align: middle;\n}\n\n.media-object-section.bottom {\n  vertical-align: bottom;\n}\n\n.is-off-canvas-open {\n  overflow: hidden;\n}\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\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}\n\n.js-off-canvas-overlay.is-visible {\n  opacity: 1;\n  visibility: visible;\n}\n\n.js-off-canvas-overlay.is-closable {\n  cursor: pointer;\n}\n\n.js-off-canvas-overlay.is-overlay-absolute {\n  position: absolute;\n}\n\n.js-off-canvas-overlay.is-overlay-fixed {\n  position: fixed;\n}\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden;\n}\n\n.off-canvas {\n  position: fixed;\n  z-index: 1;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6;\n}\n\n[data-whatinput='mouse'] .off-canvas {\n  outline: 0;\n}\n\n.off-canvas.is-transition-overlap {\n  z-index: 10;\n}\n\n.off-canvas.is-transition-overlap.is-open {\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n}\n\n.off-canvas.is-open {\n  transform: translate(0, 0);\n}\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 1;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6;\n}\n\n[data-whatinput='mouse'] .off-canvas-absolute {\n  outline: 0;\n}\n\n.off-canvas-absolute.is-transition-overlap {\n  z-index: 10;\n}\n\n.off-canvas-absolute.is-transition-overlap.is-open {\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n}\n\n.off-canvas-absolute.is-open {\n  transform: translate(0, 0);\n}\n\n.position-left {\n  top: 0;\n  left: 0;\n  width: 250px;\n  height: 100%;\n  transform: translateX(-250px);\n  overflow-y: auto;\n}\n\n.position-left.is-open ~ .off-canvas-content {\n  transform: translateX(250px);\n}\n\n.position-left.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  right: 0;\n  height: 100%;\n  width: 1px;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-left.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-right {\n  top: 0;\n  right: 0;\n  width: 250px;\n  height: 100%;\n  transform: translateX(250px);\n  overflow-y: auto;\n}\n\n.position-right.is-open ~ .off-canvas-content {\n  transform: translateX(-250px);\n}\n\n.position-right.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  left: 0;\n  height: 100%;\n  width: 1px;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-right.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 250px;\n  transform: translateY(-250px);\n  overflow-x: auto;\n}\n\n.position-top.is-open ~ .off-canvas-content {\n  transform: translateY(250px);\n}\n\n.position-top.is-transition-push::after {\n  position: absolute;\n  bottom: 0;\n  left: 0;\n  height: 1px;\n  width: 100%;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-top.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  height: 250px;\n  transform: translateY(250px);\n  overflow-x: auto;\n}\n\n.position-bottom.is-open ~ .off-canvas-content {\n  transform: translateY(-250px);\n}\n\n.position-bottom.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  left: 0;\n  height: 1px;\n  width: 100%;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-bottom.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.off-canvas-content {\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n}\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-left.reveal-for-medium ~ .off-canvas-content {\n    margin-left: 250px;\n  }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-right.reveal-for-medium ~ .off-canvas-content {\n    margin-right: 250px;\n  }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-top.reveal-for-medium ~ .off-canvas-content {\n    margin-top: 250px;\n  }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-bottom.reveal-for-medium ~ .off-canvas-content {\n    margin-bottom: 250px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-left.reveal-for-large ~ .off-canvas-content {\n    margin-left: 250px;\n  }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-right.reveal-for-large ~ .off-canvas-content {\n    margin-right: 250px;\n  }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-top.reveal-for-large ~ .off-canvas-content {\n    margin-top: 250px;\n  }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-bottom.reveal-for-large ~ .off-canvas-content {\n    margin-bottom: 250px;\n  }\n}\n\n.orbit {\n  position: relative;\n}\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n.orbit-slide {\n  width: 100%;\n}\n\n.orbit-slide.no-motionui.is-active {\n  top: 0;\n  left: 0;\n}\n\n.orbit-figure {\n  margin: 0;\n}\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\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\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}\n\n[data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n  outline: 0;\n}\n\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\n.orbit-previous {\n  left: 0;\n}\n\n.orbit-next {\n  left: auto;\n  right: 0;\n}\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center;\n}\n\n[data-whatinput='mouse'] .orbit-bullets {\n  outline: 0;\n}\n\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}\n\n.orbit-bullets button:hover {\n  background-color: #8a8a8a;\n}\n\n.orbit-bullets button.is-active {\n  background-color: #8a8a8a;\n}\n\n.pagination {\n  margin-left: 0;\n  margin-bottom: 1rem;\n}\n\n.pagination::before, .pagination::after {\n  display: table;\n  content: ' ';\n}\n\n.pagination::after {\n  clear: both;\n}\n\n.pagination li {\n  margin-right: 0.0625rem;\n  border-radius: 0;\n  font-size: 0.875rem;\n  display: none;\n}\n\n.pagination li:last-child, .pagination li:first-child {\n  display: inline-block;\n}\n\n@media print, screen and (min-width: 40em) {\n  .pagination li {\n    display: inline-block;\n  }\n}\n\n.pagination a,\n.pagination button {\n  display: block;\n  padding: 0.1875rem 0.625rem;\n  border-radius: 0;\n  color: #0a0a0a;\n}\n\n.pagination a:hover,\n.pagination button:hover {\n  background: #e6e6e6;\n}\n\n.pagination .current {\n  padding: 0.1875rem 0.625rem;\n  background: #1779ba;\n  color: #fefefe;\n  cursor: default;\n}\n\n.pagination .disabled {\n  padding: 0.1875rem 0.625rem;\n  color: #cacaca;\n  cursor: not-allowed;\n}\n\n.pagination .disabled:hover {\n  background: transparent;\n}\n\n.pagination .ellipsis::after {\n  padding: 0.1875rem 0.625rem;\n  content: '\\2026';\n  color: #0a0a0a;\n}\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\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: '\\00bb';\n}\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca;\n}\n\n.progress.primary .progress-meter {\n  background-color: #1779ba;\n}\n\n.progress.secondary .progress-meter {\n  background-color: #767676;\n}\n\n.progress.success .progress-meter {\n  background-color: #3adb76;\n}\n\n.progress.warning .progress-meter {\n  background-color: #ffae00;\n}\n\n.progress.alert .progress-meter {\n  background-color: #cc4b37;\n}\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #1779ba;\n}\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  position: absolute;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap;\n}\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\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}\n\n.slider-fill.is-dragging {\n  transition: all 0s linear;\n}\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  position: absolute;\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}\n\n[data-whatinput='mouse'] .slider-handle {\n  outline: 0;\n}\n\n.slider-handle:hover {\n  background-color: #14679e;\n}\n\n.slider-handle.is-dragging {\n  transition: all 0s linear;\n}\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\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}\n\n.slider.vertical .slider-fill {\n  top: 0;\n  width: 0.5rem;\n  max-height: 100%;\n}\n\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\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}\n\n.sticky.is-stuck.is-at-top {\n  top: 0;\n}\n\n.sticky.is-stuck.is-at-bottom {\n  bottom: 0;\n}\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto;\n}\n\n.sticky.is-anchored.is-at-bottom {\n  bottom: 0;\n}\n\nbody.is-reveal-open {\n  overflow: hidden;\n}\n\nhtml.is-reveal-open,\nhtml.is-reveal-open body {\n  min-height: 100%;\n  overflow: hidden;\n  user-select: none;\n}\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: scroll;\n}\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}\n\n[data-whatinput='mouse'] .reveal {\n  outline: 0;\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal {\n    min-height: 0;\n  }\n}\n\n.reveal .column, .reveal .columns,\n.reveal .columns {\n  min-width: 0;\n}\n\n.reveal > :last-child {\n  margin-bottom: 0;\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal {\n    width: 600px;\n    max-width: 75rem;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal .reveal {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n.reveal.collapse {\n  padding: 0;\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal.tiny {\n    width: 30%;\n    max-width: 75rem;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal.small {\n    width: 50%;\n    max-width: 75rem;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .reveal.large {\n    width: 90%;\n    max-width: 75rem;\n  }\n}\n\n.reveal.full {\n  top: 0;\n  left: 0;\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  height: 100vh;\n  min-height: 100vh;\n  margin-left: 0;\n  border: 0;\n  border-radius: 0;\n}\n\n@media screen and (max-width: 39.9375em) {\n  .reveal {\n    top: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    height: 100vh;\n    min-height: 100vh;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0;\n  }\n}\n\n.reveal.without-overlay {\n  position: fixed;\n}\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\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0;\n}\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}\n\ninput + .switch-paddle {\n  margin: 0;\n}\n\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}\n\ninput:checked ~ .switch-paddle {\n  background: #1779ba;\n}\n\ninput:checked ~ .switch-paddle::after {\n  left: 2.25rem;\n}\n\n[data-whatinput='mouse'] input:focus ~ .switch-paddle {\n  outline: 0;\n}\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n.switch-active {\n  left: 8%;\n  display: none;\n}\n\ninput:checked + label > .switch-active {\n  display: block;\n}\n\n.switch-inactive {\n  right: 15%;\n}\n\ninput:checked + label > .switch-inactive {\n  display: none;\n}\n\n.switch.tiny {\n  height: 1.5rem;\n}\n\n.switch.tiny .switch-paddle {\n  width: 3rem;\n  height: 1.5rem;\n  font-size: 0.625rem;\n}\n\n.switch.tiny .switch-paddle::after {\n  top: 0.25rem;\n  left: 0.25rem;\n  width: 1rem;\n  height: 1rem;\n}\n\n.switch.tiny input:checked ~ .switch-paddle::after {\n  left: 1.75rem;\n}\n\n.switch.small {\n  height: 1.75rem;\n}\n\n.switch.small .switch-paddle {\n  width: 3.5rem;\n  height: 1.75rem;\n  font-size: 0.75rem;\n}\n\n.switch.small .switch-paddle::after {\n  top: 0.25rem;\n  left: 0.25rem;\n  width: 1.25rem;\n  height: 1.25rem;\n}\n\n.switch.small input:checked ~ .switch-paddle::after {\n  left: 2rem;\n}\n\n.switch.large {\n  height: 2.5rem;\n}\n\n.switch.large .switch-paddle {\n  width: 5rem;\n  height: 2.5rem;\n  font-size: 1rem;\n}\n\n.switch.large .switch-paddle::after {\n  top: 0.25rem;\n  left: 0.25rem;\n  width: 2rem;\n  height: 2rem;\n}\n\n.switch.large input:checked ~ .switch-paddle::after {\n  left: 2.75rem;\n}\n\ntable {\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0;\n}\n\nthead, tbody, tfoot {\n  border: 1px solid #f1f1f1;\n  background-color: #fefefe;\n}\n\ncaption {\n  padding: 0.5rem 0.625rem 0.625rem;\n  font-weight: bold;\n}\n\nthead {\n  background: #f8f8f8;\n  color: #0a0a0a;\n}\n\ntfoot {\n  background: #f1f1f1;\n  color: #0a0a0a;\n}\n\nthead tr, tfoot tr {\n  background: transparent;\n}\n\nthead th, thead td, tfoot th, tfoot td {\n  padding: 0.5rem 0.625rem 0.625rem;\n  font-weight: bold;\n  text-align: left;\n}\n\ntbody th, tbody td {\n  padding: 0.5rem 0.625rem 0.625rem;\n}\n\ntbody tr:nth-child(even) {\n  border-bottom: 0;\n  background-color: #f1f1f1;\n}\n\ntable.unstriped tbody {\n  background-color: #fefefe;\n}\n\ntable.unstriped tbody tr {\n  border-bottom: 0;\n  border-bottom: 1px solid #f1f1f1;\n  background-color: #fefefe;\n}\n\n@media screen and (max-width: 63.9375em) {\n  table.stack thead {\n    display: none;\n  }\n  table.stack tfoot {\n    display: none;\n  }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block;\n  }\n  table.stack td {\n    border-top: 0;\n  }\n}\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3;\n}\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec;\n}\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9;\n}\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec;\n}\n\n.table-scroll {\n  overflow-x: auto;\n}\n\n.table-scroll table {\n  width: auto;\n}\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none;\n}\n\n.tabs::before, .tabs::after {\n  display: table;\n  content: ' ';\n}\n\n.tabs::after {\n  clear: both;\n}\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto;\n}\n\n.tabs.simple > li > a {\n  padding: 0;\n}\n\n.tabs.simple > li > a:hover {\n  background: transparent;\n}\n\n.tabs.primary {\n  background: #1779ba;\n}\n\n.tabs.primary > li > a {\n  color: #fefefe;\n}\n\n.tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n  background: #1673b1;\n}\n\n.tabs-title {\n  float: left;\n}\n\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}\n\n.tabs-title > a:hover {\n  background: #fefefe;\n  color: #1468a0;\n}\n\n.tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n  background: #e6e6e6;\n  color: #1779ba;\n}\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\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-left: 0;\n}\n\n.tabs-panel {\n  display: none;\n  padding: 1rem;\n}\n\n.tabs-panel[aria-hidden=\"false\"] {\n  display: block;\n}\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: solid 4px #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0;\n}\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out;\n}\n\na.thumbnail:hover, a.thumbnail:focus {\n  box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);\n}\n\na.thumbnail image {\n  box-shadow: none;\n}\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe;\n}\n\n.title-bar::before, .title-bar::after {\n  display: table;\n  content: ' ';\n}\n\n.title-bar::after {\n  clear: both;\n}\n\n.title-bar .menu-icon {\n  margin-left: 0.25rem;\n  margin-right: 0.25rem;\n}\n\n.title-bar-left {\n  float: left;\n}\n\n.title-bar-right {\n  float: right;\n  text-align: right;\n}\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold;\n}\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\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}\n\n.tooltip::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  position: absolute;\n  bottom: 100%;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\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}\n\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  top: 50%;\n  bottom: auto;\n  left: 100%;\n  transform: translateY(-50%);\n}\n\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  top: 50%;\n  right: 100%;\n  bottom: auto;\n  left: auto;\n  transform: translateY(-50%);\n}\n\n.top-bar {\n  padding: 0.5rem;\n}\n\n.top-bar::before, .top-bar::after {\n  display: table;\n  content: ' ';\n}\n\n.top-bar::after {\n  clear: both;\n}\n\n.top-bar,\n.top-bar ul {\n  background-color: #e6e6e6;\n}\n\n.top-bar input {\n  max-width: 200px;\n  margin-right: 1rem;\n}\n\n.top-bar .input-group-field {\n  width: 100%;\n  margin-right: 0;\n}\n\n.top-bar input.button {\n  width: auto;\n}\n\n.top-bar .top-bar-left,\n.top-bar .top-bar-right {\n  width: 100%;\n}\n\n@media print, screen and (min-width: 40em) {\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    width: auto;\n  }\n}\n\n@media screen and (max-width: 63.9375em) {\n  .top-bar.stacked-for-medium .top-bar-left,\n  .top-bar.stacked-for-medium .top-bar-right {\n    width: 100%;\n  }\n}\n\n@media screen and (max-width: 74.9375em) {\n  .top-bar.stacked-for-large .top-bar-left,\n  .top-bar.stacked-for-large .top-bar-right {\n    width: 100%;\n  }\n}\n\n.top-bar-title {\n  display: inline-block;\n  float: left;\n  padding: 0.5rem 1rem 0.5rem 0;\n}\n\n.top-bar-title .menu-icon {\n  bottom: 2px;\n}\n\n.top-bar-left {\n  float: left;\n}\n\n.top-bar-right {\n  float: right;\n}\n\n.hide {\n  display: none !important;\n}\n\n.invisible {\n  visibility: hidden;\n}\n\n@media screen and (max-width: 39.9375em) {\n  .hide-for-small-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 39.9375em) {\n  .show-for-medium {\n    display: none !important;\n  }\n}\n\n@media screen and (min-width: 40em) and (max-width: 63.9375em) {\n  .hide-for-medium-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 63.9375em) {\n  .show-for-large {\n    display: none !important;\n  }\n}\n\n@media screen and (min-width: 64em) and (max-width: 74.9375em) {\n  .hide-for-large-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important;\n  }\n}\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n}\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}\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important;\n}\n\n@media screen and (orientation: landscape) {\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n  }\n}\n\n@media screen and (orientation: portrait) {\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: none !important;\n  }\n}\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important;\n}\n\n@media screen and (orientation: landscape) {\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n  }\n}\n\n@media screen and (orientation: portrait) {\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: block !important;\n  }\n}\n\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::before, .clearfix::after {\n  display: table;\n  content: ' ';\n}\n\n.clearfix::after {\n  clear: both;\n}\n\n.off-canvas .is-accordion-submenu {\n  padding-left: 1rem;\n}\n","/**\r\n * Theme Name: _s\r\n * Theme URI: http://underscores.me/\r\n * Author: Automattic\r\n * Author URI: http://automattic.com/\r\n * Description: Hi. I'm a starter theme called <code>_s</code>, or <em>underscores</em>, if you like. I'm a theme meant for hacking so don't use me as a <em>Parent Theme</em>. Instead try turning me into the next, most awesome, WordPress theme out there. That's what I'm here for.\r\n * Version: 1.0.0\r\n * License: GNU General Public License v2 or later\r\n * License URI: http://www.gnu.org/licenses/gpl-2.0.html\r\n * Text Domain: _s\r\n * Tags: custom\r\n *\r\n * This theme, like WordPress, is licensed under the GPL.\r\n *\r\n * Based on Underscores http://underscores.me/, (C) 2012-2017 Automattic, Inc.\r\n *\r\n */\r\n\r\n// Load Foundation.\r\n@import 'foundation/index';\r\n\r\n// Our most basic level file type (variables, typography, etc).\r\n@import 'base/index';\r\n\r\n// Our second level of file types that make up base files (forms, lists, etc).\r\n@import 'components/index';\r\n\r\n// Large parts of our site that make up components (header, footer, etc).\r\n@import 'sections/index';\r\n\r\n// Our largest file types that encompass overall individual page styles.\r\n@import 'pages/index';\r\n\r\n// Third-party file types such as plugins.\r\n@import 'plugins/index';\r\n","/**\n * Foundation for Sites by ZURB\n * Version 6.3.1\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import '../_vendor/normalize-scss/sass/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/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// Sass utilities\n@import 'util/util';\n\n// Global variables and styles\n@import 'global';\n\n// Components\n@import 'grid/grid';\n@import 'typography/typography';\n@import 'forms/forms';\n@import 'components/visibility';\n@import 'components/float';\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/accordion-menu';\n@import 'components/accordion';\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/close-button';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n@import 'components/dropdown';\n@import 'components/flex';\n@import 'components/responsive-embed';\n@import 'components/label';\n@import 'components/media-object';\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/off-canvas';\n@import 'components/orbit';\n@import 'components/pagination';\n@import 'components/progress-bar';\n@import 'components/reveal';\n@import 'components/slider';\n@import 'components/sticky';\n@import 'components/switch';\n@import 'components/table';\n@import 'components/tabs';\n@import 'components/title-bar';\n@import 'components/top-bar';\n@import 'components/thumbnail';\n@import 'components/tooltip';\n\n@mixin foundation-everything($flex: false) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  @include foundation-global-styles;\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @include foundation-flex-grid;\n  }\n  @include foundation-typography;\n  @include foundation-forms;\n  @include foundation-button;\n  @include foundation-accordion;\n  @include foundation-accordion-menu;\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-button-group;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-close-button;\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown;\n  @include foundation-dropdown-menu;\n  @include foundation-responsive-embed;\n  @include foundation-label;\n  @include foundation-media-object;\n  @include foundation-off-canvas;\n  @include foundation-orbit;\n  @include foundation-pagination;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-sticky;\n  @include foundation-reveal;\n  @include foundation-switch;\n  @include foundation-table;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  @include foundation-title-bar;\n  @include foundation-tooltip;\n  @include foundation-top-bar;\n  @include foundation-visibility-classes;\n  @include foundation-float-classes;\n\n  @if $flex {\n    @include foundation-flex-classes;\n  }\n}\n","// Helper function for the normalize() mixin.\n@function _normalize-include($section, $exclude: null) {\n  // Initialize the global variables needed by this function.\n  @if not global_variable_exists(_normalize-include) {\n    $_normalize-include: () !global;\n    $_normalize-exclude: () !global;\n  }\n  // Since we are given 2 parameters, set the global variables.\n  @if $exclude != null {\n    $include: $section;\n    // Sass doesn't have static variables, so the work-around is to stuff these\n    // values into global variables so we can access them in future calls.\n    $_normalize-include: if(type-of($include) == 'list', $include, ($include)) !global;\n    $_normalize-exclude: if(type-of($exclude) == 'list', $exclude, ($exclude)) !global;\n    @return true;\n  }\n\n  // Check if $section is in the $include list.\n  @if index($_normalize-include, $section) {\n    @return true;\n  }\n  // If $include is set to (all), make sure $section is not in $exclude.\n  @else if not index($_normalize-exclude, $section) and index($_normalize-include, all) {\n    @return true;\n  }\n  @return false;\n}\n\n@mixin normalize($include: (all), $exclude: ()) {\n  // Initialize the helper function by passing it this mixin's parameters.\n  $init: _normalize-include($include, $exclude);\n\n  // If we've customized any font variables, we'll need extra properties.\n  @if $base-font-size != 16px\n    or $base-line-height != 24px\n    or $base-unit != 'em'\n    or $h1-font-size != 2    * $base-font-size\n    or $h2-font-size != 1.5  * $base-font-size\n    or $h3-font-size != 1.17 * $base-font-size\n    or $h4-font-size != 1    * $base-font-size\n    or $h5-font-size != 0.83 * $base-font-size\n    or $h6-font-size != 0.67 * $base-font-size {\n    $normalize-vertical-rhythm: true !global;\n  }\n\n  /*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */\n\n  @if _normalize-include(document) {\n    /* Document\n       ========================================================================== */\n\n    /**\n     * 1. Change the default font family in all browsers (opinionated).\n     * 2. Correct the line height in all browsers.\n     * 3. Prevent adjustments of font size after orientation changes in\n     *    IE on Windows Phone and in iOS.\n     */\n\n    html {\n      font-family: $base-font-family; /* 1 */\n      @if $normalize-vertical-rhythm {\n        // Correct old browser bug that prevented accessible resizing of text\n        // when root font-size is set with px or em.\n        font-size: ($base-font-size / 16px) * 100%;\n        line-height: ($base-line-height / $base-font-size) * 1em; /* 2 */\n      }\n      @else {\n        line-height: 1.15; /* 2 */\n      }\n      -ms-text-size-adjust: 100%; /* 3 */\n      -webkit-text-size-adjust: 100%; /* 3 */\n    }\n  }\n\n  @if _normalize-include(sections) {\n    /* Sections\n       ========================================================================== */\n\n    /**\n     * Remove the margin in all browsers (opinionated).\n     */\n\n    body {\n      margin: 0;\n    }\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    article,\n    aside,\n    footer,\n    header,\n    nav,\n    section {\n      display: block;\n    }\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\n    h1 {\n      @include normalize-font-size($h1-font-size);\n      @if $normalize-vertical-rhythm {\n        @include normalize-line-height($h1-font-size);\n      }\n\n      @if $normalize-vertical-rhythm {\n        /* Set 1 unit of vertical rhythm on the top and bottom margins. */\n        @include normalize-margin(1 0, $h1-font-size);\n      }\n      @else {\n        margin: 0.67em 0;\n      }\n    }\n\n    @if $normalize-vertical-rhythm {\n      h2 {\n        @include normalize-font-size($h2-font-size);\n        @include normalize-line-height($h2-font-size);\n        @include normalize-margin(1 0, $h2-font-size);\n      }\n\n      h3 {\n        @include normalize-font-size($h3-font-size);\n        @include normalize-line-height($h3-font-size);\n        @include normalize-margin(1 0, $h3-font-size);\n      }\n\n      h4 {\n        @include normalize-font-size($h4-font-size);\n        @include normalize-line-height($h4-font-size);\n        @include normalize-margin(1 0, $h4-font-size);\n      }\n\n      h5 {\n        @include normalize-font-size($h5-font-size);\n        @include normalize-line-height($h5-font-size);\n        @include normalize-margin(1 0, $h5-font-size);\n      }\n\n      h6 {\n        @include normalize-font-size($h6-font-size);\n        @include normalize-line-height($h6-font-size);\n        @include normalize-margin(1 0, $h6-font-size);\n      }\n    }\n  }\n\n  @if _normalize-include(grouping) {\n    /* Grouping content\n       ========================================================================== */\n\n    @if $normalize-vertical-rhythm {\n      /**\n       * Set 1 unit of vertical rhythm on the top and bottom margin.\n       */\n\n      blockquote {\n        @include normalize-margin(1 $indent-amount);\n      }\n\n      dl,\n      ol,\n      ul {\n        @include normalize-margin(1 0);\n      }\n\n      /**\n       * Turn off margins on nested lists.\n       */\n\n      ol,\n      ul {\n        ol,\n        ul {\n          margin: 0;\n        }\n      }\n\n      dd {\n        margin: 0 0 0 $indent-amount;\n      }\n\n      ol,\n      ul {\n        padding: 0 0 0 $indent-amount;\n      }\n    }\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    figcaption,\n    figure {\n      display: block;\n    }\n\n    /**\n     * Add the correct margin in IE 8.\n     */\n\n    figure {\n      @if $normalize-vertical-rhythm {\n        @include normalize-margin(1 $indent-amount);\n      }\n      @else {\n        margin: 1em $indent-amount;\n      }\n    }\n\n    /**\n     * 1. Add the correct box sizing in Firefox.\n     * 2. Show the overflow in Edge and IE.\n     */\n\n    hr {\n      box-sizing: content-box; /* 1 */\n      height: 0; /* 1 */\n      overflow: visible; /* 2 */\n    }\n\n    /**\n     * Add the correct display in IE.\n     */\n\n    main {\n      display: block;\n    }\n\n    @if $normalize-vertical-rhythm {\n      /**\n       * Set 1 unit of vertical rhythm on the top and bottom margin.\n       */\n\n      p,\n      pre {\n        @include normalize-margin(1 0);\n      }\n    }\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\n    pre {\n      font-family: monospace, monospace; /* 1 */\n      font-size: 1em; /* 2 */\n    }\n  }\n\n  @if _normalize-include(links) {\n    /* Links\n       ========================================================================== */\n\n    /**\n     * 1. Remove the gray background on active links in IE 10.\n     * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n     */\n\n    a {\n      background-color: transparent; /* 1 */\n      -webkit-text-decoration-skip: objects; /* 2 */\n    }\n\n    /**\n     * Remove the outline on focused links when they are also active or hovered\n     * in all browsers (opinionated).\n     */\n\n    a:active,\n    a:hover {\n      outline-width: 0;\n    }\n  }\n\n  @if _normalize-include(text) {\n    /* Text-level semantics\n       ========================================================================== */\n\n    /**\n     * 1. Remove the bottom border in Firefox 39-.\n     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n     */\n\n    abbr[title] {\n      border-bottom: none; /* 1 */\n      text-decoration: underline; /* 2 */\n      text-decoration: underline dotted; /* 2 */\n    }\n\n    /**\n     * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n     */\n\n    b,\n    strong {\n      font-weight: inherit;\n    }\n\n    /**\n     * Add the correct font weight in Chrome, Edge, and Safari.\n     */\n\n    b,\n    strong {\n      font-weight: bolder;\n    }\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\n    code,\n    kbd,\n    samp {\n      font-family: monospace, monospace; /* 1 */\n      font-size: 1em; /* 2 */\n    }\n\n    /**\n     * Add the correct font style in Android 4.3-.\n     */\n\n    dfn {\n      font-style: italic;\n    }\n\n    /**\n     * Add the correct background and color in IE 9-.\n     */\n\n    mark {\n      background-color: #ff0;\n      color: #000;\n    }\n\n    /**\n     * Add the correct font size in all browsers.\n     */\n\n    small {\n      font-size: 80%;\n    }\n\n    /**\n     * Prevent `sub` and `sup` elements from affecting the line height in\n     * all browsers.\n     */\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\n  @if _normalize-include(embedded) {\n    /* Embedded content\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    audio,\n    video {\n      display: inline-block;\n    }\n\n    /**\n     * Add the correct display in iOS 4-7.\n     */\n\n    audio:not([controls]) {\n      display: none;\n      height: 0;\n    }\n\n    /**\n     * Remove the border on images inside links in IE 10-.\n     */\n\n    img {\n      border-style: none;\n    }\n\n    /**\n     * Hide the overflow in IE.\n     */\n\n    svg:not(:root) {\n      overflow: hidden;\n    }\n  }\n\n  @if _normalize-include(forms) {\n    /* Forms\n       ========================================================================== */\n\n    /**\n     * 1. Change the font styles in all browsers (opinionated).\n     * 2. Remove the margin in Firefox and Safari.\n     */\n\n    button,\n    input,\n    optgroup,\n    select,\n    textarea {\n      font-family: $base-font-family; /* 1 */\n      font-size: 100%; /* 1 */\n      @if $normalize-vertical-rhythm {\n        line-height: ($base-line-height / $base-font-size) * 1em; /* 1 */\n      }\n      @else {\n        line-height: 1.15; /* 1 */\n      }\n      margin: 0; /* 2 */\n    }\n\n    /**\n     * Show the overflow in IE.\n     */\n\n    button {\n      overflow: visible;\n    }\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\n    button,\n    select { /* 1 */\n      text-transform: none;\n    }\n\n    /**\n     * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n     *    controls in Android 4.\n     * 2. Correct the inability to style clickable types in iOS and Safari.\n     */\n\n    button,\n    html [type=\"button\"], /* 1 */\n    [type=\"reset\"],\n    [type=\"submit\"] {\n      -webkit-appearance: button; /* 2 */\n    }\n\n    button,\n    [type=\"button\"],\n    [type=\"reset\"],\n    [type=\"submit\"] {\n\n      /**\n       * Remove the inner border and padding in Firefox.\n       */\n\n      &::-moz-focus-inner {\n        border-style: none;\n        padding: 0;\n      }\n\n      /**\n       * Restore the focus styles unset by the previous rule.\n       */\n\n      &:-moz-focusring {\n        outline: 1px dotted ButtonText;\n      }\n    }\n\n    /**\n     * Show the overflow in Edge.\n     */\n\n    input {\n      overflow: visible;\n    }\n\n    /**\n     * 1. Add the correct box sizing in IE 10-.\n     * 2. Remove the padding in IE 10-.\n     */\n\n    [type=\"checkbox\"],\n    [type=\"radio\"] {\n      box-sizing: border-box; /* 1 */\n      padding: 0; /* 2 */\n    }\n\n    /**\n     * Correct the cursor style of increment and decrement buttons in Chrome.\n     */\n\n    [type=\"number\"]::-webkit-inner-spin-button,\n    [type=\"number\"]::-webkit-outer-spin-button {\n      height: auto;\n    }\n\n    /**\n     * 1. Correct the odd appearance in Chrome and Safari.\n     * 2. Correct the outline style in Safari.\n     */\n\n    [type=\"search\"] {\n      -webkit-appearance: textfield; /* 1 */\n      outline-offset: -2px; /* 2 */\n\n      /**\n       * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n       */\n\n      &::-webkit-search-cancel-button,\n      &::-webkit-search-decoration {\n        -webkit-appearance: none;\n      }\n    }\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\n    ::-webkit-file-upload-button {\n      -webkit-appearance: button; /* 1 */\n      font: inherit; /* 2 */\n    }\n\n    /**\n     * Change the border, margin, and padding in all browsers (opinionated).\n     */\n\n    fieldset {\n      border: 1px solid #c0c0c0;\n      margin: 0 2px;\n      padding: 0.35em 0.625em 0.75em;\n    }\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\n    legend {\n      box-sizing: border-box; /* 1 */\n      display: table; /* 1 */\n      max-width: 100%; /* 1 */\n      padding: 0; /* 3 */\n      color: inherit; /* 2 */\n      white-space: normal; /* 1 */\n    }\n\n    /**\n     * 1. Add the correct display in IE 9-.\n     * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n     */\n\n    progress {\n      display: inline-block; /* 1 */\n      vertical-align: baseline; /* 2 */\n    }\n\n    /**\n     * Remove the default vertical scrollbar in IE.\n     */\n\n    textarea {\n      overflow: auto;\n    }\n  }\n\n  @if _normalize-include(interactive) {\n    /* Interactive\n       ========================================================================== */\n\n    /*\n     * Add the correct display in Edge, IE, and Firefox.\n     */\n\n    details {\n      display: block;\n    }\n\n    /*\n     * Add the correct display in all browsers.\n     */\n\n    summary {\n      display: list-item;\n    }\n\n    /*\n     * Add the correct display in IE 9-.\n     */\n\n    menu {\n      display: block;\n\n      @if $normalize-vertical-rhythm {\n        /*\n         * 1. Set 1 unit of vertical rhythm on the top and bottom margin.\n         * 2. Set consistent space for the list style image.\n         */\n\n        @include normalize-margin(1 0); /* 1 */\n        padding: 0 0 0 $indent-amount; /* 2 */\n\n        /**\n         * Turn off margins on nested lists.\n         */\n\n        menu &,\n        ol &,\n        ul & {\n          margin: 0;\n        }\n      }\n    }\n  }\n\n  @if _normalize-include(scripting) {\n    /* Scripting\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    canvas {\n      display: inline-block;\n    }\n\n    /**\n     * Add the correct display in IE.\n     */\n\n    template {\n      display: none;\n    }\n  }\n\n  @if _normalize-include(hidden) {\n    /* Hidden\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 10-.\n     */\n\n    [hidden] {\n      display: none;\n    }\n  }\n}\n","//\n// Variables\n//\n// You can override the default values by setting the variables in your Sass\n// before importing the normalize-scss library.\n\n// The font size set on the root html element.\n$base-font-size: 16px !default;\n\n// The base line height determines the basic unit of vertical rhythm.\n$base-line-height: 24px !default;\n\n// The length unit in which to output vertical rhythm values.\n// Supported values: px, em, rem.\n$base-unit: 'em' !default;\n\n// The default font family.\n$base-font-family: sans-serif !default;\n\n// The font sizes for h1-h6.\n$h1-font-size: 2    * $base-font-size !default;\n$h2-font-size: 1.5  * $base-font-size !default;\n$h3-font-size: 1.17 * $base-font-size !default;\n$h4-font-size: 1    * $base-font-size !default;\n$h5-font-size: 0.83 * $base-font-size !default;\n$h6-font-size: 0.67 * $base-font-size !default;\n\n// The amount lists and blockquotes are indented.\n$indent-amount: 40px !default;\n\n// The following variable controls whether normalize-scss will output\n// font-sizes, line-heights and block-level top/bottom margins that form a basic\n// vertical rhythm on the page, which differs from the original Normalize.css.\n// However, changing any of the variables above will cause\n// $normalize-vertical-rhythm to be automatically set to true.\n$normalize-vertical-rhythm: false !default;\n","//\n// Vertical Rhythm\n//\n// This is the minimal amount of code needed to create vertical rhythm in our\n// CSS. If you are looking for a robust solution, look at the excellent Typey\n// library. @see https://github.com/jptaranto/typey\n\n@function normalize-rhythm($value, $relative-to: $base-font-size, $unit: $base-unit) {\n  @if unit($value) != px {\n    @error \"The normalize vertical-rhythm module only supports px inputs. The typey library is better.\";\n  }\n  @if $unit == rem {\n    @return ($value / $base-font-size) * 1rem;\n  }\n  @else if $unit == em {\n    @return ($value / $relative-to) * 1em;\n  }\n  @else { // $unit == px\n    @return $value;\n  }\n}\n\n@mixin normalize-font-size($value, $relative-to: $base-font-size) {\n  @if unit($value) != 'px' {\n    @error \"normalize-font-size() only supports px inputs. The typey library is better.\";\n  }\n  font-size: normalize-rhythm($value, $relative-to);\n}\n\n@mixin normalize-rhythm($property, $values, $relative-to: $base-font-size) {\n  $value-list: $values;\n  $sep: space;\n  @if type-of($values) == 'list' {\n    $sep: list-separator($values);\n  }\n  @else {\n    $value-list: append((), $values);\n  }\n\n  $normalized-values: ();\n  @each $value in $value-list {\n    @if unitless($value) and $value != 0 {\n      $value: $value * normalize-rhythm($base-line-height, $relative-to);\n    }\n    $normalized-values: append($normalized-values, $value, $sep);\n  }\n  #{$property}: $normalized-values;\n}\n\n@mixin normalize-margin($values, $relative-to: $base-font-size) {\n  @include normalize-rhythm(margin, $values, $relative-to);\n}\n\n@mixin normalize-line-height($font-size, $min-line-padding: 2px) {\n  $lines: ceil($font-size / $base-line-height);\n  // If lines are cramped include some extra leading.\n  @if ($lines * $base-line-height - $font-size) < ($min-line-padding * 2) {\n    $lines: $lines + 1;\n  }\n  @include normalize-rhythm(line-height, $lines, $font-size);\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable force-attribute-nesting, force-pseudo-nesting, no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\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 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/// 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: false !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 variables used for colors\n$primary-color: get-color(primary);\n$secondary-color: get-color(secondary);\n$success-color: get-color(success);\n$warning-color: get-color(warning);\n$alert-color: get-color(alert);\n\n@mixin foundation-global-styles {\n  @include -zf-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;\n      -moz-osx-font-smoothing: grayscale;\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\n    padding: 0;\n\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n\n    line-height: 1;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\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\n/// Loads normalize.css.\n/// @access private\n@mixin -zf-normalize {\n  @include normalize();\n}\n","//--------------------------------------------------------------\r\n// Foundation for Sites Settings\r\n//\r\n// http://foundation.zurb.com/sites/docs/sass.html#the-settings-file\r\n//--------------------------------------------------------------\r\n//\r\n//  Table of Contents:\r\n//\r\n//   1. Global\r\n//   2. Breakpoints\r\n//   3. The Grid\r\n//   4. Base Typography\r\n//   5. Typography Helpers\r\n//   6. Abide\r\n//   7. Accordion\r\n//   8. Accordion Menu\r\n//   9. Badge\r\n//  10. Breadcrumbs\r\n//  11. Button\r\n//  12. Button Group\r\n//  13. Callout\r\n//  14. Card\r\n//  15. Close Button\r\n//  16. Drilldown\r\n//  17. Dropdown\r\n//  18. Dropdown Menu\r\n//  19. Forms\r\n//  20. Label\r\n//  21. Media Object\r\n//  22. Menu\r\n//  23. Meter\r\n//  24. Off-canvas\r\n//  25. Orbit\r\n//  26. Pagination\r\n//  27. Progress Bar\r\n//  28. Responsive Embed\r\n//  29. Reveal\r\n//  30. Slider\r\n//  31. Switch\r\n//  32. Table\r\n//  33. Tabs\r\n//  34. Thumbnail\r\n//  35. Title Bar\r\n//  36. Tooltip\r\n//  37. Top Bar\r\n\r\n// 1. Global\r\n// ---------\r\n\r\n$global-font-size: 100%;\r\n$global-width: rem-calc(1200);\r\n$global-lineheight: 1.5;\r\n$foundation-palette: (\r\n  primary: #1779ba,\r\n  secondary: #767676,\r\n  success: #3adb76,\r\n  warning: #ffae00,\r\n  alert: #cc4b37,\r\n);\r\n$light-gray: #e6e6e6;\r\n$medium-gray: #cacaca;\r\n$dark-gray: #8a8a8a;\r\n$black: #0a0a0a;\r\n$white: #fefefe;\r\n$body-background: $white;\r\n$body-font-color: $black;\r\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;\r\n$body-antialiased: true;\r\n$global-margin: 1rem;\r\n$global-padding: 1rem;\r\n$global-weight-normal: normal;\r\n$global-weight-bold: bold;\r\n$global-radius: 0;\r\n$global-text-direction: ltr;\r\n$global-flexbox: false;\r\n$print-transparent-backgrounds: true;\r\n\r\n@include add-foundation-colors;\r\n\r\n// 2. Breakpoints\r\n// --------------\r\n\r\n$breakpoints: (\r\n  small: 0,\r\n  medium: 640px,\r\n  large: 1024px,\r\n  xlarge: 1200px,\r\n  xxlarge: 1440px,\r\n);\r\n$print-breakpoint: large;\r\n$breakpoint-classes: (small medium large);\r\n\r\n// 3. The Grid\r\n// -----------\r\n\r\n$grid-row-width: $global-width;\r\n$grid-column-count: 12;\r\n$grid-column-gutter: (\r\n  small: 20px,\r\n  medium: 30px,\r\n);\r\n$grid-column-align-edge: true;\r\n$block-grid-max: 8;\r\n\r\n// 4. Base Typography\r\n// ------------------\r\n\r\n$header-font-family: $body-font-family;\r\n$header-font-weight: $global-weight-normal;\r\n$header-font-style: normal;\r\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace;\r\n$header-color: inherit;\r\n$header-lineheight: 1.4;\r\n$header-margin-bottom: 0.5rem;\r\n$header-styles: (\r\n  small: (\r\n    'h1': ('font-size': 24),\r\n    'h2': ('font-size': 20),\r\n    'h3': ('font-size': 19),\r\n    'h4': ('font-size': 18),\r\n    'h5': ('font-size': 17),\r\n    'h6': ('font-size': 16),\r\n  ),\r\n  medium: (\r\n    'h1': ('font-size': 48),\r\n    'h2': ('font-size': 40),\r\n    'h3': ('font-size': 31),\r\n    'h4': ('font-size': 25),\r\n    'h5': ('font-size': 20),\r\n    'h6': ('font-size': 16),\r\n  ),\r\n);\r\n$header-text-rendering: optimizeLegibility;\r\n$small-font-size: 80%;\r\n$header-small-font-color: $medium-gray;\r\n$paragraph-lineheight: 1.6;\r\n$paragraph-margin-bottom: 1rem;\r\n$paragraph-text-rendering: optimizeLegibility;\r\n$code-color: $black;\r\n$code-font-family: $font-family-monospace;\r\n$code-font-weight: $global-weight-normal;\r\n$code-background: $light-gray;\r\n$code-border: 1px solid $medium-gray;\r\n$code-padding: rem-calc(2 5 1);\r\n$anchor-color: $primary-color;\r\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%);\r\n$anchor-text-decoration: none;\r\n$anchor-text-decoration-hover: none;\r\n$hr-width: $global-width;\r\n$hr-border: 1px solid $medium-gray;\r\n$hr-margin: rem-calc(20) auto;\r\n$list-lineheight: $paragraph-lineheight;\r\n$list-margin-bottom: $paragraph-margin-bottom;\r\n$list-style-type: disc;\r\n$list-style-position: outside;\r\n$list-side-margin: 1.25rem;\r\n$list-nested-side-margin: 1.25rem;\r\n$defnlist-margin-bottom: 1rem;\r\n$defnlist-term-weight: $global-weight-bold;\r\n$defnlist-term-margin-bottom: 0.3rem;\r\n$blockquote-color: $dark-gray;\r\n$blockquote-padding: rem-calc(9 20 0 19);\r\n$blockquote-border: 1px solid $medium-gray;\r\n$cite-font-size: rem-calc(13);\r\n$cite-color: $dark-gray;\r\n$cite-pseudo-content: '\\2014 \\0020';\r\n$keystroke-font: $font-family-monospace;\r\n$keystroke-color: $black;\r\n$keystroke-background: $light-gray;\r\n$keystroke-padding: rem-calc(2 4 0);\r\n$keystroke-radius: $global-radius;\r\n$abbr-underline: 1px dotted $black;\r\n\r\n// 5. Typography Helpers\r\n// ---------------------\r\n\r\n$lead-font-size: $global-font-size * 1.25;\r\n$lead-lineheight: 1.6;\r\n$subheader-lineheight: 1.4;\r\n$subheader-color: $dark-gray;\r\n$subheader-font-weight: $global-weight-normal;\r\n$subheader-margin-top: 0.2rem;\r\n$subheader-margin-bottom: 0.5rem;\r\n$stat-font-size: 2.5rem;\r\n\r\n// 6. Abide\r\n// --------\r\n\r\n$abide-inputs: true;\r\n$abide-labels: true;\r\n$input-background-invalid: get-color(alert);\r\n$form-label-color-invalid: get-color(alert);\r\n$input-error-color: get-color(alert);\r\n$input-error-font-size: rem-calc(12);\r\n$input-error-font-weight: $global-weight-bold;\r\n\r\n// 7. Accordion\r\n// ------------\r\n\r\n$accordion-background: $white;\r\n$accordion-plusminus: true;\r\n$accordion-title-font-size: rem-calc(12);\r\n$accordion-item-color: $primary-color;\r\n$accordion-item-background-hover: $light-gray;\r\n$accordion-item-padding: 1.25rem 1rem;\r\n$accordion-content-background: $white;\r\n$accordion-content-border: 1px solid $light-gray;\r\n$accordion-content-color: $body-font-color;\r\n$accordion-content-padding: 1rem;\r\n\r\n// 8. Accordion Menu\r\n// -----------------\r\n\r\n$accordionmenu-arrows: true;\r\n$accordionmenu-arrow-color: $primary-color;\r\n$accordionmenu-arrow-size: 6px;\r\n\r\n// 9. Badge\r\n// --------\r\n\r\n$badge-background: $primary-color;\r\n$badge-color: $white;\r\n$badge-color-alt: $black;\r\n$badge-palette: $foundation-palette;\r\n$badge-padding: 0.3em;\r\n$badge-minwidth: 2.1em;\r\n$badge-font-size: 0.6rem;\r\n\r\n// 10. Breadcrumbs\r\n// ---------------\r\n\r\n$breadcrumbs-margin: 0 0 $global-margin 0;\r\n$breadcrumbs-item-font-size: rem-calc(11);\r\n$breadcrumbs-item-color: $primary-color;\r\n$breadcrumbs-item-color-current: $black;\r\n$breadcrumbs-item-color-disabled: $medium-gray;\r\n$breadcrumbs-item-margin: 0.75rem;\r\n$breadcrumbs-item-uppercase: true;\r\n$breadcrumbs-item-slash: true;\r\n\r\n// 11. Button\r\n// ----------\r\n\r\n$button-padding: 0.85em 1em;\r\n$button-margin: 0 0 $global-margin 0;\r\n$button-fill: solid;\r\n$button-background: $primary-color;\r\n$button-background-hover: scale-color($button-background, $lightness: -15%);\r\n$button-color: $white;\r\n$button-color-alt: $black;\r\n$button-radius: $global-radius;\r\n$button-sizes: (\r\n  tiny: 0.6rem,\r\n  small: 0.75rem,\r\n  default: 0.9rem,\r\n  large: 1.25rem,\r\n);\r\n$button-palette: $foundation-palette;\r\n$button-opacity-disabled: 0.25;\r\n$button-background-hover-lightness: -20%;\r\n$button-hollow-hover-lightness: -50%;\r\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out;\r\n\r\n// 12. Button Group\r\n// ----------------\r\n\r\n$buttongroup-margin: 1rem;\r\n$buttongroup-spacing: 1px;\r\n$buttongroup-child-selector: '.button';\r\n$buttongroup-expand-max: 6;\r\n$buttongroup-radius-on-each: true;\r\n\r\n// 13. Callout\r\n// -----------\r\n\r\n$callout-background: $white;\r\n$callout-background-fade: 85%;\r\n$callout-border: 1px solid rgba($black, 0.25);\r\n$callout-margin: 0 0 1rem 0;\r\n$callout-padding: 1rem;\r\n$callout-font-color: $body-font-color;\r\n$callout-font-color-alt: $body-background;\r\n$callout-radius: $global-radius;\r\n$callout-link-tint: 30%;\r\n\r\n// 14. Card\r\n// --------\r\n\r\n$card-background: $white;\r\n$card-font-color: $body-font-color;\r\n$card-divider-background: $light-gray;\r\n$card-border: 1px solid $light-gray;\r\n$card-shadow: none;\r\n$card-border-radius: $global-radius;\r\n$card-padding: $global-padding;\r\n$card-margin: $global-margin;\r\n\r\n// 15. Close Button\r\n// ----------------\r\n\r\n$closebutton-position: right top;\r\n$closebutton-offset-horizontal: (\r\n  small: 0.66rem,\r\n  medium: 1rem,\r\n);\r\n$closebutton-offset-vertical: (\r\n  small: 0.33em,\r\n  medium: 0.5rem,\r\n);\r\n$closebutton-size: (\r\n  small: 1.5em,\r\n  medium: 2em,\r\n);\r\n$closebutton-lineheight: 1;\r\n$closebutton-color: $dark-gray;\r\n$closebutton-color-hover: $black;\r\n\r\n// 16. Drilldown\r\n// -------------\r\n\r\n$drilldown-transition: transform 0.15s linear;\r\n$drilldown-arrows: true;\r\n$drilldown-arrow-color: $primary-color;\r\n$drilldown-arrow-size: 6px;\r\n$drilldown-background: $white;\r\n\r\n// 17. Dropdown\r\n// ------------\r\n\r\n$dropdown-padding: 1rem;\r\n$dropdown-background: $body-background;\r\n$dropdown-border: 1px solid $medium-gray;\r\n$dropdown-font-size: 1rem;\r\n$dropdown-width: 300px;\r\n$dropdown-radius: $global-radius;\r\n$dropdown-sizes: (\r\n  tiny: 100px,\r\n  small: 200px,\r\n  large: 400px,\r\n);\r\n\r\n// 18. Dropdown Menu\r\n// -----------------\r\n\r\n$dropdownmenu-arrows: true;\r\n$dropdownmenu-arrow-color: $anchor-color;\r\n$dropdownmenu-arrow-size: 6px;\r\n$dropdownmenu-min-width: 200px;\r\n$dropdownmenu-background: $white;\r\n$dropdownmenu-border: 1px solid $medium-gray;\r\n\r\n// 19. Forms\r\n// ---------\r\n\r\n$fieldset-border: 1px solid $medium-gray;\r\n$fieldset-padding: rem-calc(20);\r\n$fieldset-margin: rem-calc(18 0);\r\n$legend-padding: rem-calc(0 3);\r\n$form-spacing: rem-calc(16);\r\n$helptext-color: $black;\r\n$helptext-font-size: rem-calc(13);\r\n$helptext-font-style: italic;\r\n$input-prefix-color: $black;\r\n$input-prefix-background: $light-gray;\r\n$input-prefix-border: 1px solid $medium-gray;\r\n$input-prefix-padding: 1rem;\r\n$form-label-color: $black;\r\n$form-label-font-size: rem-calc(14);\r\n$form-label-font-weight: $global-weight-normal;\r\n$form-label-line-height: 1.8;\r\n$select-background: $white;\r\n$select-triangle-color: $dark-gray;\r\n$select-radius: $global-radius;\r\n$input-color: $black;\r\n$input-placeholder-color: $medium-gray;\r\n$input-font-family: inherit;\r\n$input-font-size: rem-calc(16);\r\n$input-font-weight: $global-weight-normal;\r\n$input-background: $white;\r\n$input-background-focus: $white;\r\n$input-background-disabled: $light-gray;\r\n$input-border: 1px solid $medium-gray;\r\n$input-border-focus: 1px solid $dark-gray;\r\n$input-shadow: inset 0 1px 2px rgba($black, 0.1);\r\n$input-shadow-focus: 0 0 5px $medium-gray;\r\n$input-cursor-disabled: not-allowed;\r\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\r\n$input-number-spinners: true;\r\n$input-radius: $global-radius;\r\n$form-button-radius: $global-radius;\r\n\r\n// 20. Label\r\n// ---------\r\n\r\n$label-background: $primary-color;\r\n$label-color: $white;\r\n$label-color-alt: $black;\r\n$label-palette: $foundation-palette;\r\n$label-font-size: 0.8rem;\r\n$label-padding: 0.33333rem 0.5rem;\r\n$label-radius: $global-radius;\r\n\r\n// 21. Media Object\r\n// ----------------\r\n\r\n$mediaobject-margin-bottom: $global-margin;\r\n$mediaobject-section-padding: $global-padding;\r\n$mediaobject-image-width-stacked: 100%;\r\n\r\n// 22. Menu\r\n// --------\r\n\r\n$menu-margin: 0;\r\n$menu-margin-nested: 1rem;\r\n$menu-item-padding: 0.7rem 1rem;\r\n$menu-item-color-active: $white;\r\n$menu-item-background-active: get-color(primary);\r\n$menu-icon-spacing: 0.25rem;\r\n$menu-item-background-hover: $light-gray;\r\n$menu-border: $light-gray;\r\n\r\n// 23. Meter\r\n// ---------\r\n\r\n$meter-height: 1rem;\r\n$meter-radius: $global-radius;\r\n$meter-background: $medium-gray;\r\n$meter-fill-good: $success-color;\r\n$meter-fill-medium: $warning-color;\r\n$meter-fill-bad: $alert-color;\r\n\r\n// 24. Off-canvas\r\n// --------------\r\n\r\n$offcanvas-size: 250px;\r\n$offcanvas-vertical-size: 250px;\r\n$offcanvas-background: $light-gray;\r\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7);\r\n$offcanvas-push-zindex: 1;\r\n$offcanvas-overlap-zindex: 10;\r\n$offcanvas-reveal-zindex: 1;\r\n$offcanvas-transition-length: 0.5s;\r\n$offcanvas-transition-timing: ease;\r\n$offcanvas-fixed-reveal: true;\r\n$offcanvas-exit-background: rgba($white, 0.25);\r\n$maincontent-class: 'off-canvas-content';\r\n\r\n// 25. Orbit\r\n// ---------\r\n\r\n$orbit-bullet-background: $medium-gray;\r\n$orbit-bullet-background-active: $dark-gray;\r\n$orbit-bullet-diameter: 1.2rem;\r\n$orbit-bullet-margin: 0.1rem;\r\n$orbit-bullet-margin-top: 0.8rem;\r\n$orbit-bullet-margin-bottom: 0.8rem;\r\n$orbit-caption-background: rgba($black, 0.5);\r\n$orbit-caption-padding: 1rem;\r\n$orbit-control-background-hover: rgba($black, 0.5);\r\n$orbit-control-padding: 1rem;\r\n$orbit-control-zindex: 10;\r\n\r\n// 26. Pagination\r\n// --------------\r\n\r\n$pagination-font-size: rem-calc(14);\r\n$pagination-margin-bottom: $global-margin;\r\n$pagination-item-color: $black;\r\n$pagination-item-padding: rem-calc(3 10);\r\n$pagination-item-spacing: rem-calc(1);\r\n$pagination-radius: $global-radius;\r\n$pagination-item-background-hover: $light-gray;\r\n$pagination-item-background-current: $primary-color;\r\n$pagination-item-color-current: $white;\r\n$pagination-item-color-disabled: $medium-gray;\r\n$pagination-ellipsis-color: $black;\r\n$pagination-mobile-items: false;\r\n$pagination-mobile-current-item: false;\r\n$pagination-arrows: true;\r\n\r\n// 27. Progress Bar\r\n// ----------------\r\n\r\n$progress-height: 1rem;\r\n$progress-background: $medium-gray;\r\n$progress-margin-bottom: $global-margin;\r\n$progress-meter-background: $primary-color;\r\n$progress-radius: $global-radius;\r\n\r\n// 28. Responsive Embed\r\n// --------------------\r\n\r\n$responsive-embed-margin-bottom: rem-calc(16);\r\n$responsive-embed-ratios: (\r\n  default: 4 by 3,\r\n  widescreen: 16 by 9,\r\n);\r\n\r\n// 29. Reveal\r\n// ----------\r\n\r\n$reveal-background: $white;\r\n$reveal-width: 600px;\r\n$reveal-max-width: $global-width;\r\n$reveal-padding: $global-padding;\r\n$reveal-border: 1px solid $medium-gray;\r\n$reveal-radius: $global-radius;\r\n$reveal-zindex: 1005;\r\n$reveal-overlay-background: rgba($black, 0.45);\r\n\r\n// 30. Slider\r\n// ----------\r\n\r\n$slider-width-vertical: 0.5rem;\r\n$slider-transition: all 0.2s ease-in-out;\r\n$slider-height: 0.5rem;\r\n$slider-background: $light-gray;\r\n$slider-fill-background: $medium-gray;\r\n$slider-handle-height: 1.4rem;\r\n$slider-handle-width: 1.4rem;\r\n$slider-handle-background: $primary-color;\r\n$slider-opacity-disabled: 0.25;\r\n$slider-radius: $global-radius;\r\n\r\n// 31. Switch\r\n// ----------\r\n\r\n$switch-background: $medium-gray;\r\n$switch-background-active: $primary-color;\r\n$switch-height: 2rem;\r\n$switch-height-tiny: 1.5rem;\r\n$switch-height-small: 1.75rem;\r\n$switch-height-large: 2.5rem;\r\n$switch-radius: $global-radius;\r\n$switch-margin: $global-margin;\r\n$switch-paddle-background: $white;\r\n$switch-paddle-offset: 0.25rem;\r\n$switch-paddle-radius: $global-radius;\r\n$switch-paddle-transition: all 0.25s ease-out;\r\n\r\n// 32. Table\r\n// ---------\r\n\r\n$table-background: $white;\r\n$table-color-scale: 5%;\r\n$table-border: 1px solid smart-scale($table-background, $table-color-scale);\r\n$table-padding: rem-calc(8 10 10);\r\n$table-hover-scale: 2%;\r\n$table-row-hover: darken($table-background, $table-hover-scale);\r\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale);\r\n$table-is-striped: true;\r\n$table-striped-background: smart-scale($table-background, $table-color-scale);\r\n$table-stripe: even;\r\n$table-head-background: smart-scale($table-background, $table-color-scale / 2);\r\n$table-head-row-hover: darken($table-head-background, $table-hover-scale);\r\n$table-foot-background: smart-scale($table-background, $table-color-scale);\r\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale);\r\n$table-head-font-color: $body-font-color;\r\n$table-foot-font-color: $body-font-color;\r\n$show-header-for-stacked: false;\r\n\r\n// 33. Tabs\r\n// --------\r\n\r\n$tab-margin: 0;\r\n$tab-background: $white;\r\n$tab-color: $primary-color;\r\n$tab-background-active: $light-gray;\r\n$tab-active-color: $primary-color;\r\n$tab-item-font-size: rem-calc(12);\r\n$tab-item-background-hover: $white;\r\n$tab-item-padding: 1.25rem 1.5rem;\r\n$tab-expand-max: 6;\r\n$tab-content-background: $white;\r\n$tab-content-border: $light-gray;\r\n$tab-content-color: $body-font-color;\r\n$tab-content-padding: 1rem;\r\n\r\n// 34. Thumbnail\r\n// -------------\r\n\r\n$thumbnail-border: solid 4px $white;\r\n$thumbnail-margin-bottom: $global-margin;\r\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2);\r\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5);\r\n$thumbnail-transition: box-shadow 200ms ease-out;\r\n$thumbnail-radius: $global-radius;\r\n\r\n// 35. Title Bar\r\n// -------------\r\n\r\n$titlebar-background: $black;\r\n$titlebar-color: $white;\r\n$titlebar-padding: 0.5rem;\r\n$titlebar-text-font-weight: bold;\r\n$titlebar-icon-color: $white;\r\n$titlebar-icon-color-hover: $medium-gray;\r\n$titlebar-icon-spacing: 0.25rem;\r\n\r\n// 36. Tooltip\r\n// -----------\r\n\r\n$has-tip-font-weight: $global-weight-bold;\r\n$has-tip-border-bottom: dotted 1px $dark-gray;\r\n$tooltip-background-color: $black;\r\n$tooltip-color: $white;\r\n$tooltip-padding: 0.75rem;\r\n$tooltip-font-size: $small-font-size;\r\n$tooltip-pip-width: 0.75rem;\r\n$tooltip-pip-height: $tooltip-pip-width * 0.866;\r\n$tooltip-radius: $global-radius;\r\n\r\n// 37. Top Bar\r\n// -----------\r\n\r\n$topbar-padding: 0.5rem;\r\n$topbar-background: $light-gray;\r\n$topbar-submenu-background: $topbar-background;\r\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0;\r\n$topbar-input-width: 200px;\r\n$topbar-unstack-breakpoint: medium;\r\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 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@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 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}\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@mixin -zf-each-breakpoint($small: 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    $-zf-size: $name !global;\n\n    @include breakpoint($name) {\n      @content;\n    }\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|Keyword} $name [auto] - Single value or breakpoint name 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 flex-grid\n////\n\n/// Creates a container for a flex grid row.\n///\n/// @param {Keyword|List} $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 {Number} $columns [null] - Number of columns to use for this row. If set to `null` (the default), the global column count will be used.\n/// @param {Boolean} $base [true] - Set to `false` to prevent basic styles from being output. Useful if you're calling this mixin on the same element twice, as it prevents duplicate CSS output.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use when inverting margins, in case the row is nested. Responsive gutter settings by default.\n@mixin flex-grid-row(\n  $behavior: null,\n  $size: $grid-row-width,\n  $columns: null,\n  $base: true,\n  $wrap: true,\n  $gutters: $grid-column-gutter\n) {\n  $margin: auto;\n  $wrap: if($wrap, wrap, nowrap);\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 $base {\n    display: flex;\n    flex-flow: row $wrap;\n  }\n\n  @if $columns != null {\n    @include grid-context($columns, $base) {\n      @content;\n    }\n  }\n}\n\n/// Calculates the `flex` property for a flex grid column. It accepts all of the same values as the basic `grid-column()` function, along with two extras:\n///   - `expand` (the default) will make the column expand to fill space.\n///   - `shrink` will make the column contract, so it only takes up the horizontal space it needs.\n///\n/// @param {Mixed} $columns [expand] - Width of the column.\n@function flex-grid-column($columns: expand) {\n  $flex: 1 1 0px; // sass-lint:disable-line zero-unit\n\n  @if $columns == shrink {\n    $flex: 0 0 auto;\n  }\n  @else if $columns != expand {\n    $flex: 0 0 grid-column($columns);\n  }\n\n  @return $flex;\n}\n\n/// Creates a column for a flex grid. By default, the column will stretch to the full width of its container, but this can be overridden with sizing classes, or by using the `unstack` class on the parent flex row.\n///\n/// @param {Mixed} $columns [expand] - Width of the column. Refer to the `flex-grid-column()` function to see possible values.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Map or single value for gutters width. See the `grid-column-gutter` mixin.\n@mixin flex-grid-column(\n  $columns: expand,\n  $gutters: $grid-column-gutter\n) {\n  // Base properties\n  @include flex-grid-size($columns);\n\n  // Gutters\n  @include grid-column-gutter($gutters: $gutters);\n\n  // fixes recent Chrome version not limiting child width\n  // https://stackoverflow.com/questions/34934586/white-space-nowrap-and-flexbox-did-not-work-in-chrome\n  @if $columns == expand {\n    min-width: initial;\n  }\n  // max-width fixes IE 10/11 not respecting the flex-basis property\n  @if $columns != expand and $columns != shrink {\n    max-width: grid-column($columns);\n  }\n}\n\n/// Creates a block grid for a flex grid row.\n///\n/// @param {Number} $n - Number of columns to display on each row.\n/// @param {String} $selector - Selector to use to target columns within the row.\n@mixin flex-grid-layout(\n  $n,\n  $selector: '.column'\n) {\n  flex-wrap: wrap;\n\n  > #{$selector} {\n    $pct: percentage(1/$n);\n\n    flex: 0 0 $pct;\n    max-width: $pct;\n  }\n}\n\n/// Changes the width flex grid column.\n/// @param {Mixed} $columns [expand] - Width of the column. Refer to the `flex-grid-column()` function to see possible values.\n@mixin flex-grid-size($columns: null) {\n  $columns: $columns or expand;\n\n  flex: flex-grid-column($columns);\n\n  // max-width fixes IE 10/11 not respecting the flex-basis property\n  @if $columns != expand and $columns != shrink {\n    max-width: grid-column($columns);\n  }\n}\n\n\n@mixin foundation-flex-grid {\n  // Row\n  .row {\n    @include flex-grid-row;\n\n    // Nesting behavior\n    & .row {\n      @include flex-grid-row(nest, $base: false);\n\n      &.collapse {\n        margin-right: 0;\n        margin-left: 0;\n      }\n    }\n\n    // Expanded row\n    &.expanded {\n      @include grid-row-size(expand);\n    }\n\n    &:not(.expanded) .row {\n      @include grid-row-size(expand);\n    }\n\n    &.collapse {\n      > .column {\n        @include grid-col-collapse;\n      }\n    }\n\n    // Undo negative margins\n    // From collapsed child\n    &.is-collapse-child,\n    &.collapse > .column > .row {\n      margin-right: 0;\n      margin-left: 0;\n    }\n  }\n\n  // Column\n  .column {\n    @include flex-grid-column;\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    display: block;\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\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  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-column-count {\n      // Sizing (percentage)\n      .#{$-zf-size}-#{$i} {\n        flex: flex-grid-column($i);\n        max-width: grid-column($i);\n      }\n\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include grid-column-offset($o);\n      }\n    }\n\n    // Source ordering\n    @for $i from 1 through 6 {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n\n    // Block grid\n    @for $i from 1 through $block-grid-max {\n      .#{$-zf-size}-up-#{$i} {\n        @include flex-grid-layout($i);\n      }\n    }\n\n    @if $-zf-size != $-zf-zero-breakpoint {\n      // Sizing (expand)\n      @include breakpoint($-zf-size) {\n        .#{$-zf-size}-expand {\n          flex: flex-grid-column();\n        }\n      }\n\n      // direction helper classes\n      @each $dir, $prop in $-zf-flex-direction {\n        .#{$-zf-size}-flex-dir-#{$dir} {\n          @include flex-direction($prop);\n        }\n      }\n      // child helper classes\n      .#{$-zf-size}-flex-child-auto {\n        flex: 1 1 auto;\n      }\n\n      .#{$-zf-size}-flex-child-grow {\n        flex: 1 0 auto;\n      }\n\n      .#{$-zf-size}-flex-child-shrink {\n        flex: 0 1 auto;\n      }\n\n      // Auto-stacking/unstacking\n      @at-root (without: media) {\n        .row.#{$-zf-size}-unstack {\n          > .column {\n            flex: flex-grid-column(100%);\n\n            @include breakpoint($-zf-size) {\n              flex: flex-grid-column();\n            }\n          }\n        }\n      }\n    }\n\n    // Responsive collapsing\n    .#{$-zf-size}-collapse {\n      > .column { @include grid-col-collapse; }\n    }\n\n    .#{$-zf-size}-uncollapse {\n      > .column { @include grid-col-gutter($-zf-size); }\n    }\n  }\n\n  // Sizing (shrink)\n  .shrink {\n    flex: flex-grid-column(shrink);\n    max-width: 100%;\n  }\n\n  // Block grid columns\n  .column-block {\n    @include grid-column-margin;\n  }\n\n  .columns {\n    @extend .column; // sass-lint:disable-line placeholder-in-extend\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 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 `$base-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 lets 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 greatern then 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 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/// Un-collapse the gutters on a column by re-adding the padding.\n///\n/// @param {Number} $gutter [$grid-column-gutter] - Spacing between columns.\n@mixin grid-column-uncollapse($gutter: $grid-column-gutter) {\n  @warn 'This mixin is being replaced by grid-column-gutter(). grid-column-uncollapse() will be removed in Foundation 6.4.';\n  @include grid-column-gutter($gutters: $gutter);\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/// Shorthand for `grid-column-uncollapse()`.\n/// @alias grid-column-uncollapse\n@mixin grid-col-uncollapse($gutter: $grid-column-gutter) {\n  @warn 'This mixin is being replaced by grid-col-gutter(). grid-col-uncollapse() will be removed in Foundation 6.4.';\n  @include grid-column-uncollapse($gutter);\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","$-zf-flex-justify: (\n  'left': flex-start,\n  'right': flex-end,\n  'center': center,\n  'justify': space-between,\n  'spaced': space-around,\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////\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  // Last column alignment\n  @if $grid-column-align-edge {\n    &:last-child:not(:first-child) {\n      float: $global-right;\n    }\n  }\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 - Direction and amount to move. The column will move equal to the width of the column count specified. A positive number will push the column to the right, while a negative number will pull it to the left. Set to center to center the column.\n@mixin grid-column-position($position) {\n  @if type-of($position) == 'number' {\n    $offset: percentage($position / $grid-column-count);\n\n    position: relative;\n    #{$global-left}: $offset;\n  }\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  @else {\n    @warn 'Wrong syntax for grid-column-position(). Enter a positive or negative number, or center.';\n  }\n}\n\n/// Reset a position definition.\n@mixin grid-column-unposition {\n  position: static;\n  float: left;\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","@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in map-remove($-zf-flex-justify, left) {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\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  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through 6 {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\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 deocration 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,\n  h2,\n  h3,\n  h4,\n  h5,\n  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} {\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 {\n    border-bottom: $abbr-underline;\n    color: $body-font-color;\n    cursor: help;\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 subhheaders.\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  // Use to remove the bullets from an unordered list\n  .no-bullet {\n    margin-#{$global-left}: 0;\n    list-style: none;\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$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}\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/// 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/// 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 + ($form-spacing * 1.5) - 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: $form-spacing / 2;\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  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    // Placeholder text\n    &::placeholder {\n      color: $input-placeholder-color;\n    }\n\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-prefix\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefix\n        margin: 0;\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@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 + $form-spacing * 1.5);\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      border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n    }\n\n    > :last-child {\n      > * {\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      height: auto;\n      min-width: 0;\n    }\n    @else {\n      height: $height;\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      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      height: $height;\n      padding-top: 0;\n      padding-bottom: 0;\n\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 .input-group-button {\n          display: table-cell;\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    background: $body-background;\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 + ($form-spacing * 1.5) - rem-calc(1));\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2);\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  line-height: normal;\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    &::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 button\n////\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/// 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// 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  padding: $button-padding;\n\n  -webkit-appearance: none;\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n\n  font-size: map-get($button-sizes, default);\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, &:focus {\n    background-color: transparent;\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $primary-color,\n  $hover-lightness: $button-hollow-hover-lightness\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: 1px solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\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 [$primary-color] - 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: $primary-color,\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}: get-side($button-padding, right);\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    // 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    // 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    // 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    // 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\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","// 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\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","////\n/// @group accordion-menu\n////\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 arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin foundation-accordion-menu {\n  @if $accordionmenu-arrows {\n    .is-accordion-submenu-parent > 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    .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n      transform: rotate(180deg);\n      transform-origin: 50% 50%;\n    }\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 slash between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-slash: true !default;\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-slash {\n      // Need to escape the backslash\n      $slash: if($global-text-direction == 'ltr', '/', '\\\\');\n\n      &:not(:last-child)::after {\n        position: relative;\n        top: 1px;\n        margin: 0 $breadcrumbs-item-margin;\n\n        opacity: 1;\n        content: $slash;\n        color: $medium-gray;\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 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 Border\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.\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@mixin button-group(\n  $child-selector: $buttongroup-child-selector\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}: $buttongroup-spacing;\n    margin-bottom: $buttongroup-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: $global-radius;\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      }\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@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$buttongroup-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:last-child {\n        width: 100%\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)} - #{$buttongroup-spacing});\n            margin-#{$global-right}: $buttongroup-spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $buttongroup-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: 1 1 0px; // sass-lint:disable-line zero-unit\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 { @include button-group-expand; }\n\n    // Colors\n    @each $name, $color in $foundation-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\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 { // sass-lint:disable-line force-element-nesting\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}\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/// Defualt 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: $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,\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  }\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: $card-font-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    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","// 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 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-margin-nested: 1rem !default;\n\n/// Padding for items in a menu.\n/// @type Number\n$menu-item-padding: 0.7rem 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/// Background color for an hovered menu item.\n/// @type Color\n$menu-item-background-hover: $light-gray !default;\n\n/// Color for bordered menu\n/// @type Color\n$menu-border: $light-gray !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  margin: $menu-margin;\n  list-style-type: none;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: center;\n    width: 100%;\n  }\n\n  // List items are table cell to allow for vertical alignment\n  > li {\n    @include disable-mouse-outline;\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  // Reset line height to make the height of the overall item easier to calculate\n  > li > a {\n    display: block;\n    padding: $menu-item-padding;\n    line-height: 1;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\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    table-layout: fixed;\n  }\n\n  > li:first-child:last-child {\n    width: 100%;\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: nowrap;\n\n      > li {\n        flex: 0 0 auto;\n      }\n    }\n    @else {\n      > li {\n        display: table-cell;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n\n      > li {\n        flex: 0 0 100%;\n        max-width: 100%;\n      }\n\n      > li  > a {\n        justify-content: flex-start;\n        align-items: flex-start;\n      }\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. Set to `null` to do not generate styles for direction.\n@mixin menu-simple($dir: $global-left) {\n  li {\n    display: inline-block;\n    vertical-align: top;\n    line-height: 1;\n  }\n\n  a {\n    padding: 0;\n  }\n\n  @if $dir != null {\n    @include menu-simple-direction($dir);\n  }\n}\n\n/// Direction modifier for a simple Menu\n/// @param {Keyword} $dir [$global-left] - Direction of the menu\n@mixin menu-simple-direction($dir: $global-left) {\n  $no-margin-dir: $dir;\n  $margin-dir: direction-opposite($dir);\n\n  li {\n    margin-#{$no-margin-dir}: 0;\n    margin-#{$margin-dir}: get-side($menu-item-padding, $margin-dir);\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $padding [auto] - Length of the margin.\n@mixin menu-nested($margin: $menu-margin-nested) {\n  margin-#{$global-left}: $margin;\n}\n\n/// Adds support for icons to Menu items.\n/// @param {Keyword} $position [side] - Positioning for icons. Can be `side` (left, or right on RTL) or `top`.\n/// @param {Boolean} $base [true] - Set to `false` to prevent the shared CSS between side- and top-aligned icons from being printed. Set this to `false` if you're calling the mixin multiple times on the same element.\n@mixin menu-icons($position: side, $base: true) {\n  @if $base {\n    @if $global-flexbox {\n      > li > a {\n        display: flex;\n      }\n    }\n    @else {\n      > li > a {\n        img,\n        i,\n        svg {\n          vertical-align: middle;\n\n          + span {\n            vertical-align: middle;\n          }\n        }\n      }\n    }\n  }\n\n  @if $position == side {\n    > li > a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $menu-icon-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 $menu-icon-spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $menu-icon-spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding-top: 0;\n  padding-bottom: 0;\n  padding: $menu-item-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n    @include menu-icons;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n\n      &.align-#{$global-right} {\n        @include menu-simple-direction($global-right);\n      }\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @if $global-flexbox {\n        justify-content: flex-end;\n      }\n      @else {\n        @include clearfix;\n\n        > li {\n          float: $global-right;\n        }\n      }\n    }\n\n    // Vertical icons\n    &.icon-top {\n      @include menu-icons(top, $base: false);\n      // Make vertical menu with icons on top work\n      &.vertical {\n        a > span {\n          margin: auto;\n        }\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Active state\n    .active > a {\n      background: $menu-item-background-active;\n      color: $menu-item-color-active;\n    }\n\n    // Menu with border\n    &.menu-bordered {\n      li {\n        border: 1px solid $menu-border;\n        &:not(:first-child) {\n          border-top: 0;\n        }\n      }\n    }\n\n    // Menu with background hover\n    &.menu-hover {\n      li:hover {\n        background-color: $menu-item-background-hover;\n      }\n    }\n  }\n\n  .menu-text {\n    @include menu-text;\n  }\n\n  // Align center\n  .menu-centered {\n    text-align: center;\n\n    > .menu {\n      display: inline-block;\n      vertical-align: top;\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","// 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 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/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-background: $white !default;\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  // Applied to nested <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-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\n  .drilldown-submenu-cover-previous {\n    min-height: 100%;\n  }\n\n  @if $drilldown-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    .js-drilldown-back > a::before {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n      border-#{$global-left}-width: 0;\n      display: inline-block;\n      vertical-align: middle;\n      margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n\n      border-#{$global-left}-width: 0;\n    }\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: block;\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  &.is-open {\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.#{$name} {\n      width: $size;\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/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-background: $white !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@mixin 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  }\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 {\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right {\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 {\n        position: relative;\n        padding-#{$global-right}: 1.5rem;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after {\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\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          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 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    .no-js & ul {\n      display: none;\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      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-background;\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include 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 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\n@mixin foundation-flex-video {\n  @warn 'This mixin is being replaced by foundation-responsive-embed(). foundation-flex-video() will be removed in Foundation 6.4.';\n  @include foundation-responsive-embed;\n}\n\n@mixin flex-video($ratio: $responsive-embed-ratio) {\n  @warn 'This mixin is being replaced by responsive-embed(). flex-video() will be removed in Foundation 6.4.';\n  @include responsive-embed;\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: 12) {\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 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////\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\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\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    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    &.stack-for-#{$-zf-zero-breakpoint} .media-object-section {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        @include media-object-stack;\n      }\n    }\n  }\n\n  .media-object-section {\n    @include media-object-section;\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","// 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 of a left/right off-canvas panel.\n/// @type Number\n$offcanvas-size: 250px !default;\n\n/// Height of a top/bottom off-canvas panel.\n/// @type Number\n$offcanvas-vertical-size: 250px !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 panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 1 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 10 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 1 !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  // 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\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  z-index: $offcanvas-push-zindex;\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\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  $size: if($orientation == horizontal, $offcanvas-size, $offcanvas-vertical-size)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    width: $size;\n    height: 100%;\n\n    transform: translateX(-$size);\n    overflow-y: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateX($size);\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    width: $size;\n    height: 100%;\n\n    transform: translateX($size);\n    overflow-y: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateX(-$size);\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n\n    width: 100%;\n    height: $size;\n\n    transform: translateY(-$size);\n    overflow-x: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateY($size);\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n\n    width: 100%;\n    height: $size;\n\n    transform: translateY($size);\n    overflow-x: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateY(-$size);\n    }\n  }\n\n  // If $offcanvas-shadow is set, add it as a pseudo-element.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-shadow {\n    &.is-transition-push::after {\n      position: absolute;\n\n      @if $position == left {\n        top: 0;\n        right: 0;\n\n        height: 100%;\n        width: 1px;\n      }\n      @else if $position == right {\n        top: 0;\n        left: 0;\n\n        height: 100%;\n        width: 1px;\n      }\n      @else if $position == top {\n        bottom: 0;\n        left: 0;\n\n        height: 1px;\n        width: 100%;\n      }\n      @else if $position == bottom {\n        top: 0;\n        left: 0;\n\n        height: 1px;\n        width: 100%;\n      }\n\n      box-shadow: $offcanvas-shadow;\n      content: \" \";\n    }\n  }\n\n  // No transform on overlap transition\n  &.is-transition-overlap.is-open ~ .#{$maincontent-class} {\n    transform: none;\n  }\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\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) {\n  transform: none;\n  z-index: $zindex;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  & ~ .#{$content} {\n    margin-#{$position}: $offcanvas-size;\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\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);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(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 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\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 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: $global-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/// 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  position: absolute;\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// [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  position: absolute;\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@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\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 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/// 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: scroll;\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  .columns {\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  @include breakpoint(medium) {\n    @extend %reveal-centered;\n    width: $width;\n    max-width: $reveal-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  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  height: 100vh; // sass-lint:disable-line no-duplicate-properties\n  min-height: 100vh;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n  // [TODO] Is this necessary?\n  body.is-reveal-open { // sass-lint:disable-line no-qualifying-elements\n    overflow: hidden;\n  }\n\n  // html gets this class only in iOS\n  html.is-reveal-open,\n  html.is-reveal-open body {\n    min-height: 100%;\n    overflow: hidden;\n    user-select: none;\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    // Placeholder selector for medium-and-up modals\n    // Prevents duplicate CSS when defining multiple Reveal sizes\n    @include breakpoint(medium) {\n      %reveal-centered {\n        right: auto;\n        left: auto;\n        margin: 0 auto;\n      }\n    }\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","// 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 force-element-nesting, 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@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  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    @elseif($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    @elseif($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:first-child {\n        display: block;\n      }\n\n      th {\n        display: none;\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(medium 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    table {\n      width: 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////\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} $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-pick-contrast($base, $colors: ($white, $black), $tolerance: 0) {\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 < 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  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  }\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/// Maximum number of `expand-n` classes to include in the CSS.\n/// @type Number\n$tab-expand-max: 6 !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    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  &[aria-hidden=\"false\"] {\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: solid 4px $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 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: space-between;\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 tooltip\n////\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 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: help;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: 10rem;\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    @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n    position: absolute;\n    bottom: 100%;\n    left: 50%;\n    transform: translateX(-50%);\n  }\n\n  &.top::before {\n    @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n    top: 100%;\n    bottom: auto;\n  }\n\n  &.left::before {\n    @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n    top: 50%;\n    bottom: auto;\n    left: 100%;\n    transform: translateY(-50%);\n  }\n\n  &.right::before {\n    @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n    top: 50%;\n    right: 100%;\n    bottom: auto;\n    left: auto;\n    transform: translateY(-50%);\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 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    }\n\n    .top-bar-right {\n      flex: 0 1 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/// 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  $size: -zf-bp-to-em($size) - (1 / 16);\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) - (1 / 16);\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 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","//--------------------------------------------------------------\r\n// Primary Navigation Menu\r\n//\r\n// Styles for the primary navigation menu in the header and the off-canvas mobile menu.\r\n//--------------------------------------------------------------\r\n\r\n// Target the off-canvas menu.\r\n.off-canvas {\r\n\r\n\t// Indent our submenus on mobile.\r\n\t.is-accordion-submenu {\r\n\t\tpadding-left: 1rem;\r\n\t} // .is-accordion-submenu\r\n} // .off-canvas\r\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 'Your smallest breakpoint (defined in $breakpoints) must be set to \"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  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - (1/16);\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  // 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\n/// Convers 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/// 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  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @return null;\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@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\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@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@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@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n"]} */
+/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["style.css","style.scss","../../node_modules/foundation-sites/scss/foundation.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_normalize-mixin.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_variables.scss","../../node_modules/foundation-sites/_vendor/normalize-scss/sass/normalize/_vertical-rhythm.scss","../../node_modules/foundation-sites/scss/_global.scss","foundation/_settings.scss","../../node_modules/foundation-sites/scss/util/_mixins.scss","../../node_modules/foundation-sites/scss/grid/_flex-grid.scss","../../node_modules/foundation-sites/scss/grid/_row.scss","../../node_modules/foundation-sites/scss/util/_unit.scss","../../node_modules/foundation-sites/scss/grid/_gutter.scss","../../node_modules/foundation-sites/scss/util/_flex.scss","../../node_modules/foundation-sites/scss/grid/_column.scss","../../node_modules/foundation-sites/scss/grid/_position.scss","../../node_modules/foundation-sites/scss/components/_flex.scss","../../node_modules/foundation-sites/scss/typography/_base.scss","../../node_modules/foundation-sites/scss/typography/_helpers.scss","../../node_modules/foundation-sites/scss/typography/_alignment.scss","../../node_modules/foundation-sites/scss/typography/_print.scss","../../node_modules/foundation-sites/scss/forms/_text.scss","../../node_modules/foundation-sites/scss/forms/_checkbox.scss","../../node_modules/foundation-sites/scss/forms/_label.scss","../../node_modules/foundation-sites/scss/forms/_help-text.scss","../../node_modules/foundation-sites/scss/forms/_input-group.scss","../../node_modules/foundation-sites/scss/forms/_fieldset.scss","../../node_modules/foundation-sites/scss/forms/_select.scss","../../node_modules/foundation-sites/scss/forms/_error.scss","../../node_modules/foundation-sites/scss/components/_button.scss","../../node_modules/foundation-sites/scss/components/_button-group.scss","../../node_modules/foundation-sites/scss/components/_menu.scss","../../node_modules/foundation-sites/scss/components/_dropdown.scss","../../node_modules/foundation-sites/scss/components/_dropdown-menu.scss","../../node_modules/foundation-sites/scss/components/_off-canvas.scss","../../node_modules/foundation-sites/scss/components/_visibility.scss","../../node_modules/foundation-sites/scss/components/_float.scss","base/_helpers.scss","utilities/mixins/_size.scss","base/_wordpress.scss","utilities/mixins/_margin-padding-reset.scss","components/_navigation.scss","components/_content-blocks.scss","sections/_comments.scss","utilities/mixins/_list-reset.scss","sections/_content.scss","utilities/mixins/_word-break.scss","sections/_footer.scss","sections/_header.scss","sections/_hero.scss","utilities/mixins/_position.scss","../../node_modules/foundation-sites/scss/util/_breakpoint.scss"],"names":[],"mappings":"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,eAAc;CACf;;AAGD;EACE,gBAAe;EACf,eAAc;EACd,iBAAgB;EAChB,gBAAe;CAChB;;AAGD;EIpKA,qBAAa;EAAb,cAAa;CJsKZ;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAED;EACE,mBAAc;MAAd,eAAc;CACf;;AAGC;EI1HF,wBAnEU;MAmEV,oBAnEU;CJ+LP;;AAFD;EI1HF,gCAlE0B;MAkE1B,4BAlE0B;CJ8LvB;;AAFD;EI1HF,2BAjEgB;MAiEhB,uBAjEgB;CJ6Lb;;AAFD;EI1HF,mCAhEgC;MAgEhC,+BAhEgC;CJ4L7B;;AAMC;EACE,uBKzL+C;MLyL/C,mBKzL+C;EL0L/C,oBK1L+C;CL2LhD;;AAKD;EMnLJ,gBDhBgC;CLqM3B;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,sBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,kBKzL+C;MLyL/C,cKzL+C;EL0L/C,eK1L+C;CL2LhD;;AAKD;EMnLJ,uBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/C,oBKzL+C;EL0L/C,qBK1L+C;CL2LhD;;AAKD;EMnLJ,iBDbqD;CLkMhD;;AAVD;EACE,wBKzL+C;MLyL/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AaI,eAAc;EACd,eVtQe;CUuQhB;;AAQG;EAII,kBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,mBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,qBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,oBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,qBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAjCD;EAII,gBNvP6C;EMmQ7C,iBV3OW;EUmPX,cAAa;EAOb,sBVzPiB;CU2PpB;;AAMP;EACE,qBAAoB;EACpB,eV/Tc;EUgUd,sBVnOyB;EUqOzB,gBAAe;CAahB;;AAlBD;EASI,eV1O2D;CU8O5D;;AAbH;EAgBI,UAAS;CACV;;AAIH;EACE,YAAW;EAEX,iBNlTqD;EMmTrD,UAAS;EACT,qBVtPyB;EUwPzB,cAAa;EACb,gBAAe;EACf,iCVpViB;EUqVjB,eAAc;CACf;;AAGD;;;EAGE,oBVhR0B;EUiR1B,6BV/PyB;EUgQzB,iBVnRsB;CUoRvB;;AAGD;EACE,mBAAkB;CACnB;;AAGD;EACE,qBVzQsB;EU0QtB,sBV5QkB;CU6QnB;;AAGD;EACE,qBV/QsB;CUgRvB;;AAGD;EAEI,qBVpR2B;EUqR3B,iBAAgB;CACjB;;AAIH;EACE,oBV1RyB;CUgS1B;;AAPD;EAII,sBV3R8B;EU4R9B,kBVpXmB;CUqXpB;;AAIH;EACE,iBVzT0B;EU0T1B,uCN1WqD;EM2WrD,+BVvYiB;CU6YlB;;AATD;EAMI,iBV/ToB;EUgUpB,eV1Ya;CU2Yd;;AAIH;EACE,eAAc;EACd,qBNtXqD;EMuXrD,eVlZe;CUuZhB;;AARD;EAMI,cV7SgB;CU8SjB;;AAIH;EACE,kCV1ZW;EU2ZX,eV3ZW;EU4ZX,aAAY;CACb;;AAGD;EACE,UAAS;CACV;;AAGD;EACE,sCN5YqD;EM8YrD,0BV1aiB;EU2ajB,0BV5agB;EU8ahB,6DV3XmE;EU4XnE,oBVpa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CC,kBAA+B;CAC/B;;ACFD;EACC,mBAAkB;EAClB,mBAAkB;EAClB,WAAU;CA+CV;;AAlDD;EXkCI,aW3BgB;EXkChB,YWlCgB;ECmDlB,mBDlD0B;ECsDtB,ODtDyB;ECsDzB,SDtD2B;EAE/B,wC1CiDa;E0ChDb,YAAW;EACX,WAAU;CACV;;AAGD;EACC,gBAA8B;EAC9B,mBAAkB;EAClB,WAAU;EAGT,gBAA8B;CAE/B;;AAGD;EACC,gBtCyDuD;EsCxDvD,iBAAgB;EAChB,oBAAkC;CAKlC;;AAGD;EACC,oBtC8CuD;CsCzCvD;;AAGD;EACC,qBtCqCuD;CsCpCvD;;AEuGI;E1CzBJ;IC9CE,yBAF+D;IAG/D,wBAH+D;GD2D9D;EA2BH;IGlJE,yBAFqC;IAGrC,wBAHqC;GHsJtC;EA2CG;IACE,uBKzL+C;ILyL/C,mBKzL+C;IL0L/C,oBK1L+C;GL2LhD;EAKD;IMnLJ,gBDhBgC;GLqM3B;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,sBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+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;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,sBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,kBKzL+C;ILyL/C,cKzL+C;IL0L/C,eK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,iBDbqD;GLkMhD;EAVD;IACE,wBKzL+C;ILyL/C,oBKzL+C;IL0L/C,qBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAVD;IACE,mBKzL+C;ILyL/C,eKzL+C;IL0L/C,gBK1L+C;GL2LhD;EAKD;IMnLJ,uBDbqD;GLkMhD;EAKD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAFD;II3JJ,kBJ0JgB;II1JhB,SJ0JgB;GAGX;EAKD;IAnIJ,oBAAe;IAAf,gBAAe;GAqIV;EAnIH;IAGA,mBAFsB;IAEtB,eAFsB;IAGtB,gBAHsB;GAIvB;EA4HG;IAnIJ,oBA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","file":"style.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Theme Name: _s\n * Theme URI: http://underscores.me/\n * Author: Automattic\n * Author URI: http://automattic.com/\n * Description: Hi. I'm a starter theme called <code>_s</code>, or <em>underscores</em>, if you like. I'm a theme meant for hacking so don't use me as a <em>Parent Theme</em>. Instead try turning me into the next, most awesome, WordPress theme out there. That's what I'm here for.\n * Version: 1.0.0\n * License: GNU General Public License v2 or later\n * License URI: http://www.gnu.org/licenses/gpl-2.0.html\n * Text Domain: _s\n * Tags: custom\n *\n * This theme, like WordPress, is licensed under the GPL.\n *\n * Based on Underscores http://underscores.me/, (C) 2012-2017 Automattic, Inc.\n *\n */\n/**\n * Foundation for Sites by ZURB\n * Version 6.3.1\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */\n/* Document\n       ========================================================================== */\n/**\n     * 1. Change the default font family in all browsers (opinionated).\n     * 2. Correct the line height in all browsers.\n     * 3. Prevent adjustments of font size after orientation changes in\n     *    IE on Windows Phone and in iOS.\n     */\nhtml {\n  font-family: sans-serif;\n  /* 1 */\n  line-height: 1.15;\n  /* 2 */\n  -ms-text-size-adjust: 100%;\n  /* 3 */\n  -webkit-text-size-adjust: 100%;\n  /* 3 */\n}\n\n/* Sections\n       ========================================================================== */\n/**\n     * Remove the margin in all browsers (opinionated).\n     */\nbody {\n  margin: 0;\n}\n\n/**\n     * Add the correct display in IE 9-.\n     */\narticle,\naside,\nfooter,\nheader,\nnav,\nsection {\n  display: block;\n}\n\n/**\n     * Correct the font size and margin on `h1` elements within `section` and\n     * `article` contexts in Chrome, Firefox, and Safari.\n     */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\nfigcaption,\nfigure {\n  display: block;\n}\n\n/**\n     * Add the correct margin in IE 8.\n     */\nfigure {\n  margin: 1em 40px;\n}\n\n/**\n     * 1. Add the correct box sizing in Firefox.\n     * 2. Show the overflow in Edge and IE.\n     */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n     * Add the correct display in IE.\n     */\nmain {\n  display: block;\n}\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     */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Links\n       ========================================================================== */\n/**\n     * 1. Remove the gray background on active links in IE 10.\n     * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n     */\na {\n  background-color: transparent;\n  /* 1 */\n  -webkit-text-decoration-skip: objects;\n  /* 2 */\n}\n\n/**\n     * Remove the outline on focused links when they are also active or hovered\n     * in all browsers (opinionated).\n     */\na:active,\na:hover {\n  outline-width: 0;\n}\n\n/* Text-level semantics\n       ========================================================================== */\n/**\n     * 1. Remove the bottom border in Firefox 39-.\n     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n     */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n     * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n     */\nb,\nstrong {\n  font-weight: inherit;\n}\n\n/**\n     * Add the correct font weight in Chrome, Edge, and Safari.\n     */\nb,\nstrong {\n  font-weight: bolder;\n}\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     */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n     * Add the correct font style in Android 4.3-.\n     */\ndfn {\n  font-style: italic;\n}\n\n/**\n     * Add the correct background and color in IE 9-.\n     */\nmark {\n  background-color: #ff0;\n  color: #000;\n}\n\n/**\n     * Add the correct font size in all browsers.\n     */\nsmall {\n  font-size: 80%;\n}\n\n/**\n     * Prevent `sub` and `sup` elements from affecting the line height in\n     * all browsers.\n     */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\naudio,\nvideo {\n  display: inline-block;\n}\n\n/**\n     * Add the correct display in iOS 4-7.\n     */\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n     * Remove the border on images inside links in IE 10-.\n     */\nimg {\n  border-style: none;\n}\n\n/**\n     * Hide the overflow in IE.\n     */\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* Forms\n       ========================================================================== */\n/**\n     * 1. Change the font styles in all browsers (opinionated).\n     * 2. Remove the margin in Firefox and Safari.\n     */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: sans-serif;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n     * Show the overflow in IE.\n     */\nbutton {\n  overflow: visible;\n}\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     */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n     * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n     *    controls in Android 4.\n     * 2. Correct the inability to style clickable types in iOS and Safari.\n     */\nbutton,\nhtml [type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n  /* 2 */\n}\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  /**\n       * Remove the inner border and padding in Firefox.\n       */\n  /**\n       * Restore the focus styles unset by the previous rule.\n       */\n}\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}\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}\n\n/**\n     * Show the overflow in Edge.\n     */\ninput {\n  overflow: visible;\n}\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;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\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/**\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;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n  /**\n       * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n       */\n}\n\n[type=\"search\"]::-webkit-search-cancel-button, [type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\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;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/**\n     * Change the border, margin, and padding in all browsers (opinionated).\n     */\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\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     */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  color: inherit;\n  /* 2 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n     * 1. Add the correct display in IE 9-.\n     * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n     */\nprogress {\n  display: inline-block;\n  /* 1 */\n  vertical-align: baseline;\n  /* 2 */\n}\n\n/**\n     * Remove the default vertical scrollbar in IE.\n     */\ntextarea {\n  overflow: auto;\n}\n\n/* Interactive\n       ========================================================================== */\n/*\n     * Add the correct display in Edge, IE, and Firefox.\n     */\ndetails {\n  display: block;\n}\n\n/*\n     * Add the correct display in all browsers.\n     */\nsummary {\n  display: list-item;\n}\n\n/*\n     * Add the correct display in IE 9-.\n     */\nmenu {\n  display: block;\n}\n\n/* Scripting\n       ========================================================================== */\n/**\n     * Add the correct display in IE 9-.\n     */\ncanvas {\n  display: inline-block;\n}\n\n/**\n     * Add the correct display in IE.\n     */\ntemplate {\n  display: none;\n}\n\n/* Hidden\n       ========================================================================== */\n/**\n     * Add the correct display in IE 10-.\n     */\n[hidden] {\n  display: none;\n}\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\";\n}\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%;\n}\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit;\n}\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}\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic;\n}\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0;\n}\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0;\n}\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}\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n}\n\n[data-whatinput='mouse'] button {\n  outline: 0;\n}\n\npre {\n  overflow: auto;\n}\n\n.is-visible {\n  display: block !important;\n}\n\n.is-hidden {\n  display: none !important;\n}\n\n.row {\n  max-width: 60rem;\n  margin-right: auto;\n  margin-left: auto;\n  display: flex;\n  flex-flow: row wrap;\n}\n\n.row .row {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .row .row {\n    margin-right: -0.9375rem;\n    margin-left: -0.9375rem;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .row .row {\n    margin-right: -0.9375rem;\n    margin-left: -0.9375rem;\n  }\n}\n\n.row .row.collapse {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.row.expanded {\n  max-width: none;\n}\n\n.row:not(.expanded) .row {\n  max-width: none;\n}\n\n.row.collapse > .column, .row.collapse > .columns {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.row.is-collapse-child,\n.row.collapse > .column > .row,\n.row.collapse > .columns > .row {\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.column, .columns {\n  flex: 1 1 0px;\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  min-width: initial;\n}\n\n@media print, screen and (min-width: 40em) {\n  .column, .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n.column.row.row, .row.row.columns {\n  float: none;\n  display: block;\n}\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\n.flex-container {\n  display: 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.flex-dir-row {\n  flex-direction: row;\n}\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse;\n}\n\n.flex-dir-column {\n  flex-direction: column;\n}\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse;\n}\n\n.small-1 {\n  flex: 0 0 8.33333%;\n  max-width: 8.33333%;\n}\n\n.small-offset-0 {\n  margin-left: 0%;\n}\n\n.small-2 {\n  flex: 0 0 16.66667%;\n  max-width: 16.66667%;\n}\n\n.small-offset-1 {\n  margin-left: 8.33333%;\n}\n\n.small-3 {\n  flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.small-offset-2 {\n  margin-left: 16.66667%;\n}\n\n.small-4 {\n  flex: 0 0 33.33333%;\n  max-width: 33.33333%;\n}\n\n.small-offset-3 {\n  margin-left: 25%;\n}\n\n.small-5 {\n  flex: 0 0 41.66667%;\n  max-width: 41.66667%;\n}\n\n.small-offset-4 {\n  margin-left: 33.33333%;\n}\n\n.small-6 {\n  flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.small-offset-5 {\n  margin-left: 41.66667%;\n}\n\n.small-7 {\n  flex: 0 0 58.33333%;\n  max-width: 58.33333%;\n}\n\n.small-offset-6 {\n  margin-left: 50%;\n}\n\n.small-8 {\n  flex: 0 0 66.66667%;\n  max-width: 66.66667%;\n}\n\n.small-offset-7 {\n  margin-left: 58.33333%;\n}\n\n.small-9 {\n  flex: 0 0 75%;\n  max-width: 75%;\n}\n\n.small-offset-8 {\n  margin-left: 66.66667%;\n}\n\n.small-10 {\n  flex: 0 0 83.33333%;\n  max-width: 83.33333%;\n}\n\n.small-offset-9 {\n  margin-left: 75%;\n}\n\n.small-11 {\n  flex: 0 0 91.66667%;\n  max-width: 91.66667%;\n}\n\n.small-offset-10 {\n  margin-left: 83.33333%;\n}\n\n.small-12 {\n  flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.small-offset-11 {\n  margin-left: 91.66667%;\n}\n\n.small-order-1 {\n  order: 1;\n}\n\n.small-order-2 {\n  order: 2;\n}\n\n.small-order-3 {\n  order: 3;\n}\n\n.small-order-4 {\n  order: 4;\n}\n\n.small-order-5 {\n  order: 5;\n}\n\n.small-order-6 {\n  order: 6;\n}\n\n.small-up-1 {\n  flex-wrap: wrap;\n}\n\n.small-up-1 > .column, .small-up-1 > .columns {\n  flex: 0 0 100%;\n  max-width: 100%;\n}\n\n.small-up-2 {\n  flex-wrap: wrap;\n}\n\n.small-up-2 > .column, .small-up-2 > .columns {\n  flex: 0 0 50%;\n  max-width: 50%;\n}\n\n.small-up-3 {\n  flex-wrap: wrap;\n}\n\n.small-up-3 > .column, .small-up-3 > .columns {\n  flex: 0 0 33.33333%;\n  max-width: 33.33333%;\n}\n\n.small-up-4 {\n  flex-wrap: wrap;\n}\n\n.small-up-4 > .column, .small-up-4 > .columns {\n  flex: 0 0 25%;\n  max-width: 25%;\n}\n\n.small-up-5 {\n  flex-wrap: wrap;\n}\n\n.small-up-5 > .column, .small-up-5 > .columns {\n  flex: 0 0 20%;\n  max-width: 20%;\n}\n\n.small-up-6 {\n  flex-wrap: wrap;\n}\n\n.small-up-6 > .column, .small-up-6 > .columns {\n  flex: 0 0 16.66667%;\n  max-width: 16.66667%;\n}\n\n.small-up-7 {\n  flex-wrap: wrap;\n}\n\n.small-up-7 > .column, .small-up-7 > .columns {\n  flex: 0 0 14.28571%;\n  max-width: 14.28571%;\n}\n\n.small-up-8 {\n  flex-wrap: wrap;\n}\n\n.small-up-8 > .column, .small-up-8 > .columns {\n  flex: 0 0 12.5%;\n  max-width: 12.5%;\n}\n\n.small-collapse > .column, .small-collapse > .columns {\n  padding-right: 0;\n  padding-left: 0;\n}\n\n.small-uncollapse > .column, .small-uncollapse > .columns {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-1 {\n    flex: 0 0 8.33333%;\n    max-width: 8.33333%;\n  }\n  .medium-offset-0 {\n    margin-left: 0%;\n  }\n  .medium-2 {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .medium-offset-1 {\n    margin-left: 8.33333%;\n  }\n  .medium-3 {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .medium-offset-2 {\n    margin-left: 16.66667%;\n  }\n  .medium-4 {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .medium-offset-3 {\n    margin-left: 25%;\n  }\n  .medium-5 {\n    flex: 0 0 41.66667%;\n    max-width: 41.66667%;\n  }\n  .medium-offset-4 {\n    margin-left: 33.33333%;\n  }\n  .medium-6 {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .medium-offset-5 {\n    margin-left: 41.66667%;\n  }\n  .medium-7 {\n    flex: 0 0 58.33333%;\n    max-width: 58.33333%;\n  }\n  .medium-offset-6 {\n    margin-left: 50%;\n  }\n  .medium-8 {\n    flex: 0 0 66.66667%;\n    max-width: 66.66667%;\n  }\n  .medium-offset-7 {\n    margin-left: 58.33333%;\n  }\n  .medium-9 {\n    flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .medium-offset-8 {\n    margin-left: 66.66667%;\n  }\n  .medium-10 {\n    flex: 0 0 83.33333%;\n    max-width: 83.33333%;\n  }\n  .medium-offset-9 {\n    margin-left: 75%;\n  }\n  .medium-11 {\n    flex: 0 0 91.66667%;\n    max-width: 91.66667%;\n  }\n  .medium-offset-10 {\n    margin-left: 83.33333%;\n  }\n  .medium-12 {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .medium-offset-11 {\n    margin-left: 91.66667%;\n  }\n  .medium-order-1 {\n    order: 1;\n  }\n  .medium-order-2 {\n    order: 2;\n  }\n  .medium-order-3 {\n    order: 3;\n  }\n  .medium-order-4 {\n    order: 4;\n  }\n  .medium-order-5 {\n    order: 5;\n  }\n  .medium-order-6 {\n    order: 6;\n  }\n  .medium-up-1 {\n    flex-wrap: wrap;\n  }\n  .medium-up-1 > .column, .medium-up-1 > .columns {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .medium-up-2 {\n    flex-wrap: wrap;\n  }\n  .medium-up-2 > .column, .medium-up-2 > .columns {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .medium-up-3 {\n    flex-wrap: wrap;\n  }\n  .medium-up-3 > .column, .medium-up-3 > .columns {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .medium-up-4 {\n    flex-wrap: wrap;\n  }\n  .medium-up-4 > .column, .medium-up-4 > .columns {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .medium-up-5 {\n    flex-wrap: wrap;\n  }\n  .medium-up-5 > .column, .medium-up-5 > .columns {\n    flex: 0 0 20%;\n    max-width: 20%;\n  }\n  .medium-up-6 {\n    flex-wrap: wrap;\n  }\n  .medium-up-6 > .column, .medium-up-6 > .columns {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .medium-up-7 {\n    flex-wrap: wrap;\n  }\n  .medium-up-7 > .column, .medium-up-7 > .columns {\n    flex: 0 0 14.28571%;\n    max-width: 14.28571%;\n  }\n  .medium-up-8 {\n    flex-wrap: wrap;\n  }\n  .medium-up-8 > .column, .medium-up-8 > .columns {\n    flex: 0 0 12.5%;\n    max-width: 12.5%;\n  }\n}\n\n@media print, screen and (min-width: 40em) and (min-width: 40em) {\n  .medium-expand {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-dir-row {\n    flex-direction: row;\n  }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse;\n  }\n  .medium-flex-dir-column {\n    flex-direction: column;\n  }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse;\n  }\n  .medium-flex-child-auto {\n    flex: 1 1 auto;\n  }\n  .medium-flex-child-grow {\n    flex: 1 0 auto;\n  }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto;\n  }\n}\n\n.row.medium-unstack > .column, .row.medium-unstack > .columns {\n  flex: 0 0 100%;\n}\n\n@media print, screen and (min-width: 40em) {\n  .row.medium-unstack > .column, .row.medium-unstack > .columns {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-collapse > .column, .medium-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0;\n  }\n  .medium-uncollapse > .column, .medium-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-1 {\n    flex: 0 0 8.33333%;\n    max-width: 8.33333%;\n  }\n  .large-offset-0 {\n    margin-left: 0%;\n  }\n  .large-2 {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .large-offset-1 {\n    margin-left: 8.33333%;\n  }\n  .large-3 {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .large-offset-2 {\n    margin-left: 16.66667%;\n  }\n  .large-4 {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .large-offset-3 {\n    margin-left: 25%;\n  }\n  .large-5 {\n    flex: 0 0 41.66667%;\n    max-width: 41.66667%;\n  }\n  .large-offset-4 {\n    margin-left: 33.33333%;\n  }\n  .large-6 {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .large-offset-5 {\n    margin-left: 41.66667%;\n  }\n  .large-7 {\n    flex: 0 0 58.33333%;\n    max-width: 58.33333%;\n  }\n  .large-offset-6 {\n    margin-left: 50%;\n  }\n  .large-8 {\n    flex: 0 0 66.66667%;\n    max-width: 66.66667%;\n  }\n  .large-offset-7 {\n    margin-left: 58.33333%;\n  }\n  .large-9 {\n    flex: 0 0 75%;\n    max-width: 75%;\n  }\n  .large-offset-8 {\n    margin-left: 66.66667%;\n  }\n  .large-10 {\n    flex: 0 0 83.33333%;\n    max-width: 83.33333%;\n  }\n  .large-offset-9 {\n    margin-left: 75%;\n  }\n  .large-11 {\n    flex: 0 0 91.66667%;\n    max-width: 91.66667%;\n  }\n  .large-offset-10 {\n    margin-left: 83.33333%;\n  }\n  .large-12 {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .large-offset-11 {\n    margin-left: 91.66667%;\n  }\n  .large-order-1 {\n    order: 1;\n  }\n  .large-order-2 {\n    order: 2;\n  }\n  .large-order-3 {\n    order: 3;\n  }\n  .large-order-4 {\n    order: 4;\n  }\n  .large-order-5 {\n    order: 5;\n  }\n  .large-order-6 {\n    order: 6;\n  }\n  .large-up-1 {\n    flex-wrap: wrap;\n  }\n  .large-up-1 > .column, .large-up-1 > .columns {\n    flex: 0 0 100%;\n    max-width: 100%;\n  }\n  .large-up-2 {\n    flex-wrap: wrap;\n  }\n  .large-up-2 > .column, .large-up-2 > .columns {\n    flex: 0 0 50%;\n    max-width: 50%;\n  }\n  .large-up-3 {\n    flex-wrap: wrap;\n  }\n  .large-up-3 > .column, .large-up-3 > .columns {\n    flex: 0 0 33.33333%;\n    max-width: 33.33333%;\n  }\n  .large-up-4 {\n    flex-wrap: wrap;\n  }\n  .large-up-4 > .column, .large-up-4 > .columns {\n    flex: 0 0 25%;\n    max-width: 25%;\n  }\n  .large-up-5 {\n    flex-wrap: wrap;\n  }\n  .large-up-5 > .column, .large-up-5 > .columns {\n    flex: 0 0 20%;\n    max-width: 20%;\n  }\n  .large-up-6 {\n    flex-wrap: wrap;\n  }\n  .large-up-6 > .column, .large-up-6 > .columns {\n    flex: 0 0 16.66667%;\n    max-width: 16.66667%;\n  }\n  .large-up-7 {\n    flex-wrap: wrap;\n  }\n  .large-up-7 > .column, .large-up-7 > .columns {\n    flex: 0 0 14.28571%;\n    max-width: 14.28571%;\n  }\n  .large-up-8 {\n    flex-wrap: wrap;\n  }\n  .large-up-8 > .column, .large-up-8 > .columns {\n    flex: 0 0 12.5%;\n    max-width: 12.5%;\n  }\n}\n\n@media print, screen and (min-width: 64em) and (min-width: 64em) {\n  .large-expand {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-dir-row {\n    flex-direction: row;\n  }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse;\n  }\n  .large-flex-dir-column {\n    flex-direction: column;\n  }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse;\n  }\n  .large-flex-child-auto {\n    flex: 1 1 auto;\n  }\n  .large-flex-child-grow {\n    flex: 1 0 auto;\n  }\n  .large-flex-child-shrink {\n    flex: 0 1 auto;\n  }\n}\n\n.row.large-unstack > .column, .row.large-unstack > .columns {\n  flex: 0 0 100%;\n}\n\n@media print, screen and (min-width: 64em) {\n  .row.large-unstack > .column, .row.large-unstack > .columns {\n    flex: 1 1 0px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-collapse > .column, .large-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0;\n  }\n  .large-uncollapse > .column, .large-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem;\n  }\n}\n\n.shrink {\n  flex: 0 0 auto;\n  max-width: 100%;\n}\n\n.column-block {\n  margin-bottom: 1.25rem;\n}\n\n.column-block > :last-child {\n  margin-bottom: 0;\n}\n\n@media print, screen and (min-width: 40em) {\n  .column-block {\n    margin-bottom: 1.875rem;\n  }\n  .column-block > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n.align-right {\n  justify-content: flex-end;\n}\n\n.align-center {\n  justify-content: center;\n}\n\n.align-justify {\n  justify-content: space-between;\n}\n\n.align-spaced {\n  justify-content: space-around;\n}\n\n.align-top {\n  align-items: flex-start;\n}\n\n.align-self-top {\n  align-self: flex-start;\n}\n\n.align-bottom {\n  align-items: flex-end;\n}\n\n.align-self-bottom {\n  align-self: flex-end;\n}\n\n.align-middle {\n  align-items: center;\n}\n\n.align-self-middle {\n  align-self: center;\n}\n\n.align-stretch {\n  align-items: stretch;\n}\n\n.align-self-stretch {\n  align-self: stretch;\n}\n\n.small-order-1 {\n  order: 1;\n}\n\n.small-order-2 {\n  order: 2;\n}\n\n.small-order-3 {\n  order: 3;\n}\n\n.small-order-4 {\n  order: 4;\n}\n\n.small-order-5 {\n  order: 5;\n}\n\n.small-order-6 {\n  order: 6;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1;\n  }\n  .medium-order-2 {\n    order: 2;\n  }\n  .medium-order-3 {\n    order: 3;\n  }\n  .medium-order-4 {\n    order: 4;\n  }\n  .medium-order-5 {\n    order: 5;\n  }\n  .medium-order-6 {\n    order: 6;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1;\n  }\n  .large-order-2 {\n    order: 2;\n  }\n  .large-order-3 {\n    order: 3;\n  }\n  .large-order-4 {\n    order: 4;\n  }\n  .large-order-5 {\n    order: 5;\n  }\n  .large-order-6 {\n    order: 6;\n  }\n}\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}\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility;\n}\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit;\n}\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit;\n}\n\nsmall {\n  font-size: 80%;\n  line-height: inherit;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6 {\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}\n\nh1 small,\nh2 small,\nh3 small,\nh4 small,\nh5 small,\nh6 small {\n  line-height: 0;\n  color: #cacaca;\n}\n\nh1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\nh6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  h1 {\n    font-size: 3rem;\n  }\n  h2 {\n    font-size: 2.5rem;\n  }\n  h3 {\n    font-size: 1.9375rem;\n  }\n  h4 {\n    font-size: 1.5625rem;\n  }\n  h5 {\n    font-size: 1.25rem;\n  }\n  h6 {\n    font-size: 1rem;\n  }\n}\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer;\n}\n\na:hover, a:focus {\n  color: #1468a0;\n}\n\na img {\n  border: 0;\n}\n\nhr {\n  clear: both;\n  max-width: 60rem;\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}\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6;\n}\n\nli {\n  font-size: inherit;\n}\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc;\n}\n\nol {\n  margin-left: 1.25rem;\n}\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0;\n}\n\ndl {\n  margin-bottom: 1rem;\n}\n\ndl dt {\n  margin-bottom: 0.3rem;\n  font-weight: bold;\n}\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca;\n}\n\nblockquote, blockquote p {\n  line-height: 1.6;\n  color: #8a8a8a;\n}\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a;\n}\n\ncite:before {\n  content: \"— \";\n}\n\nabbr {\n  border-bottom: 1px dotted #0a0a0a;\n  color: #0a0a0a;\n  cursor: help;\n}\n\nfigure {\n  margin: 0;\n}\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}\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\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\n.lead {\n  font-size: 125%;\n  line-height: 1.6;\n}\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1;\n}\n\np + .stat {\n  margin-top: -1rem;\n}\n\n.no-bullet {\n  margin-left: 0;\n  list-style: none;\n}\n\n.text-left {\n  text-align: left;\n}\n\n.text-right {\n  text-align: right;\n}\n\n.text-center {\n  text-align: center;\n}\n\n.text-justify {\n  text-align: justify;\n}\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left;\n  }\n  .medium-text-right {\n    text-align: right;\n  }\n  .medium-text-center {\n    text-align: center;\n  }\n  .medium-text-justify {\n    text-align: justify;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left;\n  }\n  .large-text-right {\n    text-align: right;\n  }\n  .large-text-center {\n    text-align: center;\n  }\n  .large-text-justify {\n    text-align: justify;\n  }\n}\n\n.show-for-print {\n  display: none !important;\n}\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important;\n  }\n  .show-for-print {\n    display: block !important;\n  }\n  .hide-for-print {\n    display: none !important;\n  }\n  table.show-for-print {\n    display: table !important;\n  }\n  thead.show-for-print {\n    display: table-header-group !important;\n  }\n  tbody.show-for-print {\n    display: table-row-group !important;\n  }\n  tr.show-for-print {\n    display: table-row !important;\n  }\n  td.show-for-print {\n    display: table-cell !important;\n  }\n  th.show-for-print {\n    display: table-cell !important;\n  }\n  a,\n  a:visited {\n    text-decoration: underline;\n  }\n  a[href]:after {\n    content: \" (\" attr(href) \")\";\n  }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: '';\n  }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\";\n  }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid;\n  }\n  thead {\n    display: table-header-group;\n  }\n  tr,\n  img {\n    page-break-inside: avoid;\n  }\n  img {\n    max-width: 100% !important;\n  }\n  @page {\n    margin: 0.5cm;\n  }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3;\n  }\n  h2,\n  h3 {\n    page-break-after: avoid;\n  }\n}\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  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none;\n}\n\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,\ntextarea: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}\n\ntextarea {\n  max-width: 100%;\n}\n\ntextarea[rows] {\n  height: auto;\n}\n\ninput::placeholder,\ntextarea::placeholder {\n  color: #cacaca;\n}\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed;\n}\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0;\n}\n\ninput[type='search'] {\n  box-sizing: border-box;\n}\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem;\n}\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}\n\n[type='checkbox'] + label[for],\n[type='radio'] + label[for] {\n  cursor: pointer;\n}\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem;\n}\n\n[type='file'] {\n  width: 100%;\n}\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}\n\nlabel.middle {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 0;\n}\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a;\n}\n\n.input-group {\n  display: table;\n  width: 100%;\n  margin-bottom: 1rem;\n}\n\n.input-group > :first-child {\n  border-radius: 0 0 0 0;\n}\n\n.input-group > :last-child > * {\n  border-radius: 0 0 0 0;\n}\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\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}\n\n.input-group-label:first-child {\n  border-right: 0;\n}\n\n.input-group-label:last-child {\n  border-left: 0;\n}\n\n.input-group-field {\n  border-radius: 0;\n  height: 2.5rem;\n}\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  width: 1%;\n  height: 100%;\n}\n\n.input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  height: 2.5rem;\n  padding-top: 0;\n  padding-bottom: 0;\n  font-size: 1rem;\n}\n\n.input-group .input-group-button {\n  display: table-cell;\n}\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0;\n}\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem;\n}\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca;\n}\n\n.fieldset legend {\n  margin: 0;\n  margin-left: -0.1875rem;\n  padding: 0 0.1875rem;\n  background: #fefefe;\n}\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  line-height: normal;\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}\n\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  }\n}\n\nselect: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}\n\nselect:disabled {\n  background-color: #e6e6e6;\n  cursor: not-allowed;\n}\n\nselect::-ms-expand {\n  display: none;\n}\n\nselect[multiple] {\n  height: auto;\n  background-image: none;\n}\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea;\n}\n\n.is-invalid-input:not(:focus)::placeholder {\n  color: #cc4b37;\n}\n\n.is-invalid-label {\n  color: #cc4b37;\n}\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}\n\n.form-error.is-visible {\n  display: block;\n}\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  -webkit-appearance: none;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-size: 0.9rem;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n[data-whatinput='mouse'] .button {\n  outline: 0;\n}\n\n.button:hover, .button:focus {\n  background-color: #14679e;\n  color: #fefefe;\n}\n\n.button.tiny {\n  font-size: 0.6rem;\n}\n\n.button.small {\n  font-size: 0.75rem;\n}\n\n.button.large {\n  font-size: 1.25rem;\n}\n\n.button.expanded {\n  display: block;\n  width: 100%;\n  margin-right: 0;\n  margin-left: 0;\n}\n\n.button.primary {\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n.button.primary:hover, .button.primary:focus {\n  background-color: #126195;\n  color: #fefefe;\n}\n\n.button.secondary {\n  background-color: #767676;\n  color: #fefefe;\n}\n\n.button.secondary:hover, .button.secondary:focus {\n  background-color: #5e5e5e;\n  color: #fefefe;\n}\n\n.button.success {\n  background-color: #3adb76;\n  color: #0a0a0a;\n}\n\n.button.success:hover, .button.success:focus {\n  background-color: #22bb5b;\n  color: #0a0a0a;\n}\n\n.button.warning {\n  background-color: #ffae00;\n  color: #0a0a0a;\n}\n\n.button.warning:hover, .button.warning:focus {\n  background-color: #cc8b00;\n  color: #0a0a0a;\n}\n\n.button.alert {\n  background-color: #cc4b37;\n  color: #fefefe;\n}\n\n.button.alert:hover, .button.alert:focus {\n  background-color: #a53b2a;\n  color: #fefefe;\n}\n\n.button.hollow {\n  border: 1px solid #1779ba;\n  color: #1779ba;\n}\n\n.button.hollow, .button.hollow:hover, .button.hollow:focus {\n  background-color: transparent;\n}\n\n.button.hollow:hover, .button.hollow:focus {\n  border-color: #0c3d5d;\n  color: #0c3d5d;\n}\n\n.button.hollow.primary {\n  border: 1px solid #1779ba;\n  color: #1779ba;\n}\n\n.button.hollow.primary:hover, .button.hollow.primary:focus {\n  border-color: #0c3d5d;\n  color: #0c3d5d;\n}\n\n.button.hollow.secondary {\n  border: 1px solid #767676;\n  color: #767676;\n}\n\n.button.hollow.secondary:hover, .button.hollow.secondary:focus {\n  border-color: #3b3b3b;\n  color: #3b3b3b;\n}\n\n.button.hollow.success {\n  border: 1px solid #3adb76;\n  color: #3adb76;\n}\n\n.button.hollow.success:hover, .button.hollow.success:focus {\n  border-color: #157539;\n  color: #157539;\n}\n\n.button.hollow.warning {\n  border: 1px solid #ffae00;\n  color: #ffae00;\n}\n\n.button.hollow.warning:hover, .button.hollow.warning:focus {\n  border-color: #805700;\n  color: #805700;\n}\n\n.button.hollow.alert {\n  border: 1px solid #cc4b37;\n  color: #cc4b37;\n}\n\n.button.hollow.alert:hover, .button.hollow.alert:focus {\n  border-color: #67251a;\n  color: #67251a;\n}\n\n.button.disabled, .button[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.primary, .button[disabled].primary {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.secondary, .button[disabled].secondary {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.success, .button[disabled].success {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.warning, .button[disabled].warning {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\n.button.disabled.alert, .button[disabled].alert {\n  opacity: 0.25;\n  cursor: not-allowed;\n}\n\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}\n\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}\n\n.button.arrow-only::after {\n  top: -0.1em;\n  float: none;\n  margin-left: 0;\n}\n\n.button-group {\n  margin-bottom: 1rem;\n  font-size: 0;\n}\n\n.button-group::before, .button-group::after {\n  display: table;\n  content: ' ';\n}\n\n.button-group::after {\n  clear: both;\n}\n\n.button-group .button {\n  margin: 0;\n  margin-right: 1px;\n  margin-bottom: 1px;\n  font-size: 0.9rem;\n}\n\n.button-group .button:last-child {\n  margin-right: 0;\n}\n\n.button-group.tiny .button {\n  font-size: 0.6rem;\n}\n\n.button-group.small .button {\n  font-size: 0.75rem;\n}\n\n.button-group.large .button {\n  font-size: 1.25rem;\n}\n\n.button-group.expanded {\n  margin-right: -1px;\n}\n\n.button-group.expanded::before, .button-group.expanded::after {\n  display: none;\n}\n\n.button-group.expanded .button:first-child:last-child {\n  width: 100%;\n}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\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}\n\n.button-group.primary .button {\n  background-color: #1779ba;\n  color: #fefefe;\n}\n\n.button-group.primary .button:hover, .button-group.primary .button:focus {\n  background-color: #126195;\n  color: #fefefe;\n}\n\n.button-group.secondary .button {\n  background-color: #767676;\n  color: #fefefe;\n}\n\n.button-group.secondary .button:hover, .button-group.secondary .button:focus {\n  background-color: #5e5e5e;\n  color: #fefefe;\n}\n\n.button-group.success .button {\n  background-color: #3adb76;\n  color: #0a0a0a;\n}\n\n.button-group.success .button:hover, .button-group.success .button:focus {\n  background-color: #22bb5b;\n  color: #0a0a0a;\n}\n\n.button-group.warning .button {\n  background-color: #ffae00;\n  color: #0a0a0a;\n}\n\n.button-group.warning .button:hover, .button-group.warning .button:focus {\n  background-color: #cc8b00;\n  color: #0a0a0a;\n}\n\n.button-group.alert .button {\n  background-color: #cc4b37;\n  color: #fefefe;\n}\n\n.button-group.alert .button:hover, .button-group.alert .button:focus {\n  background-color: #a53b2a;\n  color: #fefefe;\n}\n\n.button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n  width: 100%;\n}\n\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}\n\n@media print, screen and (min-width: 40em) {\n  .button-group.stacked-for-small .button {\n    width: auto;\n    margin-bottom: 0;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .button-group.stacked-for-medium .button {\n    width: auto;\n    margin-bottom: 0;\n  }\n}\n\n@media screen and (max-width: 39.9375em) {\n  .button-group.stacked-for-small.expanded {\n    display: block;\n  }\n  .button-group.stacked-for-small.expanded .button {\n    display: block;\n    margin-right: 0;\n  }\n}\n\n.menu {\n  margin: 0;\n  list-style-type: none;\n}\n\n.menu > li {\n  display: table-cell;\n  vertical-align: middle;\n}\n\n[data-whatinput='mouse'] .menu > li {\n  outline: 0;\n}\n\n.menu > li > a {\n  display: block;\n  padding: 0.7rem 1rem;\n  line-height: 1;\n}\n\n.menu input,\n.menu select,\n.menu a,\n.menu button {\n  margin-bottom: 0;\n}\n\n.menu > li > a img,\n.menu > li > a i,\n.menu > li > a svg {\n  vertical-align: middle;\n}\n\n.menu > li > a img + span,\n.menu > li > a i + span,\n.menu > li > a svg + span {\n  vertical-align: middle;\n}\n\n.menu > li > a img,\n.menu > li > a i,\n.menu > li > a svg {\n  margin-right: 0.25rem;\n  display: inline-block;\n}\n\n.menu > li, .menu.horizontal > li {\n  display: table-cell;\n}\n\n.menu.expanded {\n  display: table;\n  width: 100%;\n  table-layout: fixed;\n}\n\n.menu.expanded > li:first-child:last-child {\n  width: 100%;\n}\n\n.menu.vertical > li {\n  display: block;\n}\n\n@media print, screen and (min-width: 40em) {\n  .menu.medium-horizontal > li {\n    display: table-cell;\n  }\n  .menu.medium-expanded {\n    display: table;\n    width: 100%;\n    table-layout: fixed;\n  }\n  .menu.medium-expanded > li:first-child:last-child {\n    width: 100%;\n  }\n  .menu.medium-vertical > li {\n    display: block;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .menu.large-horizontal > li {\n    display: table-cell;\n  }\n  .menu.large-expanded {\n    display: table;\n    width: 100%;\n    table-layout: fixed;\n  }\n  .menu.large-expanded > li:first-child:last-child {\n    width: 100%;\n  }\n  .menu.large-vertical > li {\n    display: block;\n  }\n}\n\n.menu.simple li {\n  display: inline-block;\n  vertical-align: top;\n  line-height: 1;\n}\n\n.menu.simple a {\n  padding: 0;\n}\n\n.menu.simple li {\n  margin-left: 0;\n  margin-right: 1rem;\n}\n\n.menu.simple.align-right li {\n  margin-right: 0;\n  margin-left: 1rem;\n}\n\n.menu.align-right::before, .menu.align-right::after {\n  display: table;\n  content: ' ';\n}\n\n.menu.align-right::after {\n  clear: both;\n}\n\n.menu.align-right > li {\n  float: right;\n}\n\n.menu.icon-top > li > a {\n  text-align: center;\n}\n\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}\n\n.menu.icon-top.vertical a > span {\n  margin: auto;\n}\n\n.menu.nested {\n  margin-left: 1rem;\n}\n\n.menu .active > a {\n  background: #1779ba;\n  color: #fefefe;\n}\n\n.menu.menu-bordered li {\n  border: 1px solid #e6e6e6;\n}\n\n.menu.menu-bordered li:not(:first-child) {\n  border-top: 0;\n}\n\n.menu.menu-hover li:hover {\n  background-color: #e6e6e6;\n}\n\n.menu-text {\n  padding-top: 0;\n  padding-bottom: 0;\n  padding: 0.7rem 1rem;\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n.menu-centered {\n  text-align: center;\n}\n\n.menu-centered > .menu {\n  display: inline-block;\n  vertical-align: top;\n}\n\n.no-js [data-responsive-menu] ul {\n  display: none;\n}\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: block;\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}\n\n.dropdown-pane.is-open {\n  visibility: visible;\n}\n\n.dropdown-pane.tiny {\n  width: 100px;\n}\n\n.dropdown-pane.small {\n  width: 200px;\n}\n\n.dropdown-pane.large {\n  width: 400px;\n}\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto;\n}\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0;\n}\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem;\n}\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  margin-top: -3px;\n}\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0;\n}\n\n.no-js .dropdown.menu ul {\n  display: none;\n}\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0;\n}\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  right: 100%;\n  left: auto;\n}\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%;\n}\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px;\n}\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}\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\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  }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0;\n  }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem;\n  }\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    margin-top: -3px;\n  }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0;\n  }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto;\n  }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%;\n  }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px;\n  }\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  }\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}\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  }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0;\n  }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem;\n  }\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    margin-top: -3px;\n  }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0;\n  }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto;\n  }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%;\n  }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px;\n  }\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  }\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}\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto;\n}\n\n.is-dropdown-menu.vertical {\n  width: 100px;\n}\n\n.is-dropdown-menu.vertical.align-right {\n  float: right;\n}\n\n.is-dropdown-submenu-parent {\n  position: relative;\n}\n\n.is-dropdown-submenu-parent a::after {\n  position: absolute;\n  top: 50%;\n  right: 5px;\n  margin-top: -6px;\n}\n\n.is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n  top: 100%;\n  left: auto;\n}\n\n.is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n  right: 100%;\n  left: auto;\n}\n\n.is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%;\n}\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}\n\n.is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n  right: 14px;\n}\n\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}\n\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}\n\n.is-dropdown-submenu .is-dropdown-submenu {\n  margin-top: -1px;\n}\n\n.is-dropdown-submenu > li {\n  width: 100%;\n}\n\n.is-dropdown-submenu.js-dropdown-active {\n  display: block;\n}\n\n.is-off-canvas-open {\n  overflow: hidden;\n}\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\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}\n\n.js-off-canvas-overlay.is-visible {\n  opacity: 1;\n  visibility: visible;\n}\n\n.js-off-canvas-overlay.is-closable {\n  cursor: pointer;\n}\n\n.js-off-canvas-overlay.is-overlay-absolute {\n  position: absolute;\n}\n\n.js-off-canvas-overlay.is-overlay-fixed {\n  position: fixed;\n}\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden;\n}\n\n.off-canvas {\n  position: fixed;\n  z-index: 1;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6;\n}\n\n[data-whatinput='mouse'] .off-canvas {\n  outline: 0;\n}\n\n.off-canvas.is-transition-overlap {\n  z-index: 10;\n}\n\n.off-canvas.is-transition-overlap.is-open {\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n}\n\n.off-canvas.is-open {\n  transform: translate(0, 0);\n}\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 1;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6;\n}\n\n[data-whatinput='mouse'] .off-canvas-absolute {\n  outline: 0;\n}\n\n.off-canvas-absolute.is-transition-overlap {\n  z-index: 10;\n}\n\n.off-canvas-absolute.is-transition-overlap.is-open {\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n}\n\n.off-canvas-absolute.is-open {\n  transform: translate(0, 0);\n}\n\n.position-left {\n  top: 0;\n  left: 0;\n  width: 250px;\n  height: 100%;\n  transform: translateX(-250px);\n  overflow-y: auto;\n}\n\n.position-left.is-open ~ .off-canvas-content {\n  transform: translateX(250px);\n}\n\n.position-left.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  right: 0;\n  height: 100%;\n  width: 1px;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-left.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-right {\n  top: 0;\n  right: 0;\n  width: 250px;\n  height: 100%;\n  transform: translateX(250px);\n  overflow-y: auto;\n}\n\n.position-right.is-open ~ .off-canvas-content {\n  transform: translateX(-250px);\n}\n\n.position-right.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  left: 0;\n  height: 100%;\n  width: 1px;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-right.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 250px;\n  transform: translateY(-250px);\n  overflow-x: auto;\n}\n\n.position-top.is-open ~ .off-canvas-content {\n  transform: translateY(250px);\n}\n\n.position-top.is-transition-push::after {\n  position: absolute;\n  bottom: 0;\n  left: 0;\n  height: 1px;\n  width: 100%;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-top.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  height: 250px;\n  transform: translateY(250px);\n  overflow-x: auto;\n}\n\n.position-bottom.is-open ~ .off-canvas-content {\n  transform: translateY(-250px);\n}\n\n.position-bottom.is-transition-push::after {\n  position: absolute;\n  top: 0;\n  left: 0;\n  height: 1px;\n  width: 100%;\n  box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);\n  content: \" \";\n}\n\n.position-bottom.is-transition-overlap.is-open ~ .off-canvas-content {\n  transform: none;\n}\n\n.off-canvas-content {\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n}\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-left.reveal-for-medium ~ .off-canvas-content {\n    margin-left: 250px;\n  }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-right.reveal-for-medium ~ .off-canvas-content {\n    margin-right: 250px;\n  }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-top.reveal-for-medium ~ .off-canvas-content {\n    margin-top: 250px;\n  }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 1;\n  }\n  .position-bottom.reveal-for-medium ~ .off-canvas-content {\n    margin-bottom: 250px;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-left.reveal-for-large ~ .off-canvas-content {\n    margin-left: 250px;\n  }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-right.reveal-for-large ~ .off-canvas-content {\n    margin-right: 250px;\n  }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-top.reveal-for-large ~ .off-canvas-content {\n    margin-top: 250px;\n  }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 1;\n  }\n  .position-bottom.reveal-for-large ~ .off-canvas-content {\n    margin-bottom: 250px;\n  }\n}\n\n.hide {\n  display: none !important;\n}\n\n.invisible {\n  visibility: hidden;\n}\n\n@media screen and (max-width: 39.9375em) {\n  .hide-for-small-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important;\n  }\n}\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 39.9375em) {\n  .show-for-medium {\n    display: none !important;\n  }\n}\n\n@media screen and (min-width: 40em) and (max-width: 63.9375em) {\n  .hide-for-medium-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important;\n  }\n}\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 63.9375em) {\n  .show-for-large {\n    display: none !important;\n  }\n}\n\n@media screen and (min-width: 64em) and (max-width: 74.9375em) {\n  .hide-for-large-only {\n    display: none !important;\n  }\n}\n\n@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important;\n  }\n}\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n}\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}\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important;\n}\n\n@media screen and (orientation: landscape) {\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n  }\n}\n\n@media screen and (orientation: portrait) {\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: none !important;\n  }\n}\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important;\n}\n\n@media screen and (orientation: landscape) {\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n  }\n}\n\n@media screen and (orientation: portrait) {\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: block !important;\n  }\n}\n\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::before, .clearfix::after {\n  display: table;\n  content: ' ';\n}\n\n.clearfix::after {\n  clear: both;\n}\n\n.full-width {\n  margin-left: -2.1875rem;\n  max-width: calc(100% + 70px);\n  width: calc(100% + 70px);\n}\n\n@media screen and (min-width: 64em) {\n  .full-width {\n    margin-left: -7.1875rem;\n    max-width: calc(100% + 230px);\n    width: calc(100% + 230px);\n  }\n}\n\n.image-as-background {\n  background-position: center center;\n  background-repeat: no-repeat;\n  background-size: cover;\n}\n\n.video-as-background {\n  height: 100%;\n  width: 100%;\n  display: block;\n  object-fit: cover;\n  object-position: center top;\n  position: absolute;\n  z-index: 1;\n}\n\n.svg-defs {\n  display: none;\n}\n\n.alignleft {\n  display: inline;\n  float: left;\n  margin: 0 1rem 0 0;\n}\n\n.alignright {\n  display: inline;\n  float: right;\n  margin: 0 0 0 1rem;\n}\n\n.aligncenter {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n}\n\npre {\n  background-color: #e6e6e6;\n  color: #0a0a0a;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-size: em(15);\n  font-weight: normal;\n  line-height: 1.5;\n  margin: 1rem 0 1rem;\n  overflow: auto;\n  padding: 0.125rem 0.3125rem 0.0625rem;\n  white-space: pre;\n  word-break: normal;\n  word-wrap: normal;\n}\n\ncode,\nkbd,\ntt,\nvar {\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-size: em(15);\n}\n\nabbr,\nacronym {\n  border-bottom: 1px solid #cacaca;\n  cursor: help;\n}\n\nmark,\nins {\n  text-decoration: none;\n}\n\nsup,\nsub {\n  font-size: 75%;\n  height: 0;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  bottom: 1ex;\n}\n\nsub {\n  top: 0.5ex;\n}\n\nsmall {\n  font-size: 75%;\n}\n\nbig {\n  font-size: 125%;\n}\n\n.screen-reader-text {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n}\n\n.wp-caption {\n  margin: 0 0 1rem 0;\n  max-width: 100%;\n}\n\n.wp-caption img[class*='wp-image-'] {\n  display: block;\n  margin: 0 auto;\n}\n\n.wp-caption.aligncenter {\n  margin: 0 auto 1rem auto;\n}\n\n.wp-caption.alignleft {\n  margin-right: 1rem;\n}\n\n.wp-caption.alignright {\n  margin-left: 1rem;\n}\n\n.wp-caption .wp-caption-text {\n  margin: 1rem 0;\n}\n\n.wp-caption-text {\n  text-align: center;\n}\n\n.gallery {\n  margin: 0 0 1rem 0;\n}\n\n.gallery-caption {\n  display: block;\n}\n\n.gallery-item {\n  height: 100% auto;\n  width: 100% auto;\n  display: inline-block;\n  text-align: center;\n  vertical-align: top;\n}\n\n.gallery-columns-2 .gallery-item {\n  max-width: 50%;\n}\n\n.gallery-columns-3 .gallery-item {\n  max-width: 33.33%;\n}\n\n.gallery-columns-4 .gallery-item {\n  max-width: 25%;\n}\n\n.gallery-columns-5 .gallery-item {\n  max-width: 20%;\n}\n\n.gallery-columns-6 .gallery-item {\n  max-width: 16.66%;\n}\n\n.gallery-columns-7 .gallery-item {\n  max-width: 14.28%;\n}\n\n.gallery-columns-8 .gallery-item {\n  max-width: 12.5%;\n}\n\n.gallery-columns-9 .gallery-item {\n  max-width: 11.11%;\n}\n\n.wp-smiley {\n  margin: 0;\n  padding: 0;\n  border: none;\n}\n\n.hamburger-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer;\n}\n\n.hamburger-icon::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}\n\n.hamburger-icon:hover::after {\n  background: #cacaca;\n  box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;\n}\n\n.admin-bar .off-canvas {\n  padding-top: 3.5rem;\n}\n\n.off-canvas .is-accordion-submenu {\n  padding-left: 1rem;\n}\n\n.content-block {\n  padding: 1rem;\n}\n\n.comments-area {\n  border-top: 1px solid #cacaca;\n  margin: 1rem 0;\n}\n\n@media screen and (min-width: 85.375em) {\n  .comments-area {\n    margin-left: auto;\n    margin-right: auto;\n  }\n}\n\n.comments-area .comment-reply-title {\n  margin-top: 1rem;\n}\n\n.comments-area .comments-title {\n  font-size: em(24);\n  margin-top: 1rem;\n}\n\n.comments-area .comment-notes {\n  font-size: em(16);\n  margin-top: 1rem;\n}\n\n.comment-form-comment label,\n.comment-form-author label,\n.comment-form-email label,\n.comment-form-url label {\n  float: left;\n  font-size: em(16);\n  text-transform: uppercase;\n  width: 100%;\n}\n\n.comment-form {\n  width: 100%;\n}\n\n.comment-form::before, .comment-form::after {\n  display: table;\n  content: ' ';\n}\n\n.comment-form::after {\n  clear: both;\n}\n\n.comment-form input:not(.submit) {\n  clear: both;\n  transition: border 0.2s ease-in-out;\n  width: 100%;\n}\n\n@media screen and (min-width: 40em) {\n  .comment-form input:not(.submit) {\n    max-width: 15.625rem;\n  }\n}\n\n.comment-form textarea {\n  max-width: 54.375rem;\n  transition: border 0.2s ease-in-out;\n}\n\n.comment-form .form-submit {\n  margin: 0;\n}\n\n.comment-form input[type='submit'] {\n  width: 12.25rem;\n}\n\n.comment-list {\n  margin: 0;\n  padding: 0;\n  list-style: none;\n  margin: 0;\n}\n\n.comment-list::before, .comment-list::after {\n  display: table;\n  content: ' ';\n}\n\n.comment-list::after {\n  clear: both;\n}\n\n.comment-list .even:not(.bypostauthor) > .comment-body {\n  background-color: #cacaca;\n}\n\n.comment-list .comment-body {\n  margin: 1rem 0;\n  padding: 1rem;\n}\n\n.comment-list .comment-content {\n  margin: 1rem 0;\n  max-width: 58.5rem;\n}\n\n.comment-list .comment-meta {\n  margin: 0 0 1rem 0;\n}\n\n.comment-list .comment-meta::before, .comment-list .comment-meta::after {\n  display: table;\n  content: ' ';\n}\n\n.comment-list .comment-meta::after {\n  clear: both;\n}\n\n.comment-list .comment-author {\n  line-height: 1;\n}\n\n.comment-list .comment-metadata {\n  line-height: 1;\n  margin-top: 0.3125rem;\n}\n\n.comment-list .comment-metadata a {\n  color: #0a0a0a;\n  text-decoration: none;\n}\n\n.comment-list .comment-metadata time,\n.comment-list .comment-metadata .comment-edit-link {\n  font-size: em(12);\n}\n\n.comment-list .avatar {\n  border-radius: 50%;\n  float: left;\n  margin: 0 1rem 0 0;\n}\n\n.comment-list .bypostauthor {\n  background-color: #767676;\n  display: block;\n}\n\n.comment-list .comment-reply-link {\n  font-weight: 700;\n}\n\n.comment-list pre,\n.comment-list code {\n  margin: 0;\n  width: 100%;\n}\n\n.comment-list .children {\n  list-style: none;\n  margin: 2rem 0;\n  padding-left: 1rem;\n}\n\n@media screen and (min-width: 40em) {\n  .comment-list .children {\n    padding-left: 2rem;\n  }\n}\n\n@media screen and (min-width: 48em) {\n  .comment-list .children {\n    padding-left: 4rem;\n  }\n}\n\n.comment-list .children .depth-4 .comment-author,\n.comment-list .children .depth-5 .comment-author,\n.comment-list .children .depth-6 .comment-author,\n.comment-list .children .depth-7 .comment-author,\n.comment-list .children .depth-8 .comment-author,\n.comment-list .children .depth-9 .comment-author,\n.comment-list .children .depth-10 .comment-author {\n  line-height: 1.25;\n}\n\n@media screen and (min-width: 40em) {\n  .comment-list .children .depth-4 .comment-author,\n  .comment-list .children .depth-5 .comment-author,\n  .comment-list .children .depth-6 .comment-author,\n  .comment-list .children .depth-7 .comment-author,\n  .comment-list .children .depth-8 .comment-author,\n  .comment-list .children .depth-9 .comment-author,\n  .comment-list .children .depth-10 .comment-author {\n    line-height: 1;\n  }\n}\n\n.comment-list .comment-respond {\n  background-color: #fefefe;\n  padding: 1rem 0;\n}\n\n@media screen and (min-width: 40em) {\n  .comment-list .comment-respond {\n    padding-left: 2rem;\n    padding-right: 2rem;\n  }\n}\n\n.comment-list .comment-respond .comment-reply-title a {\n  display: inline-block;\n  text-transform: lowercase;\n}\n\n.comment-list .comment-respond .comment-reply-title a::before {\n  content: '(';\n}\n\n.comment-list .comment-respond .comment-reply-title a::after {\n  content: ')';\n}\n\n.comment-list .comment-respond .form-submit {\n  margin: 0;\n}\n\n.comment-list .comment-respond .form-submit input[type='submit'] {\n  margin-top: 0.3125rem;\n}\n\n.sticky,\n.comments-link {\n  display: block;\n}\n\n.hentry {\n  margin: 0 0 2rem 0;\n}\n\n.byline,\n.updated:not(.published) {\n  display: none;\n}\n\n.single .byline,\n.group-blog .byline {\n  display: inline;\n}\n\n.page-content,\n.entry-content,\n.entry-summary {\n  margin: 2rem 0 0;\n}\n\n.page-links {\n  clear: both;\n  margin: 0 0 2rem 0;\n}\n\n.tags-links {\n  margin-left: 2rem;\n}\n\n.edit-link a {\n  font-size: em(12);\n  text-transform: lowercase;\n}\n\n.edit-link a::before {\n  content: '(';\n}\n\n.edit-link a::after {\n  content: ')';\n}\n\n.blog .format-aside .entry-title,\n.archive .format-aside .entry-title {\n  display: none;\n}\n\n.site-main .comment-navigation, .site-main\n.posts-navigation, .site-main\n.post-navigation {\n  margin: 0 0 1rem 0;\n  overflow: hidden;\n}\n\n.comment-navigation .nav-previous,\n.posts-navigation .nav-previous,\n.post-navigation .nav-previous {\n  height: 50% auto;\n  width: 50% auto;\n  float: left;\n}\n\n.comment-navigation .nav-next,\n.posts-navigation .nav-next,\n.post-navigation .nav-next {\n  height: 50% auto;\n  width: 50% auto;\n  float: right;\n  text-align: right;\n}\n\n.entry-title,\n.entry-content,\n.comments-title,\n.comment-content,\n.widget-title,\n.widget {\n  word-break: keep-all;\n  word-wrap: break-word;\n}\n\n.site-footer {\n  margin: 2rem auto;\n}\n\n.site-header {\n  margin: 2rem auto;\n}\n\n.hero {\n  overflow-y: hidden;\n  position: relative;\n  z-index: 1;\n}\n\n.hero::after {\n  height: 100%;\n  width: 100%;\n  position: absolute;\n  top: 0;\n  right: 0;\n  background-color: rgba(10, 10, 10, 0.7);\n  content: '';\n  z-index: 2;\n}\n\n.hero-content {\n  padding: 4rem 0;\n  position: relative;\n  z-index: 3;\n  padding: 8rem 0;\n}\n\n.hero-headline {\n  font-size: 3rem;\n  line-height: 1.2;\n  margin-bottom: 2rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .hero-headline {\n    margin-bottom: 1rem;\n  }\n}\n\n.hero-text {\n  font-size: 1.125rem;\n}\n\n@media print, screen and (min-width: 40em) {\n  .hero-text {\n    font-size: 1.5rem;\n  }\n}\n\n.hero-button {\n  margin-top: 0.625rem;\n}\n","/**\n * Theme Name: _s\n * Theme URI: http://underscores.me/\n * Author: Automattic\n * Author URI: http://automattic.com/\n * Description: Hi. I'm a starter theme called <code>_s</code>, or <em>underscores</em>, if you like. I'm a theme meant for hacking so don't use me as a <em>Parent Theme</em>. Instead try turning me into the next, most awesome, WordPress theme out there. That's what I'm here for.\n * Version: 1.0.0\n * License: GNU General Public License v2 or later\n * License URI: http://www.gnu.org/licenses/gpl-2.0.html\n * Text Domain: _s\n * Tags: custom\n *\n * This theme, like WordPress, is licensed under the GPL.\n *\n * Based on Underscores http://underscores.me/, (C) 2012-2017 Automattic, Inc.\n *\n */\n\n// Load Foundation.\n@import 'foundation/index';\n\n// Load custom variables, functions, and mixins.\n@import 'utilities/variables/index';\n@import 'utilities/functions/index';\n@import 'utilities/mixins/index';\n\n// Our most basic level file type (variables, typography, etc).\n@import 'base/index';\n\n// Our second level of file types that make up base files (forms, lists, etc).\n@import 'components/index';\n\n// Large parts of our site that make up components (header, footer, etc).\n@import 'sections/index';\n\n// Our largest file types that encompass overall individual page styles.\n@import 'pages/index';\n\n// Third-party file types such as plugins.\n@import 'plugins/index';\n","/**\n * Foundation for Sites by ZURB\n * Version 6.3.1\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import '../_vendor/normalize-scss/sass/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/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// Sass utilities\n@import 'util/util';\n\n// Global variables and styles\n@import 'global';\n\n// Components\n@import 'grid/grid';\n@import 'typography/typography';\n@import 'forms/forms';\n@import 'components/visibility';\n@import 'components/float';\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/accordion-menu';\n@import 'components/accordion';\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/close-button';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n@import 'components/dropdown';\n@import 'components/flex';\n@import 'components/responsive-embed';\n@import 'components/label';\n@import 'components/media-object';\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/off-canvas';\n@import 'components/orbit';\n@import 'components/pagination';\n@import 'components/progress-bar';\n@import 'components/reveal';\n@import 'components/slider';\n@import 'components/sticky';\n@import 'components/switch';\n@import 'components/table';\n@import 'components/tabs';\n@import 'components/title-bar';\n@import 'components/top-bar';\n@import 'components/thumbnail';\n@import 'components/tooltip';\n\n@mixin foundation-everything($flex: false) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  @include foundation-global-styles;\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @include foundation-flex-grid;\n  }\n  @include foundation-typography;\n  @include foundation-forms;\n  @include foundation-button;\n  @include foundation-accordion;\n  @include foundation-accordion-menu;\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-button-group;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-close-button;\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown;\n  @include foundation-dropdown-menu;\n  @include foundation-responsive-embed;\n  @include foundation-label;\n  @include foundation-media-object;\n  @include foundation-off-canvas;\n  @include foundation-orbit;\n  @include foundation-pagination;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-sticky;\n  @include foundation-reveal;\n  @include foundation-switch;\n  @include foundation-table;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  @include foundation-title-bar;\n  @include foundation-tooltip;\n  @include foundation-top-bar;\n  @include foundation-visibility-classes;\n  @include foundation-float-classes;\n\n  @if $flex {\n    @include foundation-flex-classes;\n  }\n}\n","// Helper function for the normalize() mixin.\n@function _normalize-include($section, $exclude: null) {\n  // Initialize the global variables needed by this function.\n  @if not global_variable_exists(_normalize-include) {\n    $_normalize-include: () !global;\n    $_normalize-exclude: () !global;\n  }\n  // Since we are given 2 parameters, set the global variables.\n  @if $exclude != null {\n    $include: $section;\n    // Sass doesn't have static variables, so the work-around is to stuff these\n    // values into global variables so we can access them in future calls.\n    $_normalize-include: if(type-of($include) == 'list', $include, ($include)) !global;\n    $_normalize-exclude: if(type-of($exclude) == 'list', $exclude, ($exclude)) !global;\n    @return true;\n  }\n\n  // Check if $section is in the $include list.\n  @if index($_normalize-include, $section) {\n    @return true;\n  }\n  // If $include is set to (all), make sure $section is not in $exclude.\n  @else if not index($_normalize-exclude, $section) and index($_normalize-include, all) {\n    @return true;\n  }\n  @return false;\n}\n\n@mixin normalize($include: (all), $exclude: ()) {\n  // Initialize the helper function by passing it this mixin's parameters.\n  $init: _normalize-include($include, $exclude);\n\n  // If we've customized any font variables, we'll need extra properties.\n  @if $base-font-size != 16px\n    or $base-line-height != 24px\n    or $base-unit != 'em'\n    or $h1-font-size != 2    * $base-font-size\n    or $h2-font-size != 1.5  * $base-font-size\n    or $h3-font-size != 1.17 * $base-font-size\n    or $h4-font-size != 1    * $base-font-size\n    or $h5-font-size != 0.83 * $base-font-size\n    or $h6-font-size != 0.67 * $base-font-size {\n    $normalize-vertical-rhythm: true !global;\n  }\n\n  /*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */\n\n  @if _normalize-include(document) {\n    /* Document\n       ========================================================================== */\n\n    /**\n     * 1. Change the default font family in all browsers (opinionated).\n     * 2. Correct the line height in all browsers.\n     * 3. Prevent adjustments of font size after orientation changes in\n     *    IE on Windows Phone and in iOS.\n     */\n\n    html {\n      font-family: $base-font-family; /* 1 */\n      @if $normalize-vertical-rhythm {\n        // Correct old browser bug that prevented accessible resizing of text\n        // when root font-size is set with px or em.\n        font-size: ($base-font-size / 16px) * 100%;\n        line-height: ($base-line-height / $base-font-size) * 1em; /* 2 */\n      }\n      @else {\n        line-height: 1.15; /* 2 */\n      }\n      -ms-text-size-adjust: 100%; /* 3 */\n      -webkit-text-size-adjust: 100%; /* 3 */\n    }\n  }\n\n  @if _normalize-include(sections) {\n    /* Sections\n       ========================================================================== */\n\n    /**\n     * Remove the margin in all browsers (opinionated).\n     */\n\n    body {\n      margin: 0;\n    }\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    article,\n    aside,\n    footer,\n    header,\n    nav,\n    section {\n      display: block;\n    }\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\n    h1 {\n      @include normalize-font-size($h1-font-size);\n      @if $normalize-vertical-rhythm {\n        @include normalize-line-height($h1-font-size);\n      }\n\n      @if $normalize-vertical-rhythm {\n        /* Set 1 unit of vertical rhythm on the top and bottom margins. */\n        @include normalize-margin(1 0, $h1-font-size);\n      }\n      @else {\n        margin: 0.67em 0;\n      }\n    }\n\n    @if $normalize-vertical-rhythm {\n      h2 {\n        @include normalize-font-size($h2-font-size);\n        @include normalize-line-height($h2-font-size);\n        @include normalize-margin(1 0, $h2-font-size);\n      }\n\n      h3 {\n        @include normalize-font-size($h3-font-size);\n        @include normalize-line-height($h3-font-size);\n        @include normalize-margin(1 0, $h3-font-size);\n      }\n\n      h4 {\n        @include normalize-font-size($h4-font-size);\n        @include normalize-line-height($h4-font-size);\n        @include normalize-margin(1 0, $h4-font-size);\n      }\n\n      h5 {\n        @include normalize-font-size($h5-font-size);\n        @include normalize-line-height($h5-font-size);\n        @include normalize-margin(1 0, $h5-font-size);\n      }\n\n      h6 {\n        @include normalize-font-size($h6-font-size);\n        @include normalize-line-height($h6-font-size);\n        @include normalize-margin(1 0, $h6-font-size);\n      }\n    }\n  }\n\n  @if _normalize-include(grouping) {\n    /* Grouping content\n       ========================================================================== */\n\n    @if $normalize-vertical-rhythm {\n      /**\n       * Set 1 unit of vertical rhythm on the top and bottom margin.\n       */\n\n      blockquote {\n        @include normalize-margin(1 $indent-amount);\n      }\n\n      dl,\n      ol,\n      ul {\n        @include normalize-margin(1 0);\n      }\n\n      /**\n       * Turn off margins on nested lists.\n       */\n\n      ol,\n      ul {\n        ol,\n        ul {\n          margin: 0;\n        }\n      }\n\n      dd {\n        margin: 0 0 0 $indent-amount;\n      }\n\n      ol,\n      ul {\n        padding: 0 0 0 $indent-amount;\n      }\n    }\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    figcaption,\n    figure {\n      display: block;\n    }\n\n    /**\n     * Add the correct margin in IE 8.\n     */\n\n    figure {\n      @if $normalize-vertical-rhythm {\n        @include normalize-margin(1 $indent-amount);\n      }\n      @else {\n        margin: 1em $indent-amount;\n      }\n    }\n\n    /**\n     * 1. Add the correct box sizing in Firefox.\n     * 2. Show the overflow in Edge and IE.\n     */\n\n    hr {\n      box-sizing: content-box; /* 1 */\n      height: 0; /* 1 */\n      overflow: visible; /* 2 */\n    }\n\n    /**\n     * Add the correct display in IE.\n     */\n\n    main {\n      display: block;\n    }\n\n    @if $normalize-vertical-rhythm {\n      /**\n       * Set 1 unit of vertical rhythm on the top and bottom margin.\n       */\n\n      p,\n      pre {\n        @include normalize-margin(1 0);\n      }\n    }\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\n    pre {\n      font-family: monospace, monospace; /* 1 */\n      font-size: 1em; /* 2 */\n    }\n  }\n\n  @if _normalize-include(links) {\n    /* Links\n       ========================================================================== */\n\n    /**\n     * 1. Remove the gray background on active links in IE 10.\n     * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.\n     */\n\n    a {\n      background-color: transparent; /* 1 */\n      -webkit-text-decoration-skip: objects; /* 2 */\n    }\n\n    /**\n     * Remove the outline on focused links when they are also active or hovered\n     * in all browsers (opinionated).\n     */\n\n    a:active,\n    a:hover {\n      outline-width: 0;\n    }\n  }\n\n  @if _normalize-include(text) {\n    /* Text-level semantics\n       ========================================================================== */\n\n    /**\n     * 1. Remove the bottom border in Firefox 39-.\n     * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n     */\n\n    abbr[title] {\n      border-bottom: none; /* 1 */\n      text-decoration: underline; /* 2 */\n      text-decoration: underline dotted; /* 2 */\n    }\n\n    /**\n     * Prevent the duplicate application of `bolder` by the next rule in Safari 6.\n     */\n\n    b,\n    strong {\n      font-weight: inherit;\n    }\n\n    /**\n     * Add the correct font weight in Chrome, Edge, and Safari.\n     */\n\n    b,\n    strong {\n      font-weight: bolder;\n    }\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\n    code,\n    kbd,\n    samp {\n      font-family: monospace, monospace; /* 1 */\n      font-size: 1em; /* 2 */\n    }\n\n    /**\n     * Add the correct font style in Android 4.3-.\n     */\n\n    dfn {\n      font-style: italic;\n    }\n\n    /**\n     * Add the correct background and color in IE 9-.\n     */\n\n    mark {\n      background-color: #ff0;\n      color: #000;\n    }\n\n    /**\n     * Add the correct font size in all browsers.\n     */\n\n    small {\n      font-size: 80%;\n    }\n\n    /**\n     * Prevent `sub` and `sup` elements from affecting the line height in\n     * all browsers.\n     */\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\n  @if _normalize-include(embedded) {\n    /* Embedded content\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    audio,\n    video {\n      display: inline-block;\n    }\n\n    /**\n     * Add the correct display in iOS 4-7.\n     */\n\n    audio:not([controls]) {\n      display: none;\n      height: 0;\n    }\n\n    /**\n     * Remove the border on images inside links in IE 10-.\n     */\n\n    img {\n      border-style: none;\n    }\n\n    /**\n     * Hide the overflow in IE.\n     */\n\n    svg:not(:root) {\n      overflow: hidden;\n    }\n  }\n\n  @if _normalize-include(forms) {\n    /* Forms\n       ========================================================================== */\n\n    /**\n     * 1. Change the font styles in all browsers (opinionated).\n     * 2. Remove the margin in Firefox and Safari.\n     */\n\n    button,\n    input,\n    optgroup,\n    select,\n    textarea {\n      font-family: $base-font-family; /* 1 */\n      font-size: 100%; /* 1 */\n      @if $normalize-vertical-rhythm {\n        line-height: ($base-line-height / $base-font-size) * 1em; /* 1 */\n      }\n      @else {\n        line-height: 1.15; /* 1 */\n      }\n      margin: 0; /* 2 */\n    }\n\n    /**\n     * Show the overflow in IE.\n     */\n\n    button {\n      overflow: visible;\n    }\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\n    button,\n    select { /* 1 */\n      text-transform: none;\n    }\n\n    /**\n     * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`\n     *    controls in Android 4.\n     * 2. Correct the inability to style clickable types in iOS and Safari.\n     */\n\n    button,\n    html [type=\"button\"], /* 1 */\n    [type=\"reset\"],\n    [type=\"submit\"] {\n      -webkit-appearance: button; /* 2 */\n    }\n\n    button,\n    [type=\"button\"],\n    [type=\"reset\"],\n    [type=\"submit\"] {\n\n      /**\n       * Remove the inner border and padding in Firefox.\n       */\n\n      &::-moz-focus-inner {\n        border-style: none;\n        padding: 0;\n      }\n\n      /**\n       * Restore the focus styles unset by the previous rule.\n       */\n\n      &:-moz-focusring {\n        outline: 1px dotted ButtonText;\n      }\n    }\n\n    /**\n     * Show the overflow in Edge.\n     */\n\n    input {\n      overflow: visible;\n    }\n\n    /**\n     * 1. Add the correct box sizing in IE 10-.\n     * 2. Remove the padding in IE 10-.\n     */\n\n    [type=\"checkbox\"],\n    [type=\"radio\"] {\n      box-sizing: border-box; /* 1 */\n      padding: 0; /* 2 */\n    }\n\n    /**\n     * Correct the cursor style of increment and decrement buttons in Chrome.\n     */\n\n    [type=\"number\"]::-webkit-inner-spin-button,\n    [type=\"number\"]::-webkit-outer-spin-button {\n      height: auto;\n    }\n\n    /**\n     * 1. Correct the odd appearance in Chrome and Safari.\n     * 2. Correct the outline style in Safari.\n     */\n\n    [type=\"search\"] {\n      -webkit-appearance: textfield; /* 1 */\n      outline-offset: -2px; /* 2 */\n\n      /**\n       * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.\n       */\n\n      &::-webkit-search-cancel-button,\n      &::-webkit-search-decoration {\n        -webkit-appearance: none;\n      }\n    }\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\n    ::-webkit-file-upload-button {\n      -webkit-appearance: button; /* 1 */\n      font: inherit; /* 2 */\n    }\n\n    /**\n     * Change the border, margin, and padding in all browsers (opinionated).\n     */\n\n    fieldset {\n      border: 1px solid #c0c0c0;\n      margin: 0 2px;\n      padding: 0.35em 0.625em 0.75em;\n    }\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\n    legend {\n      box-sizing: border-box; /* 1 */\n      display: table; /* 1 */\n      max-width: 100%; /* 1 */\n      padding: 0; /* 3 */\n      color: inherit; /* 2 */\n      white-space: normal; /* 1 */\n    }\n\n    /**\n     * 1. Add the correct display in IE 9-.\n     * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.\n     */\n\n    progress {\n      display: inline-block; /* 1 */\n      vertical-align: baseline; /* 2 */\n    }\n\n    /**\n     * Remove the default vertical scrollbar in IE.\n     */\n\n    textarea {\n      overflow: auto;\n    }\n  }\n\n  @if _normalize-include(interactive) {\n    /* Interactive\n       ========================================================================== */\n\n    /*\n     * Add the correct display in Edge, IE, and Firefox.\n     */\n\n    details {\n      display: block;\n    }\n\n    /*\n     * Add the correct display in all browsers.\n     */\n\n    summary {\n      display: list-item;\n    }\n\n    /*\n     * Add the correct display in IE 9-.\n     */\n\n    menu {\n      display: block;\n\n      @if $normalize-vertical-rhythm {\n        /*\n         * 1. Set 1 unit of vertical rhythm on the top and bottom margin.\n         * 2. Set consistent space for the list style image.\n         */\n\n        @include normalize-margin(1 0); /* 1 */\n        padding: 0 0 0 $indent-amount; /* 2 */\n\n        /**\n         * Turn off margins on nested lists.\n         */\n\n        menu &,\n        ol &,\n        ul & {\n          margin: 0;\n        }\n      }\n    }\n  }\n\n  @if _normalize-include(scripting) {\n    /* Scripting\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 9-.\n     */\n\n    canvas {\n      display: inline-block;\n    }\n\n    /**\n     * Add the correct display in IE.\n     */\n\n    template {\n      display: none;\n    }\n  }\n\n  @if _normalize-include(hidden) {\n    /* Hidden\n       ========================================================================== */\n\n    /**\n     * Add the correct display in IE 10-.\n     */\n\n    [hidden] {\n      display: none;\n    }\n  }\n}\n","//\n// Variables\n//\n// You can override the default values by setting the variables in your Sass\n// before importing the normalize-scss library.\n\n// The font size set on the root html element.\n$base-font-size: 16px !default;\n\n// The base line height determines the basic unit of vertical rhythm.\n$base-line-height: 24px !default;\n\n// The length unit in which to output vertical rhythm values.\n// Supported values: px, em, rem.\n$base-unit: 'em' !default;\n\n// The default font family.\n$base-font-family: sans-serif !default;\n\n// The font sizes for h1-h6.\n$h1-font-size: 2    * $base-font-size !default;\n$h2-font-size: 1.5  * $base-font-size !default;\n$h3-font-size: 1.17 * $base-font-size !default;\n$h4-font-size: 1    * $base-font-size !default;\n$h5-font-size: 0.83 * $base-font-size !default;\n$h6-font-size: 0.67 * $base-font-size !default;\n\n// The amount lists and blockquotes are indented.\n$indent-amount: 40px !default;\n\n// The following variable controls whether normalize-scss will output\n// font-sizes, line-heights and block-level top/bottom margins that form a basic\n// vertical rhythm on the page, which differs from the original Normalize.css.\n// However, changing any of the variables above will cause\n// $normalize-vertical-rhythm to be automatically set to true.\n$normalize-vertical-rhythm: false !default;\n","//\n// Vertical Rhythm\n//\n// This is the minimal amount of code needed to create vertical rhythm in our\n// CSS. If you are looking for a robust solution, look at the excellent Typey\n// library. @see https://github.com/jptaranto/typey\n\n@function normalize-rhythm($value, $relative-to: $base-font-size, $unit: $base-unit) {\n  @if unit($value) != px {\n    @error \"The normalize vertical-rhythm module only supports px inputs. The typey library is better.\";\n  }\n  @if $unit == rem {\n    @return ($value / $base-font-size) * 1rem;\n  }\n  @else if $unit == em {\n    @return ($value / $relative-to) * 1em;\n  }\n  @else { // $unit == px\n    @return $value;\n  }\n}\n\n@mixin normalize-font-size($value, $relative-to: $base-font-size) {\n  @if unit($value) != 'px' {\n    @error \"normalize-font-size() only supports px inputs. The typey library is better.\";\n  }\n  font-size: normalize-rhythm($value, $relative-to);\n}\n\n@mixin normalize-rhythm($property, $values, $relative-to: $base-font-size) {\n  $value-list: $values;\n  $sep: space;\n  @if type-of($values) == 'list' {\n    $sep: list-separator($values);\n  }\n  @else {\n    $value-list: append((), $values);\n  }\n\n  $normalized-values: ();\n  @each $value in $value-list {\n    @if unitless($value) and $value != 0 {\n      $value: $value * normalize-rhythm($base-line-height, $relative-to);\n    }\n    $normalized-values: append($normalized-values, $value, $sep);\n  }\n  #{$property}: $normalized-values;\n}\n\n@mixin normalize-margin($values, $relative-to: $base-font-size) {\n  @include normalize-rhythm(margin, $values, $relative-to);\n}\n\n@mixin normalize-line-height($font-size, $min-line-padding: 2px) {\n  $lines: ceil($font-size / $base-line-height);\n  // If lines are cramped include some extra leading.\n  @if ($lines * $base-line-height - $font-size) < ($min-line-padding * 2) {\n    $lines: $lines + 1;\n  }\n  @include normalize-rhythm(line-height, $lines, $font-size);\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable force-attribute-nesting, force-pseudo-nesting, no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\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 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/// 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: false !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 variables used for colors\n$primary-color: get-color(primary);\n$secondary-color: get-color(secondary);\n$success-color: get-color(success);\n$warning-color: get-color(warning);\n$alert-color: get-color(alert);\n\n@mixin foundation-global-styles {\n  @include -zf-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;\n      -moz-osx-font-smoothing: grayscale;\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\n    padding: 0;\n\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n\n    line-height: 1;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\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\n/// Loads normalize.css.\n/// @access private\n@mixin -zf-normalize {\n  @include normalize();\n}\n","//--------------------------------------------------------------\n// Foundation for Sites Settings\n//\n// http://foundation.zurb.com/sites/docs/sass.html#the-settings-file\n//--------------------------------------------------------------\n//\n//  Table of Contents:\n//\n//   1. Global\n//   2. Breakpoints\n//   3. The Grid\n//   4. Base Typography\n//   5. Typography Helpers\n//   6. Abide\n//   7. Accordion\n//   8. Accordion Menu\n//   9. Badge\n//  10. Breadcrumbs\n//  11. Button\n//  12. Button Group\n//  13. Callout\n//  14. Card\n//  15. Close Button\n//  16. Drilldown\n//  17. Dropdown\n//  18. Dropdown Menu\n//  19. Forms\n//  20. Label\n//  21. Media Object\n//  22. Menu\n//  23. Meter\n//  24. Off-canvas\n//  25. Orbit\n//  26. Pagination\n//  27. Progress Bar\n//  28. Responsive Embed\n//  29. Reveal\n//  30. Slider\n//  31. Switch\n//  32. Table\n//  33. Tabs\n//  34. Thumbnail\n//  35. Title Bar\n//  36. Tooltip\n//  37. Top Bar\n\n// 1. Global\n// ---------\n\n$global-font-size: 100%;\n$global-width: rem-calc(960);\n$global-lineheight: 1.5;\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n);\n$light-gray: #e6e6e6;\n$medium-gray: #cacaca;\n$dark-gray: #8a8a8a;\n$black: #0a0a0a;\n$white: #fefefe;\n$body-background: $white;\n$body-font-color: $black;\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;\n$body-antialiased: true;\n$global-margin: 1rem;\n$global-padding: 1rem;\n$global-weight-normal: normal;\n$global-weight-bold: bold;\n$global-radius: 0;\n$global-text-direction: ltr;\n$global-flexbox: false;\n$print-transparent-backgrounds: true;\n\n@include add-foundation-colors;\n\n// 2. Breakpoints\n// --------------\n\n$breakpoints: (\n  small: 0,\n  medium: 640px,\n  large: 1024px,\n  xlarge: 1200px,\n  xxlarge: 1440px,\n);\n$print-breakpoint: large;\n$breakpoint-classes: (small medium large);\n\n// 3. The Grid\n// -----------\n\n$grid-row-width: $global-width;\n$grid-column-count: 12;\n$grid-column-gutter: (\n  small: 20px,\n  medium: 30px,\n);\n$grid-column-align-edge: true;\n$block-grid-max: 8;\n\n// 4. Base Typography\n// ------------------\n\n$header-font-family: $body-font-family;\n$header-font-weight: $global-weight-normal;\n$header-font-style: normal;\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace;\n$header-color: inherit;\n$header-lineheight: 1.4;\n$header-margin-bottom: 0.5rem;\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);\n$header-text-rendering: optimizeLegibility;\n$small-font-size: 80%;\n$header-small-font-color: $medium-gray;\n$paragraph-lineheight: 1.6;\n$paragraph-margin-bottom: 1rem;\n$paragraph-text-rendering: optimizeLegibility;\n$code-color: $black;\n$code-font-family: $font-family-monospace;\n$code-font-weight: $global-weight-normal;\n$code-background: $light-gray;\n$code-border: 1px solid $medium-gray;\n$code-padding: rem-calc(2 5 1);\n$anchor-color: $primary-color;\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%);\n$anchor-text-decoration: none;\n$anchor-text-decoration-hover: none;\n$hr-width: $global-width;\n$hr-border: 1px solid $medium-gray;\n$hr-margin: rem-calc(20) auto;\n$list-lineheight: $paragraph-lineheight;\n$list-margin-bottom: $paragraph-margin-bottom;\n$list-style-type: disc;\n$list-style-position: outside;\n$list-side-margin: 1.25rem;\n$list-nested-side-margin: 1.25rem;\n$defnlist-margin-bottom: 1rem;\n$defnlist-term-weight: $global-weight-bold;\n$defnlist-term-margin-bottom: 0.3rem;\n$blockquote-color: $dark-gray;\n$blockquote-padding: rem-calc(9 20 0 19);\n$blockquote-border: 1px solid $medium-gray;\n$cite-font-size: rem-calc(13);\n$cite-color: $dark-gray;\n$cite-pseudo-content: '\\2014 \\0020';\n$keystroke-font: $font-family-monospace;\n$keystroke-color: $black;\n$keystroke-background: $light-gray;\n$keystroke-padding: rem-calc(2 4 0);\n$keystroke-radius: $global-radius;\n$abbr-underline: 1px dotted $black;\n\n// 5. Typography Helpers\n// ---------------------\n\n$lead-font-size: $global-font-size * 1.25;\n$lead-lineheight: 1.6;\n$subheader-lineheight: 1.4;\n$subheader-color: $dark-gray;\n$subheader-font-weight: $global-weight-normal;\n$subheader-margin-top: 0.2rem;\n$subheader-margin-bottom: 0.5rem;\n$stat-font-size: 2.5rem;\n\n// 6. Abide\n// --------\n\n$abide-inputs: true;\n$abide-labels: true;\n$input-background-invalid: get-color(alert);\n$form-label-color-invalid: get-color(alert);\n$input-error-color: get-color(alert);\n$input-error-font-size: rem-calc(12);\n$input-error-font-weight: $global-weight-bold;\n\n// 7. Accordion\n// ------------\n\n$accordion-background: $white;\n$accordion-plusminus: true;\n$accordion-title-font-size: rem-calc(12);\n$accordion-item-color: $primary-color;\n$accordion-item-background-hover: $light-gray;\n$accordion-item-padding: 1.25rem 1rem;\n$accordion-content-background: $white;\n$accordion-content-border: 1px solid $light-gray;\n$accordion-content-color: $body-font-color;\n$accordion-content-padding: 1rem;\n\n// 8. Accordion Menu\n// -----------------\n\n$accordionmenu-arrows: true;\n$accordionmenu-arrow-color: $primary-color;\n$accordionmenu-arrow-size: 6px;\n\n// 9. Badge\n// --------\n\n$badge-background: $primary-color;\n$badge-color: $white;\n$badge-color-alt: $black;\n$badge-palette: $foundation-palette;\n$badge-padding: 0.3em;\n$badge-minwidth: 2.1em;\n$badge-font-size: 0.6rem;\n\n// 10. Breadcrumbs\n// ---------------\n\n$breadcrumbs-margin: 0 0 $global-margin 0;\n$breadcrumbs-item-font-size: rem-calc(11);\n$breadcrumbs-item-color: $primary-color;\n$breadcrumbs-item-color-current: $black;\n$breadcrumbs-item-color-disabled: $medium-gray;\n$breadcrumbs-item-margin: 0.75rem;\n$breadcrumbs-item-uppercase: true;\n$breadcrumbs-item-slash: true;\n\n// 11. Button\n// ----------\n\n$button-padding: 0.85em 1em;\n$button-margin: 0 0 $global-margin 0;\n$button-fill: solid;\n$button-background: $primary-color;\n$button-background-hover: scale-color($button-background, $lightness: -15%);\n$button-color: $white;\n$button-color-alt: $black;\n$button-radius: $global-radius;\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n);\n$button-palette: $foundation-palette;\n$button-opacity-disabled: 0.25;\n$button-background-hover-lightness: -20%;\n$button-hollow-hover-lightness: -50%;\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out;\n\n// 12. Button Group\n// ----------------\n\n$buttongroup-margin: 1rem;\n$buttongroup-spacing: 1px;\n$buttongroup-child-selector: '.button';\n$buttongroup-expand-max: 6;\n$buttongroup-radius-on-each: true;\n\n// 13. Callout\n// -----------\n\n$callout-background: $white;\n$callout-background-fade: 85%;\n$callout-border: 1px solid rgba($black, 0.25);\n$callout-margin: 0 0 1rem 0;\n$callout-padding: 1rem;\n$callout-font-color: $body-font-color;\n$callout-font-color-alt: $body-background;\n$callout-radius: $global-radius;\n$callout-link-tint: 30%;\n\n// 14. Card\n// --------\n\n$card-background: $white;\n$card-font-color: $body-font-color;\n$card-divider-background: $light-gray;\n$card-border: 1px solid $light-gray;\n$card-shadow: none;\n$card-border-radius: $global-radius;\n$card-padding: $global-padding;\n$card-margin: $global-margin;\n\n// 15. Close Button\n// ----------------\n\n$closebutton-position: right top;\n$closebutton-offset-horizontal: (\n  small: 0.66rem,\n  medium: 1rem,\n);\n$closebutton-offset-vertical: (\n  small: 0.33em,\n  medium: 0.5rem,\n);\n$closebutton-size: (\n  small: 1.5em,\n  medium: 2em,\n);\n$closebutton-lineheight: 1;\n$closebutton-color: $dark-gray;\n$closebutton-color-hover: $black;\n\n// 16. Drilldown\n// -------------\n\n$drilldown-transition: transform 0.15s linear;\n$drilldown-arrows: true;\n$drilldown-arrow-color: $primary-color;\n$drilldown-arrow-size: 6px;\n$drilldown-background: $white;\n\n// 17. Dropdown\n// ------------\n\n$dropdown-padding: 1rem;\n$dropdown-background: $body-background;\n$dropdown-border: 1px solid $medium-gray;\n$dropdown-font-size: 1rem;\n$dropdown-width: 300px;\n$dropdown-radius: $global-radius;\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n);\n\n// 18. Dropdown Menu\n// -----------------\n\n$dropdownmenu-arrows: true;\n$dropdownmenu-arrow-color: $anchor-color;\n$dropdownmenu-arrow-size: 6px;\n$dropdownmenu-min-width: 200px;\n$dropdownmenu-background: $white;\n$dropdownmenu-border: 1px solid $medium-gray;\n\n// 19. Forms\n// ---------\n\n$fieldset-border: 1px solid $medium-gray;\n$fieldset-padding: rem-calc(20);\n$fieldset-margin: rem-calc(18 0);\n$legend-padding: rem-calc(0 3);\n$form-spacing: rem-calc(16);\n$helptext-color: $black;\n$helptext-font-size: rem-calc(13);\n$helptext-font-style: italic;\n$input-prefix-color: $black;\n$input-prefix-background: $light-gray;\n$input-prefix-border: 1px solid $medium-gray;\n$input-prefix-padding: 1rem;\n$form-label-color: $black;\n$form-label-font-size: rem-calc(14);\n$form-label-font-weight: $global-weight-normal;\n$form-label-line-height: 1.8;\n$select-background: $white;\n$select-triangle-color: $dark-gray;\n$select-radius: $global-radius;\n$input-color: $black;\n$input-placeholder-color: $medium-gray;\n$input-font-family: inherit;\n$input-font-size: rem-calc(16);\n$input-font-weight: $global-weight-normal;\n$input-background: $white;\n$input-background-focus: $white;\n$input-background-disabled: $light-gray;\n$input-border: 1px solid $medium-gray;\n$input-border-focus: 1px solid $dark-gray;\n$input-shadow: inset 0 1px 2px rgba($black, 0.1);\n$input-shadow-focus: 0 0 5px $medium-gray;\n$input-cursor-disabled: not-allowed;\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n$input-number-spinners: true;\n$input-radius: $global-radius;\n$form-button-radius: $global-radius;\n\n// 20. Label\n// ---------\n\n$label-background: $primary-color;\n$label-color: $white;\n$label-color-alt: $black;\n$label-palette: $foundation-palette;\n$label-font-size: 0.8rem;\n$label-padding: 0.33333rem 0.5rem;\n$label-radius: $global-radius;\n\n// 21. Media Object\n// ----------------\n\n$mediaobject-margin-bottom: $global-margin;\n$mediaobject-section-padding: $global-padding;\n$mediaobject-image-width-stacked: 100%;\n\n// 22. Menu\n// --------\n\n$menu-margin: 0;\n$menu-margin-nested: 1rem;\n$menu-item-padding: 0.7rem 1rem;\n$menu-item-color-active: $white;\n$menu-item-background-active: get-color(primary);\n$menu-icon-spacing: 0.25rem;\n$menu-item-background-hover: $light-gray;\n$menu-border: $light-gray;\n\n// 23. Meter\n// ---------\n\n$meter-height: 1rem;\n$meter-radius: $global-radius;\n$meter-background: $medium-gray;\n$meter-fill-good: $success-color;\n$meter-fill-medium: $warning-color;\n$meter-fill-bad: $alert-color;\n\n// 24. Off-canvas\n// --------------\n\n$offcanvas-size: 250px;\n$offcanvas-vertical-size: 250px;\n$offcanvas-background: $light-gray;\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7);\n$offcanvas-push-zindex: 1;\n$offcanvas-overlap-zindex: 10;\n$offcanvas-reveal-zindex: 1;\n$offcanvas-transition-length: 0.5s;\n$offcanvas-transition-timing: ease;\n$offcanvas-fixed-reveal: true;\n$offcanvas-exit-background: rgba($white, 0.25);\n$maincontent-class: 'off-canvas-content';\n\n// 25. Orbit\n// ---------\n\n$orbit-bullet-background: $medium-gray;\n$orbit-bullet-background-active: $dark-gray;\n$orbit-bullet-diameter: 1.2rem;\n$orbit-bullet-margin: 0.1rem;\n$orbit-bullet-margin-top: 0.8rem;\n$orbit-bullet-margin-bottom: 0.8rem;\n$orbit-caption-background: rgba($black, 0.5);\n$orbit-caption-padding: 1rem;\n$orbit-control-background-hover: rgba($black, 0.5);\n$orbit-control-padding: 1rem;\n$orbit-control-zindex: 10;\n\n// 26. Pagination\n// --------------\n\n$pagination-font-size: rem-calc(14);\n$pagination-margin-bottom: $global-margin;\n$pagination-item-color: $black;\n$pagination-item-padding: rem-calc(3 10);\n$pagination-item-spacing: rem-calc(1);\n$pagination-radius: $global-radius;\n$pagination-item-background-hover: $light-gray;\n$pagination-item-background-current: $primary-color;\n$pagination-item-color-current: $white;\n$pagination-item-color-disabled: $medium-gray;\n$pagination-ellipsis-color: $black;\n$pagination-mobile-items: false;\n$pagination-mobile-current-item: false;\n$pagination-arrows: true;\n\n// 27. Progress Bar\n// ----------------\n\n$progress-height: 1rem;\n$progress-background: $medium-gray;\n$progress-margin-bottom: $global-margin;\n$progress-meter-background: $primary-color;\n$progress-radius: $global-radius;\n\n// 28. Responsive Embed\n// --------------------\n\n$responsive-embed-margin-bottom: rem-calc(16);\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n);\n\n// 29. Reveal\n// ----------\n\n$reveal-background: $white;\n$reveal-width: 600px;\n$reveal-max-width: $global-width;\n$reveal-padding: $global-padding;\n$reveal-border: 1px solid $medium-gray;\n$reveal-radius: $global-radius;\n$reveal-zindex: 1005;\n$reveal-overlay-background: rgba($black, 0.45);\n\n// 30. Slider\n// ----------\n\n$slider-width-vertical: 0.5rem;\n$slider-transition: all 0.2s ease-in-out;\n$slider-height: 0.5rem;\n$slider-background: $light-gray;\n$slider-fill-background: $medium-gray;\n$slider-handle-height: 1.4rem;\n$slider-handle-width: 1.4rem;\n$slider-handle-background: $primary-color;\n$slider-opacity-disabled: 0.25;\n$slider-radius: $global-radius;\n\n// 31. Switch\n// ----------\n\n$switch-background: $medium-gray;\n$switch-background-active: $primary-color;\n$switch-height: 2rem;\n$switch-height-tiny: 1.5rem;\n$switch-height-small: 1.75rem;\n$switch-height-large: 2.5rem;\n$switch-radius: $global-radius;\n$switch-margin: $global-margin;\n$switch-paddle-background: $white;\n$switch-paddle-offset: 0.25rem;\n$switch-paddle-radius: $global-radius;\n$switch-paddle-transition: all 0.25s ease-out;\n\n// 32. Table\n// ---------\n\n$table-background: $white;\n$table-color-scale: 5%;\n$table-border: 1px solid smart-scale($table-background, $table-color-scale);\n$table-padding: rem-calc(8 10 10);\n$table-hover-scale: 2%;\n$table-row-hover: darken($table-background, $table-hover-scale);\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale);\n$table-is-striped: true;\n$table-striped-background: smart-scale($table-background, $table-color-scale);\n$table-stripe: even;\n$table-head-background: smart-scale($table-background, $table-color-scale / 2);\n$table-head-row-hover: darken($table-head-background, $table-hover-scale);\n$table-foot-background: smart-scale($table-background, $table-color-scale);\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale);\n$table-head-font-color: $body-font-color;\n$table-foot-font-color: $body-font-color;\n$show-header-for-stacked: false;\n\n// 33. Tabs\n// --------\n\n$tab-margin: 0;\n$tab-background: $white;\n$tab-color: $primary-color;\n$tab-background-active: $light-gray;\n$tab-active-color: $primary-color;\n$tab-item-font-size: rem-calc(12);\n$tab-item-background-hover: $white;\n$tab-item-padding: 1.25rem 1.5rem;\n$tab-expand-max: 6;\n$tab-content-background: $white;\n$tab-content-border: $light-gray;\n$tab-content-color: $body-font-color;\n$tab-content-padding: 1rem;\n\n// 34. Thumbnail\n// -------------\n\n$thumbnail-border: solid 4px $white;\n$thumbnail-margin-bottom: $global-margin;\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2);\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5);\n$thumbnail-transition: box-shadow 200ms ease-out;\n$thumbnail-radius: $global-radius;\n\n// 35. Title Bar\n// -------------\n\n$titlebar-background: $black;\n$titlebar-color: $white;\n$titlebar-padding: 0.5rem;\n$titlebar-text-font-weight: bold;\n$titlebar-icon-color: $white;\n$titlebar-icon-color-hover: $medium-gray;\n$titlebar-icon-spacing: 0.25rem;\n\n// 36. Tooltip\n// -----------\n\n$has-tip-font-weight: $global-weight-bold;\n$has-tip-border-bottom: dotted 1px $dark-gray;\n$tooltip-background-color: $black;\n$tooltip-color: $white;\n$tooltip-padding: 0.75rem;\n$tooltip-font-size: $small-font-size;\n$tooltip-pip-width: 0.75rem;\n$tooltip-pip-height: $tooltip-pip-width * 0.866;\n$tooltip-radius: $global-radius;\n\n// 37. Top Bar\n// -----------\n\n$topbar-padding: 0.5rem;\n$topbar-background: $light-gray;\n$topbar-submenu-background: $topbar-background;\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0;\n$topbar-input-width: 200px;\n$topbar-unstack-breakpoint: medium;\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 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@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 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}\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@mixin -zf-each-breakpoint($small: 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    $-zf-size: $name !global;\n\n    @include breakpoint($name) {\n      @content;\n    }\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|Keyword} $name [auto] - Single value or breakpoint name 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 flex-grid\n////\n\n/// Creates a container for a flex grid row.\n///\n/// @param {Keyword|List} $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 {Number} $columns [null] - Number of columns to use for this row. If set to `null` (the default), the global column count will be used.\n/// @param {Boolean} $base [true] - Set to `false` to prevent basic styles from being output. Useful if you're calling this mixin on the same element twice, as it prevents duplicate CSS output.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use when inverting margins, in case the row is nested. Responsive gutter settings by default.\n@mixin flex-grid-row(\n  $behavior: null,\n  $size: $grid-row-width,\n  $columns: null,\n  $base: true,\n  $wrap: true,\n  $gutters: $grid-column-gutter\n) {\n  $margin: auto;\n  $wrap: if($wrap, wrap, nowrap);\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 $base {\n    display: flex;\n    flex-flow: row $wrap;\n  }\n\n  @if $columns != null {\n    @include grid-context($columns, $base) {\n      @content;\n    }\n  }\n}\n\n/// Calculates the `flex` property for a flex grid column. It accepts all of the same values as the basic `grid-column()` function, along with two extras:\n///   - `expand` (the default) will make the column expand to fill space.\n///   - `shrink` will make the column contract, so it only takes up the horizontal space it needs.\n///\n/// @param {Mixed} $columns [expand] - Width of the column.\n@function flex-grid-column($columns: expand) {\n  $flex: 1 1 0px; // sass-lint:disable-line zero-unit\n\n  @if $columns == shrink {\n    $flex: 0 0 auto;\n  }\n  @else if $columns != expand {\n    $flex: 0 0 grid-column($columns);\n  }\n\n  @return $flex;\n}\n\n/// Creates a column for a flex grid. By default, the column will stretch to the full width of its container, but this can be overridden with sizing classes, or by using the `unstack` class on the parent flex row.\n///\n/// @param {Mixed} $columns [expand] - Width of the column. Refer to the `flex-grid-column()` function to see possible values.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Map or single value for gutters width. See the `grid-column-gutter` mixin.\n@mixin flex-grid-column(\n  $columns: expand,\n  $gutters: $grid-column-gutter\n) {\n  // Base properties\n  @include flex-grid-size($columns);\n\n  // Gutters\n  @include grid-column-gutter($gutters: $gutters);\n\n  // fixes recent Chrome version not limiting child width\n  // https://stackoverflow.com/questions/34934586/white-space-nowrap-and-flexbox-did-not-work-in-chrome\n  @if $columns == expand {\n    min-width: initial;\n  }\n  // max-width fixes IE 10/11 not respecting the flex-basis property\n  @if $columns != expand and $columns != shrink {\n    max-width: grid-column($columns);\n  }\n}\n\n/// Creates a block grid for a flex grid row.\n///\n/// @param {Number} $n - Number of columns to display on each row.\n/// @param {String} $selector - Selector to use to target columns within the row.\n@mixin flex-grid-layout(\n  $n,\n  $selector: '.column'\n) {\n  flex-wrap: wrap;\n\n  > #{$selector} {\n    $pct: percentage(1/$n);\n\n    flex: 0 0 $pct;\n    max-width: $pct;\n  }\n}\n\n/// Changes the width flex grid column.\n/// @param {Mixed} $columns [expand] - Width of the column. Refer to the `flex-grid-column()` function to see possible values.\n@mixin flex-grid-size($columns: null) {\n  $columns: $columns or expand;\n\n  flex: flex-grid-column($columns);\n\n  // max-width fixes IE 10/11 not respecting the flex-basis property\n  @if $columns != expand and $columns != shrink {\n    max-width: grid-column($columns);\n  }\n}\n\n\n@mixin foundation-flex-grid {\n  // Row\n  .row {\n    @include flex-grid-row;\n\n    // Nesting behavior\n    & .row {\n      @include flex-grid-row(nest, $base: false);\n\n      &.collapse {\n        margin-right: 0;\n        margin-left: 0;\n      }\n    }\n\n    // Expanded row\n    &.expanded {\n      @include grid-row-size(expand);\n    }\n\n    &:not(.expanded) .row {\n      @include grid-row-size(expand);\n    }\n\n    &.collapse {\n      > .column {\n        @include grid-col-collapse;\n      }\n    }\n\n    // Undo negative margins\n    // From collapsed child\n    &.is-collapse-child,\n    &.collapse > .column > .row {\n      margin-right: 0;\n      margin-left: 0;\n    }\n  }\n\n  // Column\n  .column {\n    @include flex-grid-column;\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    display: block;\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\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  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-column-count {\n      // Sizing (percentage)\n      .#{$-zf-size}-#{$i} {\n        flex: flex-grid-column($i);\n        max-width: grid-column($i);\n      }\n\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include grid-column-offset($o);\n      }\n    }\n\n    // Source ordering\n    @for $i from 1 through 6 {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n\n    // Block grid\n    @for $i from 1 through $block-grid-max {\n      .#{$-zf-size}-up-#{$i} {\n        @include flex-grid-layout($i);\n      }\n    }\n\n    @if $-zf-size != $-zf-zero-breakpoint {\n      // Sizing (expand)\n      @include breakpoint($-zf-size) {\n        .#{$-zf-size}-expand {\n          flex: flex-grid-column();\n        }\n      }\n\n      // direction helper classes\n      @each $dir, $prop in $-zf-flex-direction {\n        .#{$-zf-size}-flex-dir-#{$dir} {\n          @include flex-direction($prop);\n        }\n      }\n      // child helper classes\n      .#{$-zf-size}-flex-child-auto {\n        flex: 1 1 auto;\n      }\n\n      .#{$-zf-size}-flex-child-grow {\n        flex: 1 0 auto;\n      }\n\n      .#{$-zf-size}-flex-child-shrink {\n        flex: 0 1 auto;\n      }\n\n      // Auto-stacking/unstacking\n      @at-root (without: media) {\n        .row.#{$-zf-size}-unstack {\n          > .column {\n            flex: flex-grid-column(100%);\n\n            @include breakpoint($-zf-size) {\n              flex: flex-grid-column();\n            }\n          }\n        }\n      }\n    }\n\n    // Responsive collapsing\n    .#{$-zf-size}-collapse {\n      > .column { @include grid-col-collapse; }\n    }\n\n    .#{$-zf-size}-uncollapse {\n      > .column { @include grid-col-gutter($-zf-size); }\n    }\n  }\n\n  // Sizing (shrink)\n  .shrink {\n    flex: flex-grid-column(shrink);\n    max-width: 100%;\n  }\n\n  // Block grid columns\n  .column-block {\n    @include grid-column-margin;\n  }\n\n  .columns {\n    @extend .column; // sass-lint:disable-line placeholder-in-extend\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 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 `$base-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 lets 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 greatern then 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 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/// Un-collapse the gutters on a column by re-adding the padding.\n///\n/// @param {Number} $gutter [$grid-column-gutter] - Spacing between columns.\n@mixin grid-column-uncollapse($gutter: $grid-column-gutter) {\n  @warn 'This mixin is being replaced by grid-column-gutter(). grid-column-uncollapse() will be removed in Foundation 6.4.';\n  @include grid-column-gutter($gutters: $gutter);\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/// Shorthand for `grid-column-uncollapse()`.\n/// @alias grid-column-uncollapse\n@mixin grid-col-uncollapse($gutter: $grid-column-gutter) {\n  @warn 'This mixin is being replaced by grid-col-gutter(). grid-col-uncollapse() will be removed in Foundation 6.4.';\n  @include grid-column-uncollapse($gutter);\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","$-zf-flex-justify: (\n  'left': flex-start,\n  'right': flex-end,\n  'center': center,\n  'justify': space-between,\n  'spaced': space-around,\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////\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  // Last column alignment\n  @if $grid-column-align-edge {\n    &:last-child:not(:first-child) {\n      float: $global-right;\n    }\n  }\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 - Direction and amount to move. The column will move equal to the width of the column count specified. A positive number will push the column to the right, while a negative number will pull it to the left. Set to center to center the column.\n@mixin grid-column-position($position) {\n  @if type-of($position) == 'number' {\n    $offset: percentage($position / $grid-column-count);\n\n    position: relative;\n    #{$global-left}: $offset;\n  }\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  @else {\n    @warn 'Wrong syntax for grid-column-position(). Enter a positive or negative number, or center.';\n  }\n}\n\n/// Reset a position definition.\n@mixin grid-column-unposition {\n  position: static;\n  float: left;\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","@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in map-remove($-zf-flex-justify, left) {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\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  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through 6 {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\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 deocration 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,\n  h2,\n  h3,\n  h4,\n  h5,\n  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} {\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 {\n    border-bottom: $abbr-underline;\n    color: $body-font-color;\n    cursor: help;\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 subhheaders.\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  // Use to remove the bullets from an unordered list\n  .no-bullet {\n    margin-#{$global-left}: 0;\n    list-style: none;\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$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}\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/// 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/// 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 + ($form-spacing * 1.5) - 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: $form-spacing / 2;\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  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    // Placeholder text\n    &::placeholder {\n      color: $input-placeholder-color;\n    }\n\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-prefix\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefix\n        margin: 0;\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@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 + $form-spacing * 1.5);\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      border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n    }\n\n    > :last-child {\n      > * {\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      height: auto;\n      min-width: 0;\n    }\n    @else {\n      height: $height;\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      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      height: $height;\n      padding-top: 0;\n      padding-bottom: 0;\n\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 .input-group-button {\n          display: table-cell;\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    background: $body-background;\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 + ($form-spacing * 1.5) - rem-calc(1));\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2);\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  line-height: normal;\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    &::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 button\n////\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/// 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// 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  padding: $button-padding;\n\n  -webkit-appearance: none;\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n\n  font-size: map-get($button-sizes, default);\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, &:focus {\n    background-color: transparent;\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $primary-color,\n  $hover-lightness: $button-hollow-hover-lightness\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: 1px solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\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 [$primary-color] - 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: $primary-color,\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}: get-side($button-padding, right);\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    // 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    // 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    // 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    // 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\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","// 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 Border\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.\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@mixin button-group(\n  $child-selector: $buttongroup-child-selector\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}: $buttongroup-spacing;\n    margin-bottom: $buttongroup-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: $global-radius;\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      }\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@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$buttongroup-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:last-child {\n        width: 100%\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)} - #{$buttongroup-spacing});\n            margin-#{$global-right}: $buttongroup-spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $buttongroup-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: 1 1 0px; // sass-lint:disable-line zero-unit\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 { @include button-group-expand; }\n\n    // Colors\n    @each $name, $color in $foundation-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\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 { // sass-lint:disable-line force-element-nesting\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}\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-margin-nested: 1rem !default;\n\n/// Padding for items in a menu.\n/// @type Number\n$menu-item-padding: 0.7rem 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/// Background color for an hovered menu item.\n/// @type Color\n$menu-item-background-hover: $light-gray !default;\n\n/// Color for bordered menu\n/// @type Color\n$menu-border: $light-gray !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  margin: $menu-margin;\n  list-style-type: none;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: center;\n    width: 100%;\n  }\n\n  // List items are table cell to allow for vertical alignment\n  > li {\n    @include disable-mouse-outline;\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  // Reset line height to make the height of the overall item easier to calculate\n  > li > a {\n    display: block;\n    padding: $menu-item-padding;\n    line-height: 1;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\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    table-layout: fixed;\n  }\n\n  > li:first-child:last-child {\n    width: 100%;\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: nowrap;\n\n      > li {\n        flex: 0 0 auto;\n      }\n    }\n    @else {\n      > li {\n        display: table-cell;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n\n      > li {\n        flex: 0 0 100%;\n        max-width: 100%;\n      }\n\n      > li  > a {\n        justify-content: flex-start;\n        align-items: flex-start;\n      }\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. Set to `null` to do not generate styles for direction.\n@mixin menu-simple($dir: $global-left) {\n  li {\n    display: inline-block;\n    vertical-align: top;\n    line-height: 1;\n  }\n\n  a {\n    padding: 0;\n  }\n\n  @if $dir != null {\n    @include menu-simple-direction($dir);\n  }\n}\n\n/// Direction modifier for a simple Menu\n/// @param {Keyword} $dir [$global-left] - Direction of the menu\n@mixin menu-simple-direction($dir: $global-left) {\n  $no-margin-dir: $dir;\n  $margin-dir: direction-opposite($dir);\n\n  li {\n    margin-#{$no-margin-dir}: 0;\n    margin-#{$margin-dir}: get-side($menu-item-padding, $margin-dir);\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $padding [auto] - Length of the margin.\n@mixin menu-nested($margin: $menu-margin-nested) {\n  margin-#{$global-left}: $margin;\n}\n\n/// Adds support for icons to Menu items.\n/// @param {Keyword} $position [side] - Positioning for icons. Can be `side` (left, or right on RTL) or `top`.\n/// @param {Boolean} $base [true] - Set to `false` to prevent the shared CSS between side- and top-aligned icons from being printed. Set this to `false` if you're calling the mixin multiple times on the same element.\n@mixin menu-icons($position: side, $base: true) {\n  @if $base {\n    @if $global-flexbox {\n      > li > a {\n        display: flex;\n      }\n    }\n    @else {\n      > li > a {\n        img,\n        i,\n        svg {\n          vertical-align: middle;\n\n          + span {\n            vertical-align: middle;\n          }\n        }\n      }\n    }\n  }\n\n  @if $position == side {\n    > li > a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $menu-icon-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 $menu-icon-spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $menu-icon-spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding-top: 0;\n  padding-bottom: 0;\n  padding: $menu-item-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n    @include menu-icons;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n\n      &.align-#{$global-right} {\n        @include menu-simple-direction($global-right);\n      }\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @if $global-flexbox {\n        justify-content: flex-end;\n      }\n      @else {\n        @include clearfix;\n\n        > li {\n          float: $global-right;\n        }\n      }\n    }\n\n    // Vertical icons\n    &.icon-top {\n      @include menu-icons(top, $base: false);\n      // Make vertical menu with icons on top work\n      &.vertical {\n        a > span {\n          margin: auto;\n        }\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Active state\n    .active > a {\n      background: $menu-item-background-active;\n      color: $menu-item-color-active;\n    }\n\n    // Menu with border\n    &.menu-bordered {\n      li {\n        border: 1px solid $menu-border;\n        &:not(:first-child) {\n          border-top: 0;\n        }\n      }\n    }\n\n    // Menu with background hover\n    &.menu-hover {\n      li:hover {\n        background-color: $menu-item-background-hover;\n      }\n    }\n  }\n\n  .menu-text {\n    @include menu-text;\n  }\n\n  // Align center\n  .menu-centered {\n    text-align: center;\n\n    > .menu {\n      display: inline-block;\n      vertical-align: top;\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","// 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: block;\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  &.is-open {\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.#{$name} {\n      width: $size;\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/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-background: $white !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@mixin 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  }\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 {\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right {\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 {\n        position: relative;\n        padding-#{$global-right}: 1.5rem;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after {\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\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          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 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    .no-js & ul {\n      display: none;\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      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-background;\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include 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 of a left/right off-canvas panel.\n/// @type Number\n$offcanvas-size: 250px !default;\n\n/// Height of a top/bottom off-canvas panel.\n/// @type Number\n$offcanvas-vertical-size: 250px !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 panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 1 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 10 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 1 !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  // 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\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  z-index: $offcanvas-push-zindex;\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\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  $size: if($orientation == horizontal, $offcanvas-size, $offcanvas-vertical-size)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    width: $size;\n    height: 100%;\n\n    transform: translateX(-$size);\n    overflow-y: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateX($size);\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    width: $size;\n    height: 100%;\n\n    transform: translateX($size);\n    overflow-y: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateX(-$size);\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n\n    width: 100%;\n    height: $size;\n\n    transform: translateY(-$size);\n    overflow-x: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateY($size);\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n\n    width: 100%;\n    height: $size;\n\n    transform: translateY($size);\n    overflow-x: auto;\n\n    // Sets the open position for the content\n    &.is-open ~ .#{$maincontent-class} {\n      transform: translateY(-$size);\n    }\n  }\n\n  // If $offcanvas-shadow is set, add it as a pseudo-element.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-shadow {\n    &.is-transition-push::after {\n      position: absolute;\n\n      @if $position == left {\n        top: 0;\n        right: 0;\n\n        height: 100%;\n        width: 1px;\n      }\n      @else if $position == right {\n        top: 0;\n        left: 0;\n\n        height: 100%;\n        width: 1px;\n      }\n      @else if $position == top {\n        bottom: 0;\n        left: 0;\n\n        height: 1px;\n        width: 100%;\n      }\n      @else if $position == bottom {\n        top: 0;\n        left: 0;\n\n        height: 1px;\n        width: 100%;\n      }\n\n      box-shadow: $offcanvas-shadow;\n      content: \" \";\n    }\n  }\n\n  // No transform on overlap transition\n  &.is-transition-overlap.is-open ~ .#{$maincontent-class} {\n    transform: none;\n  }\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\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) {\n  transform: none;\n  z-index: $zindex;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  & ~ .#{$content} {\n    margin-#{$position}: $offcanvas-size;\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\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);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(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/// 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  $size: -zf-bp-to-em($size) - (1 / 16);\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) - (1 / 16);\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 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","//--------------------------------------------------------------\n// Helpers\n//--------------------------------------------------------------\n\n//-----------------------------------------\n// Full Width\n//-----------------------------------------\n.full-width {\n\tmargin-left: rem-calc(-35);\n\tmax-width: calc(100% + 70px);\n\twidth: calc(100% + 70px);\n\n\t@include breakpoint(tablet-landscape) {\n\t\tmargin-left: rem-calc(-115);\n\t\tmax-width: calc(100% + 230px);\n\t\twidth: calc(100% + 230px);\n\t}\n} // .full-width\n\n//-----------------------------------------\n// Image As Background\n//-----------------------------------------\n.image-as-background {\n\tbackground-position: center center;\n\tbackground-repeat: no-repeat;\n\tbackground-size: cover;\n} // .image-as-background\n\n//-----------------------------------------\n// Video As Background\n//-----------------------------------------\n.video-as-background {\n\t@include size(100%);\n\n\tdisplay: block;\n\tobject-fit: cover;\n\tobject-position: center top;\n\tposition: absolute;\n\tz-index: 1;\n} // .video-as-background\n\n//-----------------------------------------\n// SVG Definitions\n//-----------------------------------------\n.svg-defs {\n\tdisplay: none;\n} // .svg-defs\n","@charset \"UTF-8\";\n\n/// Sets the `width` and `height` of the element in one statement.\n///\n/// @argument {number (with unit) | string} $width\n///\n/// @argument {number (with unit) | string} $height [$width]\n///\n/// @example scss\n///   .first-element {\n///     @include size(2em);\n///   }\n///\n///   // CSS Output\n///   .first-element {\n///     width: 2em;\n///     height: 2em;\n///   }\n///\n/// @example scss\n///   .second-element {\n///     @include size(auto, 10em);\n///   }\n///\n///   // CSS Output\n///   .second-element {\n///     width: auto;\n///     height: 10em;\n///   }\n///\n/// @require {function} _is-size\n\n@mixin size(\n  $width,\n  $height: $width\n) {\n  @if _is-size($height) {\n    height: $height;\n  } @else {\n    @error \"`#{$height}` is not a valid length for the `$height` argument \" +\n           \"in the `size` mixin.\";\n  }\n\n  @if _is-size($width) {\n    width: $width;\n  } @else {\n    @error \"`#{$width}` is not a valid length for the `$width` argument \" +\n           \"in the `size` mixin.\";\n  }\n}\n","//--------------------------------------------------------------\n// WordPress Classes\n//--------------------------------------------------------------\n\n//-----------------------------------------\n// Alignments\n//-----------------------------------------\n.alignleft {\n\tdisplay: inline;\n\tfloat: left;\n\tmargin: 0 $global-margin 0 0;\n} // .alignleft\n\n.alignright {\n\tdisplay: inline;\n\tfloat: right;\n\tmargin: 0 0 0 $global-margin;\n} // .alignright\n\n.aligncenter {\n\tdisplay: block;\n\tmargin-left: auto;\n\tmargin-right: auto;\n} // .aligncenter\n\n//-----------------------------------------\n// Typography\n//-----------------------------------------\npre {\n\tbackground-color: $code-background;\n\tcolor: $code-color;\n\tfont-family: $font-family-monospace;\n\tfont-size: em(15);\n\tfont-weight: $code-font-weight;\n\tline-height: $global-lineheight;\n\tmargin: $paragraph-margin-bottom 0 $paragraph-margin-bottom;\n\toverflow: auto;\n\tpadding: $code-padding;\n\twhite-space: pre;\n\tword-break: normal;\n\tword-wrap: normal;\n} // pre\n\ncode,\nkbd,\ntt,\nvar {\n\tfont-family: $font-family-monospace;\n\tfont-size: em(15);\n} // code, kbd, tt, var\n\nabbr,\nacronym {\n\tborder-bottom: $code-border;\n\tcursor: help;\n} // abbr, acronym\n\nmark,\nins {\n\ttext-decoration: none;\n} // mark, ins\n\nsup,\nsub {\n\tfont-size: 75%;\n\theight: 0;\n\tline-height: 0;\n\tposition: relative;\n\tvertical-align: baseline;\n} // sup, sub\n\nsup {\n\tbottom: 1ex;\n} // sup\n\nsub {\n\ttop: 0.5ex;\n} // sub\n\nsmall {\n\tfont-size: 75%;\n} // small\n\nbig {\n\tfont-size: 125%;\n} // big\n\n//-----------------------------------------\n// Screen Readers\n//-----------------------------------------\n.screen-reader-text {\n\t@include element-invisible;\n} // .screen-reader-text\n\n//-----------------------------------------\n// Captions\n//-----------------------------------------\n.wp-caption {\n\tmargin: 0 0 $global-margin 0;\n\tmax-width: 100%;\n\n\timg[class*='wp-image-'] {\n\t\tdisplay: block;\n\t\tmargin: 0 auto;\n\t} // img[class*=\"wp-image-\"]\n\n\t// Add auto margins so image is centered\n\t&.aligncenter {\n\t\tmargin: 0 auto $global-margin auto;\n\t} // &.aligncenter\n\n\t// Add a margin right to left-aligned images with captions\n\t&.alignleft {\n\t\tmargin-right: $global-margin;\n\t} // &.alignleft\n\n\t// Add a margin left to right-aligned images with captions\n\t&.alignright {\n\t\tmargin-left: $global-margin;\n\t} // &.alignright\n\n\t// Add top and bottom margin to caption text\n\t.wp-caption-text {\n\t\tmargin: $global-margin 0;\n\t} // .wp-caption-text\n} // .wp-caption\n\n// Image caption text\n.wp-caption-text {\n\ttext-align: center;\n} // .wp-caption-text\n\n//-----------------------------------------\n// Galleries\n//-----------------------------------------\n.gallery {\n\tmargin: 0 0 $global-margin 0;\n} // .gallery\n\n// Gallery caption\n.gallery-caption {\n\tdisplay: block;\n} // .gallery-caption\n\n// Gallery items\n.gallery-item {\n\t@include size(100% auto);\n\n\tdisplay: inline-block;\n\ttext-align: center;\n\tvertical-align: top;\n\n\t.gallery-columns-2 & {\n\t\tmax-width: 50%;\n\t} // .gallery-columns-2 &\n\n\t.gallery-columns-3 & {\n\t\tmax-width: 33.33%;\n\t} // .gallery-columns-3 &\n\n\t.gallery-columns-4 & {\n\t\tmax-width: 25%;\n\t} // .gallery-columns-4 &\n\n\t.gallery-columns-5 & {\n\t\tmax-width: 20%;\n\t} // .gallery-columns-5 &\n\n\t.gallery-columns-6 & {\n\t\tmax-width: 16.66%;\n\t} // .gallery-columns-6 &\n\n\t.gallery-columns-7 & {\n\t\tmax-width: 14.28%;\n\t} // .gallery-columns-7 &\n\n\t.gallery-columns-8 & {\n\t\tmax-width: 12.5%;\n\t} // .gallery-columns-8 &\n\n\t.gallery-columns-9 & {\n\t\tmax-width: 11.11%;\n\t} // .gallery-columns-9 &\n} // .gallery-item\n\n//-----------------------------------------\n// Misc.\n//-----------------------------------------\n.wp-smiley {\n\t@include margin-padding-reset;\n\n\tborder: none;\n} // .wp-smiley\n","// ----------------------------------------------------------------------\n// Margin & Padding Reset\n// ----------------------------------------------------------------------\n\n////\n/// @author Greg Rickaby\n/// @group wds\n////\n\n/// Resets margin and padding on any element\n///\n/// @example scss - Basic Usage Sass\n///    .foo {\n///\t\t\t@include margin-padding-reset;\n///    }\n///\n/// @example scss - Basic Usage CSS Output\n///    .foo {\n///         margin: 0;\n///         padding: 0;\n///    }\n\n@mixin margin-padding-reset {\n\tmargin: 0;\n\tpadding: 0;\n}\n","//--------------------------------------------------------------\n// Primary Navigation Menu\n//--------------------------------------------------------------\n\n//-----------------------------------------\n// Hamburger Icon\n//-----------------------------------------\n.hamburger-icon {\n\t@include hamburger($black, $medium-gray, 20px, 16px, 2px, 3);\n} // .hamburger\n\n//-----------------------------------------\n// Off Canvas Drawer\n//-----------------------------------------\n.off-canvas {\n\n\t// When the admin bar is present.\n\t.admin-bar & {\n\t\tpadding-top: $global-padding * 3.5;\n\t} // .admin-bar\n\n\t// Indent our submenus on mobile.\n\t.is-accordion-submenu {\n\t\tpadding-left: $global-padding;\n\t} // .is-accordion-submenu\n} // .off-canvas\n","//--------------------------------------------------------------\n// Content Blocks\n//--------------------------------------------------------------\n.content-block {\n\tpadding: $global-padding;\n} // .content-block","//--------------------------------------------------------------\n// Comments\n//--------------------------------------------------------------\n\n//-----------------------------------------\n// Comment area scaffolding\n//-----------------------------------------\n.comments-area {\n\tborder-top: $input-border;\n\tmargin: $global-margin 0;\n\n\t@include breakpoint(desktop) {\n\t\tmargin-left: auto;\n\t\tmargin-right: auto;\n\t}\n\n\t.comment-reply-title {\n\t\tmargin-top: $global-margin;\n\t} // .comment-reply-title\n\n\t.comments-title {\n\t\tfont-size: em(24);\n\t\tmargin-top: $global-margin;\n\t} // .comments-title\n\n\t.comment-notes {\n\t\tfont-size: em(16);\n\t\tmargin-top: $global-margin;\n\t} // .comment-notes\n} // .comments-area\n\n//-----------------------------------------\n// Labels\n//-----------------------------------------\n.comment-form-comment,\n.comment-form-author,\n.comment-form-email,\n.comment-form-url {\n\n\tlabel {\n\t\tfloat: left;\n\t\tfont-size: em(16);\n\t\ttext-transform: uppercase;\n\t\twidth: 100%;\n\t} // label\n} // .comment-form-comment, .comment-form-author, .comment-form-email, .comment-form-url\n\n//-----------------------------------------\n// The comment form.\n//-----------------------------------------\n.comment-form {\n\t@include clearfix;\n\n\twidth: 100%;\n\n\t// Any input (except submit button)\n\tinput:not(.submit) {\n\t\tclear: both;\n\t\ttransition: border 0.2s ease-in-out;\n\t\twidth: 100%;\n\n\t\t@include breakpoint(phone-landscape) {\n\t\t\tmax-width: rem-calc(250);\n\t\t}\n\t} // input:not(.submit)\n\n\t// Comment text area.\n\ttextarea {\n\t\tmax-width: rem-calc(870);\n\t\ttransition: border 0.2s ease-in-out;\n\t} // textara\n\n\t.form-submit {\n\t\tmargin: 0;\n\t} // .form-submit\n\n\t// Submit button.\n\tinput[type='submit'] {\n\t\twidth: rem-calc(196);\n\t} // input[type=\"submit\"]\n} // .comment-form\n\n//-----------------------------------------\n// Comments\n//-----------------------------------------\n.comment-list {\n\t@include list-reset;\n\n\tmargin: 0;\n\n\t// Even comments get nice gray background.\n\t.even:not(.bypostauthor) > .comment-body {\n\t\tbackground-color: $medium-gray;\n\t} // .even > .comment-body\n\n\t// Each comment body.\n\t.comment-body {\n\t\tmargin: $global-margin 0;\n\t\tpadding: $global-padding;\n\t} // .comment-body\n\n\t// Comment content.\n\t.comment-content {\n\t\tmargin: $global-margin 0;\n\t\tmax-width: rem-calc(936);\n\t} // .comment-content\n\n\t// Comment meta.\n\t.comment-meta {\n\t\t@include clearfix;\n\n\t\tmargin: 0 0 $global-margin 0;\n\t} // .comment-meta\n\n\t// The comment author name.\n\t.comment-author {\n\t\tline-height: 1;\n\t} // .comment-author\n\n\t// The date/time.\n\t.comment-metadata {\n\t\tline-height: 1;\n\t\tmargin-top: rem-calc(5);\n\n\t\ta {\n\t\t\tcolor: $black;\n\t\t\ttext-decoration: none;\n\t\t} // a\n\n\t\ttime,\n\t\t.comment-edit-link {\n\t\t\tfont-size: em(12);\n\t\t} // time, .comment-edit-link\n\t} // .comment-metadata\n\n\t// Comments avatar.\n\t.avatar {\n\t\tborder-radius: 50%;\n\t\tfloat: left;\n\t\tmargin: 0 $global-margin 0 0;\n\t} // .avatar\n\n\t// By post author.\n\t.bypostauthor {\n\t\tbackground-color: get-color(secondary);\n\t\tdisplay: block;\n\t} // .bypostauthor\n\n\t// The reply link/button thingy.\n\t.comment-reply-link {\n\t\tfont-weight: 700;\n\t} // .comment-reply-link\n\n\t// If someone replies with code...\n\tpre,\n\tcode {\n\t\tmargin: 0;\n\t\twidth: 100%;\n\t} // pre, code\n} // .comment-list\n\n//-----------------------------------------\n// Nested children scaffolding.\n//-----------------------------------------\n.comment-list {\n\n\t// Comment children.\n\t.children {\n\t\tlist-style: none;\n\t\tmargin: $global-margin * 2 0;\n\t\tpadding-left: $global-padding;\n\n\t\t@include breakpoint(phone-landscape) {\n\t\t\tpadding-left: $global-padding * 2;\n\t\t}\n\n\t\t@include breakpoint(tablet-portrait) {\n\t\t\tpadding-left: $global-padding * 4;\n\t\t}\n\n\t\t.depth-4,\n\t\t.depth-5,\n\t\t.depth-6,\n\t\t.depth-7,\n\t\t.depth-8,\n\t\t.depth-9,\n\t\t.depth-10 {\n\n\t\t\t// Increase line height on mobile for better readability.\n\t\t\t.comment-author {\n\t\t\t\tline-height: 1.25;\n\n\t\t\t\t@include breakpoint(phone-landscape) {\n\t\t\t\t\tline-height: 1;\n\t\t\t\t}\n\t\t\t} // .comment-author\n\t\t} // .depth-x\n\t} // .children\n} // .comment-list\n\n//-----------------------------------------\n// Inline reply\n//-----------------------------------------\n.comment-list {\n\n\t.comment-respond {\n\t\tbackground-color: $white;\n\t\tpadding: $global-padding 0;\n\n\t\t@include breakpoint(phone-landscape) {\n\t\t\tpadding-left: $global-padding * 2;\n\t\t\tpadding-right: $global-padding * 2;\n\t\t}\n\n\t\t.comment-reply-title {\n\n\t\t\t// The \"cancel reply\".\n\t\t\ta {\n\t\t\t\tdisplay: inline-block;\n\t\t\t\ttext-transform: lowercase;\n\n\t\t\t\t&::before {\n\t\t\t\t\tcontent: '(';\n\t\t\t\t}\n\n\t\t\t\t&::after {\n\t\t\t\t\tcontent: ')';\n\t\t\t\t}\n\t\t\t} // a\n\t\t} // .comment-reply-title\n\n\t\t.form-submit {\n\t\t\tmargin: 0;\n\n\t\t\tinput[type='submit'] {\n\t\t\t\tmargin-top: rem-calc(5);\n\t\t\t}\n\t\t} // .form-submit\n\t} // .comment-respond\n} // .comment-list\n","// ----------------------------------------------------------------------\n// List Reset\n// ----------------------------------------------------------------------\n\n////\n/// @author Greg Rickaby\n/// @group wds\n////\n\n/// Reset all padding and styles on both unordered and ordered lists.\n///\n/// @example scss - Basic Usage Sass\n///    .foo-list {\n///        @include list-reset;\n///    }\n///\n/// @example scss - Basic Usage CSS Output\n///    .foo-list {\n///         clear: both;\n///\t\t\tcontent: \"\";\n///\t\t\tdisplay: table;\n///        \tmargin: 0;\n///        \tpadding: 0;\n///        \tlist-style: none;\n///\n///    }\n\n@mixin list-reset {\n\t@include clearfix;\n\t@include margin-padding-reset;\n\n\tlist-style: none;\n}\n","//--------------------------------------------------------------\n// Content\n//--------------------------------------------------------------\n\n// Sticky and comments Link.\n.sticky,\n.comments-link {\n\tdisplay: block;\n} // .sticky, .comments-link\n\n// hentry\n.hentry {\n\tmargin: 0 0 $global-margin * 2 0;\n} // .hentry\n\n// Byline and update post date.\n.byline,\n.updated:not(.published) {\n\tdisplay: none;\n} // .byline, .updated:not(.published)\n\n// Byline for single and group.\n.single .byline,\n.group-blog .byline {\n\tdisplay: inline;\n} // .single .byline, .group-blog .byline\n\n// Page content, entry content and entry summary.\n.page-content,\n.entry-content,\n.entry-summary {\n\tmargin: $global-margin * 2 0 0;\n} // .page-content, .entry-content, .entry-summary\n\n// Page links.\n.page-links {\n\tclear: both;\n\tmargin: 0 0 $global-margin * 2 0;\n} // .page-links\n\n// Tags links.\n.tags-links {\n\tmargin-left: $global-margin * 2;\n} // .tags-links\n\n// Edit link.\n.edit-link {\n\ta {\n\t\tfont-size: em(12);\n\t\ttext-transform: lowercase;\n\n\t\t&::before {\n\t\t\tcontent: '(';\n\t\t}\n\n\t\t&::after {\n\t\t\tcontent: ')';\n\t\t}\n\t} // a\n} // .edit-link\n\n// Asides.\n.blog .format-aside .entry-title,\n.archive .format-aside .entry-title {\n\tdisplay: none;\n} // .blog .format-aside .entry-title, .archive .format-aside .entry-title\n\n// Navigation on Comment, Post and Posts.\n.comment-navigation,\n.posts-navigation,\n.post-navigation {\n\n\t.site-main & {\n\t\tmargin: 0 0 $global-margin 0;\n\t\toverflow: hidden;\n\t} // .site-main &\n\n\t.nav-previous {\n\t\t@include size(50% auto);\n\n\t\tfloat: left;\n\t} // &.nav-previous\n\n\t.nav-next {\n\t\t@include size(50% auto);\n\n\t\tfloat: right;\n\t\ttext-align: right;\n\t} // &.nav-next\n} // .comment-navigation, .posts-navigation, .post-navigation\n\n// Word wrapping.\n.entry-title,\n.entry-content,\n.comments-title,\n.comment-content,\n.widget-title,\n.widget {\n\t@include word-break;\n} // .entry-title, .entry-content, .comments-title, .comment-content, .widget-title, .widget","//--------------------------------------------------------------\n// Word Break\n//--------------------------------------------------------------\n\n////\n/// @author Stacy Kvernmo\n/// @group wds\n////\n\n/// Keep words together if possible, but force break anything that is too long\n/// @param {String} $word-break [keep-all]\n///      `normal` | `break-all` | `keep-all`\n///\n/// @link https://developer.mozilla.org/en-US/docs/Web/CSS/word-break View background information about word-break here\n/// @link http://sassmeister.com/gist/3f09e69a73e14859f967 View word-break in action\n///\n/// @example scss - Basic Usage Sass\n///    .break-long-words-only {\n///        @include word-break(keep-all);\n///    }\n///\n/// @example scss - Basic Usage CSS Output\n///    .break-long-words-only {\n///            word-wrap: break-word;\n///            word-break: keep-all;\n///     }\n\n@mixin word-break($word-break: keep-all) {\n\tword-break: $word-break;\n\tword-wrap: break-word;\n}\n","//--------------------------------------------------------------\n// Site Footer\n//--------------------------------------------------------------\n.site-footer {\n\tmargin: $global-margin * 2 auto;\n} // .site-footer\n","//--------------------------------------------------------------\n// Site Header\n//--------------------------------------------------------------\n.site-header {\n\tmargin: $global-margin * 2 auto;\n} // .site-header\n","//--------------------------------------------------------------\n// Hero\n//--------------------------------------------------------------\n.hero {\n\toverflow-y: hidden;\n\tposition: relative;\n\tz-index: 1;\n\n\t// Optional transparent overlay.\n\t&::after {\n\t\t@include size(100%);\n\t\t@include position(absolute, 0 0 null null);\n\n\t\tbackground-color: rgba($black, 0.7);\n\t\tcontent: '';\n\t\tz-index: 2;\n\t} // .hero::after\n\n\t// Content container.\n\t&-content {\n\t\tpadding: $global-padding * 4 0;\n\t\tposition: relative;\n\t\tz-index: 3;\n\n\t\t@include breakpoint(admin-bar) {\n\t\t\tpadding: $global-padding * 8 0;\n\t\t}\n\t} // .hero-content\n\n\t// Headline container.\n\t&-headline {\n\t\tfont-size: rem-calc(48);\n\t\tline-height: 1.2;\n\t\tmargin-bottom: $global-padding * 2;\n\n\t\t@include breakpoint(medium) {\n\t\t\tmargin-bottom: $global-padding;\n\t\t}\n\t} // .hero-headline\n\n\t// Text/burb container.\n\t&-text {\n\t\tfont-size: rem-calc(18);\n\n\t\t@include breakpoint(medium) {\n\t\t\tfont-size: rem-calc(24);\n\t\t}\n\t} // .hero-text\n\n\t// CTA button.\n\t&-button {\n\t\tmargin-top: rem-calc(10);\n\t} // .hero-button\n} // .hero\n","// ----------------------------------------------------------------------\n// Position\n// ----------------------------------------------------------------------\n\n////\n/// @author Bourbon v5\n/// @group Thoughtbot\n////\n\n/// Provides a concise, one-line method for setting an element’s positioning\n/// properties: `position`, `top`, `right`, `bottom` and `left`. Use a `null`\n/// value to “skip” an edge of the box.\n///\n/// @argument {string} $position\n///   A CSS position value.\n///\n/// @argument {list} $box-edge-values\n///   List of lengths; accepts CSS shorthand.\n///\n/// @example scss\n///   .element {\n///     @include position(relative, 0 null null 10em);\n///   }\n///\n///   // CSS Output\n///   .element {\n///     left: 10em;\n///     position: relative;\n///     top: 0;\n///   }\n///\n/// @example scss\n///   .element {\n///     @include position(absolute, 0);\n///   }\n///\n///   // CSS Output\n///   .element {\n///     position: absolute;\n///     top: 0;\n///     right: 0;\n///     bottom: 0;\n///     left: 0;\n///   }\n///\n/// @require {function} _is-length\n///\n/// @require {function} _unpack-shorthand\n\n@mixin position(\n  $position,\n  $box-edge-values\n) {\n  $box-edge-values: _unpack-shorthand($box-edge-values);\n  $offsets: (\n    top:    nth($box-edge-values, 1),\n    right:  nth($box-edge-values, 2),\n    bottom: nth($box-edge-values, 3),\n    left:   nth($box-edge-values, 4),\n  );\n\n  position: $position;\n\n  @each $offset, $value in $offsets {\n    @if _is-length($value) {\n      #{$offset}: $value;\n    }\n  }\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 'Your smallest breakpoint (defined in $breakpoints) must be set to \"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  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - (1/16);\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  // 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\n/// Convers 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/// 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  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @return null;\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@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\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@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@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@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n"]} */
diff --git a/style.min.css b/style.min.css
index 5bc6be8d4..5b2f6322b 100644
--- a/style.min.css
+++ b/style.min.css
@@ -1,2 +1,2 @@
 @charset "UTF-8";
-/*! 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%}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;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;font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}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]{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{box-sizing:border-box;display:table;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}[hidden],template{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{box-sizing:border-box;font-size:100%}*,:after,:before{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{box-sizing:border-box;width:100%}.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:transparent;line-height:1}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}.is-visible{display:block!important}.is-hidden{display:none!important}.row{max-width:75rem;margin-right:auto;margin-left:auto;display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap}.row .row{margin-right:-.625rem;margin-left:-.625rem}.row .row.collapse{margin-right:0;margin-left:0}.row.expanded,.row:not(.expanded) .row{max-width:none}.row.collapse>.column,.row.collapse>.columns{padding-right:0;padding-left:0}.row.collapse>.column>.row,.row.collapse>.columns>.row,.row.is-collapse-child{margin-right:0;margin-left:0}.column,.columns{-ms-flex:1 1 0px;flex:1 1 0px;padding-right:.625rem;padding-left:.625rem;min-width:0}.column.row.row,.row.row.columns{float:none;display:block}.row .column.row.row,.row .row.row.columns{margin-right:0;margin-left:0;padding-right:0;padding-left:0}.flex-container{display:-ms-flexbox;display:flex}.flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.small-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.small-offset-0{margin-left:0}.small-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.small-offset-1{margin-left:8.33333%}.small-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.small-offset-2{margin-left:16.66667%}.small-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.small-offset-3{margin-left:25%}.small-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.small-offset-4{margin-left:33.33333%}.small-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.small-offset-5{margin-left:41.66667%}.small-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.small-offset-6{margin-left:50%}.small-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.small-offset-7{margin-left:58.33333%}.small-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.small-offset-8{margin-left:66.66667%}.small-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.small-offset-9{margin-left:75%}.small-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.small-offset-10{margin-left:83.33333%}.small-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.small-offset-11{margin-left:91.66667%}.small-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-1>.column,.small-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.small-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-2>.column,.small-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.small-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-3>.column,.small-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.small-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-4>.column,.small-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.small-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-5>.column,.small-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.small-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-6>.column,.small-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.small-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-7>.column,.small-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.small-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-8>.column,.small-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.small-collapse>.column,.small-collapse>.columns{padding-right:0;padding-left:0}.small-uncollapse>.column,.small-uncollapse>.columns{padding-right:.625rem;padding-left:.625rem}.row.large-unstack>.column,.row.large-unstack>.columns,.row.medium-unstack>.column,.row.medium-unstack>.columns{-ms-flex:0 0 100%;flex:0 0 100%}.shrink{-ms-flex:0 0 auto;flex:0 0 auto;max-width:100%}.column-block{margin-bottom:1.25rem}.column-block>:last-child{margin-bottom:0}.align-right{-ms-flex-pack:end;justify-content:flex-end}.align-center{-ms-flex-pack:center;justify-content:center}.align-justify{-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-ms-flex-pack:distribute;justify-content:space-around}.align-top{-ms-flex-align:start;align-items:flex-start}.align-self-top{-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-ms-flex-item-align:end;align-self:flex-end}.align-middle{-ms-flex-align:center;align-items:center}.align-self-middle{-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.align-stretch{-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch}.small-order-1{-ms-flex-order:1;order:1}.small-order-2{-ms-flex-order:2;order:2}.small-order-3{-ms-flex-order:3;order:3}.small-order-4{-ms-flex-order:4;order:4}.small-order-5{-ms-flex-order:5;order:5}.small-order-6{-ms-flex-order:6;order:6}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}b,em,i,strong{line-height:inherit}b,strong{font-weight:700}small{font-size:80%;line-height:inherit}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{line-height:0;color:#cacaca}h1{font-size:1.5rem}h1,h2{line-height:1.4;margin-top:0;margin-bottom:.5rem}h2{font-size:1.25rem}h3{font-size:1.1875rem}h3,h4{line-height:1.4;margin-top:0;margin-bottom:.5rem}h4{font-size:1.125rem}h5{font-size:1.0625rem}h5,h6{line-height:1.4;margin-top:0;margin-bottom:.5rem}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{list-style-type:disc}ol,ul{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{border-bottom:1px dotted #0a0a0a;color:#0a0a0a;cursor:help}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;font-weight:400}code,kbd{background-color:#e6e6e6;font-family:Consolas,Liberation Mono,Courier,monospace;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0}.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}.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}.show-for-print{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;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;box-shadow:inset 0 1px 2px hsla(0,0%,4%,.1);font-family:inherit;font-size:1rem;font-weight:400;color:#0a0a0a;transition:box-shadow .5s,border-color .25s ease-in-out;-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:none;border:1px solid #8a8a8a;background-color:#fefefe;box-shadow:0 0 5px #cacaca;transition:box-shadow .5s,border-color .25s ease-in-out}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]{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,.input-group>:last-child>*{border-radius:0 0 0 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;background:#fefefe}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;font-family:inherit;font-size:1rem;line-height:normal;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}select,select:focus{background-color:#fefefe;transition:box-shadow .5s,border-color .25s ease-in-out}select:focus{outline:none;border:1px solid #8a8a8a;box-shadow:0 0 5px #cacaca}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}.form-error,.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;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.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.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.dropdown:after{display:block;width:0;height:0;border:.4em inset;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.arrow-only:after{top:-.1em;float:none;margin-left:0}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion-item:first-child>:first-child,.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:.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: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}.is-accordion-submenu-parent>a{position:relative}.is-accordion-submenu-parent>a:after{display:block;width:0;height:0;border:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.is-accordion-submenu-parent[aria-expanded=true]>a:after{transform:rotate(180deg);transform-origin:50% 50%}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center}.badge,.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;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;top:1px;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-for-medium .button,.button-group.stacked-for-small .button,.button-group.stacked .button{width:100%}.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child,.button-group.stacked .button:last-child{margin-bottom:0}.callout{position:relative;margin:0 0 1rem;padding:1rem;border:1px solid hsla(0,0%,4%,.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:.5rem}.callout.large{padding:3rem}.card{margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;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}.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{margin:0;list-style-type:none}.menu>li{display:table-cell;vertical-align:middle}[data-whatinput=mouse] .menu>li{outline:0}.menu>li>a{display:block;padding:.7rem 1rem;line-height:1}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu>li>a i,.menu>li>a i+span,.menu>li>a img,.menu>li>a img+span,.menu>li>a svg,.menu>li>a svg+span{vertical-align:middle}.menu>li>a i,.menu>li>a img,.menu>li>a svg{margin-right:.25rem;display:inline-block}.menu.horizontal>li,.menu>li{display:table-cell}.menu.expanded{display:table;width:100%;table-layout:fixed}.menu.expanded>li:first-child:last-child{width:100%}.menu.vertical>li{display:block}.menu.simple li{display:inline-block;vertical-align:top;line-height:1}.menu.simple a{padding:0}.menu.simple li{margin-left:0;margin-right:1rem}.menu.simple.align-right li{margin-right:0;margin-left:1rem}.menu.align-right:after,.menu.align-right:before{display:table;content:" "}.menu.align-right:after{clear:both}.menu.align-right>li{float:right}.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-top.vertical a>span{margin:auto}.menu.nested{margin-left:1rem}.menu .active>a{background:#1779ba;color:#fefefe}.menu.menu-bordered li{border:1px solid #e6e6e6}.menu.menu-bordered li:not(:first-child){border-top:0}.menu.menu-hover li:hover{background-color:#e6e6e6}.menu-text{padding-top:0;padding-bottom:0;padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered{text-align:center}.menu-centered>.menu{display:inline-block;vertical-align:top}.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;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:""}.menu-icon:hover:after{background:#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;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:""}.menu-icon.dark:hover:after{background:#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{transition:height .5s}.is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;transition:transform .15s linear}.is-drilldown-submenu.is-active{z-index:1;display:block;transform:translateX(-100%)}.is-drilldown-submenu.is-closing{transform:translateX(100%)}.drilldown-submenu-cover-previous{min-height:100%}.is-drilldown-submenu-parent>a{position:relative}.is-drilldown-submenu-parent>a:after{display:block;width:0;height:0;border:6px inset;content:"";border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;position:absolute;top:50%;margin-top:-6px;right:1rem}.js-drilldown-back>a:before{display:block;width:0;height:0;border:6px inset;content:"";border-right-style:solid;border-color:transparent #1779ba transparent transparent;display:inline-block;vertical-align:middle;margin-right:.75rem;border-left-width:0}.dropdown-pane{position:absolute;z-index:10;display:block;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-open{visibility:visible}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.no-js .dropdown.menu ul{display:none}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{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:6px inset;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:6px inset;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;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}.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:6px inset;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:6px inset;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}.label,.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-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;width:100%;height:100%;transition:opacity .5s ease,visibility .5s ease;background:hsla(0,0%,100%,.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:1;transition:transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-overlap{z-index:10}.off-canvas.is-transition-overlap.is-open{box-shadow:0 0 10px hsla(0,0%,4%,.7)}.off-canvas.is-open{transform:translate(0)}.off-canvas-absolute{position:absolute;z-index:1;transition: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-overlap{z-index:10}.off-canvas-absolute.is-transition-overlap.is-open{box-shadow:0 0 10px hsla(0,0%,4%,.7)}.off-canvas-absolute.is-open{transform:translate(0)}.position-left{top:0;left:0;width:250px;height:100%;transform:translateX(-250px);overflow-y:auto}.position-left.is-open~.off-canvas-content{transform:translateX(250px)}.position-left.is-transition-push:after{position:absolute;top:0;right:0;height:100%;width:1px;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-left.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-right{top:0;right:0;width:250px;height:100%;transform:translateX(250px);overflow-y:auto}.position-right.is-open~.off-canvas-content{transform:translateX(-250px)}.position-right.is-transition-push:after{position:absolute;top:0;left:0;height:100%;width:1px;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-right.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-top{top:0;left:0;width:100%;height:250px;transform:translateY(-250px);overflow-x:auto}.position-top.is-open~.off-canvas-content{transform:translateY(250px)}.position-top.is-transition-push:after{position:absolute;bottom:0;left:0;height:1px;width:100%;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-top.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-bottom{bottom:0;left:0;width:100%;height:250px;transform:translateY(250px);overflow-x:auto}.position-bottom.is-open~.off-canvas-content{transform:translateY(-250px)}.position-bottom.is-transition-push:after{position:absolute;top:0;left:0;height:1px;width:100%;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-bottom.is-transition-overlap.is-open~.off-canvas-content{transform:none}.off-canvas-content{transition:transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.orbit,.orbit-container{position:relative}.orbit-container{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{bottom:0;width:100%;margin-bottom:0;background-color:hsla(0,0%,4%,.5)}.orbit-caption,.orbit-next,.orbit-previous{position:absolute;padding:1rem;color:#fefefe}.orbit-next,.orbit-previous{top:50%;transform:translateY(-50%);z-index:10}[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:hsla(0,0%,4%,.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.is-active,.orbit-bullets button:hover{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}.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:transparent}.pagination .ellipsis:after{padding:.1875rem .625rem;content:"\2026";color:#0a0a0a}.pagination-previous.disabled:before,.pagination-previous a:before{display:inline-block;margin-right:.5rem;content:"\00ab"}.pagination-next.disabled:after,.pagination-next a: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{top:50%;left: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;transition:all .2s ease-in-out}.slider-fill.is-dragging{transition:all 0s linear}.slider-handle{top:50%;transform:translateY(-50%);position:absolute;left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;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{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;transform:scaleY(-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;transform:translateX(-50%)}.sticky,.sticky-container{position:relative}.sticky{z-index:0;transform:translateZ(0)}.sticky.is-stuck{position:fixed;z-index:5}.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;-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:hsla(0,0%,4%,.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}.reveal .column,.reveal .columns{min-width:0}.reveal>:last-child{margin-bottom:0}.reveal.collapse{padding:0}.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}.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;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;transform:translateZ(0);border-radius:0;background:#fefefe;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%;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{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}tfoot,thead{color:#0a0a0a}tfoot{background:#f1f1f1}tfoot tr,thead tr{background:transparent}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(2n){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}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(2n):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:transparent}.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;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel[aria-hidden=false]{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:4px solid #fefefe;border-radius:0;box-shadow:0 0 0 1px hsla(0,0%,4%,.2);line-height:0}a.thumbnail{transition:box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{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{vertical-align:middle}.has-tip,.title-bar-title{display:inline-block;font-weight:700}.has-tip{position:relative;border-bottom:1px dotted #8a8a8a;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{border:.75rem inset;border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;position:absolute;bottom:100%;left:50%;transform:translateX(-50%)}.tooltip.top:before,.tooltip:before{display:block;width:0;height:0;content:""}.tooltip.top:before{border:.75rem inset;border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.left:before{border:.75rem inset;border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left:before,.tooltip.right:before{display:block;width:0;height:0;content:"";top:50%;bottom:auto;transform:translateY(-50%)}.tooltip.right:before{border:.75rem inset;border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.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%}.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}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto}.hide-for-portrait,.show-for-landscape{display:block!important}.hide-for-landscape,.show-for-portrait{display:none!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}.off-canvas .is-accordion-submenu{padding-left:1rem}@media print,screen and (min-width:40em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}.column,.columns{padding-right:.9375rem;padding-left:.9375rem}.medium-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.medium-offset-0{margin-left:0}.medium-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.medium-offset-1{margin-left:8.33333%}.medium-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.medium-offset-2{margin-left:16.66667%}.medium-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.medium-offset-3{margin-left:25%}.medium-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.medium-offset-4{margin-left:33.33333%}.medium-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.medium-offset-5{margin-left:41.66667%}.medium-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.medium-offset-6{margin-left:50%}.medium-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.medium-offset-7{margin-left:58.33333%}.medium-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.medium-offset-8{margin-left:66.66667%}.medium-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.medium-offset-9{margin-left:75%}.medium-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.medium-offset-10{margin-left:83.33333%}.medium-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.medium-offset-11{margin-left:91.66667%}.medium-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-1>.column,.medium-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.medium-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-2>.column,.medium-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.medium-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-3>.column,.medium-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.medium-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-4>.column,.medium-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.medium-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-5>.column,.medium-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.medium-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-6>.column,.medium-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.medium-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-7>.column,.medium-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.medium-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-8>.column,.medium-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.medium-flex-dir-row{-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.medium-flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.row.medium-unstack>.column,.row.medium-unstack>.columns{-ms-flex:1 1 0px;flex:1 1 0px}.medium-collapse>.column,.medium-collapse>.columns{padding-right:0;padding-left:0}.medium-uncollapse>.column,.medium-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.column-block{margin-bottom:1.875rem}.column-block>:last-child{margin-bottom:0}.medium-order-1{-ms-flex-order:1;order:1}.medium-order-2{-ms-flex-order:2;order:2}.medium-order-3{-ms-flex-order:3;order:3}.medium-order-4{-ms-flex-order:4;order:4}.medium-order-5{-ms-flex-order:5;order:5}.medium-order-6{-ms-flex-order:6;order:6}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:1.9375rem}h4{font-size:1.5625rem}h5{font-size:1.25rem}h6{font-size:1rem}.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}.button-group.stacked-for-small .button{width:auto;margin-bottom:0}.menu.medium-horizontal>li{display:table-cell}.menu.medium-expanded{display:table;width:100%;table-layout:fixed}.menu.medium-expanded>li:first-child:last-child{width:100%}.menu.medium-vertical>li{display:block}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;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}.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:6px inset;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:6px inset;content:"";border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.position-left.reveal-for-medium{transform:none;z-index:1}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{transform:none;z-index:1}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{transform:none;z-index:1}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{transform:none;z-index:1}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}.pagination li{display:inline-block}.reveal{min-height:0;width:600px;max-width:75rem}.reveal .reveal{right:auto;left:auto;margin:0 auto}.reveal.tiny{width:30%;max-width:75rem}.reveal.small{width:50%;max-width:75rem}.reveal.large{width:90%;max-width:75rem}.top-bar .top-bar-left,.top-bar .top-bar-right{width:auto}.hide-for-medium{display:none!important}}@media print,screen and (min-width:40em) and (min-width:40em){.medium-expand{-ms-flex:1 1 0px;flex:1 1 0px}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media print,screen and (min-width:64em) and (min-width:64em){.large-expand{-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}.large-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.large-offset-0{margin-left:0}.large-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.large-offset-1{margin-left:8.33333%}.large-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.large-offset-2{margin-left:16.66667%}.large-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.large-offset-3{margin-left:25%}.large-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.large-offset-4{margin-left:33.33333%}.large-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.large-offset-5{margin-left:41.66667%}.large-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.large-offset-6{margin-left:50%}.large-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.large-offset-7{margin-left:58.33333%}.large-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.large-offset-8{margin-left:66.66667%}.large-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.large-offset-9{margin-left:75%}.large-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.large-offset-10{margin-left:83.33333%}.large-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.large-offset-11{margin-left:91.66667%}.large-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-1>.column,.large-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.large-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-2>.column,.large-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.large-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-3>.column,.large-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.large-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-4>.column,.large-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.large-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-5>.column,.large-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.large-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-6>.column,.large-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.large-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-7>.column,.large-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.large-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-8>.column,.large-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.large-flex-dir-row{-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.large-flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.row.large-unstack>.column,.row.large-unstack>.columns{-ms-flex:1 1 0px;flex:1 1 0px}.large-collapse>.column,.large-collapse>.columns{padding-right:0;padding-left:0}.large-uncollapse>.column,.large-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.large-order-1{-ms-flex-order:1;order:1}.large-order-2{-ms-flex-order:2;order:2}.large-order-3{-ms-flex-order:3;order:3}.large-order-4{-ms-flex-order:4;order:4}.large-order-5{-ms-flex-order:5;order:5}.large-order-6{-ms-flex-order:6;order:6}.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}.button-group.stacked-for-medium .button{width:auto;margin-bottom:0}.menu.large-horizontal>li{display:table-cell}.menu.large-expanded{display:table;width:100%;table-layout:fixed}.menu.large-expanded>li:first-child:last-child{width:100%}.menu.large-vertical>li{display:block}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;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}.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:6px inset;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:6px inset;content:"";border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.position-left.reveal-for-large{transform:none;z-index:1}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{transform:none;z-index:1}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{transform:none;z-index:1}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{transform:none;z-index:1}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}.hide-for-large{display:none!important}}@media screen and (max-width:39.9375em),screen and (min-width:64em){.show-for-medium-only{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}}@media print{*{background:transparent!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,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}}@media screen and (min-width:0\0){select{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==")}}@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}.media-object.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;display:block}.media-object.stack-for-small .media-object-section img,.reveal{width:100%}.reveal{top:0;left:0;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}.hide-for-small-only,.show-for-medium{display:none!important}}@media screen and (max-width:63.9375em){table.stack tfoot,table.stack thead{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{width:100%}.show-for-large{display:none!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}.hide-for-landscape,.show-for-portrait{display:block!important}}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}.hide-for-landscape,.show-for-portrait{display:none!important}}@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%}}
\ No newline at end of file
+/*! 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%}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{box-sizing:content-box;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;font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}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]{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{box-sizing:border-box;display:table;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}[hidden],template{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{box-sizing:border-box;font-size:100%}*,:after,:before{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{box-sizing:border-box;width:100%}.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:transparent;line-height:1}[data-whatinput=mouse] button{outline:0}.is-visible{display:block!important}.is-hidden{display:none!important}.row{max-width:60rem;margin-right:auto;margin-left:auto;display:-ms-flexbox;display:flex;-ms-flex-flow:row wrap;flex-flow:row wrap}.row .row{margin-right:-.625rem;margin-left:-.625rem}.row .row.collapse{margin-right:0;margin-left:0}.row.expanded,.row:not(.expanded) .row{max-width:none}.row.collapse>.column,.row.collapse>.columns{padding-right:0;padding-left:0}.row.collapse>.column>.row,.row.collapse>.columns>.row,.row.is-collapse-child{margin-right:0;margin-left:0}.column,.columns{-ms-flex:1 1 0px;flex:1 1 0px;padding-right:.625rem;padding-left:.625rem;min-width:0}.column.row.row,.row.row.columns{float:none;display:block}.row .column.row.row,.row .row.row.columns{margin-right:0;margin-left:0;padding-right:0;padding-left:0}.flex-container{display:-ms-flexbox;display:flex}.flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.small-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.small-offset-0{margin-left:0}.small-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.small-offset-1{margin-left:8.33333%}.small-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.small-offset-2{margin-left:16.66667%}.small-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.small-offset-3{margin-left:25%}.small-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.small-offset-4{margin-left:33.33333%}.small-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.small-offset-5{margin-left:41.66667%}.small-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.small-offset-6{margin-left:50%}.small-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.small-offset-7{margin-left:58.33333%}.small-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.small-offset-8{margin-left:66.66667%}.small-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.small-offset-9{margin-left:75%}.small-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.small-offset-10{margin-left:83.33333%}.small-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.small-offset-11{margin-left:91.66667%}.small-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-1>.column,.small-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.small-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-2>.column,.small-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.small-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-3>.column,.small-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.small-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-4>.column,.small-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.small-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-5>.column,.small-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.small-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-6>.column,.small-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.small-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-7>.column,.small-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.small-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.small-up-8>.column,.small-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.small-collapse>.column,.small-collapse>.columns{padding-right:0;padding-left:0}.small-uncollapse>.column,.small-uncollapse>.columns{padding-right:.625rem;padding-left:.625rem}.row.large-unstack>.column,.row.large-unstack>.columns,.row.medium-unstack>.column,.row.medium-unstack>.columns{-ms-flex:0 0 100%;flex:0 0 100%}.shrink{-ms-flex:0 0 auto;flex:0 0 auto;max-width:100%}.column-block{margin-bottom:1.25rem}.column-block>:last-child{margin-bottom:0}.align-right{-ms-flex-pack:end;justify-content:flex-end}.align-center{-ms-flex-pack:center;justify-content:center}.align-justify{-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-ms-flex-pack:distribute;justify-content:space-around}.align-top{-ms-flex-align:start;align-items:flex-start}.align-self-top{-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-ms-flex-item-align:end;align-self:flex-end}.align-middle{-ms-flex-align:center;align-items:center}.align-self-middle{-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.align-stretch{-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch}.small-order-1{-ms-flex-order:1;order:1}.small-order-2{-ms-flex-order:2;order:2}.small-order-3{-ms-flex-order:3;order:3}.small-order-4{-ms-flex-order:4;order:4}.small-order-5{-ms-flex-order:5;order:5}.small-order-6{-ms-flex-order:6;order:6}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}b,em,i,strong{line-height:inherit}b,strong{font-weight:700}small{font-size:80%;line-height:inherit}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{line-height:0;color:#cacaca}h1{font-size:1.5rem}h1,h2{line-height:1.4;margin-top:0;margin-bottom:.5rem}h2{font-size:1.25rem}h3{font-size:1.1875rem}h3,h4{line-height:1.4;margin-top:0;margin-bottom:.5rem}h4{font-size:1.125rem}h5{font-size:1.0625rem}h5,h6{line-height:1.4;margin-top:0;margin-bottom:.5rem}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:60rem;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{list-style-type:disc}ol,ul{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{border-bottom:1px dotted #0a0a0a;color:#0a0a0a;cursor:help}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;font-weight:400}code,kbd{background-color:#e6e6e6;font-family:Consolas,Liberation Mono,Courier,monospace;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0}.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}.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}.show-for-print{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;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;box-shadow:inset 0 1px 2px hsla(0,0%,4%,.1);font-family:inherit;font-size:1rem;font-weight:400;color:#0a0a0a;transition:box-shadow .5s,border-color .25s ease-in-out;-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:none;border:1px solid #8a8a8a;background-color:#fefefe;box-shadow:0 0 5px #cacaca;transition:box-shadow .5s,border-color .25s ease-in-out}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]{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,.input-group>:last-child>*{border-radius:0 0 0 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;background:#fefefe}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;font-family:inherit;font-size:1rem;line-height:normal;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}select,select:focus{background-color:#fefefe;transition:box-shadow .5s,border-color .25s ease-in-out}select:focus{outline:none;border:1px solid #8a8a8a;box-shadow:0 0 5px #cacaca}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}.form-error,.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;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.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.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.dropdown:after{display:block;width:0;height:0;border:.4em inset;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.arrow-only:after{top:-.1em;float:none;margin-left:0}.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-for-medium .button,.button-group.stacked-for-small .button,.button-group.stacked .button{width:100%}.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child,.button-group.stacked .button:last-child{margin-bottom:0}.menu{margin:0;list-style-type:none}.menu>li{display:table-cell;vertical-align:middle}[data-whatinput=mouse] .menu>li{outline:0}.menu>li>a{display:block;padding:.7rem 1rem;line-height:1}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu>li>a i,.menu>li>a i+span,.menu>li>a img,.menu>li>a img+span,.menu>li>a svg,.menu>li>a svg+span{vertical-align:middle}.menu>li>a i,.menu>li>a img,.menu>li>a svg{margin-right:.25rem;display:inline-block}.menu.horizontal>li,.menu>li{display:table-cell}.menu.expanded{display:table;width:100%;table-layout:fixed}.menu.expanded>li:first-child:last-child{width:100%}.menu.vertical>li{display:block}.menu.simple li{display:inline-block;vertical-align:top;line-height:1}.menu.simple a{padding:0}.menu.simple li{margin-left:0;margin-right:1rem}.menu.simple.align-right li{margin-right:0;margin-left:1rem}.menu.align-right:after,.menu.align-right:before{display:table;content:" "}.menu.align-right:after{clear:both}.menu.align-right>li{float:right}.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-top.vertical a>span{margin:auto}.menu.nested{margin-left:1rem}.menu .active>a{background:#1779ba;color:#fefefe}.menu.menu-bordered li{border:1px solid #e6e6e6}.menu.menu-bordered li:not(:first-child){border-top:0}.menu.menu-hover li:hover{background-color:#e6e6e6}.menu-text{padding-top:0;padding-bottom:0;padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered{text-align:center}.menu-centered>.menu{display:inline-block;vertical-align:top}.no-js [data-responsive-menu] ul{display:none}.dropdown-pane{position:absolute;z-index:10;display:block;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-open{visibility:visible}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.no-js .dropdown.menu ul{display:none}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{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:6px inset;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:6px inset;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;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}.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:6px inset;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:6px inset;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;width:100%;height:100%;transition:opacity .5s ease,visibility .5s ease;background:hsla(0,0%,100%,.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:1;transition:transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-overlap{z-index:10}.off-canvas.is-transition-overlap.is-open{box-shadow:0 0 10px hsla(0,0%,4%,.7)}.off-canvas.is-open{transform:translate(0)}.off-canvas-absolute{position:absolute;z-index:1;transition: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-overlap{z-index:10}.off-canvas-absolute.is-transition-overlap.is-open{box-shadow:0 0 10px hsla(0,0%,4%,.7)}.off-canvas-absolute.is-open{transform:translate(0)}.position-left{top:0;left:0;width:250px;height:100%;transform:translateX(-250px);overflow-y:auto}.position-left.is-open~.off-canvas-content{transform:translateX(250px)}.position-left.is-transition-push:after{position:absolute;top:0;right:0;height:100%;width:1px;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-left.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-right{top:0;right:0;width:250px;height:100%;transform:translateX(250px);overflow-y:auto}.position-right.is-open~.off-canvas-content{transform:translateX(-250px)}.position-right.is-transition-push:after{position:absolute;top:0;left:0;height:100%;width:1px;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-right.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-top{top:0;left:0;width:100%;height:250px;transform:translateY(-250px);overflow-x:auto}.position-top.is-open~.off-canvas-content{transform:translateY(250px)}.position-top.is-transition-push:after{position:absolute;bottom:0;left:0;height:1px;width:100%;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-top.is-transition-overlap.is-open~.off-canvas-content{transform:none}.position-bottom{bottom:0;left:0;width:100%;height:250px;transform:translateY(250px);overflow-x:auto}.position-bottom.is-open~.off-canvas-content{transform:translateY(-250px)}.position-bottom.is-transition-push:after{position:absolute;top:0;left:0;height:1px;width:100%;box-shadow:0 0 10px hsla(0,0%,4%,.7);content:" "}.position-bottom.is-transition-overlap.is-open~.off-canvas-content{transform:none}.off-canvas-content{transition:transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.hide{display:none!important}.invisible{visibility:hidden}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto}.hide-for-portrait,.show-for-landscape{display:block!important}.hide-for-landscape,.show-for-portrait{display:none!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}.full-width{margin-left:-2.1875rem;max-width:calc(100% + 70px);width:calc(100% + 70px)}.image-as-background{background-position:50%;background-repeat:no-repeat;background-size:cover}.video-as-background{height:100%;width:100%;display:block;object-fit:cover;object-position:center top;position:absolute;z-index:1}.svg-defs{display:none}.alignleft{display:inline;float:left;margin:0 1rem 0 0}.alignright{display:inline;float:right;margin:0 0 0 1rem}.aligncenter{display:block;margin-left:auto;margin-right:auto}pre{background-color:#e6e6e6;color:#0a0a0a;font-weight:400;line-height:1.5;margin:1rem 0;overflow:auto;padding:.125rem .3125rem .0625rem;white-space:pre;word-break:normal;word-wrap:normal}code,kbd,pre,tt,var{font-family:Consolas,Liberation Mono,Courier,monospace;font-size:em(15)}abbr,acronym{border-bottom:1px solid #cacaca;cursor:help}ins,mark{text-decoration:none}sub,sup{font-size:75%;height:0;line-height:0;position:relative;vertical-align:baseline}sup{bottom:1ex}sub{top:.5ex}small{font-size:75%}big{font-size:125%}.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.wp-caption{margin:0 0 1rem;max-width:100%}.wp-caption img[class*=wp-image-]{display:block;margin:0 auto}.wp-caption.aligncenter{margin:0 auto 1rem}.wp-caption.alignleft{margin-right:1rem}.wp-caption.alignright{margin-left:1rem}.wp-caption .wp-caption-text{margin:1rem 0}.wp-caption-text{text-align:center}.gallery{margin:0 0 1rem}.gallery-caption{display:block}.gallery-item{height:100% auto;width:100% auto;display:inline-block;text-align:center;vertical-align:top}.gallery-columns-2 .gallery-item{max-width:50%}.gallery-columns-3 .gallery-item{max-width:33.33%}.gallery-columns-4 .gallery-item{max-width:25%}.gallery-columns-5 .gallery-item{max-width:20%}.gallery-columns-6 .gallery-item{max-width:16.66%}.gallery-columns-7 .gallery-item{max-width:14.28%}.gallery-columns-8 .gallery-item{max-width:12.5%}.gallery-columns-9 .gallery-item{max-width:11.11%}.wp-smiley{margin:0;padding:0;border:none}.hamburger-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.hamburger-icon:after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:""}.hamburger-icon:hover:after{background:#cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.admin-bar .off-canvas{padding-top:3.5rem}.off-canvas .is-accordion-submenu{padding-left:1rem}.content-block{padding:1rem}.comments-area{border-top:1px solid #cacaca;margin:1rem 0}.comments-area .comment-reply-title{margin-top:1rem}.comments-area .comments-title{font-size:em(24);margin-top:1rem}.comments-area .comment-notes{font-size:em(16);margin-top:1rem}.comment-form-author label,.comment-form-comment label,.comment-form-email label,.comment-form-url label{float:left;font-size:em(16);text-transform:uppercase;width:100%}.comment-form{width:100%}.comment-form:after,.comment-form:before{display:table;content:" "}.comment-form:after{clear:both}.comment-form input:not(.submit){clear:both;transition:border .2s ease-in-out;width:100%}.comment-form textarea{max-width:54.375rem;transition:border .2s ease-in-out}.comment-form .form-submit{margin:0}.comment-form input[type=submit]{width:12.25rem}.comment-list{padding:0;list-style:none;margin:0}.comment-list:after,.comment-list:before{display:table;content:" "}.comment-list:after{clear:both}.comment-list .even:not(.bypostauthor)>.comment-body{background-color:#cacaca}.comment-list .comment-body{margin:1rem 0;padding:1rem}.comment-list .comment-content{margin:1rem 0;max-width:58.5rem}.comment-list .comment-meta{margin:0 0 1rem}.comment-list .comment-meta:after,.comment-list .comment-meta:before{display:table;content:" "}.comment-list .comment-meta:after{clear:both}.comment-list .comment-author{line-height:1}.comment-list .comment-metadata{line-height:1;margin-top:.3125rem}.comment-list .comment-metadata a{color:#0a0a0a;text-decoration:none}.comment-list .comment-metadata .comment-edit-link,.comment-list .comment-metadata time{font-size:em(12)}.comment-list .avatar{border-radius:50%;float:left;margin:0 1rem 0 0}.comment-list .bypostauthor{background-color:#767676;display:block}.comment-list .comment-reply-link{font-weight:700}.comment-list code,.comment-list pre{margin:0;width:100%}.comment-list .children{list-style:none;margin:2rem 0;padding-left:1rem}.comment-list .children .depth-4 .comment-author,.comment-list .children .depth-5 .comment-author,.comment-list .children .depth-6 .comment-author,.comment-list .children .depth-7 .comment-author,.comment-list .children .depth-8 .comment-author,.comment-list .children .depth-9 .comment-author,.comment-list .children .depth-10 .comment-author{line-height:1.25}.comment-list .comment-respond{background-color:#fefefe;padding:1rem 0}.comment-list .comment-respond .comment-reply-title a{display:inline-block;text-transform:lowercase}.comment-list .comment-respond .comment-reply-title a:before{content:"("}.comment-list .comment-respond .comment-reply-title a:after{content:")"}.comment-list .comment-respond .form-submit{margin:0}.comment-list .comment-respond .form-submit input[type=submit]{margin-top:.3125rem}.comments-link,.sticky{display:block}.hentry{margin:0 0 2rem}.byline,.updated:not(.published){display:none}.group-blog .byline,.single .byline{display:inline}.entry-content,.entry-summary,.page-content{margin:2rem 0 0}.page-links{clear:both;margin:0 0 2rem}.tags-links{margin-left:2rem}.edit-link a{font-size:em(12);text-transform:lowercase}.edit-link a:before{content:"("}.edit-link a:after{content:")"}.archive .format-aside .entry-title,.blog .format-aside .entry-title{display:none}.site-main .comment-navigation,.site-main .post-navigation,.site-main .posts-navigation{margin:0 0 1rem;overflow:hidden}.comment-navigation .nav-previous,.post-navigation .nav-previous,.posts-navigation .nav-previous{height:50% auto;width:50% auto;float:left}.comment-navigation .nav-next,.post-navigation .nav-next,.posts-navigation .nav-next{height:50% auto;width:50% auto;float:right;text-align:right}.comment-content,.comments-title,.entry-content,.entry-title,.widget,.widget-title{word-break:keep-all;word-wrap:break-word}.site-footer,.site-header{margin:2rem auto}.hero{overflow-y:hidden;position:relative;z-index:1}.hero:after{height:100%;width:100%;position:absolute;top:0;right:0;background-color:hsla(0,0%,4%,.7);content:"";z-index:2}.hero-content{padding:4rem 0;position:relative;z-index:3;padding:8rem 0}.hero-headline{font-size:3rem;line-height:1.2;margin-bottom:2rem}.hero-text{font-size:1.125rem}.hero-button{margin-top:.625rem}@media print,screen and (min-width:40em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}.column,.columns{padding-right:.9375rem;padding-left:.9375rem}.medium-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.medium-offset-0{margin-left:0}.medium-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.medium-offset-1{margin-left:8.33333%}.medium-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.medium-offset-2{margin-left:16.66667%}.medium-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.medium-offset-3{margin-left:25%}.medium-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.medium-offset-4{margin-left:33.33333%}.medium-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.medium-offset-5{margin-left:41.66667%}.medium-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.medium-offset-6{margin-left:50%}.medium-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.medium-offset-7{margin-left:58.33333%}.medium-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.medium-offset-8{margin-left:66.66667%}.medium-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.medium-offset-9{margin-left:75%}.medium-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.medium-offset-10{margin-left:83.33333%}.medium-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.medium-offset-11{margin-left:91.66667%}.medium-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-1>.column,.medium-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.medium-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-2>.column,.medium-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.medium-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-3>.column,.medium-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.medium-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-4>.column,.medium-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.medium-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-5>.column,.medium-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.medium-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-6>.column,.medium-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.medium-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-7>.column,.medium-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.medium-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.medium-up-8>.column,.medium-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.medium-flex-dir-row{-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.medium-flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.row.medium-unstack>.column,.row.medium-unstack>.columns{-ms-flex:1 1 0px;flex:1 1 0px}.medium-collapse>.column,.medium-collapse>.columns{padding-right:0;padding-left:0}.medium-uncollapse>.column,.medium-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.column-block{margin-bottom:1.875rem}.column-block>:last-child{margin-bottom:0}.medium-order-1{-ms-flex-order:1;order:1}.medium-order-2{-ms-flex-order:2;order:2}.medium-order-3{-ms-flex-order:3;order:3}.medium-order-4{-ms-flex-order:4;order:4}.medium-order-5{-ms-flex-order:5;order:5}.medium-order-6{-ms-flex-order:6;order:6}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:1.9375rem}h4{font-size:1.5625rem}h5{font-size:1.25rem}h6{font-size:1rem}.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}.button-group.stacked-for-small .button{width:auto;margin-bottom:0}.menu.medium-horizontal>li{display:table-cell}.menu.medium-expanded{display:table;width:100%;table-layout:fixed}.menu.medium-expanded>li:first-child:last-child{width:100%}.menu.medium-vertical>li{display:block}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;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}.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:6px inset;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:6px inset;content:"";border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.position-left.reveal-for-medium{transform:none;z-index:1}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{transform:none;z-index:1}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{transform:none;z-index:1}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{transform:none;z-index:1}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}.hide-for-medium{display:none!important}.hero-headline{margin-bottom:1rem}.hero-text{font-size:1.5rem}}@media print,screen and (min-width:40em) and (min-width:40em){.medium-expand{-ms-flex:1 1 0px;flex:1 1 0px}}@media screen and (min-width:40em){.comment-form input:not(.submit){max-width:15.625rem}.comment-list .children{padding-left:2rem}.comment-list .children .depth-4 .comment-author,.comment-list .children .depth-5 .comment-author,.comment-list .children .depth-6 .comment-author,.comment-list .children .depth-7 .comment-author,.comment-list .children .depth-8 .comment-author,.comment-list .children .depth-9 .comment-author,.comment-list .children .depth-10 .comment-author{line-height:1}.comment-list .comment-respond{padding-left:2rem;padding-right:2rem}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media screen and (min-width:48em){.comment-list .children{padding-left:4rem}}@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) and (min-width:64em){.large-expand{-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}.large-1{-ms-flex:0 0 8.33333%;flex:0 0 8.33333%;max-width:8.33333%}.large-offset-0{margin-left:0}.large-2{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.large-offset-1{margin-left:8.33333%}.large-3{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.large-offset-2{margin-left:16.66667%}.large-4{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.large-offset-3{margin-left:25%}.large-5{-ms-flex:0 0 41.66667%;flex:0 0 41.66667%;max-width:41.66667%}.large-offset-4{margin-left:33.33333%}.large-6{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.large-offset-5{margin-left:41.66667%}.large-7{-ms-flex:0 0 58.33333%;flex:0 0 58.33333%;max-width:58.33333%}.large-offset-6{margin-left:50%}.large-8{-ms-flex:0 0 66.66667%;flex:0 0 66.66667%;max-width:66.66667%}.large-offset-7{margin-left:58.33333%}.large-9{-ms-flex:0 0 75%;flex:0 0 75%;max-width:75%}.large-offset-8{margin-left:66.66667%}.large-10{-ms-flex:0 0 83.33333%;flex:0 0 83.33333%;max-width:83.33333%}.large-offset-9{margin-left:75%}.large-11{-ms-flex:0 0 91.66667%;flex:0 0 91.66667%;max-width:91.66667%}.large-offset-10{margin-left:83.33333%}.large-12{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.large-offset-11{margin-left:91.66667%}.large-up-1{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-1>.column,.large-up-1>.columns{-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}.large-up-2{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-2>.column,.large-up-2>.columns{-ms-flex:0 0 50%;flex:0 0 50%;max-width:50%}.large-up-3{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-3>.column,.large-up-3>.columns{-ms-flex:0 0 33.33333%;flex:0 0 33.33333%;max-width:33.33333%}.large-up-4{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-4>.column,.large-up-4>.columns{-ms-flex:0 0 25%;flex:0 0 25%;max-width:25%}.large-up-5{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-5>.column,.large-up-5>.columns{-ms-flex:0 0 20%;flex:0 0 20%;max-width:20%}.large-up-6{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-6>.column,.large-up-6>.columns{-ms-flex:0 0 16.66667%;flex:0 0 16.66667%;max-width:16.66667%}.large-up-7{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-7>.column,.large-up-7>.columns{-ms-flex:0 0 14.28571%;flex:0 0 14.28571%;max-width:14.28571%}.large-up-8{-ms-flex-wrap:wrap;flex-wrap:wrap}.large-up-8>.column,.large-up-8>.columns{-ms-flex:0 0 12.5%;flex:0 0 12.5%;max-width:12.5%}.large-flex-dir-row{-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-ms-flex-direction:column-reverse;flex-direction:column-reverse}.large-flex-child-auto{-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-ms-flex:0 1 auto;flex:0 1 auto}.row.large-unstack>.column,.row.large-unstack>.columns{-ms-flex:1 1 0px;flex:1 1 0px}.large-collapse>.column,.large-collapse>.columns{padding-right:0;padding-left:0}.large-uncollapse>.column,.large-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.large-order-1{-ms-flex-order:1;order:1}.large-order-2{-ms-flex-order:2;order:2}.large-order-3{-ms-flex-order:3;order:3}.large-order-4{-ms-flex-order:4;order:4}.large-order-5{-ms-flex-order:5;order:5}.large-order-6{-ms-flex-order:6;order:6}.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}.button-group.stacked-for-medium .button{width:auto;margin-bottom:0}.menu.large-horizontal>li{display:table-cell}.menu.large-expanded{display:table;width:100%;table-layout:fixed}.menu.large-expanded>li:first-child:last-child{width:100%}.menu.large-vertical>li{display:block}.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:6px inset;content:"";border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;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}.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:6px inset;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:6px inset;content:"";border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.position-left.reveal-for-large{transform:none;z-index:1}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{transform:none;z-index:1}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{transform:none;z-index:1}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{transform:none;z-index:1}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}.hide-for-large{display:none!important}}@media screen and (min-width:64em){.full-width{margin-left:-7.1875rem;max-width:calc(100% + 230px);width:calc(100% + 230px)}}@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}}@media screen and (min-width:85.375em){.comments-area{margin-left:auto;margin-right:auto}}@media screen and (min-width:0\0){select{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==")}}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}.hide-for-landscape,.show-for-portrait{display:block!important}}@media screen and (max-width:63.9375em){.show-for-large{display:none!important}}@media print{*{background:transparent!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,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}}@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}.hide-for-small-only,.show-for-medium{display:none!important}}
\ No newline at end of file
diff --git a/template-parts/content-blocks/block-fifty_fifty_block.php b/template-parts/content-blocks/block-fifty_fifty_block.php
new file mode 100644
index 000000000..7a610bce7
--- /dev/null
+++ b/template-parts/content-blocks/block-fifty_fifty_block.php
@@ -0,0 +1,27 @@
+<?php
+/**
+ * The template used for displaying fifty/fifty blocks.
+ *
+ * @package _s
+ */
+
+// Get the block layout field so block template is conditionally loaded.
+$block_layout = get_sub_field( 'block_layout' );
+
+switch ( $block_layout ) {
+
+	case 'text_media' :
+		get_template_part( 'template-parts/content-blocks/block', 'fifty_text_media' );
+		break;
+
+	case 'media_text' :
+		get_template_part( 'template-parts/content-blocks/block', 'fifty_media_text' );
+		break;
+
+	case 'text_text' :
+		get_template_part( 'template-parts/content-blocks/block', 'fifty_text_only' );
+		break;
+
+	default :
+		get_template_part( 'template-parts/content-blocks/block', 'fifty_text_media' );
+}
diff --git a/template-parts/content-blocks/block-fifty_media_text.php b/template-parts/content-blocks/block-fifty_media_text.php
new file mode 100644
index 000000000..d9c1dc582
--- /dev/null
+++ b/template-parts/content-blocks/block-fifty_media_text.php
@@ -0,0 +1,26 @@
+<?php
+/**
+ * The template used for displaying fifty/fifty media/text.
+ *
+ * @package _s
+ */
+
+// Get <img> data.
+$image_data = get_sub_field( 'media_left' );
+
+// Start a <container> with a possible media background.
+_s_display_block_options( array(
+	'container' => 'section', // Any HTML5 container: section, div, etc...
+	'class'     => 'content-block fifty-media-text', // The class of the container.
+) );
+?>
+	<div class="row">
+		<div class="column small-12 medium-6 fifty-media-wrap">
+			<img class="fifty-media-image" src="<?php echo esc_url( $image_data['sizes']['medium'] );  ?>" alt="<?php echo esc_html( $image_data['alt'] ); ?>">
+		</div><!-- .fifty-media-wrap -->
+
+		<div class="column small-12 medium-6 fifty-text-wrap">
+			<?php echo force_balance_tags( get_sub_field( 'content_right' ) ); // WPCS XSS OK. ?>
+		</div><!-- .fifty-text-wrap -->
+	</div><!-- .row -->
+</section><!-- .fifty-media-text -->
diff --git a/template-parts/content-blocks/block-fifty_text_media.php b/template-parts/content-blocks/block-fifty_text_media.php
new file mode 100644
index 000000000..a4e69d85e
--- /dev/null
+++ b/template-parts/content-blocks/block-fifty_text_media.php
@@ -0,0 +1,26 @@
+<?php
+/**
+ * The template used for displaying fifty-fifty text/media.
+ *
+ * @package _s
+ */
+
+// Get <img> data.
+$image_data = get_sub_field( 'media_right' );
+
+// Start a <container> with a possible media background.
+_s_display_block_options( array(
+	'container' => 'section', // Any HTML5 container: section, div, etc...
+	'class'     => 'content-block fifty-text-media', // Container class.
+) );
+?>
+	<div class="row">
+		<div class="column small-12 medium-6 fifty-text-wrap">
+			<?php echo force_balance_tags( get_sub_field( 'content_left' ) ); // WPCS: XSS OK. ?>
+		</div><!-- .fifty-text-wrap -->
+
+		<div class="column small-12 medium-6 fifty-media-wrap">
+			<img class="fifty-media-image" src="<?php echo esc_url( $image_data['sizes']['medium'] );  ?>" alt="<?php echo esc_html( $image_data['alt'] ); ?>">
+		</div><!-- .fifty-media-wrap -->
+	</div><!-- .row -->
+</section><!-- .fifty-text-media -->
diff --git a/template-parts/content-blocks/block-fifty_text_only.php b/template-parts/content-blocks/block-fifty_text_only.php
new file mode 100644
index 000000000..cec795533
--- /dev/null
+++ b/template-parts/content-blocks/block-fifty_text_only.php
@@ -0,0 +1,23 @@
+<?php
+/**
+ * The template used for displaying 50/50 text only.
+ *
+ * @package _s
+ */
+
+// Start a <container> with a possible media background.
+_s_display_block_options( array(
+	'container' => 'section', // Any HTML5 container: section, div, etc...
+	'class'     => 'rcontent-block fifty-text-only', // The container class.
+) );
+?>
+	<div class="row">
+		<div class="column small-12 medium-6 fifty-text-left">
+			<?php echo force_balance_tags( get_sub_field( 'content_left' ) ); // WPCS: XSS OK. ?>
+		</div><!-- .fifty-text-left-->
+
+		<div class="column small-12 medium-6 fifty-text-right">
+			<?php echo force_balance_tags( get_sub_field( 'content_right' ) ); // WPCS: XSS OK. ?>
+		</div><!-- .fifty-text-right-->
+	</div><!-- .row -->
+</section><!-- .fifty-text-only -->
diff --git a/template-parts/content-blocks/block-generic_content.php b/template-parts/content-blocks/block-generic_content.php
index 0657d08b1..011781d22 100644
--- a/template-parts/content-blocks/block-generic_content.php
+++ b/template-parts/content-blocks/block-generic_content.php
@@ -5,15 +5,15 @@
  * @package _s
  */
 
-// Set up fields.
-$title = get_sub_field( 'title' );
-$content = get_sub_field( 'content' );
-
+// Start a <container> with a possible media background.
+_s_display_block_options( array(
+	'container' => 'section', // Any HTML5 container: section, div, etc...
+	'class'     => 'content-block generic-content', // The class of the container.
+) );
 ?>
-<section class="generic-content">
-	<?php if ( $title ) : ?>
-		<p class="generic-content-title"><?php echo esc_html( $title ); ?>
-	<?php endif; ?>
-
-	<?php echo force_balance_tags( $content ); // WP XSS OK. ?>
-</section><!-- .hero-area -->
+	<div class="row">
+		<div class="column small-12">
+		<?php echo force_balance_tags( get_sub_field( 'content' ) ); // WP XSS OK. ?>
+		</div><!-- .column -->
+	</div><!-- .row -->
+</section><!-- .generic-content -->
diff --git a/template-parts/content-blocks/block-hero.php b/template-parts/content-blocks/block-hero.php
index 9e8b3806a..30f5f1e5f 100644
--- a/template-parts/content-blocks/block-hero.php
+++ b/template-parts/content-blocks/block-hero.php
@@ -6,25 +6,27 @@
  */
 
 // Set up fields.
-$background_image = get_sub_field( 'background_image' );
-$background_video = get_sub_field( 'background_video' );
-$title = get_sub_field( 'title' );
-$blurb = get_sub_field( 'blurb' );
+$headline = get_sub_field( 'headline' );
+$text = get_sub_field( 'text' );
 $button_text = get_sub_field( 'button_text' );
 $button_url = get_sub_field( 'button_url' );
-$background_video_markup = '';
-
-// If a background video is uploaded.
-if ( $background_video['url'] ) {
-	$background_video_markup .= '<video class="video-as-background" autoplay muted loop preload="auto"><source src="' . esc_url( $background_video['url'] ) . '" type="video/mp4"></video>';
-}
 
+// Start a <container> with a possible media background.
+_s_display_block_options( array(
+	'container' => 'section', // Any HTML5 container: section, div, etc...
+	'class'     => 'hero content-block', // The class of the container.
+) );
 ?>
-<section class="hero-area image-as-background" style="background-image: url( <?php echo esc_url( $background_image['url'] ); ?> );" role="dialog" aria-labelledby="hero-title" aria-describedby="hero-description">
-	<?php echo $background_video_markup; // WPCS XSS OK. ?>
-	<div class="hero-content">
-		<h2 class="hero-title"><?php echo esc_html( $title ); ?></h2>
-		<p class="hero-description"><?php echo force_balance_tags( $blurb ); // WP XSS OK. ?></p>
-		<a href="<?php echo esc_url( $button_url ); ?>" class="hero-button" title="<?php echo esc_html( $button_text ); ?>"><?php echo esc_html( $button_text ); ?></a>
+	<div class="row align-center hero-content">
+		<div class="small-8 large-11 align-self-middle text-center">
+		<?php if ( $headline ) : ?>
+			<h1 class="hero-headline"><?php echo esc_html( $headline ); ?></h2>
+		<?php endif; ?>
+		<?php if ( $text ) : ?>
+			<h2 class="hero-text"><?php echo force_balance_tags( $text ); // WPCS xss ok. ?></h2>
+		<?php endif; ?>
+		<?php if ( $button_text ) : ?>
+			<a href="<?php echo esc_url( $button_url ); ?>" class="button large hero-button" title="<?php echo esc_attr( $button_text ); ?>"><?php echo esc_html( $button_text ); ?></a>
+		<?php endif; ?>
 	</div><!-- .hero-content -->
-</section><!-- .hero-area -->
+</section><!-- .hero -->
diff --git a/template-parts/content-page.php b/template-parts/content-page.php
index 86b2c30ef..4e3f0de02 100644
--- a/template-parts/content-page.php
+++ b/template-parts/content-page.php
@@ -32,7 +32,7 @@
 					sprintf(
 						/* translators: %s: Name of current post */
 						esc_html__( 'Edit %s', '_s' ),
-						the_title( '<span class="screen-reader-text">"', '"</span>', false )
+						the_title( '<span class="show-for-sr">"', '"</span>', false )
 					),
 					'<span class="edit-link">',
 					'</span>'
diff --git a/template-parts/content.php b/template-parts/content.php
index 973e20b17..767cc4839 100644
--- a/template-parts/content.php
+++ b/template-parts/content.php
@@ -30,7 +30,7 @@
 			the_content( sprintf(
 				/* translators: %s: Name of current post. */
 				wp_kses( __( 'Continue reading %s <span class="meta-nav">&rarr;</span>', '_s' ), array( 'span' => array( 'class' => array() ) ) ),
-				the_title( '<span class="screen-reader-text">"', '"</span>', false )
+				the_title( '<span class="show-for-sr">"', '"</span>', false )
 			) );
 
 			wp_link_pages( array(