diff --git a/.gitignore b/.gitignore index aca410d..34ece95 100644 --- a/.gitignore +++ b/.gitignore @@ -3,4 +3,5 @@ __pycache__ *~ key.py -*.pyc \ No newline at end of file +*.pyc +*.yaml \ No newline at end of file diff --git a/bot1/chats.py b/bot1/chats.py index 8f92a50..3ded811 100644 --- a/bot1/chats.py +++ b/bot1/chats.py @@ -59,14 +59,8 @@ def download_file(url): return local_filename - - - - - - - -class Chat(SaveFileObject): +class BaseChat(SaveFileObject): + "Basis für einen Telegram Chat" def __init__(self,id, bot): self.id=id #self.chat_id=chat_id @@ -84,8 +78,6 @@ class Chat(SaveFileObject): "type": self.type, "mode": self.mode } - def asdict(self): - return self.to_dict() @classmethod def from_dict(self, bot, d): c=Chat(d["id"],bot) @@ -94,20 +86,17 @@ class Chat(SaveFileObject): c.mode=d.get("mode","") return c - def inline(self, query): - InlineQueryResultArticle - r=solr.search("text_txt: %s" % query.query,sort="date_dt desc").docs - r= [fet.find_one({"slug": rr["id"]}) for rr in r ] - res=[ InlineQueryResultArticle( - id=d["url"], - title=d["title"], - url=urljoin(TARGET,d["url"]), - thumb_url = urljoin(TARGET,d["image"]), - input_message_content = InputTextMessageContent(message_text=urljoin(TARGET,d["url"])) - ) for d in r] - links=[p["title"]+": "+"(%s) "% p["public_date"] + urljoin(TARGET,p["url"]) for p in r] - self.bot.answer_inline_query(inline_query_id=query.id,results=res ) - return + def echo(self,update): + self.reply_msg(yaml.dump(update._raw)+"\nfrom"+str(get_from_id(update))) + def send_msg(self, text,**kwargs): + self.bot.send_message(chat_id=self.id, text=text, **kwargs) + def reply_msg(self, text, **kwargs): + self.bot.send_message(chat_id=self.id, text=text, reply_to_message_id=self.last_message_id,**kwargs) + def asdict(self): + return self.to_dict() + + def inline(self,query): + pass def process_update(self,update): @@ -137,7 +126,7 @@ class Chat(SaveFileObject): text=update.callback_query.message.text+": "+update.callback_query.data) if update.message and update.message.photo: - ff=max(update.message.photo, key=lambda x: x.file_size) + ff=max(update.message.photo, key=lambda x: x.file_size) # Foto mit bester Auflösung fff = self.bot.get_file(ff.file_id) url=fff.get_download_url(API_KEY) r = requests.get(url) @@ -150,19 +139,28 @@ class Chat(SaveFileObject): u=users[update] users.to_file() - def echo(self,update): - self.reply_msg(yaml.dump(update._raw)+"\nfrom"+str(get_from_id(update))) - def send_msg(self, text,**kwargs): - self.bot.send_message(chat_id=self.id, text=text, **kwargs) - def reply_msg(self, text, **kwargs): - self.bot.send_message(chat_id=self.id, text=text, reply_to_message_id=self.last_message_id,**kwargs) + +class Chat(BaseChat): + + def inline(self, query): + #r=solr.search("text_txt: %s" % ,sort="date_dt desc").docs + links,hits=solr.search(query.query) + r= links[0:6] + res=[ InlineQueryResultArticle( + id=d["url"], + title=d["title"], + url=urljoin(TARGET,d["url"]), + thumb_url = urljoin(TARGET,d["image"]), + input_message_content = InputTextMessageContent(message_text=urljoin(TARGET,d["url"])) + ) for d in r] + #links=[p["title"]+": "+"(%s) "% p["public_date"] + urljoin(TARGET,p["url"]) for p in r] + self.bot.answer_inline_query(inline_query_id=query.id,results=res ) + return def process_command(self,cmd,txt,update): self.last_message_id=get_message_id(update) - u=users[update] - - print("--\ndict: %s" % str(users.asdict())) + # print("--\ndict: %s" % str(users.asdict())) #users[get_from_id(update)]=u if cmd == "/s" or cmd =="/search": @@ -179,12 +177,16 @@ class Chat(SaveFileObject): self.reply_msg("Mode: %s" % txt) return True elif cmd == "/debug": + if not u.fet_user: + self.reply_msg("bitte vorher /auth ausführen wenn du ein FET Mitglied bist") + return True if self.debug: self.debug = False else: self.debug = True #not self.debug self.reply_msg("Debug: %s" % str(self.debug)) return True + elif cmd =="/post": if not u.fet_user: self.reply_msg("bitte vorher /auth ausführen wenn du ein FET Mitglied bist") @@ -192,6 +194,9 @@ class Chat(SaveFileObject): self.workflows[get_from_id(update)]=CreatePostWorkflow(chat=self) return True elif cmd == "/reindex": + if not u.fet_user: + self.reply_msg("bitte vorher /auth ausführen wenn du ein FET Mitglied bist") + return True self.reply_msg("Das kann ein bissl dauern...") solr.reindex() self.send_msg("Fertig mit dem neuen Index") @@ -221,6 +226,7 @@ def get_command_from_update(update): + class ChatManager(SaveFileMapping): def __init__(self,bot): diff --git a/bot1/states.py b/bot1/states.py index df3ef72..4853009 100644 --- a/bot1/states.py +++ b/bot1/states.py @@ -29,17 +29,16 @@ class TelegramWorkflow(TelegramStateMachine): class CreatePostWorkflow(TelegramWorkflow): + # init --> wait step 0 --> confirm --> wait step 1--> confirm -->wait_photo --> finished + init =State('init', initial=True) # Initialize the workflow finished = State('finished') # Workflow has ended wait = State('wait',value=0) - confirm =State('confirm') - -# finished = State('finished') - wait_photo=State('wait_photo') + initialize = init.to(wait) # init --> wait entered = wait.to(confirm) # wait --> confirm next=confirm.to(wait) # confirm --> wait @@ -98,7 +97,7 @@ class CreatePostWorkflow(TelegramWorkflow): #elif self.current_state == self.wait_photo: if media: if self.debug: - self.send("Workflow received media -- yey") + self.send("Danke fürs Foto") self.p["files"]={"image":media} if self.current_state == self.wait_photo: self.finish() @@ -118,8 +117,6 @@ class CreatePostWorkflow(TelegramWorkflow): if self.debug: self.send("retry") def on_cancel(self): - #self.p={} - #self.step=0 if self.debug: self.send("Canceled") def on_finish(self): @@ -130,12 +127,12 @@ class CreatePostWorkflow(TelegramWorkflow): self.p["public_date"]=datetime.date.today() self.send("posting to %s" % TARGET) r,d=fet.create(self.p) - print(r) logger.info(r) if r ==201: self.send("Eingabe fertig:%s" % str(urljoin(TARGET,"posts/"+d["slug"]))) else: self.send("Fehler beim posten -- sorry") + def on_enter_confirm(self): self.send_confirm("Bitte die Eingabe von %s bestaetigen" % self.value) diff --git a/docker-compose.yml b/docker-compose.yml index 43203b6..a15baf2 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -15,7 +15,7 @@ services: image: bot build: . environment: - TARGET: https://alpha.2020.fet.at + TARGET: https://andis.2020.fet.at SOLR_HOST: http://solr:8983 ports: - "5000:5000" diff --git a/solrfet2020/__init__.py b/solrfet2020/__init__.py index 369f274..b914136 100644 --- a/solrfet2020/__init__.py +++ b/solrfet2020/__init__.py @@ -2,7 +2,7 @@ from lxml.html.clean import clean_html, Cleaner import environ import pysolr from .convert import post_to_solr -from urllib.parse import urljoin +from urllib.parse import urljoin,urlparse from fet2020api import fet2020postapi import yaml env=environ.Env( @@ -43,9 +43,17 @@ def result_to_posts(result): urljoin(env('TARGET'), p["url"]).rstrip("/")+" "+\ str(strip_html(highlights[p["slug"]]["text_txt"])) + def create_highlights(p): + return str(strip_html(highlights[p["slug"]]["text_txt"])) + for post in posts: - post["text"] = create_text(post) + if post: + post["text"] = create_text(post) + post["highlights"]=create_highlights(post) + if post["url"]: post["url"]= urljoin(env('TARGET'),post["url"]).rstrip("/") + if post["image"]:post["image"]=urljoin(env('TARGET'),urlparse(post["image"]).path) return posts + class SolrFet2020(): def __init__(self): self.solr=pysolr.Solr( diff --git a/solrfet2020/convert.py b/solrfet2020/convert.py index a1b99ef..9458a64 100644 --- a/solrfet2020/convert.py +++ b/solrfet2020/convert.py @@ -1,5 +1,5 @@ from lxml.html.clean import clean_html, Cleaner - +from bs4 import BeautifulSoup def PostKeyError(KeyError): pass @@ -12,9 +12,13 @@ def post_to_solr(p): return "" if len(l)<1: return "" - c=Cleaner(allow_tags=['i','em','p'], remove_tags=['p','div']) - h=c.clean_html(l.replace("\n"," ").replace("\r"," ").replace("\t"," ").replace("\\"," ")) + c=Cleaner(allow_tags=['i','em'], remove_tags=['p','div','ul','li']) # + h=c.clean_html(l.replace("\n"," ").replace("\r"," ").replace("\t"," ").replace("\\"," ")).text_content() return h + def get_text2(l): + if not l: return "" + soup=BeautifulSoup(l,features="lxml") + return soup.get_text().replace("\n"," ").replace("\r"," ").replace("\t"," ") if type(p) is list: return [post_to_solr(pp) for pp in p] # Check Dict and keys @@ -26,5 +30,5 @@ def post_to_solr(p): return { "id": p["slug"], "date_dt": p["public_date"], - "text_txt": (get_text(p.get("body","")) or "")+(p.get("agenda_html","") or "") + "text_txt": (get_text2(p.get("body","")) or "")+" "+get_text2(p.get("agenda_html","") or "") } diff --git a/static/app.css b/static/app.css new file mode 100644 index 0000000..5c25e1e --- /dev/null +++ b/static/app.css @@ -0,0 +1,8872 @@ +@charset "UTF-8"; +@font-face { + font-family: 'Acumin Pro Bold'; + font-style: normal; + font-weight: normal; + src: local("Acumin Pro Bold"), url("Acumin-BdPro.woff") format("woff"); } + +@font-face { + font-family: 'Acumin Pro'; + font-style: normal; + font-weight: normal; + src: local("Acumin Pro"), url("Acumin-RPro.woff") format("woff"); } + +@font-face { + font-family: myRoboto; + src: url("/assets/fonts/RobotoMono-Light.ttf"); } + +@font-face { + font-family: BalooBhaina; + src: url("/assets/fonts/BalooBhaina2-Regular.ttf"); } + +@font-face { + font-family: DancingScript; + src: url("/assets/fonts/DancingScript.ttf"); } + +.large-article-header { + background-position: center; } + +div.top-bar { + border-bottom: #2D6699 thin solid; } + +/** + * Foundation for Sites + * Version 6.6.3 + * https://get.foundation + * Licensed under MIT Open Source + */ +@media print, screen and (min-width: 40em) { + .reveal, .reveal.tiny, .reveal.small, .reveal.large { + right: auto; + left: auto; + margin: 0 auto; } } + +/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */ +html { + line-height: 1.15; + -webkit-text-size-adjust: 100%; } + +body { + margin: 0; } + +h1 { + font-size: 2em; + margin: 0.67em 0; } + +hr { + -webkit-box-sizing: content-box; + box-sizing: content-box; + height: 0; + overflow: visible; } + +pre { + font-family: monospace, monospace; + font-size: 1em; } + +a { + background-color: transparent; } + +abbr[title] { + border-bottom: none; + text-decoration: underline; + -webkit-text-decoration: underline dotted; + text-decoration: underline dotted; } + +b, +strong { + font-weight: bolder; } + +code, +kbd, +samp { + font-family: monospace, monospace; + font-size: 1em; } + +small { + font-size: 80%; } + +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; } + +sub { + bottom: -0.25em; } + +sup { + top: -0.5em; } + +img { + border-style: none; } + +button, +input, +optgroup, +select, +textarea { + font-family: inherit; + font-size: 100%; + line-height: 1.15; + margin: 0; } + +button, +input { + overflow: visible; } + +button, +select { + text-transform: none; } + +button, +[type="button"], +[type="reset"], +[type="submit"] { + -webkit-appearance: button; } + +button::-moz-focus-inner, +[type="button"]::-moz-focus-inner, +[type="reset"]::-moz-focus-inner, +[type="submit"]::-moz-focus-inner { + border-style: none; + padding: 0; } + +button:-moz-focusring, +[type="button"]:-moz-focusring, +[type="reset"]:-moz-focusring, +[type="submit"]:-moz-focusring { + outline: 1px dotted ButtonText; } + +fieldset { + padding: 0.35em 0.75em 0.625em; } + +legend { + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: inherit; + display: table; + max-width: 100%; + padding: 0; + white-space: normal; } + +progress { + vertical-align: baseline; } + +textarea { + overflow: auto; } + +[type="checkbox"], +[type="radio"] { + -webkit-box-sizing: border-box; + box-sizing: border-box; + padding: 0; } + +[type="number"]::-webkit-inner-spin-button, +[type="number"]::-webkit-outer-spin-button { + height: auto; } + +[type="search"] { + -webkit-appearance: textfield; + outline-offset: -2px; } + +[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; } + +::-webkit-file-upload-button { + -webkit-appearance: button; + font: inherit; } + +details { + display: block; } + +summary { + display: list-item; } + +template { + display: none; } + +[hidden] { + display: none; } + +.foundation-mq { + font-family: "small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"; } + +html { + -webkit-box-sizing: border-box; + box-sizing: border-box; + font-size: 100%; } + +*, +*::before, +*::after { + -webkit-box-sizing: inherit; + box-sizing: inherit; } + +body { + margin: 0; + padding: 0; + background: #F0F0F0; + font-family: "Acumin Pro", "Helvetica Neue", Helvetica; + font-weight: normal; + line-height: 1.5; + color: #0a0a0a; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; } + +img { + display: inline-block; + vertical-align: middle; + max-width: 100%; + height: auto; + -ms-interpolation-mode: bicubic; } + +textarea { + height: auto; + min-height: 50px; + border-radius: 0; } + +select { + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 100%; + border-radius: 0; } + +.map_canvas img, +.map_canvas embed, +.map_canvas object, +.mqa-display img, +.mqa-display embed, +.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; + cursor: auto; } + [data-whatinput='mouse'] button { + outline: 0; } + +pre { + overflow: auto; } + +button, +input, +optgroup, +select, +textarea { + font-family: inherit; } + +.is-visible { + display: block !important; } + +.is-hidden { + display: none !important; } + +[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'], +textarea { + display: block; + -webkit-box-sizing: border-box; + box-sizing: border-box; + width: 100%; + height: 2.4375rem; + margin: 0 0 1rem; + padding: 0.5rem; + border: 1px solid #cacaca; + border-radius: 0; + background-color: #fefefe; + -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1); + box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1); + font-family: inherit; + font-size: 1rem; + font-weight: normal; + line-height: 1.5; + color: #0a0a0a; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; } + [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus, + textarea:focus { + outline: none; + border: 1px solid #8a8a8a; + background-color: #fefefe; + -webkit-box-shadow: 0 0 5px #cacaca; + box-shadow: 0 0 5px #cacaca; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } + +textarea { + max-width: 100%; } + textarea[rows] { + height: auto; } + +input:disabled, input[readonly], +textarea:disabled, +textarea[readonly] { + background-color: #e6e6e6; + cursor: not-allowed; } + +[type='submit'], +[type='button'] { + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + border-radius: 0; } + +input[type='search'] { + -webkit-box-sizing: border-box; + box-sizing: border-box; } + +::-webkit-input-placeholder { + color: #cacaca; } + +::-moz-placeholder { + color: #cacaca; } + +:-ms-input-placeholder { + color: #cacaca; } + +::-ms-input-placeholder { + color: #cacaca; } + +::placeholder { + color: #cacaca; } + +[type='file'], +[type='checkbox'], +[type='radio'] { + margin: 0 0 1rem; } + +[type='checkbox'] + label, +[type='radio'] + label { + display: inline-block; + vertical-align: baseline; + margin-left: 0.5rem; + margin-right: 1rem; + margin-bottom: 0; } + [type='checkbox'] + label[for], + [type='radio'] + label[for] { + cursor: pointer; } + +label > [type='checkbox'], +label > [type='radio'] { + margin-right: 0.5rem; } + +[type='file'] { + width: 100%; } + +label { + display: block; + margin: 0; + font-size: 0.875rem; + font-weight: normal; + line-height: 1.8; + color: #0a0a0a; } + label.middle { + margin: 0 0 1rem; + padding: 0.5625rem 0; } + +.help-text { + margin-top: -0.5rem; + font-size: 0.8125rem; + font-style: italic; + color: #0a0a0a; } + +.input-group { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + width: 100%; + margin-bottom: 1rem; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; } + .input-group > :first-child, .input-group > :first-child.input-group-button > * { + border-radius: 0 0 0 0; } + .input-group > :last-child, .input-group > :last-child.input-group-button > * { + border-radius: 0 0 0 0; } + +.input-group-label, .input-group-field, .input-group-button, .input-group-button a, +.input-group-button input, +.input-group-button button, +.input-group-button label { + margin: 0; + white-space: nowrap; } + +.input-group-label { + padding: 0 1rem; + border: 1px solid #cacaca; + background: #e6e6e6; + color: #0a0a0a; + text-align: center; + white-space: nowrap; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; } + .input-group-label:first-child { + border-right: 0; } + .input-group-label:last-child { + border-left: 0; } + +.input-group-field { + border-radius: 0; + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + min-width: 0; } + +.input-group-button { + padding-top: 0; + padding-bottom: 0; + text-align: center; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .input-group-button a, + .input-group-button input, + .input-group-button button, + .input-group-button label { + -webkit-align-self: stretch; + -ms-flex-item-align: stretch; + align-self: stretch; + height: auto; + padding-top: 0; + padding-bottom: 0; + font-size: 1rem; } + +fieldset { + margin: 0; + padding: 0; + border: 0; } + +legend { + max-width: 100%; + margin-bottom: 0.5rem; } + +.fieldset { + margin: 1.125rem 0; + padding: 1.25rem; + border: 1px solid #cacaca; } + .fieldset legend { + margin: 0; + margin-left: -0.1875rem; + padding: 0 0.1875rem; } + +select { + height: 2.4375rem; + margin: 0 0 1rem; + padding: 0.5rem; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; + border: 1px solid #cacaca; + border-radius: 0; + background-color: #fefefe; + font-family: inherit; + font-size: 1rem; + font-weight: normal; + line-height: 1.5; + color: #0a0a0a; + background-image: url("data:image/svg+xml;utf8,"); + background-origin: content-box; + background-position: right -1rem center; + background-repeat: no-repeat; + background-size: 9px 6px; + padding-right: 1.5rem; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } + @media screen and (min-width: 0\0) { + select { + background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } } + select:focus { + outline: none; + border: 1px solid #8a8a8a; + background-color: #fefefe; + -webkit-box-shadow: 0 0 5px #cacaca; + box-shadow: 0 0 5px #cacaca; + -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out; + transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; } + select:disabled { + background-color: #e6e6e6; + cursor: not-allowed; } + select::-ms-expand { + display: none; } + select[multiple] { + height: auto; + background-image: none; } + select:not([multiple]) { + padding-top: 0; + padding-bottom: 0; } + +.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)::-moz-placeholder { + color: #cc4b37; } + .is-invalid-input:not(:focus):-ms-input-placeholder { + color: #cc4b37; } + .is-invalid-input:not(:focus)::-ms-input-placeholder { + color: #cc4b37; } + .is-invalid-input:not(:focus)::placeholder { + color: #cc4b37; } + +.is-invalid-label { + color: #cc4b37; } + +.form-error { + display: none; + margin-top: -0.5rem; + margin-bottom: 1rem; + font-size: 0.75rem; + font-weight: bold; + color: #cc4b37; } + .form-error.is-visible { + display: block; } + +div, +dl, +dt, +dd, +ul, +ol, +li, +h1, +h2, +h3, +h4, +h5, +h6, +pre, +form, +p, +blockquote, +th, +td { + margin: 0; + padding: 0; } + +p { + margin-bottom: 1rem; + font-size: inherit; + line-height: 1.6; + text-rendering: optimizeLegibility; } + +em, +i { + font-style: italic; + line-height: inherit; } + +strong, +b { + font-weight: bold; + line-height: inherit; } + +small { + font-size: 80%; + line-height: inherit; } + +h1, .h1, +h2, .h2, +h3, .h3, +h4, .h4, +h5, .h5, +h6, .h6 { + font-family: "Helvetica Neue", Helvetica; + font-style: normal; + font-weight: normal; + color: inherit; + text-rendering: optimizeLegibility; } + h1 small, .h1 small, + h2 small, .h2 small, + h3 small, .h3 small, + h4 small, .h4 small, + h5 small, .h5 small, + h6 small, .h6 small { + line-height: 0; + color: #cacaca; } + +h1, .h1 { + font-size: 1.5rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +h2, .h2 { + font-size: 1.25rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +h3, .h3 { + font-size: 1.1875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +h4, .h4 { + font-size: 1.125rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +h5, .h5 { + font-size: 1.0625rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +h6, .h6 { + font-size: 1rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +@media print, screen and (min-width: 40em) { + h1, .h1 { + font-size: 1.5rem; } + h2, .h2 { + font-size: 1.25rem; } + h3, .h3 { + font-size: 1.1875rem; } + h4, .h4 { + font-size: 1.125rem; } + h5, .h5 { + font-size: 1.0625rem; } + h6, .h6 { + font-size: 1rem; } } + +a { + line-height: inherit; + color: #2D6699; + text-decoration: none; + cursor: pointer; } + a:hover, a:focus { + color: #275884; } + a img { + border: 0; } + +hr { + clear: both; + max-width: 75rem; + height: 0; + margin: 1.25rem auto; + border-top: 0; + border-right: 0; + border-bottom: 1px solid #cacaca; + border-left: 0; } + +ul, +ol, +dl { + margin-bottom: 1rem; + list-style-position: outside; + line-height: 1.6; } + +li { + font-size: inherit; } + +ul { + margin-left: 1.25rem; + list-style-type: disc; } + +ol { + margin-left: 1.25rem; } + +ul ul, ol ul, ul ol, ol ol { + margin-left: 1.25rem; + margin-bottom: 0; } + +dl { + margin-bottom: 1rem; } + dl dt { + margin-bottom: 0.3rem; + font-weight: bold; } + +blockquote { + margin: 0 0 1rem; + padding: 0.5625rem 1.25rem 0 1.1875rem; + border-left: 1px solid #cacaca; } + blockquote, blockquote p { + line-height: 1.6; + color: #8a8a8a; } + +abbr, abbr[title] { + border-bottom: 1px dotted #0a0a0a; + cursor: help; + text-decoration: none; } + +figure { + margin: 0; } + +kbd { + margin: 0; + padding: 0.125rem 0.25rem 0; + background-color: #e6e6e6; + font-family: Consolas, "Liberation Mono", Courier, monospace; + color: #0a0a0a; } + +.subheader { + margin-top: 0.2rem; + margin-bottom: 0.5rem; + font-weight: normal; + 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; } + +ul.no-bullet, ol.no-bullet { + margin-left: 0; + list-style: none; } + +.cite-block, cite { + display: block; + color: #8a8a8a; + font-size: 0.8125rem; } + .cite-block:before, cite:before { + content: "— "; } + +.code-inline, code { + border: 1px solid #cacaca; + background-color: #e6e6e6; + font-family: Consolas, "Liberation Mono", Courier, monospace; + font-weight: normal; + color: #0a0a0a; + display: inline; + max-width: 100%; + word-wrap: break-word; + padding: 0.125rem 0.3125rem 0.0625rem; } + +.code-block { + border: 1px solid #cacaca; + background-color: #e6e6e6; + font-family: Consolas, "Liberation Mono", Courier, monospace; + font-weight: normal; + color: #0a0a0a; + display: block; + overflow: auto; + white-space: pre; + padding: 1rem; + margin-bottom: 1.5rem; } + +.text-left { + text-align: left; } + +.text-right { + text-align: right; } + +.text-center { + text-align: center; } + +.text-justify { + text-align: justify; } + +@media print, screen and (min-width: 40em) { + .medium-text-left { + text-align: left; } + .medium-text-right { + text-align: right; } + .medium-text-center { + text-align: center; } + .medium-text-justify { + text-align: justify; } } + +@media print, screen and (min-width: 64em) { + .large-text-left { + text-align: left; } + .large-text-right { + text-align: right; } + .large-text-center { + text-align: center; } + .large-text-justify { + text-align: justify; } } + +.show-for-print { + display: none !important; } + +@media print { + * { + background: transparent !important; + color: black !important; + -webkit-print-color-adjust: economy; + color-adjust: economy; + -webkit-box-shadow: none !important; + box-shadow: none !important; + text-shadow: none !important; } + .show-for-print { + display: block !important; } + .hide-for-print { + display: none !important; } + table.show-for-print { + display: table !important; } + thead.show-for-print { + display: table-header-group !important; } + tbody.show-for-print { + display: table-row-group !important; } + tr.show-for-print { + display: table-row !important; } + td.show-for-print { + display: table-cell !important; } + th.show-for-print { + display: table-cell !important; } + a, + a:visited { + text-decoration: underline; } + a[href]:after { + content: " (" attr(href) ")"; } + .ir a:after, + a[href^='javascript:']:after, + a[href^='#']:after { + content: ''; } + abbr[title]:after { + content: " (" attr(title) ")"; } + pre, + blockquote { + border: 1px solid #8a8a8a; + page-break-inside: avoid; } + thead { + display: table-header-group; } + tr, + img { + page-break-inside: avoid; } + img { + max-width: 100% !important; } + @page { + margin: 0.5cm; } + p, + h2, + h3 { + orphans: 3; + widows: 3; } + h2, + h3 { + page-break-after: avoid; } + .print-break-inside { + page-break-inside: auto; } } + +.grid-container { + padding-right: 0.625rem; + padding-left: 0.625rem; + max-width: 75rem; + margin-left: auto; + margin-right: auto; } + @media print, screen and (min-width: 40em) { + .grid-container { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .grid-container.fluid { + padding-right: 0.625rem; + padding-left: 0.625rem; + max-width: 100%; + margin-left: auto; + margin-right: auto; } + @media print, screen and (min-width: 40em) { + .grid-container.fluid { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .grid-container.full { + padding-right: 0; + padding-left: 0; + max-width: 100%; + margin-left: auto; + margin-right: auto; } + +.grid-x { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-flow: row wrap; + -ms-flex-flow: row wrap; + flex-flow: row wrap; } + +.cell { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + min-height: 0px; + min-width: 0px; + width: 100%; } + .cell.auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + .cell.shrink { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + +.grid-x > .auto { + width: auto; } + +.grid-x > .shrink { + width: auto; } + +.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } + +@media print, screen and (min-width: 40em) { + .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } } + +@media print, screen and (min-width: 64em) { + .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } } + +.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + +.grid-x > .small-1 { + width: 8.33333%; } + +.grid-x > .small-2 { + width: 16.66667%; } + +.grid-x > .small-3 { + width: 25%; } + +.grid-x > .small-4 { + width: 33.33333%; } + +.grid-x > .small-5 { + width: 41.66667%; } + +.grid-x > .small-6 { + width: 50%; } + +.grid-x > .small-7 { + width: 58.33333%; } + +.grid-x > .small-8 { + width: 66.66667%; } + +.grid-x > .small-9 { + width: 75%; } + +.grid-x > .small-10 { + width: 83.33333%; } + +.grid-x > .small-11 { + width: 91.66667%; } + +.grid-x > .small-12 { + width: 100%; } + +@media print, screen and (min-width: 40em) { + .grid-x > .medium-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + width: auto; } + .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .grid-x > .medium-shrink { + width: auto; } + .grid-x > .medium-1 { + width: 8.33333%; } + .grid-x > .medium-2 { + width: 16.66667%; } + .grid-x > .medium-3 { + width: 25%; } + .grid-x > .medium-4 { + width: 33.33333%; } + .grid-x > .medium-5 { + width: 41.66667%; } + .grid-x > .medium-6 { + width: 50%; } + .grid-x > .medium-7 { + width: 58.33333%; } + .grid-x > .medium-8 { + width: 66.66667%; } + .grid-x > .medium-9 { + width: 75%; } + .grid-x > .medium-10 { + width: 83.33333%; } + .grid-x > .medium-11 { + width: 91.66667%; } + .grid-x > .medium-12 { + width: 100%; } } + +@media print, screen and (min-width: 64em) { + .grid-x > .large-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + width: auto; } + .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .grid-x > .large-shrink { + width: auto; } + .grid-x > .large-1 { + width: 8.33333%; } + .grid-x > .large-2 { + width: 16.66667%; } + .grid-x > .large-3 { + width: 25%; } + .grid-x > .large-4 { + width: 33.33333%; } + .grid-x > .large-5 { + width: 41.66667%; } + .grid-x > .large-6 { + width: 50%; } + .grid-x > .large-7 { + width: 58.33333%; } + .grid-x > .large-8 { + width: 66.66667%; } + .grid-x > .large-9 { + width: 75%; } + .grid-x > .large-10 { + width: 83.33333%; } + .grid-x > .large-11 { + width: 91.66667%; } + .grid-x > .large-12 { + width: 100%; } } + +.grid-margin-x:not(.grid-x) > .cell { + width: auto; } + +.grid-margin-y:not(.grid-y) > .cell { + height: auto; } + +.grid-margin-x { + margin-left: -0.625rem; + margin-right: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-x { + margin-left: -0.9375rem; + margin-right: -0.9375rem; } } + .grid-margin-x > .cell { + width: calc(100% - 1.25rem); + margin-left: 0.625rem; + margin-right: 0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-x > .cell { + width: calc(100% - 1.875rem); + margin-left: 0.9375rem; + margin-right: 0.9375rem; } } + .grid-margin-x > .auto { + width: auto; } + .grid-margin-x > .shrink { + width: auto; } + .grid-margin-x > .small-1 { + width: calc(8.33333% - 1.25rem); } + .grid-margin-x > .small-2 { + width: calc(16.66667% - 1.25rem); } + .grid-margin-x > .small-3 { + width: calc(25% - 1.25rem); } + .grid-margin-x > .small-4 { + width: calc(33.33333% - 1.25rem); } + .grid-margin-x > .small-5 { + width: calc(41.66667% - 1.25rem); } + .grid-margin-x > .small-6 { + width: calc(50% - 1.25rem); } + .grid-margin-x > .small-7 { + width: calc(58.33333% - 1.25rem); } + .grid-margin-x > .small-8 { + width: calc(66.66667% - 1.25rem); } + .grid-margin-x > .small-9 { + width: calc(75% - 1.25rem); } + .grid-margin-x > .small-10 { + width: calc(83.33333% - 1.25rem); } + .grid-margin-x > .small-11 { + width: calc(91.66667% - 1.25rem); } + .grid-margin-x > .small-12 { + width: calc(100% - 1.25rem); } + @media print, screen and (min-width: 40em) { + .grid-margin-x > .auto { + width: auto; } + .grid-margin-x > .shrink { + width: auto; } + .grid-margin-x > .small-1 { + width: calc(8.33333% - 1.875rem); } + .grid-margin-x > .small-2 { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x > .small-3 { + width: calc(25% - 1.875rem); } + .grid-margin-x > .small-4 { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x > .small-5 { + width: calc(41.66667% - 1.875rem); } + .grid-margin-x > .small-6 { + width: calc(50% - 1.875rem); } + .grid-margin-x > .small-7 { + width: calc(58.33333% - 1.875rem); } + .grid-margin-x > .small-8 { + width: calc(66.66667% - 1.875rem); } + .grid-margin-x > .small-9 { + width: calc(75% - 1.875rem); } + .grid-margin-x > .small-10 { + width: calc(83.33333% - 1.875rem); } + .grid-margin-x > .small-11 { + width: calc(91.66667% - 1.875rem); } + .grid-margin-x > .small-12 { + width: calc(100% - 1.875rem); } + .grid-margin-x > .medium-auto { + width: auto; } + .grid-margin-x > .medium-shrink { + width: auto; } + .grid-margin-x > .medium-1 { + width: calc(8.33333% - 1.875rem); } + .grid-margin-x > .medium-2 { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x > .medium-3 { + width: calc(25% - 1.875rem); } + .grid-margin-x > .medium-4 { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x > .medium-5 { + width: calc(41.66667% - 1.875rem); } + .grid-margin-x > .medium-6 { + width: calc(50% - 1.875rem); } + .grid-margin-x > .medium-7 { + width: calc(58.33333% - 1.875rem); } + .grid-margin-x > .medium-8 { + width: calc(66.66667% - 1.875rem); } + .grid-margin-x > .medium-9 { + width: calc(75% - 1.875rem); } + .grid-margin-x > .medium-10 { + width: calc(83.33333% - 1.875rem); } + .grid-margin-x > .medium-11 { + width: calc(91.66667% - 1.875rem); } + .grid-margin-x > .medium-12 { + width: calc(100% - 1.875rem); } } + @media print, screen and (min-width: 64em) { + .grid-margin-x > .large-auto { + width: auto; } + .grid-margin-x > .large-shrink { + width: auto; } + .grid-margin-x > .large-1 { + width: calc(8.33333% - 1.875rem); } + .grid-margin-x > .large-2 { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x > .large-3 { + width: calc(25% - 1.875rem); } + .grid-margin-x > .large-4 { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x > .large-5 { + width: calc(41.66667% - 1.875rem); } + .grid-margin-x > .large-6 { + width: calc(50% - 1.875rem); } + .grid-margin-x > .large-7 { + width: calc(58.33333% - 1.875rem); } + .grid-margin-x > .large-8 { + width: calc(66.66667% - 1.875rem); } + .grid-margin-x > .large-9 { + width: calc(75% - 1.875rem); } + .grid-margin-x > .large-10 { + width: calc(83.33333% - 1.875rem); } + .grid-margin-x > .large-11 { + width: calc(91.66667% - 1.875rem); } + .grid-margin-x > .large-12 { + width: calc(100% - 1.875rem); } } + +.grid-padding-x .grid-padding-x { + margin-right: -0.625rem; + margin-left: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-padding-x .grid-padding-x { + margin-right: -0.9375rem; + margin-left: -0.9375rem; } } + +.grid-container:not(.full) > .grid-padding-x { + margin-right: -0.625rem; + margin-left: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-container:not(.full) > .grid-padding-x { + margin-right: -0.9375rem; + margin-left: -0.9375rem; } } + +.grid-padding-x > .cell { + padding-right: 0.625rem; + padding-left: 0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-padding-x > .cell { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + +.small-up-1 > .cell { + width: 100%; } + +.small-up-2 > .cell { + width: 50%; } + +.small-up-3 > .cell { + width: 33.33333%; } + +.small-up-4 > .cell { + width: 25%; } + +.small-up-5 > .cell { + width: 20%; } + +.small-up-6 > .cell { + width: 16.66667%; } + +.small-up-7 > .cell { + width: 14.28571%; } + +.small-up-8 > .cell { + width: 12.5%; } + +@media print, screen and (min-width: 40em) { + .medium-up-1 > .cell { + width: 100%; } + .medium-up-2 > .cell { + width: 50%; } + .medium-up-3 > .cell { + width: 33.33333%; } + .medium-up-4 > .cell { + width: 25%; } + .medium-up-5 > .cell { + width: 20%; } + .medium-up-6 > .cell { + width: 16.66667%; } + .medium-up-7 > .cell { + width: 14.28571%; } + .medium-up-8 > .cell { + width: 12.5%; } } + +@media print, screen and (min-width: 64em) { + .large-up-1 > .cell { + width: 100%; } + .large-up-2 > .cell { + width: 50%; } + .large-up-3 > .cell { + width: 33.33333%; } + .large-up-4 > .cell { + width: 25%; } + .large-up-5 > .cell { + width: 20%; } + .large-up-6 > .cell { + width: 16.66667%; } + .large-up-7 > .cell { + width: 14.28571%; } + .large-up-8 > .cell { + width: 12.5%; } } + +.grid-margin-x.small-up-1 > .cell { + width: calc(100% - 1.25rem); } + +.grid-margin-x.small-up-2 > .cell { + width: calc(50% - 1.25rem); } + +.grid-margin-x.small-up-3 > .cell { + width: calc(33.33333% - 1.25rem); } + +.grid-margin-x.small-up-4 > .cell { + width: calc(25% - 1.25rem); } + +.grid-margin-x.small-up-5 > .cell { + width: calc(20% - 1.25rem); } + +.grid-margin-x.small-up-6 > .cell { + width: calc(16.66667% - 1.25rem); } + +.grid-margin-x.small-up-7 > .cell { + width: calc(14.28571% - 1.25rem); } + +.grid-margin-x.small-up-8 > .cell { + width: calc(12.5% - 1.25rem); } + +@media print, screen and (min-width: 40em) { + .grid-margin-x.small-up-1 > .cell { + width: calc(100% - 1.875rem); } + .grid-margin-x.small-up-2 > .cell { + width: calc(50% - 1.875rem); } + .grid-margin-x.small-up-3 > .cell { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x.small-up-4 > .cell { + width: calc(25% - 1.875rem); } + .grid-margin-x.small-up-5 > .cell { + width: calc(20% - 1.875rem); } + .grid-margin-x.small-up-6 > .cell { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x.small-up-7 > .cell { + width: calc(14.28571% - 1.875rem); } + .grid-margin-x.small-up-8 > .cell { + width: calc(12.5% - 1.875rem); } + .grid-margin-x.medium-up-1 > .cell { + width: calc(100% - 1.875rem); } + .grid-margin-x.medium-up-2 > .cell { + width: calc(50% - 1.875rem); } + .grid-margin-x.medium-up-3 > .cell { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x.medium-up-4 > .cell { + width: calc(25% - 1.875rem); } + .grid-margin-x.medium-up-5 > .cell { + width: calc(20% - 1.875rem); } + .grid-margin-x.medium-up-6 > .cell { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x.medium-up-7 > .cell { + width: calc(14.28571% - 1.875rem); } + .grid-margin-x.medium-up-8 > .cell { + width: calc(12.5% - 1.875rem); } } + +@media print, screen and (min-width: 64em) { + .grid-margin-x.large-up-1 > .cell { + width: calc(100% - 1.875rem); } + .grid-margin-x.large-up-2 > .cell { + width: calc(50% - 1.875rem); } + .grid-margin-x.large-up-3 > .cell { + width: calc(33.33333% - 1.875rem); } + .grid-margin-x.large-up-4 > .cell { + width: calc(25% - 1.875rem); } + .grid-margin-x.large-up-5 > .cell { + width: calc(20% - 1.875rem); } + .grid-margin-x.large-up-6 > .cell { + width: calc(16.66667% - 1.875rem); } + .grid-margin-x.large-up-7 > .cell { + width: calc(14.28571% - 1.875rem); } + .grid-margin-x.large-up-8 > .cell { + width: calc(12.5% - 1.875rem); } } + +.small-margin-collapse { + margin-right: 0; + margin-left: 0; } + .small-margin-collapse > .cell { + margin-right: 0; + margin-left: 0; } + .small-margin-collapse > .small-1 { + width: 8.33333%; } + .small-margin-collapse > .small-2 { + width: 16.66667%; } + .small-margin-collapse > .small-3 { + width: 25%; } + .small-margin-collapse > .small-4 { + width: 33.33333%; } + .small-margin-collapse > .small-5 { + width: 41.66667%; } + .small-margin-collapse > .small-6 { + width: 50%; } + .small-margin-collapse > .small-7 { + width: 58.33333%; } + .small-margin-collapse > .small-8 { + width: 66.66667%; } + .small-margin-collapse > .small-9 { + width: 75%; } + .small-margin-collapse > .small-10 { + width: 83.33333%; } + .small-margin-collapse > .small-11 { + width: 91.66667%; } + .small-margin-collapse > .small-12 { + width: 100%; } + @media print, screen and (min-width: 40em) { + .small-margin-collapse > .medium-1 { + width: 8.33333%; } + .small-margin-collapse > .medium-2 { + width: 16.66667%; } + .small-margin-collapse > .medium-3 { + width: 25%; } + .small-margin-collapse > .medium-4 { + width: 33.33333%; } + .small-margin-collapse > .medium-5 { + width: 41.66667%; } + .small-margin-collapse > .medium-6 { + width: 50%; } + .small-margin-collapse > .medium-7 { + width: 58.33333%; } + .small-margin-collapse > .medium-8 { + width: 66.66667%; } + .small-margin-collapse > .medium-9 { + width: 75%; } + .small-margin-collapse > .medium-10 { + width: 83.33333%; } + .small-margin-collapse > .medium-11 { + width: 91.66667%; } + .small-margin-collapse > .medium-12 { + width: 100%; } } + @media print, screen and (min-width: 64em) { + .small-margin-collapse > .large-1 { + width: 8.33333%; } + .small-margin-collapse > .large-2 { + width: 16.66667%; } + .small-margin-collapse > .large-3 { + width: 25%; } + .small-margin-collapse > .large-4 { + width: 33.33333%; } + .small-margin-collapse > .large-5 { + width: 41.66667%; } + .small-margin-collapse > .large-6 { + width: 50%; } + .small-margin-collapse > .large-7 { + width: 58.33333%; } + .small-margin-collapse > .large-8 { + width: 66.66667%; } + .small-margin-collapse > .large-9 { + width: 75%; } + .small-margin-collapse > .large-10 { + width: 83.33333%; } + .small-margin-collapse > .large-11 { + width: 91.66667%; } + .small-margin-collapse > .large-12 { + width: 100%; } } + +.small-padding-collapse { + margin-right: 0; + margin-left: 0; } + .small-padding-collapse > .cell { + padding-right: 0; + padding-left: 0; } + +@media print, screen and (min-width: 40em) { + .medium-margin-collapse { + margin-right: 0; + margin-left: 0; } + .medium-margin-collapse > .cell { + margin-right: 0; + margin-left: 0; } } + +@media print, screen and (min-width: 40em) { + .medium-margin-collapse > .small-1 { + width: 8.33333%; } + .medium-margin-collapse > .small-2 { + width: 16.66667%; } + .medium-margin-collapse > .small-3 { + width: 25%; } + .medium-margin-collapse > .small-4 { + width: 33.33333%; } + .medium-margin-collapse > .small-5 { + width: 41.66667%; } + .medium-margin-collapse > .small-6 { + width: 50%; } + .medium-margin-collapse > .small-7 { + width: 58.33333%; } + .medium-margin-collapse > .small-8 { + width: 66.66667%; } + .medium-margin-collapse > .small-9 { + width: 75%; } + .medium-margin-collapse > .small-10 { + width: 83.33333%; } + .medium-margin-collapse > .small-11 { + width: 91.66667%; } + .medium-margin-collapse > .small-12 { + width: 100%; } } + +@media print, screen and (min-width: 40em) { + .medium-margin-collapse > .medium-1 { + width: 8.33333%; } + .medium-margin-collapse > .medium-2 { + width: 16.66667%; } + .medium-margin-collapse > .medium-3 { + width: 25%; } + .medium-margin-collapse > .medium-4 { + width: 33.33333%; } + .medium-margin-collapse > .medium-5 { + width: 41.66667%; } + .medium-margin-collapse > .medium-6 { + width: 50%; } + .medium-margin-collapse > .medium-7 { + width: 58.33333%; } + .medium-margin-collapse > .medium-8 { + width: 66.66667%; } + .medium-margin-collapse > .medium-9 { + width: 75%; } + .medium-margin-collapse > .medium-10 { + width: 83.33333%; } + .medium-margin-collapse > .medium-11 { + width: 91.66667%; } + .medium-margin-collapse > .medium-12 { + width: 100%; } } + +@media print, screen and (min-width: 64em) { + .medium-margin-collapse > .large-1 { + width: 8.33333%; } + .medium-margin-collapse > .large-2 { + width: 16.66667%; } + .medium-margin-collapse > .large-3 { + width: 25%; } + .medium-margin-collapse > .large-4 { + width: 33.33333%; } + .medium-margin-collapse > .large-5 { + width: 41.66667%; } + .medium-margin-collapse > .large-6 { + width: 50%; } + .medium-margin-collapse > .large-7 { + width: 58.33333%; } + .medium-margin-collapse > .large-8 { + width: 66.66667%; } + .medium-margin-collapse > .large-9 { + width: 75%; } + .medium-margin-collapse > .large-10 { + width: 83.33333%; } + .medium-margin-collapse > .large-11 { + width: 91.66667%; } + .medium-margin-collapse > .large-12 { + width: 100%; } } + +@media print, screen and (min-width: 40em) { + .medium-padding-collapse { + margin-right: 0; + margin-left: 0; } + .medium-padding-collapse > .cell { + padding-right: 0; + padding-left: 0; } } + +@media print, screen and (min-width: 64em) { + .large-margin-collapse { + margin-right: 0; + margin-left: 0; } + .large-margin-collapse > .cell { + margin-right: 0; + margin-left: 0; } } + +@media print, screen and (min-width: 64em) { + .large-margin-collapse > .small-1 { + width: 8.33333%; } + .large-margin-collapse > .small-2 { + width: 16.66667%; } + .large-margin-collapse > .small-3 { + width: 25%; } + .large-margin-collapse > .small-4 { + width: 33.33333%; } + .large-margin-collapse > .small-5 { + width: 41.66667%; } + .large-margin-collapse > .small-6 { + width: 50%; } + .large-margin-collapse > .small-7 { + width: 58.33333%; } + .large-margin-collapse > .small-8 { + width: 66.66667%; } + .large-margin-collapse > .small-9 { + width: 75%; } + .large-margin-collapse > .small-10 { + width: 83.33333%; } + .large-margin-collapse > .small-11 { + width: 91.66667%; } + .large-margin-collapse > .small-12 { + width: 100%; } } + +@media print, screen and (min-width: 64em) { + .large-margin-collapse > .medium-1 { + width: 8.33333%; } + .large-margin-collapse > .medium-2 { + width: 16.66667%; } + .large-margin-collapse > .medium-3 { + width: 25%; } + .large-margin-collapse > .medium-4 { + width: 33.33333%; } + .large-margin-collapse > .medium-5 { + width: 41.66667%; } + .large-margin-collapse > .medium-6 { + width: 50%; } + .large-margin-collapse > .medium-7 { + width: 58.33333%; } + .large-margin-collapse > .medium-8 { + width: 66.66667%; } + .large-margin-collapse > .medium-9 { + width: 75%; } + .large-margin-collapse > .medium-10 { + width: 83.33333%; } + .large-margin-collapse > .medium-11 { + width: 91.66667%; } + .large-margin-collapse > .medium-12 { + width: 100%; } } + +@media print, screen and (min-width: 64em) { + .large-margin-collapse > .large-1 { + width: 8.33333%; } + .large-margin-collapse > .large-2 { + width: 16.66667%; } + .large-margin-collapse > .large-3 { + width: 25%; } + .large-margin-collapse > .large-4 { + width: 33.33333%; } + .large-margin-collapse > .large-5 { + width: 41.66667%; } + .large-margin-collapse > .large-6 { + width: 50%; } + .large-margin-collapse > .large-7 { + width: 58.33333%; } + .large-margin-collapse > .large-8 { + width: 66.66667%; } + .large-margin-collapse > .large-9 { + width: 75%; } + .large-margin-collapse > .large-10 { + width: 83.33333%; } + .large-margin-collapse > .large-11 { + width: 91.66667%; } + .large-margin-collapse > .large-12 { + width: 100%; } } + +@media print, screen and (min-width: 64em) { + .large-padding-collapse { + margin-right: 0; + margin-left: 0; } + .large-padding-collapse > .cell { + padding-right: 0; + padding-left: 0; } } + +.small-offset-0 { + margin-left: 0%; } + +.grid-margin-x > .small-offset-0 { + margin-left: calc(0% + 0.625rem); } + +.small-offset-1 { + margin-left: 8.33333%; } + +.grid-margin-x > .small-offset-1 { + margin-left: calc(8.33333% + 0.625rem); } + +.small-offset-2 { + margin-left: 16.66667%; } + +.grid-margin-x > .small-offset-2 { + margin-left: calc(16.66667% + 0.625rem); } + +.small-offset-3 { + margin-left: 25%; } + +.grid-margin-x > .small-offset-3 { + margin-left: calc(25% + 0.625rem); } + +.small-offset-4 { + margin-left: 33.33333%; } + +.grid-margin-x > .small-offset-4 { + margin-left: calc(33.33333% + 0.625rem); } + +.small-offset-5 { + margin-left: 41.66667%; } + +.grid-margin-x > .small-offset-5 { + margin-left: calc(41.66667% + 0.625rem); } + +.small-offset-6 { + margin-left: 50%; } + +.grid-margin-x > .small-offset-6 { + margin-left: calc(50% + 0.625rem); } + +.small-offset-7 { + margin-left: 58.33333%; } + +.grid-margin-x > .small-offset-7 { + margin-left: calc(58.33333% + 0.625rem); } + +.small-offset-8 { + margin-left: 66.66667%; } + +.grid-margin-x > .small-offset-8 { + margin-left: calc(66.66667% + 0.625rem); } + +.small-offset-9 { + margin-left: 75%; } + +.grid-margin-x > .small-offset-9 { + margin-left: calc(75% + 0.625rem); } + +.small-offset-10 { + margin-left: 83.33333%; } + +.grid-margin-x > .small-offset-10 { + margin-left: calc(83.33333% + 0.625rem); } + +.small-offset-11 { + margin-left: 91.66667%; } + +.grid-margin-x > .small-offset-11 { + margin-left: calc(91.66667% + 0.625rem); } + +@media print, screen and (min-width: 40em) { + .medium-offset-0 { + margin-left: 0%; } + .grid-margin-x > .medium-offset-0 { + margin-left: calc(0% + 0.9375rem); } + .medium-offset-1 { + margin-left: 8.33333%; } + .grid-margin-x > .medium-offset-1 { + margin-left: calc(8.33333% + 0.9375rem); } + .medium-offset-2 { + margin-left: 16.66667%; } + .grid-margin-x > .medium-offset-2 { + margin-left: calc(16.66667% + 0.9375rem); } + .medium-offset-3 { + margin-left: 25%; } + .grid-margin-x > .medium-offset-3 { + margin-left: calc(25% + 0.9375rem); } + .medium-offset-4 { + margin-left: 33.33333%; } + .grid-margin-x > .medium-offset-4 { + margin-left: calc(33.33333% + 0.9375rem); } + .medium-offset-5 { + margin-left: 41.66667%; } + .grid-margin-x > .medium-offset-5 { + margin-left: calc(41.66667% + 0.9375rem); } + .medium-offset-6 { + margin-left: 50%; } + .grid-margin-x > .medium-offset-6 { + margin-left: calc(50% + 0.9375rem); } + .medium-offset-7 { + margin-left: 58.33333%; } + .grid-margin-x > .medium-offset-7 { + margin-left: calc(58.33333% + 0.9375rem); } + .medium-offset-8 { + margin-left: 66.66667%; } + .grid-margin-x > .medium-offset-8 { + margin-left: calc(66.66667% + 0.9375rem); } + .medium-offset-9 { + margin-left: 75%; } + .grid-margin-x > .medium-offset-9 { + margin-left: calc(75% + 0.9375rem); } + .medium-offset-10 { + margin-left: 83.33333%; } + .grid-margin-x > .medium-offset-10 { + margin-left: calc(83.33333% + 0.9375rem); } + .medium-offset-11 { + margin-left: 91.66667%; } + .grid-margin-x > .medium-offset-11 { + margin-left: calc(91.66667% + 0.9375rem); } } + +@media print, screen and (min-width: 64em) { + .large-offset-0 { + margin-left: 0%; } + .grid-margin-x > .large-offset-0 { + margin-left: calc(0% + 0.9375rem); } + .large-offset-1 { + margin-left: 8.33333%; } + .grid-margin-x > .large-offset-1 { + margin-left: calc(8.33333% + 0.9375rem); } + .large-offset-2 { + margin-left: 16.66667%; } + .grid-margin-x > .large-offset-2 { + margin-left: calc(16.66667% + 0.9375rem); } + .large-offset-3 { + margin-left: 25%; } + .grid-margin-x > .large-offset-3 { + margin-left: calc(25% + 0.9375rem); } + .large-offset-4 { + margin-left: 33.33333%; } + .grid-margin-x > .large-offset-4 { + margin-left: calc(33.33333% + 0.9375rem); } + .large-offset-5 { + margin-left: 41.66667%; } + .grid-margin-x > .large-offset-5 { + margin-left: calc(41.66667% + 0.9375rem); } + .large-offset-6 { + margin-left: 50%; } + .grid-margin-x > .large-offset-6 { + margin-left: calc(50% + 0.9375rem); } + .large-offset-7 { + margin-left: 58.33333%; } + .grid-margin-x > .large-offset-7 { + margin-left: calc(58.33333% + 0.9375rem); } + .large-offset-8 { + margin-left: 66.66667%; } + .grid-margin-x > .large-offset-8 { + margin-left: calc(66.66667% + 0.9375rem); } + .large-offset-9 { + margin-left: 75%; } + .grid-margin-x > .large-offset-9 { + margin-left: calc(75% + 0.9375rem); } + .large-offset-10 { + margin-left: 83.33333%; } + .grid-margin-x > .large-offset-10 { + margin-left: calc(83.33333% + 0.9375rem); } + .large-offset-11 { + margin-left: 91.66667%; } + .grid-margin-x > .large-offset-11 { + margin-left: calc(91.66667% + 0.9375rem); } } + +.grid-y { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-flow: column nowrap; + -ms-flex-flow: column nowrap; + flex-flow: column nowrap; } + .grid-y > .cell { + height: auto; + max-height: none; } + .grid-y > .auto { + height: auto; } + .grid-y > .shrink { + height: auto; } + .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } + @media print, screen and (min-width: 40em) { + .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } } + @media print, screen and (min-width: 64em) { + .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 { + -webkit-flex-basis: auto; + -ms-flex-preferred-size: auto; + flex-basis: auto; } } + .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .grid-y > .small-1 { + height: 8.33333%; } + .grid-y > .small-2 { + height: 16.66667%; } + .grid-y > .small-3 { + height: 25%; } + .grid-y > .small-4 { + height: 33.33333%; } + .grid-y > .small-5 { + height: 41.66667%; } + .grid-y > .small-6 { + height: 50%; } + .grid-y > .small-7 { + height: 58.33333%; } + .grid-y > .small-8 { + height: 66.66667%; } + .grid-y > .small-9 { + height: 75%; } + .grid-y > .small-10 { + height: 83.33333%; } + .grid-y > .small-11 { + height: 91.66667%; } + .grid-y > .small-12 { + height: 100%; } + @media print, screen and (min-width: 40em) { + .grid-y > .medium-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + height: auto; } + .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .grid-y > .medium-shrink { + height: auto; } + .grid-y > .medium-1 { + height: 8.33333%; } + .grid-y > .medium-2 { + height: 16.66667%; } + .grid-y > .medium-3 { + height: 25%; } + .grid-y > .medium-4 { + height: 33.33333%; } + .grid-y > .medium-5 { + height: 41.66667%; } + .grid-y > .medium-6 { + height: 50%; } + .grid-y > .medium-7 { + height: 58.33333%; } + .grid-y > .medium-8 { + height: 66.66667%; } + .grid-y > .medium-9 { + height: 75%; } + .grid-y > .medium-10 { + height: 83.33333%; } + .grid-y > .medium-11 { + height: 91.66667%; } + .grid-y > .medium-12 { + height: 100%; } } + @media print, screen and (min-width: 64em) { + .grid-y > .large-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + height: auto; } + .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .grid-y > .large-shrink { + height: auto; } + .grid-y > .large-1 { + height: 8.33333%; } + .grid-y > .large-2 { + height: 16.66667%; } + .grid-y > .large-3 { + height: 25%; } + .grid-y > .large-4 { + height: 33.33333%; } + .grid-y > .large-5 { + height: 41.66667%; } + .grid-y > .large-6 { + height: 50%; } + .grid-y > .large-7 { + height: 58.33333%; } + .grid-y > .large-8 { + height: 66.66667%; } + .grid-y > .large-9 { + height: 75%; } + .grid-y > .large-10 { + height: 83.33333%; } + .grid-y > .large-11 { + height: 91.66667%; } + .grid-y > .large-12 { + height: 100%; } } + +.grid-padding-y .grid-padding-y { + margin-top: -0.625rem; + margin-bottom: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-padding-y .grid-padding-y { + margin-top: -0.9375rem; + margin-bottom: -0.9375rem; } } + +.grid-padding-y > .cell { + padding-top: 0.625rem; + padding-bottom: 0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-padding-y > .cell { + padding-top: 0.9375rem; + padding-bottom: 0.9375rem; } } + +.grid-margin-y { + margin-top: -0.625rem; + margin-bottom: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-y { + margin-top: -0.9375rem; + margin-bottom: -0.9375rem; } } + .grid-margin-y > .cell { + height: calc(100% - 1.25rem); + margin-top: 0.625rem; + margin-bottom: 0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-y > .cell { + height: calc(100% - 1.875rem); + margin-top: 0.9375rem; + margin-bottom: 0.9375rem; } } + .grid-margin-y > .auto { + height: auto; } + .grid-margin-y > .shrink { + height: auto; } + .grid-margin-y > .small-1 { + height: calc(8.33333% - 1.25rem); } + .grid-margin-y > .small-2 { + height: calc(16.66667% - 1.25rem); } + .grid-margin-y > .small-3 { + height: calc(25% - 1.25rem); } + .grid-margin-y > .small-4 { + height: calc(33.33333% - 1.25rem); } + .grid-margin-y > .small-5 { + height: calc(41.66667% - 1.25rem); } + .grid-margin-y > .small-6 { + height: calc(50% - 1.25rem); } + .grid-margin-y > .small-7 { + height: calc(58.33333% - 1.25rem); } + .grid-margin-y > .small-8 { + height: calc(66.66667% - 1.25rem); } + .grid-margin-y > .small-9 { + height: calc(75% - 1.25rem); } + .grid-margin-y > .small-10 { + height: calc(83.33333% - 1.25rem); } + .grid-margin-y > .small-11 { + height: calc(91.66667% - 1.25rem); } + .grid-margin-y > .small-12 { + height: calc(100% - 1.25rem); } + @media print, screen and (min-width: 40em) { + .grid-margin-y > .auto { + height: auto; } + .grid-margin-y > .shrink { + height: auto; } + .grid-margin-y > .small-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .small-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .small-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .small-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .small-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .small-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .small-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .small-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .small-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .small-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .small-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .small-12 { + height: calc(100% - 1.875rem); } + .grid-margin-y > .medium-auto { + height: auto; } + .grid-margin-y > .medium-shrink { + height: auto; } + .grid-margin-y > .medium-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .medium-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .medium-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .medium-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .medium-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .medium-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .medium-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .medium-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .medium-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .medium-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .medium-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .medium-12 { + height: calc(100% - 1.875rem); } } + @media print, screen and (min-width: 64em) { + .grid-margin-y > .large-auto { + height: auto; } + .grid-margin-y > .large-shrink { + height: auto; } + .grid-margin-y > .large-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .large-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .large-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .large-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .large-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .large-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .large-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .large-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .large-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .large-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .large-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .large-12 { + height: calc(100% - 1.875rem); } } + +.grid-frame { + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + width: 100vw; } + +.cell .grid-frame { + width: 100%; } + +.cell-block { + overflow-x: auto; + max-width: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } + +.cell-block-y { + overflow-y: auto; + max-height: 100%; + min-height: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } + +.cell-block-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + max-height: 100%; } + .cell-block-container > .grid-x { + max-height: 100%; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; } + +@media print, screen and (min-width: 40em) { + .medium-grid-frame { + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + width: 100vw; } + .cell .medium-grid-frame { + width: 100%; } + .medium-cell-block { + overflow-x: auto; + max-width: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } + .medium-cell-block-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + max-height: 100%; } + .medium-cell-block-container > .grid-x { + max-height: 100%; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; } + .medium-cell-block-y { + overflow-y: auto; + max-height: 100%; + min-height: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } } + +@media print, screen and (min-width: 64em) { + .large-grid-frame { + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + width: 100vw; } + .cell .large-grid-frame { + width: 100%; } + .large-cell-block { + overflow-x: auto; + max-width: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } + .large-cell-block-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + max-height: 100%; } + .large-cell-block-container > .grid-x { + max-height: 100%; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; } + .large-cell-block-y { + overflow-y: auto; + max-height: 100%; + min-height: 100%; + -webkit-overflow-scrolling: touch; + -ms-overflow-style: -ms-autohiding-scrollbar; } } + +.grid-y.grid-frame { + width: auto; + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + height: 100vh; } + +@media print, screen and (min-width: 40em) { + .grid-y.medium-grid-frame { + width: auto; + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + height: 100vh; } } + +@media print, screen and (min-width: 64em) { + .grid-y.large-grid-frame { + width: auto; + overflow: hidden; + position: relative; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + height: 100vh; } } + +.cell .grid-y.grid-frame { + height: 100%; } + +@media print, screen and (min-width: 40em) { + .cell .grid-y.medium-grid-frame { + height: 100%; } } + +@media print, screen and (min-width: 64em) { + .cell .grid-y.large-grid-frame { + height: 100%; } } + +.grid-margin-y { + margin-top: -0.625rem; + margin-bottom: -0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-y { + margin-top: -0.9375rem; + margin-bottom: -0.9375rem; } } + .grid-margin-y > .cell { + height: calc(100% - 1.25rem); + margin-top: 0.625rem; + margin-bottom: 0.625rem; } + @media print, screen and (min-width: 40em) { + .grid-margin-y > .cell { + height: calc(100% - 1.875rem); + margin-top: 0.9375rem; + margin-bottom: 0.9375rem; } } + .grid-margin-y > .auto { + height: auto; } + .grid-margin-y > .shrink { + height: auto; } + .grid-margin-y > .small-1 { + height: calc(8.33333% - 1.25rem); } + .grid-margin-y > .small-2 { + height: calc(16.66667% - 1.25rem); } + .grid-margin-y > .small-3 { + height: calc(25% - 1.25rem); } + .grid-margin-y > .small-4 { + height: calc(33.33333% - 1.25rem); } + .grid-margin-y > .small-5 { + height: calc(41.66667% - 1.25rem); } + .grid-margin-y > .small-6 { + height: calc(50% - 1.25rem); } + .grid-margin-y > .small-7 { + height: calc(58.33333% - 1.25rem); } + .grid-margin-y > .small-8 { + height: calc(66.66667% - 1.25rem); } + .grid-margin-y > .small-9 { + height: calc(75% - 1.25rem); } + .grid-margin-y > .small-10 { + height: calc(83.33333% - 1.25rem); } + .grid-margin-y > .small-11 { + height: calc(91.66667% - 1.25rem); } + .grid-margin-y > .small-12 { + height: calc(100% - 1.25rem); } + @media print, screen and (min-width: 40em) { + .grid-margin-y > .auto { + height: auto; } + .grid-margin-y > .shrink { + height: auto; } + .grid-margin-y > .small-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .small-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .small-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .small-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .small-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .small-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .small-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .small-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .small-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .small-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .small-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .small-12 { + height: calc(100% - 1.875rem); } + .grid-margin-y > .medium-auto { + height: auto; } + .grid-margin-y > .medium-shrink { + height: auto; } + .grid-margin-y > .medium-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .medium-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .medium-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .medium-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .medium-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .medium-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .medium-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .medium-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .medium-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .medium-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .medium-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .medium-12 { + height: calc(100% - 1.875rem); } } + @media print, screen and (min-width: 64em) { + .grid-margin-y > .large-auto { + height: auto; } + .grid-margin-y > .large-shrink { + height: auto; } + .grid-margin-y > .large-1 { + height: calc(8.33333% - 1.875rem); } + .grid-margin-y > .large-2 { + height: calc(16.66667% - 1.875rem); } + .grid-margin-y > .large-3 { + height: calc(25% - 1.875rem); } + .grid-margin-y > .large-4 { + height: calc(33.33333% - 1.875rem); } + .grid-margin-y > .large-5 { + height: calc(41.66667% - 1.875rem); } + .grid-margin-y > .large-6 { + height: calc(50% - 1.875rem); } + .grid-margin-y > .large-7 { + height: calc(58.33333% - 1.875rem); } + .grid-margin-y > .large-8 { + height: calc(66.66667% - 1.875rem); } + .grid-margin-y > .large-9 { + height: calc(75% - 1.875rem); } + .grid-margin-y > .large-10 { + height: calc(83.33333% - 1.875rem); } + .grid-margin-y > .large-11 { + height: calc(91.66667% - 1.875rem); } + .grid-margin-y > .large-12 { + height: calc(100% - 1.875rem); } } + +.grid-frame.grid-margin-y { + height: calc(100vh + 1.25rem); } + @media print, screen and (min-width: 40em) { + .grid-frame.grid-margin-y { + height: calc(100vh + 1.875rem); } } + @media print, screen and (min-width: 64em) { + .grid-frame.grid-margin-y { + height: calc(100vh + 1.875rem); } } + +@media print, screen and (min-width: 40em) { + .grid-margin-y.medium-grid-frame { + height: calc(100vh + 1.875rem); } } + +@media print, screen and (min-width: 64em) { + .grid-margin-y.large-grid-frame { + height: calc(100vh + 1.875rem); } } + +.button { + display: inline-block; + vertical-align: middle; + margin: 0 0 1rem 0; + padding: 0.85em 1em; + border: 1px solid transparent; + border-radius: 0; + -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out; + transition: background-color 0.25s ease-out, color 0.25s ease-out; + font-family: inherit; + font-size: 0.9rem; + -webkit-appearance: none; + line-height: 1; + text-align: center; + cursor: pointer; } + [data-whatinput='mouse'] .button { + outline: 0; } + .button.tiny { + font-size: 0.6rem; } + .button.small { + font-size: 0.75rem; } + .button.large { + font-size: 1.25rem; } + .button.expanded { + display: block; + width: 100%; + margin-right: 0; + margin-left: 0; } + .button, .button.disabled, .button[disabled], .button.disabled:hover, .button[disabled]:hover, .button.disabled:focus, .button[disabled]:focus { + background-color: #2D6699; + color: #fefefe; } + .button:hover, .button:focus { + background-color: #265782; + color: #fefefe; } + .button.primary, .button.primary.disabled, .button.primary[disabled], .button.primary.disabled:hover, .button.primary[disabled]:hover, .button.primary.disabled:focus, .button.primary[disabled]:focus { + background-color: #2D6699; + color: #fefefe; } + .button.primary:hover, .button.primary:focus { + background-color: #24527a; + color: #fefefe; } + .button.secondary, .button.secondary.disabled, .button.secondary[disabled], .button.secondary.disabled:hover, .button.secondary[disabled]:hover, .button.secondary.disabled:focus, .button.secondary[disabled]:focus { + background-color: #A6ADB4; + color: #0a0a0a; } + .button.secondary:hover, .button.secondary:focus { + background-color: #808a94; + color: #0a0a0a; } + .button.success, .button.success.disabled, .button.success[disabled], .button.success.disabled:hover, .button.success[disabled]:hover, .button.success.disabled:focus, .button.success[disabled]:focus { + background-color: #3adb76; + color: #0a0a0a; } + .button.success:hover, .button.success:focus { + background-color: #22bb5b; + color: #0a0a0a; } + .button.warning, .button.warning.disabled, .button.warning[disabled], .button.warning.disabled:hover, .button.warning[disabled]:hover, .button.warning.disabled:focus, .button.warning[disabled]:focus { + background-color: #ffae00; + color: #0a0a0a; } + .button.warning:hover, .button.warning:focus { + background-color: #cc8b00; + color: #0a0a0a; } + .button.alert, .button.alert.disabled, .button.alert[disabled], .button.alert.disabled:hover, .button.alert[disabled]:hover, .button.alert.disabled:focus, .button.alert[disabled]:focus { + background-color: #cc4b37; + color: #fefefe; } + .button.alert:hover, .button.alert:focus { + background-color: #a53b2a; + color: #fefefe; } + .button.hollow, .button.hollow:hover, .button.hollow:focus, .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus { + background-color: transparent; } + .button.hollow, .button.hollow.disabled, .button.hollow[disabled], .button.hollow.disabled:hover, .button.hollow[disabled]:hover, .button.hollow.disabled:focus, .button.hollow[disabled]:focus { + border: 1px solid #2D6699; + color: #2D6699; } + .button.hollow:hover, .button.hollow:focus { + border-color: #17334d; + color: #17334d; } + .button.hollow.primary, .button.hollow.primary.disabled, .button.hollow.primary[disabled], .button.hollow.primary.disabled:hover, .button.hollow.primary[disabled]:hover, .button.hollow.primary.disabled:focus, .button.hollow.primary[disabled]:focus { + border: 1px solid #2D6699; + color: #2D6699; } + .button.hollow.primary:hover, .button.hollow.primary:focus { + border-color: #17334d; + color: #17334d; } + .button.hollow.secondary, .button.hollow.secondary.disabled, .button.hollow.secondary[disabled], .button.hollow.secondary.disabled:hover, .button.hollow.secondary[disabled]:hover, .button.hollow.secondary.disabled:focus, .button.hollow.secondary[disabled]:focus { + border: 1px solid #A6ADB4; + color: #A6ADB4; } + .button.hollow.secondary:hover, .button.hollow.secondary:focus { + border-color: #4f575e; + color: #4f575e; } + .button.hollow.success, .button.hollow.success.disabled, .button.hollow.success[disabled], .button.hollow.success.disabled:hover, .button.hollow.success[disabled]:hover, .button.hollow.success.disabled:focus, .button.hollow.success[disabled]:focus { + border: 1px solid #3adb76; + color: #3adb76; } + .button.hollow.success:hover, .button.hollow.success:focus { + border-color: #157539; + color: #157539; } + .button.hollow.warning, .button.hollow.warning.disabled, .button.hollow.warning[disabled], .button.hollow.warning.disabled:hover, .button.hollow.warning[disabled]:hover, .button.hollow.warning.disabled:focus, .button.hollow.warning[disabled]:focus { + border: 1px solid #ffae00; + color: #ffae00; } + .button.hollow.warning:hover, .button.hollow.warning:focus { + border-color: #805700; + color: #805700; } + .button.hollow.alert, .button.hollow.alert.disabled, .button.hollow.alert[disabled], .button.hollow.alert.disabled:hover, .button.hollow.alert[disabled]:hover, .button.hollow.alert.disabled:focus, .button.hollow.alert[disabled]:focus { + border: 1px solid #cc4b37; + color: #cc4b37; } + .button.hollow.alert:hover, .button.hollow.alert:focus { + border-color: #67251a; + color: #67251a; } + .button.clear, .button.clear:hover, .button.clear:focus, .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus { + border-color: transparent; + background-color: transparent; } + .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear.disabled:hover, .button.clear[disabled]:hover, .button.clear.disabled:focus, .button.clear[disabled]:focus { + color: #2D6699; } + .button.clear:hover, .button.clear:focus { + color: #17334d; } + .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary.disabled:hover, .button.clear.primary[disabled]:hover, .button.clear.primary.disabled:focus, .button.clear.primary[disabled]:focus { + color: #2D6699; } + .button.clear.primary:hover, .button.clear.primary:focus { + color: #17334d; } + .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary.disabled:hover, .button.clear.secondary[disabled]:hover, .button.clear.secondary.disabled:focus, .button.clear.secondary[disabled]:focus { + color: #A6ADB4; } + .button.clear.secondary:hover, .button.clear.secondary:focus { + color: #4f575e; } + .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success.disabled:hover, .button.clear.success[disabled]:hover, .button.clear.success.disabled:focus, .button.clear.success[disabled]:focus { + color: #3adb76; } + .button.clear.success:hover, .button.clear.success:focus { + color: #157539; } + .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning.disabled:hover, .button.clear.warning[disabled]:hover, .button.clear.warning.disabled:focus, .button.clear.warning[disabled]:focus { + color: #ffae00; } + .button.clear.warning:hover, .button.clear.warning:focus { + color: #805700; } + .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert.disabled:hover, .button.clear.alert[disabled]:hover, .button.clear.alert.disabled:focus, .button.clear.alert[disabled]:focus { + color: #cc4b37; } + .button.clear.alert:hover, .button.clear.alert:focus { + color: #67251a; } + .button.disabled, .button[disabled] { + opacity: 0.25; + cursor: not-allowed; } + .button.dropdown::after { + display: block; + width: 0; + height: 0; + border: inset 0.4em; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #fefefe transparent transparent; + position: relative; + top: 0.4em; + display: inline-block; + float: right; + margin-left: 1em; } + .button.dropdown.hollow::after, .button.dropdown.clear::after { + border-top-color: #2D6699; } + .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after { + border-top-color: #2D6699; } + .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after { + border-top-color: #A6ADB4; } + .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after { + border-top-color: #3adb76; } + .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after { + border-top-color: #ffae00; } + .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after { + border-top-color: #cc4b37; } + .button.arrow-only::after { + top: -0.1em; + float: none; + margin-left: 0; } + +a.button:hover, a.button:focus { + text-decoration: none; } + +.button-group { + margin-bottom: 1rem; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; + -webkit-box-flex: 1; + -webkit-flex-grow: 1; + -ms-flex-positive: 1; + flex-grow: 1; } + .button-group::before, .button-group::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .button-group::after { + clear: both; } + .button-group::before, .button-group::after { + display: none; } + .button-group .button { + margin: 0; + margin-right: 1px; + margin-bottom: 1px; + font-size: 0.9rem; + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + .button-group .button:last-child { + margin-right: 0; } + .button-group.tiny .button { + font-size: 0.6rem; } + .button-group.small .button { + font-size: 0.75rem; } + .button-group.large .button { + font-size: 1.25rem; } + .button-group.expanded .button { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + margin-right: 0; } + .button-group.primary .button, .button-group.primary .button.disabled, .button-group.primary .button[disabled], .button-group.primary .button.disabled:hover, .button-group.primary .button[disabled]:hover, .button-group.primary .button.disabled:focus, .button-group.primary .button[disabled]:focus { + background-color: #2D6699; + color: #fefefe; } + .button-group.primary .button:hover, .button-group.primary .button:focus { + background-color: #24527a; + color: #fefefe; } + .button-group.secondary .button, .button-group.secondary .button.disabled, .button-group.secondary .button[disabled], .button-group.secondary .button.disabled:hover, .button-group.secondary .button[disabled]:hover, .button-group.secondary .button.disabled:focus, .button-group.secondary .button[disabled]:focus { + background-color: #A6ADB4; + color: #0a0a0a; } + .button-group.secondary .button:hover, .button-group.secondary .button:focus { + background-color: #808a94; + color: #0a0a0a; } + .button-group.success .button, .button-group.success .button.disabled, .button-group.success .button[disabled], .button-group.success .button.disabled:hover, .button-group.success .button[disabled]:hover, .button-group.success .button.disabled:focus, .button-group.success .button[disabled]:focus { + background-color: #3adb76; + color: #0a0a0a; } + .button-group.success .button:hover, .button-group.success .button:focus { + background-color: #22bb5b; + color: #0a0a0a; } + .button-group.warning .button, .button-group.warning .button.disabled, .button-group.warning .button[disabled], .button-group.warning .button.disabled:hover, .button-group.warning .button[disabled]:hover, .button-group.warning .button.disabled:focus, .button-group.warning .button[disabled]:focus { + background-color: #ffae00; + color: #0a0a0a; } + .button-group.warning .button:hover, .button-group.warning .button:focus { + background-color: #cc8b00; + color: #0a0a0a; } + .button-group.alert .button, .button-group.alert .button.disabled, .button-group.alert .button[disabled], .button-group.alert .button.disabled:hover, .button-group.alert .button[disabled]:hover, .button-group.alert .button.disabled:focus, .button-group.alert .button[disabled]:focus { + background-color: #cc4b37; + color: #fefefe; } + .button-group.alert .button:hover, .button-group.alert .button:focus { + background-color: #a53b2a; + color: #fefefe; } + .button-group.hollow .button, .button-group.hollow .button:hover, .button-group.hollow .button:focus, .button-group.hollow .button.disabled, .button-group.hollow .button.disabled:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled], .button-group.hollow .button[disabled]:hover, .button-group.hollow .button[disabled]:focus { + background-color: transparent; } + .button-group.hollow .button, .button-group.hollow .button.disabled, .button-group.hollow .button[disabled], .button-group.hollow .button.disabled:hover, .button-group.hollow .button[disabled]:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled]:focus { + border: 1px solid #2D6699; + color: #2D6699; } + .button-group.hollow .button:hover, .button-group.hollow .button:focus { + border-color: #17334d; + color: #17334d; } + .button-group.hollow.primary .button, .button-group.hollow.primary .button.disabled, .button-group.hollow.primary .button[disabled], .button-group.hollow.primary .button.disabled:hover, .button-group.hollow.primary .button[disabled]:hover, .button-group.hollow.primary .button.disabled:focus, .button-group.hollow.primary .button[disabled]:focus, .button-group.hollow .button.primary, .button-group.hollow .button.primary.disabled, .button-group.hollow .button.primary[disabled], .button-group.hollow .button.primary.disabled:hover, .button-group.hollow .button.primary[disabled]:hover, .button-group.hollow .button.primary.disabled:focus, .button-group.hollow .button.primary[disabled]:focus { + border: 1px solid #2D6699; + color: #2D6699; } + .button-group.hollow.primary .button:hover, .button-group.hollow.primary .button:focus, .button-group.hollow .button.primary:hover, .button-group.hollow .button.primary:focus { + border-color: #17334d; + color: #17334d; } + .button-group.hollow.secondary .button, .button-group.hollow.secondary .button.disabled, .button-group.hollow.secondary .button[disabled], .button-group.hollow.secondary .button.disabled:hover, .button-group.hollow.secondary .button[disabled]:hover, .button-group.hollow.secondary .button.disabled:focus, .button-group.hollow.secondary .button[disabled]:focus, .button-group.hollow .button.secondary, .button-group.hollow .button.secondary.disabled, .button-group.hollow .button.secondary[disabled], .button-group.hollow .button.secondary.disabled:hover, .button-group.hollow .button.secondary[disabled]:hover, .button-group.hollow .button.secondary.disabled:focus, .button-group.hollow .button.secondary[disabled]:focus { + border: 1px solid #A6ADB4; + color: #A6ADB4; } + .button-group.hollow.secondary .button:hover, .button-group.hollow.secondary .button:focus, .button-group.hollow .button.secondary:hover, .button-group.hollow .button.secondary:focus { + border-color: #4f575e; + color: #4f575e; } + .button-group.hollow.success .button, .button-group.hollow.success .button.disabled, .button-group.hollow.success .button[disabled], .button-group.hollow.success .button.disabled:hover, .button-group.hollow.success .button[disabled]:hover, .button-group.hollow.success .button.disabled:focus, .button-group.hollow.success .button[disabled]:focus, .button-group.hollow .button.success, .button-group.hollow .button.success.disabled, .button-group.hollow .button.success[disabled], .button-group.hollow .button.success.disabled:hover, .button-group.hollow .button.success[disabled]:hover, .button-group.hollow .button.success.disabled:focus, .button-group.hollow .button.success[disabled]:focus { + border: 1px solid #3adb76; + color: #3adb76; } + .button-group.hollow.success .button:hover, .button-group.hollow.success .button:focus, .button-group.hollow .button.success:hover, .button-group.hollow .button.success:focus { + border-color: #157539; + color: #157539; } + .button-group.hollow.warning .button, .button-group.hollow.warning .button.disabled, .button-group.hollow.warning .button[disabled], .button-group.hollow.warning .button.disabled:hover, .button-group.hollow.warning .button[disabled]:hover, .button-group.hollow.warning .button.disabled:focus, .button-group.hollow.warning .button[disabled]:focus, .button-group.hollow .button.warning, .button-group.hollow .button.warning.disabled, .button-group.hollow .button.warning[disabled], .button-group.hollow .button.warning.disabled:hover, .button-group.hollow .button.warning[disabled]:hover, .button-group.hollow .button.warning.disabled:focus, .button-group.hollow .button.warning[disabled]:focus { + border: 1px solid #ffae00; + color: #ffae00; } + .button-group.hollow.warning .button:hover, .button-group.hollow.warning .button:focus, .button-group.hollow .button.warning:hover, .button-group.hollow .button.warning:focus { + border-color: #805700; + color: #805700; } + .button-group.hollow.alert .button, .button-group.hollow.alert .button.disabled, .button-group.hollow.alert .button[disabled], .button-group.hollow.alert .button.disabled:hover, .button-group.hollow.alert .button[disabled]:hover, .button-group.hollow.alert .button.disabled:focus, .button-group.hollow.alert .button[disabled]:focus, .button-group.hollow .button.alert, .button-group.hollow .button.alert.disabled, .button-group.hollow .button.alert[disabled], .button-group.hollow .button.alert.disabled:hover, .button-group.hollow .button.alert[disabled]:hover, .button-group.hollow .button.alert.disabled:focus, .button-group.hollow .button.alert[disabled]:focus { + border: 1px solid #cc4b37; + color: #cc4b37; } + .button-group.hollow.alert .button:hover, .button-group.hollow.alert .button:focus, .button-group.hollow .button.alert:hover, .button-group.hollow .button.alert:focus { + border-color: #67251a; + color: #67251a; } + .button-group.clear .button, .button-group.clear .button:hover, .button-group.clear .button:focus, .button-group.clear .button.disabled, .button-group.clear .button.disabled:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled], .button-group.clear .button[disabled]:hover, .button-group.clear .button[disabled]:focus { + border-color: transparent; + background-color: transparent; } + .button-group.clear .button, .button-group.clear .button.disabled, .button-group.clear .button[disabled], .button-group.clear .button.disabled:hover, .button-group.clear .button[disabled]:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled]:focus { + color: #2D6699; } + .button-group.clear .button:hover, .button-group.clear .button:focus { + color: #17334d; } + .button-group.clear.primary .button, .button-group.clear.primary .button.disabled, .button-group.clear.primary .button[disabled], .button-group.clear.primary .button.disabled:hover, .button-group.clear.primary .button[disabled]:hover, .button-group.clear.primary .button.disabled:focus, .button-group.clear.primary .button[disabled]:focus, .button-group.clear .button.primary, .button-group.clear .button.primary.disabled, .button-group.clear .button.primary[disabled], .button-group.clear .button.primary.disabled:hover, .button-group.clear .button.primary[disabled]:hover, .button-group.clear .button.primary.disabled:focus, .button-group.clear .button.primary[disabled]:focus { + color: #2D6699; } + .button-group.clear.primary .button:hover, .button-group.clear.primary .button:focus, .button-group.clear .button.primary:hover, .button-group.clear .button.primary:focus { + color: #17334d; } + .button-group.clear.secondary .button, .button-group.clear.secondary .button.disabled, .button-group.clear.secondary .button[disabled], .button-group.clear.secondary .button.disabled:hover, .button-group.clear.secondary .button[disabled]:hover, .button-group.clear.secondary .button.disabled:focus, .button-group.clear.secondary .button[disabled]:focus, .button-group.clear .button.secondary, .button-group.clear .button.secondary.disabled, .button-group.clear .button.secondary[disabled], .button-group.clear .button.secondary.disabled:hover, .button-group.clear .button.secondary[disabled]:hover, .button-group.clear .button.secondary.disabled:focus, .button-group.clear .button.secondary[disabled]:focus { + color: #A6ADB4; } + .button-group.clear.secondary .button:hover, .button-group.clear.secondary .button:focus, .button-group.clear .button.secondary:hover, .button-group.clear .button.secondary:focus { + color: #4f575e; } + .button-group.clear.success .button, .button-group.clear.success .button.disabled, .button-group.clear.success .button[disabled], .button-group.clear.success .button.disabled:hover, .button-group.clear.success .button[disabled]:hover, .button-group.clear.success .button.disabled:focus, .button-group.clear.success .button[disabled]:focus, .button-group.clear .button.success, .button-group.clear .button.success.disabled, .button-group.clear .button.success[disabled], .button-group.clear .button.success.disabled:hover, .button-group.clear .button.success[disabled]:hover, .button-group.clear .button.success.disabled:focus, .button-group.clear .button.success[disabled]:focus { + color: #3adb76; } + .button-group.clear.success .button:hover, .button-group.clear.success .button:focus, .button-group.clear .button.success:hover, .button-group.clear .button.success:focus { + color: #157539; } + .button-group.clear.warning .button, .button-group.clear.warning .button.disabled, .button-group.clear.warning .button[disabled], .button-group.clear.warning .button.disabled:hover, .button-group.clear.warning .button[disabled]:hover, .button-group.clear.warning .button.disabled:focus, .button-group.clear.warning .button[disabled]:focus, .button-group.clear .button.warning, .button-group.clear .button.warning.disabled, .button-group.clear .button.warning[disabled], .button-group.clear .button.warning.disabled:hover, .button-group.clear .button.warning[disabled]:hover, .button-group.clear .button.warning.disabled:focus, .button-group.clear .button.warning[disabled]:focus { + color: #ffae00; } + .button-group.clear.warning .button:hover, .button-group.clear.warning .button:focus, .button-group.clear .button.warning:hover, .button-group.clear .button.warning:focus { + color: #805700; } + .button-group.clear.alert .button, .button-group.clear.alert .button.disabled, .button-group.clear.alert .button[disabled], .button-group.clear.alert .button.disabled:hover, .button-group.clear.alert .button[disabled]:hover, .button-group.clear.alert .button.disabled:focus, .button-group.clear.alert .button[disabled]:focus, .button-group.clear .button.alert, .button-group.clear .button.alert.disabled, .button-group.clear .button.alert[disabled], .button-group.clear .button.alert.disabled:hover, .button-group.clear .button.alert[disabled]:hover, .button-group.clear .button.alert.disabled:focus, .button-group.clear .button.alert[disabled]:focus { + color: #cc4b37; } + .button-group.clear.alert .button:hover, .button-group.clear.alert .button:focus, .button-group.clear .button.alert:hover, .button-group.clear .button.alert:focus { + color: #67251a; } + .button-group.no-gaps .button { + margin-right: -0.0625rem; } + .button-group.no-gaps .button + .button { + border-left-color: transparent; } + .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } + .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button { + -webkit-box-flex: 0; + -webkit-flex: 0 0 100%; + -ms-flex: 0 0 100%; + flex: 0 0 100%; } + .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child { + margin-bottom: 0; } + .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; + margin-right: 0; } + @media print, screen and (min-width: 40em) { + .button-group.stacked-for-small .button { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + margin-bottom: 0; } } + @media print, screen and (min-width: 64em) { + .button-group.stacked-for-medium .button { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + margin-bottom: 0; } } + @media print, screen and (max-width: 39.99875em) { + .button-group.stacked-for-small.expanded { + display: block; } + .button-group.stacked-for-small.expanded .button { + display: block; + margin-right: 0; } } + @media print, screen and (max-width: 63.99875em) { + .button-group.stacked-for-medium.expanded { + display: block; } + .button-group.stacked-for-medium.expanded .button { + display: block; + margin-right: 0; } } + +.close-button { + position: absolute; + z-index: 10; + 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.medium, .close-button { + right: 1rem; + top: 0.5rem; + font-size: 2em; + line-height: 1; } + +.label { + display: inline-block; + padding: 0.33333rem 0.5rem; + border-radius: 0; + font-size: 0.8rem; + line-height: 1; + white-space: nowrap; + cursor: default; + background: #2D6699; + color: #fefefe; } + .label.primary { + background: #2D6699; + color: #fefefe; } + .label.secondary { + background: #A6ADB4; + color: #0a0a0a; } + .label.success { + background: #3adb76; + color: #0a0a0a; } + .label.warning { + background: #ffae00; + color: #0a0a0a; } + .label.alert { + background: #cc4b37; + color: #fefefe; } + +.progress { + height: 1rem; + margin-bottom: 1rem; + border-radius: 0; + background-color: #cacaca; } + .progress.primary .progress-meter { + background-color: #2D6699; } + .progress.secondary .progress-meter { + background-color: #A6ADB4; } + .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: #2D6699; } + +.progress-meter-text { + position: absolute; + top: 50%; + left: 50%; + -webkit-transform: translate(-50%, -50%); + -ms-transform: translate(-50%, -50%); + transform: translate(-50%, -50%); + margin: 0; + font-size: 0.75rem; + font-weight: bold; + color: #fefefe; + white-space: nowrap; } + +.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; + -webkit-transition: all 0.2s ease-in-out; + transition: all 0.2s ease-in-out; } + .slider-fill.is-dragging { + -webkit-transition: all 0s linear; + transition: all 0s linear; } + +.slider-handle { + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); + left: 0; + z-index: 1; + display: inline-block; + width: 1.4rem; + height: 1.4rem; + border-radius: 0; + background-color: #2D6699; + -webkit-transition: all 0.2s ease-in-out; + transition: all 0.2s ease-in-out; + -ms-touch-action: manipulation; + touch-action: manipulation; } + [data-whatinput='mouse'] .slider-handle { + outline: 0; } + .slider-handle:hover { + background-color: #265782; } + .slider-handle.is-dragging { + -webkit-transition: all 0s linear; + transition: all 0s linear; } + +.slider.disabled, +.slider[disabled] { + opacity: 0.25; + cursor: not-allowed; } + +.slider.vertical { + display: inline-block; + width: 0.5rem; + height: 12.5rem; + margin: 0 1.25rem; + -webkit-transform: scale(1, -1); + -ms-transform: scale(1, -1); + transform: scale(1, -1); } + .slider.vertical .slider-fill { + top: 0; + width: 0.5rem; + max-height: 100%; } + .slider.vertical .slider-handle { + position: absolute; + top: 0; + left: 50%; + width: 1.4rem; + height: 1.4rem; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); } + +.switch { + height: 2rem; + position: relative; + margin-bottom: 1rem; + outline: 0; + font-size: 0.875rem; + font-weight: bold; + color: #fefefe; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } + +.switch-input { + position: absolute; + margin-bottom: 0; + opacity: 0; } + +.switch-paddle { + position: relative; + display: block; + width: 4rem; + height: 2rem; + border-radius: 0; + background: #cacaca; + -webkit-transition: all 0.25s ease-out; + transition: all 0.25s ease-out; + font-weight: inherit; + color: inherit; + cursor: pointer; } + input + .switch-paddle { + margin: 0; } + .switch-paddle::after { + position: absolute; + top: 0.25rem; + left: 0.25rem; + display: block; + width: 1.5rem; + height: 1.5rem; + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); + border-radius: 0; + background: #fefefe; + -webkit-transition: all 0.25s ease-out; + transition: all 0.25s ease-out; + content: ''; } + input:checked ~ .switch-paddle { + background: #2D6699; } + input:checked ~ .switch-paddle::after { + left: 2.25rem; } + input:disabled ~ .switch-paddle { + cursor: not-allowed; + opacity: 0.5; } + [data-whatinput='mouse'] input:focus ~ .switch-paddle { + outline: 0; } + +.switch-active, .switch-inactive { + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); } + +.switch-active { + left: 8%; + display: none; } + input:checked + label > .switch-active { + display: block; } + +.switch-inactive { + right: 15%; } + input:checked + label > .switch-inactive { + display: none; } + +.switch.tiny { + height: 1.5rem; } + .switch.tiny .switch-paddle { + width: 3rem; + height: 1.5rem; + font-size: 0.625rem; } + .switch.tiny .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 1rem; + height: 1rem; } + .switch.tiny input:checked ~ .switch-paddle::after { + left: 1.75rem; } + +.switch.small { + height: 1.75rem; } + .switch.small .switch-paddle { + width: 3.5rem; + height: 1.75rem; + font-size: 0.75rem; } + .switch.small .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 1.25rem; + height: 1.25rem; } + .switch.small input:checked ~ .switch-paddle::after { + left: 2rem; } + +.switch.large { + height: 2.5rem; } + .switch.large .switch-paddle { + width: 5rem; + height: 2.5rem; + font-size: 1rem; } + .switch.large .switch-paddle::after { + top: 0.25rem; + left: 0.25rem; + width: 2rem; + height: 2rem; } + .switch.large input:checked ~ .switch-paddle::after { + left: 2.75rem; } + +table { + border-collapse: collapse; + width: 100%; + margin-bottom: 1rem; + border-radius: 0; } + thead, + tbody, + tfoot { + border: 1px solid #f1f1f1; + background-color: #fefefe; } + caption { + padding: 0.5rem 0.625rem 0.625rem; + font-weight: bold; } + thead { + background: #f8f8f8; + color: #0a0a0a; } + tfoot { + background: #f1f1f1; + color: #0a0a0a; } + thead tr, + tfoot tr { + background: transparent; } + thead th, + thead td, + tfoot th, + tfoot td { + padding: 0.5rem 0.625rem 0.625rem; + font-weight: bold; + text-align: left; } + tbody th, + tbody td { + padding: 0.5rem 0.625rem 0.625rem; } + tbody tr:nth-child(even) { + border-bottom: 0; + background-color: #f1f1f1; } + table.unstriped tbody { + background-color: #fefefe; } + table.unstriped tbody tr { + border-bottom: 0; + border-bottom: 1px solid #f1f1f1; + background-color: #fefefe; } + +@media print, screen and (max-width: 63.99875em) { + table.stack thead { + display: none; } + table.stack tfoot { + display: none; } + table.stack tr, + table.stack th, + table.stack td { + display: block; } + table.stack td { + border-top: 0; } } + +table.scroll { + display: block; + width: 100%; + overflow-x: auto; } + +table.hover thead tr:hover { + background-color: #f3f3f3; } + +table.hover tfoot tr:hover { + background-color: #ececec; } + +table.hover tbody tr:hover { + background-color: #f9f9f9; } + +table.hover:not(.unstriped) tr:nth-of-type(even):hover { + background-color: #ececec; } + +.table-scroll { + overflow-x: auto; } + +.badge { + display: inline-block; + min-width: 2.1em; + padding: 0.3em; + border-radius: 50%; + font-size: 0.6rem; + text-align: center; + background: #2D6699; + color: #fefefe; } + .badge.primary { + background: #2D6699; + color: #fefefe; } + .badge.secondary { + background: #A6ADB4; + color: #0a0a0a; } + .badge.success { + background: #3adb76; + color: #0a0a0a; } + .badge.warning { + background: #ffae00; + color: #0a0a0a; } + .badge.alert { + background: #cc4b37; + color: #fefefe; } + +.breadcrumbs { + margin: 0 0 1rem 0; + list-style: none; } + .breadcrumbs::before, .breadcrumbs::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .breadcrumbs::after { + clear: both; } + .breadcrumbs li { + float: left; + font-size: 0.6875rem; + color: #0a0a0a; + cursor: default; + text-transform: uppercase; } + .breadcrumbs li:not(:last-child)::after { + position: relative; + margin: 0 0.75rem; + opacity: 1; + content: "/"; + color: #cacaca; } + .breadcrumbs a { + color: #2D6699; } + .breadcrumbs a:hover { + text-decoration: underline; } + .breadcrumbs .disabled { + color: #cacaca; + cursor: not-allowed; } + +.callout { + position: relative; + margin: 0 0 1rem 0; + padding: 1rem; + border: 1px solid rgba(10, 10, 10, 0.25); + border-radius: 0; + background-color: white; + color: #0a0a0a; } + .callout > :first-child { + margin-top: 0; } + .callout > :last-child { + margin-bottom: 0; } + .callout.primary { + background-color: #dbe8f4; + color: #0a0a0a; } + .callout.secondary { + background-color: #f2f3f4; + color: #0a0a0a; } + .callout.success { + background-color: #e1faea; + color: #0a0a0a; } + .callout.warning { + background-color: #fff3d9; + color: #0a0a0a; } + .callout.alert { + background-color: #f7e4e1; + color: #0a0a0a; } + .callout.small { + padding-top: 0.5rem; + padding-right: 0.5rem; + padding-bottom: 0.5rem; + padding-left: 0.5rem; } + .callout.large { + padding-top: 3rem; + padding-right: 3rem; + padding-bottom: 3rem; + padding-left: 3rem; } + +.card { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-flex: 1; + -webkit-flex-grow: 1; + -ms-flex-positive: 1; + flex-grow: 1; + margin-bottom: 1rem; + border: 1px solid #e6e6e6; + border-radius: 0; + background: #fefefe; + -webkit-box-shadow: none; + box-shadow: none; + overflow: hidden; + color: #0a0a0a; } + .card > :last-child { + margin-bottom: 0; } + +.card-divider { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; + padding: 1rem; + background: #e6e6e6; } + .card-divider > :last-child { + margin-bottom: 0; } + +.card-section { + -webkit-box-flex: 1; + -webkit-flex: 1 0 auto; + -ms-flex: 1 0 auto; + flex: 1 0 auto; + padding: 1rem; } + .card-section > :last-child { + margin-bottom: 0; } + +.card-image { + min-height: 1px; } + +.dropdown-pane { + position: absolute; + z-index: 10; + display: none; + width: 300px; + padding: 1rem; + visibility: hidden; + border: 1px solid #cacaca; + border-radius: 0; + background-color: #F0F0F0; + font-size: 1rem; } + .dropdown-pane.is-opening { + display: block; } + .dropdown-pane.is-open { + display: block; + visibility: visible; } + +.dropdown-pane.tiny { + width: 100px; } + +.dropdown-pane.small { + width: 200px; } + +.dropdown-pane.large { + width: 400px; } + +.pagination { + margin-left: 0; + margin-bottom: 1rem; } + .pagination::before, .pagination::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .pagination::after { + clear: both; } + .pagination li { + margin-right: 0.0625rem; + border-radius: 0; + font-size: 0.875rem; + display: none; } + .pagination li:last-child, .pagination li:first-child { + display: inline-block; } + @media print, screen and (min-width: 40em) { + .pagination li { + display: inline-block; } } + .pagination a, + .pagination button { + display: block; + padding: 0.1875rem 0.625rem; + border-radius: 0; + color: #0a0a0a; } + .pagination a:hover, + .pagination button:hover { + background: #e6e6e6; } + .pagination .current { + padding: 0.1875rem 0.625rem; + background: #2D6699; + 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: "«"; } + +.pagination-next a::after, +.pagination-next.disabled::after { + display: inline-block; + margin-left: 0.5rem; + content: "»"; } + +.has-tip { + position: relative; + display: inline-block; + border-bottom: dotted 1px #8a8a8a; + font-weight: bold; + cursor: help; } + +.tooltip { + position: absolute; + top: calc(100% + 0.6495rem); + z-index: 1200; + max-width: 10rem; + padding: 0.75rem; + border-radius: 0; + background-color: #0a0a0a; + font-size: 80%; + color: #fefefe; } + .tooltip::before { + position: absolute; } + .tooltip.bottom::before { + display: block; + width: 0; + height: 0; + border: inset 0.75rem; + content: ''; + border-top-width: 0; + border-bottom-style: solid; + border-color: transparent transparent #0a0a0a; + bottom: 100%; } + .tooltip.bottom.align-center::before { + left: 50%; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); } + .tooltip.top::before { + display: block; + width: 0; + height: 0; + border: inset 0.75rem; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #0a0a0a transparent transparent; + top: 100%; + bottom: auto; } + .tooltip.top.align-center::before { + left: 50%; + -webkit-transform: translateX(-50%); + -ms-transform: translateX(-50%); + transform: translateX(-50%); } + .tooltip.left::before { + display: block; + width: 0; + height: 0; + border: inset 0.75rem; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #0a0a0a; + left: 100%; } + .tooltip.left.align-center::before { + bottom: auto; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); } + .tooltip.right::before { + display: block; + width: 0; + height: 0; + border: inset 0.75rem; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #0a0a0a transparent transparent; + right: 100%; + left: auto; } + .tooltip.right.align-center::before { + bottom: auto; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); } + .tooltip.align-top::before { + bottom: auto; + top: 10%; } + .tooltip.align-bottom::before { + bottom: 10%; + top: auto; } + .tooltip.align-left::before { + left: 10%; + right: auto; } + .tooltip.align-right::before { + left: auto; + right: 10%; } + +.accordion { + margin-left: 0; + background: #fefefe; + list-style-type: none; } + .accordion[disabled] .accordion-title { + cursor: not-allowed; } + +.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: #2D6699; } + :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: "–"; } + +.accordion-content { + display: none; + padding: 1rem; + border: 1px solid #e6e6e6; + border-bottom: 0; + background-color: #fefefe; + color: #0a0a0a; } + :last-child > .accordion-content:last-child { + border-bottom: 1px solid #e6e6e6; } + +.media-object { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + margin-bottom: 1rem; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; } + .media-object img { + max-width: none; } + @media print, screen and (max-width: 39.99875em) { + .media-object.stack-for-small { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } } + +.media-object-section { + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; } + .media-object-section:first-child { + padding-right: 8rem; } + .media-object-section:last-child:not(:nth-child(2)) { + padding-left: 8rem; } + .media-object-section > :last-child { + margin-bottom: 0; } + @media print, screen and (max-width: 39.99875em) { + .stack-for-small .media-object-section { + padding: 0; + padding-bottom: 8rem; + -webkit-flex-basis: 100%; + -ms-flex-preferred-size: 100%; + flex-basis: 100%; + max-width: 100%; } + .stack-for-small .media-object-section img { + width: 100%; } } + .media-object-section.main-section { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + +.orbit { + position: relative; } + +.orbit-container { + position: relative; + height: 0; + margin: 0; + list-style: none; + overflow: hidden; } + +.orbit-slide { + width: 100%; + position: absolute; } + .orbit-slide.no-motionui.is-active { + top: 0; + left: 0; } + +.orbit-figure { + margin: 0; } + +.orbit-image { + width: 100%; + max-width: 100%; + margin: 0; } + +.orbit-caption { + position: absolute; + bottom: 0; + width: 100%; + margin-bottom: 0; + padding: 1rem; + background-color: rgba(10, 10, 10, 0.5); + color: #fefefe; } + +.orbit-previous, .orbit-next { + position: absolute; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); + z-index: 10; + padding: 1rem; + color: #fefefe; } + [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next { + outline: 0; } + .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus { + background-color: rgba(10, 10, 10, 0.5); } + +.orbit-previous { + left: 0; } + +.orbit-next { + left: auto; + right: 0; } + +.orbit-bullets { + position: relative; + margin-top: 0.8rem; + margin-bottom: 0.8rem; + text-align: center; } + [data-whatinput='mouse'] .orbit-bullets { + outline: 0; } + .orbit-bullets button { + width: 1.2rem; + height: 1.2rem; + margin: 0.1rem; + border-radius: 50%; + background-color: #cacaca; } + .orbit-bullets button:hover { + background-color: #8a8a8a; } + .orbit-bullets button.is-active { + background-color: #8a8a8a; } + +.responsive-embed, +.flex-video { + position: relative; + height: 0; + margin-bottom: 1rem; + padding-bottom: 75%; + overflow: hidden; } + .responsive-embed iframe, + .responsive-embed object, + .responsive-embed embed, + .responsive-embed video, + .flex-video iframe, + .flex-video object, + .flex-video embed, + .flex-video video { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; } + .responsive-embed.widescreen, + .flex-video.widescreen { + padding-bottom: 56.25%; } + +.tabs { + margin: 0; + border: 1px solid #e6e6e6; + background: #fefefe; + list-style-type: none; } + .tabs::before, .tabs::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .tabs::after { + clear: both; } + +.tabs.vertical > li { + display: block; + float: none; + width: auto; } + +.tabs.simple > li > a { + padding: 0; } + .tabs.simple > li > a:hover { + background: transparent; } + +.tabs.primary { + background: #2D6699; } + .tabs.primary > li > a { + color: #fefefe; } + .tabs.primary > li > a:hover, .tabs.primary > li > a:focus { + background: #316ea5; } + +.tabs-title { + float: left; } + .tabs-title > a { + display: block; + padding: 1.25rem 1.5rem; + font-size: 0.75rem; + line-height: 1; + color: #2D6699; } + [data-whatinput='mouse'] .tabs-title > a { + outline: 0; } + .tabs-title > a:hover { + background: #fefefe; + color: #275884; } + .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] { + background: #e6e6e6; + color: #2D6699; } + +.tabs-content { + border: 1px solid #e6e6e6; + border-top: 0; + background: #fefefe; + color: #0a0a0a; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; } + +.tabs-content.vertical { + border: 1px solid #e6e6e6; + border-left: 0; } + +.tabs-panel { + display: none; + padding: 1rem; } + .tabs-panel.is-active { + display: block; } + +.thumbnail { + display: inline-block; + max-width: 100%; + margin-bottom: 1rem; + border: 4px solid #fefefe; + border-radius: 0; + -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2); + box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2); + line-height: 0; } + +a.thumbnail { + -webkit-transition: -webkit-box-shadow 200ms ease-out; + transition: -webkit-box-shadow 200ms ease-out; + transition: box-shadow 200ms ease-out; + transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; } + a.thumbnail:hover, a.thumbnail:focus { + -webkit-box-shadow: 0 0 6px 1px rgba(45, 102, 153, 0.5); + box-shadow: 0 0 6px 1px rgba(45, 102, 153, 0.5); } + a.thumbnail image { + -webkit-box-shadow: none; + box-shadow: none; } + +.menu { + padding: 0; + margin: 0; + list-style: none; + position: relative; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } + [data-whatinput='mouse'] .menu li { + outline: 0; } + .menu a, + .menu .button { + line-height: 1; + text-decoration: none; + display: block; + padding: 0.7rem 1rem; } + .menu input, + .menu select, + .menu a, + .menu button { + margin-bottom: 0; } + .menu input { + display: inline-block; } + .menu, .menu.horizontal { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + .menu.vertical { + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + .menu.expanded li { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + .menu.simple { + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; } + .menu.simple li + li { + margin-left: 1rem; } + .menu.simple a { + padding: 0; } + @media print, screen and (min-width: 40em) { + .menu.medium-horizontal { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + .menu.medium-vertical { + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + .menu.medium-expanded li { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + .menu.medium-simple li { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } } + @media print, screen and (min-width: 64em) { + .menu.large-horizontal { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + .menu.large-vertical { + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + .menu.large-expanded li { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + .menu.large-simple li { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } } + .menu.nested { + margin-right: 0; + margin-left: 1rem; } + .menu.icons a { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; } + .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; } + .menu.icon-left li a { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-flow: row nowrap; + -ms-flex-flow: row nowrap; + flex-flow: row nowrap; } + .menu.icon-left li a img, + .menu.icon-left li a i, + .menu.icon-left li a svg { + margin-right: 0.25rem; } + .menu.icon-right li a { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-flow: row nowrap; + -ms-flex-flow: row nowrap; + flex-flow: row nowrap; } + .menu.icon-right li a img, + .menu.icon-right li a i, + .menu.icon-right li a svg { + margin-left: 0.25rem; } + .menu.icon-top li a { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-flow: column nowrap; + -ms-flex-flow: column nowrap; + flex-flow: column nowrap; } + .menu.icon-top li a img, + .menu.icon-top li a i, + .menu.icon-top li a svg { + -webkit-align-self: stretch; + -ms-flex-item-align: stretch; + align-self: stretch; + margin-bottom: 0.25rem; + text-align: center; } + .menu.icon-bottom li a { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-flow: column nowrap; + -ms-flex-flow: column nowrap; + flex-flow: column nowrap; } + .menu.icon-bottom li a img, + .menu.icon-bottom li a i, + .menu.icon-bottom li a svg { + -webkit-align-self: stretch; + -ms-flex-item-align: stretch; + align-self: stretch; + margin-bottom: 0.25rem; + text-align: center; } + .menu .is-active > a { + background: #2D6699; + color: #fefefe; } + .menu .active > a { + background: #2D6699; + color: #fefefe; } + .menu.align-left { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + .menu.align-right li { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: end; + -webkit-justify-content: flex-end; + -ms-flex-pack: end; + justify-content: flex-end; } + .menu.align-right li .submenu li { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + .menu.align-right.vertical li { + display: block; + text-align: right; } + .menu.align-right.vertical li .submenu li { + text-align: right; } + .menu.align-right .nested { + margin-right: 1rem; + margin-left: 0; } + .menu.align-center li { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + .menu.align-center li .submenu li { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + .menu .menu-text { + padding: 0.7rem 1rem; + font-weight: bold; + line-height: 1; + color: inherit; } + +.menu-centered > .menu { + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + .menu-centered > .menu li { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + .menu-centered > .menu li .submenu li { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + +.no-js [data-responsive-menu] ul { + display: none; } + +.menu-icon { + position: relative; + display: inline-block; + vertical-align: middle; + width: 20px; + height: 16px; + cursor: pointer; } + .menu-icon::after { + position: absolute; + top: 0; + left: 0; + display: block; + width: 100%; + height: 2px; + background: #fefefe; + -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + content: ''; } + .menu-icon:hover::after { + background: #cacaca; + -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; + box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; } + +.menu-icon.dark { + position: relative; + display: inline-block; + vertical-align: middle; + width: 20px; + height: 16px; + cursor: pointer; } + .menu-icon.dark::after { + position: absolute; + top: 0; + left: 0; + display: block; + width: 100%; + height: 2px; + background: #0a0a0a; + -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; + box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a; + content: ''; } + .menu-icon.dark:hover::after { + background: #8a8a8a; + -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; + box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; } + +.accordion-menu li { + width: 100%; } + +.accordion-menu a { + padding: 0.7rem 1rem; } + +.accordion-menu .is-accordion-submenu a { + padding: 0.7rem 1rem; } + +.accordion-menu .nested.is-accordion-submenu { + margin-right: 0; + margin-left: 1rem; } + +.accordion-menu.align-right .nested.is-accordion-submenu { + margin-right: 1rem; + margin-left: 0; } + +.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a { + position: relative; } + .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #2D6699 transparent transparent; + position: absolute; + top: 50%; + margin-top: -3px; + right: 1rem; } + +.accordion-menu.align-left .is-accordion-submenu-parent > a::after { + right: 1rem; + left: auto; } + +.accordion-menu.align-right .is-accordion-submenu-parent > a::after { + right: auto; + left: 1rem; } + +.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after { + -webkit-transform: rotate(180deg); + -ms-transform: rotate(180deg); + transform: rotate(180deg); + -webkit-transform-origin: 50% 50%; + -ms-transform-origin: 50% 50%; + transform-origin: 50% 50%; } + +.is-accordion-submenu-parent { + position: relative; } + +.has-submenu-toggle > a { + margin-right: 40px; } + +.submenu-toggle { + position: absolute; + top: 0; + right: 0; + width: 40px; + height: 40px; + cursor: pointer; } + .submenu-toggle::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #2D6699 transparent transparent; + top: 0; + bottom: 0; + margin: auto; } + +.submenu-toggle[aria-expanded='true']::after { + -webkit-transform: scaleY(-1); + -ms-transform: scaleY(-1); + transform: scaleY(-1); + -webkit-transform-origin: 50% 50%; + -ms-transform-origin: 50% 50%; + transform-origin: 50% 50%; } + +.submenu-toggle-text { + position: absolute !important; + width: 1px !important; + height: 1px !important; + padding: 0 !important; + overflow: hidden !important; + clip: rect(0, 0, 0, 0) !important; + white-space: nowrap !important; + border: 0 !important; } + +.is-drilldown { + position: relative; + overflow: hidden; } + .is-drilldown li { + display: block; } + .is-drilldown.animate-height { + -webkit-transition: height 0.5s; + transition: height 0.5s; } + +.drilldown a { + padding: 0.7rem 1rem; + background: #fefefe; } + +.drilldown .is-drilldown-submenu { + position: absolute; + top: 0; + left: 100%; + z-index: -1; + width: 100%; + background: #fefefe; + -webkit-transition: -webkit-transform 0.15s linear; + transition: -webkit-transform 0.15s linear; + transition: transform 0.15s linear; + transition: transform 0.15s linear, -webkit-transform 0.15s linear; } + .drilldown .is-drilldown-submenu.is-active { + z-index: 1; + display: block; + -webkit-transform: translateX(-100%); + -ms-transform: translateX(-100%); + transform: translateX(-100%); } + .drilldown .is-drilldown-submenu.is-closing { + -webkit-transform: translateX(100%); + -ms-transform: translateX(100%); + transform: translateX(100%); } + .drilldown .is-drilldown-submenu a { + padding: 0.7rem 1rem; } + +.drilldown .nested.is-drilldown-submenu { + margin-right: 0; + margin-left: 0; } + +.drilldown .drilldown-submenu-cover-previous { + min-height: 100%; } + +.drilldown .is-drilldown-submenu-parent > a { + position: relative; } + .drilldown .is-drilldown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; + position: absolute; + top: 50%; + margin-top: -6px; + right: 1rem; } + +.drilldown.align-left .is-drilldown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; + right: 1rem; + left: auto; } + +.drilldown.align-right .is-drilldown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + right: auto; + left: 1rem; } + +.drilldown .js-drilldown-back > a::before { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + display: inline-block; + vertical-align: middle; + margin-right: 0.75rem; } + +.dropdown.menu > li.opens-left > .is-dropdown-submenu { + top: 100%; + right: 0; + left: auto; } + +.dropdown.menu > li.opens-right > .is-dropdown-submenu { + top: 100%; + right: auto; + left: 0; } + +.dropdown.menu > li.is-dropdown-submenu-parent > a { + position: relative; + padding-right: 1.5rem; } + +.dropdown.menu > li.is-dropdown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #2D6699 transparent transparent; + right: 5px; + left: auto; + margin-top: -3px; } + +[data-whatinput='mouse'] .dropdown.menu a { + outline: 0; } + +.dropdown.menu > li > a { + padding: 0.7rem 1rem; } + +.dropdown.menu > li.is-active > a { + background: transparent; + color: #2D6699; } + +.no-js .dropdown.menu ul { + display: none; } + +.dropdown.menu .nested.is-dropdown-submenu { + margin-right: 0; + margin-left: 0; } + +.dropdown.menu.vertical > li .is-dropdown-submenu { + top: 0; } + +.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu { + top: 0; + right: 100%; + left: auto; } + +.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu { + right: auto; + left: 100%; } + +.dropdown.menu.vertical > li > a::after { + right: 14px; } + +.dropdown.menu.vertical > li.opens-left > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + right: auto; + left: 5px; } + +.dropdown.menu.vertical > li.opens-right > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; } + +@media print, screen and (min-width: 40em) { + .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu { + top: 100%; + right: 0; + left: auto; } + .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu { + top: 100%; + right: auto; + left: 0; } + .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a { + position: relative; + padding-right: 1.5rem; } + .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #2D6699 transparent transparent; + right: 5px; + left: auto; + margin-top: -3px; } + .dropdown.menu.medium-vertical > li .is-dropdown-submenu { + top: 0; } + .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu { + top: 0; + right: 100%; + left: auto; } + .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu { + right: auto; + left: 100%; } + .dropdown.menu.medium-vertical > li > a::after { + right: 14px; } + .dropdown.menu.medium-vertical > li.opens-left > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + right: auto; + left: 5px; } + .dropdown.menu.medium-vertical > li.opens-right > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; } } + +@media print, screen and (min-width: 64em) { + .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu { + top: 100%; + right: 0; + left: auto; } + .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu { + top: 100%; + right: auto; + left: 0; } + .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a { + position: relative; + padding-right: 1.5rem; } + .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #2D6699 transparent transparent; + right: 5px; + left: auto; + margin-top: -3px; } + .dropdown.menu.large-vertical > li .is-dropdown-submenu { + top: 0; } + .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu { + top: 0; + right: 100%; + left: auto; } + .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu { + right: auto; + left: 100%; } + .dropdown.menu.large-vertical > li > a::after { + right: 14px; } + .dropdown.menu.large-vertical > li.opens-left > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + right: auto; + left: 5px; } + .dropdown.menu.large-vertical > li.opens-right > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; } } + +.dropdown.menu.align-right .is-dropdown-submenu.first-sub { + top: 100%; + right: 0; + left: auto; } + +.is-dropdown-menu.vertical { + width: 100px; } + .is-dropdown-menu.vertical.align-right { + float: right; } + +.is-dropdown-submenu-parent { + position: relative; } + .is-dropdown-submenu-parent a::after { + position: absolute; + top: 50%; + right: 5px; + left: auto; + margin-top: -6px; } + .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu { + top: 100%; + left: auto; } + .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu { + right: 100%; + left: auto; } + .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu { + right: auto; + left: 100%; } + +.is-dropdown-submenu { + position: absolute; + top: 0; + left: 100%; + z-index: 1; + display: none; + min-width: 200px; + border: 1px solid #cacaca; + background: #fefefe; } + .dropdown .is-dropdown-submenu a { + padding: 0.7rem 1rem; } + .is-dropdown-submenu .is-dropdown-submenu-parent > a::after { + right: 14px; } + .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #2D6699 transparent transparent; + right: auto; + left: 5px; } + .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after { + display: block; + width: 0; + height: 0; + border: inset 6px; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #2D6699; } + .is-dropdown-submenu .is-dropdown-submenu { + margin-top: -1px; } + .is-dropdown-submenu > li { + width: 100%; } + .is-dropdown-submenu.js-dropdown-active { + display: block; } + +.is-off-canvas-open { + overflow: hidden; } + +.js-off-canvas-overlay { + position: absolute; + top: 0; + left: 0; + z-index: 11; + width: 100%; + height: 100%; + -webkit-transition: opacity 0.5s ease, visibility 0.5s ease; + transition: opacity 0.5s ease, visibility 0.5s ease; + background: rgba(254, 254, 254, 0.25); + opacity: 0; + visibility: hidden; + overflow: hidden; } + .js-off-canvas-overlay.is-visible { + opacity: 1; + visibility: visible; } + .js-off-canvas-overlay.is-closable { + cursor: pointer; } + .js-off-canvas-overlay.is-overlay-absolute { + position: absolute; } + .js-off-canvas-overlay.is-overlay-fixed { + position: fixed; } + +.off-canvas-wrapper { + position: relative; + overflow: hidden; } + +.off-canvas { + position: fixed; + z-index: 12; + -webkit-transition: -webkit-transform 0.5s ease; + transition: -webkit-transform 0.5s ease; + transition: transform 0.5s ease; + transition: transform 0.5s ease, -webkit-transform 0.5s ease; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; + background: #e6e6e6; } + [data-whatinput='mouse'] .off-canvas { + outline: 0; } + .off-canvas.is-transition-push { + z-index: 12; } + .off-canvas.is-closed { + visibility: hidden; } + .off-canvas.is-transition-overlap { + z-index: 13; } + .off-canvas.is-transition-overlap.is-open { + -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); + box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); } + .off-canvas.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + +.off-canvas-absolute { + position: absolute; + z-index: 12; + -webkit-transition: -webkit-transform 0.5s ease; + transition: -webkit-transform 0.5s ease; + transition: transform 0.5s ease; + transition: transform 0.5s ease, -webkit-transform 0.5s ease; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; + background: #e6e6e6; } + [data-whatinput='mouse'] .off-canvas-absolute { + outline: 0; } + .off-canvas-absolute.is-transition-push { + z-index: 12; } + .off-canvas-absolute.is-closed { + visibility: hidden; } + .off-canvas-absolute.is-transition-overlap { + z-index: 13; } + .off-canvas-absolute.is-transition-overlap.is-open { + -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); + box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); } + .off-canvas-absolute.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + +.position-left { + top: 0; + left: 0; + height: 100%; + overflow-y: auto; + width: 250px; + -webkit-transform: translateX(-250px); + -ms-transform: translateX(-250px); + transform: translateX(-250px); } + .off-canvas-content .off-canvas.position-left { + -webkit-transform: translateX(-250px); + -ms-transform: translateX(-250px); + transform: translateX(-250px); } + .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + .off-canvas-content.is-open-left.has-transition-push { + -webkit-transform: translateX(250px); + -ms-transform: translateX(250px); + transform: translateX(250px); } + .position-left.is-transition-push { + -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); } + +.position-right { + top: 0; + right: 0; + height: 100%; + overflow-y: auto; + width: 250px; + -webkit-transform: translateX(250px); + -ms-transform: translateX(250px); + transform: translateX(250px); } + .off-canvas-content .off-canvas.position-right { + -webkit-transform: translateX(250px); + -ms-transform: translateX(250px); + transform: translateX(250px); } + .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + .off-canvas-content.is-open-right.has-transition-push { + -webkit-transform: translateX(-250px); + -ms-transform: translateX(-250px); + transform: translateX(-250px); } + .position-right.is-transition-push { + -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); } + +.position-top { + top: 0; + left: 0; + width: 100%; + overflow-x: auto; + height: 250px; + -webkit-transform: translateY(-250px); + -ms-transform: translateY(-250px); + transform: translateY(-250px); } + .off-canvas-content .off-canvas.position-top { + -webkit-transform: translateY(-250px); + -ms-transform: translateY(-250px); + transform: translateY(-250px); } + .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + .off-canvas-content.is-open-top.has-transition-push { + -webkit-transform: translateY(250px); + -ms-transform: translateY(250px); + transform: translateY(250px); } + .position-top.is-transition-push { + -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); } + +.position-bottom { + bottom: 0; + left: 0; + width: 100%; + overflow-x: auto; + height: 250px; + -webkit-transform: translateY(250px); + -ms-transform: translateY(250px); + transform: translateY(250px); } + .off-canvas-content .off-canvas.position-bottom { + -webkit-transform: translateY(250px); + -ms-transform: translateY(250px); + transform: translateY(250px); } + .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + .off-canvas-content.is-open-bottom.has-transition-push { + -webkit-transform: translateY(-250px); + -ms-transform: translateY(-250px); + transform: translateY(-250px); } + .position-bottom.is-transition-push { + -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); + box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); } + +.off-canvas-content { + -webkit-transform: none; + -ms-transform: none; + transform: none; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + .off-canvas-content.has-transition-overlap, .off-canvas-content.has-transition-push { + -webkit-transition: -webkit-transform 0.5s ease; + transition: -webkit-transform 0.5s ease; + transition: transform 0.5s ease; + transition: transform 0.5s ease, -webkit-transform 0.5s ease; } + .off-canvas-content.has-transition-push { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + .off-canvas-content .off-canvas.is-open { + -webkit-transform: translate(0, 0); + -ms-transform: translate(0, 0); + transform: translate(0, 0); } + +@media print, screen and (min-width: 40em) { + .position-left.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-left.reveal-for-medium .close-button { + display: none; } + .off-canvas-content .position-left.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-left { + margin-left: 250px; } + .position-left.reveal-for-medium ~ .off-canvas-content { + margin-left: 250px; } + .position-right.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-right.reveal-for-medium .close-button { + display: none; } + .off-canvas-content .position-right.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-right { + margin-right: 250px; } + .position-right.reveal-for-medium ~ .off-canvas-content { + margin-right: 250px; } + .position-top.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-top.reveal-for-medium .close-button { + display: none; } + .off-canvas-content .position-top.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-top { + margin-top: 250px; } + .position-top.reveal-for-medium ~ .off-canvas-content { + margin-top: 250px; } + .position-bottom.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-bottom.reveal-for-medium .close-button { + display: none; } + .off-canvas-content .position-bottom.reveal-for-medium { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-bottom { + margin-bottom: 250px; } + .position-bottom.reveal-for-medium ~ .off-canvas-content { + margin-bottom: 250px; } } + +@media print, screen and (min-width: 64em) { + .position-left.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-left.reveal-for-large .close-button { + display: none; } + .off-canvas-content .position-left.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-left { + margin-left: 250px; } + .position-left.reveal-for-large ~ .off-canvas-content { + margin-left: 250px; } + .position-right.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-right.reveal-for-large .close-button { + display: none; } + .off-canvas-content .position-right.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-right { + margin-right: 250px; } + .position-right.reveal-for-large ~ .off-canvas-content { + margin-right: 250px; } + .position-top.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-top.reveal-for-large .close-button { + display: none; } + .off-canvas-content .position-top.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-top { + margin-top: 250px; } + .position-top.reveal-for-large ~ .off-canvas-content { + margin-top: 250px; } + .position-bottom.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; + z-index: 12; + -webkit-transition: none; + transition: none; + visibility: visible; } + .position-bottom.reveal-for-large .close-button { + display: none; } + .off-canvas-content .position-bottom.reveal-for-large { + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas-content.has-reveal-bottom { + margin-bottom: 250px; } + .position-bottom.reveal-for-large ~ .off-canvas-content { + margin-bottom: 250px; } } + +@media print, screen and (min-width: 40em) { + .off-canvas.in-canvas-for-medium { + visibility: visible; + height: auto; + position: static; + background: none; + width: auto; + overflow: visible; + -webkit-transition: none; + transition: none; } + .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom { + -webkit-box-shadow: none; + box-shadow: none; + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas.in-canvas-for-medium .close-button { + display: none; } } + +@media print, screen and (min-width: 64em) { + .off-canvas.in-canvas-for-large { + visibility: visible; + height: auto; + position: static; + background: none; + width: auto; + overflow: visible; + -webkit-transition: none; + transition: none; } + .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom { + -webkit-box-shadow: none; + box-shadow: none; + -webkit-transform: none; + -ms-transform: none; + transform: none; } + .off-canvas.in-canvas-for-large .close-button { + display: none; } } + +html.is-reveal-open { + position: fixed; + width: 100%; + overflow-y: hidden; } + html.is-reveal-open.zf-has-scroll { + overflow-y: scroll; } + html.is-reveal-open body { + overflow-y: hidden; } + +.reveal-overlay { + position: fixed; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: 1005; + display: none; + background-color: rgba(10, 10, 10, 0.45); + overflow-y: auto; } + +.reveal { + z-index: 1006; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; + display: none; + padding: 1rem; + border: 1px solid #cacaca; + border-radius: 0; + background-color: #fefefe; + position: relative; + top: 100px; + margin-right: auto; + margin-left: auto; + overflow-y: auto; } + [data-whatinput='mouse'] .reveal { + outline: 0; } + @media print, screen and (min-width: 40em) { + .reveal { + min-height: 0; } } + .reveal .column { + min-width: 0; } + .reveal > :last-child { + margin-bottom: 0; } + @media print, screen and (min-width: 40em) { + .reveal { + width: 600px; + max-width: 75rem; } } + .reveal.collapse { + padding: 0; } + @media print, screen and (min-width: 40em) { + .reveal.tiny { + width: 30%; + max-width: 75rem; } } + @media print, screen and (min-width: 40em) { + .reveal.small { + width: 50%; + max-width: 75rem; } } + @media print, screen and (min-width: 40em) { + .reveal.large { + width: 90%; + max-width: 75rem; } } + .reveal.full { + top: 0; + right: 0; + bottom: 0; + left: 0; + width: 100%; + max-width: none; + height: 100%; + min-height: 100%; + margin-left: 0; + border: 0; + border-radius: 0; } + @media print, screen and (max-width: 39.99875em) { + .reveal { + top: 0; + right: 0; + bottom: 0; + left: 0; + width: 100%; + max-width: none; + height: 100%; + min-height: 100%; + margin-left: 0; + border: 0; + border-radius: 0; } } + .reveal.without-overlay { + position: fixed; } + +.sticky-container { + position: relative; } + +.sticky { + position: relative; + z-index: 0; + -webkit-transform: translate3d(0, 0, 0); + transform: translate3d(0, 0, 0); } + +.sticky.is-stuck { + position: fixed; + z-index: 5; + width: 100%; } + .sticky.is-stuck.is-at-top { + top: 0; } + .sticky.is-stuck.is-at-bottom { + bottom: 0; } + +.sticky.is-anchored { + position: relative; + right: auto; + left: auto; } + .sticky.is-anchored.is-at-bottom { + bottom: 0; } + +.title-bar { + padding: 0.5rem; + background: #0a0a0a; + color: #fefefe; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; } + .title-bar .menu-icon { + margin-left: 0.25rem; + margin-right: 0.25rem; } + +.title-bar-left, +.title-bar-right { + -webkit-box-flex: 1; + -webkit-flex: 1 1 0px; + -ms-flex: 1 1 0px; + flex: 1 1 0px; } + +.title-bar-right { + text-align: right; } + +.title-bar-title { + display: inline-block; + vertical-align: middle; + font-weight: bold; } + +.top-bar { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + padding: 0.3rem; + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } + .top-bar, + .top-bar ul { + background-color: #e6e6e6; } + .top-bar input { + max-width: 200px; + margin-right: 1rem; } + .top-bar .input-group-field { + width: 100%; + margin-right: 0; } + .top-bar input.button { + width: auto; } + .top-bar .top-bar-left, + .top-bar .top-bar-right { + -webkit-box-flex: 0; + -webkit-flex: 0 0 100%; + -ms-flex: 0 0 100%; + flex: 0 0 100%; + max-width: 100%; } + @media print, screen and (min-width: 40em) { + .top-bar { + -webkit-flex-wrap: nowrap; + -ms-flex-wrap: nowrap; + flex-wrap: nowrap; } + .top-bar .top-bar-left { + -webkit-box-flex: 1; + -webkit-flex: 1 1 auto; + -ms-flex: 1 1 auto; + flex: 1 1 auto; + margin-right: auto; } + .top-bar .top-bar-right { + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; + margin-left: auto; } } + @media print, screen and (max-width: 63.99875em) { + .top-bar.stacked-for-medium { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } + .top-bar.stacked-for-medium .top-bar-left, + .top-bar.stacked-for-medium .top-bar-right { + -webkit-box-flex: 0; + -webkit-flex: 0 0 100%; + -ms-flex: 0 0 100%; + flex: 0 0 100%; + max-width: 100%; } } + @media print, screen and (max-width: 74.99875em) { + .top-bar.stacked-for-large { + -webkit-flex-wrap: wrap; + -ms-flex-wrap: wrap; + flex-wrap: wrap; } + .top-bar.stacked-for-large .top-bar-left, + .top-bar.stacked-for-large .top-bar-right { + -webkit-box-flex: 0; + -webkit-flex: 0 0 100%; + -ms-flex: 0 0 100%; + flex: 0 0 100%; + max-width: 100%; } } + +.top-bar-title { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; + margin: 0.5rem 1rem 0.5rem 0; } + +.top-bar-left, +.top-bar-right { + -webkit-box-flex: 0; + -webkit-flex: 0 0 auto; + -ms-flex: 0 0 auto; + flex: 0 0 auto; } + +.float-left { + float: left !important; } + +.float-right { + float: right !important; } + +.float-center { + display: block; + margin-right: auto; + margin-left: auto; } + +.clearfix::before, .clearfix::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + +.clearfix::after { + clear: both; } + +.align-left { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + +.align-right { + -webkit-box-pack: end; + -webkit-justify-content: flex-end; + -ms-flex-pack: end; + justify-content: flex-end; } + +.align-center { + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + +.align-justify { + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; } + +.align-spaced { + -webkit-justify-content: space-around; + -ms-flex-pack: distribute; + justify-content: space-around; } + +.align-left.vertical.menu > li > a { + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; } + +.align-right.vertical.menu > li > a { + -webkit-box-pack: end; + -webkit-justify-content: flex-end; + -ms-flex-pack: end; + justify-content: flex-end; } + +.align-center.vertical.menu > li > a { + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + +.align-top { + -webkit-box-align: start; + -webkit-align-items: flex-start; + -ms-flex-align: start; + align-items: flex-start; } + +.align-self-top { + -webkit-align-self: flex-start; + -ms-flex-item-align: start; + align-self: flex-start; } + +.align-bottom { + -webkit-box-align: end; + -webkit-align-items: flex-end; + -ms-flex-align: end; + align-items: flex-end; } + +.align-self-bottom { + -webkit-align-self: flex-end; + -ms-flex-item-align: end; + align-self: flex-end; } + +.align-middle { + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; } + +.align-self-middle { + -webkit-align-self: center; + -ms-flex-item-align: center; + align-self: center; } + +.align-stretch { + -webkit-box-align: stretch; + -webkit-align-items: stretch; + -ms-flex-align: stretch; + align-items: stretch; } + +.align-self-stretch { + -webkit-align-self: stretch; + -ms-flex-item-align: stretch; + align-self: stretch; } + +.align-center-middle { + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + -webkit-align-content: center; + -ms-flex-line-pack: center; + align-content: center; } + +.small-order-1 { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + +.small-order-2 { + -webkit-box-ordinal-group: 3; + -webkit-order: 2; + -ms-flex-order: 2; + order: 2; } + +.small-order-3 { + -webkit-box-ordinal-group: 4; + -webkit-order: 3; + -ms-flex-order: 3; + order: 3; } + +.small-order-4 { + -webkit-box-ordinal-group: 5; + -webkit-order: 4; + -ms-flex-order: 4; + order: 4; } + +.small-order-5 { + -webkit-box-ordinal-group: 6; + -webkit-order: 5; + -ms-flex-order: 5; + order: 5; } + +.small-order-6 { + -webkit-box-ordinal-group: 7; + -webkit-order: 6; + -ms-flex-order: 6; + order: 6; } + +@media print, screen and (min-width: 40em) { + .medium-order-1 { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .medium-order-2 { + -webkit-box-ordinal-group: 3; + -webkit-order: 2; + -ms-flex-order: 2; + order: 2; } + .medium-order-3 { + -webkit-box-ordinal-group: 4; + -webkit-order: 3; + -ms-flex-order: 3; + order: 3; } + .medium-order-4 { + -webkit-box-ordinal-group: 5; + -webkit-order: 4; + -ms-flex-order: 4; + order: 4; } + .medium-order-5 { + -webkit-box-ordinal-group: 6; + -webkit-order: 5; + -ms-flex-order: 5; + order: 5; } + .medium-order-6 { + -webkit-box-ordinal-group: 7; + -webkit-order: 6; + -ms-flex-order: 6; + order: 6; } } + +@media print, screen and (min-width: 64em) { + .large-order-1 { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .large-order-2 { + -webkit-box-ordinal-group: 3; + -webkit-order: 2; + -ms-flex-order: 2; + order: 2; } + .large-order-3 { + -webkit-box-ordinal-group: 4; + -webkit-order: 3; + -ms-flex-order: 3; + order: 3; } + .large-order-4 { + -webkit-box-ordinal-group: 5; + -webkit-order: 4; + -ms-flex-order: 4; + order: 4; } + .large-order-5 { + -webkit-box-ordinal-group: 6; + -webkit-order: 5; + -ms-flex-order: 5; + order: 5; } + .large-order-6 { + -webkit-box-ordinal-group: 7; + -webkit-order: 6; + -ms-flex-order: 6; + order: 6; } } + +.flex-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; } + +.flex-child-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 auto; + -ms-flex: 1 1 auto; + flex: 1 1 auto; } + +.flex-child-grow { + -webkit-box-flex: 1; + -webkit-flex: 1 0 auto; + -ms-flex: 1 0 auto; + flex: 1 0 auto; } + +.flex-child-shrink { + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; } + +.flex-dir-row { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + +.flex-dir-row-reverse { + -webkit-box-orient: horizontal; + -webkit-box-direction: reverse; + -webkit-flex-direction: row-reverse; + -ms-flex-direction: row-reverse; + flex-direction: row-reverse; } + +.flex-dir-column { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + +.flex-dir-column-reverse { + -webkit-box-orient: vertical; + -webkit-box-direction: reverse; + -webkit-flex-direction: column-reverse; + -ms-flex-direction: column-reverse; + flex-direction: column-reverse; } + +@media print, screen and (min-width: 40em) { + .medium-flex-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; } + .medium-flex-child-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 auto; + -ms-flex: 1 1 auto; + flex: 1 1 auto; } + .medium-flex-child-grow { + -webkit-box-flex: 1; + -webkit-flex: 1 0 auto; + -ms-flex: 1 0 auto; + flex: 1 0 auto; } + .medium-flex-child-shrink { + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; } + .medium-flex-dir-row { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + .medium-flex-dir-row-reverse { + -webkit-box-orient: horizontal; + -webkit-box-direction: reverse; + -webkit-flex-direction: row-reverse; + -ms-flex-direction: row-reverse; + flex-direction: row-reverse; } + .medium-flex-dir-column { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + .medium-flex-dir-column-reverse { + -webkit-box-orient: vertical; + -webkit-box-direction: reverse; + -webkit-flex-direction: column-reverse; + -ms-flex-direction: column-reverse; + flex-direction: column-reverse; } } + +@media print, screen and (min-width: 64em) { + .large-flex-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; } + .large-flex-child-auto { + -webkit-box-flex: 1; + -webkit-flex: 1 1 auto; + -ms-flex: 1 1 auto; + flex: 1 1 auto; } + .large-flex-child-grow { + -webkit-box-flex: 1; + -webkit-flex: 1 0 auto; + -ms-flex: 1 0 auto; + flex: 1 0 auto; } + .large-flex-child-shrink { + -webkit-box-flex: 0; + -webkit-flex: 0 1 auto; + -ms-flex: 0 1 auto; + flex: 0 1 auto; } + .large-flex-dir-row { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } + .large-flex-dir-row-reverse { + -webkit-box-orient: horizontal; + -webkit-box-direction: reverse; + -webkit-flex-direction: row-reverse; + -ms-flex-direction: row-reverse; + flex-direction: row-reverse; } + .large-flex-dir-column { + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; } + .large-flex-dir-column-reverse { + -webkit-box-orient: vertical; + -webkit-box-direction: reverse; + -webkit-flex-direction: column-reverse; + -ms-flex-direction: column-reverse; + flex-direction: column-reverse; } } + +.hide { + display: none !important; } + +.invisible { + visibility: hidden; } + +@media print, screen and (max-width: 39.99875em) { + .hide-for-small-only { + display: none !important; } } + +@media screen and (max-width: 0em), screen and (min-width: 40em) { + .show-for-small-only { + display: none !important; } } + +@media print, screen and (min-width: 40em) { + .hide-for-medium { + display: none !important; } } + +@media screen and (max-width: 39.99875em) { + .show-for-medium { + display: none !important; } } + +@media print, screen and (min-width: 40em) and (max-width: 63.99875em) { + .hide-for-medium-only { + display: none !important; } } + +@media screen and (max-width: 39.99875em), screen and (min-width: 64em) { + .show-for-medium-only { + display: none !important; } } + +@media print, screen and (min-width: 64em) { + .hide-for-large { + display: none !important; } } + +@media screen and (max-width: 63.99875em) { + .show-for-large { + display: none !important; } } + +@media print, screen and (min-width: 64em) and (max-width: 74.99875em) { + .hide-for-large-only { + display: none !important; } } + +@media screen and (max-width: 63.99875em), screen and (min-width: 75em) { + .show-for-large-only { + display: none !important; } } + +.show-for-sr, +.show-on-focus { + position: absolute !important; + width: 1px !important; + height: 1px !important; + padding: 0 !important; + overflow: hidden !important; + clip: rect(0, 0, 0, 0) !important; + white-space: nowrap !important; + border: 0 !important; } + +.show-on-focus:active, .show-on-focus:focus { + position: static !important; + width: auto !important; + height: auto !important; + overflow: visible !important; + clip: auto !important; + white-space: normal !important; } + +.show-for-landscape, +.hide-for-portrait { + display: block !important; } + @media screen and (orientation: landscape) { + .show-for-landscape, + .hide-for-portrait { + display: block !important; } } + @media screen and (orientation: portrait) { + .show-for-landscape, + .hide-for-portrait { + display: none !important; } } + +.hide-for-landscape, +.show-for-portrait { + display: none !important; } + @media screen and (orientation: landscape) { + .hide-for-landscape, + .show-for-portrait { + display: none !important; } } + @media screen and (orientation: portrait) { + .hide-for-landscape, + .show-for-portrait { + display: block !important; } } + +.text-hide { + font: 0/0 a !important; + color: transparent !important; + text-shadow: none !important; + background-color: transparent !important; + border: 0 !important; } + +.text-truncate { + max-width: 100% !important; + overflow: hidden !important; + text-overflow: ellipsis; + white-space: nowrap !important; } + +.text-nowrap { + white-space: nowrap !important; } + +.text-wrap { + word-wrap: break-word !important; } + +.text-lowercase { + text-transform: lowercase !important; } + +.text-uppercase { + text-transform: uppercase !important; } + +.text-capitalize { + text-transform: capitalize !important; } + +.text-overline { + text-decoration: overline !important; } + +.text-underline { + text-decoration: underline !important; } + +.text-line-through { + text-decoration: line-through !important; } + +.font-wide { + letter-spacing: 0.25rem; } + +.font-normal { + font-weight: normal; } + +.font-bold { + font-weight: bold; } + +.font-italic { + font-style: italic !important; } + +ul.list-disc { + list-style-type: disc !important; } + +ul.list-circle { + list-style-type: circle !important; } + +ul.list-square { + list-style-type: square !important; } + +ol.list-decimal { + list-style-type: decimal !important; } + +ol.list-lower-alpha { + list-style-type: lower-alpha !important; } + +ol.list-lower-latin { + list-style-type: lower-latin !important; } + +ol.list-lower-roman { + list-style-type: lower-roman !important; } + +ol.list-upper-alpha { + list-style-type: upper-alpha !important; } + +ol.list-upper-latin { + list-style-type: upper-latin !important; } + +ol.list-upper-roman { + list-style-type: upper-roman !important; } + +.rounded { + border-radius: 5000px !important; } + .rounded .switch-paddle { + border-radius: 5000px !important; } + .rounded .switch-paddle:after { + border-radius: 50%; } + +.radius { + border-radius: 0.1875rem; } + +.bordered { + border: 0.0625rem solid #cacaca; } + +.shadow { + -webkit-box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12); + box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12); } + +.arrow-down { + display: block; + width: 0; + height: 0; + border: inset 0.4375rem; + content: ''; + border-bottom-width: 0; + border-top-style: solid; + border-color: #0a0a0a transparent transparent; } + +.arrow-up { + display: block; + width: 0; + height: 0; + border: inset 0.4375rem; + content: ''; + border-top-width: 0; + border-bottom-style: solid; + border-color: transparent transparent #0a0a0a; } + +.arrow-right { + display: block; + width: 0; + height: 0; + border: inset 0.4375rem; + content: ''; + border-right-width: 0; + border-left-style: solid; + border-color: transparent transparent transparent #0a0a0a; } + +.arrow-left { + display: block; + width: 0; + height: 0; + border: inset 0.4375rem; + content: ''; + border-left-width: 0; + border-right-style: solid; + border-color: transparent #0a0a0a transparent transparent; } + +.separator-center { + text-align: center !important; } + .separator-center::before, .separator-center::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .separator-center::after { + clear: both; } + .separator-center::after { + position: relative !important; + width: 3rem; + border-bottom: 0.125rem solid #2D6699; + margin: 1rem auto 0; } + +.separator-left { + text-align: left !important; } + .separator-left::before, .separator-left::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .separator-left::after { + clear: both; } + .separator-left::after { + position: relative !important; + width: 3rem; + border-bottom: 0.125rem solid #2D6699; + margin: 1rem auto 0; + margin-left: 0 !important; } + +.separator-right { + text-align: right !important; } + .separator-right::before, .separator-right::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .separator-right::after { + clear: both; } + .separator-right::after { + position: relative !important; + width: 3rem; + border-bottom: 0.125rem solid #2D6699; + margin: 1rem auto 0; + margin-right: 0 !important; } + +.overflow-visible { + overflow: visible !important; } + +.overflow-x-visible { + overflow-x: visible !important; } + +.overflow-y-visible { + overflow-y: visible !important; } + +.overflow-hidden { + overflow: hidden !important; } + +.overflow-x-hidden { + overflow-x: hidden !important; } + +.overflow-y-hidden { + overflow-y: hidden !important; } + +.overflow-scroll { + overflow: scroll !important; } + +.overflow-x-scroll { + overflow-x: scroll !important; } + +.overflow-y-scroll { + overflow-y: scroll !important; } + +.display-inline { + display: inline !important; } + +.display-inline-block { + display: inline-block !important; } + +.display-block { + display: block !important; } + +.display-table { + display: table !important; } + +.display-table-cell { + display: table-cell !important; } + +.position-static { + position: static !important; } + +.position-relative { + position: relative !important; } + +.position-absolute { + position: absolute !important; } + +.position-fixed { + position: fixed !important; } + +.position-fixed-top { + position: fixed !important; + top: 0rem !important; + right: 0rem !important; + left: 0rem !important; + z-index: 975; } + +.position-fixed-bottom { + position: fixed !important; + right: 0rem !important; + bottom: 0rem !important; + left: 0rem !important; + z-index: 975; } + +.border-box { + -webkit-box-sizing: border-box !important; + box-sizing: border-box !important; } + +.border-none { + border: none !important; } + +.width-25 { + width: 25% !important; } + +.width-50 { + width: 50% !important; } + +.width-75 { + width: 75% !important; } + +.width-100 { + width: 100% !important; } + +.height-25 { + height: 25% !important; } + +.height-50 { + height: 50% !important; } + +.height-75 { + height: 75% !important; } + +.height-100 { + height: 100% !important; } + +.max-width-100 { + max-width: 100% !important; } + +.max-height-100 { + max-height: 100% !important; } + +.margin-0 { + margin: 0rem !important; } + +.margin-top-0 { + margin-top: 0rem !important; } + +.margin-right-0 { + margin-right: 0rem !important; } + +.margin-bottom-0 { + margin-bottom: 0rem !important; } + +.margin-left-0 { + margin-left: 0rem !important; } + +.margin-horizontal-0 { + margin-right: 0rem !important; + margin-left: 0rem !important; } + +.margin-vertical-0 { + margin-top: 0rem !important; + margin-bottom: 0rem !important; } + +.padding-0 { + padding: 0rem !important; } + +.padding-top-0 { + padding-top: 0rem !important; } + +.padding-right-0 { + padding-right: 0rem !important; } + +.padding-bottom-0 { + padding-bottom: 0rem !important; } + +.padding-left-0 { + padding-left: 0rem !important; } + +.padding-horizontal-0 { + padding-right: 0rem !important; + padding-left: 0rem !important; } + +.padding-vertical-0 { + padding-top: 0rem !important; + padding-bottom: 0rem !important; } + +.margin-1 { + margin: 1rem !important; } + +.margin-top-1 { + margin-top: 1rem !important; } + +.margin-right-1 { + margin-right: 1rem !important; } + +.margin-bottom-1 { + margin-bottom: 1rem !important; } + +.margin-left-1 { + margin-left: 1rem !important; } + +.margin-horizontal-1 { + margin-right: 1rem !important; + margin-left: 1rem !important; } + +.margin-vertical-1 { + margin-top: 1rem !important; + margin-bottom: 1rem !important; } + +.padding-1 { + padding: 1rem !important; } + +.padding-top-1 { + padding-top: 1rem !important; } + +.padding-right-1 { + padding-right: 1rem !important; } + +.padding-bottom-1 { + padding-bottom: 1rem !important; } + +.padding-left-1 { + padding-left: 1rem !important; } + +.padding-horizontal-1 { + padding-right: 1rem !important; + padding-left: 1rem !important; } + +.padding-vertical-1 { + padding-top: 1rem !important; + padding-bottom: 1rem !important; } + +.margin-2 { + margin: 2rem !important; } + +.margin-top-2 { + margin-top: 2rem !important; } + +.margin-right-2 { + margin-right: 2rem !important; } + +.margin-bottom-2 { + margin-bottom: 2rem !important; } + +.margin-left-2 { + margin-left: 2rem !important; } + +.margin-horizontal-2 { + margin-right: 2rem !important; + margin-left: 2rem !important; } + +.margin-vertical-2 { + margin-top: 2rem !important; + margin-bottom: 2rem !important; } + +.padding-2 { + padding: 2rem !important; } + +.padding-top-2 { + padding-top: 2rem !important; } + +.padding-right-2 { + padding-right: 2rem !important; } + +.padding-bottom-2 { + padding-bottom: 2rem !important; } + +.padding-left-2 { + padding-left: 2rem !important; } + +.padding-horizontal-2 { + padding-right: 2rem !important; + padding-left: 2rem !important; } + +.padding-vertical-2 { + padding-top: 2rem !important; + padding-bottom: 2rem !important; } + +.margin-3 { + margin: 3rem !important; } + +.margin-top-3 { + margin-top: 3rem !important; } + +.margin-right-3 { + margin-right: 3rem !important; } + +.margin-bottom-3 { + margin-bottom: 3rem !important; } + +.margin-left-3 { + margin-left: 3rem !important; } + +.margin-horizontal-3 { + margin-right: 3rem !important; + margin-left: 3rem !important; } + +.margin-vertical-3 { + margin-top: 3rem !important; + margin-bottom: 3rem !important; } + +.padding-3 { + padding: 3rem !important; } + +.padding-top-3 { + padding-top: 3rem !important; } + +.padding-right-3 { + padding-right: 3rem !important; } + +.padding-bottom-3 { + padding-bottom: 3rem !important; } + +.padding-left-3 { + padding-left: 3rem !important; } + +.padding-horizontal-3 { + padding-right: 3rem !important; + padding-left: 3rem !important; } + +.padding-vertical-3 { + padding-top: 3rem !important; + padding-bottom: 3rem !important; } + +.slide-in-down.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateY(-100%); + -ms-transform: translateY(-100%); + transform: translateY(-100%); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-in-down.mui-enter.mui-enter-active { + -webkit-transform: translateY(0); + -ms-transform: translateY(0); + transform: translateY(0); } + +.slide-in-left.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateX(-100%); + -ms-transform: translateX(-100%); + transform: translateX(-100%); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-in-left.mui-enter.mui-enter-active { + -webkit-transform: translateX(0); + -ms-transform: translateX(0); + transform: translateX(0); } + +.slide-in-up.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateY(100%); + -ms-transform: translateY(100%); + transform: translateY(100%); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-in-up.mui-enter.mui-enter-active { + -webkit-transform: translateY(0); + -ms-transform: translateY(0); + transform: translateY(0); } + +.slide-in-right.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateX(100%); + -ms-transform: translateX(100%); + transform: translateX(100%); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-in-right.mui-enter.mui-enter-active { + -webkit-transform: translateX(0); + -ms-transform: translateX(0); + transform: translateX(0); } + +.slide-out-down.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateY(0); + -ms-transform: translateY(0); + transform: translateY(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-out-down.mui-leave.mui-leave-active { + -webkit-transform: translateY(100%); + -ms-transform: translateY(100%); + transform: translateY(100%); } + +.slide-out-right.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateX(0); + -ms-transform: translateX(0); + transform: translateX(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-out-right.mui-leave.mui-leave-active { + -webkit-transform: translateX(100%); + -ms-transform: translateX(100%); + transform: translateX(100%); } + +.slide-out-up.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateY(0); + -ms-transform: translateY(0); + transform: translateY(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-out-up.mui-leave.mui-leave-active { + -webkit-transform: translateY(-100%); + -ms-transform: translateY(-100%); + transform: translateY(-100%); } + +.slide-out-left.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: translateX(0); + -ms-transform: translateX(0); + transform: translateX(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + -webkit-backface-visibility: hidden; + backface-visibility: hidden; } + +.slide-out-left.mui-leave.mui-leave-active { + -webkit-transform: translateX(-100%); + -ms-transform: translateX(-100%); + transform: translateX(-100%); } + +.fade-in.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + opacity: 0; + -webkit-transition-property: opacity; + transition-property: opacity; } + +.fade-in.mui-enter.mui-enter-active { + opacity: 1; } + +.fade-out.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + opacity: 1; + -webkit-transition-property: opacity; + transition-property: opacity; } + +.fade-out.mui-leave.mui-leave-active { + opacity: 0; } + +.hinge-in-from-top.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateX(-90deg); + transform: perspective(2000px) rotateX(-90deg); + -webkit-transform-origin: top; + -ms-transform-origin: top; + transform-origin: top; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-top.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-in-from-right.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateY(-90deg); + transform: perspective(2000px) rotateY(-90deg); + -webkit-transform-origin: right; + -ms-transform-origin: right; + transform-origin: right; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-right.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-in-from-bottom.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateX(90deg); + transform: perspective(2000px) rotateX(90deg); + -webkit-transform-origin: bottom; + -ms-transform-origin: bottom; + transform-origin: bottom; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-bottom.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-in-from-left.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateY(90deg); + transform: perspective(2000px) rotateY(90deg); + -webkit-transform-origin: left; + -ms-transform-origin: left; + transform-origin: left; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-left.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-in-from-middle-x.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateX(-90deg); + transform: perspective(2000px) rotateX(-90deg); + -webkit-transform-origin: center; + -ms-transform-origin: center; + transform-origin: center; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-middle-x.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-in-from-middle-y.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotateY(-90deg); + transform: perspective(2000px) rotateY(-90deg); + -webkit-transform-origin: center; + -ms-transform-origin: center; + transform-origin: center; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.hinge-in-from-middle-y.mui-enter.mui-enter-active { + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + opacity: 1; } + +.hinge-out-from-top.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: top; + -ms-transform-origin: top; + transform-origin: top; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-top.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateX(90deg); + transform: perspective(2000px) rotateX(90deg); + opacity: 0; } + +.hinge-out-from-right.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: right; + -ms-transform-origin: right; + transform-origin: right; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-right.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateY(90deg); + transform: perspective(2000px) rotateY(90deg); + opacity: 0; } + +.hinge-out-from-bottom.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: bottom; + -ms-transform-origin: bottom; + transform-origin: bottom; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-bottom.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateX(-90deg); + transform: perspective(2000px) rotateX(-90deg); + opacity: 0; } + +.hinge-out-from-left.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: left; + -ms-transform-origin: left; + transform-origin: left; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-left.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateY(-90deg); + transform: perspective(2000px) rotateY(-90deg); + opacity: 0; } + +.hinge-out-from-middle-x.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: center; + -ms-transform-origin: center; + transform-origin: center; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-middle-x.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateX(90deg); + transform: perspective(2000px) rotateX(90deg); + opacity: 0; } + +.hinge-out-from-middle-y.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: perspective(2000px) rotate(0deg); + transform: perspective(2000px) rotate(0deg); + -webkit-transform-origin: center; + -ms-transform-origin: center; + transform-origin: center; + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.hinge-out-from-middle-y.mui-leave.mui-leave-active { + -webkit-transform: perspective(2000px) rotateY(90deg); + transform: perspective(2000px) rotateY(90deg); + opacity: 0; } + +.scale-in-up.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: scale(0.5); + -ms-transform: scale(0.5); + transform: scale(0.5); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.scale-in-up.mui-enter.mui-enter-active { + -webkit-transform: scale(1); + -ms-transform: scale(1); + transform: scale(1); + opacity: 1; } + +.scale-in-down.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: scale(1.5); + -ms-transform: scale(1.5); + transform: scale(1.5); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.scale-in-down.mui-enter.mui-enter-active { + -webkit-transform: scale(1); + -ms-transform: scale(1); + transform: scale(1); + opacity: 1; } + +.scale-out-up.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: scale(1); + -ms-transform: scale(1); + transform: scale(1); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.scale-out-up.mui-leave.mui-leave-active { + -webkit-transform: scale(1.5); + -ms-transform: scale(1.5); + transform: scale(1.5); + opacity: 0; } + +.scale-out-down.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: scale(1); + -ms-transform: scale(1); + transform: scale(1); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.scale-out-down.mui-leave.mui-leave-active { + -webkit-transform: scale(0.5); + -ms-transform: scale(0.5); + transform: scale(0.5); + opacity: 0; } + +.spin-in.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: rotate(-0.75turn); + -ms-transform: rotate(-0.75turn); + transform: rotate(-0.75turn); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.spin-in.mui-enter.mui-enter-active { + -webkit-transform: rotate(0); + -ms-transform: rotate(0); + transform: rotate(0); + opacity: 1; } + +.spin-out.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: rotate(0); + -ms-transform: rotate(0); + transform: rotate(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.spin-out.mui-leave.mui-leave-active { + -webkit-transform: rotate(0.75turn); + -ms-transform: rotate(0.75turn); + transform: rotate(0.75turn); + opacity: 0; } + +.spin-in-ccw.mui-enter { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: rotate(0.75turn); + -ms-transform: rotate(0.75turn); + transform: rotate(0.75turn); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 0; } + +.spin-in-ccw.mui-enter.mui-enter-active { + -webkit-transform: rotate(0); + -ms-transform: rotate(0); + transform: rotate(0); + opacity: 1; } + +.spin-out-ccw.mui-leave { + -webkit-transition-duration: 500ms; + transition-duration: 500ms; + -webkit-transition-timing-function: linear; + transition-timing-function: linear; + -webkit-transform: rotate(0); + -ms-transform: rotate(0); + transform: rotate(0); + -webkit-transition-property: opacity, -webkit-transform; + transition-property: opacity, -webkit-transform; + transition-property: transform, opacity; + transition-property: transform, opacity, -webkit-transform; + opacity: 1; } + +.spin-out-ccw.mui-leave.mui-leave-active { + -webkit-transform: rotate(-0.75turn); + -ms-transform: rotate(-0.75turn); + transform: rotate(-0.75turn); + opacity: 0; } + +.slow { + -webkit-transition-duration: 750ms !important; + transition-duration: 750ms !important; } + +.fast { + -webkit-transition-duration: 250ms !important; + transition-duration: 250ms !important; } + +.linear { + -webkit-transition-timing-function: linear !important; + transition-timing-function: linear !important; } + +.ease { + -webkit-transition-timing-function: ease !important; + transition-timing-function: ease !important; } + +.ease-in { + -webkit-transition-timing-function: ease-in !important; + transition-timing-function: ease-in !important; } + +.ease-out { + -webkit-transition-timing-function: ease-out !important; + transition-timing-function: ease-out !important; } + +.ease-in-out { + -webkit-transition-timing-function: ease-in-out !important; + transition-timing-function: ease-in-out !important; } + +.bounce-in { + -webkit-transition-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; + transition-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; } + +.bounce-out { + -webkit-transition-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; + transition-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; } + +.bounce-in-out { + -webkit-transition-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; + transition-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; } + +.short-delay { + -webkit-transition-delay: 300ms !important; + transition-delay: 300ms !important; } + +.long-delay { + -webkit-transition-delay: 700ms !important; + transition-delay: 700ms !important; } + +.shake { + -webkit-animation-name: shake-7; + animation-name: shake-7; } + +@-webkit-keyframes shake-7 { + 0%, 10%, 20%, 30%, 40%, 50%, 60%, 70%, 80%, 90% { + -webkit-transform: translateX(7%); + transform: translateX(7%); } + 5%, 15%, 25%, 35%, 45%, 55%, 65%, 75%, 85%, 95% { + -webkit-transform: translateX(-7%); + transform: translateX(-7%); } } + +@keyframes shake-7 { + 0%, 10%, 20%, 30%, 40%, 50%, 60%, 70%, 80%, 90% { + -webkit-transform: translateX(7%); + transform: translateX(7%); } + 5%, 15%, 25%, 35%, 45%, 55%, 65%, 75%, 85%, 95% { + -webkit-transform: translateX(-7%); + transform: translateX(-7%); } } + +.spin-cw { + -webkit-animation-name: spin-cw-1turn; + animation-name: spin-cw-1turn; } + +@-webkit-keyframes spin-cw-1turn { + 0% { + -webkit-transform: rotate(-1turn); + transform: rotate(-1turn); } + 100% { + -webkit-transform: rotate(0); + transform: rotate(0); } } + +@keyframes spin-cw-1turn { + 0% { + -webkit-transform: rotate(-1turn); + transform: rotate(-1turn); } + 100% { + -webkit-transform: rotate(0); + transform: rotate(0); } } + +.spin-ccw { + -webkit-animation-name: spin-ccw-1turn; + animation-name: spin-ccw-1turn; } + +@-webkit-keyframes spin-ccw-1turn { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); } + 100% { + -webkit-transform: rotate(-1turn); + transform: rotate(-1turn); } } + +@keyframes spin-ccw-1turn { + 0% { + -webkit-transform: rotate(0); + transform: rotate(0); } + 100% { + -webkit-transform: rotate(-1turn); + transform: rotate(-1turn); } } + +.wiggle { + -webkit-animation-name: wiggle-7deg; + animation-name: wiggle-7deg; } + +@-webkit-keyframes wiggle-7deg { + 40%, 50%, 60% { + -webkit-transform: rotate(7deg); + transform: rotate(7deg); } + 35%, 45%, 55%, 65% { + -webkit-transform: rotate(-7deg); + transform: rotate(-7deg); } + 0%, 30%, 70%, 100% { + -webkit-transform: rotate(0); + transform: rotate(0); } } + +@keyframes wiggle-7deg { + 40%, 50%, 60% { + -webkit-transform: rotate(7deg); + transform: rotate(7deg); } + 35%, 45%, 55%, 65% { + -webkit-transform: rotate(-7deg); + transform: rotate(-7deg); } + 0%, 30%, 70%, 100% { + -webkit-transform: rotate(0); + transform: rotate(0); } } + +.shake, +.spin-cw, +.spin-ccw, +.wiggle { + -webkit-animation-duration: 500ms; + animation-duration: 500ms; } + +.infinite { + -webkit-animation-iteration-count: infinite; + animation-iteration-count: infinite; } + +.slow { + -webkit-animation-duration: 750ms !important; + animation-duration: 750ms !important; } + +.fast { + -webkit-animation-duration: 250ms !important; + animation-duration: 250ms !important; } + +.linear { + -webkit-animation-timing-function: linear !important; + animation-timing-function: linear !important; } + +.ease { + -webkit-animation-timing-function: ease !important; + animation-timing-function: ease !important; } + +.ease-in { + -webkit-animation-timing-function: ease-in !important; + animation-timing-function: ease-in !important; } + +.ease-out { + -webkit-animation-timing-function: ease-out !important; + animation-timing-function: ease-out !important; } + +.ease-in-out { + -webkit-animation-timing-function: ease-in-out !important; + animation-timing-function: ease-in-out !important; } + +.bounce-in { + -webkit-animation-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; + animation-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; } + +.bounce-out { + -webkit-animation-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; + animation-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; } + +.bounce-in-out { + -webkit-animation-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; + animation-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; } + +.short-delay { + -webkit-animation-delay: 300ms !important; + animation-delay: 300ms !important; } + +.long-delay { + -webkit-animation-delay: 700ms !important; + animation-delay: 700ms !important; } + +div.card { + border-radius: 5px; + overflow: hidden !important; } + +div.responsive-side-box { + background: #fefefe; + padding-top: 1rem !important; + padding-right: 0rem !important; + padding-bottom: 0rem !important; + padding-left: 0rem !important; } + @media print, screen and (min-width: 40em) { + div.responsive-side-box { + padding-top: 1rem !important; + padding-right: 1rem !important; + padding-bottom: 1rem !important; + padding-left: 1rem !important; } } + @media print, screen and (min-width: 64em) { + div.responsive-side-box { + padding-top: 2rem !important; + padding-right: 2rem !important; + padding-bottom: 2rem !important; + padding-left: 2rem !important; } } + +div.media-object-section > h1, .h1 { + font-size: 1.3125rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.media-object-section > h2, .h2 { + font-size: 1.25rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.media-object-section > h3, .h3 { + font-size: 1.1875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.media-object-section > h4, .h4 { + font-size: 1.125rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.media-object-section > h5, .h5 { + font-size: 1.0625rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.media-object-section > h6, .h6 { + font-size: 1rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +@media print, screen and (min-width: 40em) { + div.media-object-section > h1, .h1 { + font-size: 1rem; } + div.media-object-section > h2, .h2 { + font-size: 0.9375rem; } + div.media-object-section > h3, .h3 { + font-size: 0.875rem; } + div.media-object-section > h4, .h4 { + font-size: 0.875rem; } + div.media-object-section > h5, .h5 { + font-size: 0.875rem; } + div.media-object-section > h6, .h6 { + font-size: 0.875rem; } } + +div.article-row-content > h1, .h1 { + font-weight: bold; + font-size: 1rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.article-row-content > h2, .h2 { + font-weight: bold; + font-size: 0.9375rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.article-row-content > h3, .h3 { + font-weight: bold; + font-size: 0.875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.article-row-content > h4, .h4 { + font-weight: bold; + font-size: 0.875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.article-row-content > h5, .h5 { + font-weight: bold; + font-size: 0.875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.article-row-content > h6, .h6 { + font-weight: bold; + font-size: 0.875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +@media print, screen and (min-width: 40em) { + div.article-row-content > h1, .h1 { + font-weight: bold; + font-size: 1rem; } + div.article-row-content > h2, .h2 { + font-weight: bold; + font-size: 0.9375rem; } + div.article-row-content > h3, .h3 { + font-weight: bold; + font-size: 0.875rem; } + div.article-row-content > h4, .h4 { + font-weight: bold; + font-size: 0.875rem; } + div.article-row-content > h5, .h5 { + font-weight: bold; + font-size: 0.875rem; } + div.article-row-content > h6, .h6 { + font-weight: bold; + font-size: 0.875rem; } } + +.news-hero { + border-radius: 5px; + margin-top: 1rem !important; + margin-bottom: 1rem !important; + height: 30vh; } + @media print, screen and (min-width: 40em) { + .news-hero { + height: 40vh; } } + @media print, screen and (min-width: 64em) { + .news-hero { + height: 50vh; } } + +.news-hero-large { + height: 100%; + min-height: 35vh; } + @media print, screen and (min-width: 40em) { + .news-hero-large { + min-height: 70vh 0.7; } } + @media print, screen and (min-width: 64em) { + .news-hero-large { + min-height: 70vh; } } + +.news-hero, .news-hero-large { + background: url("https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg") 50% no-repeat; + background-color: #444; + position: relative; + background-size: cover; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; + vertical-align: middle; + text-align: left; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + width: 100%; } + .news-hero .news-hero-text, .news-hero-large .news-hero-text { + position: absolute; + bottom: 15%; + left: 5%; + color: #fefefe; + text-shadow: 1px 1px 2px #0a0a0a; } + @media print, screen and (min-width: 40em) { + .news-hero .news-hero-text, .news-hero-large .news-hero-text { + left: 10%; } } + @media print, screen and (min-width: 64em) { + .news-hero .news-hero-text, .news-hero-large .news-hero-text { + left: 20%; } } + +div.news-hero-text > .article-title > h1, .h1 { + font-weight: bold; + font-size: 1.3125rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.news-hero-text > .article-title > h2, .h2 { + font-weight: bold; + font-size: 1.25rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.news-hero-text > .article-title > h3, .h3 { + font-weight: bold; + font-size: 1.1875rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.news-hero-text > .article-title > h4, .h4 { + font-weight: bold; + font-size: 1.125rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.news-hero-text > .article-title > h5, .h5 { + font-weight: bold; + font-size: 1.0625rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +div.news-hero-text > .article-title > h6, .h6 { + font-weight: bold; + font-size: 1rem; + line-height: 1.4; + margin-top: 0; + margin-bottom: 0.5rem; } + +@media print, screen and (min-width: 40em) { + div.news-hero-text > .article-title > h1, .h1 { + font-weight: bold; + font-size: 1.5rem; } + div.news-hero-text > .article-title > h2, .h2 { + font-weight: bold; + font-size: 1.375rem; } + div.news-hero-text > .article-title > h3, .h3 { + font-weight: bold; + font-size: 1.3125rem; } + div.news-hero-text > .article-title > h4, .h4 { + font-weight: bold; + font-size: 1.125rem; } + div.news-hero-text > .article-title > h5, .h5 { + font-weight: bold; + font-size: 1rem; } + div.news-hero-text > .article-title > h6, .h6 { + font-weight: bold; + font-size: 0.9375rem; } } + +.date-box { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-pack: start; + -webkit-justify-content: flex-start; + -ms-flex-pack: start; + justify-content: flex-start; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + height: 71px; + background-color: #FFF; + padding-top: 0rem !important; + padding-right: 0rem !important; + padding-bottom: 0rem !important; + padding-left: 1rem !important; + margin-top: 0rem !important; + margin-right: 0rem !important; + margin-bottom: 1rem !important; + margin-left: 0rem !important; } + .date-box .date-badge { + width: 41px; + height: 41px; + padding-top: 8px; } + .date-box .date-badge .date-badge-day { + font-size: 20px; + line-height: 1em; + font-weight: bold; } + .date-box .date-badge .date-badge-month { + font-size: 12px; + position: relative; + top: -7px; } + .date-box .date-text { + margin-top: 0rem !important; + margin-right: 0rem !important; + margin-bottom: 0rem !important; + margin-left: 1rem !important; } + +.news-card-tag { + margin-bottom: 0.5rem; } + .news-card-tag .label { + border-radius: 0.125rem; + background-color: #2D6699; + color: #fefefe; } + .news-card-tag .label a { + background-color: inherit; + color: inherit; } + .news-card-tag .label:hover, .news-card-tag .label:focus { + background-color: #265782; } + .news-card-tag .label:hover a, .news-card-tag .label:focus a { + background-color: inherit; + color: inherit; } + +.news-card { + background-color: #fefefe; + font-weight: 400; + margin-bottom: 1.6rem; + border-radius: 0.125rem; + -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24); + box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24); } + .news-card .card-section { + background-color: inherit; } + .news-card .card-section .news-card-date { + font-size: 1em; + color: #8a8a8a; } + .news-card .card-section .news-card-article { + background-color: inherit; } + .news-card .card-section .news-card-article .news-card-title { + line-height: 1.3; + font-weight: bold; } + .news-card .card-section .news-card-article .news-card-title a { + text-decoration: none; + color: #8a8a8a; + -webkit-transition: color 0.5s ease; + transition: color 0.5s ease; } + .news-card .card-section .news-card-article .news-card-title a:hover { + color: #2D6699; } + .news-card .card-section .news-card-article .news-card-description { + color: #8a8a8a; } + .news-card .card-section .news-card-author { + overflow: hidden; + padding-bottom: 1.6rem; } + .news-card .card-section .news-card-author .news-card-author-image { + display: inline-block; + vertical-align: middle; } + .news-card .card-section .news-card-author .news-card-author-image img { + border-radius: 50%; + margin-right: 0.6em; } + .news-card .card-section .news-card-author .news-card-author-name { + display: inline-block; + vertical-align: middle; } + +/*! CSS for Responsive Hidden Nav */ +.responsive-hidden-nav-container { + min-width: 240px; + background: #2D6699; + padding: .5rem 1rem; + height: 80vh; } + +.responsive-hidden-nav { + margin: 0; + padding: 0; + background-color: #fefefe; + position: relative; + min-width: 240px; + background: #fefefe; } + .responsive-hidden-nav a { + display: block; + padding: 1.25rem 2rem; + background: #fefefe; + font-size: 1.1em; + color: #2D6699; + text-decoration: none; } + .responsive-hidden-nav a:hover { + color: #16314a; } + .responsive-hidden-nav button { + position: absolute; + height: 100%; + right: 0; + padding: 0 1rem; + border: 0; + outline: none; + background-color: #214c72; + color: #fefefe; + cursor: pointer; } + .responsive-hidden-nav button:hover { + background-color: #16314a; } + .responsive-hidden-nav button::after { + content: attr(count); + position: absolute; + width: 2rem; + height: 2rem; + left: -1rem; + top: .75rem; + text-align: center; + background-color: #16314a; + color: #fefefe; + font-size: .9em; + line-height: 1.6; + border-radius: 50%; + border: 0.25rem solid #fefefe; + font-weight: bold; } + .responsive-hidden-nav button:hover::after { + -webkit-transform: scale(1.075); + -ms-transform: scale(1.075); + transform: scale(1.075); } + .responsive-hidden-nav .hamburger { + position: relative; + display: inline-block; + vertical-align: middle; + width: 20px; + height: 16px; + cursor: pointer; } + .responsive-hidden-nav .hamburger::after { + position: absolute; + top: 0; + left: 0; + display: block; + width: 100%; + height: 2px; + background: #fefefe; + -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + content: ''; } + .responsive-hidden-nav .hamburger:hover::after { + background: #fefefe; + -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; + box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; } + .responsive-hidden-nav .visible-links { + display: inline-table; + margin: 0; + padding: 0; } + .responsive-hidden-nav .visible-links li { + display: table-cell; + border-left: 1px solid #2D6699; } + .responsive-hidden-nav .visible-links li:first-child { + font-weight: bold; } + .responsive-hidden-nav .visible-links li:first-child a { + color: #2D6699 !important; } + .responsive-hidden-nav .hidden-links { + position: absolute; + right: 0; + top: 100%; + margin: 0; + padding: 0; } + .responsive-hidden-nav .hidden-links li { + display: block; + border-top: 0.0625rem solid #214c72; } + .responsive-hidden-nav .hidden { + visibility: hidden; } + +.topbar-responsive { + background: #2c3840; + padding: 1rem 1.5rem; } + .topbar-responsive .topbar-responsive-logo { + color: #fefefe; + vertical-align: middle; } + .topbar-responsive .menu { + background: #2c3840; } + .topbar-responsive .menu li:last-of-type { + margin-right: 0; } + .topbar-responsive .menu a { + color: #fefefe; + -webkit-transition: color 0.15s ease-in; + transition: color 0.15s ease-in; } + .topbar-responsive .menu a:hover { + color: #c6d1d8; } + @media screen and (max-width: 39.9375em) { + .topbar-responsive .menu a { + padding: 0.875rem 0; } } + .topbar-responsive .menu .topbar-responsive-button { + color: #fefefe; + border-color: #fefefe; + border-radius: 5000px; + -webkit-transition: color 0.15s ease-in, border-color 0.15s ease-in; + transition: color 0.15s ease-in, border-color 0.15s ease-in; } + .topbar-responsive .menu .topbar-responsive-button:hover { + color: #c6d1d8; + border-color: #c6d1d8; } + @media screen and (max-width: 39.9375em) { + .topbar-responsive .menu .topbar-responsive-button { + width: 100%; + margin: 0.875rem 0; } } + @media screen and (max-width: 39.9375em) { + .topbar-responsive { + padding: 0.75rem; } + .topbar-responsive .top-bar-title { + position: relative; + width: 100%; } + .topbar-responsive .top-bar-title span { + position: absolute; + right: 0; + border: 1px solid #fefefe; + border-radius: 5px; + padding: 0.25rem 0.45rem; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); } + .topbar-responsive .top-bar-title span .menu-icon { + margin-bottom: 4px; } } + +@-webkit-keyframes fadeIn { + from { + opacity: 0; } + to { + opacity: 1; } } + +@keyframes fadeIn { + from { + opacity: 0; } + to { + opacity: 1; } } + +@-webkit-keyframes slideDown { + 0% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); } + 100% { + -webkit-transform: translateY(0%); + transform: translateY(0%); } } + +@keyframes slideDown { + 0% { + -webkit-transform: translateY(-100%); + transform: translateY(-100%); } + 100% { + -webkit-transform: translateY(0%); + transform: translateY(0%); } } + +@media print, screen and (max-width: 39.99875em) { + .topbar-responsive-links { + -webkit-animation-fill-mode: both; + animation-fill-mode: both; + -webkit-animation-duration: 0.5s; + animation-duration: 0.5s; + width: 100%; + -webkit-animation: fadeIn 1s ease-in; + animation: fadeIn 1s ease-in; } } + +.comment-section-container { + background-color: #fefefe; + padding: 1rem; } + +.comment-section-author { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + margin-bottom: 1rem; } + .comment-section-author .comment-section-name { + margin-left: 1rem; } + .comment-section-author .comment-section-name p { + margin-bottom: 0; } + +.comment-section-box { + background-color: #e6e6e6; + padding: 1rem; } + +.about-the-author { + background-color: #fefefe; + padding: 1rem; + border: 1px solid #cacaca; } + .about-the-author .separator-left { + text-align: left; } + .about-the-author .separator-left::before, .about-the-author .separator-left::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .about-the-author .separator-left::after { + clear: both; } + .about-the-author .separator-left::after { + position: relative; + width: 5rem; + border-bottom: 0.125rem solid #2D6699; + margin: 0.3rem auto 0; + margin-left: 0; } + .about-the-author .author-title { + text-transform: uppercase; } + .about-the-author .author-social { + text-align: center; + margin-top: 0.7rem; + margin-bottom: 0.7rem; } + .about-the-author .author-social .fa-stack { + display: inline-block; } + .about-the-author .author-social .fa-stack.facebook { + color: #4c70ba; } + .about-the-author .author-social .fa-stack.facebook:hover, .about-the-author .author-social .fa-stack.facebook:focus { + color: #3b5998; } + .about-the-author .author-social .fa-stack.twitter { + color: #83c3f3; } + .about-the-author .author-social .fa-stack.twitter:hover, .about-the-author .author-social .fa-stack.twitter:focus { + color: #55acee; } + .about-the-author .author-social .fa-stack.linkedin { + color: #009ee8; } + .about-the-author .author-social .fa-stack.linkedin:hover, .about-the-author .author-social .fa-stack.linkedin:focus { + color: #007bb5; } + .about-the-author .author-image { + border: 1px solid #cacaca; } + +.wide-article-link { + background-color: #fefefe; + padding: 1rem 1rem 0.5rem; + border: 1px solid #cacaca; + margin-bottom: 1rem; } + .wide-article-link .article-title a { + color: #0a0a0a; } + .wide-article-link .article-title a:hover, .wide-article-link .article-title a:focus { + color: #2D6699; } + .wide-article-link .article-elipsis .read-more { + font-weight: bold; } + .wide-article-link .article-title, + .wide-article-link .article-author, + .wide-article-link .article-elipsis { + margin-bottom: 0.25rem; } + .wide-article-link .article-social { + margin-top: 0.75rem; } + .wide-article-link .article-social .social { + margin-right: 0.25rem; } + .wide-article-link .article-social .social.comments, .wide-article-link .article-social .social.comments.disabled, .wide-article-link .article-social .social.comments[disabled], .wide-article-link .article-social .social.comments.disabled:hover, .wide-article-link .article-social .social.comments[disabled]:hover, .wide-article-link .article-social .social.comments.disabled:focus, .wide-article-link .article-social .social.comments[disabled]:focus { + background-color: #8a8a8a; + color: #fefefe; } + .wide-article-link .article-social .social.comments:hover, .wide-article-link .article-social .social.comments:focus { + background-color: #6e6e6e; + color: #fefefe; } + .wide-article-link .article-social .social.facebook, .wide-article-link .article-social .social.facebook.disabled, .wide-article-link .article-social .social.facebook[disabled], .wide-article-link .article-social .social.facebook.disabled:hover, .wide-article-link .article-social .social.facebook[disabled]:hover, .wide-article-link .article-social .social.facebook.disabled:focus, .wide-article-link .article-social .social.facebook[disabled]:focus { + background-color: #3b5998; + color: #fefefe; } + .wide-article-link .article-social .social.facebook:hover, .wide-article-link .article-social .social.facebook:focus { + background-color: #2f477a; + color: #fefefe; } + .wide-article-link .article-social .social.twitter, .wide-article-link .article-social .social.twitter.disabled, .wide-article-link .article-social .social.twitter[disabled], .wide-article-link .article-social .social.twitter.disabled:hover, .wide-article-link .article-social .social.twitter[disabled]:hover, .wide-article-link .article-social .social.twitter.disabled:focus, .wide-article-link .article-social .social.twitter[disabled]:focus { + background-color: #55acee; + color: #fefefe; } + .wide-article-link .article-social .social.twitter:hover, .wide-article-link .article-social .social.twitter:focus { + background-color: #1a8fe8; + color: #fefefe; } + .wide-article-link .article-social .social.linkedin, .wide-article-link .article-social .social.linkedin.disabled, .wide-article-link .article-social .social.linkedin[disabled], .wide-article-link .article-social .social.linkedin.disabled:hover, .wide-article-link .article-social .social.linkedin[disabled]:hover, .wide-article-link .article-social .social.linkedin.disabled:focus, .wide-article-link .article-social .social.linkedin[disabled]:focus { + background-color: #007bb5; + color: #fefefe; } + .wide-article-link .article-social .social.linkedin:hover, .wide-article-link .article-social .social.linkedin:focus { + background-color: #006291; + color: #fefefe; } + .wide-article-link .article-social .social.google-plus, .wide-article-link .article-social .social.google-plus.disabled, .wide-article-link .article-social .social.google-plus[disabled], .wide-article-link .article-social .social.google-plus.disabled:hover, .wide-article-link .article-social .social.google-plus[disabled]:hover, .wide-article-link .article-social .social.google-plus.disabled:focus, .wide-article-link .article-social .social.google-plus[disabled]:focus { + background-color: #dd4b39; + color: #fefefe; } + .wide-article-link .article-social .social.google-plus:hover, .wide-article-link .article-social .social.google-plus:focus { + background-color: #be3221; + color: #fefefe; } + .wide-article-link .article-social .social > .fa { + color: #fefefe; } + .wide-article-link .article-social .social > .fa.fa-comments-o { + margin-right: 0.25rem; } + +.large-article-header { + background: "" #8a8a8a no-repeat center; + background-size: cover; + background-color: #8a8a8a; + height: 25rem; + position: relative; } + @media print, screen and (max-width: 39.99875em) { + .large-article-header { + height: 16.66667rem; } } + +.large-article-header-content { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + position: absolute; + bottom: 3.125rem; + left: 0; + right: 0; + text-shadow: 1px 1px 2px #0a0a0a; } + @media print, screen and (max-width: 39.99875em) { + .large-article-header-content { + bottom: 1.25rem; } } + .large-article-header-content .center-container { + width: 50%; + margin: 0 auto; } + @media print, screen and (max-width: 39.99875em) { + .large-article-header-content .center-container { + width: 100%; + padding: 0 1.25rem; } } + .large-article-header-content .article-date { + color: #fefefe; } + .large-article-header-content .article-title h1 { + line-height: 3.125rem; + color: #fefefe; + font-weight: 600; } + @media print, screen and (max-width: 39.99875em) { + .large-article-header-content .article-title h1 { + line-height: 1.875rem; } } + .large-article-header-content .article-details { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; } + .large-article-header-content .article-details a { + color: #fefefe; } + .large-article-header-content .article-author { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + margin: 1rem 0; } + .large-article-header-content .article-author img { + border-radius: 3.125rem; } + .large-article-header-content .article-author a { + margin-left: 1rem; } + +.simple-article-header { + background: #fefefe; + padding: 1.3rem 2rem .7rem; + border: 1px solid #cacaca; + margin-bottom: 1rem; } + .simple-article-header .article-date-read { + color: #8a8a8a; } + .simple-article-header .article-title { + text-transform: uppercase; } + .simple-article-header .article-title a { + color: #0a0a0a; } + .simple-article-header .article-title a:hover, .simple-article-header .article-title a:focus { + color: #2D6699; } + .simple-article-header .article-author-comments a.article-comments { + color: #8a8a8a; } + .simple-article-header .article-author-comments a.article-comments:hover, .simple-article-header .article-author-comments a.article-comments:focus { + color: #2D6699; } + .simple-article-header .article-date-read, + .simple-article-header .article-title, + .simple-article-header .article-author-comments, + .simple-article-header .article-social, + .simple-article-header .article-post-image, + .simple-article-header .article-post-content { + margin-bottom: 0.25rem; } + .simple-article-header .article-social { + margin-top: 0.75rem; } + .simple-article-header .article-social .social { + margin-right: 0.25rem; } + .simple-article-header .article-social .social.facebook, .simple-article-header .article-social .social.facebook.disabled, .simple-article-header .article-social .social.facebook[disabled], .simple-article-header .article-social .social.facebook.disabled:hover, .simple-article-header .article-social .social.facebook[disabled]:hover, .simple-article-header .article-social .social.facebook.disabled:focus, .simple-article-header .article-social .social.facebook[disabled]:focus { + background-color: #3b5998; + color: #fefefe; } + .simple-article-header .article-social .social.facebook:hover, .simple-article-header .article-social .social.facebook:focus { + background-color: #2f477a; + color: #fefefe; } + .simple-article-header .article-social .social.twitter, .simple-article-header .article-social .social.twitter.disabled, .simple-article-header .article-social .social.twitter[disabled], .simple-article-header .article-social .social.twitter.disabled:hover, .simple-article-header .article-social .social.twitter[disabled]:hover, .simple-article-header .article-social .social.twitter.disabled:focus, .simple-article-header .article-social .social.twitter[disabled]:focus { + background-color: #55acee; + color: #fefefe; } + .simple-article-header .article-social .social.twitter:hover, .simple-article-header .article-social .social.twitter:focus { + background-color: #1a8fe8; + color: #fefefe; } + .simple-article-header .article-social .social.linkedin, .simple-article-header .article-social .social.linkedin.disabled, .simple-article-header .article-social .social.linkedin[disabled], .simple-article-header .article-social .social.linkedin.disabled:hover, .simple-article-header .article-social .social.linkedin[disabled]:hover, .simple-article-header .article-social .social.linkedin.disabled:focus, .simple-article-header .article-social .social.linkedin[disabled]:focus { + background-color: #007bb5; + color: #fefefe; } + .simple-article-header .article-social .social.linkedin:hover, .simple-article-header .article-social .social.linkedin:focus { + background-color: #006291; + color: #fefefe; } + .simple-article-header .article-social .social.google-plus, .simple-article-header .article-social .social.google-plus.disabled, .simple-article-header .article-social .social.google-plus[disabled], .simple-article-header .article-social .social.google-plus.disabled:hover, .simple-article-header .article-social .social.google-plus[disabled]:hover, .simple-article-header .article-social .social.google-plus.disabled:focus, .simple-article-header .article-social .social.google-plus[disabled]:focus { + background-color: #dd4b39; + color: #fefefe; } + .simple-article-header .article-social .social.google-plus:hover, .simple-article-header .article-social .social.google-plus:focus { + background-color: #be3221; + color: #fefefe; } + .simple-article-header .article-social .social > .fa { + color: #fefefe; } + .simple-article-header .article-social .social > .fa.fa-comments-o { + margin-right: 0.25rem; } + +.blockquote-container.blockquote-left { + float: left; + width: 35%; + margin-right: 1rem; } + @media print, screen and (max-width: 39.99875em) { + .blockquote-container.blockquote-left { + float: none; + margin: 0; + width: 100%; } } + +.blockquote-container.blockquote-right { + float: right; + width: 35%; + margin-left: 1rem; } + +.blockquote-container .callout .blockquote-title { + margin-left: 1rem; } + +.blockquote-container .callout blockquote { + quotes: "“" "”" "‘" "’ "; + border-left: none; } + .blockquote-container .callout blockquote:before { + content: open-quote; + color: #8a8a8a; + font-size: 4em; + line-height: 0.1em; + vertical-align: -0.4em; } + .blockquote-container .callout blockquote:after { + content: close-quote; + color: #8a8a8a; + font-size: 4em; + line-height: 0.1em; + vertical-align: -0.6em; } + .blockquote-container .callout blockquote .blockquote-content { + display: inline; + color: #0a0a0a; } + +.flexible-article-image-full .thumbnail { + width: 100%; } + .flexible-article-image-full .thumbnail img { + width: 100%; } + +.flexible-article-image-full .caption { + font-size: 0.9rem; } + +.flexible-article-image-left { + float: left; + margin: 1rem 1.5rem 0 0; + max-width: 12.5rem; } + .flexible-article-image-left .caption { + font-size: 0.9rem; } + @media print, screen and (max-width: 39.99875em) { + .flexible-article-image-left { + float: none; + max-width: 100%; + margin: 0; } + .flexible-article-image-left .thumbnail { + width: 100%; } + .flexible-article-image-left .thumbnail img { + width: 100%; } } + +.flexible-article-image-right { + float: right; + margin: 0 0 1rem 1.5rem; + max-width: 12.5rem; } + .flexible-article-image-right .caption { + font-size: 0.9rem; } + @media print, screen and (max-width: 39.99875em) { + .flexible-article-image-right { + float: none; + max-width: 100%; + margin: 0; } + .flexible-article-image-right .thumbnail { + width: 100%; } + .flexible-article-image-right .thumbnail img { + width: 100%; } } + +.featured-article-big { + background: url("https://placehold.it/600?text=Big+Feature") no-repeat center center; + background-size: cover; + height: 28.125rem; + width: 100%; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; + padding: 0.625rem; + border-right: 0.0625rem solid #fefefe; } + .featured-article-big .featured-article-text .featured-article-title { + font-size: 1.75rem; + font-weight: bold; + line-height: 1.875rem; } + .featured-article-big .featured-article-text .featured-article-title .author { + font-size: 1.125rem; } + .featured-article-big .featured-article-text p { + color: #fefefe; + margin-bottom: 0; } + +.featured-article-small-container { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; + height: 28.125rem; } + .featured-article-small-container :last-child .featured-article-small { + border-bottom: 0; } + +.featured-article-small { + background: url("https://placehold.it/200?text=Small+Feature") no-repeat center center; + height: 9.375rem; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + -webkit-box-pack: justify; + -webkit-justify-content: space-between; + -ms-flex-pack: justify; + justify-content: space-between; + padding: 0.625rem; + border-bottom: 0.0625rem solid #fefefe; } + .featured-article-small :last-child { + border-bottom: 0; } + .featured-article-small .featured-article-text .featured-article-title { + font-size: 1rem; + font-weight: bold; + line-height: 0.9375rem; + max-height: 2.8125rem; + overflow: hidden; + text-overflow: ellipsis; } + .featured-article-small .featured-article-text p { + color: #fefefe; + margin-bottom: 0; } + +.featured-article-links-container { + border: 0.0625rem solid #e6e6e6; + background-color: #fefefe; + height: 28.125rem; + overflow: scroll; } + +.featured-article-links, +.featured-article-links-header { + padding: 0.625rem; + border-bottom: 0.0625rem solid #e6e6e6; } + .featured-article-links:last-child, + .featured-article-links-header:last-child { + border-bottom: 0; } + +.featured-article-links-header { + font-weight: 600; + text-transform: uppercase; } + +.posts-panel { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; + float: none !important; + margin: 1.25rem 0.625rem; + background-color: #fefefe; + border-radius: 0; + -webkit-box-shadow: 0 0 0.25rem 0 rgba(0, 0, 0, 0.2); + box-shadow: 0 0 0.25rem 0 rgba(0, 0, 0, 0.2); } + .posts-panel::before, .posts-panel::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel::after { + clear: both; } + @media print, screen and (min-width: 40em) { + .posts-panel { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel, .posts-panel:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel:last-child:not(:first-child) { + float: right; } + .posts-panel, .posts-panel:last-child { + float: none; } + .posts-panel .panel-header { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; + border-bottom: 0.25rem solid #e6e6e6; } + .posts-panel .panel-header::before, .posts-panel .panel-header::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel .panel-header::after { + clear: both; } + @media print, screen and (min-width: 40em) { + .posts-panel .panel-header { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel .panel-header, .posts-panel .panel-header:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .panel-header:last-child:not(:first-child) { + float: right; } + .posts-panel .panel-header, .posts-panel .panel-header:last-child { + float: none; } + .posts-panel .panel-header .panel-title { + margin: 0; + padding: 0.9375rem 0; + color: #8a8a8a; + font-size: 1.625rem; } + .posts-panel .panel-content { + padding: 0.9375rem 0; } + .posts-panel .pinned-post, .posts-panel .posts-list { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0; + padding-left: 0; } + .posts-panel .pinned-post::before, .posts-panel .pinned-post::after, .posts-panel .posts-list::before, .posts-panel .posts-list::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel .pinned-post::after, .posts-panel .posts-list::after { + clear: both; } + .posts-panel .pinned-post, .posts-panel .pinned-post:last-child:not(:first-child), .posts-panel .posts-list, .posts-panel .posts-list:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .pinned-post:last-child:not(:first-child), .posts-panel .posts-list:last-child:not(:first-child) { + float: right; } + .posts-panel .pinned-post, .posts-panel .pinned-post:last-child, .posts-panel .posts-list, .posts-panel .posts-list:last-child { + float: none; } + .posts-panel .posts-list .post-item:not(:last-child) { + border-bottom: 0.0625rem solid #e6e6e6; } + .posts-panel .post-item { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + padding: 0.9375rem 0; } + .posts-panel .post-item::before, .posts-panel .post-item::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel .post-item::after { + clear: both; } + .posts-panel .post-item .post-thumbnail { + display: block; + width: 33.33333%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; } + @media print, screen and (min-width: 40em) { + .posts-panel .post-item .post-thumbnail { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel .post-item .post-thumbnail, .posts-panel .post-item .post-thumbnail:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .post-item .post-thumbnail:last-child:not(:first-child) { + float: right; } + .posts-panel .post-item .post-thumbnail img { + width: 100%; + height: auto; } + .posts-panel .post-item .post-text { + width: 66.66667%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; } + @media print, screen and (min-width: 40em) { + .posts-panel .post-item .post-text { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel .post-item .post-text, .posts-panel .post-item .post-text:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .post-item .post-text:last-child:not(:first-child) { + float: right; } + .posts-panel .post-item .post-text p { + margin: 0; } + .posts-panel .post-item .post-title { + font-size: 1.625rem; } + .posts-panel .post-item .post-meta { + color: #8a8a8a; + font-size: 0.875rem; } + .posts-panel .post-item .meta { + display: inline-block; + margin-right: 0.9375rem; } + .posts-panel .post-item .meta-icon, .posts-panel .post-item .meta-text { + display: inline-block; + padding-right: 0.3125rem; } + .posts-panel .post-item .post-read-more { + display: block; + font-size: 0.875rem; } + .posts-panel .post-item .post-read-more .fa { + padding: 0 0.3125rem; } + .posts-panel .pinned-post .post-item { + border-bottom: 0.0625rem solid #e6e6e6; } + .posts-panel .pinned-post .post-thumbnail { + display: block; + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; } + .posts-panel .pinned-post .post-thumbnail::before, .posts-panel .pinned-post .post-thumbnail::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel .pinned-post .post-thumbnail::after { + clear: both; } + @media print, screen and (min-width: 40em) { + .posts-panel .pinned-post .post-thumbnail { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel .pinned-post .post-thumbnail, .posts-panel .pinned-post .post-thumbnail:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .pinned-post .post-thumbnail:last-child:not(:first-child) { + float: right; } + .posts-panel .pinned-post .post-thumbnail, .posts-panel .pinned-post .post-thumbnail:last-child { + float: none; } + .posts-panel .pinned-post .post-thumbnail img { + width: 100%; + height: auto; } + .posts-panel .pinned-post .post-text { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0.625rem; + padding-left: 0.625rem; + margin-top: 0.9375rem; } + .posts-panel .pinned-post .post-text::before, .posts-panel .pinned-post .post-text::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel .pinned-post .post-text::after { + clear: both; } + @media print, screen and (min-width: 40em) { + .posts-panel .pinned-post .post-text { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + .posts-panel .pinned-post .post-text, .posts-panel .pinned-post .post-text:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel .pinned-post .post-text:last-child:not(:first-child) { + float: right; } + .posts-panel .pinned-post .post-text, .posts-panel .pinned-post .post-text:last-child { + float: none; } + @media print, screen and (max-width: 39.99875em) { + .posts-panel .posts-list .post-title { + font-size: 1.125rem; } + .posts-panel .posts-list .post-meta { + font-size: 0.75rem; } + .posts-panel .posts-list .post-summary { + font-size: 0.75rem; } + .posts-panel .posts-list .post-read-more { + display: none; } } + @media print, screen and (min-width: 40em) and (max-width: 63.99875em) { + .posts-panel .posts-list .post-title { + font-size: 1.25rem; } + .posts-panel .posts-list .post-meta { + font-size: 0.875rem; } + .posts-panel .posts-list .post-summary { + font-size: 0.875rem; } } + .posts-panel.grid .pinned-post, .posts-panel.grid .posts-list { + width: 50%; + float: left; + padding-right: 0; + padding-left: 0; } + .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list:last-child:not(:first-child) { + float: right; } + @media print, screen and (max-width: 39.99875em) { + .posts-panel.grid .pinned-post, .posts-panel.grid .posts-list { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + width: 100%; + float: left; + padding-right: 0; + padding-left: 0; } + .posts-panel.grid .pinned-post::before, .posts-panel.grid .pinned-post::after, .posts-panel.grid .posts-list::before, .posts-panel.grid .posts-list::after { + display: table; + content: ' '; + -webkit-flex-basis: 0; + -ms-flex-preferred-size: 0; + flex-basis: 0; + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .posts-panel.grid .pinned-post::after, .posts-panel.grid .posts-list::after { + clear: both; } + .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child:not(:first-child) { + float: left; + clear: none; } + .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list:last-child:not(:first-child) { + float: right; } + .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child, .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child { + float: none; } } + .posts-panel.grid .pinned-post .post-item { + border: 0; } + .posts-panel.grid .posts-list .post-title { + font-size: 1.125rem; } + .posts-panel.grid .posts-list .post-meta { + font-size: 0.75rem; } + .posts-panel.grid .posts-list .post-summary { + font-size: 0.75rem; } + .posts-panel.grid .posts-list .post-read-more { + display: none; } + +.sticky-social-bar { + padding: 0; + margin: 0; + top: 50%; + -webkit-transform: translateY(-50%); + -ms-transform: translateY(-50%); + transform: translateY(-50%); + width: 11.25rem; + background-color: #333333; + position: fixed; + left: -8.75rem; } + .sticky-social-bar .social-icon { + list-style-type: none; + color: #fefefe; + background-color: inherit; + margin: 0; + -webkit-transition: all 0.3s ease-in-out; + transition: all 0.3s ease-in-out; + cursor: pointer; + font-size: 1.1rem; + padding: 0.25rem 0.25rem 0.5rem; } + .sticky-social-bar .social-icon:first-of-type { + padding-top: 0.375rem; } + .sticky-social-bar .social-icon:last-of-type { + padding-bottom: 0.625rem; } + .sticky-social-bar .social-icon > a { + color: inherit; + background-color: inherit; } + .sticky-social-bar .social-icon > a > .fa { + padding: 0.5rem; + width: 2rem; + height: 2rem; + float: right; + margin-left: 0.5rem; } + .sticky-social-bar .social-icon > a > .fa.fa-facebook { + background-color: #3b5998; } + .sticky-social-bar .social-icon > a > .fa.fa-twitter { + background-color: #55acee; } + .sticky-social-bar .social-icon > a > .fa.fa-linkedin { + background-color: #007bb5; } + .sticky-social-bar .social-icon > a > .fa.fa-youtube { + background-color: #bb0000; } + .sticky-social-bar .social-icon > a > .fa.fa-instagram { + background-color: #125688; } + .sticky-social-bar .social-icon > a > .fa.fa-pinterest-p { + background-color: #cb2027; } + .sticky-social-bar .social-icon > a > .social-icon-text { + font-size: 80%; + color: #fefefe; + text-transform: uppercase; + margin-right: 0.5rem; } + .sticky-social-bar .social-icon:hover { + -webkit-transform: translateX(8.75rem); + -ms-transform: translateX(8.75rem); + transform: translateX(8.75rem); } + .sticky-social-bar .social-icon:hover > a { + color: inherit; + background-color: inherit; } + +.ecommerce-footer { + background-color: #fefefe; + padding: 70px 20px 40px 20px; } + +.ecommerce-footer-links h5 { + color: #0a0a0a; + font-size: 1.2rem; + font-weight: 600; } + +.ecommerce-footer-links .menu > li > a { + line-height: 1.5em; + padding: 0.5rem 0rem; } + +.ecommerce-footer-links a { + color: #707070; + font-size: 1rem; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; } + +.ecommerce-footer-links a:hover { + color: #0a0a0a; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; } + +.ecommerce-footer-links .more-categories { + margin-top: 2rem; } + @media print, screen and (max-width: 39.99875em) { + .ecommerce-footer-links .more-categories { + margin-top: 2rem; } } + +@media print, screen and (max-width: 63.99875em) { + .ecommerce-footer-links .ecommerce-footer-links-block { + margin-bottom: 3rem; } } + +.ecommerce-footer-bottom-bar { + border-top: 1px solid #e6e6e6; + margin-top: 40px; + padding-bottom: 80px; + padding-top: 30px; } + .ecommerce-footer-bottom-bar .menu > li > a { + line-height: 1.2em; + padding: 10px 0; } + .ecommerce-footer-bottom-bar a { + color: #8a8a8a; + font-size: 0.9rem; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; } + .ecommerce-footer-bottom-bar a:hover { + color: #0a0a0a; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; } + @media print, screen and (max-width: 39.99875em) { + .ecommerce-footer-bottom-bar ul { + text-align: center; } } + .ecommerce-footer-bottom-bar li { + display: inline; } + .ecommerce-footer-bottom-bar .bottom-links { + margin-top: 0.65rem; + margin-left: 0; } + .ecommerce-footer-bottom-bar .bottom-links li { + padding-right: 2rem; } + @media print, screen and (max-width: 39.99875em) { + .ecommerce-footer-bottom-bar .bottom-links li { + text-align: center; } } + .ecommerce-footer-bottom-bar .ecommerce-footer-logomark { + text-align: center; } + @media print, screen and (max-width: 39.99875em) { + .ecommerce-footer-bottom-bar .ecommerce-footer-logomark { + padding-top: 1rem; + margin-bottom: 1rem; } } + .ecommerce-footer-bottom-bar .bottom-copyright { + color: #8a8a8a; + font-size: 0.9rem; + line-height: 1.2em; + padding-top: 1rem; + text-align: right; } + @media print, screen and (max-width: 39.99875em) { + .ecommerce-footer-bottom-bar .bottom-copyright { + text-align: center; } } + +.pagination-circular li.current { + border: 1px solid #2D6699; + border-radius: 5000px; + padding: 0.285em 0.8em; + font-size: 18px; } + +.pagination-circular li.disabled { + border: 1px solid #cacaca; + padding: 0.285em 0.8em; + border-radius: 5000px; + font-size: 18px; } + +.pagination-circular a { + border-radius: 5000px; + padding: 0.285em 0.8em; + border: 1px solid #2D6699; + font-size: 18px; } + +.pagination-circular li:not(.disabled):hover a { + background: #2D6699; + color: #fefefe; } + +.pagination-circular li a { + -webkit-transition: background 0.15s ease-in, color 0.15s ease-in; + transition: background 0.15s ease-in, color 0.15s ease-in; } + +.pagination-pointed .pagination-pointed-button, .pagination-pointed .current, .pagination-pointed .pagination-previous { + position: relative; + display: inline-block; + padding: 6px 12px; + margin-bottom: 0; + text-align: center; + white-space: nowrap; + vertical-align: middle; + cursor: pointer; + background-image: none; + border: 1px solid transparent; + border-radius: 4px; + background-color: #2c3840; + color: #fff; + outline: 0; + text-decoration: none; + -webkit-transition: all 0.2s linear; + transition: all 0.2s linear; } + .pagination-pointed .pagination-pointed-button:hover, .pagination-pointed .current:hover, .pagination-pointed .pagination-previous:hover { + background-color: #41525e; } + +.pagination-pointed .current { + background: dodgerblue; } + .pagination-pointed .current:hover { + background-color: #0077ea; } + +.pagination-pointed .pagination-next a { + border-radius: 4px 0 0 4px; + margin-right: 18px; } + .pagination-pointed .pagination-next a:hover::after { + border-left: 17px solid #41525e; } + .pagination-pointed .pagination-next a::after { + content: ""; + position: absolute; + top: 0; + right: -18px; + width: 0; + height: 0; + border-top: 17px solid transparent; + border-bottom: 17px solid transparent; + border-left: 17px solid #2c3840; + -webkit-transition: all 0.2s linear; + transition: all 0.2s linear; } + +.pagination-pointed .pagination-previous { + border-radius: 0 4px 4px 0; + margin-left: 18px; } + .pagination-pointed .pagination-previous:hover::after { + border-right: 17px solid #41525e; } + .pagination-pointed .pagination-previous::before { + content: ""; } + .pagination-pointed .pagination-previous::after { + content: ""; + position: absolute; + top: 0; + left: -18px; + width: 0; + height: 0; + border-bottom: 17px solid transparent; + border-top: 17px solid transparent; + border-right: 17px solid #2c3840; + -webkit-transition: all 0.2s linear; + transition: all 0.2s linear; } + +.tag-cloud-section { + background: #7b93a4; + padding: 4rem; + max-width: 800px; + margin: 0 auto; } + +.tag-cloud-title { + text-align: center; + text-transform: uppercase; + font-weight: bold; + color: #e6e6e6; + border-bottom: 1px solid #cacaca; + padding: 1rem 0; + margin-bottom: 1rem; } + +.tag-cloud { + margin: 1rem; + text-align: center; + list-style: none; } + .tag-cloud .tag-cloud-individual-tag { + display: inline-block; + padding: 0.33333rem 0.5rem; + border-radius: 0; + font-size: 0.8rem; + line-height: 1; + white-space: nowrap; + cursor: default; + border-radius: 5000px; + background: #2c3840; + display: inline-block; + color: #e6e6e6; + margin: 3px; + text-transform: uppercase; + font-weight: bold; } + .tag-cloud .tag-cloud-individual-tag .fa { + margin-left: 7px; + color: #e6e6e6; } + .tag-cloud .tag-cloud-individual-tag:hover { + background: black; + -webkit-transition: background-color .2s ease-in; + transition: background-color .2s ease-in; } + +.social { + margin-right: .25rem; } + .social.facebook, .social.facebook.disabled, .social.facebook[disabled], .social.facebook.disabled:hover, .social.facebook[disabled]:hover, .social.facebook.disabled:focus, .social.facebook[disabled]:focus { + background-color: #3b5998; + color: #fff; } + .social.facebook:hover, .social.facebook:focus { + background-color: #2f477a; + color: #fff; } + .social.twitter, .social.twitter.disabled, .social.twitter[disabled], .social.twitter.disabled:hover, .social.twitter[disabled]:hover, .social.twitter.disabled:focus, .social.twitter[disabled]:focus { + background-color: #55acee; + color: #fff; } + .social.twitter:hover, .social.twitter:focus { + background-color: #1a8fe8; + color: #fff; } + .social.linkedin, .social.linkedin.disabled, .social.linkedin[disabled], .social.linkedin.disabled:hover, .social.linkedin[disabled]:hover, .social.linkedin.disabled:focus, .social.linkedin[disabled]:focus { + background-color: #007bb5; + color: #fff; } + .social.linkedin:hover, .social.linkedin:focus { + background-color: #006291; + color: #fff; } + .social.youtube, .social.youtube.disabled, .social.youtube[disabled], .social.youtube.disabled:hover, .social.youtube[disabled]:hover, .social.youtube.disabled:focus, .social.youtube[disabled]:focus { + background-color: #bb0000; + color: #fff; } + .social.youtube:hover, .social.youtube:focus { + background-color: #960000; + color: #fff; } + .social.instagram, .social.instagram.disabled, .social.instagram[disabled], .social.instagram.disabled:hover, .social.instagram[disabled]:hover, .social.instagram.disabled:focus, .social.instagram[disabled]:focus { + background-color: #125688; + color: #fff; } + .social.instagram:hover, .social.instagram:focus { + background-color: #0e456d; + color: #fff; } + .social.pinterest, .social.pinterest.disabled, .social.pinterest[disabled], .social.pinterest.disabled:hover, .social.pinterest[disabled]:hover, .social.pinterest.disabled:focus, .social.pinterest[disabled]:focus { + background-color: #cb2027; + color: #fff; } + .social.pinterest:hover, .social.pinterest:focus { + background-color: #a21a1f; + color: #fff; } + .social.google-plus, .social.google-plus.disabled, .social.google-plus[disabled], .social.google-plus.disabled:hover, .social.google-plus[disabled]:hover, .social.google-plus.disabled:focus, .social.google-plus[disabled]:focus { + background-color: #dd4b39; + color: #fff; } + .social.google-plus:hover, .social.google-plus:focus { + background-color: #be3221; + color: #fff; } + .social.github, .social.github.disabled, .social.github[disabled], .social.github.disabled:hover, .social.github[disabled]:hover, .social.github.disabled:focus, .social.github[disabled]:focus { + background-color: #000000; + color: #fff; } + .social.github:hover, .social.github:focus { + background-color: black; + color: #fff; } + .social.tumblr, .social.tumblr.disabled, .social.tumblr[disabled], .social.tumblr.disabled:hover, .social.tumblr[disabled]:hover, .social.tumblr.disabled:focus, .social.tumblr[disabled]:focus { + background-color: #32506d; + color: #fff; } + .social.tumblr:hover, .social.tumblr:focus { + background-color: #284057; + color: #fff; } + .social > .fa { + color: #fff; + margin-right: .25rem; } + +.polls { + margin-bottom: 1rem; } + .polls .polls-question { + margin-bottom: .5rem; } + .polls .polls-question .polls-question-label { + color: #2D6699; + font-weight: 500; + margin-right: .25rem; } + .polls .polls-submit { + margin-top: .3rem; } + .polls .polls-submit .button { + margin-right: .5rem; + text-transform: uppercase; } + +.news-image-gallery-container { + background-color: #fff; + padding: 2rem 1.5rem 1rem; } + .news-image-gallery-container .rounded-social-buttons { + text-align: left; } + .news-image-gallery-container .rounded-social-buttons .social-button { + display: inline-block; + position: relative; + cursor: pointer; + width: 2.5rem; + height: 2.5rem; + border: 0.125rem solid transparent; + padding: 0; + text-decoration: none; + text-align: center; + color: #fff; + font-size: 1.25rem; + font-weight: normal; + line-height: 1.8em; + border-radius: 1.6875rem; + -webkit-transition: 0.5s ease all; + transition: 0.5s ease all; + margin-right: 0.25rem; + margin-bottom: 0.25rem; } + .news-image-gallery-container .rounded-social-buttons .social-button:hover, .news-image-gallery-container .rounded-social-buttons .social-button:focus { + -webkit-transform: rotate(360deg); + -ms-transform: rotate(360deg); + transform: rotate(360deg); } + .news-image-gallery-container .rounded-social-buttons .social-button.facebook { + background: #3b5998; } + .news-image-gallery-container .rounded-social-buttons .social-button.facebook:before { + font-family: "FontAwesome"; + content: ""; } + .news-image-gallery-container .rounded-social-buttons .social-button.facebook:hover, .news-image-gallery-container .rounded-social-buttons .social-button.facebook:focus { + color: #3b5998; + background: #fff; + border-color: #3b5998; } + .news-image-gallery-container .rounded-social-buttons .social-button.twitter { + background: #55acee; } + .news-image-gallery-container .rounded-social-buttons .social-button.twitter:before { + font-family: "FontAwesome"; + content: ""; } + .news-image-gallery-container .rounded-social-buttons .social-button.twitter:hover, .news-image-gallery-container .rounded-social-buttons .social-button.twitter:focus { + color: #55acee; + background: #fff; + border-color: #55acee; } + .news-image-gallery-container .rounded-social-buttons .social-button.linkedin { + background: #007bb5; } + .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:before { + font-family: "FontAwesome"; + content: ""; } + .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:hover, .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:focus { + color: #007bb5; + background: #fff; + border-color: #007bb5; } + .news-image-gallery-container .rounded-social-buttons .social-button.google-plus { + background: #dd4b39; } + .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:before { + font-family: "FontAwesome"; + content: ""; } + .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:hover, .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:focus { + color: #dd4b39; + background: #fff; + border-color: #dd4b39; } + .news-image-gallery-container .news-image-gallery-title { + margin-top: .5rem; } + .news-image-gallery-container .read-more { + color: #8a8a8a; } + +.quote-inline-wrap-article-content { + max-width: 100%; + position: relative; } + +.quote-inline-wrap { + float: left; + max-width: 21.875rem; + padding: 0 1rem 1rem 0; } + .quote-inline-wrap .quote-inline-marks { + font-size: 6.25rem; + color: #8a8a8a; + line-height: 1rem; } + .quote-inline-wrap .quote-inline-testimonial { + border-radius: 5px; } + .quote-inline-wrap .quote-inline-testimonial p { + font-weight: 300; } + .quote-inline-wrap .quote-inline-person { + margin-bottom: 1.5rem; } + .quote-inline-wrap .quote-inline-person .quote-inline-photo img { + border-radius: 50%; + width: 4.375rem; + height: 4.375rem; + float: left; + margin-right: 1rem; } + .quote-inline-wrap .quote-inline-person p { + position: relative; + top: 5px; } + .quote-inline-wrap .quote-inline-person p:nth-child(2) { + font-size: 1rem; + font-weight: 500; + margin-bottom: 0; } + .quote-inline-wrap .quote-inline-person p:nth-child(3) { + font-size: 0.875rem; + font-weight: 400; + color: #8a8a8a; } + @media print, screen and (max-width: 63.99875em) { + .quote-inline-wrap { + width: 100%; + float: none; + display: block; } } + +.neat-article-container { + margin-top: 1.5rem; } + .neat-article-container .neat-article-header { + width: 100%; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-align: start; + -webkit-align-items: flex-start; + -ms-flex-align: start; + align-items: flex-start; } + .neat-article-container .neat-article-header .article-header-avatar { + padding-right: 0.5rem; + padding-left: 0.5rem; } + .neat-article-container .neat-article-header .article-header-avatar .header-avatar { + width: 3.75rem; + height: 3.75rem; + border-radius: 50%; } + .neat-article-container .neat-article-header .article-header-author { + -webkit-box-flex: 1; + -webkit-flex: 1 0 0; + -ms-flex: 1 0 0px; + flex: 1 0 0; } + .neat-article-container .neat-article-header .article-header-author .author-name { + color: #0a0a0a; + margin-bottom: 0; } + .neat-article-container .neat-article-header .article-header-author .author-description, + .neat-article-container .neat-article-header .article-header-author .article-date-read { + color: #8a8a8a; + margin-bottom: 0; + font-size: 0.85em; } + .neat-article-container .neat-article-title { + margin-top: 1rem; } + .neat-article-container .neat-article-title .article-title { + color: #0a0a0a; + font-weight: 600; } + .neat-article-container .neat-article-image { + margin-top: 1.5rem; } + .neat-article-container .neat-article-image .article-image { + width: 100%; + height: 100vh; } + @media print, screen and (min-width: 40em) and (max-width: 63.99875em) { + .neat-article-container .neat-article-image .article-image { + height: 65vh; } } + @media print, screen and (max-width: 39.99875em) { + .neat-article-container .neat-article-image .article-image { + height: 45vh; } } + .neat-article-container .neat-article-content { + margin-top: 2rem; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons { + text-align: center; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button { + display: block; + position: relative; + cursor: pointer; + width: 3.125rem; + height: 3.125rem; + border: 0.125rem solid transparent; + padding: 0; + text-decoration: none; + text-align: center; + color: #fff; + font-size: 1.5625rem; + font-weight: normal; + line-height: 2em; + border-radius: 1.6875rem; + -webkit-transition: all 0.5s ease; + transition: all 0.5s ease; + margin-right: 0.75rem; + margin-bottom: 0.75rem; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button:focus { + -webkit-transform: rotate(360deg); + -ms-transform: rotate(360deg); + transform: rotate(360deg); } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook { + background: #3b5998; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:before { + font-family: "FontAwesome"; + content: ""; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:focus { + color: #3b5998; + background: #fff; + border-color: #3b5998; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter { + background: #55acee; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:before { + font-family: "FontAwesome"; + content: ""; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:focus { + color: #55acee; + background: #fff; + border-color: #55acee; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus { + background: #dd4b39; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:before { + font-family: "FontAwesome"; + content: ""; } + .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:focus { + color: #dd4b39; + background: #fff; + border-color: #dd4b39; } + .neat-article-container .neat-article-content .article-content { + color: #0a0a0a; } + +.article-row-section { + max-width: 75rem; + margin-right: auto; + margin-left: auto; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-flow: row wrap; + -ms-flex-flow: row wrap; + flex-flow: row wrap; + -webkit-box-pack: left; + -webkit-justify-content: left; + -ms-flex-pack: left; + justify-content: left; } + +.article-row-section-inner { + -webkit-box-flex: 0; + -webkit-flex: 0 0 100%; + -ms-flex: 0 0 100%; + flex: 0 0 100%; + max-width: 100%; + padding-right: 0.625rem; + padding-left: 0.625rem; } + @media print, screen and (min-width: 40em) { + .article-row-section-inner { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + @media print, screen and (min-width: 40em) { + .article-row-section-inner { + -webkit-box-flex: 0; + -webkit-flex: 0 0 83.33333%; + -ms-flex: 0 0 83.33333%; + flex: 0 0 83.33333%; + max-width: 83.33333%; + padding-right: 0.625rem; + padding-left: 0.625rem; } } + @media print, screen and (min-width: 40em) and (min-width: 40em) { + .article-row-section-inner { + padding-right: 0.9375rem; + padding-left: 0.9375rem; } } + +.article-row-section-header { + padding: 1.5rem 0; + margin: 0; + line-height: 1; } + +.article-row { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + -webkit-flex-direction: column; + -ms-flex-direction: column; + flex-direction: column; + padding: 1.5rem 0; } + @media print, screen and (min-width: 40em) { + .article-row { + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + -webkit-flex-direction: row; + -ms-flex-direction: row; + flex-direction: row; } } + +.article-row-img img { + width: 100%; } + @media print, screen and (min-width: 40em) { + .article-row-img img { + max-width: none; + width: auto; } } + +.article-row-content { + padding: 1.5rem 0 0; + color: #0a0a0a; } + @media print, screen and (min-width: 40em) { + .article-row-content { + padding: 0 0 0 1.5rem; } } + +.article-row-header { + padding: 1.5rem 0 0; + color: #0a0a0a; } + @media print, screen and (min-width: 40em) { + .article-row-header { + padding: 0 0 0 1.5rem; } } + +.article-row-content-header { + font-size: 1.5rem; } + +.article-row-content-description { + font-size: 1.25rem; } + +.article-row-content-author, +.article-row-content-time { + font-size: 0.875rem; + margin-bottom: 0; + color: #8a8a8a; } + +.article-row-reversed .article-row-content { + -webkit-box-ordinal-group: 3; + -webkit-order: 2; + -ms-flex-order: 2; + order: 2; + padding: 0 1.5rem 0 0; } + +.article-row-reversed .article-row-img { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; + padding: 0 0 1.5rem 0; } + +@media print, screen and (min-width: 40em) { + .article-row-reversed .article-row-content { + -webkit-box-ordinal-group: 2; + -webkit-order: 1; + -ms-flex-order: 1; + order: 1; } + .article-row-reversed .article-row-img { + -webkit-box-ordinal-group: 3; + -webkit-order: 2; + -ms-flex-order: 2; + order: 2; } } + +.hero-section { + background: url("https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg") 50% no-repeat; + background-size: cover; + height: 60vh; + text-align: center; + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + -webkit-box-align: center; + -webkit-align-items: center; + -ms-flex-align: center; + align-items: center; + -webkit-box-pack: center; + -webkit-justify-content: center; + -ms-flex-pack: center; + justify-content: center; } + .hero-section .hero-section-text { + color: #fff; + text-shadow: 1px 1px 2px #0a0a0a; } + +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["app.css","_settings.scss","../../../node_modules/foundation-sites/scss/foundation.scss","../../../node_modules/foundation-sites/scss/util/_breakpoint.scss","../../../node_modules/foundation-sites/scss/components/_reveal.scss","../../../node_modules/foundation-sites/scss/vendor/normalize.scss","../../../node_modules/foundation-sites/scss/_global.scss","../../../node_modules/foundation-sites/scss/util/_mixins.scss","../../../node_modules/foundation-sites/scss/forms/_text.scss","../../../node_modules/foundation-sites/scss/util/_unit.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/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/xy-grid/_classes.scss","../../../node_modules/foundation-sites/scss/xy-grid/_gutters.scss","../../../node_modules/foundation-sites/scss/xy-grid/_grid.scss","../../../node_modules/foundation-sites/scss/xy-grid/_cell.scss","../../../node_modules/foundation-sites/scss/util/_math.scss","../../../node_modules/foundation-sites/scss/xy-grid/_layout.scss","../../../node_modules/foundation-sites/scss/xy-grid/_collapse.scss","../../../node_modules/foundation-sites/scss/xy-grid/_position.scss","../../../node_modules/foundation-sites/scss/xy-grid/_frame.scss","../../../node_modules/foundation-sites/scss/components/_button.scss","../../../node_modules/foundation-sites/scss/components/_button-group.scss","../../../node_modules/foundation-sites/scss/components/_close-button.scss","../../../node_modules/foundation-sites/scss/components/_label.scss","../../../node_modules/foundation-sites/scss/components/_progress-bar.scss","../../../node_modules/foundation-sites/scss/components/_slider.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/_badge.scss","../../../node_modules/foundation-sites/scss/components/_breadcrumbs.scss","../../../node_modules/foundation-sites/scss/components/_callout.scss","../../../node_modules/foundation-sites/scss/components/_card.scss","../../../node_modules/foundation-sites/scss/components/_dropdown.scss","../../../node_modules/foundation-sites/scss/components/_pagination.scss","../../../node_modules/foundation-sites/scss/components/_tooltip.scss","../../../node_modules/foundation-sites/scss/components/_accordion.scss","../../../node_modules/foundation-sites/scss/components/_media-object.scss","../../../node_modules/foundation-sites/scss/components/_orbit.scss","../../../node_modules/foundation-sites/scss/components/_responsive-embed.scss","../../../node_modules/foundation-sites/scss/components/_tabs.scss","../../../node_modules/foundation-sites/scss/components/_thumbnail.scss","../../../node_modules/foundation-sites/scss/components/_menu.scss","../../../node_modules/foundation-sites/scss/components/_menu-icon.scss","../../../node_modules/foundation-sites/scss/components/_accordion-menu.scss","../../../node_modules/foundation-sites/scss/components/_drilldown.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/_sticky.scss","../../../node_modules/foundation-sites/scss/components/_title-bar.scss","../../../node_modules/foundation-sites/scss/components/_top-bar.scss","../../../node_modules/foundation-sites/scss/components/_float.scss","../../../node_modules/foundation-sites/scss/components/_flex.scss","../../../node_modules/foundation-sites/scss/util/_flex.scss","../../../node_modules/foundation-sites/scss/components/_visibility.scss","../../../node_modules/foundation-sites/scss/prototype/_text-utilities.scss","../../../node_modules/foundation-sites/scss/prototype/_text-transformation.scss","../../../node_modules/foundation-sites/scss/prototype/_text-decoration.scss","../../../node_modules/foundation-sites/scss/prototype/_font-styling.scss","../../../node_modules/foundation-sites/scss/prototype/_list-style-type.scss","../../../node_modules/foundation-sites/scss/prototype/_rounded.scss","../../../node_modules/foundation-sites/scss/prototype/_bordered.scss","../../../node_modules/foundation-sites/scss/prototype/_shadow.scss","../../../node_modules/foundation-sites/scss/prototype/_arrow.scss","../../../node_modules/foundation-sites/scss/prototype/_separator.scss","../../../node_modules/foundation-sites/scss/prototype/_position.scss","../../../node_modules/foundation-sites/scss/prototype/_overflow.scss","../../../node_modules/foundation-sites/scss/prototype/_display.scss","../../../node_modules/foundation-sites/scss/prototype/_border-box.scss","../../../node_modules/foundation-sites/scss/prototype/_border-none.scss","../../../node_modules/foundation-sites/scss/prototype/_sizing.scss","../../../node_modules/foundation-sites/scss/prototype/_spacing.scss","../../../node_modules/motion-ui/src/util/_transition.scss","../../../node_modules/motion-ui/src/_classes.scss","../../../node_modules/motion-ui/src/_settings.scss","../../../node_modules/motion-ui/src/util/_keyframe.scss","../../../node_modules/motion-ui/src/transitions/_slide.scss","../../../node_modules/motion-ui/src/transitions/_fade.scss","../../../node_modules/motion-ui/src/effects/_hinge.scss","../../../node_modules/motion-ui/src/transitions/_hinge.scss","../../../node_modules/motion-ui/src/transitions/_zoom.scss","../../../node_modules/motion-ui/src/transitions/_spin.scss","../../../node_modules/motion-ui/src/util/_animation.scss","global/_style.scss","global/_typography.scss","global/_responsive-news-hero.scss","global/_date_badge.scss","components/building-blocks/_news-card.scss","components/building-blocks/_responsive-hidden-nav.scss","components/building-blocks/_topbar-responsive.scss","components/building-blocks/_comment-section.scss","components/building-blocks/_about-the-author.scss","components/building-blocks/_wide-article-link.scss","components/building-blocks/_large-article-header.scss","components/building-blocks/_simple-article-header.scss","components/building-blocks/_blockquote.scss","components/building-blocks/_flexible-article-images.scss","components/building-blocks/_featured-article-side-links.scss","components/building-blocks/_featured-blog-posts-panel.scss","../../../node_modules/foundation-sites/scss/grid/_row.scss","../../../node_modules/foundation-sites/scss/grid/_size.scss","../../../node_modules/foundation-sites/scss/grid/_column.scss","../../../node_modules/foundation-sites/scss/grid/_gutter.scss","../../../node_modules/foundation-sites/scss/grid/_position.scss","components/building-blocks/_sticky-social-bar.scss","components/building-blocks/_ecommerce-footer.scss","components/building-blocks/_pagination-circular.scss","components/building-blocks/_pagination-pointed.scss","components/building-blocks/_tag-cloud.scss","components/building-blocks/_social-buttons.scss","components/building-blocks/_polls.scss","components/building-blocks/_news-image-gallery.scss","components/building-blocks/_quote-inline.scss","components/building-blocks/_neat-article-container.scss","components/building-blocks/_article-row-section.scss","../../../node_modules/foundation-sites/scss/grid/_flex-grid.scss","components/building-blocks/_responsive-hero-section.scss"],"names":[],"mappings":"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,eR3N6C;EQuO7C,gBhBlJW;EgB0JX,aAAa;EAOb,qBhBhKiB,EAAA;;AEErB;Ec+HA;IAII,iBR3N6C,EAAA;EQuNjD;IAII,kBR3N6C,EAAA;EQuNjD;IAII,oBR3N6C,EAAA;EQuNjD;IAII,mBR3N6C,EAAA;EQuNjD;IAII,oBR3N6C,EAAA;EQuNjD;IAII,eR3N6C,EAAA,EQwPhD;;AZxRP;EY+RE,oBAAoB;EACpB,chBjRc;EgBkRd,qBhB/IyB;EgBiJzB,eAAe,EAAA;EALjB;IASI,chBtJ2D,EAAA;EgB6I/D;IAgBI,SAAS,EAAA;;AZjUb;EYuUE,WAAW;EAEX,gBRtRqD;EQuRrD,SAAS;EACT,oBhBlKyB;EgBoKzB,aAAa;EACb,eAAe;EACf,gChBtSiB;EgBuSjB,cAAc,EAAA;;AAIhB;;;EAGE,mBhBvL0B;EgBwL1B,4BhB3KyB;EgB4KzB,gBhB1LsB,EAAA;;AgB8LxB;EACE,kBAAkB,EAAA;;AAIpB;EACE,oBhBrLsB;EgBsLtB,qBhBxLkB,EAAA;;AgB4LpB;EACE,oBhB3LsB,EAAA;;AgB+LxB;EAEI,oBhBhM2B;EgBiM3B,gBAAgB,EAAA;;AAKpB;EACE,mBhBtMyB,EAAA;EgBqM3B;IAII,qBhBvM8B;IgBwM9B,iBhBzSmB,EAAA;;AgB8SvB;EACE,gBhBhO0B;EgBiO1B,sCR9UqD;EQ+UrD,8BhBzViB,EAAA;EgBsVnB;IAMI,gBhBtOoB;IgBuOpB,chB5Va,EAAA;;AgB0WjB;EACE,iChB1WW;EgB2WX,YAAY;EACZ,qBAAqB,EAAA;;AAIvB;EACE,SAAS,EAAA;;AAWX;EACE,SAAS;EACT,2BRjXS;EQmXT,yBhBnYgB;EgBqYhB,4DhBvSmE;EgBwSnE,chBnYW,EAAA;;AiBqDb;EACE,kBjBqGyB;EiBpGzB,qBjBqG4B;EiBnG5B,mBjBpByB;EiBqBzB,gBjB8FsB;EiB7FtB,cjB5De,EAAA;;AiBgEjB;EACE,ejBsFqC;EiBrFrC,gBjBsFiB,EAAA;;AiBlFnB;EACE,iBjBuFmB;EiBtFnB,cAAc,EAAA;EAEd;IACE,iBAAiB,EAAA;;AAIrB;EAGI,cAAgC;EAChC,gBAAgB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,UCnByD,EAAA;;AJtDvD;EGyEF,gBCnByD,EAAA;;AJtDvD;EGyEF,gBCnByD,EAAA;;AJtDvD;EGyEF,UCnByD,EAAA;;AJtDvD;EGyEF,gBCnByD,EAAA;;AJtDvD;EGyEF,gBCnByD,EAAA;;AJtDvD;EGyEF,WCnByD,EAAA;;AtB+BrD;EkBzGF;IGkDJ,mBAAM;IAAN,qBAAM;QAAN,iBAAM;YAAN,aAAM;IA2CJ,WAlFY,EAAA;EHNZ;IG6CF,mBAAM;IAAN,sBAAM;QAAN,kBAAM;YAAN,cAAM,EAAA;EHvCF;IGkFF,WAlFY,EAAA;EHSV;IGyEF,eCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,WCnByD,EAAA,EJnDtD;;AlBkFC;EkBzGF;IGkDJ,mBAAM;IAAN,qBAAM;QAAN,iBAAM;YAAN,aAAM;IA2CJ,WAlFY,EAAA;EHNZ;IG6CF,mBAAM;IAAN,sBAAM;QAAN,kBAAM;YAAN,cAAM,EAAA;EHvCF;IGkFF,WAlFY,EAAA;EHSV;IGyEF,eCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,UCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,gBCnByD,EAAA;EJtDvD;IGyEF,WCnByD,EAAA,EJnDtD;;AAKL;EACE,WAAW,EAAA;;AAIb;EACE,YAAY,EAAA;;AA8Bd;ECvGM,sBAA6D;EAA7D,uBAA6D,EAAA;EnBgJ7D;IkBzCN;MCvGM,uBAA6D;MAA7D,wBAA6D,EAAA,EDsIlE;EA/BD;IG6BE,2BAtD8F;IFrE5F,qBAA6D;IAA7D,sBAA6D,EAAA;EnBuI3D;IkBzCN;MG6BE,4BAtD8F;MFrE5F,sBAA6D;MAA7D,uBAA6D,EAAA,ED2G1D;EArCP;IGqDE,WAlFY,EAAA;EHiCd;IGiDE,WAlFY,EAAA;EHyCZ;IGyCA,+BAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,0BAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,0BAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,0BAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;ErBkE1F;IkBjEN;MGqDE,WAlFY,EAAA;IHiCd;MGiDE,WAlFY,EAAA;IHyCZ;MGyCA,gCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHChG;MGqDE,WAlFY,EAAA;IHiCd;MGiDE,WAlFY,EAAA;IHyCZ;MGyCA,gCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA,EHe7F;ElBmDG;IkBjEN;MGqDE,WAlFY,EAAA;IHiCd;MGiDE,WAlFY,EAAA;IHyCZ;MGyCA,gCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,2BAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA,EHe7F;;AA8CH;EC3IM,uBAA6D;EAA7D,sBAA6D,EAAA;EnBgJ7D;IkBLN;MC3IM,wBAA6D;MAA7D,uBAA6D,EAAA,EDgJhE;;AAID;ECpJI,uBAA6D;EAA7D,sBAA6D,EAAA;EnBgJ7D;IkBIJ;MCpJI,wBAA6D;MAA7D,uBAA6D,EAAA,EDsJhE;;AAXH;EC3IM,uBAA6D;EAA7D,sBAA6D,EAAA;EnBgJ7D;IkBLN;MC3IM,wBAA6D;MAA7D,uBAA6D,EAAA,ED2JhE;;AK3JH;EFoIE,WCnByD,EAAA;;ACjH3D;EFoIE,UCnByD,EAAA;;ACjH3D;EFoIE,gBCnByD,EAAA;;ACjH3D;EFoIE,UCnByD,EAAA;;ACjH3D;EFoIE,UCnByD,EAAA;;ACjH3D;EFoIE,gBCnByD,EAAA;;ACjH3D;EFoIE,gBCnByD,EAAA;;ACjH3D;EFoIE,YCnByD,EAAA;;AtB+BrD;EuBhJN;IFoIE,WCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,YCnByD,EAAA,EC/G1D;;AvB8IK;EuBhJN;IFoIE,WCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,UCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,gBCnByD,EAAA;ECjH3D;IFoIE,YCnByD,EAAA,EC/G1D;;AAFD;EFoIE,2BAtD8F,EAAA;;AE9EhG;EFoIE,0BAtD8F,EAAA;;AE9EhG;EFoIE,gCAtD8F,EAAA;;AE9EhG;EFoIE,0BAtD8F,EAAA;;AE9EhG;EFoIE,0BAtD8F,EAAA;;AE9EhG;EFoIE,gCAtD8F,EAAA;;AE9EhG;EFoIE,gCAtD8F,EAAA;;AE9EhG;EFoIE,4BAtD8F,EAAA;;ArBkE1F;EuBhJN;IFoIE,4BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,6BAtD8F,EAAA;EE9EhG;IFoIE,4BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,6BAtD8F,EAAA,EE5E/F;;AvB8IK;EuBhJN;IFoIE,4BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,2BAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,iCAtD8F,EAAA;EE9EhG;IFoIE,6BAtD8F,EAAA,EE5E/F;;ALqMG;EM9ME,eAA0B;EAA1B,cAA0B,EAAA;EAG5B;IAEI,eAA0B;IAA1B,cAA0B,EAAA;EAsBxB;IHgHR,eCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,WCnByD,EAAA;EtB+BrD;IwB5HI;MHgHR,eCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,WCnByD,EAAA,EE3FhD;ExB0HL;IwB5HI;MHgHR,eCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,UCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,gBCnByD,EAAA;IE7FjD;MHgHR,WCnByD,EAAA,EE3FhD;;ANuLP;EM7KE,eAA0B;EAA1B,cAA0B,EAAA;EAG5B;IAEI,gBAA4B;IAA5B,eAA4B,EAAA;;AxB2G9B;EkBuDF;IM9ME,eAA0B;IAA1B,cAA0B,EAAA;IAG5B;MAEI,eAA0B;MAA1B,cAA0B,EAAA,EAE7B;;AxBgJC;EwBrII;IHyHR,eCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,WCnByD,EAAA,EEpGhD;;AxBmIL;EwB5HI;IHgHR,eCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,WCnByD,EAAA,EE3FhD;;AxB0HL;EwB5HI;IHgHR,eCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,WCnByD,EAAA,EE3FhD;;AxB0HL;EkB6DF;IM7KE,eAA0B;IAA1B,cAA0B,EAAA;IAG5B;MAEI,gBAA4B;MAA5B,eAA4B,EAAA,EAE/B;;AxByGC;EkBuDF;IM9ME,eAA0B;IAA1B,cAA0B,EAAA;IAG5B;MAEI,eAA0B;MAA1B,cAA0B,EAAA,EAE7B;;AxBgJC;EwBrII;IHyHR,eCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,WCnByD,EAAA,EEpGhD;;AxBmIL;EwBrII;IHyHR,eCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,UCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,gBCnByD,EAAA;EEtGjD;IHyHR,WCnByD,EAAA,EEpGhD;;AxBmIL;EwB5HI;IHgHR,eCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,UCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,gBCnByD,EAAA;EE7FjD;IHgHR,WCnByD,EAAA,EE3FhD;;AxB0HL;EkB6DF;IM7KE,eAA0B;IAA1B,cAA0B,EAAA;IAG5B;MAEI,gBAA4B;MAA5B,eAA4B,EAAA,EAE/B;;ANoLD;EOvMF,eAA6B,EAAA;;AP2M3B;EO3MF,gCAA6B,EAAA;;APuM3B;EOvMF,qBAA6B,EAAA;;AP2M3B;EO3MF,sCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,gBAA6B,EAAA;;AP2M3B;EO3MF,iCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,gBAA6B,EAAA;;AP2M3B;EO3MF,iCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,gBAA6B,EAAA;;AP2M3B;EO3MF,iCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;APuM3B;EOvMF,sBAA6B,EAAA;;AP2M3B;EO3MF,uCAA6B,EAAA;;AzB4HzB;EkB2EF;IOvMF,eAA6B,EAAA;EP2M3B;IO3MF,iCAA6B,EAAA;EPuM3B;IOvMF,qBAA6B,EAAA;EP2M3B;IO3MF,uCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA,EP6M1B;;AlBjFC;EkB2EF;IOvMF,eAA6B,EAAA;EP2M3B;IO3MF,iCAA6B,EAAA;EPuM3B;IOvMF,qBAA6B,EAAA;EP2M3B;IO3MF,uCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,gBAA6B,EAAA;EP2M3B;IO3MF,kCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA;EPuM3B;IOvMF,sBAA6B,EAAA;EP2M3B;IO3MF,wCAA6B,EAAA,EP6M1B;;AAzJS;EEtEd,oBAAa;EAAb,qBAAa;EAAb,oBAAa;EAAb,aAAa;EACb,4BAH6B;EAG7B,6BAH6B;EAG7B,gCAH6B;MAG7B,4BAH6B;UAG7B,wBAH6B,EAAA;EFiP7B;IG1IA,YAAmB;IACnB,gBAA2B,EAAA;EHyI3B;IG7GE,YAlFY,EAAA;EH+Ld;IG7GE,YAlFY,EAAA;EH+Ld;IA2BM,wBAAgB;QAAhB,6BAAgB;YAAhB,gBAAgB,EAAA;ElB5HhB;IkBiGN;MA2BM,wBAAgB;UAAhB,6BAAgB;cAAhB,gBAAgB,EAAA,EACjB;ElB7HC;IkBiGN;MA2BM,wBAAgB;UAAhB,6BAAgB;cAAhB,gBAAgB,EAAA,EACjB;EA5BL;IGxJA,mBAAM;IAAN,sBAAM;QAAN,kBAAM;YAAN,cAAM,EAAA;EHwJN;IG7GE,gBCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,WCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,WCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,WCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,iBCnByD,EAAA;EJgI3D;IG7GE,YCnByD,EAAA;EtB+BrD;IkBiGN;MGxJA,mBAAM;MAAN,qBAAM;UAAN,iBAAM;cAAN,aAAM;MA2CJ,YAlFY,EAAA;IH+Ld;MGxJA,mBAAM;MAAN,sBAAM;UAAN,kBAAM;cAAN,cAAM,EAAA;IHwJN;MG7GE,YAlFY,EAAA;IH+Ld;MG7GE,gBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,YCnByD,EAAA,EJyLpD;ElB1JD;IkBiGN;MGxJA,mBAAM;MAAN,qBAAM;UAAN,iBAAM;cAAN,aAAM;MA2CJ,YAlFY,EAAA;IH+Ld;MGxJA,mBAAM;MAAN,sBAAM;UAAN,kBAAM;cAAN,cAAM,EAAA;IHwJN;MG7GE,YAlFY,EAAA;IH+Ld;MG7GE,gBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,WCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,iBCnByD,EAAA;IJgI3D;MG7GE,YCnByD,EAAA,EJyLpD;;AAOL;ECjTI,qBAA6D;EAA7D,wBAA6D,EAAA;EnBgJ7D;IkBiKJ;MCjTI,sBAA6D;MAA7D,yBAA6D,EAAA,EDqT9D;;AAJH;ECjTI,qBAA6D;EAA7D,wBAA6D,EAAA;EnBgJ7D;IkBiKJ;MCjTI,sBAA6D;MAA7D,yBAA6D,EAAA,ED0T9D;;AAnNL;ECvGM,qBAA6D;EAA7D,wBAA6D,EAAA;EnBgJ7D;IkBzCN;MCvGM,sBAA6D;MAA7D,yBAA6D,EAAA,EDsIlE;EA/BD;IG6BE,4BAtD8F;IFrE5F,oBAA6D;IAA7D,uBAA6D,EAAA;EnBuI3D;IkBzCN;MG6BE,6BAtD8F;MFrE5F,qBAA6D;MAA7D,wBAA6D,EAAA,ED2G1D;EArCP;IGqDE,YAlFY,EAAA;EHiCd;IGiDE,YAlFY,EAAA;EHyCZ;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,4BAtD8F,EAAA;ErBkE1F;IkBjEN;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,6BAtD8F,EAAA;IHChG;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,6BAtD8F,EAAA,EHe7F;ElBmDG;IkBjEN;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F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lFY,EAAA;EHyCZ;IGyCA,gCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,2BAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,iCAtD8F,EAAA;EHa9F;IGyCA,4BAtD8F,EAAA;ErBkE1F;IkBjEN;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,6BAtD8F,EAAA;IHChG;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,6BAtD8F,EAAA,EHe7F;ElBmDG;IkBjEN;MGqDE,YAlFY,EAAA;IHiCd;MGiDE,YAlFY,EAAA;IHyCZ;MGyCA,iCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,4BAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,kCAtD8F,EAAA;IHa9F;MGyCA,6BAtD8F,EAAA,EHe7F;;AAkTD;EQ5YI,6BAAmC,EAAA;E1B6InC;IkB+PJ;MQ5YI,8BAAmC,EAAA,ER8YtC;ElBjQG;IkB+PJ;MQ5YI,8BAAmC,EAAA,ER8YtC;;AlBjQG;EkBmQF;IQhZE,8BAAmC,EAAA,ERkZpC;;AlBrQC;EkBmQF;IQhZE,8BAAmC,EAAA,ERkZpC;;ASzGL;EA1OA,qBAAqB;EACrB,sBAAsB;EACtB,kB7BiOkC;E6BvNhC,mB7BsNuB;E6BnNzB,6B7B2NmC;E6B1NnC,gB7BKe;E6BJf,yE7BqOuE;E6BrOvE,iE7BqOuE;E6BpOvE,oB7B8M0B;E6B7M1B,iB7B4Ne;E6B1Nf,wBAAwB;EACxB,cAAc;EACd,kBAAkB;EAClB,eAAe,EAAA;E9BwlEf;IOxgEE,UAAU,EAAA;EuBkIZ;IAMM,iB7BHM,EAAA;E6BHZ;IAMM,kB7BFQ,EAAA;E6BJd;IAMM,kB7BAQ,EAAA;E6BNd;IA3ME,cAAc;IACd,WAAW;IACX,eAAe;IACf,cAAc,EAAA;EAiEhB;IAIE,yB7BlIc;I6BmId,c7BzHW,EAAA;E6B4Hb;IACE,yB7B0HuE;I6BzHvE,c7B9HW,EAAA;E6BoHb;IAIE,yB7BlIc;I6BmId,c7BzHW,EAAA;E6B4Hb;IACE,yBAboF;IAcpF,c7B9HW,EAAA;E6BoHb;IAIE,yB7BjIgB;I6BkIhB,c7B1HW,EAAA;E6B6Hb;IACE,yBAboF;IAcpF,c7B/HW,EAAA;E6BqHb;IAIE,yB7BhIc;I6BiId,c7B1HW,EAAA;E6B6Hb;IACE,yBAboF;IAcpF,c7B/HW,EAAA;E6BqHb;IAIE,yB7B/Hc;I6BgId,c7B1HW,EAAA;E6B6Hb;IACE,yBAboF;IAcpF,c7B/HW,EAAA;E6BqHb;IAIE,yB7B9HY;I6B+HZ,c7BzHW,EAAA;E6B4Hb;IACE,yBAboF;IAcpF,c7B9HW,EAAA;E6BsIX;IACE,6BAA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EAAA;;ADiFhB;ECxBF,4BAzDkB;MAyDlB,wBAzDkB;UAyDlB,oBAzDkB,EAAA;;AD6EhB;ECpCF,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB,EAAA;;ADgFd;ECxBF,0BAxDgB;MAwDhB,2BAxDgB;UAwDhB,kBAxDgB,EAAA;;AD4Ed;ECpCF,0BAvCkB;EAuClB,4BAvCkB;MAuClB,uBAvCkB;UAuClB,oBAvCkB,EAAA;;AD+EhB;ECxBF,2BAvDkB;MAuDlB,4BAvDkB;UAuDlB,mBAvDkB,EAAA;;ADqFlB;EC/CA,wBAnDkB;EAmDlB,+BAnDkB;MAmDlB,qBAnDkB;UAmDlB,uBAnDkB;EAoDlB,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB;EDwFd,6BAAqB;MAArB,0BAAqB;UAArB,qBAAqB,EAAA;;AAMnB;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;A3DmEV;E2DlEF;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD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kCCiCe;ECgBb,UFhCkC;EIElC,oCAA4B;EAA5B,4BAA4B,EAAA;;ALU5B;EGoBA,UFhCqC,EAAA;;ADArC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,UF/BkC;EIClC,oCAA4B;EAA5B,4BAA4B,EAAA;;ALU5B;EGoBA,UF/BqC,EAAA;;ADDrC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,sDGrCmC;UHqCnC,8CGrCmC;EHqCnC,6BF5BmD;ME4BnD,yBF5BmD;UE4BnD,qBF5BmD;EMIjD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,sDGpCqC;UHoCrC,8CGpCqC;EHoCrC,+BF3BqD;ME2BrD,2BF3BqD;UE2BrD,uBF3BqD;EMGnD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,qDGnCiC;UHmCjC,6CGnCiC;EHmCjC,gCF1BsD;ME0BtD,4BF1BsD;UE0BtD,wBF1BsD;EMEpD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,qDGlC+B;UHkC/B,6CGlC+B;EHkC/B,8BFzBoD;MEyBpD,0BFzBoD;UEyBpD,sBFzBoD;EMClD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,sDGrCmC;UHqCnC,8CGrCmC;EHqCnC,gCGEe;MHFf,4BGEe;UHFf,wBGEe;EC1Bb,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,sDGpCqC;UHoCrC,8CGpCqC;EHoCrC,gCGEe;MHFf,4BGEe;UHFf,wBGEe;EC1Bb,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;APG7B;EGoBA,mDGT4C;UHS5C,2CGT4C;ECJ1C,UAA2B,EAAA;;APnB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,6BFtBmD;MEsBnD,yBFtBmD;UEsBnD,qBFtBmD;EMFjD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,qDG/B8B;UH+B9B,6CG/B8B;ECkB5B,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,+BFrBqD;MEqBrD,2BFrBqD;UEqBrD,uBFrBqD;EMHnD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,qDG9BgC;UH8BhC,6CG9BgC;ECiB9B,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,gCFpBsD;MEoBtD,4BFpBsD;UEoBtD,wBFpBsD;EMJpD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,sDG7BsC;UH6BtC,8CG7BsC;ECgBpC,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,8BFnBoD;MEmBpD,0BFnBoD;UEmBpD,sBFnBoD;EMLlD,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,sDG5BoC;UH4BpC,8CG5BoC;ECelC,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,gCGEe;MHFf,4BGEe;UHFf,wBGEe;EC1Bb,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,qDG/B8B;UH+B9B,6CG/B8B;ECkB5B,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,mDGP8C;UHO9C,2CGP8C;EHO9C,gCGEe;MHFf,4BGEe;UHFf,wBGEe;EC1Bb,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA8B,EAAA;;APGhC;EGoBA,qDG9BgC;UH8BhC,6CG9BgC;ECiB9B,UAA8B,EAAA;;APnBhC;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,6BAFyB;MAEzB,yBAFyB;UAEzB,qBAFyB;EKzBvB,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;ARM7B;EGoBA,2BAFyB;MAEzB,uBAFyB;UAEzB,mBAFyB;EKdvB,UAA2B,EAAA;;ARhB7B;EClBF,kCCkBc;UDlBd,0BCkBc;EDjBd,0CCiCe;UDjCf,kCCiCe;ECgBb,6BAFyB;MAEzB,yBAFyB;UAEzB,qBAFyB;EKzBvB,uDAAuC;EAAvC,+CAAuC;EAAvC,uCAAuC;EAAvC,0DAAuC;EACvC,UAA2B,EAAA;;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a;EAOb,qB7FsGiB,EAAA;;A6FrIrB;EAII,kBrF2C6C;EqF/B7C,gB7FoHW;E6F5GX,aAAa;EAOb,qB7FsGiB,EAAA;;A6FrIrB;EAII,oBrF2C6C;EqF/B7C,gB7FoHW;E6F5GX,aAAa;EAOb,qB7FsGiB,EAAA;;A6FrIrB;EAII,mBrF2C6C;EqF/B7C,gB7FoHW;E6F5GX,aAAa;EAOb,qB7FsGiB,EAAA;;A6FrIrB;EAII,oBrF2C6C;EqF/B7C,gB7FoHW;E6F5GX,aAAa;EAOb,qB7FsGiB,EAAA;;A6FrIrB;EAII,erF2C6C;EqF/B7C,gB7FoHW;E6F5GX,aAAa;EAOb,qB7FsGiB,EAAA;;AEErB;E2FvIA;IAII,erF2C6C,EAAA;EqF/CjD;IAII,oBrF2C6C,EAAA;EqF/CjD;IAII,mBrF2C6C,EAAA;EqF/CjD;IAII,mBrF2C6C,EAAA;EqF/CjD;IAII,mBrF2C6C,EAAA;EqF/CjD;IAII,mBrF2C6C,EAAA,EqFdhD;;AAWD;EACI,iBAAiB;EAIjB,erFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;A6FzFrB;EACI,iBAAiB;EAIjB,oBrFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;A6FzFrB;EACI,iBAAiB;EAIjB,mBrFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;A6FzFrB;EACI,iBAAiB;EAIjB,mBrFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;A6FzFrB;EACI,iBAAiB;EAIjB,mBrFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;A6FzFrB;EACI,iBAAiB;EAIjB,mBrFF6C;EqFc7C,gB7FuEW;E6F/DX,aAAa;EAOb,qB7FyDiB,EAAA;;AEErB;E2F3FA;IACI,iBAAiB;IAIjB,erFF6C,EAAA;EqFHjD;IACI,iBAAiB;IAIjB,oBrFF6C,EAAA;EqFHjD;IACI,iBAAiB;IAIjB,mBrFF6C,EAAA;EqFHjD;IACI,iBAAiB;IAIjB,mBrFF6C,EAAA;EqFHjD;IACI,iBAA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","file":"app.css","sourcesContent":["@charset \"UTF-8\";\n@font-face {\n  font-family: 'Acumin Pro Bold';\n  font-style: normal;\n  font-weight: normal;\n  src: local(\"Acumin Pro Bold\"), url(\"Acumin-BdPro.woff\") format(\"woff\"); }\n\n@font-face {\n  font-family: 'Acumin Pro';\n  font-style: normal;\n  font-weight: normal;\n  src: local(\"Acumin Pro\"), url(\"Acumin-RPro.woff\") format(\"woff\"); }\n\n@font-face {\n  font-family: myRoboto;\n  src: url(\"/assets/fonts/RobotoMono-Light.ttf\"); }\n\n@font-face {\n  font-family: BalooBhaina;\n  src: url(\"/assets/fonts/BalooBhaina2-Regular.ttf\"); }\n\n@font-face {\n  font-family: DancingScript;\n  src: url(\"/assets/fonts/DancingScript.ttf\"); }\n\n.large-article-header {\n  background-position: center; }\n\ndiv.top-bar {\n  border-bottom: #2D6699 thin solid; }\n\n/**\n * Foundation for Sites\n * Version 6.6.3\n * https://get.foundation\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n  .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n    right: auto;\n    left: auto;\n    margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  line-height: 1.15;\n  -webkit-text-size-adjust: 100%; }\n\nbody {\n  margin: 0; }\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0; }\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n  overflow: visible; }\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\na {\n  background-color: transparent; }\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted; }\n\nb,\nstrong {\n  font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\nsmall {\n  font-size: 80%; }\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline; }\n\nsub {\n  bottom: -0.25em; }\n\nsup {\n  top: -0.5em; }\n\nimg {\n  border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0; }\n\nbutton,\ninput {\n  overflow: visible; }\n\nbutton,\nselect {\n  text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText; }\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n  box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal; }\n\nprogress {\n  vertical-align: baseline; }\n\ntextarea {\n  overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto; }\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit; }\n\ndetails {\n  display: block; }\n\nsummary {\n  display: list-item; }\n\ntemplate {\n  display: none; }\n\n[hidden] {\n  display: none; }\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%; }\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background: #F0F0F0;\n  font-family: \"Acumin Pro\", \"Helvetica Neue\", Helvetica;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale; }\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic; }\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0; }\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n  max-width: none !important; }\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n  cursor: auto; }\n  [data-whatinput='mouse'] button {\n    outline: 0; }\n\npre {\n  overflow: auto; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; }\n\n.is-visible {\n  display: block !important; }\n\n.is-hidden {\n  display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none; }\n  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n  textarea:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n  max-width: 100%; }\n  textarea[rows] {\n    height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0; }\n\ninput[type='search'] {\n  box-sizing: border-box; }\n\n::placeholder {\n  color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n  display: inline-block;\n  vertical-align: baseline;\n  margin-left: 0.5rem;\n  margin-right: 1rem;\n  margin-bottom: 0; }\n  [type='checkbox'] + label[for],\n  [type='radio'] + label[for] {\n    cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem; }\n\n[type='file'] {\n  width: 100%; }\n\nlabel {\n  display: block;\n  margin: 0;\n  font-size: 0.875rem;\n  font-weight: normal;\n  line-height: 1.8;\n  color: #0a0a0a; }\n  label.middle {\n    margin: 0 0 1rem;\n    padding: 0.5625rem 0; }\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a; }\n\n.input-group {\n  display: flex;\n  width: 100%;\n  margin-bottom: 1rem;\n  align-items: stretch; }\n  .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n  .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  margin: 0;\n  white-space: nowrap; }\n\n.input-group-label {\n  padding: 0 1rem;\n  border: 1px solid #cacaca;\n  background: #e6e6e6;\n  color: #0a0a0a;\n  text-align: center;\n  white-space: nowrap;\n  display: flex;\n  flex: 0 0 auto;\n  align-items: center; }\n  .input-group-label:first-child {\n    border-right: 0; }\n  .input-group-label:last-child {\n    border-left: 0; }\n\n.input-group-field {\n  border-radius: 0;\n  flex: 1 1 0px;\n  min-width: 0; }\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  display: flex;\n  flex: 0 0 auto; }\n  .input-group-button a,\n  .input-group-button input,\n  .input-group-button button,\n  .input-group-button label {\n    align-self: stretch;\n    height: auto;\n    padding-top: 0;\n    padding-bottom: 0;\n    font-size: 1rem; }\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0; }\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem; }\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca; }\n  .fieldset legend {\n    margin: 0;\n    margin-left: -0.1875rem;\n    padding: 0 0.1875rem; }\n\nselect {\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  appearance: none;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>\");\n  background-origin: content-box;\n  background-position: right -1rem center;\n  background-repeat: no-repeat;\n  background-size: 9px 6px;\n  padding-right: 1.5rem;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  @media screen and (min-width: 0\\0) {\n    select {\n      background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n  select:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  select:disabled {\n    background-color: #e6e6e6;\n    cursor: not-allowed; }\n  select::-ms-expand {\n    display: none; }\n  select[multiple] {\n    height: auto;\n    background-image: none; }\n  select:not([multiple]) {\n    padding-top: 0;\n    padding-bottom: 0; }\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea; }\n  .is-invalid-input:not(:focus)::placeholder {\n    color: #cc4b37; }\n\n.is-invalid-label {\n  color: #cc4b37; }\n\n.form-error {\n  display: none;\n  margin-top: -0.5rem;\n  margin-bottom: 1rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #cc4b37; }\n  .form-error.is-visible {\n    display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n  margin: 0;\n  padding: 0; }\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility; }\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit; }\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit; }\n\nsmall {\n  font-size: 80%;\n  line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  font-family: \"Helvetica Neue\", Helvetica;\n  font-style: normal;\n  font-weight: normal;\n  color: inherit;\n  text-rendering: optimizeLegibility; }\n  h1 small, .h1 small,\n  h2 small, .h2 small,\n  h3 small, .h3 small,\n  h4 small, .h4 small,\n  h5 small, .h5 small,\n  h6 small, .h6 small {\n    line-height: 0;\n    color: #cacaca; }\n\nh1, .h1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  h1, .h1 {\n    font-size: 1.5rem; }\n  h2, .h2 {\n    font-size: 1.25rem; }\n  h3, .h3 {\n    font-size: 1.1875rem; }\n  h4, .h4 {\n    font-size: 1.125rem; }\n  h5, .h5 {\n    font-size: 1.0625rem; }\n  h6, .h6 {\n    font-size: 1rem; } }\n\na {\n  line-height: inherit;\n  color: #2D6699;\n  text-decoration: none;\n  cursor: pointer; }\n  a:hover, a:focus {\n    color: #275884; }\n  a img {\n    border: 0; }\n\nhr {\n  clear: both;\n  max-width: 75rem;\n  height: 0;\n  margin: 1.25rem auto;\n  border-top: 0;\n  border-right: 0;\n  border-bottom: 1px solid #cacaca;\n  border-left: 0; }\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6; }\n\nli {\n  font-size: inherit; }\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc; }\n\nol {\n  margin-left: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0; }\n\ndl {\n  margin-bottom: 1rem; }\n  dl dt {\n    margin-bottom: 0.3rem;\n    font-weight: bold; }\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca; }\n  blockquote, blockquote p {\n    line-height: 1.6;\n    color: #8a8a8a; }\n\nabbr, abbr[title] {\n  border-bottom: 1px dotted #0a0a0a;\n  cursor: help;\n  text-decoration: none; }\n\nfigure {\n  margin: 0; }\n\nkbd {\n  margin: 0;\n  padding: 0.125rem 0.25rem 0;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  color: #0a0a0a; }\n\n.subheader {\n  margin-top: 0.2rem;\n  margin-bottom: 0.5rem;\n  font-weight: normal;\n  line-height: 1.4;\n  color: #8a8a8a; }\n\n.lead {\n  font-size: 125%;\n  line-height: 1.6; }\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1; }\n  p + .stat {\n    margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n  margin-left: 0;\n  list-style: none; }\n\n.cite-block, cite {\n  display: block;\n  color: #8a8a8a;\n  font-size: 0.8125rem; }\n  .cite-block:before, cite:before {\n    content: \"— \"; }\n\n.code-inline, code {\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  display: inline;\n  max-width: 100%;\n  word-wrap: break-word;\n  padding: 0.125rem 0.3125rem 0.0625rem; }\n\n.code-block {\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  display: block;\n  overflow: auto;\n  white-space: pre;\n  padding: 1rem;\n  margin-bottom: 1.5rem; }\n\n.text-left {\n  text-align: left; }\n\n.text-right {\n  text-align: right; }\n\n.text-center {\n  text-align: center; }\n\n.text-justify {\n  text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left; }\n  .medium-text-right {\n    text-align: right; }\n  .medium-text-center {\n    text-align: center; }\n  .medium-text-justify {\n    text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left; }\n  .large-text-right {\n    text-align: right; }\n  .large-text-center {\n    text-align: center; }\n  .large-text-justify {\n    text-align: justify; } }\n\n.show-for-print {\n  display: none !important; }\n\n@media print {\n  * {\n    background: transparent !important;\n    color: black !important;\n    color-adjust: economy;\n    box-shadow: none !important;\n    text-shadow: none !important; }\n  .show-for-print {\n    display: block !important; }\n  .hide-for-print {\n    display: none !important; }\n  table.show-for-print {\n    display: table !important; }\n  thead.show-for-print {\n    display: table-header-group !important; }\n  tbody.show-for-print {\n    display: table-row-group !important; }\n  tr.show-for-print {\n    display: table-row !important; }\n  td.show-for-print {\n    display: table-cell !important; }\n  th.show-for-print {\n    display: table-cell !important; }\n  a,\n  a:visited {\n    text-decoration: underline; }\n  a[href]:after {\n    content: \" (\" attr(href) \")\"; }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: ''; }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\"; }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid; }\n  thead {\n    display: table-header-group; }\n  tr,\n  img {\n    page-break-inside: avoid; }\n  img {\n    max-width: 100% !important; }\n  @page {\n    margin: 0.5cm; }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3; }\n  h2,\n  h3 {\n    page-break-after: avoid; }\n  .print-break-inside {\n    page-break-inside: auto; } }\n\n.grid-container {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  max-width: 75rem;\n  margin-left: auto;\n  margin-right: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .grid-container.fluid {\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n    @media print, screen and (min-width: 40em) {\n      .grid-container.fluid {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n  .grid-container.full {\n    padding-right: 0;\n    padding-left: 0;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n\n.grid-x {\n  display: flex;\n  flex-flow: row wrap; }\n\n.cell {\n  flex: 0 0 auto;\n  min-height: 0px;\n  min-width: 0px;\n  width: 100%; }\n  .cell.auto {\n    flex: 1 1 0px; }\n  .cell.shrink {\n    flex: 0 0 auto; }\n\n.grid-x > .auto {\n  width: auto; }\n\n.grid-x > .shrink {\n  width: auto; }\n\n.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex-basis: auto; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex-basis: auto; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex-basis: auto; } }\n\n.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex: 0 0 auto; }\n\n.grid-x > .small-1 {\n  width: 8.33333%; }\n\n.grid-x > .small-2 {\n  width: 16.66667%; }\n\n.grid-x > .small-3 {\n  width: 25%; }\n\n.grid-x > .small-4 {\n  width: 33.33333%; }\n\n.grid-x > .small-5 {\n  width: 41.66667%; }\n\n.grid-x > .small-6 {\n  width: 50%; }\n\n.grid-x > .small-7 {\n  width: 58.33333%; }\n\n.grid-x > .small-8 {\n  width: 66.66667%; }\n\n.grid-x > .small-9 {\n  width: 75%; }\n\n.grid-x > .small-10 {\n  width: 83.33333%; }\n\n.grid-x > .small-11 {\n  width: 91.66667%; }\n\n.grid-x > .small-12 {\n  width: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex: 0 0 auto; }\n  .grid-x > .medium-shrink {\n    width: auto; }\n  .grid-x > .medium-1 {\n    width: 8.33333%; }\n  .grid-x > .medium-2 {\n    width: 16.66667%; }\n  .grid-x > .medium-3 {\n    width: 25%; }\n  .grid-x > .medium-4 {\n    width: 33.33333%; }\n  .grid-x > .medium-5 {\n    width: 41.66667%; }\n  .grid-x > .medium-6 {\n    width: 50%; }\n  .grid-x > .medium-7 {\n    width: 58.33333%; }\n  .grid-x > .medium-8 {\n    width: 66.66667%; }\n  .grid-x > .medium-9 {\n    width: 75%; }\n  .grid-x > .medium-10 {\n    width: 83.33333%; }\n  .grid-x > .medium-11 {\n    width: 91.66667%; }\n  .grid-x > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex: 0 0 auto; }\n  .grid-x > .large-shrink {\n    width: auto; }\n  .grid-x > .large-1 {\n    width: 8.33333%; }\n  .grid-x > .large-2 {\n    width: 16.66667%; }\n  .grid-x > .large-3 {\n    width: 25%; }\n  .grid-x > .large-4 {\n    width: 33.33333%; }\n  .grid-x > .large-5 {\n    width: 41.66667%; }\n  .grid-x > .large-6 {\n    width: 50%; }\n  .grid-x > .large-7 {\n    width: 58.33333%; }\n  .grid-x > .large-8 {\n    width: 66.66667%; }\n  .grid-x > .large-9 {\n    width: 75%; }\n  .grid-x > .large-10 {\n    width: 83.33333%; }\n  .grid-x > .large-11 {\n    width: 91.66667%; }\n  .grid-x > .large-12 {\n    width: 100%; } }\n\n.grid-margin-x:not(.grid-x) > .cell {\n  width: auto; }\n\n.grid-margin-y:not(.grid-y) > .cell {\n  height: auto; }\n\n.grid-margin-x {\n  margin-left: -0.625rem;\n  margin-right: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x {\n      margin-left: -0.9375rem;\n      margin-right: -0.9375rem; } }\n  .grid-margin-x > .cell {\n    width: calc(100% - 1.25rem);\n    margin-left: 0.625rem;\n    margin-right: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .cell {\n      width: calc(100% - 1.875rem);\n      margin-left: 0.9375rem;\n      margin-right: 0.9375rem; } }\n  .grid-margin-x > .auto {\n    width: auto; }\n  .grid-margin-x > .shrink {\n    width: auto; }\n  .grid-margin-x > .small-1 {\n    width: calc(8.33333% - 1.25rem); }\n  .grid-margin-x > .small-2 {\n    width: calc(16.66667% - 1.25rem); }\n  .grid-margin-x > .small-3 {\n    width: calc(25% - 1.25rem); }\n  .grid-margin-x > .small-4 {\n    width: calc(33.33333% - 1.25rem); }\n  .grid-margin-x > .small-5 {\n    width: calc(41.66667% - 1.25rem); }\n  .grid-margin-x > .small-6 {\n    width: calc(50% - 1.25rem); }\n  .grid-margin-x > .small-7 {\n    width: calc(58.33333% - 1.25rem); }\n  .grid-margin-x > .small-8 {\n    width: calc(66.66667% - 1.25rem); }\n  .grid-margin-x > .small-9 {\n    width: calc(75% - 1.25rem); }\n  .grid-margin-x > .small-10 {\n    width: calc(83.33333% - 1.25rem); }\n  .grid-margin-x > .small-11 {\n    width: calc(91.66667% - 1.25rem); }\n  .grid-margin-x > .small-12 {\n    width: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .auto {\n      width: auto; }\n    .grid-margin-x > .shrink {\n      width: auto; }\n    .grid-margin-x > .small-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .small-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .small-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .small-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .small-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .small-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .small-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .small-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .small-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .small-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .small-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .small-12 {\n      width: calc(100% - 1.875rem); }\n    .grid-margin-x > .medium-auto {\n      width: auto; }\n    .grid-margin-x > .medium-shrink {\n      width: auto; }\n    .grid-margin-x > .medium-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .medium-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .medium-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .medium-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .medium-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .medium-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .medium-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .medium-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .medium-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .medium-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .medium-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .medium-12 {\n      width: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-x > .large-auto {\n      width: auto; }\n    .grid-margin-x > .large-shrink {\n      width: auto; }\n    .grid-margin-x > .large-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .large-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .large-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .large-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .large-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .large-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .large-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .large-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .large-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .large-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .large-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .large-12 {\n      width: calc(100% - 1.875rem); } }\n\n.grid-padding-x .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-container:not(.full) > .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container:not(.full) > .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-padding-x > .cell {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x > .cell {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n\n.small-up-1 > .cell {\n  width: 100%; }\n\n.small-up-2 > .cell {\n  width: 50%; }\n\n.small-up-3 > .cell {\n  width: 33.33333%; }\n\n.small-up-4 > .cell {\n  width: 25%; }\n\n.small-up-5 > .cell {\n  width: 20%; }\n\n.small-up-6 > .cell {\n  width: 16.66667%; }\n\n.small-up-7 > .cell {\n  width: 14.28571%; }\n\n.small-up-8 > .cell {\n  width: 12.5%; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-up-1 > .cell {\n    width: 100%; }\n  .medium-up-2 > .cell {\n    width: 50%; }\n  .medium-up-3 > .cell {\n    width: 33.33333%; }\n  .medium-up-4 > .cell {\n    width: 25%; }\n  .medium-up-5 > .cell {\n    width: 20%; }\n  .medium-up-6 > .cell {\n    width: 16.66667%; }\n  .medium-up-7 > .cell {\n    width: 14.28571%; }\n  .medium-up-8 > .cell {\n    width: 12.5%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-up-1 > .cell {\n    width: 100%; }\n  .large-up-2 > .cell {\n    width: 50%; }\n  .large-up-3 > .cell {\n    width: 33.33333%; }\n  .large-up-4 > .cell {\n    width: 25%; }\n  .large-up-5 > .cell {\n    width: 20%; }\n  .large-up-6 > .cell {\n    width: 16.66667%; }\n  .large-up-7 > .cell {\n    width: 14.28571%; }\n  .large-up-8 > .cell {\n    width: 12.5%; } }\n\n.grid-margin-x.small-up-1 > .cell {\n  width: calc(100% - 1.25rem); }\n\n.grid-margin-x.small-up-2 > .cell {\n  width: calc(50% - 1.25rem); }\n\n.grid-margin-x.small-up-3 > .cell {\n  width: calc(33.33333% - 1.25rem); }\n\n.grid-margin-x.small-up-4 > .cell {\n  width: calc(25% - 1.25rem); }\n\n.grid-margin-x.small-up-5 > .cell {\n  width: calc(20% - 1.25rem); }\n\n.grid-margin-x.small-up-6 > .cell {\n  width: calc(16.66667% - 1.25rem); }\n\n.grid-margin-x.small-up-7 > .cell {\n  width: calc(14.28571% - 1.25rem); }\n\n.grid-margin-x.small-up-8 > .cell {\n  width: calc(12.5% - 1.25rem); }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-x.small-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.small-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.small-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.small-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.small-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.small-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.small-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.small-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); }\n  .grid-margin-x.medium-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.medium-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.medium-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.medium-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.medium-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.medium-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.medium-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.medium-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-x.large-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.large-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.large-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.large-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.large-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.large-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.large-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.large-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n.small-margin-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-margin-collapse > .cell {\n    margin-right: 0;\n    margin-left: 0; }\n  .small-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .small-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .small-margin-collapse > .small-3 {\n    width: 25%; }\n  .small-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .small-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .small-margin-collapse > .small-6 {\n    width: 50%; }\n  .small-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .small-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .small-margin-collapse > .small-9 {\n    width: 75%; }\n  .small-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .small-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .small-margin-collapse > .small-12 {\n    width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .small-margin-collapse > .medium-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .medium-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .medium-3 {\n      width: 25%; }\n    .small-margin-collapse > .medium-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .medium-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .medium-6 {\n      width: 50%; }\n    .small-margin-collapse > .medium-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .medium-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .medium-9 {\n      width: 75%; }\n    .small-margin-collapse > .medium-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .medium-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .medium-12 {\n      width: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .small-margin-collapse > .large-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .large-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .large-3 {\n      width: 25%; }\n    .small-margin-collapse > .large-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .large-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .large-6 {\n      width: 50%; }\n    .small-margin-collapse > .large-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .large-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .large-9 {\n      width: 75%; }\n    .small-margin-collapse > .large-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .large-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .large-12 {\n      width: 100%; } }\n\n.small-padding-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-padding-collapse > .cell {\n    padding-right: 0;\n    padding-left: 0; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .small-3 {\n    width: 25%; }\n  .medium-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .small-6 {\n    width: 50%; }\n  .medium-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .small-9 {\n    width: 75%; }\n  .medium-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .medium-3 {\n    width: 25%; }\n  .medium-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .medium-6 {\n    width: 50%; }\n  .medium-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .medium-9 {\n    width: 75%; }\n  .medium-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .medium-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .large-3 {\n    width: 25%; }\n  .medium-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .large-6 {\n    width: 50%; }\n  .medium-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .large-9 {\n    width: 75%; }\n  .medium-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .small-3 {\n    width: 25%; }\n  .large-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .small-6 {\n    width: 50%; }\n  .large-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .small-9 {\n    width: 75%; }\n  .large-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .medium-3 {\n    width: 25%; }\n  .large-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .medium-6 {\n    width: 50%; }\n  .large-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .medium-9 {\n    width: 75%; }\n  .large-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .large-3 {\n    width: 25%; }\n  .large-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .large-6 {\n    width: 50%; }\n  .large-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .large-9 {\n    width: 75%; }\n  .large-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n.small-offset-0 {\n  margin-left: 0%; }\n\n.grid-margin-x > .small-offset-0 {\n  margin-left: calc(0% + 0.625rem); }\n\n.small-offset-1 {\n  margin-left: 8.33333%; }\n\n.grid-margin-x > .small-offset-1 {\n  margin-left: calc(8.33333% + 0.625rem); }\n\n.small-offset-2 {\n  margin-left: 16.66667%; }\n\n.grid-margin-x > .small-offset-2 {\n  margin-left: calc(16.66667% + 0.625rem); }\n\n.small-offset-3 {\n  margin-left: 25%; }\n\n.grid-margin-x > .small-offset-3 {\n  margin-left: calc(25% + 0.625rem); }\n\n.small-offset-4 {\n  margin-left: 33.33333%; }\n\n.grid-margin-x > .small-offset-4 {\n  margin-left: calc(33.33333% + 0.625rem); }\n\n.small-offset-5 {\n  margin-left: 41.66667%; }\n\n.grid-margin-x > .small-offset-5 {\n  margin-left: calc(41.66667% + 0.625rem); }\n\n.small-offset-6 {\n  margin-left: 50%; }\n\n.grid-margin-x > .small-offset-6 {\n  margin-left: calc(50% + 0.625rem); }\n\n.small-offset-7 {\n  margin-left: 58.33333%; }\n\n.grid-margin-x > .small-offset-7 {\n  margin-left: calc(58.33333% + 0.625rem); }\n\n.small-offset-8 {\n  margin-left: 66.66667%; }\n\n.grid-margin-x > .small-offset-8 {\n  margin-left: calc(66.66667% + 0.625rem); }\n\n.small-offset-9 {\n  margin-left: 75%; }\n\n.grid-margin-x > .small-offset-9 {\n  margin-left: calc(75% + 0.625rem); }\n\n.small-offset-10 {\n  margin-left: 83.33333%; }\n\n.grid-margin-x > .small-offset-10 {\n  margin-left: calc(83.33333% + 0.625rem); }\n\n.small-offset-11 {\n  margin-left: 91.66667%; }\n\n.grid-margin-x > .small-offset-11 {\n  margin-left: calc(91.66667% + 0.625rem); }\n\n@media print, screen and (min-width: 40em) {\n  .medium-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .medium-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .medium-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .medium-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .medium-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .medium-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .medium-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .medium-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .medium-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .medium-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .medium-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .medium-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .medium-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .medium-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .medium-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .medium-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .medium-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .medium-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .medium-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .medium-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .medium-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .medium-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .medium-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .medium-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .large-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .large-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .large-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .large-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .large-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .large-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .large-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .large-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .large-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .large-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .large-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .large-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .large-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .large-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .large-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .large-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .large-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .large-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .large-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .large-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .large-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .large-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .large-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .large-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n.grid-y {\n  display: flex;\n  flex-flow: column nowrap; }\n  .grid-y > .cell {\n    height: auto;\n    max-height: none; }\n  .grid-y > .auto {\n    height: auto; }\n  .grid-y > .shrink {\n    height: auto; }\n  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex-basis: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex-basis: auto; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex-basis: auto; } }\n  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex: 0 0 auto; }\n  .grid-y > .small-1 {\n    height: 8.33333%; }\n  .grid-y > .small-2 {\n    height: 16.66667%; }\n  .grid-y > .small-3 {\n    height: 25%; }\n  .grid-y > .small-4 {\n    height: 33.33333%; }\n  .grid-y > .small-5 {\n    height: 41.66667%; }\n  .grid-y > .small-6 {\n    height: 50%; }\n  .grid-y > .small-7 {\n    height: 58.33333%; }\n  .grid-y > .small-8 {\n    height: 66.66667%; }\n  .grid-y > .small-9 {\n    height: 75%; }\n  .grid-y > .small-10 {\n    height: 83.33333%; }\n  .grid-y > .small-11 {\n    height: 91.66667%; }\n  .grid-y > .small-12 {\n    height: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex: 0 0 auto; }\n    .grid-y > .medium-shrink {\n      height: auto; }\n    .grid-y > .medium-1 {\n      height: 8.33333%; }\n    .grid-y > .medium-2 {\n      height: 16.66667%; }\n    .grid-y > .medium-3 {\n      height: 25%; }\n    .grid-y > .medium-4 {\n      height: 33.33333%; }\n    .grid-y > .medium-5 {\n      height: 41.66667%; }\n    .grid-y > .medium-6 {\n      height: 50%; }\n    .grid-y > .medium-7 {\n      height: 58.33333%; }\n    .grid-y > .medium-8 {\n      height: 66.66667%; }\n    .grid-y > .medium-9 {\n      height: 75%; }\n    .grid-y > .medium-10 {\n      height: 83.33333%; }\n    .grid-y > .medium-11 {\n      height: 91.66667%; }\n    .grid-y > .medium-12 {\n      height: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex: 0 0 auto; }\n    .grid-y > .large-shrink {\n      height: auto; }\n    .grid-y > .large-1 {\n      height: 8.33333%; }\n    .grid-y > .large-2 {\n      height: 16.66667%; }\n    .grid-y > .large-3 {\n      height: 25%; }\n    .grid-y > .large-4 {\n      height: 33.33333%; }\n    .grid-y > .large-5 {\n      height: 41.66667%; }\n    .grid-y > .large-6 {\n      height: 50%; }\n    .grid-y > .large-7 {\n      height: 58.33333%; }\n    .grid-y > .large-8 {\n      height: 66.66667%; }\n    .grid-y > .large-9 {\n      height: 75%; }\n    .grid-y > .large-10 {\n      height: 83.33333%; }\n    .grid-y > .large-11 {\n      height: 91.66667%; }\n    .grid-y > .large-12 {\n      height: 100%; } }\n\n.grid-padding-y .grid-padding-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y .grid-padding-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n\n.grid-padding-y > .cell {\n  padding-top: 0.625rem;\n  padding-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y > .cell {\n      padding-top: 0.9375rem;\n      padding-bottom: 0.9375rem; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame {\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  width: 100vw; }\n\n.cell .grid-frame {\n  width: 100%; }\n\n.cell-block {\n  overflow-x: auto;\n  max-width: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-y {\n  overflow-y: auto;\n  max-height: 100%;\n  min-height: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-container {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%; }\n  .cell-block-container > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .medium-grid-frame {\n    width: 100%; }\n  .medium-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .medium-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .medium-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .medium-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .large-grid-frame {\n    width: 100%; }\n  .large-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .large-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .large-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .large-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n.grid-y.grid-frame {\n  width: auto;\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  height: 100vh; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-y.medium-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-y.large-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n.cell .grid-y.grid-frame {\n  height: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .cell .grid-y.medium-grid-frame {\n    height: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .cell .grid-y.large-grid-frame {\n    height: 100%; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame.grid-margin-y {\n  height: calc(100vh + 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-y.medium-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-y.large-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-family: inherit;\n  font-size: 0.9rem;\n  -webkit-appearance: none;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .button {\n    outline: 0; }\n  .button.tiny {\n    font-size: 0.6rem; }\n  .button.small {\n    font-size: 0.75rem; }\n  .button.large {\n    font-size: 1.25rem; }\n  .button.expanded {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0; }\n  .button, .button.disabled, .button[disabled], .button.disabled:hover, .button[disabled]:hover, .button.disabled:focus, .button[disabled]:focus {\n    background-color: #2D6699;\n    color: #fefefe; }\n  .button:hover, .button:focus {\n    background-color: #265782;\n    color: #fefefe; }\n  .button.primary, .button.primary.disabled, .button.primary[disabled], .button.primary.disabled:hover, .button.primary[disabled]:hover, .button.primary.disabled:focus, .button.primary[disabled]:focus {\n    background-color: #2D6699;\n    color: #fefefe; }\n  .button.primary:hover, .button.primary:focus {\n    background-color: #24527a;\n    color: #fefefe; }\n  .button.secondary, .button.secondary.disabled, .button.secondary[disabled], .button.secondary.disabled:hover, .button.secondary[disabled]:hover, .button.secondary.disabled:focus, .button.secondary[disabled]:focus {\n    background-color: #A6ADB4;\n    color: #0a0a0a; }\n  .button.secondary:hover, .button.secondary:focus {\n    background-color: #808a94;\n    color: #0a0a0a; }\n  .button.success, .button.success.disabled, .button.success[disabled], .button.success.disabled:hover, .button.success[disabled]:hover, .button.success.disabled:focus, .button.success[disabled]:focus {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n  .button.success:hover, .button.success:focus {\n    background-color: #22bb5b;\n    color: #0a0a0a; }\n  .button.warning, .button.warning.disabled, .button.warning[disabled], .button.warning.disabled:hover, .button.warning[disabled]:hover, .button.warning.disabled:focus, .button.warning[disabled]:focus {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n  .button.warning:hover, .button.warning:focus {\n    background-color: #cc8b00;\n    color: #0a0a0a; }\n  .button.alert, .button.alert.disabled, .button.alert[disabled], .button.alert.disabled:hover, .button.alert[disabled]:hover, .button.alert.disabled:focus, .button.alert[disabled]:focus {\n    background-color: #cc4b37;\n    color: #fefefe; }\n  .button.alert:hover, .button.alert:focus {\n    background-color: #a53b2a;\n    color: #fefefe; }\n  .button.hollow, .button.hollow:hover, .button.hollow:focus, .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n    background-color: transparent; }\n  .button.hollow, .button.hollow.disabled, .button.hollow[disabled], .button.hollow.disabled:hover, .button.hollow[disabled]:hover, .button.hollow.disabled:focus, .button.hollow[disabled]:focus {\n    border: 1px solid #2D6699;\n    color: #2D6699; }\n  .button.hollow:hover, .button.hollow:focus {\n    border-color: #17334d;\n    color: #17334d; }\n  .button.hollow.primary, .button.hollow.primary.disabled, .button.hollow.primary[disabled], .button.hollow.primary.disabled:hover, .button.hollow.primary[disabled]:hover, .button.hollow.primary.disabled:focus, .button.hollow.primary[disabled]:focus {\n    border: 1px solid #2D6699;\n    color: #2D6699; }\n  .button.hollow.primary:hover, .button.hollow.primary:focus {\n    border-color: #17334d;\n    color: #17334d; }\n  .button.hollow.secondary, .button.hollow.secondary.disabled, .button.hollow.secondary[disabled], .button.hollow.secondary.disabled:hover, .button.hollow.secondary[disabled]:hover, .button.hollow.secondary.disabled:focus, .button.hollow.secondary[disabled]:focus {\n    border: 1px solid #A6ADB4;\n    color: #A6ADB4; }\n  .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n    border-color: #4f575e;\n    color: #4f575e; }\n  .button.hollow.success, .button.hollow.success.disabled, .button.hollow.success[disabled], .button.hollow.success.disabled:hover, .button.hollow.success[disabled]:hover, .button.hollow.success.disabled:focus, .button.hollow.success[disabled]:focus {\n    border: 1px solid #3adb76;\n    color: #3adb76; }\n  .button.hollow.success:hover, .button.hollow.success:focus {\n    border-color: #157539;\n    color: #157539; }\n  .button.hollow.warning, .button.hollow.warning.disabled, .button.hollow.warning[disabled], .button.hollow.warning.disabled:hover, .button.hollow.warning[disabled]:hover, .button.hollow.warning.disabled:focus, .button.hollow.warning[disabled]:focus {\n    border: 1px solid #ffae00;\n    color: #ffae00; }\n  .button.hollow.warning:hover, .button.hollow.warning:focus {\n    border-color: #805700;\n    color: #805700; }\n  .button.hollow.alert, .button.hollow.alert.disabled, .button.hollow.alert[disabled], .button.hollow.alert.disabled:hover, .button.hollow.alert[disabled]:hover, .button.hollow.alert.disabled:focus, .button.hollow.alert[disabled]:focus {\n    border: 1px solid #cc4b37;\n    color: #cc4b37; }\n  .button.hollow.alert:hover, .button.hollow.alert:focus {\n    border-color: #67251a;\n    color: #67251a; }\n  .button.clear, .button.clear:hover, .button.clear:focus, .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n    border-color: transparent;\n    background-color: transparent; }\n  .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear.disabled:hover, .button.clear[disabled]:hover, .button.clear.disabled:focus, .button.clear[disabled]:focus {\n    color: #2D6699; }\n  .button.clear:hover, .button.clear:focus {\n    color: #17334d; }\n  .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary.disabled:hover, .button.clear.primary[disabled]:hover, .button.clear.primary.disabled:focus, .button.clear.primary[disabled]:focus {\n    color: #2D6699; }\n  .button.clear.primary:hover, .button.clear.primary:focus {\n    color: #17334d; }\n  .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary.disabled:hover, .button.clear.secondary[disabled]:hover, .button.clear.secondary.disabled:focus, .button.clear.secondary[disabled]:focus {\n    color: #A6ADB4; }\n  .button.clear.secondary:hover, .button.clear.secondary:focus {\n    color: #4f575e; }\n  .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success.disabled:hover, .button.clear.success[disabled]:hover, .button.clear.success.disabled:focus, .button.clear.success[disabled]:focus {\n    color: #3adb76; }\n  .button.clear.success:hover, .button.clear.success:focus {\n    color: #157539; }\n  .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning.disabled:hover, .button.clear.warning[disabled]:hover, .button.clear.warning.disabled:focus, .button.clear.warning[disabled]:focus {\n    color: #ffae00; }\n  .button.clear.warning:hover, .button.clear.warning:focus {\n    color: #805700; }\n  .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert.disabled:hover, .button.clear.alert[disabled]:hover, .button.clear.alert.disabled:focus, .button.clear.alert[disabled]:focus {\n    color: #cc4b37; }\n  .button.clear.alert:hover, .button.clear.alert:focus {\n    color: #67251a; }\n  .button.disabled, .button[disabled] {\n    opacity: 0.25;\n    cursor: not-allowed; }\n  .button.dropdown::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.4em;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #fefefe transparent transparent;\n    position: relative;\n    top: 0.4em;\n    display: inline-block;\n    float: right;\n    margin-left: 1em; }\n  .button.dropdown.hollow::after, .button.dropdown.clear::after {\n    border-top-color: #2D6699; }\n  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n    border-top-color: #2D6699; }\n  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n    border-top-color: #A6ADB4; }\n  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n    border-top-color: #3adb76; }\n  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n    border-top-color: #ffae00; }\n  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n    border-top-color: #cc4b37; }\n  .button.arrow-only::after {\n    top: -0.1em;\n    float: none;\n    margin-left: 0; }\n\na.button:hover, a.button:focus {\n  text-decoration: none; }\n\n.button-group {\n  margin-bottom: 1rem;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: stretch;\n  flex-grow: 1; }\n  .button-group::before, .button-group::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .button-group::after {\n    clear: both; }\n  .button-group::before, .button-group::after {\n    display: none; }\n  .button-group .button {\n    margin: 0;\n    margin-right: 1px;\n    margin-bottom: 1px;\n    font-size: 0.9rem;\n    flex: 0 0 auto; }\n    .button-group .button:last-child {\n      margin-right: 0; }\n  .button-group.tiny .button {\n    font-size: 0.6rem; }\n  .button-group.small .button {\n    font-size: 0.75rem; }\n  .button-group.large .button {\n    font-size: 1.25rem; }\n  .button-group.expanded .button {\n    flex: 1 1 0px;\n    margin-right: 0; }\n  .button-group.primary .button, .button-group.primary .button.disabled, .button-group.primary .button[disabled], .button-group.primary .button.disabled:hover, .button-group.primary .button[disabled]:hover, .button-group.primary .button.disabled:focus, .button-group.primary .button[disabled]:focus {\n    background-color: #2D6699;\n    color: #fefefe; }\n  .button-group.primary .button:hover, .button-group.primary .button:focus {\n    background-color: #24527a;\n    color: #fefefe; }\n  .button-group.secondary .button, .button-group.secondary .button.disabled, .button-group.secondary .button[disabled], .button-group.secondary .button.disabled:hover, .button-group.secondary .button[disabled]:hover, .button-group.secondary .button.disabled:focus, .button-group.secondary .button[disabled]:focus {\n    background-color: #A6ADB4;\n    color: #0a0a0a; }\n  .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n    background-color: #808a94;\n    color: #0a0a0a; }\n  .button-group.success .button, .button-group.success .button.disabled, .button-group.success .button[disabled], .button-group.success .button.disabled:hover, .button-group.success .button[disabled]:hover, .button-group.success .button.disabled:focus, .button-group.success .button[disabled]:focus {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n  .button-group.success .button:hover, .button-group.success .button:focus {\n    background-color: #22bb5b;\n    color: #0a0a0a; }\n  .button-group.warning .button, .button-group.warning .button.disabled, .button-group.warning .button[disabled], .button-group.warning .button.disabled:hover, .button-group.warning .button[disabled]:hover, .button-group.warning .button.disabled:focus, .button-group.warning .button[disabled]:focus {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n  .button-group.warning .button:hover, .button-group.warning .button:focus {\n    background-color: #cc8b00;\n    color: #0a0a0a; }\n  .button-group.alert .button, .button-group.alert .button.disabled, .button-group.alert .button[disabled], .button-group.alert .button.disabled:hover, .button-group.alert .button[disabled]:hover, .button-group.alert .button.disabled:focus, .button-group.alert .button[disabled]:focus {\n    background-color: #cc4b37;\n    color: #fefefe; }\n  .button-group.alert .button:hover, .button-group.alert .button:focus {\n    background-color: #a53b2a;\n    color: #fefefe; }\n  .button-group.hollow .button, .button-group.hollow .button:hover, .button-group.hollow .button:focus, .button-group.hollow .button.disabled, .button-group.hollow .button.disabled:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled], .button-group.hollow .button[disabled]:hover, .button-group.hollow .button[disabled]:focus {\n    background-color: transparent; }\n  .button-group.hollow .button, .button-group.hollow .button.disabled, .button-group.hollow .button[disabled], .button-group.hollow .button.disabled:hover, .button-group.hollow .button[disabled]:hover, .button-group.hollow .button.disabled:focus, .button-group.hollow .button[disabled]:focus {\n    border: 1px solid #2D6699;\n    color: #2D6699; }\n  .button-group.hollow .button:hover, .button-group.hollow .button:focus {\n    border-color: #17334d;\n    color: #17334d; }\n  .button-group.hollow.primary .button, .button-group.hollow.primary .button.disabled, .button-group.hollow.primary .button[disabled], .button-group.hollow.primary .button.disabled:hover, .button-group.hollow.primary .button[disabled]:hover, .button-group.hollow.primary .button.disabled:focus, .button-group.hollow.primary .button[disabled]:focus, .button-group.hollow .button.primary, .button-group.hollow .button.primary.disabled, .button-group.hollow .button.primary[disabled], .button-group.hollow .button.primary.disabled:hover, .button-group.hollow .button.primary[disabled]:hover, .button-group.hollow .button.primary.disabled:focus, .button-group.hollow .button.primary[disabled]:focus {\n    border: 1px solid #2D6699;\n    color: #2D6699; }\n  .button-group.hollow.primary .button:hover, .button-group.hollow.primary .button:focus, .button-group.hollow .button.primary:hover, .button-group.hollow .button.primary:focus {\n    border-color: #17334d;\n    color: #17334d; }\n  .button-group.hollow.secondary .button, .button-group.hollow.secondary .button.disabled, .button-group.hollow.secondary .button[disabled], .button-group.hollow.secondary .button.disabled:hover, .button-group.hollow.secondary .button[disabled]:hover, .button-group.hollow.secondary .button.disabled:focus, .button-group.hollow.secondary .button[disabled]:focus, .button-group.hollow .button.secondary, .button-group.hollow .button.secondary.disabled, .button-group.hollow .button.secondary[disabled], .button-group.hollow .button.secondary.disabled:hover, .button-group.hollow .button.secondary[disabled]:hover, .button-group.hollow .button.secondary.disabled:focus, .button-group.hollow .button.secondary[disabled]:focus {\n    border: 1px solid #A6ADB4;\n    color: #A6ADB4; }\n  .button-group.hollow.secondary .button:hover, .button-group.hollow.secondary .button:focus, .button-group.hollow .button.secondary:hover, .button-group.hollow .button.secondary:focus {\n    border-color: #4f575e;\n    color: #4f575e; }\n  .button-group.hollow.success .button, .button-group.hollow.success .button.disabled, .button-group.hollow.success .button[disabled], .button-group.hollow.success .button.disabled:hover, .button-group.hollow.success .button[disabled]:hover, .button-group.hollow.success .button.disabled:focus, .button-group.hollow.success .button[disabled]:focus, .button-group.hollow .button.success, .button-group.hollow .button.success.disabled, .button-group.hollow .button.success[disabled], .button-group.hollow .button.success.disabled:hover, .button-group.hollow .button.success[disabled]:hover, .button-group.hollow .button.success.disabled:focus, .button-group.hollow .button.success[disabled]:focus {\n    border: 1px solid #3adb76;\n    color: #3adb76; }\n  .button-group.hollow.success .button:hover, .button-group.hollow.success .button:focus, .button-group.hollow .button.success:hover, .button-group.hollow .button.success:focus {\n    border-color: #157539;\n    color: #157539; }\n  .button-group.hollow.warning .button, .button-group.hollow.warning .button.disabled, .button-group.hollow.warning .button[disabled], .button-group.hollow.warning .button.disabled:hover, .button-group.hollow.warning .button[disabled]:hover, .button-group.hollow.warning .button.disabled:focus, .button-group.hollow.warning .button[disabled]:focus, .button-group.hollow .button.warning, .button-group.hollow .button.warning.disabled, .button-group.hollow .button.warning[disabled], .button-group.hollow .button.warning.disabled:hover, .button-group.hollow .button.warning[disabled]:hover, .button-group.hollow .button.warning.disabled:focus, .button-group.hollow .button.warning[disabled]:focus {\n    border: 1px solid #ffae00;\n    color: #ffae00; }\n  .button-group.hollow.warning .button:hover, .button-group.hollow.warning .button:focus, .button-group.hollow .button.warning:hover, .button-group.hollow .button.warning:focus {\n    border-color: #805700;\n    color: #805700; }\n  .button-group.hollow.alert .button, .button-group.hollow.alert .button.disabled, .button-group.hollow.alert .button[disabled], .button-group.hollow.alert .button.disabled:hover, .button-group.hollow.alert .button[disabled]:hover, .button-group.hollow.alert .button.disabled:focus, .button-group.hollow.alert .button[disabled]:focus, .button-group.hollow .button.alert, .button-group.hollow .button.alert.disabled, .button-group.hollow .button.alert[disabled], .button-group.hollow .button.alert.disabled:hover, .button-group.hollow .button.alert[disabled]:hover, .button-group.hollow .button.alert.disabled:focus, .button-group.hollow .button.alert[disabled]:focus {\n    border: 1px solid #cc4b37;\n    color: #cc4b37; }\n  .button-group.hollow.alert .button:hover, .button-group.hollow.alert .button:focus, .button-group.hollow .button.alert:hover, .button-group.hollow .button.alert:focus {\n    border-color: #67251a;\n    color: #67251a; }\n  .button-group.clear .button, .button-group.clear .button:hover, .button-group.clear .button:focus, .button-group.clear .button.disabled, .button-group.clear .button.disabled:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled], .button-group.clear .button[disabled]:hover, .button-group.clear .button[disabled]:focus {\n    border-color: transparent;\n    background-color: transparent; }\n  .button-group.clear .button, .button-group.clear .button.disabled, .button-group.clear .button[disabled], .button-group.clear .button.disabled:hover, .button-group.clear .button[disabled]:hover, .button-group.clear .button.disabled:focus, .button-group.clear .button[disabled]:focus {\n    color: #2D6699; }\n  .button-group.clear .button:hover, .button-group.clear .button:focus {\n    color: #17334d; }\n  .button-group.clear.primary .button, .button-group.clear.primary .button.disabled, .button-group.clear.primary .button[disabled], .button-group.clear.primary .button.disabled:hover, .button-group.clear.primary .button[disabled]:hover, .button-group.clear.primary .button.disabled:focus, .button-group.clear.primary .button[disabled]:focus, .button-group.clear .button.primary, .button-group.clear .button.primary.disabled, .button-group.clear .button.primary[disabled], .button-group.clear .button.primary.disabled:hover, .button-group.clear .button.primary[disabled]:hover, .button-group.clear .button.primary.disabled:focus, .button-group.clear .button.primary[disabled]:focus {\n    color: #2D6699; }\n  .button-group.clear.primary .button:hover, .button-group.clear.primary .button:focus, .button-group.clear .button.primary:hover, .button-group.clear .button.primary:focus {\n    color: #17334d; }\n  .button-group.clear.secondary .button, .button-group.clear.secondary .button.disabled, .button-group.clear.secondary .button[disabled], .button-group.clear.secondary .button.disabled:hover, .button-group.clear.secondary .button[disabled]:hover, .button-group.clear.secondary .button.disabled:focus, .button-group.clear.secondary .button[disabled]:focus, .button-group.clear .button.secondary, .button-group.clear .button.secondary.disabled, .button-group.clear .button.secondary[disabled], .button-group.clear .button.secondary.disabled:hover, .button-group.clear .button.secondary[disabled]:hover, .button-group.clear .button.secondary.disabled:focus, .button-group.clear .button.secondary[disabled]:focus {\n    color: #A6ADB4; }\n  .button-group.clear.secondary .button:hover, .button-group.clear.secondary .button:focus, .button-group.clear .button.secondary:hover, .button-group.clear .button.secondary:focus {\n    color: #4f575e; }\n  .button-group.clear.success .button, .button-group.clear.success .button.disabled, .button-group.clear.success .button[disabled], .button-group.clear.success .button.disabled:hover, .button-group.clear.success .button[disabled]:hover, .button-group.clear.success .button.disabled:focus, .button-group.clear.success .button[disabled]:focus, .button-group.clear .button.success, .button-group.clear .button.success.disabled, .button-group.clear .button.success[disabled], .button-group.clear .button.success.disabled:hover, .button-group.clear .button.success[disabled]:hover, .button-group.clear .button.success.disabled:focus, .button-group.clear .button.success[disabled]:focus {\n    color: #3adb76; }\n  .button-group.clear.success .button:hover, .button-group.clear.success .button:focus, .button-group.clear .button.success:hover, .button-group.clear .button.success:focus {\n    color: #157539; }\n  .button-group.clear.warning .button, .button-group.clear.warning .button.disabled, .button-group.clear.warning .button[disabled], .button-group.clear.warning .button.disabled:hover, .button-group.clear.warning .button[disabled]:hover, .button-group.clear.warning .button.disabled:focus, .button-group.clear.warning .button[disabled]:focus, .button-group.clear .button.warning, .button-group.clear .button.warning.disabled, .button-group.clear .button.warning[disabled], .button-group.clear .button.warning.disabled:hover, .button-group.clear .button.warning[disabled]:hover, .button-group.clear .button.warning.disabled:focus, .button-group.clear .button.warning[disabled]:focus {\n    color: #ffae00; }\n  .button-group.clear.warning .button:hover, .button-group.clear.warning .button:focus, .button-group.clear .button.warning:hover, .button-group.clear .button.warning:focus {\n    color: #805700; }\n  .button-group.clear.alert .button, .button-group.clear.alert .button.disabled, .button-group.clear.alert .button[disabled], .button-group.clear.alert .button.disabled:hover, .button-group.clear.alert .button[disabled]:hover, .button-group.clear.alert .button.disabled:focus, .button-group.clear.alert .button[disabled]:focus, .button-group.clear .button.alert, .button-group.clear .button.alert.disabled, .button-group.clear .button.alert[disabled], .button-group.clear .button.alert.disabled:hover, .button-group.clear .button.alert[disabled]:hover, .button-group.clear .button.alert.disabled:focus, .button-group.clear .button.alert[disabled]:focus {\n    color: #cc4b37; }\n  .button-group.clear.alert .button:hover, .button-group.clear.alert .button:focus, .button-group.clear .button.alert:hover, .button-group.clear .button.alert:focus {\n    color: #67251a; }\n  .button-group.no-gaps .button {\n    margin-right: -0.0625rem; }\n    .button-group.no-gaps .button + .button {\n      border-left-color: transparent; }\n  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {\n    flex-wrap: wrap; }\n    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n      flex: 0 0 100%; }\n      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n        margin-bottom: 0; }\n    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {\n      flex: 1 1 0px;\n      margin-right: 0; }\n  @media print, screen and (min-width: 40em) {\n    .button-group.stacked-for-small .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media print, screen and (min-width: 64em) {\n    .button-group.stacked-for-medium .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media print, screen and (max-width: 39.99875em) {\n    .button-group.stacked-for-small.expanded {\n      display: block; }\n      .button-group.stacked-for-small.expanded .button {\n        display: block;\n        margin-right: 0; } }\n  @media print, screen and (max-width: 63.99875em) {\n    .button-group.stacked-for-medium.expanded {\n      display: block; }\n      .button-group.stacked-for-medium.expanded .button {\n        display: block;\n        margin-right: 0; } }\n\n.close-button {\n  position: absolute;\n  z-index: 10;\n  color: #8a8a8a;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .close-button {\n    outline: 0; }\n  .close-button:hover, .close-button:focus {\n    color: #0a0a0a; }\n  .close-button.small {\n    right: 0.66rem;\n    top: 0.33em;\n    font-size: 1.5em;\n    line-height: 1; }\n  .close-button.medium, .close-button {\n    right: 1rem;\n    top: 0.5rem;\n    font-size: 2em;\n    line-height: 1; }\n\n.label {\n  display: inline-block;\n  padding: 0.33333rem 0.5rem;\n  border-radius: 0;\n  font-size: 0.8rem;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n  background: #2D6699;\n  color: #fefefe; }\n  .label.primary {\n    background: #2D6699;\n    color: #fefefe; }\n  .label.secondary {\n    background: #A6ADB4;\n    color: #0a0a0a; }\n  .label.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .label.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .label.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca; }\n  .progress.primary .progress-meter {\n    background-color: #2D6699; }\n  .progress.secondary .progress-meter {\n    background-color: #A6ADB4; }\n  .progress.success .progress-meter {\n    background-color: #3adb76; }\n  .progress.warning .progress-meter {\n    background-color: #ffae00; }\n  .progress.alert .progress-meter {\n    background-color: #cc4b37; }\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #2D6699; }\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap; }\n\n.slider {\n  position: relative;\n  height: 0.5rem;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n  background-color: #e6e6e6;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none; }\n\n.slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: inline-block;\n  max-width: 100%;\n  height: 0.5rem;\n  background-color: #cacaca;\n  transition: all 0.2s ease-in-out; }\n  .slider-fill.is-dragging {\n    transition: all 0s linear; }\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  left: 0;\n  z-index: 1;\n  display: inline-block;\n  width: 1.4rem;\n  height: 1.4rem;\n  border-radius: 0;\n  background-color: #2D6699;\n  transition: all 0.2s ease-in-out;\n  touch-action: manipulation; }\n  [data-whatinput='mouse'] .slider-handle {\n    outline: 0; }\n  .slider-handle:hover {\n    background-color: #265782; }\n  .slider-handle.is-dragging {\n    transition: all 0s linear; }\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed; }\n\n.slider.vertical {\n  display: inline-block;\n  width: 0.5rem;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1); }\n  .slider.vertical .slider-fill {\n    top: 0;\n    width: 0.5rem;\n    max-height: 100%; }\n  .slider.vertical .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: 1.4rem;\n    height: 1.4rem;\n    transform: translateX(-50%); }\n\n.switch {\n  height: 2rem;\n  position: relative;\n  margin-bottom: 1rem;\n  outline: 0;\n  font-size: 0.875rem;\n  font-weight: bold;\n  color: #fefefe;\n  user-select: none; }\n\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0; }\n\n.switch-paddle {\n  position: relative;\n  display: block;\n  width: 4rem;\n  height: 2rem;\n  border-radius: 0;\n  background: #cacaca;\n  transition: all 0.25s ease-out;\n  font-weight: inherit;\n  color: inherit;\n  cursor: pointer; }\n  input + .switch-paddle {\n    margin: 0; }\n  .switch-paddle::after {\n    position: absolute;\n    top: 0.25rem;\n    left: 0.25rem;\n    display: block;\n    width: 1.5rem;\n    height: 1.5rem;\n    transform: translate3d(0, 0, 0);\n    border-radius: 0;\n    background: #fefefe;\n    transition: all 0.25s ease-out;\n    content: ''; }\n  input:checked ~ .switch-paddle {\n    background: #2D6699; }\n    input:checked ~ .switch-paddle::after {\n      left: 2.25rem; }\n  input:disabled ~ .switch-paddle {\n    cursor: not-allowed;\n    opacity: 0.5; }\n  [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n    outline: 0; }\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%); }\n\n.switch-active {\n  left: 8%;\n  display: none; }\n  input:checked + label > .switch-active {\n    display: block; }\n\n.switch-inactive {\n  right: 15%; }\n  input:checked + label > .switch-inactive {\n    display: none; }\n\n.switch.tiny {\n  height: 1.5rem; }\n  .switch.tiny .switch-paddle {\n    width: 3rem;\n    height: 1.5rem;\n    font-size: 0.625rem; }\n  .switch.tiny .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1rem;\n    height: 1rem; }\n  .switch.tiny input:checked ~ .switch-paddle::after {\n    left: 1.75rem; }\n\n.switch.small {\n  height: 1.75rem; }\n  .switch.small .switch-paddle {\n    width: 3.5rem;\n    height: 1.75rem;\n    font-size: 0.75rem; }\n  .switch.small .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1.25rem;\n    height: 1.25rem; }\n  .switch.small input:checked ~ .switch-paddle::after {\n    left: 2rem; }\n\n.switch.large {\n  height: 2.5rem; }\n  .switch.large .switch-paddle {\n    width: 5rem;\n    height: 2.5rem;\n    font-size: 1rem; }\n  .switch.large .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 2rem;\n    height: 2rem; }\n  .switch.large input:checked ~ .switch-paddle::after {\n    left: 2.75rem; }\n\ntable {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0; }\n  thead,\n  tbody,\n  tfoot {\n    border: 1px solid #f1f1f1;\n    background-color: #fefefe; }\n  caption {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold; }\n  thead {\n    background: #f8f8f8;\n    color: #0a0a0a; }\n  tfoot {\n    background: #f1f1f1;\n    color: #0a0a0a; }\n  thead tr,\n  tfoot tr {\n    background: transparent; }\n  thead th,\n  thead td,\n  tfoot th,\n  tfoot td {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold;\n    text-align: left; }\n  tbody th,\n  tbody td {\n    padding: 0.5rem 0.625rem 0.625rem; }\n  tbody tr:nth-child(even) {\n    border-bottom: 0;\n    background-color: #f1f1f1; }\n  table.unstriped tbody {\n    background-color: #fefefe; }\n    table.unstriped tbody tr {\n      border-bottom: 0;\n      border-bottom: 1px solid #f1f1f1;\n      background-color: #fefefe; }\n\n@media print, screen and (max-width: 63.99875em) {\n  table.stack thead {\n    display: none; }\n  table.stack tfoot {\n    display: none; }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block; }\n  table.stack td {\n    border-top: 0; } }\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto; }\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec; }\n\n.table-scroll {\n  overflow-x: auto; }\n\n.badge {\n  display: inline-block;\n  min-width: 2.1em;\n  padding: 0.3em;\n  border-radius: 50%;\n  font-size: 0.6rem;\n  text-align: center;\n  background: #2D6699;\n  color: #fefefe; }\n  .badge.primary {\n    background: #2D6699;\n    color: #fefefe; }\n  .badge.secondary {\n    background: #A6ADB4;\n    color: #0a0a0a; }\n  .badge.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .badge.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .badge.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none; }\n  .breadcrumbs::before, .breadcrumbs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .breadcrumbs::after {\n    clear: both; }\n  .breadcrumbs li {\n    float: left;\n    font-size: 0.6875rem;\n    color: #0a0a0a;\n    cursor: default;\n    text-transform: uppercase; }\n    .breadcrumbs li:not(:last-child)::after {\n      position: relative;\n      margin: 0 0.75rem;\n      opacity: 1;\n      content: \"/\";\n      color: #cacaca; }\n  .breadcrumbs a {\n    color: #2D6699; }\n    .breadcrumbs a:hover {\n      text-decoration: underline; }\n  .breadcrumbs .disabled {\n    color: #cacaca;\n    cursor: not-allowed; }\n\n.callout {\n  position: relative;\n  margin: 0 0 1rem 0;\n  padding: 1rem;\n  border: 1px solid rgba(10, 10, 10, 0.25);\n  border-radius: 0;\n  background-color: white;\n  color: #0a0a0a; }\n  .callout > :first-child {\n    margin-top: 0; }\n  .callout > :last-child {\n    margin-bottom: 0; }\n  .callout.primary {\n    background-color: #dbe8f4;\n    color: #0a0a0a; }\n  .callout.secondary {\n    background-color: #f2f3f4;\n    color: #0a0a0a; }\n  .callout.success {\n    background-color: #e1faea;\n    color: #0a0a0a; }\n  .callout.warning {\n    background-color: #fff3d9;\n    color: #0a0a0a; }\n  .callout.alert {\n    background-color: #f7e4e1;\n    color: #0a0a0a; }\n  .callout.small {\n    padding-top: 0.5rem;\n    padding-right: 0.5rem;\n    padding-bottom: 0.5rem;\n    padding-left: 0.5rem; }\n  .callout.large {\n    padding-top: 3rem;\n    padding-right: 3rem;\n    padding-bottom: 3rem;\n    padding-left: 3rem; }\n\n.card {\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  margin-bottom: 1rem;\n  border: 1px solid #e6e6e6;\n  border-radius: 0;\n  background: #fefefe;\n  box-shadow: none;\n  overflow: hidden;\n  color: #0a0a0a; }\n  .card > :last-child {\n    margin-bottom: 0; }\n\n.card-divider {\n  display: flex;\n  flex: 0 1 auto;\n  padding: 1rem;\n  background: #e6e6e6; }\n  .card-divider > :last-child {\n    margin-bottom: 0; }\n\n.card-section {\n  flex: 1 0 auto;\n  padding: 1rem; }\n  .card-section > :last-child {\n    margin-bottom: 0; }\n\n.card-image {\n  min-height: 1px; }\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: none;\n  width: 300px;\n  padding: 1rem;\n  visibility: hidden;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #F0F0F0;\n  font-size: 1rem; }\n  .dropdown-pane.is-opening {\n    display: block; }\n  .dropdown-pane.is-open {\n    display: block;\n    visibility: visible; }\n\n.dropdown-pane.tiny {\n  width: 100px; }\n\n.dropdown-pane.small {\n  width: 200px; }\n\n.dropdown-pane.large {\n  width: 400px; }\n\n.pagination {\n  margin-left: 0;\n  margin-bottom: 1rem; }\n  .pagination::before, .pagination::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .pagination::after {\n    clear: both; }\n  .pagination li {\n    margin-right: 0.0625rem;\n    border-radius: 0;\n    font-size: 0.875rem;\n    display: none; }\n    .pagination li:last-child, .pagination li:first-child {\n      display: inline-block; }\n    @media print, screen and (min-width: 40em) {\n      .pagination li {\n        display: inline-block; } }\n  .pagination a,\n  .pagination button {\n    display: block;\n    padding: 0.1875rem 0.625rem;\n    border-radius: 0;\n    color: #0a0a0a; }\n    .pagination a:hover,\n    .pagination button:hover {\n      background: #e6e6e6; }\n  .pagination .current {\n    padding: 0.1875rem 0.625rem;\n    background: #2D6699;\n    color: #fefefe;\n    cursor: default; }\n  .pagination .disabled {\n    padding: 0.1875rem 0.625rem;\n    color: #cacaca;\n    cursor: not-allowed; }\n    .pagination .disabled:hover {\n      background: transparent; }\n  .pagination .ellipsis::after {\n    padding: 0.1875rem 0.625rem;\n    content: '\\2026';\n    color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n  display: inline-block;\n  margin-right: 0.5rem;\n  content: \"«\"; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: \"»\"; }\n\n.has-tip {\n  position: relative;\n  display: inline-block;\n  border-bottom: dotted 1px #8a8a8a;\n  font-weight: bold;\n  cursor: help; }\n\n.tooltip {\n  position: absolute;\n  top: calc(100% + 0.6495rem);\n  z-index: 1200;\n  max-width: 10rem;\n  padding: 0.75rem;\n  border-radius: 0;\n  background-color: #0a0a0a;\n  font-size: 80%;\n  color: #fefefe; }\n  .tooltip::before {\n    position: absolute; }\n  .tooltip.bottom::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent #0a0a0a;\n    bottom: 100%; }\n  .tooltip.bottom.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.top::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #0a0a0a transparent transparent;\n    top: 100%;\n    bottom: auto; }\n  .tooltip.top.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.left::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #0a0a0a;\n    left: 100%; }\n  .tooltip.left.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.right::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #0a0a0a transparent transparent;\n    right: 100%;\n    left: auto; }\n  .tooltip.right.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.align-top::before {\n    bottom: auto;\n    top: 10%; }\n  .tooltip.align-bottom::before {\n    bottom: 10%;\n    top: auto; }\n  .tooltip.align-left::before {\n    left: 10%;\n    right: auto; }\n  .tooltip.align-right::before {\n    left: auto;\n    right: 10%; }\n\n.accordion {\n  margin-left: 0;\n  background: #fefefe;\n  list-style-type: none; }\n  .accordion[disabled] .accordion-title {\n    cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-title {\n  position: relative;\n  display: block;\n  padding: 1.25rem 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  font-size: 0.75rem;\n  line-height: 1;\n  color: #2D6699; }\n  :last-child:not(.is-active) > .accordion-title {\n    border-bottom: 1px solid #e6e6e6;\n    border-radius: 0 0 0 0; }\n  .accordion-title:hover, .accordion-title:focus {\n    background-color: #e6e6e6; }\n  .accordion-title::before {\n    position: absolute;\n    top: 50%;\n    right: 1rem;\n    margin-top: -0.5rem;\n    content: \"+\"; }\n  .is-active > .accordion-title::before {\n    content: \"–\"; }\n\n.accordion-content {\n  display: none;\n  padding: 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  background-color: #fefefe;\n  color: #0a0a0a; }\n  :last-child > .accordion-content:last-child {\n    border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n  display: flex;\n  margin-bottom: 1rem;\n  flex-wrap: nowrap; }\n  .media-object img {\n    max-width: none; }\n  @media print, screen and (max-width: 39.99875em) {\n    .media-object.stack-for-small {\n      flex-wrap: wrap; } }\n\n.media-object-section {\n  flex: 0 1 auto; }\n  .media-object-section:first-child {\n    padding-right: 8rem; }\n  .media-object-section:last-child:not(:nth-child(2)) {\n    padding-left: 8rem; }\n  .media-object-section > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (max-width: 39.99875em) {\n    .stack-for-small .media-object-section {\n      padding: 0;\n      padding-bottom: 8rem;\n      flex-basis: 100%;\n      max-width: 100%; }\n      .stack-for-small .media-object-section img {\n        width: 100%; } }\n  .media-object-section.main-section {\n    flex: 1 1 0px; }\n\n.orbit {\n  position: relative; }\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden; }\n\n.orbit-slide {\n  width: 100%;\n  position: absolute; }\n  .orbit-slide.no-motionui.is-active {\n    top: 0;\n    left: 0; }\n\n.orbit-figure {\n  margin: 0; }\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0; }\n\n.orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: 1rem;\n  background-color: rgba(10, 10, 10, 0.5);\n  color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  z-index: 10;\n  padding: 1rem;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n    outline: 0; }\n  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n    background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n  left: 0; }\n\n.orbit-next {\n  left: auto;\n  right: 0; }\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center; }\n  [data-whatinput='mouse'] .orbit-bullets {\n    outline: 0; }\n  .orbit-bullets button {\n    width: 1.2rem;\n    height: 1.2rem;\n    margin: 0.1rem;\n    border-radius: 50%;\n    background-color: #cacaca; }\n    .orbit-bullets button:hover {\n      background-color: #8a8a8a; }\n    .orbit-bullets button.is-active {\n      background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n  position: relative;\n  height: 0;\n  margin-bottom: 1rem;\n  padding-bottom: 75%;\n  overflow: hidden; }\n  .responsive-embed iframe,\n  .responsive-embed object,\n  .responsive-embed embed,\n  .responsive-embed video,\n  .flex-video iframe,\n  .flex-video object,\n  .flex-video embed,\n  .flex-video video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%; }\n  .responsive-embed.widescreen,\n  .flex-video.widescreen {\n    padding-bottom: 56.25%; }\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none; }\n  .tabs::before, .tabs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .tabs::after {\n    clear: both; }\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto; }\n\n.tabs.simple > li > a {\n  padding: 0; }\n  .tabs.simple > li > a:hover {\n    background: transparent; }\n\n.tabs.primary {\n  background: #2D6699; }\n  .tabs.primary > li > a {\n    color: #fefefe; }\n    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n      background: #316ea5; }\n\n.tabs-title {\n  float: left; }\n  .tabs-title > a {\n    display: block;\n    padding: 1.25rem 1.5rem;\n    font-size: 0.75rem;\n    line-height: 1;\n    color: #2D6699; }\n    [data-whatinput='mouse'] .tabs-title > a {\n      outline: 0; }\n    .tabs-title > a:hover {\n      background: #fefefe;\n      color: #275884; }\n    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n      background: #e6e6e6;\n      color: #2D6699; }\n\n.tabs-content {\n  border: 1px solid #e6e6e6;\n  border-top: 0;\n  background: #fefefe;\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-left: 0; }\n\n.tabs-panel {\n  display: none;\n  padding: 1rem; }\n  .tabs-panel.is-active {\n    display: block; }\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: 4px solid #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0; }\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out; }\n  a.thumbnail:hover, a.thumbnail:focus {\n    box-shadow: 0 0 6px 1px rgba(45, 102, 153, 0.5); }\n  a.thumbnail image {\n    box-shadow: none; }\n\n.menu {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n  display: flex;\n  flex-wrap: wrap; }\n  [data-whatinput='mouse'] .menu li {\n    outline: 0; }\n  .menu a,\n  .menu .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: 0.7rem 1rem; }\n  .menu input,\n  .menu select,\n  .menu a,\n  .menu button {\n    margin-bottom: 0; }\n  .menu input {\n    display: inline-block; }\n  .menu, .menu.horizontal {\n    flex-wrap: wrap;\n    flex-direction: row; }\n  .menu.vertical {\n    flex-wrap: nowrap;\n    flex-direction: column; }\n  .menu.expanded li {\n    flex: 1 1 0px; }\n  .menu.simple {\n    align-items: center; }\n    .menu.simple li + li {\n      margin-left: 1rem; }\n    .menu.simple a {\n      padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .menu.medium-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.medium-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.medium-expanded li {\n      flex: 1 1 0px; }\n    .menu.medium-simple li {\n      flex: 1 1 0px; } }\n  @media print, screen and (min-width: 64em) {\n    .menu.large-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.large-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.large-expanded li {\n      flex: 1 1 0px; }\n    .menu.large-simple li {\n      flex: 1 1 0px; } }\n  .menu.nested {\n    margin-right: 0;\n    margin-left: 1rem; }\n  .menu.icons a {\n    display: flex; }\n  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {\n    display: flex; }\n  .menu.icon-left li a {\n    flex-flow: row nowrap; }\n    .menu.icon-left li a img,\n    .menu.icon-left li a i,\n    .menu.icon-left li a svg {\n      margin-right: 0.25rem; }\n  .menu.icon-right li a {\n    flex-flow: row nowrap; }\n    .menu.icon-right li a img,\n    .menu.icon-right li a i,\n    .menu.icon-right li a svg {\n      margin-left: 0.25rem; }\n  .menu.icon-top li a {\n    flex-flow: column nowrap; }\n    .menu.icon-top li a img,\n    .menu.icon-top li a i,\n    .menu.icon-top li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu.icon-bottom li a {\n    flex-flow: column nowrap; }\n    .menu.icon-bottom li a img,\n    .menu.icon-bottom li a i,\n    .menu.icon-bottom li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu .is-active > a {\n    background: #2D6699;\n    color: #fefefe; }\n  .menu .active > a {\n    background: #2D6699;\n    color: #fefefe; }\n  .menu.align-left {\n    justify-content: flex-start; }\n  .menu.align-right li {\n    display: flex;\n    justify-content: flex-end; }\n    .menu.align-right li .submenu li {\n      justify-content: flex-start; }\n  .menu.align-right.vertical li {\n    display: block;\n    text-align: right; }\n    .menu.align-right.vertical li .submenu li {\n      text-align: right; }\n  .menu.align-right .nested {\n    margin-right: 1rem;\n    margin-left: 0; }\n  .menu.align-center li {\n    display: flex;\n    justify-content: center; }\n    .menu.align-center li .submenu li {\n      justify-content: flex-start; }\n  .menu .menu-text {\n    padding: 0.7rem 1rem;\n    font-weight: bold;\n    line-height: 1;\n    color: inherit; }\n\n.menu-centered > .menu {\n  justify-content: center; }\n  .menu-centered > .menu li {\n    display: flex;\n    justify-content: center; }\n    .menu-centered > .menu li .submenu li {\n      justify-content: flex-start; }\n\n.no-js [data-responsive-menu] ul {\n  display: none; }\n\n.menu-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #fefefe;\n    box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n    content: ''; }\n  .menu-icon:hover::after {\n    background: #cacaca;\n    box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon.dark::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #0a0a0a;\n    box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n    content: ''; }\n  .menu-icon.dark:hover::after {\n    background: #8a8a8a;\n    box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n  width: 100%; }\n\n.accordion-menu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n  margin-right: 0;\n  margin-left: 1rem; }\n\n.accordion-menu.align-right .nested.is-accordion-submenu {\n  margin-right: 1rem;\n  margin-left: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n  position: relative; }\n  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #2D6699 transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    right: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n  right: 1rem;\n  left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n  right: auto;\n  left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n  position: relative; }\n\n.has-submenu-toggle > a {\n  margin-right: 40px; }\n\n.submenu-toggle {\n  position: absolute;\n  top: 0;\n  right: 0;\n  width: 40px;\n  height: 40px;\n  cursor: pointer; }\n  .submenu-toggle::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #2D6699 transparent transparent;\n    top: 0;\n    bottom: 0;\n    margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n  transform: scaleY(-1);\n  transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n  position: absolute !important;\n  width: 1px !important;\n  height: 1px !important;\n  padding: 0 !important;\n  overflow: hidden !important;\n  clip: rect(0, 0, 0, 0) !important;\n  white-space: nowrap !important;\n  border: 0 !important; }\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden; }\n  .is-drilldown li {\n    display: block; }\n  .is-drilldown.animate-height {\n    transition: height 0.5s; }\n\n.drilldown a {\n  padding: 0.7rem 1rem;\n  background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: -1;\n  width: 100%;\n  background: #fefefe;\n  transition: transform 0.15s linear; }\n  .drilldown .is-drilldown-submenu.is-active {\n    z-index: 1;\n    display: block;\n    transform: translateX(-100%); }\n  .drilldown .is-drilldown-submenu.is-closing {\n    transform: translateX(100%); }\n  .drilldown .is-drilldown-submenu a {\n    padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n  min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n  position: relative; }\n  .drilldown .is-drilldown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #2D6699;\n    position: absolute;\n    top: 50%;\n    margin-top: -6px;\n    right: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #2D6699;\n  right: 1rem;\n  left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #2D6699 transparent transparent;\n  right: auto;\n  left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #2D6699 transparent transparent;\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #2D6699 transparent transparent;\n  right: 5px;\n  left: auto;\n  margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0; }\n\n.dropdown.menu > li > a {\n  padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n  background: transparent;\n  color: #2D6699; }\n\n.no-js .dropdown.menu ul {\n  display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  top: 0;\n  right: 100%;\n  left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #2D6699 transparent transparent;\n  right: auto;\n  left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #2D6699; }\n\n@media print, screen and (min-width: 40em) {\n  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #2D6699 transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.medium-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #2D6699 transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.medium-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #2D6699; } }\n\n@media print, screen and (min-width: 64em) {\n  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #2D6699 transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.large-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #2D6699 transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.large-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #2D6699; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.is-dropdown-menu.vertical {\n  width: 100px; }\n  .is-dropdown-menu.vertical.align-right {\n    float: right; }\n\n.is-dropdown-submenu-parent {\n  position: relative; }\n  .is-dropdown-submenu-parent a::after {\n    position: absolute;\n    top: 50%;\n    right: 5px;\n    left: auto;\n    margin-top: -6px; }\n  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n    top: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n\n.is-dropdown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: 1;\n  display: none;\n  min-width: 200px;\n  border: 1px solid #cacaca;\n  background: #fefefe; }\n  .dropdown .is-dropdown-submenu a {\n    padding: 0.7rem 1rem; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n    right: 14px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #2D6699 transparent transparent;\n    right: auto;\n    left: 5px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #2D6699; }\n  .is-dropdown-submenu .is-dropdown-submenu {\n    margin-top: -1px; }\n  .is-dropdown-submenu > li {\n    width: 100%; }\n  .is-dropdown-submenu.js-dropdown-active {\n    display: block; }\n\n.is-off-canvas-open {\n  overflow: hidden; }\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 11;\n  width: 100%;\n  height: 100%;\n  transition: opacity 0.5s ease, visibility 0.5s ease;\n  background: rgba(254, 254, 254, 0.25);\n  opacity: 0;\n  visibility: hidden;\n  overflow: hidden; }\n  .js-off-canvas-overlay.is-visible {\n    opacity: 1;\n    visibility: visible; }\n  .js-off-canvas-overlay.is-closable {\n    cursor: pointer; }\n  .js-off-canvas-overlay.is-overlay-absolute {\n    position: absolute; }\n  .js-off-canvas-overlay.is-overlay-fixed {\n    position: fixed; }\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden; }\n\n.off-canvas {\n  position: fixed;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas {\n    outline: 0; }\n  .off-canvas.is-transition-push {\n    z-index: 12; }\n  .off-canvas.is-closed {\n    visibility: hidden; }\n  .off-canvas.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas-absolute {\n    outline: 0; }\n  .off-canvas-absolute.is-transition-push {\n    z-index: 12; }\n  .off-canvas-absolute.is-closed {\n    visibility: hidden; }\n  .off-canvas-absolute.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas-absolute.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas-absolute.is-open {\n    transform: translate(0, 0); }\n\n.position-left {\n  top: 0;\n  left: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(-250px); }\n  .off-canvas-content .off-canvas.position-left {\n    transform: translateX(-250px); }\n    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-left.has-transition-push {\n    transform: translateX(250px); }\n  .position-left.is-transition-push {\n    box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n  top: 0;\n  right: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(250px); }\n  .off-canvas-content .off-canvas.position-right {\n    transform: translateX(250px); }\n    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-right.has-transition-push {\n    transform: translateX(-250px); }\n  .position-right.is-transition-push {\n    box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(-250px); }\n  .off-canvas-content .off-canvas.position-top {\n    transform: translateY(-250px); }\n    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-top.has-transition-push {\n    transform: translateY(250px); }\n  .position-top.is-transition-push {\n    box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(250px); }\n  .off-canvas-content .off-canvas.position-bottom {\n    transform: translateY(250px); }\n    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-bottom.has-transition-push {\n    transform: translateY(-250px); }\n  .position-bottom.is-transition-push {\n    box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n  transform: none;\n  backface-visibility: hidden; }\n  .off-canvas-content.has-transition-overlap, .off-canvas-content.has-transition-push {\n    transition: transform 0.5s ease; }\n  .off-canvas-content.has-transition-push {\n    transform: translate(0, 0); }\n  .off-canvas-content .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-medium ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-medium ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-medium ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-medium ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-large ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-large ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-large ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-large ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n  .off-canvas.in-canvas-for-medium {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-medium .close-button {\n      display: none; } }\n\n@media print, screen and (min-width: 64em) {\n  .off-canvas.in-canvas-for-large {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-large .close-button {\n      display: none; } }\n\nhtml.is-reveal-open {\n  position: fixed;\n  width: 100%;\n  overflow-y: hidden; }\n  html.is-reveal-open.zf-has-scroll {\n    overflow-y: scroll; }\n  html.is-reveal-open body {\n    overflow-y: hidden; }\n\n.reveal-overlay {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1005;\n  display: none;\n  background-color: rgba(10, 10, 10, 0.45);\n  overflow-y: auto; }\n\n.reveal {\n  z-index: 1006;\n  backface-visibility: hidden;\n  display: none;\n  padding: 1rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  position: relative;\n  top: 100px;\n  margin-right: auto;\n  margin-left: auto;\n  overflow-y: auto; }\n  [data-whatinput='mouse'] .reveal {\n    outline: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      min-height: 0; } }\n  .reveal .column {\n    min-width: 0; }\n  .reveal > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      width: 600px;\n      max-width: 75rem; } }\n  .reveal.collapse {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal.tiny {\n      width: 30%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.small {\n      width: 50%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.large {\n      width: 90%;\n      max-width: 75rem; } }\n  .reveal.full {\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    min-height: 100%;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0; }\n  @media print, screen and (max-width: 39.99875em) {\n    .reveal {\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      width: 100%;\n      max-width: none;\n      height: 100%;\n      min-height: 100%;\n      margin-left: 0;\n      border: 0;\n      border-radius: 0; } }\n  .reveal.without-overlay {\n    position: fixed; }\n\n.sticky-container {\n  position: relative; }\n\n.sticky {\n  position: relative;\n  z-index: 0;\n  transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n  position: fixed;\n  z-index: 5;\n  width: 100%; }\n  .sticky.is-stuck.is-at-top {\n    top: 0; }\n  .sticky.is-stuck.is-at-bottom {\n    bottom: 0; }\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto; }\n  .sticky.is-anchored.is-at-bottom {\n    bottom: 0; }\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe;\n  display: flex;\n  justify-content: flex-start;\n  align-items: center; }\n  .title-bar .menu-icon {\n    margin-left: 0.25rem;\n    margin-right: 0.25rem; }\n\n.title-bar-left,\n.title-bar-right {\n  flex: 1 1 0px; }\n\n.title-bar-right {\n  text-align: right; }\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold; }\n\n.top-bar {\n  display: flex;\n  flex-wrap: nowrap;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0.3rem;\n  flex-wrap: wrap; }\n  .top-bar,\n  .top-bar ul {\n    background-color: #e6e6e6; }\n  .top-bar input {\n    max-width: 200px;\n    margin-right: 1rem; }\n  .top-bar .input-group-field {\n    width: 100%;\n    margin-right: 0; }\n  .top-bar input.button {\n    width: auto; }\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    flex: 0 0 100%;\n    max-width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .top-bar {\n      flex-wrap: nowrap; }\n      .top-bar .top-bar-left {\n        flex: 1 1 auto;\n        margin-right: auto; }\n      .top-bar .top-bar-right {\n        flex: 0 1 auto;\n        margin-left: auto; } }\n  @media print, screen and (max-width: 63.99875em) {\n    .top-bar.stacked-for-medium {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-medium .top-bar-left,\n      .top-bar.stacked-for-medium .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n  @media print, screen and (max-width: 74.99875em) {\n    .top-bar.stacked-for-large {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-large .top-bar-left,\n      .top-bar.stacked-for-large .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n\n.top-bar-title {\n  flex: 0 0 auto;\n  margin: 0.5rem 1rem 0.5rem 0; }\n\n.top-bar-left,\n.top-bar-right {\n  flex: 0 0 auto; }\n\n.float-left {\n  float: left !important; }\n\n.float-right {\n  float: right !important; }\n\n.float-center {\n  display: block;\n  margin-right: auto;\n  margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n  display: table;\n  content: ' ';\n  flex-basis: 0;\n  order: 1; }\n\n.clearfix::after {\n  clear: both; }\n\n.align-left {\n  justify-content: flex-start; }\n\n.align-right {\n  justify-content: flex-end; }\n\n.align-center {\n  justify-content: center; }\n\n.align-justify {\n  justify-content: space-between; }\n\n.align-spaced {\n  justify-content: space-around; }\n\n.align-left.vertical.menu > li > a {\n  justify-content: flex-start; }\n\n.align-right.vertical.menu > li > a {\n  justify-content: flex-end; }\n\n.align-center.vertical.menu > li > a {\n  justify-content: center; }\n\n.align-top {\n  align-items: flex-start; }\n\n.align-self-top {\n  align-self: flex-start; }\n\n.align-bottom {\n  align-items: flex-end; }\n\n.align-self-bottom {\n  align-self: flex-end; }\n\n.align-middle {\n  align-items: center; }\n\n.align-self-middle {\n  align-self: center; }\n\n.align-stretch {\n  align-items: stretch; }\n\n.align-self-stretch {\n  align-self: stretch; }\n\n.align-center-middle {\n  justify-content: center;\n  align-items: center;\n  align-content: center; }\n\n.small-order-1 {\n  order: 1; }\n\n.small-order-2 {\n  order: 2; }\n\n.small-order-3 {\n  order: 3; }\n\n.small-order-4 {\n  order: 4; }\n\n.small-order-5 {\n  order: 5; }\n\n.small-order-6 {\n  order: 6; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1; }\n  .medium-order-2 {\n    order: 2; }\n  .medium-order-3 {\n    order: 3; }\n  .medium-order-4 {\n    order: 4; }\n  .medium-order-5 {\n    order: 5; }\n  .medium-order-6 {\n    order: 6; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1; }\n  .large-order-2 {\n    order: 2; }\n  .large-order-3 {\n    order: 3; }\n  .large-order-4 {\n    order: 4; }\n  .large-order-5 {\n    order: 5; }\n  .large-order-6 {\n    order: 6; } }\n\n.flex-container {\n  display: flex; }\n\n.flex-child-auto {\n  flex: 1 1 auto; }\n\n.flex-child-grow {\n  flex: 1 0 auto; }\n\n.flex-child-shrink {\n  flex: 0 1 auto; }\n\n.flex-dir-row {\n  flex-direction: row; }\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse; }\n\n.flex-dir-column {\n  flex-direction: column; }\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-container {\n    display: flex; }\n  .medium-flex-child-auto {\n    flex: 1 1 auto; }\n  .medium-flex-child-grow {\n    flex: 1 0 auto; }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto; }\n  .medium-flex-dir-row {\n    flex-direction: row; }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .medium-flex-dir-column {\n    flex-direction: column; }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-container {\n    display: flex; }\n  .large-flex-child-auto {\n    flex: 1 1 auto; }\n  .large-flex-child-grow {\n    flex: 1 0 auto; }\n  .large-flex-child-shrink {\n    flex: 0 1 auto; }\n  .large-flex-dir-row {\n    flex-direction: row; }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .large-flex-dir-column {\n    flex-direction: column; }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n.hide {\n  display: none !important; }\n\n.invisible {\n  visibility: hidden; }\n\n@media print, screen and (max-width: 39.99875em) {\n  .hide-for-small-only {\n    display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n  .show-for-medium {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) and (max-width: 63.99875em) {\n  .hide-for-medium-only {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n  .show-for-large {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) and (max-width: 74.99875em) {\n  .hide-for-large-only {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px !important;\n  height: 1px !important;\n  padding: 0 !important;\n  overflow: hidden !important;\n  clip: rect(0, 0, 0, 0) !important;\n  white-space: nowrap !important;\n  border: 0 !important; }\n\n.show-on-focus:active, .show-on-focus:focus {\n  position: static !important;\n  width: auto !important;\n  height: auto !important;\n  overflow: visible !important;\n  clip: auto !important;\n  white-space: normal !important; }\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important; }\n  @media screen and (orientation: landscape) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: block !important; } }\n  @media screen and (orientation: portrait) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important; }\n  @media screen and (orientation: landscape) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: none !important; } }\n  @media screen and (orientation: portrait) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: block !important; } }\n\n.text-hide {\n  font: 0/0 a !important;\n  color: transparent !important;\n  text-shadow: none !important;\n  background-color: transparent !important;\n  border: 0 !important; }\n\n.text-truncate {\n  max-width: 100% !important;\n  overflow: hidden !important;\n  text-overflow: ellipsis;\n  white-space: nowrap !important; }\n\n.text-nowrap {\n  white-space: nowrap !important; }\n\n.text-wrap {\n  word-wrap: break-word !important; }\n\n.text-lowercase {\n  text-transform: lowercase !important; }\n\n.text-uppercase {\n  text-transform: uppercase !important; }\n\n.text-capitalize {\n  text-transform: capitalize !important; }\n\n.text-overline {\n  text-decoration: overline !important; }\n\n.text-underline {\n  text-decoration: underline !important; }\n\n.text-line-through {\n  text-decoration: line-through !important; }\n\n.font-wide {\n  letter-spacing: 0.25rem; }\n\n.font-normal {\n  font-weight: normal; }\n\n.font-bold {\n  font-weight: bold; }\n\n.font-italic {\n  font-style: italic !important; }\n\nul.list-disc {\n  list-style-type: disc !important; }\n\nul.list-circle {\n  list-style-type: circle !important; }\n\nul.list-square {\n  list-style-type: square !important; }\n\nol.list-decimal {\n  list-style-type: decimal !important; }\n\nol.list-lower-alpha {\n  list-style-type: lower-alpha !important; }\n\nol.list-lower-latin {\n  list-style-type: lower-latin !important; }\n\nol.list-lower-roman {\n  list-style-type: lower-roman !important; }\n\nol.list-upper-alpha {\n  list-style-type: upper-alpha !important; }\n\nol.list-upper-latin {\n  list-style-type: upper-latin !important; }\n\nol.list-upper-roman {\n  list-style-type: upper-roman !important; }\n\n.rounded {\n  border-radius: 5000px !important; }\n  .rounded .switch-paddle {\n    border-radius: 5000px !important; }\n    .rounded .switch-paddle:after {\n      border-radius: 50%; }\n\n.radius {\n  border-radius: 0.1875rem; }\n\n.bordered {\n  border: 0.0625rem solid #cacaca; }\n\n.shadow {\n  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12); }\n\n.arrow-down {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #0a0a0a transparent transparent; }\n\n.arrow-up {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-top-width: 0;\n  border-bottom-style: solid;\n  border-color: transparent transparent #0a0a0a; }\n\n.arrow-right {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #0a0a0a; }\n\n.arrow-left {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #0a0a0a transparent transparent; }\n\n.separator-center {\n  text-align: center !important; }\n  .separator-center::before, .separator-center::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-center::after {\n    clear: both; }\n  .separator-center::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #2D6699;\n    margin: 1rem auto 0; }\n\n.separator-left {\n  text-align: left !important; }\n  .separator-left::before, .separator-left::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-left::after {\n    clear: both; }\n  .separator-left::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #2D6699;\n    margin: 1rem auto 0;\n    margin-left: 0 !important; }\n\n.separator-right {\n  text-align: right !important; }\n  .separator-right::before, .separator-right::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-right::after {\n    clear: both; }\n  .separator-right::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #2D6699;\n    margin: 1rem auto 0;\n    margin-right: 0 !important; }\n\n.overflow-visible {\n  overflow: visible !important; }\n\n.overflow-x-visible {\n  overflow-x: visible !important; }\n\n.overflow-y-visible {\n  overflow-y: visible !important; }\n\n.overflow-hidden {\n  overflow: hidden !important; }\n\n.overflow-x-hidden {\n  overflow-x: hidden !important; }\n\n.overflow-y-hidden {\n  overflow-y: hidden !important; }\n\n.overflow-scroll {\n  overflow: scroll !important; }\n\n.overflow-x-scroll {\n  overflow-x: scroll !important; }\n\n.overflow-y-scroll {\n  overflow-y: scroll !important; }\n\n.display-inline {\n  display: inline !important; }\n\n.display-inline-block {\n  display: inline-block !important; }\n\n.display-block {\n  display: block !important; }\n\n.display-table {\n  display: table !important; }\n\n.display-table-cell {\n  display: table-cell !important; }\n\n.position-static {\n  position: static !important; }\n\n.position-relative {\n  position: relative !important; }\n\n.position-absolute {\n  position: absolute !important; }\n\n.position-fixed {\n  position: fixed !important; }\n\n.position-fixed-top {\n  position: fixed !important;\n  top: 0rem !important;\n  right: 0rem !important;\n  left: 0rem !important;\n  z-index: 975; }\n\n.position-fixed-bottom {\n  position: fixed !important;\n  right: 0rem !important;\n  bottom: 0rem !important;\n  left: 0rem !important;\n  z-index: 975; }\n\n.border-box {\n  box-sizing: border-box !important; }\n\n.border-none {\n  border: none !important; }\n\n.width-25 {\n  width: 25% !important; }\n\n.width-50 {\n  width: 50% !important; }\n\n.width-75 {\n  width: 75% !important; }\n\n.width-100 {\n  width: 100% !important; }\n\n.height-25 {\n  height: 25% !important; }\n\n.height-50 {\n  height: 50% !important; }\n\n.height-75 {\n  height: 75% !important; }\n\n.height-100 {\n  height: 100% !important; }\n\n.max-width-100 {\n  max-width: 100% !important; }\n\n.max-height-100 {\n  max-height: 100% !important; }\n\n.margin-0 {\n  margin: 0rem !important; }\n\n.margin-top-0 {\n  margin-top: 0rem !important; }\n\n.margin-right-0 {\n  margin-right: 0rem !important; }\n\n.margin-bottom-0 {\n  margin-bottom: 0rem !important; }\n\n.margin-left-0 {\n  margin-left: 0rem !important; }\n\n.margin-horizontal-0 {\n  margin-right: 0rem !important;\n  margin-left: 0rem !important; }\n\n.margin-vertical-0 {\n  margin-top: 0rem !important;\n  margin-bottom: 0rem !important; }\n\n.padding-0 {\n  padding: 0rem !important; }\n\n.padding-top-0 {\n  padding-top: 0rem !important; }\n\n.padding-right-0 {\n  padding-right: 0rem !important; }\n\n.padding-bottom-0 {\n  padding-bottom: 0rem !important; }\n\n.padding-left-0 {\n  padding-left: 0rem !important; }\n\n.padding-horizontal-0 {\n  padding-right: 0rem !important;\n  padding-left: 0rem !important; }\n\n.padding-vertical-0 {\n  padding-top: 0rem !important;\n  padding-bottom: 0rem !important; }\n\n.margin-1 {\n  margin: 1rem !important; }\n\n.margin-top-1 {\n  margin-top: 1rem !important; }\n\n.margin-right-1 {\n  margin-right: 1rem !important; }\n\n.margin-bottom-1 {\n  margin-bottom: 1rem !important; }\n\n.margin-left-1 {\n  margin-left: 1rem !important; }\n\n.margin-horizontal-1 {\n  margin-right: 1rem !important;\n  margin-left: 1rem !important; }\n\n.margin-vertical-1 {\n  margin-top: 1rem !important;\n  margin-bottom: 1rem !important; }\n\n.padding-1 {\n  padding: 1rem !important; }\n\n.padding-top-1 {\n  padding-top: 1rem !important; }\n\n.padding-right-1 {\n  padding-right: 1rem !important; }\n\n.padding-bottom-1 {\n  padding-bottom: 1rem !important; }\n\n.padding-left-1 {\n  padding-left: 1rem !important; }\n\n.padding-horizontal-1 {\n  padding-right: 1rem !important;\n  padding-left: 1rem !important; }\n\n.padding-vertical-1 {\n  padding-top: 1rem !important;\n  padding-bottom: 1rem !important; }\n\n.margin-2 {\n  margin: 2rem !important; }\n\n.margin-top-2 {\n  margin-top: 2rem !important; }\n\n.margin-right-2 {\n  margin-right: 2rem !important; }\n\n.margin-bottom-2 {\n  margin-bottom: 2rem !important; }\n\n.margin-left-2 {\n  margin-left: 2rem !important; }\n\n.margin-horizontal-2 {\n  margin-right: 2rem !important;\n  margin-left: 2rem !important; }\n\n.margin-vertical-2 {\n  margin-top: 2rem !important;\n  margin-bottom: 2rem !important; }\n\n.padding-2 {\n  padding: 2rem !important; }\n\n.padding-top-2 {\n  padding-top: 2rem !important; }\n\n.padding-right-2 {\n  padding-right: 2rem !important; }\n\n.padding-bottom-2 {\n  padding-bottom: 2rem !important; }\n\n.padding-left-2 {\n  padding-left: 2rem !important; }\n\n.padding-horizontal-2 {\n  padding-right: 2rem !important;\n  padding-left: 2rem !important; }\n\n.padding-vertical-2 {\n  padding-top: 2rem !important;\n  padding-bottom: 2rem !important; }\n\n.margin-3 {\n  margin: 3rem !important; }\n\n.margin-top-3 {\n  margin-top: 3rem !important; }\n\n.margin-right-3 {\n  margin-right: 3rem !important; }\n\n.margin-bottom-3 {\n  margin-bottom: 3rem !important; }\n\n.margin-left-3 {\n  margin-left: 3rem !important; }\n\n.margin-horizontal-3 {\n  margin-right: 3rem !important;\n  margin-left: 3rem !important; }\n\n.margin-vertical-3 {\n  margin-top: 3rem !important;\n  margin-bottom: 3rem !important; }\n\n.padding-3 {\n  padding: 3rem !important; }\n\n.padding-top-3 {\n  padding-top: 3rem !important; }\n\n.padding-right-3 {\n  padding-right: 3rem !important; }\n\n.padding-bottom-3 {\n  padding-bottom: 3rem !important; }\n\n.padding-left-3 {\n  padding-left: 3rem !important; }\n\n.padding-horizontal-3 {\n  padding-right: 3rem !important;\n  padding-left: 3rem !important; }\n\n.padding-vertical-3 {\n  padding-top: 3rem !important;\n  padding-bottom: 3rem !important; }\n\n.slide-in-down.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateY(-100%);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-in-down.mui-enter.mui-enter-active {\n  transform: translateY(0); }\n\n.slide-in-left.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateX(-100%);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-in-left.mui-enter.mui-enter-active {\n  transform: translateX(0); }\n\n.slide-in-up.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateY(100%);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-in-up.mui-enter.mui-enter-active {\n  transform: translateY(0); }\n\n.slide-in-right.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateX(100%);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-in-right.mui-enter.mui-enter-active {\n  transform: translateX(0); }\n\n.slide-out-down.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateY(0);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-out-down.mui-leave.mui-leave-active {\n  transform: translateY(100%); }\n\n.slide-out-right.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateX(0);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-out-right.mui-leave.mui-leave-active {\n  transform: translateX(100%); }\n\n.slide-out-up.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateY(0);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-out-up.mui-leave.mui-leave-active {\n  transform: translateY(-100%); }\n\n.slide-out-left.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: translateX(0);\n  transition-property: transform, opacity;\n  backface-visibility: hidden; }\n\n.slide-out-left.mui-leave.mui-leave-active {\n  transform: translateX(-100%); }\n\n.fade-in.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  opacity: 0;\n  transition-property: opacity; }\n\n.fade-in.mui-enter.mui-enter-active {\n  opacity: 1; }\n\n.fade-out.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  opacity: 1;\n  transition-property: opacity; }\n\n.fade-out.mui-leave.mui-leave-active {\n  opacity: 0; }\n\n.hinge-in-from-top.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateX(-90deg);\n  transform-origin: top;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-top.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-in-from-right.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateY(-90deg);\n  transform-origin: right;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-right.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-in-from-bottom.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateX(90deg);\n  transform-origin: bottom;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-bottom.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-in-from-left.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateY(90deg);\n  transform-origin: left;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-left.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-in-from-middle-x.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateX(-90deg);\n  transform-origin: center;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-middle-x.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-in-from-middle-y.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotateY(-90deg);\n  transform-origin: center;\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.hinge-in-from-middle-y.mui-enter.mui-enter-active {\n  transform: perspective(2000px) rotate(0deg);\n  opacity: 1; }\n\n.hinge-out-from-top.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: top;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-top.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateX(90deg);\n  opacity: 0; }\n\n.hinge-out-from-right.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: right;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-right.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateY(90deg);\n  opacity: 0; }\n\n.hinge-out-from-bottom.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: bottom;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-bottom.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateX(-90deg);\n  opacity: 0; }\n\n.hinge-out-from-left.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: left;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-left.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateY(-90deg);\n  opacity: 0; }\n\n.hinge-out-from-middle-x.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: center;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-middle-x.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateX(90deg);\n  opacity: 0; }\n\n.hinge-out-from-middle-y.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: perspective(2000px) rotate(0deg);\n  transform-origin: center;\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.hinge-out-from-middle-y.mui-leave.mui-leave-active {\n  transform: perspective(2000px) rotateY(90deg);\n  opacity: 0; }\n\n.scale-in-up.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: scale(0.5);\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.scale-in-up.mui-enter.mui-enter-active {\n  transform: scale(1);\n  opacity: 1; }\n\n.scale-in-down.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: scale(1.5);\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.scale-in-down.mui-enter.mui-enter-active {\n  transform: scale(1);\n  opacity: 1; }\n\n.scale-out-up.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: scale(1);\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.scale-out-up.mui-leave.mui-leave-active {\n  transform: scale(1.5);\n  opacity: 0; }\n\n.scale-out-down.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: scale(1);\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.scale-out-down.mui-leave.mui-leave-active {\n  transform: scale(0.5);\n  opacity: 0; }\n\n.spin-in.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: rotate(-0.75turn);\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.spin-in.mui-enter.mui-enter-active {\n  transform: rotate(0);\n  opacity: 1; }\n\n.spin-out.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: rotate(0);\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.spin-out.mui-leave.mui-leave-active {\n  transform: rotate(0.75turn);\n  opacity: 0; }\n\n.spin-in-ccw.mui-enter {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: rotate(0.75turn);\n  transition-property: transform, opacity;\n  opacity: 0; }\n\n.spin-in-ccw.mui-enter.mui-enter-active {\n  transform: rotate(0);\n  opacity: 1; }\n\n.spin-out-ccw.mui-leave {\n  transition-duration: 500ms;\n  transition-timing-function: linear;\n  transform: rotate(0);\n  transition-property: transform, opacity;\n  opacity: 1; }\n\n.spin-out-ccw.mui-leave.mui-leave-active {\n  transform: rotate(-0.75turn);\n  opacity: 0; }\n\n.slow {\n  transition-duration: 750ms !important; }\n\n.fast {\n  transition-duration: 250ms !important; }\n\n.linear {\n  transition-timing-function: linear !important; }\n\n.ease {\n  transition-timing-function: ease !important; }\n\n.ease-in {\n  transition-timing-function: ease-in !important; }\n\n.ease-out {\n  transition-timing-function: ease-out !important; }\n\n.ease-in-out {\n  transition-timing-function: ease-in-out !important; }\n\n.bounce-in {\n  transition-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; }\n\n.bounce-out {\n  transition-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; }\n\n.bounce-in-out {\n  transition-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; }\n\n.short-delay {\n  transition-delay: 300ms !important; }\n\n.long-delay {\n  transition-delay: 700ms !important; }\n\n.shake {\n  animation-name: shake-7; }\n\n@keyframes shake-7 {\n  0%, 10%, 20%, 30%, 40%, 50%, 60%, 70%, 80%, 90% {\n    transform: translateX(7%); }\n  5%, 15%, 25%, 35%, 45%, 55%, 65%, 75%, 85%, 95% {\n    transform: translateX(-7%); } }\n\n.spin-cw {\n  animation-name: spin-cw-1turn; }\n\n@keyframes spin-cw-1turn {\n  0% {\n    transform: rotate(-1turn); }\n  100% {\n    transform: rotate(0); } }\n\n.spin-ccw {\n  animation-name: spin-ccw-1turn; }\n\n@keyframes spin-ccw-1turn {\n  0% {\n    transform: rotate(0); }\n  100% {\n    transform: rotate(-1turn); } }\n\n.wiggle {\n  animation-name: wiggle-7deg; }\n\n@keyframes wiggle-7deg {\n  40%, 50%, 60% {\n    transform: rotate(7deg); }\n  35%, 45%, 55%, 65% {\n    transform: rotate(-7deg); }\n  0%, 30%, 70%, 100% {\n    transform: rotate(0); } }\n\n.shake,\n.spin-cw,\n.spin-ccw,\n.wiggle {\n  animation-duration: 500ms; }\n\n.infinite {\n  animation-iteration-count: infinite; }\n\n.slow {\n  animation-duration: 750ms !important; }\n\n.fast {\n  animation-duration: 250ms !important; }\n\n.linear {\n  animation-timing-function: linear !important; }\n\n.ease {\n  animation-timing-function: ease !important; }\n\n.ease-in {\n  animation-timing-function: ease-in !important; }\n\n.ease-out {\n  animation-timing-function: ease-out !important; }\n\n.ease-in-out {\n  animation-timing-function: ease-in-out !important; }\n\n.bounce-in {\n  animation-timing-function: cubic-bezier(0.485, 0.155, 0.24, 1.245) !important; }\n\n.bounce-out {\n  animation-timing-function: cubic-bezier(0.485, 0.155, 0.515, 0.845) !important; }\n\n.bounce-in-out {\n  animation-timing-function: cubic-bezier(0.76, -0.245, 0.24, 1.245) !important; }\n\n.short-delay {\n  animation-delay: 300ms !important; }\n\n.long-delay {\n  animation-delay: 700ms !important; }\n\ndiv.card {\n  border-radius: 5px;\n  overflow: hidden !important; }\n\ndiv.responsive-side-box {\n  background: #fefefe;\n  padding-top: 1rem !important;\n  padding-right: 0rem !important;\n  padding-bottom: 0rem !important;\n  padding-left: 0rem !important; }\n  @media print, screen and (min-width: 40em) {\n    div.responsive-side-box {\n      padding-top: 1rem !important;\n      padding-right: 1rem !important;\n      padding-bottom: 1rem !important;\n      padding-left: 1rem !important; } }\n  @media print, screen and (min-width: 64em) {\n    div.responsive-side-box {\n      padding-top: 2rem !important;\n      padding-right: 2rem !important;\n      padding-bottom: 2rem !important;\n      padding-left: 2rem !important; } }\n\ndiv.media-object-section > h1, .h1 {\n  font-size: 1.3125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.media-object-section > h2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.media-object-section > h3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.media-object-section > h4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.media-object-section > h5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.media-object-section > h6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  div.media-object-section > h1, .h1 {\n    font-size: 1rem; }\n  div.media-object-section > h2, .h2 {\n    font-size: 0.9375rem; }\n  div.media-object-section > h3, .h3 {\n    font-size: 0.875rem; }\n  div.media-object-section > h4, .h4 {\n    font-size: 0.875rem; }\n  div.media-object-section > h5, .h5 {\n    font-size: 0.875rem; }\n  div.media-object-section > h6, .h6 {\n    font-size: 0.875rem; } }\n\ndiv.article-row-content > h1, .h1 {\n  font-weight: bold;\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.article-row-content > h2, .h2 {\n  font-weight: bold;\n  font-size: 0.9375rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.article-row-content > h3, .h3 {\n  font-weight: bold;\n  font-size: 0.875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.article-row-content > h4, .h4 {\n  font-weight: bold;\n  font-size: 0.875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.article-row-content > h5, .h5 {\n  font-weight: bold;\n  font-size: 0.875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.article-row-content > h6, .h6 {\n  font-weight: bold;\n  font-size: 0.875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  div.article-row-content > h1, .h1 {\n    font-weight: bold;\n    font-size: 1rem; }\n  div.article-row-content > h2, .h2 {\n    font-weight: bold;\n    font-size: 0.9375rem; }\n  div.article-row-content > h3, .h3 {\n    font-weight: bold;\n    font-size: 0.875rem; }\n  div.article-row-content > h4, .h4 {\n    font-weight: bold;\n    font-size: 0.875rem; }\n  div.article-row-content > h5, .h5 {\n    font-weight: bold;\n    font-size: 0.875rem; }\n  div.article-row-content > h6, .h6 {\n    font-weight: bold;\n    font-size: 0.875rem; } }\n\n.news-hero {\n  border-radius: 5px;\n  margin-top: 1rem !important;\n  margin-bottom: 1rem !important;\n  height: 30vh; }\n  @media print, screen and (min-width: 40em) {\n    .news-hero {\n      height: 40vh; } }\n  @media print, screen and (min-width: 64em) {\n    .news-hero {\n      height: 50vh; } }\n\n.news-hero-large {\n  height: 100%;\n  min-height: 35vh; }\n  @media print, screen and (min-width: 40em) {\n    .news-hero-large {\n      min-height: 70vh 0.7; } }\n  @media print, screen and (min-width: 64em) {\n    .news-hero-large {\n      min-height: 70vh; } }\n\n.news-hero, .news-hero-large {\n  background: url(\"https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg\") 50% no-repeat;\n  background-color: #444;\n  position: relative;\n  background-size: cover;\n  align-items: center;\n  justify-content: center;\n  vertical-align: middle;\n  text-align: left;\n  display: flex;\n  width: 100%; }\n  .news-hero .news-hero-text, .news-hero-large .news-hero-text {\n    position: absolute;\n    bottom: 15%;\n    left: 5%;\n    color: #fefefe;\n    text-shadow: 1px 1px 2px #0a0a0a; }\n    @media print, screen and (min-width: 40em) {\n      .news-hero .news-hero-text, .news-hero-large .news-hero-text {\n        left: 10%; } }\n    @media print, screen and (min-width: 64em) {\n      .news-hero .news-hero-text, .news-hero-large .news-hero-text {\n        left: 20%; } }\n\ndiv.news-hero-text > .article-title > h1, .h1 {\n  font-weight: bold;\n  font-size: 1.3125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.news-hero-text > .article-title > h2, .h2 {\n  font-weight: bold;\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.news-hero-text > .article-title > h3, .h3 {\n  font-weight: bold;\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.news-hero-text > .article-title > h4, .h4 {\n  font-weight: bold;\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.news-hero-text > .article-title > h5, .h5 {\n  font-weight: bold;\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\ndiv.news-hero-text > .article-title > h6, .h6 {\n  font-weight: bold;\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  div.news-hero-text > .article-title > h1, .h1 {\n    font-weight: bold;\n    font-size: 1.5rem; }\n  div.news-hero-text > .article-title > h2, .h2 {\n    font-weight: bold;\n    font-size: 1.375rem; }\n  div.news-hero-text > .article-title > h3, .h3 {\n    font-weight: bold;\n    font-size: 1.3125rem; }\n  div.news-hero-text > .article-title > h4, .h4 {\n    font-weight: bold;\n    font-size: 1.125rem; }\n  div.news-hero-text > .article-title > h5, .h5 {\n    font-weight: bold;\n    font-size: 1rem; }\n  div.news-hero-text > .article-title > h6, .h6 {\n    font-weight: bold;\n    font-size: 0.9375rem; } }\n\n.date-box {\n  display: flex;\n  justify-content: flex-start;\n  align-items: center;\n  height: 71px;\n  background-color: #FFF;\n  padding-top: 0rem !important;\n  padding-right: 0rem !important;\n  padding-bottom: 0rem !important;\n  padding-left: 1rem !important;\n  margin-top: 0rem !important;\n  margin-right: 0rem !important;\n  margin-bottom: 1rem !important;\n  margin-left: 0rem !important; }\n  .date-box .date-badge {\n    width: 41px;\n    height: 41px;\n    padding-top: 8px; }\n    .date-box .date-badge .date-badge-day {\n      font-size: 20px;\n      line-height: 1em;\n      font-weight: bold; }\n    .date-box .date-badge .date-badge-month {\n      font-size: 12px;\n      position: relative;\n      top: -7px; }\n  .date-box .date-text {\n    margin-top: 0rem !important;\n    margin-right: 0rem !important;\n    margin-bottom: 0rem !important;\n    margin-left: 1rem !important; }\n\n.news-card-tag {\n  margin-bottom: 0.5rem; }\n  .news-card-tag .label {\n    border-radius: 0.125rem;\n    background-color: #2D6699;\n    color: #fefefe; }\n    .news-card-tag .label a {\n      background-color: inherit;\n      color: inherit; }\n    .news-card-tag .label:hover, .news-card-tag .label:focus {\n      background-color: #265782; }\n      .news-card-tag .label:hover a, .news-card-tag .label:focus a {\n        background-color: inherit;\n        color: inherit; }\n\n.news-card {\n  background-color: #fefefe;\n  font-weight: 400;\n  margin-bottom: 1.6rem;\n  border-radius: 0.125rem;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24); }\n  .news-card .card-section {\n    background-color: inherit; }\n    .news-card .card-section .news-card-date {\n      font-size: 1em;\n      color: #8a8a8a; }\n    .news-card .card-section .news-card-article {\n      background-color: inherit; }\n      .news-card .card-section .news-card-article .news-card-title {\n        line-height: 1.3;\n        font-weight: bold; }\n        .news-card .card-section .news-card-article .news-card-title a {\n          text-decoration: none;\n          color: #8a8a8a;\n          transition: color 0.5s ease; }\n          .news-card .card-section .news-card-article .news-card-title a:hover {\n            color: #2D6699; }\n      .news-card .card-section .news-card-article .news-card-description {\n        color: #8a8a8a; }\n    .news-card .card-section .news-card-author {\n      overflow: hidden;\n      padding-bottom: 1.6rem; }\n      .news-card .card-section .news-card-author .news-card-author-image {\n        display: inline-block;\n        vertical-align: middle; }\n        .news-card .card-section .news-card-author .news-card-author-image img {\n          border-radius: 50%;\n          margin-right: 0.6em; }\n      .news-card .card-section .news-card-author .news-card-author-name {\n        display: inline-block;\n        vertical-align: middle; }\n\n/*! CSS for Responsive Hidden Nav */\n.responsive-hidden-nav-container {\n  min-width: 240px;\n  background: #2D6699;\n  padding: .5rem 1rem;\n  height: 80vh; }\n\n.responsive-hidden-nav {\n  margin: 0;\n  padding: 0;\n  background-color: #fefefe;\n  position: relative;\n  min-width: 240px;\n  background: #fefefe; }\n  .responsive-hidden-nav a {\n    display: block;\n    padding: 1.25rem 2rem;\n    background: #fefefe;\n    font-size: 1.1em;\n    color: #2D6699;\n    text-decoration: none; }\n    .responsive-hidden-nav a:hover {\n      color: #16314a; }\n  .responsive-hidden-nav button {\n    position: absolute;\n    height: 100%;\n    right: 0;\n    padding: 0 1rem;\n    border: 0;\n    outline: none;\n    background-color: #214c72;\n    color: #fefefe;\n    cursor: pointer; }\n    .responsive-hidden-nav button:hover {\n      background-color: #16314a; }\n    .responsive-hidden-nav button::after {\n      content: attr(count);\n      position: absolute;\n      width: 2rem;\n      height: 2rem;\n      left: -1rem;\n      top: .75rem;\n      text-align: center;\n      background-color: #16314a;\n      color: #fefefe;\n      font-size: .9em;\n      line-height: 1.6;\n      border-radius: 50%;\n      border: 0.25rem solid #fefefe;\n      font-weight: bold; }\n    .responsive-hidden-nav button:hover::after {\n      transform: scale(1.075); }\n  .responsive-hidden-nav .hamburger {\n    position: relative;\n    display: inline-block;\n    vertical-align: middle;\n    width: 20px;\n    height: 16px;\n    cursor: pointer; }\n    .responsive-hidden-nav .hamburger::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    .responsive-hidden-nav .hamburger:hover::after {\n      background: #fefefe;\n      box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe; }\n  .responsive-hidden-nav .visible-links {\n    display: inline-table;\n    margin: 0;\n    padding: 0; }\n    .responsive-hidden-nav .visible-links li {\n      display: table-cell;\n      border-left: 1px solid #2D6699; }\n      .responsive-hidden-nav .visible-links li:first-child {\n        font-weight: bold; }\n        .responsive-hidden-nav .visible-links li:first-child a {\n          color: #2D6699 !important; }\n  .responsive-hidden-nav .hidden-links {\n    position: absolute;\n    right: 0;\n    top: 100%;\n    margin: 0;\n    padding: 0; }\n    .responsive-hidden-nav .hidden-links li {\n      display: block;\n      border-top: 0.0625rem solid #214c72; }\n  .responsive-hidden-nav .hidden {\n    visibility: hidden; }\n\n.topbar-responsive {\n  background: #2c3840;\n  padding: 1rem 1.5rem; }\n  .topbar-responsive .topbar-responsive-logo {\n    color: #fefefe;\n    vertical-align: middle; }\n  .topbar-responsive .menu {\n    background: #2c3840; }\n    .topbar-responsive .menu li:last-of-type {\n      margin-right: 0; }\n    .topbar-responsive .menu a {\n      color: #fefefe;\n      transition: color 0.15s ease-in; }\n      .topbar-responsive .menu a:hover {\n        color: #c6d1d8; }\n      @media screen and (max-width: 39.9375em) {\n        .topbar-responsive .menu a {\n          padding: 0.875rem 0; } }\n    .topbar-responsive .menu .topbar-responsive-button {\n      color: #fefefe;\n      border-color: #fefefe;\n      border-radius: 5000px;\n      transition: color 0.15s ease-in, border-color 0.15s ease-in; }\n      .topbar-responsive .menu .topbar-responsive-button:hover {\n        color: #c6d1d8;\n        border-color: #c6d1d8; }\n      @media screen and (max-width: 39.9375em) {\n        .topbar-responsive .menu .topbar-responsive-button {\n          width: 100%;\n          margin: 0.875rem 0; } }\n  @media screen and (max-width: 39.9375em) {\n    .topbar-responsive {\n      padding: 0.75rem; }\n      .topbar-responsive .top-bar-title {\n        position: relative;\n        width: 100%; }\n        .topbar-responsive .top-bar-title span {\n          position: absolute;\n          right: 0;\n          border: 1px solid #fefefe;\n          border-radius: 5px;\n          padding: 0.25rem 0.45rem;\n          top: 50%;\n          transform: translateY(-50%); }\n          .topbar-responsive .top-bar-title span .menu-icon {\n            margin-bottom: 4px; } }\n\n@keyframes fadeIn {\n  from {\n    opacity: 0; }\n  to {\n    opacity: 1; } }\n\n@keyframes slideDown {\n  0% {\n    transform: translateY(-100%); }\n  100% {\n    transform: translateY(0%); } }\n\n@media print, screen and (max-width: 39.99875em) {\n  .topbar-responsive-links {\n    animation-fill-mode: both;\n    animation-duration: 0.5s;\n    width: 100%;\n    animation: fadeIn 1s ease-in; } }\n\n.comment-section-container {\n  background-color: #fefefe;\n  padding: 1rem; }\n\n.comment-section-author {\n  display: flex;\n  align-items: center;\n  margin-bottom: 1rem; }\n  .comment-section-author .comment-section-name {\n    margin-left: 1rem; }\n    .comment-section-author .comment-section-name p {\n      margin-bottom: 0; }\n\n.comment-section-box {\n  background-color: #e6e6e6;\n  padding: 1rem; }\n\n.about-the-author {\n  background-color: #fefefe;\n  padding: 1rem;\n  border: 1px solid #cacaca; }\n  .about-the-author .separator-left {\n    text-align: left; }\n    .about-the-author .separator-left::before, .about-the-author .separator-left::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .about-the-author .separator-left::after {\n      clear: both; }\n    .about-the-author .separator-left::after {\n      position: relative;\n      width: 5rem;\n      border-bottom: 0.125rem solid #2D6699;\n      margin: 0.3rem auto 0;\n      margin-left: 0; }\n  .about-the-author .author-title {\n    text-transform: uppercase; }\n  .about-the-author .author-social {\n    text-align: center;\n    margin-top: 0.7rem;\n    margin-bottom: 0.7rem; }\n    .about-the-author .author-social .fa-stack {\n      display: inline-block; }\n      .about-the-author .author-social .fa-stack.facebook {\n        color: #4c70ba; }\n        .about-the-author .author-social .fa-stack.facebook:hover, .about-the-author .author-social .fa-stack.facebook:focus {\n          color: #3b5998; }\n      .about-the-author .author-social .fa-stack.twitter {\n        color: #83c3f3; }\n        .about-the-author .author-social .fa-stack.twitter:hover, .about-the-author .author-social .fa-stack.twitter:focus {\n          color: #55acee; }\n      .about-the-author .author-social .fa-stack.linkedin {\n        color: #009ee8; }\n        .about-the-author .author-social .fa-stack.linkedin:hover, .about-the-author .author-social .fa-stack.linkedin:focus {\n          color: #007bb5; }\n  .about-the-author .author-image {\n    border: 1px solid #cacaca; }\n\n.wide-article-link {\n  background-color: #fefefe;\n  padding: 1rem 1rem 0.5rem;\n  border: 1px solid #cacaca;\n  margin-bottom: 1rem; }\n  .wide-article-link .article-title a {\n    color: #0a0a0a; }\n    .wide-article-link .article-title a:hover, .wide-article-link .article-title a:focus {\n      color: #2D6699; }\n  .wide-article-link .article-elipsis .read-more {\n    font-weight: bold; }\n  .wide-article-link .article-title,\n  .wide-article-link .article-author,\n  .wide-article-link .article-elipsis {\n    margin-bottom: 0.25rem; }\n  .wide-article-link .article-social {\n    margin-top: 0.75rem; }\n    .wide-article-link .article-social .social {\n      margin-right: 0.25rem; }\n      .wide-article-link .article-social .social.comments, .wide-article-link .article-social .social.comments.disabled, .wide-article-link .article-social .social.comments[disabled], .wide-article-link .article-social .social.comments.disabled:hover, .wide-article-link .article-social .social.comments[disabled]:hover, .wide-article-link .article-social .social.comments.disabled:focus, .wide-article-link .article-social .social.comments[disabled]:focus {\n        background-color: #8a8a8a;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.comments:hover, .wide-article-link .article-social .social.comments:focus {\n        background-color: #6e6e6e;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.facebook, .wide-article-link .article-social .social.facebook.disabled, .wide-article-link .article-social .social.facebook[disabled], .wide-article-link .article-social .social.facebook.disabled:hover, .wide-article-link .article-social .social.facebook[disabled]:hover, .wide-article-link .article-social .social.facebook.disabled:focus, .wide-article-link .article-social .social.facebook[disabled]:focus {\n        background-color: #3b5998;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.facebook:hover, .wide-article-link .article-social .social.facebook:focus {\n        background-color: #2f477a;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.twitter, .wide-article-link .article-social .social.twitter.disabled, .wide-article-link .article-social .social.twitter[disabled], .wide-article-link .article-social .social.twitter.disabled:hover, .wide-article-link .article-social .social.twitter[disabled]:hover, .wide-article-link .article-social .social.twitter.disabled:focus, .wide-article-link .article-social .social.twitter[disabled]:focus {\n        background-color: #55acee;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.twitter:hover, .wide-article-link .article-social .social.twitter:focus {\n        background-color: #1a8fe8;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.linkedin, .wide-article-link .article-social .social.linkedin.disabled, .wide-article-link .article-social .social.linkedin[disabled], .wide-article-link .article-social .social.linkedin.disabled:hover, .wide-article-link .article-social .social.linkedin[disabled]:hover, .wide-article-link .article-social .social.linkedin.disabled:focus, .wide-article-link .article-social .social.linkedin[disabled]:focus {\n        background-color: #007bb5;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.linkedin:hover, .wide-article-link .article-social .social.linkedin:focus {\n        background-color: #006291;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.google-plus, .wide-article-link .article-social .social.google-plus.disabled, .wide-article-link .article-social .social.google-plus[disabled], .wide-article-link .article-social .social.google-plus.disabled:hover, .wide-article-link .article-social .social.google-plus[disabled]:hover, .wide-article-link .article-social .social.google-plus.disabled:focus, .wide-article-link .article-social .social.google-plus[disabled]:focus {\n        background-color: #dd4b39;\n        color: #fefefe; }\n      .wide-article-link .article-social .social.google-plus:hover, .wide-article-link .article-social .social.google-plus:focus {\n        background-color: #be3221;\n        color: #fefefe; }\n      .wide-article-link .article-social .social > .fa {\n        color: #fefefe; }\n        .wide-article-link .article-social .social > .fa.fa-comments-o {\n          margin-right: 0.25rem; }\n\n.large-article-header {\n  background: \"\" #8a8a8a no-repeat center;\n  background-size: cover;\n  background-color: #8a8a8a;\n  height: 25rem;\n  position: relative; }\n  @media print, screen and (max-width: 39.99875em) {\n    .large-article-header {\n      height: 16.66667rem; } }\n\n.large-article-header-content {\n  display: flex;\n  flex-direction: column;\n  position: absolute;\n  bottom: 3.125rem;\n  left: 0;\n  right: 0;\n  text-shadow: 1px 1px 2px #0a0a0a; }\n  @media print, screen and (max-width: 39.99875em) {\n    .large-article-header-content {\n      bottom: 1.25rem; } }\n  .large-article-header-content .center-container {\n    width: 50%;\n    margin: 0 auto; }\n    @media print, screen and (max-width: 39.99875em) {\n      .large-article-header-content .center-container {\n        width: 100%;\n        padding: 0 1.25rem; } }\n  .large-article-header-content .article-date {\n    color: #fefefe; }\n  .large-article-header-content .article-title h1 {\n    line-height: 3.125rem;\n    color: #fefefe;\n    font-weight: 600; }\n    @media print, screen and (max-width: 39.99875em) {\n      .large-article-header-content .article-title h1 {\n        line-height: 1.875rem; } }\n  .large-article-header-content .article-details {\n    display: flex;\n    align-items: center;\n    justify-content: space-between; }\n    .large-article-header-content .article-details a {\n      color: #fefefe; }\n  .large-article-header-content .article-author {\n    display: flex;\n    align-items: center;\n    margin: 1rem 0; }\n    .large-article-header-content .article-author img {\n      border-radius: 3.125rem; }\n    .large-article-header-content .article-author a {\n      margin-left: 1rem; }\n\n.simple-article-header {\n  background: #fefefe;\n  padding: 1.3rem 2rem .7rem;\n  border: 1px solid #cacaca;\n  margin-bottom: 1rem; }\n  .simple-article-header .article-date-read {\n    color: #8a8a8a; }\n  .simple-article-header .article-title {\n    text-transform: uppercase; }\n    .simple-article-header .article-title a {\n      color: #0a0a0a; }\n      .simple-article-header .article-title a:hover, .simple-article-header .article-title a:focus {\n        color: #2D6699; }\n  .simple-article-header .article-author-comments a.article-comments {\n    color: #8a8a8a; }\n    .simple-article-header .article-author-comments a.article-comments:hover, .simple-article-header .article-author-comments a.article-comments:focus {\n      color: #2D6699; }\n  .simple-article-header .article-date-read,\n  .simple-article-header .article-title,\n  .simple-article-header .article-author-comments,\n  .simple-article-header .article-social,\n  .simple-article-header .article-post-image,\n  .simple-article-header .article-post-content {\n    margin-bottom: 0.25rem; }\n  .simple-article-header .article-social {\n    margin-top: 0.75rem; }\n    .simple-article-header .article-social .social {\n      margin-right: 0.25rem; }\n      .simple-article-header .article-social .social.facebook, .simple-article-header .article-social .social.facebook.disabled, .simple-article-header .article-social .social.facebook[disabled], .simple-article-header .article-social .social.facebook.disabled:hover, .simple-article-header .article-social .social.facebook[disabled]:hover, .simple-article-header .article-social .social.facebook.disabled:focus, .simple-article-header .article-social .social.facebook[disabled]:focus {\n        background-color: #3b5998;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.facebook:hover, .simple-article-header .article-social .social.facebook:focus {\n        background-color: #2f477a;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.twitter, .simple-article-header .article-social .social.twitter.disabled, .simple-article-header .article-social .social.twitter[disabled], .simple-article-header .article-social .social.twitter.disabled:hover, .simple-article-header .article-social .social.twitter[disabled]:hover, .simple-article-header .article-social .social.twitter.disabled:focus, .simple-article-header .article-social .social.twitter[disabled]:focus {\n        background-color: #55acee;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.twitter:hover, .simple-article-header .article-social .social.twitter:focus {\n        background-color: #1a8fe8;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.linkedin, .simple-article-header .article-social .social.linkedin.disabled, .simple-article-header .article-social .social.linkedin[disabled], .simple-article-header .article-social .social.linkedin.disabled:hover, .simple-article-header .article-social .social.linkedin[disabled]:hover, .simple-article-header .article-social .social.linkedin.disabled:focus, .simple-article-header .article-social .social.linkedin[disabled]:focus {\n        background-color: #007bb5;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.linkedin:hover, .simple-article-header .article-social .social.linkedin:focus {\n        background-color: #006291;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.google-plus, .simple-article-header .article-social .social.google-plus.disabled, .simple-article-header .article-social .social.google-plus[disabled], .simple-article-header .article-social .social.google-plus.disabled:hover, .simple-article-header .article-social .social.google-plus[disabled]:hover, .simple-article-header .article-social .social.google-plus.disabled:focus, .simple-article-header .article-social .social.google-plus[disabled]:focus {\n        background-color: #dd4b39;\n        color: #fefefe; }\n      .simple-article-header .article-social .social.google-plus:hover, .simple-article-header .article-social .social.google-plus:focus {\n        background-color: #be3221;\n        color: #fefefe; }\n      .simple-article-header .article-social .social > .fa {\n        color: #fefefe; }\n        .simple-article-header .article-social .social > .fa.fa-comments-o {\n          margin-right: 0.25rem; }\n\n.blockquote-container.blockquote-left {\n  float: left;\n  width: 35%;\n  margin-right: 1rem; }\n  @media print, screen and (max-width: 39.99875em) {\n    .blockquote-container.blockquote-left {\n      float: none;\n      margin: 0;\n      width: 100%; } }\n\n.blockquote-container.blockquote-right {\n  float: right;\n  width: 35%;\n  margin-left: 1rem; }\n\n.blockquote-container .callout .blockquote-title {\n  margin-left: 1rem; }\n\n.blockquote-container .callout blockquote {\n  quotes: \"“\" \"”\" \"‘\" \"’  \";\n  border-left: none; }\n  .blockquote-container .callout blockquote:before {\n    content: open-quote;\n    color: #8a8a8a;\n    font-size: 4em;\n    line-height: 0.1em;\n    vertical-align: -0.4em; }\n  .blockquote-container .callout blockquote:after {\n    content: close-quote;\n    color: #8a8a8a;\n    font-size: 4em;\n    line-height: 0.1em;\n    vertical-align: -0.6em; }\n  .blockquote-container .callout blockquote .blockquote-content {\n    display: inline;\n    color: #0a0a0a; }\n\n.flexible-article-image-full .thumbnail {\n  width: 100%; }\n  .flexible-article-image-full .thumbnail img {\n    width: 100%; }\n\n.flexible-article-image-full .caption {\n  font-size: 0.9rem; }\n\n.flexible-article-image-left {\n  float: left;\n  margin: 1rem 1.5rem 0 0;\n  max-width: 12.5rem; }\n  .flexible-article-image-left .caption {\n    font-size: 0.9rem; }\n  @media print, screen and (max-width: 39.99875em) {\n    .flexible-article-image-left {\n      float: none;\n      max-width: 100%;\n      margin: 0; }\n      .flexible-article-image-left .thumbnail {\n        width: 100%; }\n        .flexible-article-image-left .thumbnail img {\n          width: 100%; } }\n\n.flexible-article-image-right {\n  float: right;\n  margin: 0 0 1rem 1.5rem;\n  max-width: 12.5rem; }\n  .flexible-article-image-right .caption {\n    font-size: 0.9rem; }\n  @media print, screen and (max-width: 39.99875em) {\n    .flexible-article-image-right {\n      float: none;\n      max-width: 100%;\n      margin: 0; }\n      .flexible-article-image-right .thumbnail {\n        width: 100%; }\n        .flexible-article-image-right .thumbnail img {\n          width: 100%; } }\n\n.featured-article-big {\n  background: url(\"https://placehold.it/600?text=Big+Feature\") no-repeat center center;\n  background-size: cover;\n  height: 28.125rem;\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  padding: 0.625rem;\n  border-right: 0.0625rem solid #fefefe; }\n  .featured-article-big .featured-article-text .featured-article-title {\n    font-size: 1.75rem;\n    font-weight: bold;\n    line-height: 1.875rem; }\n    .featured-article-big .featured-article-text .featured-article-title .author {\n      font-size: 1.125rem; }\n  .featured-article-big .featured-article-text p {\n    color: #fefefe;\n    margin-bottom: 0; }\n\n.featured-article-small-container {\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 28.125rem; }\n  .featured-article-small-container :last-child .featured-article-small {\n    border-bottom: 0; }\n\n.featured-article-small {\n  background: url(\"https://placehold.it/200?text=Small+Feature\") no-repeat center center;\n  height: 9.375rem;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  padding: 0.625rem;\n  border-bottom: 0.0625rem solid #fefefe; }\n  .featured-article-small :last-child {\n    border-bottom: 0; }\n  .featured-article-small .featured-article-text .featured-article-title {\n    font-size: 1rem;\n    font-weight: bold;\n    line-height: 0.9375rem;\n    max-height: 2.8125rem;\n    overflow: hidden;\n    text-overflow: ellipsis; }\n  .featured-article-small .featured-article-text p {\n    color: #fefefe;\n    margin-bottom: 0; }\n\n.featured-article-links-container {\n  border: 0.0625rem solid #e6e6e6;\n  background-color: #fefefe;\n  height: 28.125rem;\n  overflow: scroll; }\n\n.featured-article-links,\n.featured-article-links-header {\n  padding: 0.625rem;\n  border-bottom: 0.0625rem solid #e6e6e6; }\n  .featured-article-links:last-child,\n  .featured-article-links-header:last-child {\n    border-bottom: 0; }\n\n.featured-article-links-header {\n  font-weight: 600;\n  text-transform: uppercase; }\n\n.posts-panel {\n  max-width: 75rem;\n  margin-right: auto;\n  margin-left: auto;\n  width: 100%;\n  float: left;\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  float: none !important;\n  margin: 1.25rem 0.625rem;\n  background-color: #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0.25rem 0 rgba(0, 0, 0, 0.2); }\n  .posts-panel::before, .posts-panel::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .posts-panel::after {\n    clear: both; }\n  @media print, screen and (min-width: 40em) {\n    .posts-panel {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .posts-panel, .posts-panel:last-child:not(:first-child) {\n    float: left;\n    clear: none; }\n  .posts-panel:last-child:not(:first-child) {\n    float: right; }\n  .posts-panel, .posts-panel:last-child {\n    float: none; }\n  .posts-panel .panel-header {\n    max-width: 75rem;\n    margin-right: auto;\n    margin-left: auto;\n    width: 100%;\n    float: left;\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    border-bottom: 0.25rem solid #e6e6e6; }\n    .posts-panel .panel-header::before, .posts-panel .panel-header::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .posts-panel .panel-header::after {\n      clear: both; }\n    @media print, screen and (min-width: 40em) {\n      .posts-panel .panel-header {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n    .posts-panel .panel-header, .posts-panel .panel-header:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .posts-panel .panel-header:last-child:not(:first-child) {\n      float: right; }\n    .posts-panel .panel-header, .posts-panel .panel-header:last-child {\n      float: none; }\n    .posts-panel .panel-header .panel-title {\n      margin: 0;\n      padding: 0.9375rem 0;\n      color: #8a8a8a;\n      font-size: 1.625rem; }\n  .posts-panel .panel-content {\n    padding: 0.9375rem 0; }\n  .posts-panel .pinned-post, .posts-panel .posts-list {\n    max-width: 75rem;\n    margin-right: auto;\n    margin-left: auto;\n    width: 100%;\n    float: left;\n    padding-right: 0;\n    padding-left: 0; }\n    .posts-panel .pinned-post::before, .posts-panel .pinned-post::after, .posts-panel .posts-list::before, .posts-panel .posts-list::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .posts-panel .pinned-post::after, .posts-panel .posts-list::after {\n      clear: both; }\n    .posts-panel .pinned-post, .posts-panel .pinned-post:last-child:not(:first-child), .posts-panel .posts-list, .posts-panel .posts-list:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .posts-panel .pinned-post:last-child:not(:first-child), .posts-panel .posts-list:last-child:not(:first-child) {\n      float: right; }\n    .posts-panel .pinned-post, .posts-panel .pinned-post:last-child, .posts-panel .posts-list, .posts-panel .posts-list:last-child {\n      float: none; }\n  .posts-panel .posts-list .post-item:not(:last-child) {\n    border-bottom: 0.0625rem solid #e6e6e6; }\n  .posts-panel .post-item {\n    max-width: 75rem;\n    margin-right: auto;\n    margin-left: auto;\n    padding: 0.9375rem 0; }\n    .posts-panel .post-item::before, .posts-panel .post-item::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .posts-panel .post-item::after {\n      clear: both; }\n    .posts-panel .post-item .post-thumbnail {\n      display: block;\n      width: 33.33333%;\n      float: left;\n      padding-right: 0.625rem;\n      padding-left: 0.625rem; }\n      @media print, screen and (min-width: 40em) {\n        .posts-panel .post-item .post-thumbnail {\n          padding-right: 0.9375rem;\n          padding-left: 0.9375rem; } }\n      .posts-panel .post-item .post-thumbnail, .posts-panel .post-item .post-thumbnail:last-child:not(:first-child) {\n        float: left;\n        clear: none; }\n      .posts-panel .post-item .post-thumbnail:last-child:not(:first-child) {\n        float: right; }\n      .posts-panel .post-item .post-thumbnail img {\n        width: 100%;\n        height: auto; }\n    .posts-panel .post-item .post-text {\n      width: 66.66667%;\n      float: left;\n      padding-right: 0.625rem;\n      padding-left: 0.625rem; }\n      @media print, screen and (min-width: 40em) {\n        .posts-panel .post-item .post-text {\n          padding-right: 0.9375rem;\n          padding-left: 0.9375rem; } }\n      .posts-panel .post-item .post-text, .posts-panel .post-item .post-text:last-child:not(:first-child) {\n        float: left;\n        clear: none; }\n      .posts-panel .post-item .post-text:last-child:not(:first-child) {\n        float: right; }\n      .posts-panel .post-item .post-text p {\n        margin: 0; }\n    .posts-panel .post-item .post-title {\n      font-size: 1.625rem; }\n    .posts-panel .post-item .post-meta {\n      color: #8a8a8a;\n      font-size: 0.875rem; }\n    .posts-panel .post-item .meta {\n      display: inline-block;\n      margin-right: 0.9375rem; }\n    .posts-panel .post-item .meta-icon, .posts-panel .post-item .meta-text {\n      display: inline-block;\n      padding-right: 0.3125rem; }\n    .posts-panel .post-item .post-read-more {\n      display: block;\n      font-size: 0.875rem; }\n      .posts-panel .post-item .post-read-more .fa {\n        padding: 0 0.3125rem; }\n  .posts-panel .pinned-post .post-item {\n    border-bottom: 0.0625rem solid #e6e6e6; }\n  .posts-panel .pinned-post .post-thumbnail {\n    display: block;\n    max-width: 75rem;\n    margin-right: auto;\n    margin-left: auto;\n    width: 100%;\n    float: left;\n    padding-right: 0.625rem;\n    padding-left: 0.625rem; }\n    .posts-panel .pinned-post .post-thumbnail::before, .posts-panel .pinned-post .post-thumbnail::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .posts-panel .pinned-post .post-thumbnail::after {\n      clear: both; }\n    @media print, screen and (min-width: 40em) {\n      .posts-panel .pinned-post .post-thumbnail {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n    .posts-panel .pinned-post .post-thumbnail, .posts-panel .pinned-post .post-thumbnail:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .posts-panel .pinned-post .post-thumbnail:last-child:not(:first-child) {\n      float: right; }\n    .posts-panel .pinned-post .post-thumbnail, .posts-panel .pinned-post .post-thumbnail:last-child {\n      float: none; }\n    .posts-panel .pinned-post .post-thumbnail img {\n      width: 100%;\n      height: auto; }\n  .posts-panel .pinned-post .post-text {\n    max-width: 75rem;\n    margin-right: auto;\n    margin-left: auto;\n    width: 100%;\n    float: left;\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    margin-top: 0.9375rem; }\n    .posts-panel .pinned-post .post-text::before, .posts-panel .pinned-post .post-text::after {\n      display: table;\n      content: ' ';\n      flex-basis: 0;\n      order: 1; }\n    .posts-panel .pinned-post .post-text::after {\n      clear: both; }\n    @media print, screen and (min-width: 40em) {\n      .posts-panel .pinned-post .post-text {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n    .posts-panel .pinned-post .post-text, .posts-panel .pinned-post .post-text:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .posts-panel .pinned-post .post-text:last-child:not(:first-child) {\n      float: right; }\n    .posts-panel .pinned-post .post-text, .posts-panel .pinned-post .post-text:last-child {\n      float: none; }\n  @media print, screen and (max-width: 39.99875em) {\n    .posts-panel .posts-list .post-title {\n      font-size: 1.125rem; }\n    .posts-panel .posts-list .post-meta {\n      font-size: 0.75rem; }\n    .posts-panel .posts-list .post-summary {\n      font-size: 0.75rem; }\n    .posts-panel .posts-list .post-read-more {\n      display: none; } }\n  @media print, screen and (min-width: 40em) and (max-width: 63.99875em) {\n    .posts-panel .posts-list .post-title {\n      font-size: 1.25rem; }\n    .posts-panel .posts-list .post-meta {\n      font-size: 0.875rem; }\n    .posts-panel .posts-list .post-summary {\n      font-size: 0.875rem; } }\n  .posts-panel.grid .pinned-post, .posts-panel.grid .posts-list {\n    width: 50%;\n    float: left;\n    padding-right: 0;\n    padding-left: 0; }\n    .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list:last-child:not(:first-child) {\n      float: right; }\n    @media print, screen and (max-width: 39.99875em) {\n      .posts-panel.grid .pinned-post, .posts-panel.grid .posts-list {\n        max-width: 75rem;\n        margin-right: auto;\n        margin-left: auto;\n        width: 100%;\n        float: left;\n        padding-right: 0;\n        padding-left: 0; }\n        .posts-panel.grid .pinned-post::before, .posts-panel.grid .pinned-post::after, .posts-panel.grid .posts-list::before, .posts-panel.grid .posts-list::after {\n          display: table;\n          content: ' ';\n          flex-basis: 0;\n          order: 1; }\n        .posts-panel.grid .pinned-post::after, .posts-panel.grid .posts-list::after {\n          clear: both; }\n        .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child:not(:first-child) {\n          float: left;\n          clear: none; }\n        .posts-panel.grid .pinned-post:last-child:not(:first-child), .posts-panel.grid .posts-list:last-child:not(:first-child) {\n          float: right; }\n        .posts-panel.grid .pinned-post, .posts-panel.grid .pinned-post:last-child, .posts-panel.grid .posts-list, .posts-panel.grid .posts-list:last-child {\n          float: none; } }\n  .posts-panel.grid .pinned-post .post-item {\n    border: 0; }\n  .posts-panel.grid .posts-list .post-title {\n    font-size: 1.125rem; }\n  .posts-panel.grid .posts-list .post-meta {\n    font-size: 0.75rem; }\n  .posts-panel.grid .posts-list .post-summary {\n    font-size: 0.75rem; }\n  .posts-panel.grid .posts-list .post-read-more {\n    display: none; }\n\n.sticky-social-bar {\n  padding: 0;\n  margin: 0;\n  top: 50%;\n  transform: translateY(-50%);\n  width: 11.25rem;\n  background-color: #333333;\n  position: fixed;\n  left: -8.75rem; }\n  .sticky-social-bar .social-icon {\n    list-style-type: none;\n    color: #fefefe;\n    background-color: inherit;\n    margin: 0;\n    transition: all 0.3s ease-in-out;\n    cursor: pointer;\n    font-size: 1.1rem;\n    padding: 0.25rem 0.25rem 0.5rem; }\n    .sticky-social-bar .social-icon:first-of-type {\n      padding-top: 0.375rem; }\n    .sticky-social-bar .social-icon:last-of-type {\n      padding-bottom: 0.625rem; }\n    .sticky-social-bar .social-icon > a {\n      color: inherit;\n      background-color: inherit; }\n      .sticky-social-bar .social-icon > a > .fa {\n        padding: 0.5rem;\n        width: 2rem;\n        height: 2rem;\n        float: right;\n        margin-left: 0.5rem; }\n        .sticky-social-bar .social-icon > a > .fa.fa-facebook {\n          background-color: #3b5998; }\n        .sticky-social-bar .social-icon > a > .fa.fa-twitter {\n          background-color: #55acee; }\n        .sticky-social-bar .social-icon > a > .fa.fa-linkedin {\n          background-color: #007bb5; }\n        .sticky-social-bar .social-icon > a > .fa.fa-youtube {\n          background-color: #bb0000; }\n        .sticky-social-bar .social-icon > a > .fa.fa-instagram {\n          background-color: #125688; }\n        .sticky-social-bar .social-icon > a > .fa.fa-pinterest-p {\n          background-color: #cb2027; }\n      .sticky-social-bar .social-icon > a > .social-icon-text {\n        font-size: 80%;\n        color: #fefefe;\n        text-transform: uppercase;\n        margin-right: 0.5rem; }\n    .sticky-social-bar .social-icon:hover {\n      transform: translateX(8.75rem); }\n      .sticky-social-bar .social-icon:hover > a {\n        color: inherit;\n        background-color: inherit; }\n\n.ecommerce-footer {\n  background-color: #fefefe;\n  padding: 70px 20px 40px 20px; }\n\n.ecommerce-footer-links h5 {\n  color: #0a0a0a;\n  font-size: 1.2rem;\n  font-weight: 600; }\n\n.ecommerce-footer-links .menu > li > a {\n  line-height: 1.5em;\n  padding: 0.5rem 0rem; }\n\n.ecommerce-footer-links a {\n  color: #707070;\n  font-size: 1rem;\n  transition: all 0.5s ease; }\n\n.ecommerce-footer-links a:hover {\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.ecommerce-footer-links .more-categories {\n  margin-top: 2rem; }\n  @media print, screen and (max-width: 39.99875em) {\n    .ecommerce-footer-links .more-categories {\n      margin-top: 2rem; } }\n\n@media print, screen and (max-width: 63.99875em) {\n  .ecommerce-footer-links .ecommerce-footer-links-block {\n    margin-bottom: 3rem; } }\n\n.ecommerce-footer-bottom-bar {\n  border-top: 1px solid #e6e6e6;\n  margin-top: 40px;\n  padding-bottom: 80px;\n  padding-top: 30px; }\n  .ecommerce-footer-bottom-bar .menu > li > a {\n    line-height: 1.2em;\n    padding: 10px 0; }\n  .ecommerce-footer-bottom-bar a {\n    color: #8a8a8a;\n    font-size: 0.9rem;\n    transition: all 0.5s ease; }\n  .ecommerce-footer-bottom-bar a:hover {\n    color: #0a0a0a;\n    transition: all 0.5s ease; }\n  @media print, screen and (max-width: 39.99875em) {\n    .ecommerce-footer-bottom-bar ul {\n      text-align: center; } }\n  .ecommerce-footer-bottom-bar li {\n    display: inline; }\n  .ecommerce-footer-bottom-bar .bottom-links {\n    margin-top: 0.65rem;\n    margin-left: 0; }\n  .ecommerce-footer-bottom-bar .bottom-links li {\n    padding-right: 2rem; }\n    @media print, screen and (max-width: 39.99875em) {\n      .ecommerce-footer-bottom-bar .bottom-links li {\n        text-align: center; } }\n  .ecommerce-footer-bottom-bar .ecommerce-footer-logomark {\n    text-align: center; }\n    @media print, screen and (max-width: 39.99875em) {\n      .ecommerce-footer-bottom-bar .ecommerce-footer-logomark {\n        padding-top: 1rem;\n        margin-bottom: 1rem; } }\n  .ecommerce-footer-bottom-bar .bottom-copyright {\n    color: #8a8a8a;\n    font-size: 0.9rem;\n    line-height: 1.2em;\n    padding-top: 1rem;\n    text-align: right; }\n    @media print, screen and (max-width: 39.99875em) {\n      .ecommerce-footer-bottom-bar .bottom-copyright {\n        text-align: center; } }\n\n.pagination-circular li.current {\n  border: 1px solid #2D6699;\n  border-radius: 5000px;\n  padding: 0.285em 0.8em;\n  font-size: 18px; }\n\n.pagination-circular li.disabled {\n  border: 1px solid #cacaca;\n  padding: 0.285em 0.8em;\n  border-radius: 5000px;\n  font-size: 18px; }\n\n.pagination-circular a {\n  border-radius: 5000px;\n  padding: 0.285em 0.8em;\n  border: 1px solid #2D6699;\n  font-size: 18px; }\n\n.pagination-circular li:not(.disabled):hover a {\n  background: #2D6699;\n  color: #fefefe; }\n\n.pagination-circular li a {\n  transition: background 0.15s ease-in, color 0.15s ease-in; }\n\n.pagination-pointed .pagination-pointed-button, .pagination-pointed .current, .pagination-pointed .pagination-previous {\n  position: relative;\n  display: inline-block;\n  padding: 6px 12px;\n  margin-bottom: 0;\n  text-align: center;\n  white-space: nowrap;\n  vertical-align: middle;\n  cursor: pointer;\n  background-image: none;\n  border: 1px solid transparent;\n  border-radius: 4px;\n  background-color: #2c3840;\n  color: #fff;\n  outline: 0;\n  text-decoration: none;\n  transition: all 0.2s linear; }\n  .pagination-pointed .pagination-pointed-button:hover, .pagination-pointed .current:hover, .pagination-pointed .pagination-previous:hover {\n    background-color: #41525e; }\n\n.pagination-pointed .current {\n  background: dodgerblue; }\n  .pagination-pointed .current:hover {\n    background-color: #0077ea; }\n\n.pagination-pointed .pagination-next a {\n  border-radius: 4px 0 0 4px;\n  margin-right: 18px; }\n  .pagination-pointed .pagination-next a:hover::after {\n    border-left: 17px solid #41525e; }\n  .pagination-pointed .pagination-next a::after {\n    content: \"\";\n    position: absolute;\n    top: 0;\n    right: -18px;\n    width: 0;\n    height: 0;\n    border-top: 17px solid transparent;\n    border-bottom: 17px solid transparent;\n    border-left: 17px solid #2c3840;\n    transition: all 0.2s linear; }\n\n.pagination-pointed .pagination-previous {\n  border-radius: 0 4px 4px 0;\n  margin-left: 18px; }\n  .pagination-pointed .pagination-previous:hover::after {\n    border-right: 17px solid #41525e; }\n  .pagination-pointed .pagination-previous::before {\n    content: \"\"; }\n  .pagination-pointed .pagination-previous::after {\n    content: \"\";\n    position: absolute;\n    top: 0;\n    left: -18px;\n    width: 0;\n    height: 0;\n    border-bottom: 17px solid transparent;\n    border-top: 17px solid transparent;\n    border-right: 17px solid #2c3840;\n    transition: all 0.2s linear; }\n\n.tag-cloud-section {\n  background: #7b93a4;\n  padding: 4rem;\n  max-width: 800px;\n  margin: 0 auto; }\n\n.tag-cloud-title {\n  text-align: center;\n  text-transform: uppercase;\n  font-weight: bold;\n  color: #e6e6e6;\n  border-bottom: 1px solid #cacaca;\n  padding: 1rem 0;\n  margin-bottom: 1rem; }\n\n.tag-cloud {\n  margin: 1rem;\n  text-align: center;\n  list-style: none; }\n  .tag-cloud .tag-cloud-individual-tag {\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    border-radius: 5000px;\n    background: #2c3840;\n    display: inline-block;\n    color: #e6e6e6;\n    margin: 3px;\n    text-transform: uppercase;\n    font-weight: bold; }\n    .tag-cloud .tag-cloud-individual-tag .fa {\n      margin-left: 7px;\n      color: #e6e6e6; }\n    .tag-cloud .tag-cloud-individual-tag:hover {\n      background: black;\n      transition: background-color .2s ease-in; }\n\n.social {\n  margin-right: .25rem; }\n  .social.facebook, .social.facebook.disabled, .social.facebook[disabled], .social.facebook.disabled:hover, .social.facebook[disabled]:hover, .social.facebook.disabled:focus, .social.facebook[disabled]:focus {\n    background-color: #3b5998;\n    color: #fff; }\n  .social.facebook:hover, .social.facebook:focus {\n    background-color: #2f477a;\n    color: #fff; }\n  .social.twitter, .social.twitter.disabled, .social.twitter[disabled], .social.twitter.disabled:hover, .social.twitter[disabled]:hover, .social.twitter.disabled:focus, .social.twitter[disabled]:focus {\n    background-color: #55acee;\n    color: #fff; }\n  .social.twitter:hover, .social.twitter:focus {\n    background-color: #1a8fe8;\n    color: #fff; }\n  .social.linkedin, .social.linkedin.disabled, .social.linkedin[disabled], .social.linkedin.disabled:hover, .social.linkedin[disabled]:hover, .social.linkedin.disabled:focus, .social.linkedin[disabled]:focus {\n    background-color: #007bb5;\n    color: #fff; }\n  .social.linkedin:hover, .social.linkedin:focus {\n    background-color: #006291;\n    color: #fff; }\n  .social.youtube, .social.youtube.disabled, .social.youtube[disabled], .social.youtube.disabled:hover, .social.youtube[disabled]:hover, .social.youtube.disabled:focus, .social.youtube[disabled]:focus {\n    background-color: #bb0000;\n    color: #fff; }\n  .social.youtube:hover, .social.youtube:focus {\n    background-color: #960000;\n    color: #fff; }\n  .social.instagram, .social.instagram.disabled, .social.instagram[disabled], .social.instagram.disabled:hover, .social.instagram[disabled]:hover, .social.instagram.disabled:focus, .social.instagram[disabled]:focus {\n    background-color: #125688;\n    color: #fff; }\n  .social.instagram:hover, .social.instagram:focus {\n    background-color: #0e456d;\n    color: #fff; }\n  .social.pinterest, .social.pinterest.disabled, .social.pinterest[disabled], .social.pinterest.disabled:hover, .social.pinterest[disabled]:hover, .social.pinterest.disabled:focus, .social.pinterest[disabled]:focus {\n    background-color: #cb2027;\n    color: #fff; }\n  .social.pinterest:hover, .social.pinterest:focus {\n    background-color: #a21a1f;\n    color: #fff; }\n  .social.google-plus, .social.google-plus.disabled, .social.google-plus[disabled], .social.google-plus.disabled:hover, .social.google-plus[disabled]:hover, .social.google-plus.disabled:focus, .social.google-plus[disabled]:focus {\n    background-color: #dd4b39;\n    color: #fff; }\n  .social.google-plus:hover, .social.google-plus:focus {\n    background-color: #be3221;\n    color: #fff; }\n  .social.github, .social.github.disabled, .social.github[disabled], .social.github.disabled:hover, .social.github[disabled]:hover, .social.github.disabled:focus, .social.github[disabled]:focus {\n    background-color: #000000;\n    color: #fff; }\n  .social.github:hover, .social.github:focus {\n    background-color: black;\n    color: #fff; }\n  .social.tumblr, .social.tumblr.disabled, .social.tumblr[disabled], .social.tumblr.disabled:hover, .social.tumblr[disabled]:hover, .social.tumblr.disabled:focus, .social.tumblr[disabled]:focus {\n    background-color: #32506d;\n    color: #fff; }\n  .social.tumblr:hover, .social.tumblr:focus {\n    background-color: #284057;\n    color: #fff; }\n  .social > .fa {\n    color: #fff;\n    margin-right: .25rem; }\n\n.polls {\n  margin-bottom: 1rem; }\n  .polls .polls-question {\n    margin-bottom: .5rem; }\n    .polls .polls-question .polls-question-label {\n      color: #2D6699;\n      font-weight: 500;\n      margin-right: .25rem; }\n  .polls .polls-submit {\n    margin-top: .3rem; }\n    .polls .polls-submit .button {\n      margin-right: .5rem;\n      text-transform: uppercase; }\n\n.news-image-gallery-container {\n  background-color: #fff;\n  padding: 2rem 1.5rem 1rem; }\n  .news-image-gallery-container .rounded-social-buttons {\n    text-align: left; }\n    .news-image-gallery-container .rounded-social-buttons .social-button {\n      display: inline-block;\n      position: relative;\n      cursor: pointer;\n      width: 2.5rem;\n      height: 2.5rem;\n      border: 0.125rem solid transparent;\n      padding: 0;\n      text-decoration: none;\n      text-align: center;\n      color: #fff;\n      font-size: 1.25rem;\n      font-weight: normal;\n      line-height: 1.8em;\n      border-radius: 1.6875rem;\n      transition: 0.5s ease all;\n      margin-right: 0.25rem;\n      margin-bottom: 0.25rem; }\n      .news-image-gallery-container .rounded-social-buttons .social-button:hover, .news-image-gallery-container .rounded-social-buttons .social-button:focus {\n        transform: rotate(360deg); }\n      .news-image-gallery-container .rounded-social-buttons .social-button.facebook {\n        background: #3b5998; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.facebook:before {\n          font-family: \"FontAwesome\";\n          content: \"\"; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.facebook:hover, .news-image-gallery-container .rounded-social-buttons .social-button.facebook:focus {\n          color: #3b5998;\n          background: #fff;\n          border-color: #3b5998; }\n      .news-image-gallery-container .rounded-social-buttons .social-button.twitter {\n        background: #55acee; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.twitter:before {\n          font-family: \"FontAwesome\";\n          content: \"\"; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.twitter:hover, .news-image-gallery-container .rounded-social-buttons .social-button.twitter:focus {\n          color: #55acee;\n          background: #fff;\n          border-color: #55acee; }\n      .news-image-gallery-container .rounded-social-buttons .social-button.linkedin {\n        background: #007bb5; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:before {\n          font-family: \"FontAwesome\";\n          content: \"\"; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:hover, .news-image-gallery-container .rounded-social-buttons .social-button.linkedin:focus {\n          color: #007bb5;\n          background: #fff;\n          border-color: #007bb5; }\n      .news-image-gallery-container .rounded-social-buttons .social-button.google-plus {\n        background: #dd4b39; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:before {\n          font-family: \"FontAwesome\";\n          content: \"\"; }\n        .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:hover, .news-image-gallery-container .rounded-social-buttons .social-button.google-plus:focus {\n          color: #dd4b39;\n          background: #fff;\n          border-color: #dd4b39; }\n  .news-image-gallery-container .news-image-gallery-title {\n    margin-top: .5rem; }\n  .news-image-gallery-container .read-more {\n    color: #8a8a8a; }\n\n.quote-inline-wrap-article-content {\n  max-width: 100%;\n  position: relative; }\n\n.quote-inline-wrap {\n  float: left;\n  max-width: 21.875rem;\n  padding: 0 1rem 1rem 0; }\n  .quote-inline-wrap .quote-inline-marks {\n    font-size: 6.25rem;\n    color: #8a8a8a;\n    line-height: 1rem; }\n  .quote-inline-wrap .quote-inline-testimonial {\n    border-radius: 5px; }\n    .quote-inline-wrap .quote-inline-testimonial p {\n      font-weight: 300; }\n  .quote-inline-wrap .quote-inline-person {\n    margin-bottom: 1.5rem; }\n    .quote-inline-wrap .quote-inline-person .quote-inline-photo img {\n      border-radius: 50%;\n      width: 4.375rem;\n      height: 4.375rem;\n      float: left;\n      margin-right: 1rem; }\n    .quote-inline-wrap .quote-inline-person p {\n      position: relative;\n      top: 5px; }\n      .quote-inline-wrap .quote-inline-person p:nth-child(2) {\n        font-size: 1rem;\n        font-weight: 500;\n        margin-bottom: 0; }\n      .quote-inline-wrap .quote-inline-person p:nth-child(3) {\n        font-size: 0.875rem;\n        font-weight: 400;\n        color: #8a8a8a; }\n  @media print, screen and (max-width: 63.99875em) {\n    .quote-inline-wrap {\n      width: 100%;\n      float: none;\n      display: block; } }\n\n.neat-article-container {\n  margin-top: 1.5rem; }\n  .neat-article-container .neat-article-header {\n    width: 100%;\n    display: flex;\n    align-items: flex-start; }\n    .neat-article-container .neat-article-header .article-header-avatar {\n      padding-right: 0.5rem;\n      padding-left: 0.5rem; }\n      .neat-article-container .neat-article-header .article-header-avatar .header-avatar {\n        width: 3.75rem;\n        height: 3.75rem;\n        border-radius: 50%; }\n    .neat-article-container .neat-article-header .article-header-author {\n      flex: 1 0 0; }\n      .neat-article-container .neat-article-header .article-header-author .author-name {\n        color: #0a0a0a;\n        margin-bottom: 0; }\n      .neat-article-container .neat-article-header .article-header-author .author-description,\n      .neat-article-container .neat-article-header .article-header-author .article-date-read {\n        color: #8a8a8a;\n        margin-bottom: 0;\n        font-size: 0.85em; }\n  .neat-article-container .neat-article-title {\n    margin-top: 1rem; }\n    .neat-article-container .neat-article-title .article-title {\n      color: #0a0a0a;\n      font-weight: 600; }\n  .neat-article-container .neat-article-image {\n    margin-top: 1.5rem; }\n    .neat-article-container .neat-article-image .article-image {\n      width: 100%;\n      height: 100vh; }\n      @media print, screen and (min-width: 40em) and (max-width: 63.99875em) {\n        .neat-article-container .neat-article-image .article-image {\n          height: 65vh; } }\n      @media print, screen and (max-width: 39.99875em) {\n        .neat-article-container .neat-article-image .article-image {\n          height: 45vh; } }\n  .neat-article-container .neat-article-content {\n    margin-top: 2rem; }\n    .neat-article-container .neat-article-content .article-social .rounded-social-buttons {\n      text-align: center; }\n      .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button {\n        display: block;\n        position: relative;\n        cursor: pointer;\n        width: 3.125rem;\n        height: 3.125rem;\n        border: 0.125rem solid transparent;\n        padding: 0;\n        text-decoration: none;\n        text-align: center;\n        color: #fff;\n        font-size: 1.5625rem;\n        font-weight: normal;\n        line-height: 2em;\n        border-radius: 1.6875rem;\n        transition: all 0.5s ease;\n        margin-right: 0.75rem;\n        margin-bottom: 0.75rem; }\n        .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button:focus {\n          transform: rotate(360deg); }\n        .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook {\n          background: #3b5998; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:before {\n            font-family: \"FontAwesome\";\n            content: \"\"; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.facebook:focus {\n            color: #3b5998;\n            background: #fff;\n            border-color: #3b5998; }\n        .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter {\n          background: #55acee; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:before {\n            font-family: \"FontAwesome\";\n            content: \"\"; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.twitter:focus {\n            color: #55acee;\n            background: #fff;\n            border-color: #55acee; }\n        .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus {\n          background: #dd4b39; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:before {\n            font-family: \"FontAwesome\";\n            content: \"\"; }\n          .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:hover, .neat-article-container .neat-article-content .article-social .rounded-social-buttons .social-button.google-plus:focus {\n            color: #dd4b39;\n            background: #fff;\n            border-color: #dd4b39; }\n    .neat-article-container .neat-article-content .article-content {\n      color: #0a0a0a; }\n\n.article-row-section {\n  max-width: 75rem;\n  margin-right: auto;\n  margin-left: auto;\n  display: flex;\n  flex-flow: row wrap;\n  justify-content: left; }\n\n.article-row-section-inner {\n  flex: 0 0 100%;\n  max-width: 100%;\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .article-row-section-inner {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  @media print, screen and (min-width: 40em) {\n    .article-row-section-inner {\n      flex: 0 0 83.33333%;\n      max-width: 83.33333%;\n      padding-right: 0.625rem;\n      padding-left: 0.625rem; } }\n  @media print, screen and (min-width: 40em) and (min-width: 40em) {\n    .article-row-section-inner {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n\n.article-row-section-header {\n  padding: 1.5rem 0;\n  margin: 0;\n  line-height: 1; }\n\n.article-row {\n  display: flex;\n  flex-direction: column;\n  padding: 1.5rem 0; }\n  @media print, screen and (min-width: 40em) {\n    .article-row {\n      flex-direction: row; } }\n\n.article-row-img img {\n  width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .article-row-img img {\n      max-width: none;\n      width: auto; } }\n\n.article-row-content {\n  padding: 1.5rem 0 0;\n  color: #0a0a0a; }\n  @media print, screen and (min-width: 40em) {\n    .article-row-content {\n      padding: 0 0 0 1.5rem; } }\n\n.article-row-header {\n  padding: 1.5rem 0 0;\n  color: #0a0a0a; }\n  @media print, screen and (min-width: 40em) {\n    .article-row-header {\n      padding: 0 0 0 1.5rem; } }\n\n.article-row-content-header {\n  font-size: 1.5rem; }\n\n.article-row-content-description {\n  font-size: 1.25rem; }\n\n.article-row-content-author,\n.article-row-content-time {\n  font-size: 0.875rem;\n  margin-bottom: 0;\n  color: #8a8a8a; }\n\n.article-row-reversed .article-row-content {\n  order: 2;\n  padding: 0 1.5rem 0 0; }\n\n.article-row-reversed .article-row-img {\n  order: 1;\n  padding: 0 0 1.5rem 0; }\n\n@media print, screen and (min-width: 40em) {\n  .article-row-reversed .article-row-content {\n    order: 1; }\n  .article-row-reversed .article-row-img {\n    order: 2; } }\n\n.hero-section {\n  background: url(\"https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg\") 50% no-repeat;\n  background-size: cover;\n  height: 60vh;\n  text-align: center;\n  display: flex;\n  align-items: center;\n  justify-content: center; }\n  .hero-section .hero-section-text {\n    color: #fff;\n    text-shadow: 1px 1px 2px #0a0a0a; }\n","//  Foundation for Sites Settings\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. Flexbox Utilities\n//  20. Forms\n//  21. Label\n//  22. Media Object\n//  23. Menu\n//  24. Meter\n//  25. Off-canvas\n//  26. Orbit\n//  27. Pagination\n//  28. Progress Bar\n//  29. Prototype Arrow\n//  30. Prototype Border-Box\n//  31. Prototype Border-None\n//  32. Prototype Bordered\n//  33. Prototype Display\n//  34. Prototype Font-Styling\n//  35. Prototype List-Style-Type\n//  36. Prototype Overflow\n//  37. Prototype Position\n//  38. Prototype Rounded\n//  39. Prototype Separator\n//  40. Prototype Shadow\n//  41. Prototype Sizing\n//  42. Prototype Spacing\n//  43. Prototype Text-Decoration\n//  44. Prototype Text-Transformation\n//  45. Prototype Text-Utilities\n//  46. Responsive Embed\n//  47. Reveal\n//  48. Slider\n//  49. Switch\n//  50. Table\n//  51. Tabs\n//  52. Thumbnail\n//  53. Title Bar\n//  54. Tooltip\n//  55. Top Bar\n//  56. Xy Grid\n\n@import 'util/util';\n\n// 1. Global\n// ---------\n\n$global-font-size: 100%;\n$global-width: rem-calc(1200);\n$global-lineheight: 1.5;\n$foundation-palette: (\n  primary: #2D6699,\n  secondary: #A6ADB4,\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: #F0F0F0;\n$body-font-color: $black;\n\n@font-face {\nfont-family: 'Acumin Pro Bold';\nfont-style: normal;\nfont-weight: normal;\nsrc: local('Acumin Pro Bold'), url('Acumin-BdPro.woff') format('woff');\n}\n@font-face {\nfont-family: 'Acumin Pro';\nfont-style: normal;\nfont-weight: normal;\nsrc: local('Acumin Pro'), url('Acumin-RPro.woff') format('woff');\n}\n@font-face {\n  font-family: myRoboto;\n  src: url(\"/assets/fonts/RobotoMono-Light.ttf\");\n}\n@font-face {\n  font-family: BalooBhaina;\n  src: url(\"/assets/fonts/BalooBhaina2-Regular.ttf\");\n}\n\n@font-face {\n  font-family: DancingScript;\n  src: url(\"/assets/fonts/DancingScript.ttf\");\n}\n// # $body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif;'Helvetica Neue', Helvetica,\n$body-font-family:  'Acumin Pro', 'Helvetica Neue', Helvetica;\n\n$body-antialiased: true;\n$global-margin: 1rem;\n$global-padding: 1rem;\n$global-position: 1rem;\n$global-weight-normal: normal;\n$global-weight-bold: bold;\n$global-radius: 0;\n$global-menu-padding: 0.7rem 1rem;\n$global-menu-nested-margin: 1rem;\n$global-text-direction: ltr;\n$global-flexbox: true;\n$global-prototype-breakpoints: false;\n$global-button-cursor: auto;\n$global-color-pick-contrast-tolerance: 0;\n$print-transparent-backgrounds: true;\n$print-hrefs: 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$breakpoints-hidpi: (\n  hidpi-1: 1,\n  hidpi-1-5: 1.5,\n  hidpi-2: 2,\n  retina: 2,\n  hidpi-3: 3\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$grid-column-alias: 'columns';\n$block-grid-max: 8;\n\n// 4. Base Typography\n// ------------------\n\n$header-font-family: 'Helvetica Neue', Helvetica; //$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': 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);\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$enable-code-inline: true;\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$enable-cite-block: true;\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$cite-color: $dark-gray;\n$cite-font-size: rem-calc(13);\n$cite-pseudo-content: '\\2014 \\0020';\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$code-block-padding: 1rem;\n$code-block-margin-bottom: 1.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-plus-content: '\\002B';\n$accordion-minus-content: '\\2013';\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-padding: $global-menu-padding;\n$accordionmenu-nested-margin: $global-menu-nested-margin;\n$accordionmenu-submenu-padding: $accordionmenu-padding;\n$accordionmenu-arrows: true;\n$accordionmenu-arrow-color: $primary-color;\n$accordionmenu-item-background: null;\n$accordionmenu-border: null;\n$accordionmenu-submenu-toggle-background: null;\n$accordion-submenu-toggle-border: $accordionmenu-border;\n$accordionmenu-submenu-toggle-width: 40px;\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width;\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-separator: true;\n$breadcrumbs-item-separator-item: '/';\n$breadcrumbs-item-separator-item-rtl: '\\\\';\n$breadcrumbs-item-separator-color: $medium-gray;\n\n// 11. Button\n// ----------\n\n$button-font-family: inherit;\n$button-font-weight: null;\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-border: 1px solid transparent;\n$button-hollow-border-width: 1px;\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$button-responsive-expanded: false;\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-sizes: (\n  small: 0.5rem,\n  default: 1rem,\n  large: 3rem,\n);\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-bottom: $global-margin;\n\n// 15. Close Button\n// ----------------\n\n$closebutton-position: right top;\n$closebutton-z-index: 10;\n$closebutton-default-size: medium;\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-padding: $global-menu-padding;\n$drilldown-nested-margin: 0;\n$drilldown-background: $white;\n$drilldown-submenu-padding: $drilldown-padding;\n$drilldown-submenu-background: $white;\n$drilldown-arrow-color: $primary-color;\n$drilldown-arrow-size: 6px;\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-arrow-padding: 1.5rem;\n$dropdownmenu-min-width: 200px;\n$dropdownmenu-background: null;\n$dropdownmenu-submenu-background: $white;\n$dropdownmenu-padding: $global-menu-padding;\n$dropdownmenu-nested-margin: 0;\n$dropdownmenu-submenu-padding: $dropdownmenu-padding;\n$dropdownmenu-border: 1px solid $medium-gray;\n$dropdown-menu-item-color-active: get-color(primary);\n$dropdown-menu-item-background-active: transparent;\n\n// 19. Flexbox Utilities\n// ---------------------\n\n$flex-source-ordering-count: 6;\n$flexbox-responsive-breakpoints: true;\n\n// 20. 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-line-height: $global-lineheight;\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-padding: $form-spacing / 2;\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// 21. 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// 22. Media Object\n// ----------------\n\n$mediaobject-margin-bottom: $global-margin;\n$mediaobject-section-padding:8rem;// $global-ng * 1.5;\n$mediaobject-image-width-stacked: 100%;\n\n// 23. Menu\n// --------\n\n$menu-margin: 0;\n$menu-nested-margin: $global-menu-nested-margin;\n$menu-items-padding: $global-menu-padding;\n$menu-simple-margin: 1rem;\n$menu-item-color-active: $white;\n$menu-item-color-alt-active: $black;\n$menu-item-background-active: get-color(primary);\n$menu-icon-spacing: 0.25rem;\n$menu-state-back-compat: true;\n$menu-centered-back-compat: true;\n$menu-icons-back-compat: true;\n\n// 24. 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// 25. Off-canvas\n// --------------\n\n$offcanvas-sizes: (\n  small: 250px,\n);\n$offcanvas-vertical-sizes: (\n  small: 250px,\n);\n$offcanvas-background: $light-gray;\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7);\n$offcanvas-inner-shadow-size: 20px;\n$offcanvas-inner-shadow-color: rgba($black, 0.25);\n$offcanvas-overlay-zindex: 11;\n$offcanvas-push-zindex: 12;\n$offcanvas-overlap-zindex: 13;\n$offcanvas-reveal-zindex: 12;\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// 26. 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// 27. 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$pagination-arrow-previous: '\\00AB';\n$pagination-arrow-next: '\\00BB';\n\n// 28. 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// 29. Prototype Arrow\n// -------------------\n\n$prototype-arrow-directions: (\n  down,\n  up,\n  right,\n  left\n);\n$prototype-arrow-size: 0.4375rem;\n$prototype-arrow-color: $black;\n\n// 30. Prototype Border-Box\n// ------------------------\n\n$prototype-border-box-breakpoints: $global-prototype-breakpoints;\n\n// 31. Prototype Border-None\n// -------------------------\n\n$prototype-border-none-breakpoints: $global-prototype-breakpoints;\n\n// 32. Prototype Bordered\n// ----------------------\n\n$prototype-bordered-breakpoints: $global-prototype-breakpoints;\n$prototype-border-width: rem-calc(1);\n$prototype-border-type: solid;\n$prototype-border-color: $medium-gray;\n\n// 33. Prototype Display\n// ---------------------\n\n$prototype-display-breakpoints: $global-prototype-breakpoints;\n$prototype-display: (\n  inline,\n  inline-block,\n  block,\n  table,\n  table-cell\n);\n\n// 34. Prototype Font-Styling\n// --------------------------\n\n$prototype-font-breakpoints: $global-prototype-breakpoints;\n$prototype-wide-letter-spacing: rem-calc(4);\n$prototype-font-normal: $global-weight-normal;\n$prototype-font-bold: $global-weight-bold;\n\n// 35. Prototype List-Style-Type\n// -----------------------------\n\n$prototype-list-breakpoints: $global-prototype-breakpoints;\n$prototype-style-type-unordered: (\n  disc,\n  circle,\n  square\n);\n$prototype-style-type-ordered: (\n  decimal,\n  lower-alpha,\n  lower-latin,\n  lower-roman,\n  upper-alpha,\n  upper-latin,\n  upper-roman\n);\n\n// 36. Prototype Overflow\n// ----------------------\n\n$prototype-overflow-breakpoints: $global-prototype-breakpoints;\n$prototype-overflow: (\n  visible,\n  hidden,\n  scroll\n);\n\n// 37. Prototype Position\n// ----------------------\n\n$prototype-position-breakpoints: $global-prototype-breakpoints;\n$prototype-position: (\n  static,\n  relative,\n  absolute,\n  fixed\n);\n$prototype-position-z-index: 975;\n\n// 38. Prototype Rounded\n// ---------------------\n\n$prototype-rounded-breakpoints: $global-prototype-breakpoints;\n$prototype-border-radius: rem-calc(3);\n\n// 39. Prototype Separator\n// -----------------------\n\n$prototype-separator-breakpoints: $global-prototype-breakpoints;\n$prototype-separator-align: center;\n$prototype-separator-height: rem-calc(2);\n$prototype-separator-width: 3rem;\n$prototype-separator-background: $primary-color;\n$prototype-separator-margin-top: $global-margin;\n\n// 40. Prototype Shadow\n// --------------------\n\n$prototype-shadow-breakpoints: $global-prototype-breakpoints;\n$prototype-box-shadow: 0 2px 5px 0 rgba(0,0,0,.16),\n                       0 2px 10px 0 rgba(0,0,0,.12);\n\n// 41. Prototype Sizing\n// --------------------\n\n$prototype-sizing-breakpoints: $global-prototype-breakpoints;\n$prototype-sizing: (\n  width,\n  height\n);\n$prototype-sizes: (\n  25: 25%,\n  50: 50%,\n  75: 75%,\n  100: 100%\n);\n\n// 42. Prototype Spacing\n// ---------------------\n\n$prototype-spacing-breakpoints: $global-prototype-breakpoints;\n$prototype-spacers-count: 3;\n\n// 43. Prototype Text-Decoration\n// -----------------------------\n\n$prototype-decoration-breakpoints: $global-prototype-breakpoints;\n$prototype-text-decoration: (\n  overline,\n  underline,\n  line-through,\n);\n\n// 44. Prototype Text-Transformation\n// ---------------------------------\n\n$prototype-transformation-breakpoints: $global-prototype-breakpoints;\n$prototype-text-transformation: (\n  lowercase,\n  uppercase,\n  capitalize\n);\n\n// 45. Prototype Text-Utilities\n// ----------------------------\n\n$prototype-utilities-breakpoints: $global-prototype-breakpoints;\n$prototype-text-overflow: ellipsis;\n\n// 46. 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// 47. 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// 48. 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// 49. 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$switch-opacity-disabled: .5;\n$switch-cursor-disabled: not-allowed;\n\n// 50. 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$table-stack-breakpoint: medium;\n\n// 51. 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-content-background: $white;\n$tab-content-border: $light-gray;\n$tab-content-color: $body-font-color;\n$tab-content-padding: 1rem;\n\n// 52. Thumbnail\n// -------------\n\n$thumbnail-border: 4px solid $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// 53. 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// 54. Tooltip\n// -----------\n\n$has-tip-cursor: help;\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-max-width: 10rem;\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// 55. Top Bar\n// -----------\n\n$topbar-padding: 0.3rem;\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\n// 56. Xy Grid\n// -----------\n\n$xy-grid: true;\n$grid-container: $global-width;\n$grid-columns: 12;\n$grid-margin-gutters: (\n  small: 20px,\n  medium: 30px\n);\n$grid-padding-gutters: $grid-margin-gutters;\n$grid-container-padding: $grid-padding-gutters;\n$grid-container-max: $global-width;\n$xy-block-grid-max: 8;\n\n\n$large-article-header-bg-color: $dark-gray;\n$large-article-header-color:$white;\n$large-article-header-bg: \"\";\n\n$large-article-header-height: rem-calc(400);\n$radius:5px;\n\n.large-article-header {\n  //  background-blend-mode: color-burn;\n    background-position: center;\n}\n\n\ndiv.top-bar {\n    border-bottom: $primary-color thin solid;\n}\n","/**\n * Foundation for Sites\n * Version 6.6.3\n * https://get.foundation\n * Licensed under MIT Open Source\n */\n\n// --- Dependencies ---\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n  $flex: true,\n  $prototype: false,\n  $xy-grid: $xy-grid\n) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  @if $xy-grid {\n    $xy-grid: true !global;\n  }\n\n  // Global styles\n  @include foundation-global-styles;\n  @include foundation-forms;\n  @include foundation-typography;\n\n  // Grids\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @if $xy-grid {\n      @include foundation-xy-grid-classes;\n    }\n    @else {\n      @include foundation-flex-grid;\n    }\n  }\n\n  // Generic components\n  @include foundation-button;\n  @include foundation-button-group;\n  @include foundation-close-button;\n  @include foundation-label;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-switch;\n  @include foundation-table;\n  // Basic components\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-dropdown;\n  @include foundation-pagination;\n  @include foundation-tooltip;\n\n  // Containers\n  @include foundation-accordion;\n  @include foundation-media-object;\n  @include foundation-orbit;\n  @include foundation-responsive-embed;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  // Menu-based containers\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-accordion-menu;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown-menu;\n\n  // Layout components\n  @include foundation-off-canvas;\n  @include foundation-reveal;\n  @include foundation-sticky;\n  @include foundation-title-bar;\n  @include foundation-top-bar;\n\n  // Helpers\n  @include foundation-float-classes;\n  @if $flex { @include foundation-flex-classes; }\n  @include foundation-visibility-classes;\n  @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// A list of named HiDPI breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries for resolutions.\n/// Values must represent the device pixels / web pixels ration and be unitless or in DPPX.\n/// @type Map\n$breakpoints-hidpi: (\n  hidpi-1: 1,\n  hidpi-1-5: 1.5,\n  hidpi-2: 2,\n  retina: 2,\n  hidpi-3: 3\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n  @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n  $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n  // Web standard Pixels per inch. (1ddpx / $std-web-dpi) = 1dpi\n  // See https://www.w3.org/TR/css-values-3/#absolute-lengths\n  $std-web-dpi: 96;\n\n  // Size or keyword\n  $bp: nth($val, 1);\n  // Value of the following breakpoint\n  $bp-next: null;\n  // Value for max-width media queries\n  $bp-min: null;\n  // Value for min-width media queries\n  $bp-max: null;\n  // Direction of media query (up, down, or only)\n  $dir: if(length($val) > 1, nth($val, 2), up);\n  // If named, name of the breakpoint\n  $name: null;\n  // If the breakpoint is a HiDPI breakpoint\n  $hidpi: false;\n\n  // Orientation media queries have a unique syntax\n  @if $bp == 'landscape' or $bp == 'portrait' {\n    @return '(orientation: #{$bp})';\n  }\n\n  // If a breakpoint name is given, get its value from the $breakpoints/$breakpoints-hidpi map.\n  @if type-of($bp) == 'string' {\n    @if map-has-key($breakpoints, $bp) {\n      $name: $bp;\n      $bp: map-get($breakpoints, $name);\n      $bp-next: -zf-map-next($breakpoints, $name);\n    }\n    @else if map-has-key($breakpoints-hidpi, $bp) {\n      $name: $bp;\n      $bp: map-get($breakpoints-hidpi, $name);\n      $bp-next: -zf-map-next-number($breakpoints-hidpi, $bp);\n      $hidpi: true;\n    }\n    @else {\n      $bp: 0;\n      @warn 'breakpoint(): \"#{$val}\" is not defined in your `$breakpoints` or `$breakpoints-hidpi` setting.';\n    }\n  }\n\n  @if not $name and $dir == 'only' {\n    @warn 'breakpoint(): Only named media queries can have an `only` range.';\n    @return null;\n  }\n\n  // Only 'only' and 'up' have a min limit.\n  @if $dir == 'only' or $dir == 'up' {\n    $bp-min: if($hidpi, strip-unit($bp), -zf-bp-to-em($bp));\n  }\n  // Only 'only' and 'down' have a max limit.\n  @if $dir == 'only' or $dir == 'down' {\n    // If the breakpoint is a value, use it as max limit.\n    @if not $name {\n      $bp-max: if($hidpi, strip-unit($bp), -zf-bp-to-em($bp));\n    }\n    // If the breakpoint is named, the max limit is the following breakpoint - 1px.\n    @else if $bp-next {\n      // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n      // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n      // See https://github.com/foundation/foundation-sites/issues/11313\n      $bp-max: if($hidpi, $bp-next - (1/$std-web-dpi), -zf-bp-to-em($bp-next) - 0.00125);\n    }\n  }\n\n  // Generate the media query string from min and max limits.\n  @if $hidpi {\n    // Generate values in DPI instead of DPPX for an IE9-11/Opera mini compatibility.\n    // See https://caniuse.com/#feat=css-media-resolution\n    $bp-min-dpi: if($bp-min, $bp-min * $std-web-dpi * 1dpi, $bp-min);\n    $bp-max-dpi: if($bp-max, $bp-max * $std-web-dpi * 1dpi, $bp-max);\n    @return zf-str-join(\n      -zf-bp-join($bp-min, $bp-max, '-webkit-min-device-pixel-ratio', '-webkit-max-device-pixel-ratio'),\n      -zf-bp-join($bp-min-dpi, $bp-max-dpi, 'min-resolution', 'max-resolution'),\n      ', ');\n  }\n  @else {\n    @return -zf-bp-join($bp-min, $bp-max);\n  }\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` and `$breakpoints-hidpi` maps, 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/// If multiple values are passed, the mixin will generate a media query for each of them as described above.\n/// Since the content is duplicated for each breakpoint, this mixin should only be used with properties that\n/// change across breakpoints.\n///\n/// @param {Keyword|Number} $values... - Breakpoint name or px/rem/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($values...) {\n  @for $i from 1 through length($values) {\n    $value: nth($values, $i);\n    $str: breakpoint($value);\n    $bp: index($-zf-breakpoints-keys, nth($value, 1));\n    $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n    // Direction of media query (up, down, or only)\n    $dir: if(length($value) > 1, nth($value, 2), up);\n\n    $old-zf-size: null;\n\n    // Make breakpoint size available as a variable\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n    // If $str is still an empty string, no media query is needed\n    @if $str == '' {\n      @content;\n    }\n\n    // Otherwise, wrap the content in a media query\n    @else {\n      // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n      // generate print if the breakpoint affects the print-breakpoint (or smaller).\n      // This means the current condition only needs to be extended so 'down' always generates print.\n      @if $bp != null and ($bp <= $pbp or $dir == down) {\n        @media print, screen and #{$str} {\n          @content;\n        }\n      }\n      @else {\n        @media screen and #{$str} {\n          @content;\n        }\n      }\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `<meta>` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n  $str: '';\n  @each $key, $value in $map {\n    $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n  }\n  $str: str-slice($str, 1, -2);\n\n  @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n  // Store the keys of the map as a list\n  $values: map-keys($map);\n\n  $i: 0;\n\n  // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n  @if (map-has-key($map, $key)) {\n    $i: index($values, $key) + 1;\n  }\n\n  // If the key doesn't exist, or it's the last key in the map, return null\n  @if ($i > length($map) or $i == 0) {\n    @return null;\n  }\n  // Otherwise, return the value\n  @else {\n    @return map-get($map, nth($values, $i));\n  }\n\n}\n\n/// Find the next number in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $number - Number to use as a starting point.\n///\n/// @returns {Mixed} The number following `$number`, if `$number` was found. If `$number` was not found, or `$number` was the biggest number in the map, returns `null`.\n@function -zf-map-next-number($map, $number) {\n\n  $next_number: null;\n\n  @each $k, $v in $map {\n    @if type-of($v) == 'number' and $v > $number and ($next_number == null or $v < $next_number) {\n      $next_number: $v;\n    }\n  }\n\n  @return $next_number;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n  $list: ();\n  $found_key: false;\n\n  @each $name in $-zf-breakpoints-keys {\n    @if ($name == $key) {\n      $found_key: true;\n    }\n    @if not $found_key {\n      $list: append($list, $name);\n    }\n  }\n  @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n  $last: $-zf-zero-breakpoint;\n  $found: false;\n\n  $value: unitless-calc($breakpoint, 1px);\n  @each $key, $val in $breakpoints {\n    @if not $found {\n      @if unitless-calc($val) > $value {\n        $found: true;\n      } @else {\n        $last: $key;\n      }\n    }\n  }\n\n  @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n  // If the given map is a single value, return it\n  @if type-of($map) == 'number' {\n    @return $map;\n  }\n\n\n  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @if type-of($value) == 'number' {\n      $value: -zf-closest-named-breakpoint($value);\n    } @else {\n      @return null;\n    }\n  }\n  // Check if the breakpoint name exists in the local config map\n  @else if map-has-key($map, $value) {\n    // If it does, just return the value\n    @return map-get($map, $value);\n  }\n  // Otherwise, find the next lowest breakpoint and return that value\n  @else {\n    $anchor: null;\n    $found: false;\n\n    @each $key, $val in $breakpoints {\n      @if not $found {\n        @if map-has-key($map, $key) {\n          $anchor: $key;\n        }\n        @if $key == $value {\n          $found: true;\n        }\n      }\n    }\n\n    @return map-get($map, $anchor);\n  }\n}\n\n/// Return the best breakpoint to use according to the calling context. It returns in order:\n/// 1. the given `$value` argument if it is not null.\n/// 2. the global breakpoint context `$-zf-size` if it is not null (like if called inside then `breakpoint()` mixin)\n/// 3. the given `$default` argument.\n/// @access private\n///\n/// @param {Keyword} $value [null] - Breakpoint to use in priority if non-null.\n/// @param {Keyword} $default [null] - Breakpoint to use by default if no other value can be used.\n///\n/// @return {Keyword} The resolved breakpoint.\n@function -zf-current-breakpoint($value: null, $default: null) {\n  @if ($value != null) {\n    @return $value;\n  }\n  @else if (variable-exists(-zf-size) and type-of($-zf-size) != 'number') and $-zf-size != null {\n    @return $-zf-size;\n  }\n  @else {\n    @return $default;\n  }\n}\n\n/// Return media query string from the given min and/or max limits.\n/// If a limit is equal to `null` or `0`, it is ignored.\n/// @access private\n///\n/// @param {Number} $min [0] - Min media query limit.\n/// @param {Number} $max [0] - Max media query limit.\n/// @param {String} $min-name ['min-width'] - Name of the min media query limit.\n/// @param {String} $delimiter ['max-width'] - Name of the max media query limit.\n///\n/// @returns {String} Media Query string.\n@function -zf-bp-join(\n  $min: 0,\n  $max: 0,\n  $min-name: 'min-width',\n  $max-name: 'max-width'\n) {\n  @return zf-str-join(\n    if($min and $min > 0, '(#{$min-name}: #{$min})', null),\n    if($max and $max > 0, '(#{$max-name}: #{$max})', null),\n    ' and ');\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n  $medium-up: unquote('screen and #{breakpoint(medium)}');\n  $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n  $large-up: unquote('screen and #{breakpoint(large)}');\n  $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n  $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n  $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n  %reveal-centered {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $reveal-zindex;\n\n  display: none;\n  background-color: $background;\n  overflow-y: auto;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n  @include disable-mouse-outline;\n  z-index: $reveal-zindex + 1;\n  // Workaround android browser z-index bug\n  backface-visibility: hidden;\n\n  display: none;\n  padding: $reveal-padding;\n\n  border: $reveal-border;\n  border-radius: $reveal-radius;\n  background-color: $reveal-background;\n\n  @include breakpoint(medium) {\n    min-height: 0;\n  }\n\n  // Make sure rows don't have a min-width on them\n  .column {\n    min-width: 0;\n  }\n\n  // Strip margins from the last item in the modal\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n  $width: $reveal-width,\n  $max-width: $reveal-max-width\n) {\n  // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n  @extend %reveal-centered;\n  @include breakpoint(medium) {\n    width: $width;\n    max-width: $max-width;\n  }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  min-height: 100%;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n  /// Disables the scroll when Reveal is shown to prevent the background from shifting\n  html.is-reveal-open {\n    position: fixed;\n    width: 100%;\n    overflow-y: hidden;\n\n    &.zf-has-scroll {\n      overflow-y: scroll;\n    }\n\n    body { // sass-lint:disable-line no-qualifying-elements\n      overflow-y: hidden;\n    }\n  }\n\n  // Overlay\n  .reveal-overlay {\n    @include reveal-overlay;\n  }\n\n  // Modal container\n  .reveal {\n    @include reveal-modal-base;\n    @include reveal-modal-width($reveal-width);\n    position: relative;\n    top: 100px;\n    margin-right: auto;\n    margin-left: auto;\n    overflow-y: auto;\n\n    // Remove padding\n    &.collapse {\n      padding: 0;\n    }\n\n    // Sizing classes\n    &.tiny  { @include reveal-modal-width(30%); }\n    &.small { @include reveal-modal-width(50%); }\n    &.large { @include reveal-modal-width(90%); }\n\n    // Full-screen mode\n    &.full {\n      @include reveal-modal-fullscreen;\n    }\n\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include reveal-modal-fullscreen;\n    }\n\n    &.without-overlay {\n      position: fixed;\n    }\n  }\n}\n","@mixin foundation-normalize() {\n  /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n  // Document\n  // ==========================================================================\n\n  // 1. Correct the line height in all browsers.\n  // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n  html {\n    line-height: 1.15; // 1\n    -webkit-text-size-adjust: 100%; // 2\n  }\n\n  // Sections\n  // ==========================================================================\n\n  // Remove the margin in all browsers.\n\n  body {\n    margin: 0;\n  }\n\n  // Correct the font size and margin on `h1` elements within `section` and\n  // `article` contexts in Chrome, Firefox, and Safari.\n\n  h1 {\n    font-size: 2em;\n    margin: 0.67em 0;\n  }\n\n  // Grouping content\n  // ==========================================================================\n\n  // 1. Add the correct box sizing in Firefox.\n  // 2. Show the overflow in Edge and IE.\n\n  hr {\n    box-sizing: content-box; // 1\n    height: 0; // 1\n    overflow: visible; // 2\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  pre {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Text-level semantics\n  // ==========================================================================\n\n  // Remove the gray background on active links in IE 10.\n\n  a {\n    background-color: transparent;\n  }\n\n  // 1. Remove the bottom border in Chrome 57-\n  // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n  abbr[title] {\n    border-bottom: none; // 1\n    text-decoration: underline; // 2\n    text-decoration: underline dotted; // 2\n  }\n\n  // Add the correct font weight in Chrome, Edge, and Safari.\n\n  b,\n  strong {\n    font-weight: bolder;\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  code,\n  kbd,\n  samp {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Add the correct font size in all browsers.\n\n  small {\n    font-size: 80%;\n  }\n\n  // Prevent `sub` and `sup` elements from affecting the line height in\n  // all browsers.\n\n  sub,\n  sup {\n    font-size: 75%;\n    line-height: 0;\n    position: relative;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n\n  sup {\n    top: -0.5em;\n  }\n\n  // Embedded content\n  // ==========================================================================\n\n  // Remove the border on images inside links in IE 10.\n\n  img {\n    border-style: none;\n  }\n\n  // Forms\n  // ==========================================================================\n\n  // 1. Change the font styles in all browsers.\n  // 2. Remove the margin in Firefox and Safari.\n\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit; // 1\n    font-size: 100%; // 1\n    line-height: 1.15; // 1\n    margin: 0; // 2\n  }\n\n  // Show the overflow in IE.\n  // 1. Show the overflow in Edge.\n\n  button,\n  input { // 1\n    overflow: visible;\n  }\n\n  // Remove the inheritance of text transform in Edge, Firefox, and IE.\n  // 1. Remove the inheritance of text transform in Firefox.\n\n  button,\n  select { // 1\n    text-transform: none;\n  }\n\n  // Correct the inability to style clickable types in iOS and Safari.\n\n  button,\n  [type=\"button\"],\n  [type=\"reset\"],\n  [type=\"submit\"] {\n    -webkit-appearance: button;\n  }\n\n  // Remove the inner border and padding in Firefox.\n\n  button::-moz-focus-inner,\n  [type=\"button\"]::-moz-focus-inner,\n  [type=\"reset\"]::-moz-focus-inner,\n  [type=\"submit\"]::-moz-focus-inner {\n    border-style: none;\n    padding: 0;\n  }\n\n  // Restore the focus styles unset by the previous rule.\n\n  button:-moz-focusring,\n  [type=\"button\"]:-moz-focusring,\n  [type=\"reset\"]:-moz-focusring,\n  [type=\"submit\"]:-moz-focusring {\n    outline: 1px dotted ButtonText;\n  }\n\n  // Correct the padding in Firefox.\n\n  fieldset {\n    padding: 0.35em 0.75em 0.625em;\n  }\n\n  // 1. Correct the text wrapping in Edge and IE.\n  // 2. Correct the color inheritance from `fieldset` elements in IE.\n  // 3. Remove the padding so developers are not caught out when they zero out\n  //    `fieldset` elements in all browsers.\n\n  legend {\n    box-sizing: border-box; // 1\n    color: inherit; // 2\n    display: table; // 1\n    max-width: 100%; // 1\n    padding: 0; // 3\n    white-space: normal; // 1\n  }\n\n  // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n  progress {\n    vertical-align: baseline;\n  }\n\n  // Remove the default vertical scrollbar in IE 10+.\n\n  textarea {\n    overflow: auto;\n  }\n\n  // 1. Add the correct box sizing in IE 10.\n  // 2. Remove the padding in IE 10.\n\n  [type=\"checkbox\"],\n  [type=\"radio\"] {\n    box-sizing: border-box; // 1\n    padding: 0; // 2\n  }\n\n  // Correct the cursor style of increment and decrement buttons in Chrome.\n\n  [type=\"number\"]::-webkit-inner-spin-button,\n  [type=\"number\"]::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  // 1. Correct the odd appearance in Chrome and Safari.\n  // 2. Correct the outline style in Safari.\n\n  [type=\"search\"] {\n    -webkit-appearance: textfield; // 1\n    outline-offset: -2px; // 2\n  }\n\n  // Remove the inner padding in Chrome and Safari on macOS.\n\n  [type=\"search\"]::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  // 1. Correct the inability to style clickable types in iOS and Safari.\n  // 2. Change font properties to `inherit` in Safari.\n\n  ::-webkit-file-upload-button {\n    -webkit-appearance: button; // 1\n    font: inherit; // 2\n  }\n\n  // Interactive\n  // ==========================================================================\n\n  // Add the correct display in Edge, IE 10+, and Firefox.\n\n  details {\n    display: block;\n  }\n\n  // Add the correct display in all browsers.\n\n  summary {\n    display: list-item;\n  }\n\n  // Misc\n  // ==========================================================================\n\n  // Add the correct display in IE 10+.\n\n  template {\n    display: none;\n  }\n\n  // Add the correct display in IE 10.\n\n  [hidden] {\n    display: none;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `<html>` and `<body>`. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n  @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n  @include foundation-normalize;\n\n  // These styles are applied to a <meta> tag, which is read by the Foundation JavaScript\n  .foundation-mq {\n    font-family: '#{-zf-bp-serialize($breakpoints)}';\n  }\n\n  html {\n    box-sizing: border-box;\n    font-size: $global-font-size;\n  }\n\n  // Set box-sizing globally to handle padding and border widths\n  *,\n  *::before,\n  *::after {\n    box-sizing: inherit;\n  }\n\n  // Default body styles\n  body {\n    margin: 0;\n    padding: 0;\n\n    background: $body-background;\n\n    font-family: $body-font-family;\n    font-weight: $global-weight-normal;\n    line-height: $global-lineheight;\n    color: $body-font-color;\n\n    @if ($body-antialiased) {\n      -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n      -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n    }\n  }\n\n  img {\n    // Get rid of gap under images by making them display: inline-block; by default\n    display: inline-block;\n    vertical-align: middle;\n\n    // Grid defaults to get images and embeds to work properly\n    max-width: 100%;\n    height: auto;\n    -ms-interpolation-mode: bicubic;\n  }\n\n  // Make sure textarea takes on height automatically\n  textarea {\n    height: auto;\n    min-height: 50px;\n    border-radius: $global-radius;\n  }\n\n  // Make select elements are 100% width by default\n  select {\n    box-sizing: border-box;\n    width: 100%;\n    border-radius: $global-radius;\n  }\n\n  // Styles Google Maps and MapQuest embeds properly\n  // sass-lint:disable-line no-ids\n  .map_canvas,\n  .mqa-display {\n    img,\n    embed,\n    object {\n      max-width: none !important;\n    }\n  }\n\n  // Reset <button> styles created by most browsers\n  button {\n    @include disable-mouse-outline;\n    padding: 0;\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n    line-height: 1;\n    cursor: $global-button-cursor;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\n  }\n\n  // Make reset inherit font-family instead of settings sans-serif\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit;\n  }\n\n  // Internal classes to show/hide elements in JavaScript\n  .is-visible {\n    display: block !important;\n  }\n\n  .is-hidden {\n    display: none !important;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Creates an inner box-shadow for only one side\n///\n/// @param {Keyword} $side - Side the shadow is supposed to appear. Can be `top`, `left`, `right` or `bottom`.\n/// @param {Number} $size - Width for the target side.\n/// @param {Color} $color - Color of the shadow.\n@mixin inner-side-shadow(\n  $side: bottom,\n  $size: 20px,\n  $color: rgba($black, 0.25)\n) {\n\n  $helper: round($size * 0.65);\n\n  @if ($side == top) {\n    box-shadow: inset 0 $helper $size (-1)*$helper $color;\n  } @else if ($side == left) {\n    box-shadow: inset $helper 0 $size (-1)*$helper $color;\n  } @else if ($side == right) {\n    box-shadow: inset (-1)*$helper 0 $size (-1)*$helper $color;\n  } @else if ($side == bottom) {\n    box-shadow: inset 0 (-1)*$helper $size (-1)*$helper $color;\n  }\n}\n\n/// Creates a CSS triangle, which can be used for dropdown arrows, dropdown pips, and more. Use this mixin inside a `&::before` or `&::after` selector, to attach the triangle to an existing element.\n///\n/// @param {Number} $triangle-size - Width of the triangle.\n/// @param {Color} $triangle-color - Color of the triangle.\n/// @param {Keyword} $triangle-direction - Direction the triangle points. Can be `up`, `right`, `down`, or `left`.\n@mixin css-triangle(\n  $triangle-size,\n  $triangle-color,\n  $triangle-direction\n) {\n  display: block;\n  width: 0;\n  height: 0;\n\n  border: inset $triangle-size;\n\n  content: '';\n\n  @if ($triangle-direction == down) {\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: $triangle-color transparent transparent;\n  }\n  @if ($triangle-direction == up) {\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == right) {\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == left) {\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent $triangle-color transparent transparent;\n  }\n}\n\n/// Creates a menu icon with a set width, height, number of bars, and colors. The mixin uses the height of the icon and the weight of the bars to determine spacing. <div class=\"docs-example-burger\"></div>\n///\n/// @param {Color} $color [$black] - Color to use for the icon.\n/// @param {Color} $color-hover [$dark-gray] - Color to use when the icon is hovered over.\n/// @param {Number} $width [20px] - Width of the icon.\n/// @param {Number} $height [16px] - Height of the icon.\n/// @param {Number} $weight [2px] - Height of individual bars in the icon.\n/// @param {Number} $bars [3] - Number of bars in the icon.\n@mixin hamburger(\n  $color: $black,\n  $color-hover: $dark-gray,\n  $width: 20px,\n  $height: 16px,\n  $weight: 2px,\n  $bars: 3\n) {\n  // box-shadow CSS output\n  $shadow: ();\n  $hover-shadow: ();\n\n  // Spacing between bars is calculated based on the total height of the icon and the weight of each bar\n  $spacing: ($height - ($weight * $bars)) / ($bars - 1);\n\n  @if unit($spacing) == 'px' {\n    $spacing: floor($spacing);\n  }\n\n  @for $i from 2 through $bars {\n    $offset: ($weight + $spacing) * ($i - 1);\n    $shadow: append($shadow, 0 $offset 0 $color, comma);\n  }\n\n  // Icon container\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: $width;\n  height: $height;\n  cursor: pointer;\n\n  // Icon bars\n  &::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n\n    display: block;\n    width: 100%;\n    height: $weight;\n\n    background: $color;\n    box-shadow: $shadow;\n\n    content: '';\n  }\n\n  // Hover state\n  @if $color-hover {\n    // Generate CSS\n    @for $i from 2 through $bars {\n      $offset: ($weight + $spacing) * ($i - 1);\n      $hover-shadow: append($hover-shadow, 0 $offset 0 $color-hover, comma);\n    }\n\n    &:hover::after {\n      background: $color-hover;\n      box-shadow: $hover-shadow;\n    }\n  }\n}\n\n/// Adds a downward-facing triangle as a background image to an element. The image is formatted as an SVG, making it easy to change the color. Because Internet Explorer doesn't support encoded SVGs as background images, a PNG fallback is also included.\n/// There are two PNG fallbacks: a black triangle and a white triangle. The one used depends on the lightness of the input color.\n///\n/// @param {Color} $color [$black] - Color to use for the triangle.\n@mixin background-triangle($color: $black) {\n  $rgb: 'rgb%28#{round(red($color))}, #{round(green($color))}, #{round(blue($color))}%29';\n\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: #{$rgb}'></polygon></svg>\");\n\n  @media screen and (min-width:0\\0) {\n    @if lightness($color) < 60% {\n      // White triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==');\n    }\n    @else {\n      // Black triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMBJREFUeNrEllsOhCAMRVszC9IlzU7KCmVHTJsoMWYMUtpyv9BgbuXQB5ZSdgBYYY4ycgBivk8KYFsQMfMiTTBP4o3nUzCKzOabLJbLy2/g31evGkAginR4/ZegKH5qX3bJCscA3t0x3kgO5tQFyhhFf50xRqFLbyMUNJQzgyjGS/wgCpvKqkRBpuWrE4V9d+1E4dPUXqIg107SQOE/2DRQxMwTDygIInVDET9T3lCoj/6j/VCmGjZOl2lKpZ8AAwDQP7zIimDGFQAAAABJRU5ErkJggg==');\n    }\n  }\n}\n\n/// Applies the micro clearfix hack popularized by Nicolas Gallagher. Include this mixin on a container if its children are all floated, to give the container a proper height.\n/// The clearfix is augmented with specific styles to prevent borders in flexbox environments\n/// @link http://nicolasgallagher.com/micro-clearfix-hack/ Micro Clearfix Hack\n/// @link http://danisadesigner.com/blog/flexbox-clear-fix-pseudo-elements/ Flexbox fix\n@mixin clearfix {\n  &::before,\n  &::after {\n    display: table;\n    content: ' ';\n\n    @if $global-flexbox {\n      flex-basis: 0;\n      order: 1;\n    }\n  }\n\n  &::after {\n    clear: both;\n  }\n}\n\n/// Adds CSS for a \"quantity query\" selector that automatically sizes elements based on how many there are inside a container.\n/// @link http://alistapart.com/article/quantity-queries-for-css Quantity Queries for CSS\n///\n/// @param {Number} $max - Maximum number of items to detect. The higher this number is, the more CSS that's required to cover each number of items.\n/// @param {Keyword} $elem [li] - Tag to use for sibling selectors.\n@mixin auto-width($max, $elem: li) {\n  @for $i from 2 through $max {\n    &:nth-last-child(#{$i}):first-child,\n    &:nth-last-child(#{$i}):first-child ~ #{$elem} {\n      width: percentage(1 / $i);\n    }\n  }\n}\n\n/// Removes the focus ring around an element when a mouse input is detected.\n@mixin disable-mouse-outline {\n  [data-whatinput='mouse'] & {\n    outline: 0;\n  }\n}\n\n/// Makes an element visually hidden, but still accessible to keyboards and assistive devices.\n/// @link http://snook.ca/archives/html_and_css/hiding-content-for-accessibility Hiding Content for Accessibility\n/// @link http://hugogiraudel.com/2016/10/13/css-hide-and-seek/\n///\n/// @param {Boolean} $enforce - If `true`, use `!important` on applied properties\n@mixin element-invisible(\n  $enforce: true\n) {\n  $important: if($enforce, '!important', null);\n\n  position: absolute #{$important};\n  width: 1px #{$important};\n  height: 1px #{$important};\n  padding: 0 #{$important};\n  overflow: hidden #{$important};\n  clip: rect(0,0,0,0) #{$important};\n  white-space: nowrap #{$important};\n  border: 0 #{$important};\n}\n\n/// Reverses the CSS output created by the `element-invisible()` mixin.\n/// @param {Boolean} $enforce - If `true`, use `!important` on applied properties\n@mixin element-invisible-off(\n  $enforce: true\n) {\n  $important: if($enforce, '!important', null);\n\n  position: static #{$important};\n  width: auto #{$important};\n  height: auto #{$important};\n  overflow: visible #{$important};\n  clip: auto #{$important};\n  white-space: normal #{$important};\n}\n\n/// Vertically centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin vertical-center {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Horizontally centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin horizontal-center {\n  position: absolute;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\n/// Absolutely centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin absolute-center {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n/// Iterates through breakpoints defined in `$breakpoint-classes` and prints the CSS inside the mixin at each breakpoint's media query. Use this with the grid, or any other component that has responsive classes.\n///\n/// @param {Boolean} $small [true] - If `false`, the mixin will skip the `small` breakpoint. Use this with components that don't prefix classes with `small-`, only `medium-` and up.\n/// @param {Boolean} $auto-insert-breakpoints [true] - If `false`, the mixin will iterate over breakpoints without doing the media query itself. Useful for more complex media query generation as in the margin grid.\n@mixin -zf-each-breakpoint(\n  $small: true,\n  $auto-insert-breakpoints: true\n) {\n  @include -zf-each-breakpoint-in(auto, -zf-bool($small), -zf-bool($auto-insert-breakpoints)) {\n    @content\n  };\n}\n\n/// Iterates with `@content` through the given list of breakpoints `$breakpoints`.\n///\n/// @access private\n///\n/// @param {Keyword|List} $breakpoints [auto] - Breakpoints to iterates on. It can be a breakpoint name, list of breakpoints or `auto` for all breakpoints.\n/// @param {Boolean|Null} $zero-breakpoint [null] - Whether the zero-breakpoint (often `small`) must be included. If `true`, it will always be added to the list if not already there. If `false`, it will always be removed. Does nothing by default.\n/// @param {Boolean|Keyword} $media-queries [true] - Whether media-queries must be generated. If `for-lists`, only generate media-queries when `$breakpoints` is a list.\n@mixin -zf-each-breakpoint-in(\n  $breakpoints: auto,\n  $zero-breakpoint: null,\n  $media-queries: true\n) {\n  $-list: ();\n  $-breakpoints-is-a-list: true;\n\n  // Retrieve the list of breakpoint(s) to iterate on.\n  @if $breakpoints == auto {\n    $-list: $breakpoint-classes;\n  }\n  @else if type-of($breakpoints) == 'list' {\n    $-list: $breakpoints;\n  }\n  @else if type-of($breakpoints) == 'string' {\n    $-list: ($breakpoints);\n    $-breakpoints-is-a-list: false;\n  }\n  @else {\n    @error 'Wrong syntax for \"$breakpoints\" in \"-zf-each-breakpoint-in()\". Got \"#{$breakpoints}\" (#{type-of($breakpoints)}). Expected a breakpoint name, a list of breakpoints or \"auto\"';\n  }\n\n  // Add or remove the zero breakpoint according to `$zero-breakpoint`\n  @if $zero-breakpoint == true {\n    $-list: join(($-zf-zero-breakpoint), sl-remove($-list, $-zf-zero-breakpoint));\n  }\n  @else if $zero-breakpoint == false {\n    $-list: sl-remove($-list, $-zf-zero-breakpoint);\n  }\n\n  // Iterate on breakpoint(s)\n  @each $bp in $-list {\n    $old-zf-size: null;\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: $bp !global;\n\n    @if ($media-queries == true\n      or ($media-queries == 'for-lists' and $-breakpoints-is-a-list)) {\n      @include breakpoint($bp) {\n        @content;\n      }\n    }\n    @else {\n      @content;\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Generate the `@content` passed to the mixin with a value `$-zf-bp-value` related to a breakpoint, depending on the `$name` parameter:\n/// - For a single value, `$-zf-bp-value` is this value.\n/// - For a breakpoint name, `$-zf-bp-value` is the corresponding breakpoint value in `$map`.\n/// - For \"auto\", `$-zf-bp-value` is the corresponding breakpoint value in `$map` and is passed to `@content`, which is made responsive for each breakpoint of `$map`.\n/// @param {Number|Array|Keyword} $name [auto] - Single value, breakpoint name, or list of breakpoint names to use. \"auto\" by default.\n/// @param {Number|Map} $map - Map of breakpoints and values or single value to use.\n@mixin -zf-breakpoint-value(\n  $name: auto,\n  $map: null\n) {\n  @if $name == auto and type-of($map) == 'map' {\n    // \"auto\"\n    @each $k, $v in $map {\n      @include breakpoint($k) {\n        @include -zf-breakpoint-value($v, $map) {\n          @content;\n        }\n      }\n    }\n  }\n  @else {\n    // breakpoint name\n    @if type-of($name) == 'string' {\n      $bp-value: -zf-get-bp-val($map, $name);\n      @if $bp-value != null {\n        $name: $bp-value;\n      }\n    }\n\n    // breakpoint value\n    $-zf-bp-value: $name !global;\n    @content;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Font color of text inputs.\n/// @type Color\n$input-color: $black !default;\n\n/// Font color of placeholder text within text inputs.\n/// @type Color\n$input-placeholder-color: $medium-gray !default;\n\n/// Font family of text inputs.\n/// @type Font\n$input-font-family: inherit !default;\n\n/// Font size of text inputs.\n/// @type Number\n$input-font-size: rem-calc(16) !default;\n\n/// Font weight of text inputs.\n/// @type Keyword\n$input-font-weight: $global-weight-normal !default;\n\n/// Line height of text inputs.\n/// @type Keyword\n$input-line-height: $global-lineheight !default;\n\n/// Background color of text inputs.\n/// @type Color\n$input-background: $white !default;\n\n/// Background color of focused of text inputs.\n/// @type Color\n$input-background-focus: $white !default;\n\n/// Background color of disabled text inputs.\n/// @type Color\n$input-background-disabled: $light-gray !default;\n\n/// Border around text inputs.\n/// @type Border\n$input-border: 1px solid $medium-gray !default;\n\n/// Border around focused text inputs.\n/// @type Color\n$input-border-focus: 1px solid $dark-gray !default;\n\n/// Padding of text inputs.\n/// @type Color\n$input-padding: $form-spacing / 2 !default;\n\n/// Box shadow inside text inputs when not focused.\n/// @type Shadow\n$input-shadow: inset 0 1px 2px rgba($black, 0.1) !default;\n\n/// Box shadow outside text inputs when focused.\n/// @type Shadow\n$input-shadow-focus: 0 0 5px $medium-gray !default;\n\n/// Cursor to use when hovering over a disabled text input.\n/// @type Cursor\n$input-cursor-disabled: not-allowed !default;\n\n/// Properties to transition on text inputs.\n/// @type Transition\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out !default;\n\n/// Enables the up/down buttons that Chrome and Firefox add to `<input type='number'>` elements.\n/// @type Boolean\n$input-number-spinners: true !default;\n\n/// Radius for text inputs.\n/// @type Border\n$input-radius: $global-radius !default;\n\n/// Border radius for form buttons, defaulted to global-radius.\n/// @type Number\n$form-button-radius: $global-radius !default;\n\n@mixin form-element {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  border: $input-border;\n  border-radius: $input-radius;\n  background-color: $input-background;\n  box-shadow: $input-shadow;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n}\n\n@mixin foundation-form-text {\n  // Text inputs\n  #{text-inputs()},\n  textarea {\n    @include form-element;\n    appearance: none;\n  }\n\n  // Text areas\n  textarea {\n    max-width: 100%;\n\n    &[rows] {\n      height: auto;\n    }\n  }\n\n  input,\n  textarea {\n    // Disabled/readonly state\n    &:disabled,\n    &[readonly] {\n      background-color: $input-background-disabled;\n      cursor: $input-cursor-disabled;\n    }\n  }\n\n  // Reset styles on button-like inputs\n  [type='submit'],\n  [type='button'] {\n    appearance: none;\n    border-radius: $form-button-radius;\n  }\n\n  // Reset Normalize setting content-box to search elements\n  input[type='search'] { // sass-lint:disable-line no-qualifying-elements\n    box-sizing: border-box;\n  }\n\n  // Number input styles\n  [type='number'] {\n    @if not $input-number-spinners {\n      -moz-appearance: textfield; // sass-lint:disable-line no-vendor-prefixes\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n        margin: 0;\n      }\n    }\n  }\n\n  // Placeholder text\n  ::placeholder {\n    color: $input-placeholder-color;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n$global-font-size: 100% !default;\n\n/// Removes the unit (e.g. px, em, rem) from a value, returning the number only.\n///\n/// @param {Number} $num - Number to strip unit from.\n///\n/// @returns {Number} The same number, sans unit.\n@function strip-unit($num) {\n  @return $num / ($num * 0 + 1);\n}\n\n/// Converts one or more pixel values into matching rem values.\n///\n/// @param {Number|List} $values - One or more values to convert. Be sure to separate them with spaces and not commas. If you need to convert a comma-separated list, wrap the list in parentheses.\n/// @param {Number} $base [null] - The base value to use when calculating the `rem`. If you're using Foundation out of the box, this is 16px. If this parameter is `null`, the function will reference the `$global-font-size` variable as the base.\n///\n/// @returns {List} A list of converted values.\n@function rem-calc($values, $base: null) {\n  $rem-values: ();\n  $count: length($values);\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // If the base font size is a %, then multiply it by 16px\n  // This is because 100% font size = 16px in most all browsers\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  // Using rem as base allows correct scaling\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if $count == 1 {\n    @return -zf-to-rem($values, $base);\n  }\n\n  @for $i from 1 through $count {\n    $rem-values: append($rem-values, -zf-to-rem(nth($values, $i), $base));\n  }\n\n  @return $rem-values;\n}\n\n// Converts a unitless, pixel, or rem value to em, for use in breakpoints.\n@function -zf-bp-to-em($value) {\n  // Pixel and unitless values are converted to rems\n  @if unit($value) == 'px' or unitless($value) {\n    $value: rem-calc($value, $base: 16px);\n  }\n\n  // Then the value is converted to ems\n  @return strip-unit($value) * 1em;\n}\n\n/// Converts a pixel value to matching rem value. *Any* value passed, regardless of unit, is assumed to be a pixel value. By default, the base pixel value used to calculate the rem value is taken from the `$global-font-size` variable.\n/// @access private\n///\n/// @param {Number} $value - Pixel value to convert.\n/// @param {Number} $base [null] - Base for pixel conversion.\n///\n/// @returns {Number} A number in rems, calculated based on the given value and the base pixel value. rem values are passed through as is.\n@function -zf-to-rem($value, $base: null) {\n  // Check if the value is a number\n  @if type-of($value) != 'number' {\n    @warn inspect($value) + ' was passed to rem-calc(), which is not a number.';\n    @return $value;\n  }\n\n  // Transform em into rem if someone hands over 'em's\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * 1rem;\n  }\n\n  // Calculate rem if units for $value is not rem or em\n  @if unit($value) != 'rem' {\n    $value: strip-unit($value) / strip-unit($base) * 1rem;\n  }\n\n  // Turn 0rem into 0\n  @if $value == 0rem {\n    $value: 0;\n  }\n\n  @return $value;\n}\n\n/// Converts a pixel, percentage, rem or em value to a unitless value based on a given font size. Ideal for working out unitless line heights.\n///\n/// @param {Number} $value - Value to convert to a unitless line height\n/// @param {Number} $base - The font size to use to work out the line height - defaults to $global-font-size\n///\n/// @return {Number} - Unitless number\n@function unitless-calc($value, $base: null) {\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // First, lets convert our $base to pixels\n\n  // If the base font size is a %, then multiply it by 16px\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if unit($base) == 'em' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  // Now let's convert our value to pixels too\n  @if unit($value) == '%' {\n    $value: ($value / 100%) * $base;\n  }\n\n  @if unit($value) == 'rem' {\n    $value: strip-unit($value) * $base;\n  }\n\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * $base;\n  }\n\n  // 'px'\n  @if unit($value) == 'px' {\n    @return strip-unit($value) / strip-unit($base);\n  }\n\n  // assume that line-heights greater than 10 are meant to be absolute in 'px'\n  @if unitless($value) and ($value > 10) {\n    @return $value / strip-unit($base);\n  }\n\n  @return $value;\n}\n","// Foundation for Sites\n// https://get.foundation\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\n// https://get.foundation\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\n// https://get.foundation\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color of labels prefixed to an input.\n/// @type Color\n$input-prefix-color: $black !default;\n\n/// Background color of labels prefixed to an input.\n/// @type Color\n$input-prefix-background: $light-gray !default;\n\n/// Border around labels prefixed to an input.\n/// @type Border\n$input-prefix-border: 1px solid $medium-gray !default;\n\n/// Left/right padding of an pre/postfixed input label\n$input-prefix-padding: 1rem !default;\n\n@mixin foundation-form-prepostfix {\n  $height: ($input-font-size * $input-line-height) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  .input-group {\n    display: if($global-flexbox, flex, table);\n    width: 100%;\n    margin-bottom: $form-spacing;\n\n    @if $global-flexbox {\n      align-items: stretch;\n    }\n\n    > :first-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n      }\n    }\n\n    > :last-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, $input-radius 0 0 $input-radius, 0 $input-radius $input-radius 0);\n      }\n    }\n  }\n\n  %input-group-child {\n    margin: 0;\n    white-space: nowrap;\n\n    @if not $global-flexbox {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  .input-group-label {\n    @extend %input-group-child;\n    padding: 0 $input-prefix-padding;\n    border: $input-prefix-border;\n    background: $input-prefix-background;\n\n    color: $input-prefix-color;\n    text-align: center;\n    white-space: nowrap;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n      align-items: center;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    @if has-value($input-prefix-border) {\n      &:first-child {\n        border-#{$global-right}: 0;\n      }\n\n      &:last-child {\n        border-#{$global-left}: 0;\n      }\n    }\n  }\n\n  .input-group-field {\n    @extend %input-group-child;\n    border-radius: 0;\n\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      min-width: 0;\n    }\n  }\n\n  .input-group-button {\n    @extend %input-group-child;\n    padding-top: 0;\n    padding-bottom: 0;\n    text-align: center;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    a,\n    input,\n    button,\n    label {\n      @extend %input-group-child;\n\n      @if $global-flexbox {\n        align-self: stretch;\n        height: auto;\n      }\n      @else {\n        height: $height;\n      }\n      padding-top: 0;\n      padding-bottom: 0;\n      font-size: $input-font-size;\n    }\n  }\n\n  // Specificity bump needed to prevent override by buttons\n  @if not $global-flexbox {\n    .input-group {\n      .input-group-button {\n        display: table-cell;\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default border around custom fieldsets.\n/// @type Border\n$fieldset-border: 1px solid $medium-gray !default;\n\n/// Default padding inside custom fieldsets.\n/// @type Number\n$fieldset-padding: rem-calc(20) !default;\n\n/// Default margin around custom fieldsets.\n/// @type Number\n$fieldset-margin: rem-calc(18 0) !default;\n\n/// Default padding between the legend text and fieldset border.\n/// @type Number\n$legend-padding: rem-calc(0 3) !default;\n\n@mixin fieldset {\n  margin: $fieldset-margin;\n  padding: $fieldset-padding;\n  border: $fieldset-border;\n\n  legend {\n    // Covers up the fieldset's border to create artificial padding\n    margin: 0;\n    margin-#{$global-left}: rem-calc(-3);\n    padding: $legend-padding;\n  }\n}\n\n@mixin foundation-form-fieldset {\n  fieldset {\n    margin: 0;\n    padding: 0;\n    border: 0;\n  }\n\n  legend {\n    max-width: 100%;\n    margin-bottom: $form-spacing * 0.5;\n  }\n\n  .fieldset {\n    @include fieldset;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Background color for select menus.\n/// @type Color\n$select-background: $white !default;\n\n/// Color of the dropdown triangle inside select menus. Set to `transparent` to remove it entirely.\n/// @type Color\n$select-triangle-color: $dark-gray !default;\n\n/// Default radius for select menus.\n/// @type Color\n$select-radius: $global-radius !default;\n\n@mixin form-select {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  appearance: none;\n  border: $input-border;\n  border-radius: $select-radius;\n  background-color: $select-background;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if $select-triangle-color != transparent {\n    @include background-triangle($select-triangle-color);\n    background-origin: content-box;\n    background-position: $global-right (-$form-spacing) center;\n    background-repeat: no-repeat;\n    background-size: 9px 6px;\n\n    padding-#{$global-right}: ($form-spacing * 1.5);\n  }\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n\n  // Disabled state\n  &:disabled {\n    background-color: $input-background-disabled;\n    cursor: $input-cursor-disabled;\n  }\n\n  // Hide the dropdown arrow shown in newer IE versions\n  &::-ms-expand {\n    display: none;\n  }\n\n  &[multiple] {\n    height: auto;\n    background-image: none;\n  }\n  &:not([multiple]) {\n    padding-top: 0;\n    padding-bottom: 0;\n  }\n}\n\n@mixin foundation-form-select {\n  select {\n    @include form-select;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group abide\n////\n\n/// Sets if error styles should be added to inputs.\n/// @type Boolean\n$abide-inputs: true !default;\n\n/// Sets if error styles should be added to labels.\n/// @type Boolean\n$abide-labels: true !default;\n\n/// Background color to use for invalid text inputs.\n/// @type Color\n$input-background-invalid: get-color(alert) !default;\n\n/// Color to use for labels of invalid inputs.\n/// @type Color\n$form-label-color-invalid: get-color(alert) !default;\n\n/// Default font color for form error text.\n/// @type Color\n$input-error-color: get-color(alert) !default;\n\n/// Default font size for form error text.\n/// @type Number\n$input-error-font-size: rem-calc(12) !default;\n\n/// Default font weight for form error text.\n/// @type Keyword\n$input-error-font-weight: $global-weight-bold !default;\n\n/// Styles the background and border of an input field to have an error state.\n///\n/// @param {Color} $background [$alert-color] - Color to use for the background and border.\n/// @param {Number} $background-lighten [10%] - Lightness level of the background color.\n@mixin form-input-error(\n  $background: $input-background-invalid,\n  $background-lighten: 10%\n) {\n  &:not(:focus) {\n    border-color: $background;\n    background-color: mix($background, $white, $background-lighten);\n\n    &::placeholder {\n      color: $background;\n    }\n  }\n}\n\n/// Adds error styles to a form element, using the values in the settings file.\n@mixin form-error {\n  display: none;\n  margin-top: $form-spacing * -0.5;\n  margin-bottom: $form-spacing;\n\n  font-size: $input-error-font-size;\n  font-weight: $input-error-font-weight;\n  color: $input-error-color;\n}\n\n@mixin foundation-form-error {\n  @if $abide-inputs {\n    // Error class for invalid inputs\n    .is-invalid-input {\n      @include form-input-error;\n    }\n  }\n\n  @if $abide-labels {\n    // Error class for labels of invalid outputs\n    .is-invalid-label {\n      color: $form-label-color-invalid;\n    }\n  }\n\n  // Form error element\n  .form-error {\n    @include form-error;\n\n    &.is-visible {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Use the `.code-inline` component as default for `<code>` elements.\n/// @type Boolean\n$enable-code-inline: true;\n\n/// Default color for links.\n/// @type Color\n$anchor-color: $primary-color !default;\n\n/// Default color for links on hover.\n/// @type Color\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%) !default;\n\n/// Default text decoration for links.\n/// @type String\n$anchor-text-decoration: none !default;\n\n/// Default text decoration for links on hover.\n/// @type String\n$anchor-text-decoration-hover: none !default;\n\n/// Maximum width of a divider.\n/// @type Number\n$hr-width: $global-width !default;\n\n/// Default border for a divider.\n/// @type List\n$hr-border: 1px solid $medium-gray !default;\n\n/// Default margin for a divider.\n/// @type Number | List\n$hr-margin: rem-calc(20) auto !default;\n\n/// Line height for items in a list.\n/// @type Number\n$list-lineheight: $paragraph-lineheight !default;\n\n/// Bottom margin for items in a list.\n/// @type Number\n$list-margin-bottom: $paragraph-margin-bottom !default;\n\n/// Bullet type to use for unordered lists (e.g., `square`, `circle`, `disc`).\n/// @type String\n$list-style-type: disc !default;\n\n/// Positioning for bullets on unordered list items.\n/// @type String\n$list-style-position: outside !default;\n\n/// Left (or right) margin for lists.\n/// @type Number\n$list-side-margin: 1.25rem !default;\n\n/// Left (or right) margin for a list inside a list.\n/// @type Number\n$list-nested-side-margin: 1.25rem !default;\n\n/// Bottom margin for `<dl>` elements.\n/// @type Number\n$defnlist-margin-bottom: 1rem !default;\n\n/// Font weight for `<dt>` elements.\n/// @type String\n$defnlist-term-weight: $global-weight-bold !default;\n\n/// Spacing between `<dt>` and `<dd>` elements.\n/// @type Number\n$defnlist-term-margin-bottom: 0.3rem !default;\n\n/// Text color of `<blockquote>` elements.\n/// @type Color\n$blockquote-color: $dark-gray !default;\n\n/// Padding inside a `<blockquote>` element.\n/// @type Number | List\n$blockquote-padding: rem-calc(9 20 0 19) !default;\n\n/// Side border for `<blockquote>` elements.\n/// @type List\n$blockquote-border: 1px solid $medium-gray !default;\n\n/// Use the `.cite-block` component as default for `<cite>` elements.\n/// @type Boolean\n$enable-cite-block: true;\n\n/// Font family for `<kbd>` elements.\n/// @type String | List\n$keystroke-font: $font-family-monospace !default;\n\n/// Text color for `<kbd>` elements.\n/// @type Color\n$keystroke-color: $black !default;\n\n/// Background color for `<kbd>` elements.\n/// @type Color\n$keystroke-background: $light-gray !default;\n\n/// Padding for `<kbd>` elements.\n/// @type Number | List\n$keystroke-padding: rem-calc(2 4 0) !default;\n\n/// Border radius for `<kbd>` elements.\n/// @type Number | List\n$keystroke-radius: $global-radius !default;\n\n/// Bottom border style for `<abbr>` elements.\n/// @type List\n$abbr-underline: 1px dotted $black !default;\n\n@mixin foundation-typography-base {\n  // Typography resets\n  div,\n  dl,\n  dt,\n  dd,\n  ul,\n  ol,\n  li,\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6,\n  pre,\n  form,\n  p,\n  blockquote,\n  th,\n  td {\n    margin: 0;\n    padding: 0;\n  }\n\n  // Paragraphs\n  p {\n    margin-bottom: $paragraph-margin-bottom;\n\n    font-size: inherit;\n    line-height: $paragraph-lineheight;\n    text-rendering: $paragraph-text-rendering;\n  }\n\n  // Emphasized text\n  em,\n  i {\n    font-style: italic;\n    line-height: inherit;\n  }\n\n  // Strong text\n  strong,\n  b {\n    font-weight: $global-weight-bold;\n    line-height: inherit;\n  }\n\n  // Small text\n  small {\n    font-size: $small-font-size;\n    line-height: inherit;\n  }\n\n  // Headings\n  h1, .h1,\n  h2, .h2,\n  h3, .h3,\n  h4, .h4,\n  h5, .h5,\n  h6, .h6 {\n    font-family: $header-font-family;\n    font-style: $header-font-style;\n    font-weight: $header-font-weight;\n    color: $header-color;\n    text-rendering: $header-text-rendering;\n\n    small {\n      line-height: 0;\n      color: $header-small-font-color;\n    }\n  }\n\n  // Heading styles\n  @each $size, $headers in $header-styles {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        #{$header}, .#{$header} {\n\n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n  // Links\n  a {\n    line-height: inherit;\n    color: $anchor-color;\n    text-decoration: $anchor-text-decoration;\n\n    cursor: pointer;\n\n    &:hover,\n    &:focus {\n      color: $anchor-color-hover;\n      @if $anchor-text-decoration-hover != $anchor-text-decoration {\n        text-decoration: $anchor-text-decoration-hover;\n      }\n    }\n\n    img {\n      border: 0;\n    }\n  }\n\n  // Horizontal rule\n  hr {\n    clear: both;\n\n    max-width: $hr-width;\n    height: 0;\n    margin: $hr-margin;\n\n    border-top: 0;\n    border-right: 0;\n    border-bottom: $hr-border;\n    border-left: 0;\n  }\n\n  // Lists\n  ul,\n  ol,\n  dl {\n    margin-bottom: $list-margin-bottom;\n    list-style-position: $list-style-position;\n    line-height: $list-lineheight;\n  }\n\n  // List items\n  li {\n    font-size: inherit;\n  }\n\n  // Unordered lists\n  ul {\n    margin-#{$global-left}: $list-side-margin;\n    list-style-type: $list-style-type;\n  }\n\n  // Ordered lists\n  ol {\n    margin-#{$global-left}: $list-side-margin;\n  }\n\n  // Nested unordered/ordered lists\n  ul, ol {\n    & & {\n      margin-#{$global-left}: $list-nested-side-margin;\n      margin-bottom: 0;\n    }\n  }\n\n  // Definition lists\n  dl {\n    margin-bottom: $defnlist-margin-bottom;\n\n    dt {\n      margin-bottom: $defnlist-term-margin-bottom;\n      font-weight: $defnlist-term-weight;\n    }\n  }\n\n  // Blockquotes\n  blockquote {\n    margin: 0 0 $paragraph-margin-bottom;\n    padding: $blockquote-padding;\n    border-#{$global-left}: $blockquote-border;\n\n    &, p {\n      line-height: $paragraph-lineheight;\n      color: $blockquote-color;\n    }\n  }\n\n  // Inline Citations\n  @if ($enable-cite-block == true) {\n    cite {\n      // Extending a class is not recommended.\n      // TODO: Break the typography-base/typography-helpers separation\n      @extend .cite-block;\n    }\n  }\n\n  // Abbreviations\n  abbr, abbr[title] {\n    border-bottom: $abbr-underline;\n    cursor: help;\n    text-decoration: none;\n  }\n\n  // Figures\n  figure {\n    margin: 0;\n  }\n\n  // Code\n  @if ($enable-code-inline == true) {\n    code {\n      @extend .code-inline;\n    }\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group typography-helpers\n////\n\n/// Default font size for lead paragraphs.\n/// @type Number\n$lead-font-size: $global-font-size * 1.25 !default;\n\n/// Default line height for lead paragraphs.\n/// @type String\n$lead-lineheight: 1.6 !default;\n\n/// Default line height for subheaders.\n/// @type Number\n$subheader-lineheight: 1.4 !default;\n\n/// Default font color for subheaders.\n/// @type Color\n$subheader-color: $dark-gray !default;\n\n/// Default font weight for subheaders.\n/// @type String\n$subheader-font-weight: $global-weight-normal !default;\n\n/// Default top margin for subheaders.\n/// @type Number\n$subheader-margin-top: 0.2rem !default;\n\n/// Default bottom margin for subheaders.\n/// @type Number\n$subheader-margin-bottom: 0.5rem !default;\n\n/// Default font size for statistic numbers.\n/// @type Number\n$stat-font-size: 2.5rem !default;\n\n/// Text color for `.cite-block` component.\n/// @type Color\n$cite-color: $dark-gray !default;\n\n/// Font size for `.cite-block` component.\n/// @type Number\n$cite-font-size: rem-calc(13) !default;\n\n/// Pseudo content for `.cite-block` component.\n/// @type String\n$cite-pseudo-content: '\\2014 \\0020' !default;\n\n/// Text color of `.code-inline` and `.code-block` components.\n/// @type Color\n$code-color: $black !default;\n\n/// Font family of `.code-inline` and `.code-block` components.\n/// @type String | List\n$code-font-family: $font-family-monospace !default;\n\n/// Font weight of text in `.code-inline` and `.code-block` components.\n/// @type String\n$code-font-weight: $global-weight-normal !default;\n\n/// Background color of `.code-inline` and `.code-block` components.\n/// @type Color\n$code-background: $light-gray !default;\n\n/// Border around `.code-inline` and `.code-block` components.\n/// @type List\n$code-border: 1px solid $medium-gray !default;\n\n/// Padding around text of the `.code-inline` component.\n/// @type Number | List\n$code-padding: rem-calc(2 5 1) !default;\n\n/// Padding around text of the `.code-block` component.\n/// @type Number | List\n$code-block-padding: 1rem !default;\n\n/// Margin under the `.code-block` component.\n/// @type Number\n$code-block-margin-bottom: 1.5rem !default;\n\n@mixin cite-block {\n  display: block;\n  color: $cite-color;\n  font-size: $cite-font-size;\n\n  &:before {\n    content: $cite-pseudo-content;\n  }\n}\n\n/// Add basic styles for a code helper.\n/// See `code-inline` and `code-block` mixins.\n@mixin code-style {\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/// Make code helper from the `code-style` mixin inline.\n/// Used to generate `.code-inline`\n@mixin code-inline {\n  display: inline;\n  max-width: 100%;\n  word-wrap: break-word;\n\n  padding: $code-padding;\n}\n\n/// Make code helper from the `code-style` mixin a block.\n/// Used to generate `.code-block`\n@mixin code-block {\n  display: block;\n  overflow: auto;\n  white-space: pre;\n\n  padding: $code-block-padding;\n  margin-bottom: $code-block-margin-bottom;\n}\n\n@mixin foundation-typography-helpers {\n  // Use to create a subheading under a main header\n  // Make sure you pair the two elements in a <header> element, like this:\n  // <header>\n  //   <h1>Heading</h1>\n  //   <h2>Subheading</h2>\n  // </header>\n  .subheader {\n    margin-top: $subheader-margin-top;\n    margin-bottom: $subheader-margin-bottom;\n\n    font-weight: $subheader-font-weight;\n    line-height: $subheader-lineheight;\n    color: $subheader-color;\n  }\n\n  // Use to style an introductory lead, deck, blurb, etc.\n  .lead {\n    font-size: $lead-font-size;\n    line-height: $lead-lineheight;\n  }\n\n  // Use to style a large number to display a statistic\n  .stat {\n    font-size: $stat-font-size;\n    line-height: 1;\n\n    p + & {\n      margin-top: -1rem;\n    }\n  }\n\n  ul, ol {\n    // Use to remove numbers from ordered list & bullets from unordered list\n    &.no-bullet {\n      margin-#{$global-left}: 0;\n      list-style: none;\n    }\n  }\n\n  .cite-block {\n    @include cite-block;\n  }\n\n  .code-inline {\n    @include code-style;\n    @include code-inline;\n  }\n\n  .code-block {\n    @include code-style;\n    @include code-block;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n/// If `true`, all elements will have transparent backgrounds when printed, to save on ink.\n/// @type Boolean\n/// @group global\n$print-transparent-backgrounds: true !default;\n\n/// If `true`, displays next to all links their \"href\" when printed.\n/// @type Boolean\n/// @group global\n$print-hrefs: true !default;\n\n// sass-lint:disable-all\n\n@mixin foundation-print-styles {\n  .show-for-print { display: none !important; }\n\n  @media print {\n    * {\n      // Ensure a \"black-on-white\" print by removing backgrounds,\n      // using black text everywhere and forcing the browser to economize ink.\n      @if $print-transparent-backgrounds {\n        background: transparent !important;\n        color: black !important; // Black prints faster: h5bp.com/s\n        color-adjust: economy;\n      }\n      // Otherwise, prevent any economy by the browser.\n      @else {\n        color-adjust: exact;\n      }\n\n      box-shadow: none !important;\n      text-shadow: none !important;\n    }\n\n    .show-for-print { display: block !important; }\n    .hide-for-print { display: none !important; }\n\n    table.show-for-print { display: table !important; }\n    thead.show-for-print { display: table-header-group !important; }\n    tbody.show-for-print { display: table-row-group !important; }\n    tr.show-for-print { display: table-row !important; }\n    td.show-for-print { display: table-cell !important; }\n    th.show-for-print { display: table-cell !important; }\n\n    // Display the URL of a link after the text\n    a,\n    a:visited { text-decoration: underline;}\n    @if $print-hrefs {\n      a[href]:after { content: ' (' attr(href) ')'; }\n    }\n\n    // Don't display the URL for images or JavaScript/internal links\n    .ir a:after,\n    a[href^='javascript:']:after,\n    a[href^='#']:after { content: ''; }\n\n    // Display what an abbreviation stands for after the text\n    abbr[title]:after { content: ' (' attr(title) ')'; }\n\n    // Prevent page breaks in the middle of a blockquote or preformatted text block\n    pre,\n    blockquote {\n      border: 1px solid $dark-gray;\n      page-break-inside: avoid;\n    }\n\n    // h5bp.com/t\n    thead { display: table-header-group; }\n\n    tr,\n    img { page-break-inside: avoid; }\n\n    img { max-width: 100% !important; }\n\n    @page { margin: 0.5cm; }\n\n    p,\n    h2,\n    h3 {\n      orphans: 3;\n      widows: 3;\n    }\n\n    // Avoid page breaks after a heading\n    h2,\n    h3 { page-break-after: avoid; }\n\n    // Helper to re-allow page breaks in the middle of certain elements (e.g. pre, blockquote, tr)\n    .print-break-inside {\n      page-break-inside: auto;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n// Margin Grid classes\n@mixin xy-base-grid-classes {\n\n  // Grid Container\n  .grid-container {\n    @include xy-grid-container;\n\n    &.fluid {\n      @include xy-grid-container(100%);\n    }\n\n    &.full {\n      @include xy-grid-container(100%, 0);\n    }\n  }\n\n  // Base grid styles\n  .grid-x {\n    @include xy-grid;\n  }\n\n  .cell {\n    @include xy-cell(full, $gutter-type: none);\n\n    &.auto {\n      @include xy-cell-base(auto);\n    }\n\n    &.shrink {\n      @include xy-cell-base(shrink);\n    }\n\n  }\n  .grid-x {\n    > .auto {\n      @include xy-cell-size(auto, $gutter-type: none);\n    }\n\n    > .shrink {\n      @include xy-cell-size(shrink, $gutter-type: none);\n    }\n  }\n\n  // Auto width\n  @include -zf-each-breakpoint() {\n    // This is a bit of a hack/workaround, see these issues & PRs for the backstory:\n    // https://github.com/foundation/foundation-sites/issues/10244\n    // https://github.com/foundation/foundation-sites/pull/10222 and\n    // https://github.com/foundation/foundation-sites/pull/10164\n    .grid-x {\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n  }\n\n  @include -zf-each-breakpoint() {\n    // Responsive \"auto\" modifier\n    @if not($-zf-size == $-zf-zero-breakpoint) {\n      .grid-x > .#{$-zf-size}-auto {\n        @include xy-cell(auto, $gutter-type: none);\n      }\n    }\n\n    %-xy-cell-base-shrink-horizontal-#{$-zf-size} {\n      @include xy-cell-base(shrink);\n    }\n\n    // Responsive \"shrink\" modifier\n    @if not($-zf-size == $-zf-zero-breakpoint) {\n      .grid-x > .#{$-zf-size}-shrink {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-size(shrink, $gutter-type: none);\n      }\n    }\n\n    // Responsive width modifiers\n    @for $i from 1 through $grid-columns {\n      // Sizing (percentage)\n      .grid-x > .#{$-zf-size}-#{$i} {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-size($i, $gutter-type: none);\n      }\n    }\n  }\n\n  // Reset width when using `.grid-margin-x` not on `.grid-x`\n  .grid-margin-x:not(.grid-x) > .cell {\n    width: auto;\n  }\n\n  // Reset height when using `.grid-margin-y` not on `.grid-y`\n  .grid-margin-y:not(.grid-y) > .cell {\n    height: auto;\n  }\n}\n\n@mixin -xy-breakpoint-cell-classes($class-breakpoint, $gutter-breakpoint, $vertical) {\n  $prefix: if($class-breakpoint == $-zf-zero-breakpoint, '', '#{$class-breakpoint}-');\n  > .#{$prefix}auto {\n    @include xy-cell-size(auto, $vertical: $vertical);\n  }\n\n  > .#{$prefix}shrink {\n    @include xy-cell-size(shrink, $vertical: $vertical);\n  }\n\n  @for $i from 1 through $grid-columns {\n    // Sizing (percentage)\n    $classname: if($vertical, '.#{$class-breakpoint}-#{$i}', '.#{$class-breakpoint}-#{$i}');\n\n    > #{$classname} {\n      @include xy-cell-size($i, $vertical: $vertical);\n    }\n  }\n}\n\n// Margin Grid classes\n@mixin xy-margin-grid-classes(\n  $gutter-position: left right,\n  $vertical: false,\n  $wrapping-selector: '.grid-margin-x'\n){\n  #{$wrapping-selector} {\n    @include xy-gutters($negative: true, $gutter-position: $gutter-position);\n\n    // Base cell styles\n    > .cell {\n      @include xy-cell($vertical: $vertical, $output: (size gutters));\n    }\n\n    // base styles need to all be before the auto and shrink styles\n    @include -zf-each-breakpoint() {\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size) and $-zf-size != $-zf-zero-breakpoint) {\n        > .cell {\n          @include xy-cell($vertical: $vertical, $output: (size gutters));\n        }\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n\n      // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n      // for all prior breakpoints.\n      // As their gutter is defined with their width/height, even breakpoint without a new margin must be\n      // generated to not having their width/height overrided by re-adjusted smaller breakpoints.\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n        @each $bp in -zf-breakpoints-less-than($-zf-size) {\n          @include -xy-breakpoint-cell-classes($bp, $-zf-size, $vertical);\n        }\n      }\n\n      @include -xy-breakpoint-cell-classes($-zf-size, $-zf-size, $vertical);\n    }\n  }\n}\n\n// Padding Grid classes\n@mixin xy-padding-grid-classes {\n  .grid-padding-x {\n\n    // Negative margin for nested grids\n    .grid-padding-x {\n      @include xy-gutters($negative: true);\n    }\n\n    // Negative margin for grids within `grid-container/grid-container.fluid`\n    // This allows margin and padding grids to line up with eachother\n    .grid-container:not(.full) > & {\n      @include xy-gutters($negative: true);\n    }\n\n    // Base cell styles\n    > .cell {\n      @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding);\n    }\n  }\n}\n\n// Block Grid classes\n@mixin xy-block-grid-classes($margin-grid: true, $padding-grid: true) {\n  @if $padding-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        .#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-type: padding, $output: (size));\n        }\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n        // for prior breakpoints based on the responsive gutter.\n        @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n          @each $bp in -zf-breakpoints-less-than($-zf-size) {\n            @if(map-has-key($grid-margin-gutters, $bp)) {\n              .grid-margin-x.#{$bp}-up-#{$i} {\n                @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-type: margin, $output: (size));\n              }\n            }\n          }\n        }\n      }\n      @for $i from 1 through $xy-block-grid-max {\n        .grid-margin-x.#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-type: margin, $output: (size));\n        }\n      }\n    }\n  }\n}\n\n// Collapse classes\n@mixin xy-collapse-grid-classes($margin-grid: true, $padding-grid: true) {\n  @each $bp in $breakpoint-classes {\n    @if $margin-grid {\n      .#{$bp}-margin-collapse {\n        @include xy-grid-collapse($gutter-type: margin, $min-breakpoint: $bp);\n      }\n    }\n\n    @if $padding-grid {\n      .#{$bp}-padding-collapse {\n        @include xy-grid-collapse($gutter-type: padding, $min-breakpoint: $bp);\n      }\n    }\n  }\n}\n\n// Offset classes\n@mixin xy-offset-cell-classes {\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-columns {\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $gutters: $grid-padding-gutters, $gutter-type: padding);\n      }\n\n      .grid-margin-x > .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o);\n      }\n    }\n  }\n}\n\n// Vertical Grid classes\n@mixin xy-vertical-grid-classes(\n  $margin-grid: true,\n  $padding-grid: true\n) {\n\n  @include -zf-each-breakpoint() {\n    @if not($-zf-size == $-zf-zero-breakpoint) {\n    }\n  }\n\n  .grid-y {\n    @include xy-grid(vertical, false);\n\n\n    > .cell {\n      @include xy-cell-reset();\n    }\n\n    > .auto {\n      @include xy-cell-size(auto, $gutter-type: none, $vertical: true);\n    }\n\n    > .shrink {\n      @include xy-cell-size(shrink, $gutter-type: none, $vertical: true);\n    }\n\n\n    @include -zf-each-breakpoint() {\n      // This is a bit of a hack/workaround, see these issues and PRs for the backstory:\n      // https://github.com/foundation/foundation-sites/issues/10244\n      // https://github.com/foundation/foundation-sites/pull/10222 and\n      // https://github.com/foundation/foundation-sites/pull/10164\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n      // Responsive \"auto\" modifier\n      @if not($-zf-size == $-zf-zero-breakpoint) {\n        > .#{$-zf-size}-auto {\n          @include xy-cell(auto, $gutter-type: none, $vertical: true);\n        }\n      }\n\n      %-xy-cell-base-shrink-vertical-#{$-zf-size} {\n        @include xy-cell-base(shrink);\n      }\n\n      // Responsive \"shrink\" modifier\n      @if not($-zf-size == $-zf-zero-breakpoint) {\n        > .#{$-zf-size}-shrink {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-size(shrink, $gutter-type: none, $vertical: true);\n        }\n      }\n\n      // Responsive width modifiers\n      @for $i from 1 through $grid-columns {\n        // Sizing (percentage)\n        > .#{$-zf-size}-#{$i} {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-size($i, $gutter-type: none, $vertical: true);\n        }\n      }\n\n    }\n  }\n\n  @if $padding-grid {\n    .grid-padding-y {\n      // Negative margin for nested grids\n      .grid-padding-y {\n        @include xy-gutters($negative: true, $gutter-position: top bottom);\n      }\n\n      // Base cell styles\n      > .cell {\n        @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding, $gutter-position: top bottom);\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n  }\n\n}\n\n@mixin xy-frame-grid-classes($vertical-grid: true, $margin-grid: true) {\n  // Framed grid styles\n  .grid-frame {\n    @include xy-grid-frame;\n  }\n\n  .cell .grid-frame {\n    width: 100%; // Same as include with $nested, but with less css\n  }\n\n  .cell-block {\n    @include xy-cell-block();\n  }\n\n  .cell-block-y {\n    @include xy-cell-block(true);\n  }\n\n\n  .cell-block-container {\n    @include xy-cell-block-container();\n  }\n\n\n  @include -zf-each-breakpoint(false) {\n\n    .#{$-zf-size}-grid-frame {\n      @include xy-grid-frame;\n    }\n\n    .cell .#{$-zf-size}-grid-frame {\n      width: 100%; // Same as include with $nested, but with less css\n    }\n\n    .#{$-zf-size}-cell-block {\n      @include xy-cell-block();\n    }\n\n    .#{$-zf-size}-cell-block-container {\n      @include xy-cell-block-container();\n    }\n\n    .#{$-zf-size}-cell-block-y {\n      @include xy-cell-block(true);\n    }\n  }\n\n  @if $vertical-grid {\n    .grid-y {\n      &.grid-frame {\n        width: auto;\n        @include xy-grid-frame(true);\n      }\n\n      @include -zf-each-breakpoint(false) {\n        &.#{$-zf-size}-grid-frame {\n          width: auto;\n          @include xy-grid-frame(true);\n        }\n\n      }\n    }\n    .cell {\n      .grid-y.grid-frame {\n        height: 100%; // Same as include with $nested, but with less css\n      }\n      @include -zf-each-breakpoint(false) {\n        .grid-y.#{$-zf-size}-grid-frame {\n          height: 100%; // Same as include with $nested, but with less css\n        }\n      }\n    }\n  }\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n    .grid-frame.grid-margin-y {\n      @include xy-grid-frame(true, false, $grid-margin-gutters, $include-base: false);\n    }\n    @include -zf-each-breakpoint(false) {\n      .grid-margin-y.#{$-zf-size}-grid-frame {\n        @include xy-grid-frame(true, false, $grid-margin-gutters, $-zf-size, false);\n      }\n    }\n  }\n}\n\n// Final classes\n@mixin foundation-xy-grid-classes(\n  $base-grid: true,\n  $margin-grid: true,\n  $padding-grid: true,\n  $block-grid: true,\n  $collapse: true,\n  $offset: true,\n  $vertical-grid: true,\n  $frame-grid: true\n) {\n\n  // Base grid styles\n  @if($base-grid) {\n    @include xy-base-grid-classes();\n  }\n\n  // Margin grid\n  @if($margin-grid) {\n    @include xy-margin-grid-classes();\n  }\n\n  // Padding grid\n  @if($padding-grid) {\n    @include xy-padding-grid-classes();\n  }\n\n  // Block grid\n  @if($block-grid) {\n    @include xy-block-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Collapse gutters\n  @if($collapse) {\n    @include xy-collapse-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Offset gutters\n  @if($offset) {\n    @include xy-offset-cell-classes();\n  }\n\n  // Vertical grid\n  @if($vertical-grid) {\n    @include xy-vertical-grid-classes($margin-grid, $padding-grid);\n  }\n\n  @if ($frame-grid) {\n    @include xy-frame-grid-classes($vertical-grid, $margin-grid)\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Create gutters for a cell/container.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts either margin or padding.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Boolean} $negative [false] - Whether to apply the gutter as a negative value. Commonly used for nested grids.\n@mixin xy-gutters(\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $negative: false\n) {\n  $operator: if($negative, '-', '');\n\n  // If we have declared negative gutters, force type to `margin.\n  $gutter-type: if($negative, 'margin', $gutter-type);\n\n  // Output our margin gutters.\n  @if (type-of($gutters) == 'map') {\n    @include -zf-breakpoint-value(auto, $gutters) {\n      $gutter: rem-calc($-zf-bp-value) / 2;\n\n      // Loop through each gutter position\n      @each $value in $gutter-position {\n        #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n      }\n    }\n  }\n  @else if (type-of($gutters) == 'number') {\n    $gutter: rem-calc($gutters) / 2;\n\n    // Loop through each gutter position\n    @each $value in $gutter-position {\n      #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Creates a max width container, designed to house your grid content.\n///\n/// @param {Number} $width [$grid-container] - a width to limit the container to.\n/// @param {Number} $padding [$grid-container-padding] - paddings of the container.\n@mixin xy-grid-container(\n  $width: $grid-container,\n  $padding: $grid-container-padding\n) {\n  @include xy-gutters($gutters: $padding, $gutter-type: padding);\n\n  max-width: $width;\n  margin-left: auto;\n  margin-right: auto;\n}\n\n/// Creates a container for your flex cells.\n///\n/// @param {Keyword} $direction [horizontal] - Either horizontal or vertical direction of cells within.\n/// @param {Boolean} $wrap [true] - If the cells within should wrap or not.\n@mixin xy-grid(\n  $direction: horizontal,\n  $wrap: true\n) {\n  $direction: if($direction == 'horizontal', row, column);\n  $wrap: if($wrap, wrap, nowrap);\n\n  display: flex;\n  flex-flow: $direction $wrap;\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Returns the appropriate CSS flex value for a cell base.\n///\n/// @param {Keyword} $size [full] - The size of your cell. Accepts `full`, `auto`, `shrink`, `grow`, or any other value representing a cell size (it will be treated as `shrink`).\n///\n/// @returns {List} The cell flex property value.\n@function xy-cell-base($size: full) {\n  @if ($size == 'auto') {\n    @return 1 1 0px;\n  }\n  @else if ($size == 'grow') {\n    @return 1 0 auto;\n  }\n  @else if ($size == 'shrink' or $size == 'full' or zf-is-fraction($size, $allow-no-denominator: true)) {\n    @return 0 0 auto;\n  }\n  @return null;\n}\n\n/// Calculate the size of a cell gutters.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If `auto`, returns the responsive gutters map `$gutters`. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n///\n/// @returns {Number|Map} The cell gutter size or the responsive gutters map.\n@function xy-cell-gutters(\n  $gutters: $grid-margin-gutters,\n  $breakpoint: null\n) {\n  // For `auto`, returns the responsive map `$gutters`.\n  @if ($breakpoint == 'auto') {\n    @return $gutters;\n  }\n\n  // Use the contextual breakpoint by default.\n  $breakpoint: -zf-current-breakpoint($breakpoint);\n\n  @if ($breakpoint) {\n    @return -zf-get-bp-val($gutters, $breakpoint);\n  }\n  @else {\n    @return -zf-get-bp-val($gutters, $-zf-zero-breakpoint) or 0;\n  }\n}\n\n/// Returns the percentage size of a cell.\n///\n/// @param {Number|List} $size [$grid-columns] - Size to make the cell. You can pass a value in multiple formats, such as `6`, `50%`, `1 of 2` or `1/3`.\n///\n/// @returns {Number} Size of the cell (in percent).\n@function xy-cell-size(\n  $size: $grid-columns\n) {\n  @return fraction-to-percentage($size, $denominator: $grid-columns);\n}\n\n/// Returns the appropriate CSS value for a cell size.\n///\n/// Gutters-related arguments are required for cells with margin gutters (by default) as the gutter is included in the width.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full`, `auto`, `shrink` or any fraction like `6`, `50%`, `1 of 2` or `1/2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin`, `padding` or `none`.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If `auto`, returns a map of sizes adapted to responsive gutters. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n///\n/// @returns {Number|String|Map} The cell sizing property value, or a responsive map of them.\n@function xy-cell-size-css(\n  $size: full,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: null\n) {\n  $margin-gutter: 0;\n\n  @if ($size == 'auto' or $size == 'shrink') {\n    @return auto;\n  }\n\n  // For cells with margin gutters, the gutter is included in the width.\n  @if ($gutter-type == 'margin') {\n    $margin-gutter: xy-cell-gutters($gutters, $breakpoint);\n    @if ($margin-gutter == null) {\n      @error 'xy-cell-size: no gutters were found in `$gutters` for \"$breakpoint: #{$breakpoint}\"';\n    }\n  }\n\n  // Calculate the cell size (number)\n  $size-raw: if($size == 'full', 100%, xy-cell-size($size));\n\n  // Calculate the cell CSS size including gutters (string)\n  // If the cell has responsive margin gutters, return a responsive map of sizes.\n  @if type-of($margin-gutter) == 'map' {\n    $responsive-css-sizes: ();\n\n    @each $bp, $mg in $margin-gutter {\n      $size-css: if($mg == 0, $size-raw, calc(#{$size-raw} - #{rem-calc($mg)}));\n      $responsive-css-sizes: map-merge($responsive-css-sizes, ($bp: $size-css));\n    }\n\n    @return $responsive-css-sizes;\n  }\n  // Otherwise, return a single CSS size.\n  @else {\n    $css-size: if($margin-gutter == 0, $size-raw, calc(#{$size-raw} - #{rem-calc($margin-gutter)}));\n    @return $css-size;\n  }\n}\n\n/// Sets base flex properties for cells.\n///\n/// @param {Keyword} $size [full] - The size of your cell. Accepts `full`, `auto`, `shrink`, `grow`, or any other value representing a cell size (it will be treated as `shrink`).\n@mixin xy-cell-base($size: full) {\n  $base: xy-cell-base($size);\n\n  flex: #{$base};\n\n  // Set base styles for \"full\" only\n  @if($size == 'full') {\n    min-height: 0px;\n    min-width: 0px;\n  }\n}\n\n/// Resets a cells width (or height if vertical is true) as well as strips its gutters.\n///\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-reset($vertical: true) {\n  $direction: if($vertical == true, height, width);\n  #{$direction}: auto;\n  max-#{$direction}: none;\n}\n\n/// Sets sizing properties for cells.\n///\n/// Gutters-related arguments are required for cells with margin gutters (by default) as the gutter is included in the width.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (100% width), `auto` (use all available space), `shrink` (use only the required space) or any fraction (`6`, `50%`, `1 of 2` or `1/2`...).\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin`, `padding` or `none`.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If `auto`, generates sizes adapted for responsive gutters. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-size(\n  $size: full,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $sizes: xy-cell-size-css($size, $gutters, $gutter-type, $breakpoint);\n  $direction: if($vertical == true, height, width);\n\n  @if (type-of($sizes) == 'map') {\n    @include -zf-breakpoint-value(auto, $sizes) {\n      #{$direction}: $-zf-bp-value;\n    }\n  }\n  @else {\n    #{$direction}: $sizes;\n  }\n}\n\n/// Sets gutters properties for cells.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin`, `padding` or `none`.\n/// @param {List} $gutter-position [null] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination. By default `right left` for horizontal cells and `top bottom` for vertical cells.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If `auto`, generates responsive gutters. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Direction of the gutters to output. See `$gutter-position`.\n@mixin xy-cell-gutters(\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: null,\n  $breakpoint: null,\n  $vertical: false\n) {\n  // Get the default gutter position according to cell direction\n  @if($gutter-position == null) {\n    $gutter-position: if($vertical == true, top bottom, left right);\n  }\n\n  // Get the gutter width for this breakpoint\n  $gutter-width: xy-cell-gutters($gutters, $breakpoint);\n  @if ($gutter-width == null) {\n    @error 'xy-cell-gutters: no gutters were found in `$gutters` for \"$breakpoint: #{$breakpoint}\"';\n  }\n\n  @if ($gutter-type and $gutter-type != none) {\n    @include xy-gutters($gutter-width, $gutter-type, $gutter-position);\n  }\n}\n\n/// Creates a cell for your grid.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (100% width), `auto` (use all available space), `shrink` (use only the required space) or any fraction (`6`, `50%`, `1 of 2` or `1/2`...).\n/// @param {Boolean} $gutter-output [null] - [DEPRECATED] Whether or not to output gutters.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin`, `padding` or `none`.\n/// @param {List} $gutter-position [null] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination. By default `right left` for horizontal cells and `top bottom` for vertical cells.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If `auto`, generates responsive gutters. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n/// @param {List} $output [(base size gutters)] - Cell parts to output. You will need to generate others parts of the cell seperately, it may not work properly otherwise.\n@mixin xy-cell(\n  $size: full,\n  $gutter-output: null,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: null,\n  $breakpoint: null,\n  $vertical: false,\n  $output: (base size gutters)\n) {\n  // Default for $gutter-output\n  @if ($gutter-output != null) {\n    @warn 'xy-cell: $gutter-output is deprecated and will be removed. See migration notes at https://git.io/foundation-6-6-0';\n    @if ($gutter-output == false) {\n      $output: sl-remove($output, gutters);\n    }\n  }\n\n  @if (index($output, base)) {\n    @include xy-cell-base($size);\n  }\n  @if (index($output, size)) {\n    @include xy-cell-size($size, $gutters, $gutter-type, $breakpoint, $vertical);\n  }\n  @if (index($output, gutters)) {\n    @include xy-cell-gutters($gutters, $gutter-type, $gutter-position, $breakpoint, $vertical);\n  }\n}\n\n/// Creates a single breakpoint sized grid. Used to generate our grid classes.\n///\n/// `xy-cell-static()` is deprecated and will be removed.\n/// Use `xy-cell()` instead with `$output: (size gutters)` to not generate the cell base.\n/// See migration notes at https://git.io/foundation-6-6-0\n///\n/// @deprecated v6.6.0\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (100% width), `auto` (use all available space), `shrink` (use only the required space) or any fraction (`6`, `50%`, `1 of 2` or `1/2`...).\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters. Always `true` for margin gutters.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-static(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: $-zf-zero-breakpoint,\n  $vertical: false\n) {\n  @warn 'xy-cell-static() mixin is deprecated and will be removed. Use \"xy-cell()\" instead. See migration notes at https://git.io/foundation-6-6-0';\n\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  $gutter-position: if($vertical == true, top bottom, left right);\n\n  $-gutter-output: if($gutter-type == 'margin', true, $gutter-output);\n  $-gutter-margin: if($gutter-type == 'margin', $gutter, 0);\n\n  @include -xy-cell-properties($size, $-gutter-margin, $vertical);\n  @if ($-gutter-output) {\n    @include xy-gutters($gutter, $gutter-type, $gutter-position);\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Finds the greatest common divisor of two integers.\n///\n/// @param {Number} $a - First number to compare.\n/// @param {Number} $b - Second number to compare.\n///\n/// @returns {Number} The greatest common divisor.\n@function gcd($a, $b) {\n  // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript\n  @if ($b != 0) {\n    @return gcd($b, $a % $b);\n  }\n  @else {\n    @return abs($a);\n  }\n}\n\n/// Handles decimal exponents by trying to convert them into a fraction and then use a nth-root-algorithm for parts of the calculation\n///\n/// @param {Number} $base - The base number.\n/// @param {Number} $exponent - The exponent.\n///\n/// @returns {Number} The product of the exponentiation.\n@function pow($base, $exponent, $prec: 16) {\n  @if (floor($exponent) != $exponent) {\n    $prec2 : pow(10, $prec);\n    $exponent: round($exponent * $prec2);\n    $denominator: gcd($exponent, $prec2);\n    @return nth-root(pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);\n  }\n\n  $value: $base;\n  @if $exponent > 1 {\n    @for $i from 2 through $exponent {\n      $value: $value * $base;\n    }\n  }\n  @else if $exponent < 1 {\n    @for $i from 0 through -$exponent {\n      $value: $value / $base;\n    }\n  }\n\n  @return $value;\n}\n\n@function nth-root($num, $n: 2, $prec: 12) {\n  // From: http://rosettacode.org/wiki/Nth_root#JavaScript\n  $x: 1;\n\n  @for $i from 0 through $prec {\n    $x: 1 / $n * (($n - 1) * $x + ($num / pow($x, $n - 1)));\n  }\n\n  @return $x;\n}\n\n/// Calculates the height as a percentage of the width for a given ratio.\n/// @param {List} $ratio - Ratio to use to calculate the height, formatted as `x by y`.\n/// @return {Number} A percentage value for the height relative to the width of a responsive container.\n@function ratio-to-percentage($ratio) {\n  $w: nth($ratio, 1);\n  $h: nth($ratio, 3);\n  @return $h / $w * 100%;\n}\n\n/// Parse the given `$fraction` to numerators and denumerators.\n///\n/// @param {*} $fraction - Value representing a fraction to parse. It can be formatted as `50%`, `1 of 2`, `1/2` or `50` (no denominator would be returned).\n///\n/// @return {List} List of parsed values with numerator at first position and denumerator as second. These values may be null.\n@function zf-parse-fraction($fraction) {\n\n  @if type-of($fraction) == 'number' {\n    // \"50%\"\n    @if unit($fraction) == '%' {\n      @return (strip-unit($fraction), 100);\n    }\n    @else if (unit($fraction) == '') {\n      // \"0.5\"\n      @if $fraction < 1 {\n        @return ($fraction * 100, 100);\n      }\n      // \"50\"\n      @else {\n        @return ($fraction, null);\n      }\n    }\n  }\n\n  @else if type-of($fraction) == 'list' {\n    // \"50 of 100\", \"50/100\"...\n    @if length($fraction) == 3\n      and type-of(nth($fraction, 1) == 'number')\n      and type-of(nth($fraction, 3) == 'number') {\n      @return (nth($fraction, 1), nth($fraction, 3));\n    }\n  }\n\n  @return (null, null);\n}\n\n/// Returns whether the given `$value` represents a fraction. Supports formats like `50%`, `1 of 2`, `1 per 2` or `1/2`.\n///\n/// @param {*} $value - Value to test.\n/// @param {Boolean} $allow-no-denominator [false] - If `true`, simple numbers without denominators like `50` are supported.\n///\n/// @return {Boolean} `true` if `$value` represents a fraction, `false` otherwise.\n@function zf-is-fraction($value, $allow-no-denominator: false) {\n  $parsed: zf-parse-fraction($value);\n  @return not(nth($parsed, 1) == null\n    or (nth($parsed, 2) == null and $allow-no-denominator == false));\n}\n\n/// Calculate a percentage from a given fraction.\n///\n/// @param {Number|List} $fraction - Value representing a fraction to use to calculate the percentage, formatted as `50` (relative to `$denominator`), `50%`, `1 of 2` or `1/2`.\n/// @param {Number|List} $denominator - Default value to use as denominator when `$fraction` represents an absolute value.\n@function fraction-to-percentage(\n  $fraction,\n  $denominator: null\n) {\n  $parsed: zf-parse-fraction($fraction);\n  $parsed-nominator: nth($parsed, 1);\n  $parsed-denominator: nth($parsed, 2);\n\n  @if $parsed-nominator == null {\n    @error 'Wrong syntax for \"fraction-to-percentage()\". Use a number, decimal, percentage, or \"n of n\" / \"n/n\".';\n  }\n  @if $parsed-denominator == null {\n    @if type-of($denominator) == 'number' {\n      $parsed-denominator: $denominator;\n    }\n    @else {\n      @error 'Error with \"fraction-to-percentage()\". A default \"$denominator\" is required to support absolute values';\n    }\n  }\n\n  @return percentage($parsed-nominator / $parsed-denominator);\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Sizes child elements so that `$n` number of items appear on each row.\n///\n/// @param {Number} $n - Number of elements to display per row.\n/// @param {String} $selector ['.cell'] - Selector(s) to use for child elements.\n/// @param {Boolean} $gutter-output [null] - [DEPRECATED] Whether or not to output gutters.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin`, `padding` or `none`.\n/// @param {List} $gutter-position [null] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination. By default `right left` for horizontal cells and `top bottom` for vertical cells.\n/// @param {String} $breakpoint [null] - The breakpoint to use for the cell generation. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n/// @param {List} $output [(base size gutters)] - Cell parts to output. You will need to generate others parts of the cell seperately, it may not work correctly otherwise.\n@mixin xy-grid-layout(\n  $n,\n  $selector: '.cell',\n  $gutter-output: null,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: null,\n  $breakpoint: null,\n  $vertical: false,\n  $output: (base size gutters)\n) {\n  $size: percentage(1/$n);\n\n  & > #{$selector} {\n    @include xy-cell($size, $gutter-output, $gutters, $gutter-type, $gutter-position, $breakpoint, $vertical, $output);\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Collapses the grid a cells within it.\n///\n/// @param {String} $selector [.cell] - The child element to remove the gutter from.\n/// @param {Keyword} $gutter-type [margin] - The type of gutter to remove.\n/// @param {List} $gutter-position [right left] - The positions to remove gutters from. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Keyword} $min-breakpoint [$-zf-zero-breakpoint] - Minimum breakpoint in `$breakpoint-classes` for which to collapse the gutter.\n@mixin xy-grid-collapse(\n  $selector: '.cell',\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $min-breakpoint: $-zf-zero-breakpoint\n) {\n  // First, lets negate any margins on the top level\n  @if ($gutter-type == 'margin') {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          margin-#{$value}: 0;\n        }\n      }\n    }\n\n    $excluded-bps: -zf-breakpoints-less-than($min-breakpoint);\n\n    // Output new widths to not include gutters\n    @each $bp in $breakpoint-classes {\n      @if(sl-contain($excluded-bps, $bp)) {\n        @include breakpoint($min-breakpoint) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-size($i, $gutter-type: none);\n            }\n          }\n        }\n      } @else {\n        @include breakpoint($bp) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-size($i, $gutter-type: none);\n            }\n          }\n        }\n      }\n    }\n  }\n  @else {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          padding-#{$value}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Returns the appropriate CSS value to offset a cell.\n///\n/// @param {Number|List} $n - Size to offset by. You can pass in any value accepted by the `xy-cell()` mixin, such as `6`, `50%`, or `1 of 2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] Map of gutters or single value to use for responsive gutters.\n/// @param {Keyword} $gutter-type [margin] The type of gutter to use. Can be `margin` or `padding`\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n///\n/// @returns {Number|String} The cell offset property value.\n@function xy-cell-offset(\n  $n,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: null\n) {\n  $breakpoint: -zf-current-breakpoint($breakpoint, $default: $-zf-zero-breakpoint);\n  $size: xy-cell-size($n);\n\n  $offset: $size;\n  @if ($gutter-type == 'margin') {\n    $gutter: rem-calc(xy-cell-gutters($gutters, $breakpoint) / 2);\n    $offset: if($gutter == 0, $size, calc(#{$size} + #{$gutter}));\n  }\n  @return $offset;\n}\n\n/// Offsets a column to the right/bottom by `$n` columns.\n///\n/// @param {Number|List} $n - Size to offset by. You can pass in any value accepted by the `xy-cell()` mixin, such as `6`, `50%`, or `1 of 2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] Map of gutters or single value to use for responsive gutters.\n/// @param {Keyword} $gutter-type [margin] The type of gutter to use. Can be `margin` or `padding`\n/// @param {Number|Array|Keyword} $breakpoint [null] - Breakpoint to use for `$gutters`. It can be a breakpoint name, list of breakpoints or `auto` for all breakpoints. If a list is given, media-queries will be generated. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] Sets the direction of the offset. If set to true will apply margin-top instead.\n@mixin xy-cell-offset(\n $n,\n $gutters: $grid-margin-gutters,\n $gutter-type: margin,\n $breakpoint: null,\n $vertical: false\n) {\n  $breakpoint: -zf-current-breakpoint($breakpoint, $default: $-zf-zero-breakpoint);\n  $direction: if($vertical, 'top', $global-left);\n\n  @include -zf-each-breakpoint-in($breakpoint, $media-queries: 'for-lists') {\n    $offset: xy-cell-offset($n, $gutters, $gutter-type);\n    margin-#{$direction}: #{$offset};\n  }\n}\n","/// Modifies a grid to give it \"frame\" behavior (no overflow, no wrap, stretch behavior)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n/// @param {Boolean} $nested [false] - Is grid nested or not. If nested is true this sets the frame to 100% height, otherwise will be 100vh.\n/// @param {Number|Map} $gutters [null] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from.\n/// @param {Boolean} $include-base [true] - Include the base styles that don't vary per breakpoint.\n@mixin xy-grid-frame(\n  $vertical: false,\n  $nested: false,\n  $gutters: null,\n  $breakpoint: null,\n  $include-base: true\n) {\n\n  @if $include-base {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n\n  @if $breakpoint == null and type-of($gutters) == 'map' {\n    @include -zf-each-breakpoint() {\n      @include xy-grid-frame($vertical, $nested, $gutters, $-zf-size, false);\n    }\n  } @else {\n    // Get our gutters if applicable\n    $gutter: -zf-get-bp-val($gutters, $breakpoint);\n\n    // If we have a gutter, add it to the width/height\n    @if $gutter {\n      @if $vertical == true {\n        $unit: if($nested == true, 100%, 100vh);\n        $gutter: rem-calc($gutter);\n        height: calc(#{$unit} + #{$gutter});\n      } @else {\n        $unit: if($nested == true, 100%, 100vw);\n        $gutter: rem-calc($gutter);\n        width: calc(#{$unit} + #{$gutter});\n      }\n    }\n    @else {\n      @if $vertical == true {\n        height: if($nested == true, 100%, 100vh);\n      } @else {\n        width: if($nested == true, 100%, 100vw);\n      }\n    }\n  }\n}\n\n/// Modifies a cell to give it \"block\" behavior (overflow auto, inertial scrolling)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n@mixin xy-cell-block(\n  $vertical: false\n) {\n  $property: if($vertical == true, 'overflow-y', 'overflow-x');\n\n  @if $vertical == true {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n  } @else {\n    overflow-x: auto;\n    max-width: 100%;\n  }\n\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar;\n}\n\n/// Container for inside a grid frame containing multiple blocks. Typically used\n/// as a modifier for a `.cell` to allow the cell to pass along flex sizing\n/// constraints / from parents to children.\n@mixin xy-cell-block-container() {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%;\n\n  > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group button\n////\n\n/// Font family for button elements.\n/// @type Font\n$button-font-family: inherit !default;\n\n/// Font weight for button elements.\n/// Ignored if null (default)\n/// @type Font-Weight\n$button-font-weight: null !default;\n\n/// Padding inside buttons.\n/// @type List\n$button-padding: 0.85em 1em !default;\n\n/// Margin around buttons.\n/// @type List\n$button-margin: 0 0 $global-margin 0 !default;\n\n/// Default fill for buttons. Can either be `solid` or `hollow`.\n/// @type Keyword\n$button-fill: solid !default;\n\n/// Default background color for buttons.\n/// @type Color\n$button-background: $primary-color !default;\n\n/// Background color on hover for buttons.\n/// @type Color\n$button-background-hover: scale-color($button-background, $lightness: -15%) !default;\n\n/// Font color for buttons.\n/// @type List\n$button-color: $white !default;\n\n/// Alternative font color for buttons.\n/// @type List\n$button-color-alt: $black !default;\n\n/// Border radius for buttons, defaulted to global-radius.\n/// @type Number\n$button-radius: $global-radius !default;\n\n/// Border for buttons, transparent by default\n/// @type List\n$button-border: 1px solid transparent !default;\n\n/// Border width for hollow outline buttons\n/// @type Number\n$button-hollow-border-width: 1px !default;\n\n/// Sizes for buttons.\n/// @type Map\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n) !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$button-palette: $foundation-palette !default;\n\n/// opacity for a disabled button.\n/// @type List\n$button-opacity-disabled: 0.25 !default;\n\n/// Background color lightness on hover for buttons.\n/// @type Number\n$button-background-hover-lightness: -20% !default;\n\n/// Color lightness on hover for hollow buttons.\n/// @type Number\n$button-hollow-hover-lightness: -50% !default;\n\n// Internal: flip from margin-right to margin-left for defaults\n@if $global-text-direction == 'rtl' {\n  $button-margin: 0 0 $global-margin $global-margin !default;\n}\n\n/// transitions for buttons.\n/// @type List\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out !default;\n\n/// Additional responsive classes for .expanded\n/// @type Boolean\n$button-responsive-expanded: false !default;\n\n// TODO: Document button-base() mixin\n@mixin button-base {\n  @include disable-mouse-outline;\n  display: inline-block;\n  vertical-align: middle;\n  margin: $button-margin;\n\n  @if (type-of($button-padding) == 'map') {\n    @each $size, $padding in $button-padding {\n      @include breakpoint($size) {\n        padding: $padding;\n      }\n    }\n  }\n  @else {\n    padding: $button-padding;\n  }\n\n  border: $button-border;\n  border-radius: $button-radius;\n  transition: $button-transition;\n  font-family: $button-font-family;\n  font-size: map-get($button-sizes, default);\n  font-weight: $button-font-weight;\n  -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n}\n\n/// Expands a button to make it full-width.\n/// @param {Boolean} $expand [true] - Set to `true` to enable the expand behavior. Set to `false` to reverse this behavior.\n@mixin button-expand($expand: true) {\n  @if $expand {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0;\n  }\n  @else {\n    display: inline-block;\n    width: auto;\n    margin: $button-margin;\n  }\n}\n\n/// Sets the base styles of a hollow or clear button filling according to `$fill`.\n/// See mixin `button-fill-style` for the filling styles.\n/// @param {Keyword} $fill [$button-fill] - Type of filling between `hollow` and `clear`. `solid` has no effects.\n@mixin button-fill(\n  $fill: $button-fill\n) {\n  @if $fill == hollow {\n    @include button-hollow;\n  }\n  @else if $fill == clear {\n    @include button-clear;\n  }\n}\n\n/// Sets the visual styles of a solid/hollow/clear button filling according to `$fill`.\n/// See mixins `button-style`, `button-hollow-style` and `button-clear-style` for effects of visual styling parameters.\n/// @param {Keyword} $fill [$button-fill] - Type of filling between `hollow` and `clear`.\n/// @param {Color} $background [$button-background] - -\n/// @param {Color} $background-hover [$button-background-hover] - -\n/// @param {Color} $color [$button-color] - -\n@mixin button-fill-style(\n  $fill: $button-fill,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color\n) {\n  @if $fill == solid {\n    @include button-style($background, $background-hover, $color);\n  }\n  @else if $fill == hollow {\n    @include button-hollow-style($background);\n  }\n  @else if $fill == clear {\n    @include button-clear-style($background);\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  // Default and disabled states\n  &,\n  &.disabled, &[disabled],\n  &.disabled:hover, &[disabled]:hover,\n  &.disabled:focus, &[disabled]:focus {\n    background-color: $background;\n    color: $color;\n  }\n\n  &:hover, &:focus {\n    background-color: $background-hover;\n    color: $color;\n  }\n}\n\n/// Sets the base styles of a hollow button.\n/// See mixin `button-hollow-style` for the filling styles.\n@mixin button-hollow {\n  &, &.disabled, &[disabled] {\n    &, &:hover, &:focus {\n      background-color: transparent;\n    }\n  }\n}\n\n/// Sets the visual style of a hollow button.\n/// @param {Color} $color [$button-background] - Text and border color of the button.\n/// @param {Color} $hover-lightness [$button-hollow-hover-lightness] - Color lightness on hover.\n/// @param {Color} $border-width [$button-hollow-border-width] - Border width of the button.\n@mixin button-hollow-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness,\n  $border-width: $button-hollow-border-width\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  // Default and disabled states\n  &,\n  &.disabled, &[disabled],\n  &.disabled:hover, &[disabled]:hover,\n  &.disabled:focus, &[disabled]:focus {\n    border: $border-width solid $color;\n    color: $color;\n  }\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\n  }\n}\n\n/// Sets the base styles of a clear button.\n/// See mixin `button-clear-style` for the filling styles.\n@mixin button-clear {\n  &, &.disabled, &[disabled] {\n    &, &:hover, &:focus {\n      border-color: transparent;\n      background-color: transparent;\n    }\n  }\n}\n\n/// Sets the visual style of a clear button.\n/// @param {Color} $color [$button-background] - Text color of the button.\n/// @param {Color} $hover-lightness [$button-hollow-hover-lightness] - Color lightness on hover.\n@mixin button-clear-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  // Default and disabled states\n  &,\n  &.disabled, &[disabled],\n  &.disabled:hover, &[disabled]:hover,\n  &.disabled:focus, &[disabled]:focus {\n    color: $color;\n  }\n\n  &:hover, &:focus {\n    color: $color-hover;\n  }\n}\n\n/// Adds disabled styles to a button by fading the element and reseting the cursor.\n/// @param {Number} $opacity [$button-opacity-disabled] - Opacity of the disabled button.\n@mixin button-disabled(\n  $opacity: $button-opacity-disabled\n) {\n  opacity: $button-opacity-disabled;\n  cursor: not-allowed;\n}\n\n/// Adds a dropdown arrow to a button.\n/// @param {Number} $size [0.4em] - Size of the arrow. We recommend using an `em` value so the triangle scales when used inside different sizes of buttons.\n/// @param {Color} $color [white] - Color of the arrow.\n/// @param {Number} $offset [$button-padding] - Distance between the arrow and the text of the button. Defaults to whatever the right padding of a button is.\n@mixin button-dropdown(\n  $size: 0.4em,\n  $color: $white,\n  $offset: get-side($button-padding, right)\n) {\n  &::after {\n    @include css-triangle($size, $color, down);\n    position: relative;\n    top: 0.4em; // Aligns the arrow with the text of the button\n\n    display: inline-block;\n    float: #{$global-right};\n    margin-#{$global-left}: $offset;\n  }\n}\n\n/// Adds all styles for a button. For more granular control over styles, use the individual button mixins.\n/// @param {Boolean} $expand [false] - Set to `true` to make the button full-width.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n/// @param {Keyword} $style [solid] - Set to `hollow` to create a hollow button. The color defined in `$background` will be used as the primary color of the button.\n@mixin button(\n  $expand: false,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $style: $button-fill\n) {\n  @include button-base;\n  @include button-fill($style);\n  @include button-fill-style($style, $background, $background-hover, $color);\n\n  @if $expand {\n    @include button-expand;\n  }\n}\n\n@mixin foundation-button {\n  .button {\n    @include button($style: none);\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} {\n        font-size: $value;\n      }\n    }\n\n    &.expanded { @include button-expand; }\n\n    @if $button-responsive-expanded {\n      @each $size in $breakpoint-classes {\n        @include breakpoint(#{$size} only) {\n          &.#{$size}-only-expanded {\n            @include button-expand;\n          }\n        }\n        @if $size != $-zf-zero-breakpoint {\n          @include breakpoint(#{$size} down) {\n            &.#{$size}-down-expanded {\n              @include button-expand;\n            }\n          }\n\n          @include breakpoint(#{$size}) {\n            &.#{$size}-expanded {\n              @include button-expand;\n            }\n          }\n        }\n      }\n    }\n\n    // Solid, hollow & clear styles\n    @each $filling in (solid hollow clear) {\n      $selector: if($button-fill == $filling, null, '.#{$filling}');\n\n      &#{$selector} {\n        @include button-fill($filling);\n        @include button-fill-style($filling);\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-fill-style($filling, $color, auto, auto);\n          }\n        }\n      }\n    }\n\n    // Disabled state\n    &.disabled, &[disabled] {\n      @include button-disabled;\n    }\n\n    // Dropdown arrow\n    &.dropdown {\n      @include button-dropdown;\n\n      @if $button-fill == hollow {\n        &::after {\n          border-top-color: $button-background;\n        }\n      }\n\n      &.hollow, &.clear {\n        &::after {\n          border-top-color: $button-background;\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            &::after {\n              border-top-color: $color;\n            }\n          }\n        }\n      }\n    }\n\n    // Button with dropdown arrow only\n    &.arrow-only::after {\n      top: -0.1em;\n      float: none;\n      margin-#{$global-left}: 0;\n    }\n  }\n\n  a.button { // sass-lint:disable-line no-qualifying-elements\n    &:hover,\n    &:focus {\n      text-decoration: none;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group button-group\n////\n\n/// Margin for button groups.\n/// @type Number\n$buttongroup-margin: 1rem !default;\n\n/// Margin between buttons in a button group.\n/// @type Number\n$buttongroup-spacing: 1px !default;\n\n/// Selector for the buttons inside a button group.\n/// @type String\n$buttongroup-child-selector: '.button' !default;\n\n/// Maximum number of buttons that can be in an even-width button group. (Only needed when $global-flexbox: false;)\n/// @type Number\n$buttongroup-expand-max: 6 !default;\n\n/// Determines if $button-radius is applied to each button or the button group as a whole. Use $global-radius in _settings.scss to change radius.\n/// @type Boolean\n$buttongroup-radius-on-each: true !default;\n\n/// Add styles for a button group container.\n/// @param {String} $child-selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group(\n  $child-selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing\n) {\n  @include clearfix;\n  margin-bottom: $buttongroup-margin;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n    align-items: stretch;\n    flex-grow: 1;\n\n    &::before,\n    &::after {\n      display: none; // Disable clearfix\n    }\n  }\n  @else {\n    font-size: 0;\n  }\n\n  #{$child-selector} {\n    margin: 0;\n    margin-#{$global-right}: $spacing;\n    margin-bottom: $spacing;\n    font-size: map-get($button-sizes, default);\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n\n    &:last-child {\n      margin-#{$global-right}: 0;\n    }\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $button-radius;\n        border-bottom-#{$global-left}-radius: $button-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $button-radius;\n        border-bottom-#{$global-right}-radius: $button-radius;\n      }\n    }\n  }\n}\n\n/// Make buttons bonded without gap between them. Borders between buttons are merged\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n@mixin button-group-no-gaps(\n  $selector: $buttongroup-child-selector,\n  $border-width: $button-hollow-border-width\n) {\n  #{$selector} {\n    margin-#{$global-right}: rem-calc(-$border-width);\n\n    + #{$selector} {\n      border-#{$global-left}-color: transparent;\n    }\n  }\n}\n\n/// Creates a full-width button group, making each button equal width.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$spacing;\n\n    &::before,\n    &::after {\n      display: none; // Disable clearfix\n    }\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      margin-right: 0;\n    }\n    @else {\n      // One child\n      &:first-child {\n        &:last-child {\n          width: calc(100% - #{$spacing});\n        }\n      }\n\n      // Two or more childreen\n      @for $i from 2 through $buttongroup-expand-max {\n        &:first-child:nth-last-child(#{$i}) {\n          &, &:first-child:nth-last-child(#{$i}) ~ #{$selector} {\n            display: inline-block;\n            width: calc(#{percentage(1 / $i)} - #{$spacing});\n            margin-#{$global-right}: $spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $spacing * -$buttongroup-expand-max;\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n/// Stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-stack(\n  $selector: $buttongroup-child-selector\n) {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 100%;\n    }\n    @else {\n      width: 100%;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n\n    @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/// Un-stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-unstack(\n  $selector: $buttongroup-child-selector\n) {\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      width: auto;\n    }\n    margin-bottom: 0;\n\n    @if not $buttongroup-radius-on-each {\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-left}-radius: 0;\n      }\n    }\n\n  }\n}\n\n@mixin foundation-button-group {\n  .button-group {\n    @include button-group;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} #{$buttongroup-child-selector} {\n        font-size: $value;\n      }\n    }\n\n    // Even-width Group\n    &.expanded {\n      @include button-group-expand;\n    }\n\n    // Solid, hollow & clear styles\n    @each $filling in (solid hollow clear) {\n      $base-selector: if($button-fill == $filling, null, '.#{$filling}');\n\n      &#{$base-selector} {\n        // Do not generate button base styles for the default filling\n        @if($button-fill != $filling) {\n          #{$buttongroup-child-selector} {\n            @include button-fill($filling);\n            @include button-fill-style($filling);\n          }\n        }\n\n        @each $name, $color in $button-palette {\n          $individual-selector: if($button-fill == $filling, null, ' #{$buttongroup-child-selector}.#{$name}');\n\n          &.#{$name} #{$buttongroup-child-selector}, #{$individual-selector} {\n            @include button-fill-style($filling, $color, auto, auto);\n          }\n        }\n      }\n\n    }\n\n    &.no-gaps {\n      @include button-group-no-gaps;\n    }\n\n    &.stacked,\n    &.stacked-for-small,\n    &.stacked-for-medium {\n      @include button-group-stack;\n\n      &.expanded {\n        @include button-group-expand;\n      }\n    }\n\n    &.stacked-for-small {\n      @include breakpoint(medium) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-medium {\n      @include breakpoint(large) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-small.expanded {\n      @include breakpoint(small only) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n\n    &.stacked-for-medium.expanded {\n      @include breakpoint(medium down) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Default z-index for a close button.\n/// @type Number\n$closebutton-z-index: 10 !default;\n\n/// Button size to use as default\n/// @type String\n/// @see $closebutton-size\n/// @see $closebutton-offset-horizontal\n/// @see $closebutton-offset-vertical\n$closebutton-default-size: medium !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/// Size(s) of the close button. Used to generate sizing modifiers.\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  z-index: $closebutton-z-index;\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    // Generate a placeholder and a class for each size\n    @each $name, $size in $closebutton-size {\n      @at-root {\n        %zf-close-button--#{$name} {\n          @include close-button-size($name);\n        }\n      }\n\n      &.#{$name} {\n        @extend %zf-close-button--#{$name};\n      }\n    }\n\n    // Use by default the placeholder of the default size\n    @extend %zf-close-button--#{$closebutton-default-size};\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n/// Adds styles for a progress bar container.\n@mixin progress-container {\n  height: $progress-height;\n  margin-bottom: $progress-margin-bottom;\n  border-radius: $progress-radius;\n  background-color: $progress-background;\n}\n\n/// Adds styles for the inner meter of a progress bar.\n@mixin progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: $progress-meter-background;\n\n  @if has-value($progress-radius) {\n    border-radius: $global-radius;\n  }\n}\n\n/// Adds styles for text in the progress meter.\n@mixin progress-meter-text {\n  @include absolute-center;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: $white;\n  white-space: nowrap;\n\n  @if has-value($progress-radius) {\n    border-radius: $progress-radius;\n  }\n}\n\n@mixin foundation-progress-bar {\n  // Progress bar\n  .progress {\n    @include progress-container;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        .progress-meter {\n          background-color: $color;\n        }\n      }\n    }\n  }\n\n  // Inner meter\n  .progress-meter {\n    @include progress-meter;\n  }\n\n  // Inner meter text\n  .progress-meter-text {\n    @include progress-meter-text;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n// [TODO] Check how plugin confirms disabled or vertical status\n// [TODO] Check if transition: all; is necessary\n\n////\n/// @group slider\n////\n\n/// Default slider width of a vertical slider. (Doesn't apply to the native slider.)\n/// @type Number\n$slider-width-vertical: 0.5rem !default;\n\n/// Transition properties to apply to the slider handle and fill. (Doesn't apply to the native slider.)\n/// @type Transition\n$slider-transition: all 0.2s ease-in-out !default;\n\n/// Adds the general styles for sliders.\n@mixin slider-container {\n  position: relative;\n  height: $slider-height;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n\n  background-color: $slider-background;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none;\n}\n\n/// Adds the general styles for active fill for sliders.\n@mixin slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n\n  display: inline-block;\n  max-width: 100%;\n  height: $slider-height;\n\n  background-color: $slider-fill-background;\n  transition: $slider-transition;\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n/// Adds the general styles for the slider handles.\n@mixin slider-handle {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  left: 0;\n  z-index: 1;\n\n  display: inline-block;\n  width: $slider-handle-width;\n  height: $slider-handle-height;\n\n  border-radius: $slider-radius;\n  background-color: $slider-handle-background;\n  transition: $slider-transition;\n  touch-action: manipulation;\n\n  &:hover {\n    background-color: scale-color($slider-handle-background, $lightness: -15%);\n  }\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n@mixin slider-disabled {\n  opacity: $slider-opacity-disabled;\n  cursor: not-allowed;\n}\n\n@mixin slider-vertical {\n  display: inline-block;\n  width: $slider-width-vertical;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1);\n\n  .slider-fill {\n    top: 0;\n    width: $slider-width-vertical;\n    max-height: 100%;\n  }\n\n  .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: $slider-handle-height;\n    height: $slider-handle-width;\n    transform: translateX(-50%);\n  }\n}\n\n@mixin foundation-slider {\n  // Container\n  .slider {\n    @include slider-container;\n  }\n\n  // Fill area\n  .slider-fill {\n    @include slider-fill;\n  }\n\n  // Draggable handle\n  .slider-handle {\n    @include slider-handle;\n  }\n\n  // Disabled state\n  .slider.disabled,\n  .slider[disabled] {\n    @include slider-disabled;\n  }\n\n  // Vertical slider\n  .slider.vertical {\n    @include slider-vertical;\n  }\n\n  // RTL support\n  @if $global-text-direction == rtl {\n    .slider:not(.vertical) {\n      transform: scale(-1, 1);\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Opacity of a disabled switch.\n/// @type Number\n$switch-opacity-disabled: .5 !default;\n\n/// Cursor for a disabled switch.\n/// @type Cursor\n$switch-cursor-disabled: not-allowed !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  // indicate a disabled switch\n  input:disabled ~ & {\n    cursor: $switch-cursor-disabled;\n    opacity: $switch-opacity-disabled;\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-qualifying-elements\n\n////\n/// @group table\n////\n\n/// Default color for table background.\n/// @type Color\n$table-background: $white  !default;\n\n/// Default scale for darkening the striped table rows and the table border.\n/// @type Number\n$table-color-scale: 5% !default;\n\n/// Default style for table border.\n/// @type List\n$table-border: 1px solid smart-scale($table-background, $table-color-scale) !default;\n\n/// Default padding for table.\n/// @type Number\n$table-padding: rem-calc(8 10 10) !default;\n\n/// Default scale for darkening the table rows on hover.\n/// @type Number\n$table-hover-scale: 2% !default;\n\n/// Default color of standard rows on hover.\n/// @type List\n$table-row-hover: darken($table-background, $table-hover-scale) !default;\n\n/// Default color of striped rows on hover.\n/// @type List\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale) !default;\n\n/// If `true`, tables are striped by default and an .unstriped class is created. If `false`, a .striped class is created.\n/// @type Boolean\n$table-is-striped: true !default;\n\n/// Default background color for striped rows.\n/// @type Color\n$table-striped-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default value for showing the stripe on rows of the tables, excluding the header and footer. If even, the even rows will have a background color. If odd, the odd rows will have a background color. If empty, or any other value, the table rows will have no striping.\n/// @type Keyword\n$table-stripe: even !default;\n\n/// Default color for header background.\n/// @type Color\n$table-head-background: smart-scale($table-background, $table-color-scale / 2) !default;\n\n/// Default color of header rows on hover.\n/// @type List\n$table-head-row-hover: darken($table-head-background, $table-hover-scale) !default;\n\n/// Default color for footer background.\n/// @type Color\n$table-foot-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default color of footer rows on hover.\n/// @type List\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale) !default;\n\n/// Default font color for header.\n/// @type Color\n$table-head-font-color: $body-font-color !default;\n\n/// Default font color for footer.\n/// @type Color\n$table-foot-font-color: $body-font-color !default;\n\n/// Default value for showing the header when using stacked tables.\n/// @type Boolean\n$show-header-for-stacked: false !default;\n\n/// Breakpoint at which stacked table switches from mobile to desktop view.\n/// @type Breakpoint\n$table-stack-breakpoint: medium !default;\n\n@mixin -zf-table-stripe($stripe: $table-stripe) {\n  tr {\n    // If stripe is set to even, darken the even rows.\n    @if $stripe == even {\n      &:nth-child(even) {\n        border-bottom: 0;\n        background-color: $table-striped-background;\n      }\n    }\n\n    // If stripe is set to odd, darken the odd rows.\n    @else if $stripe == odd {\n      &:nth-child(odd) {\n        background-color: $table-striped-background;\n      }\n    }\n  }\n}\n\n@mixin -zf-table-unstripe() {\n  tr {\n    border-bottom: 0;\n    border-bottom: $table-border;\n    background-color: $table-background;\n  }\n}\n\n@mixin -zf-table-children-styles($stripe: $table-stripe, $is-striped: $table-is-striped) {\n  thead,\n  tbody,\n  tfoot {\n    border: $table-border;\n    background-color: $table-background;\n  }\n\n  // Caption\n  caption {\n    padding: $table-padding;\n    font-weight: $global-weight-bold;\n  }\n\n  // Table head\n  thead {\n    background: $table-head-background;\n    color: $table-head-font-color;\n  }\n\n  // Table foot\n  tfoot {\n    background: $table-foot-background;\n    color: $table-foot-font-color;\n  }\n\n  // Table head and foot\n  thead,\n  tfoot {\n    // Rows within head and foot\n    tr {\n      background: transparent;\n    }\n\n    // Cells within head and foot\n    th,\n    td {\n      padding: $table-padding;\n      font-weight: $global-weight-bold;\n      text-align: #{$global-left};\n    }\n  }\n\n  // Table rows\n  tbody {\n    th,\n    td {\n      padding: $table-padding;\n    }\n  }\n\n  // If tables are striped\n  @if $is-striped == true {\n    tbody {\n      @include -zf-table-stripe($stripe);\n    }\n\n    &.unstriped {\n      tbody {\n        @include -zf-table-unstripe();\n        background-color: $table-background;\n      }\n    }\n  }\n\n  // If tables are not striped\n  @else if $is-striped == false {\n    tbody {\n      @include -zf-table-unstripe();\n    }\n\n    &.striped {\n      tbody {\n        @include -zf-table-stripe($stripe);\n      }\n    }\n  }\n}\n\n/// Adds the general styles for tables.\n/// @param {Keyword} $stripe [$table-stripe] - Uses keywords even, odd, or none to darken rows of the table. The default value is even.\n/// @param {Boolean} $nest [false] - Needed if you only want to apply this to a specific table.\n@mixin table(\n  $stripe: $table-stripe,\n  $nest: false\n) {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: $global-margin;\n  border-radius: $global-radius;\n\n  @if $nest {\n    @include -zf-table-children-styles($stripe);\n  }\n  @else {\n    @at-root {\n      @include -zf-table-children-styles($stripe);\n    }\n  }\n}\n\n/// Adds the ability to horizontally scroll the table when the content overflows horizontally.\n@mixin table-scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\n/// Slightly darkens the table rows on hover.\n@mixin table-hover {\n  thead tr {\n    //Darkens the table header rows on hover.\n    &:hover {\n      background-color: $table-head-row-hover;\n    }\n  }\n\n  tfoot tr {\n    //Darkens the table footer rows on hover.\n    &:hover {\n      background-color: $table-foot-row-hover;\n    }\n  }\n\n  tbody tr {\n    //Darkens the non-striped table rows on hover.\n    &:hover {\n      background-color: $table-row-hover;\n    }\n  }\n\n  @if $table-is-striped == true {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &:not(.unstriped) tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &:not(.unstriped) tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n\n  @else if $table-is-striped == false {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &.striped tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &.striped tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n}\n\n/// Adds styles for a stacked table. Useful for small-screen layouts.\n/// @param {Boolean} $header [$show-header-for-stacked] - Show the first th of header when stacked.\n@mixin table-stack($header: $show-header-for-stacked) {\n  @if $header {\n    thead {\n      th {\n        display: block;\n      }\n    }\n  }\n  @else {\n    thead {\n      display: none;\n    }\n  }\n\n  tfoot {\n    display: none;\n  }\n\n  tr,\n  th,\n  td {\n    display: block;\n  }\n\n  td {\n    border-top: 0;\n  }\n}\n\n@mixin foundation-table($nest: false) {\n  table {\n    @include table($nest: $nest);\n  }\n\n  table.stack {\n    @include breakpoint($table-stack-breakpoint down) {\n      @include table-stack;\n    }\n  }\n\n  table.scroll {\n    @include table-scroll;\n  }\n\n  table.hover {\n    @include table-hover;\n  }\n\n  .table-scroll {\n    overflow-x: auto;\n\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n@import 'math';\n\n$contrast-warnings: true !default;\n\n////\n/// @group functions\n////\n\n/// Checks the luminance of `$color`.\n///\n/// @param {Color} $color - Color to check the luminance of.\n///\n/// @returns {Number} The luminance of `$color`.\n@function color-luminance($color) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n  $rgba: red($color), green($color), blue($color);\n  $rgba2: ();\n\n  @for $i from 1 through 3 {\n    $rgb: nth($rgba, $i);\n    $rgb: $rgb / 255;\n\n    $rgb: if($rgb < 0.03928, $rgb / 12.92, pow(($rgb + 0.055) / 1.055, 2.4));\n\n    $rgba2: append($rgba2, $rgb);\n  }\n\n  @return 0.2126 * nth($rgba2, 1) + 0.7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);\n}\n\n/// Checks the contrast ratio of two colors.\n///\n/// @param {Color} $color1 - First color to compare.\n/// @param {Color} $color2 - Second color to compare.\n///\n/// @returns {Number} The contrast ratio of the compared colors.\n@function color-contrast($color1, $color2) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n  $luminance1: color-luminance($color1) + 0.05;\n  $luminance2: color-luminance($color2) + 0.05;\n  $ratio: $luminance1 / $luminance2;\n\n  @if $luminance2 > $luminance1 {\n    $ratio: 1 / $ratio;\n  }\n\n  $ratio: round($ratio * 10) / 10;\n\n  @return $ratio;\n}\n\n/// Checks the luminance of `$base`, and returns the color from `$colors` (list of colors) that has the most contrast.\n///\n/// @param {Color} $base - Color to check luminance.\n/// @param {List} $colors [($white, $black)] - Colors to compare.\n/// @param {Number} $tolerance [$global-color-pick-contrast-tolerance] - Contrast tolerance.\n///\n/// @returns {Color} the color from `$colors` (list of colors) that has the most contrast.\n@function color-pick-contrast($base, $colors: ($white, $black), $tolerance: $global-color-pick-contrast-tolerance) {\n  $contrast: color-contrast($base, nth($colors, 1));\n  $best: nth($colors, 1);\n\n  @for $i from 2 through length($colors) {\n    $current-contrast: color-contrast($base, nth($colors, $i));\n    @if ($current-contrast - $contrast > $tolerance) {\n      $contrast: color-contrast($base, nth($colors, $i));\n      $best: nth($colors, $i);\n    }\n  }\n\n  @if ($contrast-warnings and $contrast < 3) {\n    @warn \"Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}\";\n  }\n\n  @return $best;\n}\n\n/// Scales a color to be darker if it's light, or lighter if it's dark. Use this function to tint a color appropriate to its lightness.\n///\n/// @param {Color} $color - Color to scale.\n/// @param {Percentage} $scale [5%] - Amount to scale up or down.\n/// @param {Percentage} $threshold [40%] - Threshold of lightness to check against.\n///\n/// @returns {Color} A scaled color.\n@function smart-scale($color, $scale: 5%, $threshold: 40%) {\n  @if lightness($color) > $threshold {\n    $scale: -$scale;\n  }\n  @return scale-color($color, $lightness: $scale);\n}\n\n/// Get color from foundation-palette\n///\n/// @param {key} color key from foundation-palette\n///\n/// @returns {Color} color from foundation-palette\n@function get-color($key) {\n  @if map-has-key($foundation-palette, $key) {\n    @return map-get($foundation-palette, $key);\n  }\n  @else {\n    @error 'given $key is not available in $foundation-palette';\n  }\n}\n\n/// Transfers the colors in the `$foundation-palette` map into variables, such as `$primary-color` and `$secondary-color`. Call this mixin below the Global section of your settings file to properly migrate your codebase.\n@mixin add-foundation-colors() {\n  @if map-has-key($foundation-palette, primary) {\n    $primary-color: map-get($foundation-palette, primary) !global;\n  } @else {\n    $primary-color: #1779ba !global;\n  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  } @else {\n    $secondary-color: #767676 !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  } @else {\n    $success-color: #3adb76 !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  } @else {\n    $warning-color: #ffae00 !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  } @else {\n    $alert-color: #cc4b37 !global;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group breadcrumbs\n////\n\n/// Margin around a breadcrumbs container.\n/// @type Number\n$breadcrumbs-margin: 0 0 $global-margin 0 !default;\n\n/// Font size of breadcrumb links.\n/// @type Number\n$breadcrumbs-item-font-size: rem-calc(11) !default;\n\n/// Color of breadcrumb links.\n/// @type Color\n$breadcrumbs-item-color: $primary-color !default;\n\n/// Color of the active breadcrumb link.\n/// @type Color\n$breadcrumbs-item-color-current: $black !default;\n\n/// Opacity of disabled breadcrumb links.\n/// @type Number\n$breadcrumbs-item-color-disabled: $medium-gray !default;\n\n/// Margin between breadcrumb items.\n/// @type Number\n$breadcrumbs-item-margin: 0.75rem !default;\n\n/// If `true`, makes breadcrumb links uppercase.\n/// @type Boolean\n$breadcrumbs-item-uppercase: true !default;\n\n/// If `true`, adds a seperator between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-separator: true !default;\n\n// If it exists $breadcrumbs-item-slash is used to build $breadcrumbs-item-separator. See the documentation.\n@if variable-exists(breadcrumbs-item-slash) {\n  $breadcrumbs-item-separator: $breadcrumbs-item-slash;\n}\n\n/// Used character for the breadcrumb separator.\n/// @type Content\n$breadcrumbs-item-separator-item: '/' !default;\n\n/// Used character for the breadcrumb separator in rtl mode.\n/// @type Content\n$breadcrumbs-item-separator-item-rtl: '\\\\' !default;\n\n/// Color of breadcrumb item.\n/// @type Color\n$breadcrumbs-item-separator-color: $medium-gray !default;\n\n// If it exists $breadcrumbs-item-slash-color is used to build $breadcrumbs-item-separator-color. See the documentation.\n@if variable-exists(breadcrumbs-item-slash-color) {\n  $breadcrumbs-item-separator-color: $breadcrumbs-item-slash-color;\n}\n\n/// Adds styles for a breadcrumbs container, along with the styles for the `<li>` and `<a>` elements inside of it.\n@mixin breadcrumbs-container {\n  @include clearfix;\n  margin: $breadcrumbs-margin;\n  list-style: none;\n\n  // Item wrapper\n  li {\n    float: #{$global-left};\n\n    font-size: $breadcrumbs-item-font-size;\n    color: $breadcrumbs-item-color-current;\n    cursor: default;\n\n    @if $breadcrumbs-item-uppercase {\n      text-transform: uppercase;\n    }\n\n    @if $breadcrumbs-item-separator {\n      // Need to escape the backslash\n      $separator: if($global-text-direction == 'ltr', $breadcrumbs-item-separator-item, $breadcrumbs-item-separator-item-rtl);\n\n      &:not(:last-child) {\n        &::after {\n          position: relative;\n          margin: 0 $breadcrumbs-item-margin;\n          opacity: 1;\n          content: $separator;\n          color: $breadcrumbs-item-separator-color;\n        }\n      }\n    }\n    @else {\n      margin-#{$global-right}: $breadcrumbs-item-margin;\n    }\n  }\n\n  // Page links\n  a {\n    color: $breadcrumbs-item-color;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n}\n\n@mixin foundation-breadcrumbs {\n  .breadcrumbs {\n    @include breadcrumbs-container;\n\n    .disabled {\n      color: $breadcrumbs-item-color-disabled;\n      cursor: not-allowed;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Sizes for Callout paddings.\n/// @type Map\n$callout-sizes: (\n  small: 0.5rem,\n  default: 1rem,\n  large: 3rem,\n) !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: map-get($callout-sizes, default);\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    @each $size, $padding in map-remove($callout-sizes, default) {\n      &.#{$size} {\n        @include callout-size($padding);\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group card\n////\n\n/// Default background color.\n/// @type Color\n$card-background: $white !default;\n\n/// Default font color for cards.\n/// @type Color\n$card-font-color: $body-font-color !default;\n\n/// Default background.\n/// @type Color\n$card-divider-background: $light-gray !default;\n\n/// Default border style.\n/// @type List\n$card-border: 1px solid $light-gray !default;\n\n/// Default card shadow.\n/// @type List\n$card-shadow: none !default;\n\n/// Default border radius.\n/// @type List\n$card-border-radius: $global-radius !default;\n\n/// Default padding.\n/// @type Number\n$card-padding: $global-padding !default;\n\n/// Default bottom margin.\n/// @type number\n$card-margin-bottom: $global-margin !default;\n\n/// Adds styles for a card container.\n/// @param {Color} $background - Background color of the card.\n/// @param {Color} $color - font color of the card.\n/// @param {Number} $margin - Bottom margin of the card.\n/// @param {List} $border - Border around the card.\n/// @param {List} $radius - border radius of the card.\n/// @param {List} $shadow - box shadow of the card.\n@mixin card-container(\n  $background: $card-background,\n  $color: $card-font-color,\n  $margin: $card-margin-bottom,\n  $border: $card-border,\n  $radius: $card-border-radius,\n  $shadow: $card-shadow\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex-direction: column;\n    flex-grow: 1;\n  }\n\n  margin-bottom: $margin;\n\n  border: $border;\n  border-radius: $radius;\n\n  background: $background;\n  box-shadow: $shadow;\n\n  overflow: hidden;\n  color: $color;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card divider.\n@mixin card-divider(\n  $background: $card-divider-background,\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex: 0 1 auto;\n  }\n\n  padding: $padding;\n  background: $background;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card section.\n@mixin card-section(\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    flex: 1 0 auto;\n  }\n\n  padding: $padding;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n@mixin foundation-card {\n  .card {\n    @include card-container;\n  }\n\n  .card-divider {\n    @include card-divider;\n  }\n\n  .card-section {\n    @include card-section;\n  }\n\n  // For IE 11 - Flexbug\n  // https://github.com/philipwalton/flexbugs/issues/75\n  .card-image {\n    min-height: 1px;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown\n////\n\n/// Padding for dropdown panes.\n/// @type List\n$dropdown-padding: 1rem !default;\n\n/// Background for dropdown panes.\n/// @type Color\n$dropdown-background: $body-background !default;\n\n/// Border for dropdown panes.\n/// @type List\n$dropdown-border: 1px solid $medium-gray !default;\n\n/// Font size for dropdown panes.\n/// @type List\n$dropdown-font-size: 1rem !default;\n\n/// Width for dropdown panes.\n/// @type Number\n$dropdown-width: 300px !default;\n\n/// Border radius dropdown panes.\n/// @type Number\n$dropdown-radius: $global-radius !default;\n\n/// Sizes for dropdown panes. Each size is a CSS class you can apply.\n/// @type Map\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n) !default;\n\n/// Applies styles for a basic dropdown.\n@mixin dropdown-container {\n  position: absolute;\n  z-index: 10;\n\n  display: none;\n\n  width: $dropdown-width;\n  padding: $dropdown-padding;\n\n  visibility: hidden;\n  border: $dropdown-border;\n  border-radius: $dropdown-radius;\n  background-color: $dropdown-background;\n\n  font-size: $dropdown-font-size;\n\n\n  // Allow an intermittent state to do positioning before making visible.\n  &.is-opening {\n    display: block;\n  }\n\n  &.is-open {\n    display: block;\n    visibility: visible;\n  }\n}\n\n@mixin foundation-dropdown {\n  .dropdown-pane {\n    @include dropdown-container;\n  }\n\n  @each $name, $size in $dropdown-sizes {\n    .dropdown-pane {\n      &.#{$name} {\n        width: $size;\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Content for the previous arrow when `$pagination-arrows` is `true`\n/// @type String\n$pagination-arrow-previous: '\\00AB' !default;\n\n/// Content for the next arrow when `$pagination-arrows` is `true`\n/// @type String\n$pagination-arrow-next: '\\00BB' !default;\n\n/// Adds styles for a pagination container. Apply this to a `<ul>`.\n@mixin pagination-container (\n  $margin-bottom: $pagination-margin-bottom,\n  $font-size: $pagination-font-size,\n  $spacing: $pagination-item-spacing,\n  $radius: $pagination-radius,\n  $color: $pagination-item-color,\n  $padding: $pagination-item-padding,\n  $background-hover: $pagination-item-background-hover\n) {\n  @include clearfix;\n  margin-#{$global-left}: 0;\n  margin-bottom: $margin-bottom;\n\n  // List item\n  li {\n    margin-#{$global-right}: $spacing;\n    border-radius: $radius;\n    font-size: $font-size;\n\n    @if $pagination-mobile-items {\n      display: inline-block;\n    }\n    @else {\n      display: none;\n\n      &:last-child,\n      &:first-child {\n        display: inline-block;\n      }\n\n      @if $pagination-mobile-current-item {\n        &.current {\n          display: inline-block;\n        }\n      }\n\n      @include breakpoint(medium) {\n        display: inline-block;\n      }\n    }\n  }\n\n  // Page links\n  a,\n  button {\n    display: block;\n    padding: $padding;\n    border-radius: $radius;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n    }\n  }\n}\n\n/// Adds styles for the current pagination item. Apply this to an `<a>`.\n@mixin pagination-item-current (\n  $padding: $pagination-item-padding,\n  $background-current: $pagination-item-background-current,\n  $color-current: $pagination-item-color-current\n) {\n  padding: $padding;\n  background: $background-current;\n  color: $color-current;\n  cursor: default;\n}\n\n/// Adds styles for a disabled pagination item. Apply this to an `<a>`.\n@mixin pagination-item-disabled (\n  $padding: $pagination-item-padding,\n  $color: $pagination-item-color-disabled\n) {\n  padding: $padding;\n  color: $color;\n  cursor: not-allowed;\n\n  &:hover {\n    background: transparent;\n  }\n}\n\n/// Adds styles for an ellipsis for use in a pagination list.\n@mixin pagination-ellipsis (\n  $padding: $pagination-item-padding,\n  $color: $pagination-ellipsis-color\n) {\n  padding: $padding;\n  content: '\\2026';\n  color: $color;\n}\n\n@mixin foundation-pagination {\n  .pagination {\n    @include pagination-container;\n\n    .current {\n      @include pagination-item-current;\n    }\n\n    .disabled {\n      @include pagination-item-disabled;\n    }\n\n    .ellipsis::after {\n      @include pagination-ellipsis;\n    }\n  }\n\n  @if $pagination-arrows {\n    .pagination-previous a::before,\n    .pagination-previous.disabled::before {\n      display: inline-block;\n      margin-#{$global-right}: 0.5rem;\n      content: $pagination-arrow-previous;\n    }\n\n    .pagination-next a::after,\n    .pagination-next.disabled::after {\n      display: inline-block;\n      margin-#{$global-left}: 0.5rem;\n      content: $pagination-arrow-next;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group tooltip\n////\n\n/// Default cursor of the defined term.\n/// @type Keyword\n$has-tip-cursor: help !default;\n\n/// Default font weight of the defined term.\n/// @type Keyword | Number\n$has-tip-font-weight: $global-weight-bold !default;\n\n/// Default border bottom of the defined term.\n/// @type List\n$has-tip-border-bottom: dotted 1px $dark-gray !default;\n\n/// Default color of the tooltip background.\n/// @type Color\n$tooltip-background-color: $black !default;\n\n/// Default color of the tooltip font.\n/// @type Color\n$tooltip-color: $white !default;\n\n/// Default padding of the tooltip background.\n/// @type Number\n$tooltip-padding: 0.75rem !default;\n\n/// Default max width for tooltips.\n/// @type Number\n$tooltip-max-width: 10rem !default;\n\n/// Default font size of the tooltip text. By default, we recommend a smaller font size than the body copy.\n/// @type Number\n$tooltip-font-size: $small-font-size !default;\n\n/// Default pip width for tooltips.\n/// @type Number\n$tooltip-pip-width: 0.75rem !default;\n\n/// Default pip height for tooltips. This is helpful for calculating the distance of the tooltip from the tooltip word.\n/// @type Number\n$tooltip-pip-height: $tooltip-pip-width * 0.866 !default;\n\n/// Default radius for tooltips.\n/// @type Number\n$tooltip-radius: $global-radius !default;\n\n@mixin has-tip {\n  position: relative;\n  display: inline-block;\n\n  border-bottom: $has-tip-border-bottom;\n  font-weight: $has-tip-font-weight;\n  cursor: $has-tip-cursor;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: $tooltip-max-width;\n  padding: $tooltip-padding;\n\n  border-radius: $tooltip-radius;\n  background-color: $tooltip-background-color;\n  font-size: $tooltip-font-size;\n  color: $tooltip-color;\n\n  &::before {\n    position: absolute;\n  }\n\n  &.bottom {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n      bottom: 100%;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.top {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n      top: 100%;\n      bottom: auto;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.left {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n      left: 100%;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.right {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n      right: 100%;\n      left: auto;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.align-top::before {\n    bottom: auto;\n    top: 10%;\n  }\n\n  &.align-bottom::before {\n    bottom: 10%;\n    top: auto;\n  }\n\n  &.align-left::before {\n    left: 10%;\n    right: auto;\n  }\n\n  &.align-right::before {\n    left: auto;\n    right: 10%;\n  }\n}\n\n@mixin foundation-tooltip {\n  .has-tip {\n    @include has-tip;\n  }\n\n  .tooltip {\n    @include tooltip;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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/// Content for the plus icon when `$accordion-plusminus` is `true`\n/// @type String\n$accordion-plus-content: '\\002B' !default;\n\n/// Content for the minus icon when `$accordion-plusminus` is `true`\n/// @type String\n$accordion-minus-content: '\\2013' !default;\n\n/// Font size of accordion titles.\n/// @type Number\n$accordion-title-font-size: rem-calc(12) !default;\n\n/// Default text color for items in a Menu.\n/// @type Color\n$accordion-item-color: $primary-color !default;\n\n/// Default background color on hover for items in a Menu.\n/// @type Color\n$accordion-item-background-hover: $light-gray !default;\n\n/// Default padding of an accordion item.\n/// @type Number | List\n$accordion-item-padding: 1.25rem 1rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$accordion-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$accordion-content-border: 1px solid $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$accordion-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$accordion-content-padding: 1rem !default;\n\n/// Adds styles for an accordion container. Apply this to the same element that gets `data-accordion`.\n@mixin accordion-container (\n  $background: $accordion-background\n) {\n  margin-#{$global-left}: 0;\n  background: $background;\n  list-style-type: none;\n\n  &[disabled] {\n    .accordion-title {\n      cursor: not-allowed;\n    }\n  }\n}\n\n/// Adds styles for the accordion item. Apply this to the list item within an accordion ul.\n@mixin accordion-item {\n  &:first-child > :first-child {\n    border-radius: $global-radius $global-radius 0 0;\n  }\n\n  &:last-child > :last-child {\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n}\n\n/// Adds styles for the title of an accordion item. Apply this to the link within an accordion item.\n@mixin accordion-title (\n  $padding: $accordion-item-padding,\n  $font-size: $accordion-title-font-size,\n  $color: $accordion-item-color,\n  $border: $accordion-content-border,\n  $background-hover: $accordion-item-background-hover\n) {\n  position: relative;\n  display: block;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n\n  font-size: $font-size;\n  line-height: 1;\n  color: $color;\n\n  :last-child:not(.is-active) > & {\n    border-bottom: $border;\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n\n  &:hover,\n  &:focus {\n    background-color: $background-hover;\n  }\n\n  @if $accordion-plusminus {\n    &::before {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 1rem;\n      margin-top: -0.5rem;\n      content: $accordion-plus-content;\n    }\n\n    .is-active > &::before {\n      content: $accordion-minus-content;\n    }\n  }\n}\n\n/// Adds styles for accordion content. Apply this to the content pane below an accordion item's title.\n@mixin accordion-content (\n  $padding: $accordion-content-padding,\n  $border: $accordion-content-border,\n  $background: $accordion-content-background,\n  $color: $accordion-content-color\n) {\n  display: none;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n  background-color: $background;\n\n  color: $color;\n\n  :last-child > &:last-child {\n    border-bottom: $border;\n  }\n}\n\n@mixin foundation-accordion {\n  .accordion {\n    @include accordion-container;\n  }\n\n  .accordion-item {\n    @include accordion-item;\n  }\n\n  .accordion-title {\n    @include accordion-title;\n  }\n\n  .accordion-content {\n    @include accordion-content;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group media-object\n////\n\n/// Bottom margin of a media object.\n/// @type Number\n$mediaobject-margin-bottom: $global-margin !default;\n\n/// Left and right padding on sections within a media object.\n/// @type Number\n$mediaobject-section-padding: $global-padding !default;\n\n/// Width of images within a media object, when the object is stacked vertically. Set to 'auto' to use the image's natural width.\n/// @type Number\n$mediaobject-image-width-stacked: 100% !default;\n\n/// Adds styles for a media object container.\n@mixin media-object-container {\n  display: if($global-flexbox, flex, block);\n  margin-bottom: $mediaobject-margin-bottom;\n\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n  }\n\n  img {\n    max-width: none;\n  }\n\n  @if $global-flexbox {\n    &.stack-for-#{$-zf-zero-breakpoint} {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        flex-wrap: wrap;\n      }\n    }\n  }\n}\n\n/// Adds styles for sections within a media object.\n/// @param {Number} $padding [$mediaobject-section-padding] - Padding between sections.\n@mixin media-object-section($padding: $mediaobject-section-padding) {\n  @if $global-flexbox {\n    flex: 0 1 auto;\n  }\n  @else {\n    display: table-cell;\n    vertical-align: top;\n  }\n\n  &:first-child {\n    padding-#{$global-right}: $padding;\n  }\n\n  &:last-child:not(:nth-child(2)) {\n    padding-#{$global-left}: $padding;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n\n  .stack-for-#{$-zf-zero-breakpoint} & {\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include media-object-stack;\n    }\n  }\n\n  @if $global-flexbox {\n    &.main-section {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    &.middle {\n      vertical-align: middle;\n    }\n\n    &.bottom {\n      vertical-align: bottom;\n    }\n  }\n}\n\n/// Adds styles to stack sections of a media object. Apply this to the section elements, not the container.\n@mixin media-object-stack {\n  padding: 0;\n  padding-bottom: $mediaobject-section-padding;\n\n  @if $global-flexbox {\n    flex-basis: 100%;\n    max-width: 100%;\n  }\n  @else {\n    display: block;\n  }\n\n  img {\n    width: $mediaobject-image-width-stacked;\n  }\n}\n\n@mixin foundation-media-object {\n  .media-object {\n    @include media-object-container;\n  }\n\n  .media-object-section {\n    @include media-object-section;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group orbit\n////\n\n/// Default color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background: $medium-gray !default;\n\n/// Default active color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background-active: $dark-gray !default;\n\n/// Default diameter for Orbit's bullets.\n/// @type Number\n$orbit-bullet-diameter: 1.2rem !default;\n\n/// Default margin between Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin: 0.1rem !default;\n\n/// Default distance from slide region for Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin-top: 0.8rem !default;\n\n/// Default bottom margin from Orbit's bullets to whatever content may lurk below it.\n/// @type Number\n$orbit-bullet-margin-bottom: 0.8rem !default;\n\n/// Default background color for Orbit's caption.\n/// @type Color\n$orbit-caption-background: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's caption.\n/// @type Number\n$orbit-caption-padding: 1rem !default;\n\n/// Default background color for Orbit's controls when hovered.\n/// @type Color\n$orbit-control-background-hover: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's controls.\n/// @type Number\n$orbit-control-padding: 1rem !default;\n\n/// Default z-index for Orbit's controls.\n/// @type Number\n$orbit-control-zindex: 10 !default;\n\n/// Adds styles for the outer Orbit wrapper. These styles are used on the `.orbit` class.\n@mixin orbit-wrapper {\n  position: relative;\n}\n\n/// Adds styles for the inner Orbit slide container. These styles are used on the `.orbit-container` class.\n@mixin orbit-container {\n  position: relative;\n  height: 0; // Prevent FOUC by not showing until JS sets height\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n/// Adds styles for the individual slides of an Orbit slider. These styles are used on the `.orbit-slide` class.\n@mixin orbit-slide {\n  width: 100%;\n  position: absolute;\n\n  &.no-motionui {\n    &.is-active {\n      top: 0;\n      left: 0;\n    }\n  }\n}\n\n@mixin orbit-figure {\n  margin: 0;\n}\n\n/// Adds styles for a slide containing an image. These styles are used on the `.orbit-image` class.\n@mixin orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\n\n/// Adds styles for an orbit slide caption. These styles are used on the `.orbit-caption` class.\n@mixin orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: $orbit-caption-padding;\n\n  background-color: $orbit-caption-background;\n  color: color-pick-contrast($orbit-caption-background);\n}\n\n/// Adds base styles for the next/previous buttons in an Orbit slider. These styles are shared between the `.orbit-next` and `.orbit-previous` classes in the default CSS.\n@mixin orbit-control {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  z-index: $orbit-control-zindex;\n  padding: $orbit-control-padding;\n  color: $white;\n\n  &:hover,\n  &:active,\n  &:focus {\n    background-color: $orbit-control-background-hover;\n  }\n}\n\n/// Adds styles for the Orbit previous button. These styles are used on the `.orbit-previous` class.\n@mixin orbit-previous {\n  #{$global-left}: 0;\n}\n\n/// Adds styles for the Orbit next button. These styles are used on the `.orbit-next` class.\n@mixin orbit-next {\n  #{$global-left}: auto;\n  #{$global-right}: 0;\n}\n\n/// Adds styles for a container of Orbit bullets. /// Adds styles for the Orbit previous button. These styles are used on the `.orbit-bullets` class.\n@mixin orbit-bullets {\n  @include disable-mouse-outline;\n  position: relative;\n  margin-top: $orbit-bullet-margin-top;\n  margin-bottom: $orbit-bullet-margin-bottom;\n  text-align: center;\n\n  button {\n    width: $orbit-bullet-diameter;\n    height: $orbit-bullet-diameter;\n    margin: $orbit-bullet-margin;\n\n    border-radius: 50%;\n    background-color: $orbit-bullet-background;\n\n    &:hover {\n      background-color: $orbit-bullet-background-active;\n    }\n\n    &.is-active {\n      background-color: $orbit-bullet-background-active;\n    }\n  }\n}\n\n@mixin foundation-orbit {\n  .orbit {\n    @include orbit-wrapper;\n  }\n\n  .orbit-container {\n    @include orbit-container;\n  }\n\n  .orbit-slide {\n    @include orbit-slide;\n  }\n\n  .orbit-figure {\n    @include orbit-figure;\n  }\n\n  .orbit-image {\n    @include orbit-image;\n  }\n\n  .orbit-caption {\n    @include orbit-caption;\n  }\n\n  %orbit-control {\n    @include orbit-control;\n  }\n\n  .orbit-previous {\n    @extend %orbit-control;\n    @include orbit-previous;\n  }\n\n  .orbit-next {\n    @extend %orbit-control;\n    @include orbit-next;\n  }\n\n  .orbit-bullets {\n    @include orbit-bullets;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group responsive-embed\n////\n\n/// Margin below a responsive embed container.\n/// @type Number\n$responsive-embed-margin-bottom: rem-calc(16) !default;\n\n/// Aspect ratios used to determine padding-bottom of responsive embed containers.\n/// @type Map\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n) !default;\n\n/// Creates a responsive embed container.\n/// @param {String|List} $ratio [default] - Ratio of the container. Can be a key from the `$responsive-embed-ratios` map or a list formatted as `x by y`.\n@mixin responsive-embed($ratio: default) {\n  @if type-of($ratio) == 'string' {\n    $ratio: map-get($responsive-embed-ratios, $ratio);\n  }\n  position: relative;\n  height: 0;\n  margin-bottom: $responsive-embed-margin-bottom;\n  padding-bottom: ratio-to-percentage($ratio);\n  overflow: hidden;\n\n  iframe,\n  object,\n  embed,\n  video {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@mixin foundation-responsive-embed {\n  .responsive-embed,\n  .flex-video {\n    @include responsive-embed($ratio: default);\n\n    $ratios: map-remove($responsive-embed-ratios,default);\n\n    @each $name, $ratio in $ratios {\n      &.#{$name} {\n        padding-bottom: ratio-to-percentage($ratio);\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group tabs\n////\n\n/// Default margin of the tab bar.\n/// @type Number\n$tab-margin: 0 !default;\n\n/// Default background color of a tab bar.\n/// @type Color\n$tab-background: $white !default;\n\n/// Font color of tab item.\n/// @type Color\n$tab-color: $primary-color !default;\n\n/// Active background color of a tab bar.\n/// @type Color\n$tab-background-active: $light-gray !default;\n\n/// Active font color of tab item.\n/// @type Color\n$tab-active-color: $primary-color !default;\n\n/// Font size of tab items.\n/// @type Number\n$tab-item-font-size: rem-calc(12) !default;\n\n/// Default background color on hover for items in a Menu.\n$tab-item-background-hover: $white !default;\n\n/// Default padding of a tab item.\n/// @type Number\n$tab-item-padding: 1.25rem 1.5rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$tab-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$tab-content-border: $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$tab-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$tab-content-padding: 1rem !default;\n\n/// Adds styles for a tab container. Apply this to a `<ul>`.\n@mixin tabs-container (\n  $margin: $tab-margin,\n  $background: $tab-background,\n  $border-color: $tab-content-border\n) {\n  @include clearfix;\n  margin: $margin;\n  border: 1px solid $border-color;\n  background: $background;\n  list-style-type: none;\n}\n\n/// Augments a tab container to have vertical tabs. Use this in conjunction with `tabs-container()`.\n@mixin tabs-container-vertical {\n  > li {\n    display: block;\n    float: none;\n    width: auto;\n  }\n}\n\n/// Adds styles for the links within a tab container. Apply this to the `<li>` elements inside a tab container.\n@mixin tabs-title (\n  $padding: $tab-item-padding,\n  $font-size: $tab-item-font-size,\n  $color: $tab-color,\n  $color-active: $tab-active-color,\n  $background-hover: $tab-item-background-hover,\n  $background-active: $tab-background-active\n) {\n  float: #{$global-left};\n\n  > a {\n    @include disable-mouse-outline;\n    display: block;\n    padding: $padding;\n    font-size: $font-size;\n    line-height: 1;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n      color: scale-color($color, $lightness: -14%);\n    }\n\n    &:focus,\n    &[aria-selected='true'] {\n      background: $background-active;\n      color: $color-active;\n    }\n  }\n}\n\n/// Adds styles for the wrapper that surrounds a tab group's content panes.\n@mixin tabs-content (\n  $background: $tab-content-background,\n  $color: $tab-content-color,\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-top: 0;\n  background: $background;\n  color: $color;\n  transition: all 0.5s ease;\n}\n\n/// Augments a tab content container to have a vertical style, by shifting the border around. Use this in conjunction with `tabs-content()`.\n@mixin tabs-content-vertical (\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-#{$global-left}: 0;\n}\n\n/// Adds styles for an individual tab content panel within the tab content container.\n@mixin tabs-panel (\n  $padding: $tab-content-padding\n) {\n  display: none;\n  padding: $padding;\n\n  &.is-active {\n    display: block;\n  }\n}\n\n@mixin foundation-tabs {\n  .tabs {\n    @include tabs-container;\n  }\n\n  // Vertical\n  .tabs.vertical {\n    @include tabs-container-vertical;\n  }\n\n  // Simple\n  .tabs.simple {\n    > li > a {\n      padding: 0;\n\n      &:hover {\n        background: transparent;\n      }\n    }\n  }\n\n  // Primary color\n  .tabs.primary {\n    background: $primary-color;\n\n    > li > a {\n      color: color-pick-contrast($primary-color);\n\n      &:hover,\n      &:focus {\n        background: smart-scale($primary-color);\n      }\n    }\n  }\n\n  .tabs-title {\n    @include tabs-title;\n  }\n\n  .tabs-content {\n    @include tabs-content;\n  }\n\n  .tabs-content.vertical {\n    @include tabs-content-vertical;\n  }\n\n  .tabs-panel {\n    @include tabs-panel;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group thumbnail\n////\n\n/// Border around thumbnail images.\n/// @type Border\n$thumbnail-border: 4px solid $white !default;\n\n/// Bottom margin for thumbnail images.\n/// @type Length\n$thumbnail-margin-bottom: $global-margin !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2) !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5) !default;\n\n/// Transition proprties for thumbnail images.\n/// @type Transition\n$thumbnail-transition: box-shadow 200ms ease-out !default;\n\n/// Default radius for thumbnail images.\n/// @type Number\n$thumbnail-radius: $global-radius !default;\n\n/// Adds thumbnail styles to an element.\n@mixin thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: $thumbnail-margin-bottom;\n\n  border: $thumbnail-border;\n  border-radius: $thumbnail-radius;\n  box-shadow: $thumbnail-shadow;\n\n  line-height: 0;\n}\n\n@mixin thumbnail-link {\n  transition: $thumbnail-transition;\n\n  &:hover,\n  &:focus {\n    box-shadow: $thumbnail-shadow-hover;\n  }\n\n  image {\n    box-shadow: none;\n  }\n}\n\n@mixin foundation-thumbnail {\n  .thumbnail {\n    @include thumbnail;\n  }\n\n  a.thumbnail {\n    @include thumbnail-link;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group menu\n////\n\n/// Margin of a menu.\n/// @type Number\n$menu-margin: 0 !default;\n\n/// Left-hand margin of a nested menu.\n/// @type Number\n$menu-nested-margin: $global-menu-nested-margin !default;\n\n/// Padding for items in a pill menu.\n/// @type Number\n$menu-items-padding: $global-menu-padding !default;\n\n/// margin for items in a simple menu.\n/// @type Number\n$menu-simple-margin: 1rem !default;\n\n/// Text color of an active menu item.\n/// @type Color\n$menu-item-color-active: $white !default;\n\n/// Alternative text color of an active menu item..\n/// @type Color\n$menu-item-color-alt-active: $black !default;\n\n/// Background color of an active menu item.\n/// @type Color\n$menu-item-background-active: get-color(primary) !default;\n\n/// Spacing between an icon and text in a menu item.\n/// @type Number\n$menu-icon-spacing: 0.25rem !default;\n\n/// Backward compatibility for menu state. If true, this duplicate `active` with `is-active`. \n/// But please note that `active` will be removed in upcoming versions.\n/// @type Boolean\n$menu-state-back-compat: true !default;\n\n/// Backward compatibility for menu centered. If true, this duplicate `.menu-centered > .menu` with `.menu.align-center`. \n/// But please note that `menu-centered` will be removed in upcoming versions.\n/// @type Boolean\n$menu-centered-back-compat: true !default;\n\n/// Backward compatibility for using `icon-*` classes without `.icons` classes\n/// But please note that this backward compatibility will be removed in upcoming versions.\n/// @type Boolean\n$menu-icons-back-compat: true !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n  }\n\n  li {\n    @include disable-mouse-outline;\n  }\n\n  a,\n  .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: $menu-items-padding;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\n  }\n\n  input {\n    display: inline-block;\n  }\n}\n\n/// Expands the items of a Menu, so each item is the same width.\n@mixin menu-expand {\n  @if $global-flexbox {\n    li {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    display: table;\n    width: 100%;\n\n    > li {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n}\n\n/// Align menu items.\n@mixin menu-align($alignment) {\n  @if $alignment == left {\n    @if $global-flexbox {\n      justify-content: flex-start;\n    }\n    @else {\n      text-align: $global-left;\n    }\n  }\n  @else if $alignment == right {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: flex-end;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n\n      &.vertical li {\n        display: block;\n        text-align: $global-right;\n\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n    @else {\n      text-align: $global-right;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n\n      &.vertical {\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n  }\n  @else if $alignment == center {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: center;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n    }\n    @else {\n      text-align: center;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n    }\n  }\n}\n\n/// Sets the direction of a Menu.\n/// @param {Keyword} $dir [horizontal] - Direction of the Menu. Can be `horizontal` or `vertical`.\n@mixin menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n      flex-direction: row;\n    }\n    @else {\n      li {\n        display: inline-block;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: nowrap;\n      flex-direction: column;\n    }\n    @else {\n      li {\n        display: block;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for menu-direction() must be horizontal or vertical.';\n  }\n}\n\n/// Creates a simple Menu, which has no padding or hover state.\n/// @param {Keyword} $dir [$global-left] - Direction of the menu. This effects the side of the `<li>` that receives the margin.\n/// @param {Number} $margin [$menu-simple-margin] - The margin to apply to each `<li>`.\n@mixin menu-simple($dir: $global-left, $margin: $menu-simple-margin) {\n  @if $global-flexbox {\n    align-items: center;\n  }\n\n  li + li {\n    margin-#{$dir}: $margin;\n  }\n\n  a {\n    padding: 0;\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $margin [$menu-nested-margin] - Length of the margin.\n/// @param {Keyword} $nested-alignment [left] - Alignment of the nested class\n@mixin menu-nested(\n  $margin: $menu-nested-margin,\n  $nested-alignment: left\n) {\n  @if $nested-alignment == right {\n    margin-#{$global-right}: $margin;\n    margin-#{$global-left}: 0;\n  }\n  @else {\n    margin-#{$global-right}: 0;\n    margin-#{$global-left}: $margin;\n  }\n\n}\n\n/// Adds basic styles for icons in menus.\n@mixin menu-icons() {\n  @if $global-flexbox {\n    a {\n      display: flex;\n    }\n  }\n  @else {\n    img,\n    i,\n    svg {\n      vertical-align: middle;\n\n      + span {\n        vertical-align: middle;\n      }\n    }\n  }\n}\n\n/// Adds position classes for icons within a menu.\n@mixin menu-icon-position($position: left, $spacing: $menu-icon-spacing) {\n  @if $position == left {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-left}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: 0 auto $spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: $spacing auto 0;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding: $global-menu-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin menu-state-active {\n  background: $menu-item-background-active;\n  color: color-pick-contrast($menu-item-background-active, ($menu-item-color-active, $menu-item-color-alt-active));\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n    }\n\n    // Breakpoint specific versions\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-simple {\n        @include menu-expand;\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Icon Base Styles\n    &.icons {\n      @include menu-icons;\n    }\n\n    // Backward Compatibility for active state\n    @if $menu-icons-back-compat {\n      &.icon-top,\n      &.icon-right,\n      &.icon-bottom,\n      &.icon-left {\n        @include menu-icons;\n      }\n    }\n\n    // Icon Left\n    &.icon-left {\n      @include menu-icon-position(left);\n    }\n\n    // Icon Right\n    &.icon-right {\n      @include menu-icon-position(right);\n    }\n\n    // Icon Top\n    &.icon-top {\n      @include menu-icon-position(top);\n    }\n\n    // Icon Bottom\n    &.icon-bottom {\n      @include menu-icon-position(bottom);\n    }\n\n    // Active state\n    .is-active > a {\n      @include menu-state-active;\n    }\n    \n    // Backward Compatibility for active state\n    @if $menu-state-back-compat {\n      .active > a {\n        @include menu-state-active;\n      }\n    }\n\n    // Align left\n    &.align-#{$global-left} {\n      @include menu-align(left);\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @include menu-align(right);\n\n      .nested {\n        @include menu-nested($nested-alignment: right);\n      }\n    }\n\n    // Align center\n    &.align-center {\n      @include menu-align(center);\n    }\n\n    .menu-text {\n      @include menu-text;\n    }\n  }\n\n  @if $menu-centered-back-compat {\n    .menu-centered {\n      > .menu {\n        @if $global-flexbox {\n          justify-content: center;\n        }\n        \n        @include menu-align(center);\n      }\n    }\n  }\n\n  // Prevent FOUC when using the Responsive Menu plugin\n  .no-js [data-responsive-menu] ul {\n    display: none;\n  }\n}\n","@mixin foundation-menu-icon {\n  .menu-icon {\n    @include hamburger($color: $titlebar-icon-color, $color-hover: $titlebar-icon-color-hover);\n  }\n\n  .menu-icon.dark {\n    @include hamburger;\n  }\n}\n","////\n/// @group accordion-menu\n////\n\n/// Sets accordion menu padding.\n/// @type Number\n$accordionmenu-padding: $global-menu-padding !default;\n\n/// Sets accordion menu nested margin\n/// @type Number\n$accordionmenu-nested-margin: $global-menu-nested-margin !default;\n\n/// Sets accordion menu submenu padding.\n/// @type Number\n$accordionmenu-submenu-padding: $accordionmenu-padding !default;\n\n/// Sets if accordion menus have the default arrow styles.\n/// @type Boolean\n$accordionmenu-arrows: true !default;\n\n/// Sets accordion menu arrow color if arrow is used.\n/// @type Color\n$accordionmenu-arrow-color: $primary-color !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-item-background: null !default;\n\n/// Sets accordion menu item border.\n/// @type Color\n$accordionmenu-border: null !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-submenu-toggle-background: null !default;\n\n/// Sets accordion menu item padding.\n/// @type List\n$accordion-submenu-toggle-border: $accordionmenu-border !default;\n\n/// Sets accordion menu submenu toggle background width.\n/// @type Number\n$accordionmenu-submenu-toggle-width: 40px !default;\n\n/// Sets accordion menu submenu toggle background height.\n/// @type Number\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width !default;\n\n/// Sets accordion menu arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin zf-accordion-menu-left-right-arrows {\n  .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($accordionmenu-arrow-size, $accordionmenu-arrow-color, down);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * ($accordionmenu-arrow-size / 2);\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-accordion-submenu-parent > a::after {\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-accordion-submenu-parent > a::after {\n    right: auto;\n    left: 1rem;\n  }\n}\n@mixin foundation-accordion-menu {\n\n  .accordion-menu {\n    @if $accordionmenu-border {\n      border-bottom: $accordionmenu-border;\n    }\n\n    li {\n      @if $accordionmenu-border {\n        border-top: $accordionmenu-border;\n        border-right: $accordionmenu-border;\n        border-left: $accordionmenu-border;\n      }\n      width: 100%;\n    }\n\n    a {\n      @if $accordionmenu-item-background {\n        background: $accordionmenu-item-background;\n      }\n      padding: $accordionmenu-padding;\n    }\n\n    .is-accordion-submenu a {\n      padding: $accordionmenu-submenu-padding;\n    }\n\n    .nested.is-accordion-submenu {\n      @include menu-nested($accordionmenu-nested-margin);\n    }\n\n    &.align-#{$global-right} {\n      .nested.is-accordion-submenu {\n        @include menu-nested($accordionmenu-nested-margin, right);\n      }\n    }\n\n    @if $accordionmenu-arrows {\n      @include zf-accordion-menu-left-right-arrows;\n\n      .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n        transform: rotate(180deg);\n        transform-origin: 50% 50%;\n      }\n    }\n  }\n\n  .is-accordion-submenu li {\n    @if $accordionmenu-border {\n      border-right: 0;\n      border-left: 0;\n    }\n  }\n\n  .is-accordion-submenu-parent {\n    position: relative;\n  }\n\n  .has-submenu-toggle > a {\n    margin-#{$global-right}: $accordionmenu-submenu-toggle-width;\n  }\n\n  // Submenu toggle\n  .submenu-toggle {\n    position: absolute;\n    top: 0;\n    #{$global-right}: 0;\n\n    width: $accordionmenu-submenu-toggle-width;\n    height: $accordionmenu-submenu-toggle-height;\n\n    cursor: pointer;\n\n    border-#{$global-left}: $accordion-submenu-toggle-border;\n\n    @if $accordionmenu-submenu-toggle-background {\n      background: $accordionmenu-submenu-toggle-background;\n    }\n\n    // Add the arrow to the toggle\n    &::after {\n      @include css-triangle(6px, $accordionmenu-arrow-color, down);\n\n      top: 0;\n      bottom: 0;\n      margin: auto;\n    }\n  }\n\n  // Rotate the arrow when menu is open\n  .submenu-toggle[aria-expanded='true']::after {\n    transform: scaleY(-1);\n    transform-origin: 50% 50%;\n  }\n\n  .submenu-toggle-text {\n    @include element-invisible;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group drilldown\n////\n\n/// Transition property to use for animating menus.\n/// @type Transition\n$drilldown-transition: transform 0.15s linear !default;\n\n/// Adds arrows to drilldown items with submenus, as well as the back button.\n/// @type Boolean\n$drilldown-arrows: true !default;\n\n/// Sets drilldown menu item padding.\n/// @type Number\n$drilldown-padding: $global-menu-padding !default;\n\n/// Sets drilldown menu nested margin\n/// @type Number\n$drilldown-nested-margin: 0 !default;\n\n/// Background color for drilldown top level items.\n/// @type Color\n$drilldown-background: $white !default;\n\n/// Sets drilldown menu item padding in the submenu.\n/// @type Number\n$drilldown-submenu-padding: $drilldown-padding !default;\n\n/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-submenu-background: $white !default;\n\n/// Sets drilldown arrow color if arrow is used.\n/// @type Color\n$drilldown-arrow-color: $primary-color !default;\n\n/// Sets drilldown arrow size if arrow is used.\n/// @type Length\n$drilldown-arrow-size: 6px !default;\n\n@mixin zf-drilldown-left-right-arrows {\n  .is-drilldown-submenu-parent > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-right);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * $drilldown-arrow-size;\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 1rem;\n  }\n\n}\n\n@mixin foundation-drilldown-menu {\n  // Applied to the Menu container\n  .is-drilldown {\n    position: relative;\n    overflow: hidden;\n\n    li {\n      display: block;\n    }\n\n    &.animate-height {\n      transition: height 0.5s;\n    }\n  }\n\n  // The top level <ul>\n  .drilldown {\n    a {\n      padding: $drilldown-padding;\n      background: $drilldown-background;\n    }\n\n    // Applied to submenu <ul>s\n    .is-drilldown-submenu {\n      position: absolute;\n      top: 0;\n      #{$global-left}: 100%;\n      z-index: -1;\n\n      width: 100%;\n      background: $drilldown-submenu-background;\n      transition: $drilldown-transition;\n\n      &.is-active {\n        z-index: 1;\n        display: block;\n        transform: translateX(if($global-text-direction == ltr, -100%, 100%));\n      }\n\n      &.is-closing {\n        transform: translateX(if($global-text-direction == ltr, 100%, -100%));\n      }\n\n      // Submenu item padding\n      a {\n        padding: $drilldown-submenu-padding;\n      }\n    }\n\n    .nested.is-drilldown-submenu {\n      @include menu-nested($drilldown-nested-margin);\n    }\n\n    .drilldown-submenu-cover-previous {\n      min-height: 100%;\n    }\n\n    @if $drilldown-arrows {\n      @include zf-drilldown-left-right-arrows;\n\n      .js-drilldown-back > a::before {\n        @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n        display: inline-block;\n        vertical-align: middle;\n        margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown-menu\n////\n\n/// Enables arrows for items with dropdown menus.\n/// @type Boolean\n$dropdownmenu-arrows: true !default;\n\n/// Sets dropdown menu arrow color if arrow is used.\n/// @type Color\n$dropdownmenu-arrow-color: $anchor-color !default;\n\n/// Sets dropdown menu arrow size if arrow is used.\n/// @type Length\n$dropdownmenu-arrow-size: 6px !default;\n\n/// Sets dropdown menu arrow padding for aligning the arrow correctly.\n/// @type Length\n$dropdownmenu-arrow-padding: 1.5rem !default;\n\n/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for top level items.\n/// @type Color\n$dropdownmenu-background: null !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-submenu-background: $white !default;\n\n/// Padding for top level items.\n/// @type Number\n$dropdownmenu-padding: $global-menu-padding !default;\n\n/// Sets dropdown menu nested margin\n/// @type Number\n$dropdownmenu-nested-margin: 0 !default;\n\n/// Padding for sub-menu items.\n/// @type Number\n$dropdownmenu-submenu-padding: $dropdownmenu-padding !default;\n\n/// Border for dropdown sub-menus.\n/// @type List\n$dropdownmenu-border: 1px solid $medium-gray !default;\n\n// Border width for dropdown sub-menus.\n// Used to adjust top margin of a sub-menu if a border is used.\n// @type Length\n$dropdownmenu-border-width: nth($dropdownmenu-border, 1);\n\n/// Text color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-color-active: get-color(primary) !default;\n\n/// Background color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-background-active: transparent !default;\n\n@mixin zf-dropdown-left-right-arrows {\n  > a::after {\n    #{$global-right}: 14px;\n  }\n\n  &.opens-left > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 5px;\n  }\n\n  &.opens-right > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n  }\n}\n\n@mixin dropdown-menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    > li.opens-left { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: auto;\n        left: 0;\n      }\n    }\n\n    @if $dropdownmenu-arrows {\n      > li.is-dropdown-submenu-parent > a { // sass-lint:disable-line no-qualifying-elements\n        position: relative;\n        padding-#{$global-right}: $dropdownmenu-arrow-padding;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after { // sass-lint:disable-line no-qualifying-elements\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\n        #{$global-left}: auto;\n        margin-top: -1 * ($dropdownmenu-arrow-size / 2);\n      }\n    }\n  }\n  @else if $dir == vertical {\n    > li {\n      .is-dropdown-submenu {\n        top: 0;\n      }\n\n      &.opens-left {\n        > .is-dropdown-submenu {\n          top: 0;\n          right: 100%;\n          left: auto;\n        }\n      }\n\n      &.opens-right {\n        > .is-dropdown-submenu {\n          right: auto;\n          left: 100%;\n        }\n      }\n\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for dropdown-menu-direction() must be horizontal or vertical.';\n  }\n}\n\n@mixin foundation-dropdown-menu {\n  .dropdown.menu {\n    @include dropdown-menu-direction(horizontal);\n\n    a {\n      @include disable-mouse-outline;\n    }\n\n    // Top-level item\n    > li > a {\n      background: $dropdownmenu-background;\n      padding: $dropdownmenu-padding;\n    }\n\n    // Top-level item active state\n    > li.is-active > a {\n      background: $dropdown-menu-item-background-active;\n      color: $dropdown-menu-item-color-active;\n    }\n\n    .no-js & ul {\n      display: none;\n    }\n\n    .nested.is-dropdown-submenu {\n      @include menu-nested($dropdownmenu-nested-margin);\n    }\n\n    &.vertical {\n      @include dropdown-menu-direction(vertical);\n    }\n\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        @include breakpoint($size) {\n          &.#{$size}-horizontal {\n            @include dropdown-menu-direction(horizontal);\n          }\n\n          &.#{$size}-vertical {\n            @include dropdown-menu-direction(vertical);\n          }\n        }\n      }\n    }\n\n    &.align-right {\n      .is-dropdown-submenu.first-sub {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n\n  .is-dropdown-menu.vertical {\n    width: 100px;\n\n    &.align-right {\n      float: right;\n    }\n  }\n\n  .is-dropdown-submenu-parent {\n    position: relative;\n\n    a::after {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 5px;\n      #{$global-left}: auto;\n      margin-top: -1 * $dropdownmenu-arrow-size;\n    }\n\n    &.opens-inner > .is-dropdown-submenu {\n\n      top: 100%;\n      @if $global-text-direction == 'rtl' {\n        right: auto;\n      }\n      @else {\n        left: auto;\n      }\n    }\n\n    &.opens-left > .is-dropdown-submenu {\n      right: 100%;\n      left: auto;\n    }\n\n    &.opens-right > .is-dropdown-submenu {\n      right: auto;\n      left: 100%;\n    }\n  }\n\n  .is-dropdown-submenu {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 100%;\n    z-index: 1;\n\n    display: none;\n    min-width: $dropdownmenu-min-width;\n\n    border: $dropdownmenu-border;\n    background: $dropdownmenu-submenu-background;\n\n    .dropdown & a {\n      padding: $dropdownmenu-submenu-padding;\n    }\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n\n    @if (type-of($dropdownmenu-border-width) == 'number') {\n      .is-dropdown-submenu {\n        margin-top: (-$dropdownmenu-border-width);\n      }\n    }\n\n    > li {\n      width: 100%;\n    }\n\n    // [TODO] Cut back specificity\n    //&:not(.js-dropdown-nohover) > .is-dropdown-submenu-parent:hover > &, // why is this line needed? Opening is handled by JS and this causes some ugly flickering when the sub is re-positioned automatically...\n    &.js-dropdown-active {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group off-canvas\n////\n\n/// Width map of a left/right off-canvas panel.\n/// @type Map\n$offcanvas-sizes: (\n  small: 250px,\n) !default;\n\n/// Height map of a top/bottom off-canvas panel.\n/// @type Map\n$offcanvas-vertical-sizes: (\n  small: 250px,\n) !default;\n\n/// Background color of an off-canvas panel.\n/// @type Color\n$offcanvas-background: $light-gray !default;\n\n/// Box shadow for the off-canvas overlap panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Inner box shadow size for the off-canvas push panel.\n/// @type Number\n$offcanvas-inner-shadow-size: 20px !default;\n\n/// Inner box shadow color for the off-canvas push panel.\n/// @type Color\n$offcanvas-inner-shadow-color: rgba($black, 0.25) !default;\n\n/// Z-index of an off-canvas content overlay.\n/// @type Number\n$offcanvas-overlay-zindex: 11 !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 12 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 13 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 12 !default;\n\n/// Length of the animation on an off-canvas panel.\n/// @type Number\n$offcanvas-transition-length: 0.5s !default;\n\n/// Timing function of the animation on an off-canvas panel.\n/// @type Keyword\n$offcanvas-transition-timing: ease !default;\n\n/// If `true`, a revealed off-canvas will be fixed-position, and scroll with the screen.\n/// @type Bool\n$offcanvas-fixed-reveal: true !default;\n\n/// Background color for the overlay that appears when an off-canvas panel is open.\n/// @type Color\n$offcanvas-exit-background: rgba($white, 0.25) !default;\n\n/// CSS class used for the main content area. The off-canvas mixins use this to target the page content.\n$maincontent-class: 'off-canvas-content' !default;\n\n/// Adds baseline styles for off-canvas. This CSS is required to make the other pieces work.\n@mixin off-canvas-basics {\n\n  /// Transform deprecated size settings into map & show warning\n  @if variable-exists(offcanvas-size) {\n    $offcanvas-sizes: (small: $offcanvas-size, medium: $offcanvas-size) !global;\n    @warn '$offcanvas-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-sizes instead';\n  }\n  @if variable-exists(offcanvas-vertical-size) {\n    $offcanvas-vertical-sizes: (small: $offcanvas-vertical-size, medium: $offcanvas-vertical-size) !global;\n    @warn '$offcanvas-vertical-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-vertical-sizes instead';\n  }\n\n  // Checks the z-indexes and increase them due to backwards compatibility.\n  // This is necessary because the overlay's z-index is new since v6.4 and may be identical to the user custom settings of the push z-index.\n  @if $offcanvas-push-zindex <= $offcanvas-overlay-zindex { $offcanvas-push-zindex: $offcanvas-overlay-zindex + 1 !global; }\n  @if $offcanvas-overlap-zindex <= $offcanvas-push-zindex { $offcanvas-overlap-zindex: $offcanvas-push-zindex + 1 !global; }\n  @if $offcanvas-reveal-zindex <= $offcanvas-overlay-zindex { $offcanvas-reveal-zindex: $offcanvas-overlay-zindex + 1 !global; }\n\n  // Hides overflow on body when an off-canvas panel is open.\n  .is-off-canvas-open {\n    overflow: hidden;\n  }\n\n  // Off-canvas overlay (generated by JavaScript)\n  .js-off-canvas-overlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: $offcanvas-overlay-zindex;\n\n    width: 100%;\n    height: 100%;\n\n    transition: opacity $offcanvas-transition-length $offcanvas-transition-timing, visibility $offcanvas-transition-length $offcanvas-transition-timing;\n\n    background: $offcanvas-exit-background;\n\n    opacity: 0;\n    visibility: hidden;\n\n    overflow: hidden;\n\n    &.is-visible {\n      opacity: 1;\n      visibility: visible;\n    }\n\n    &.is-closable {\n      cursor: pointer;\n    }\n\n    &.is-overlay-absolute {\n      position: absolute;\n    }\n\n    &.is-overlay-fixed {\n      position: fixed;\n    }\n  }\n}\n\n// Adds basic styles for an off-canvas wrapper.\n@mixin off-canvas-wrapper() {\n  position: relative;\n  overflow: hidden;\n}\n\n/// Adds basic styles for an off-canvas panel.\n@mixin off-canvas-base(\n  $background: $offcanvas-background,\n  $transition: $offcanvas-transition-length $offcanvas-transition-timing,\n  $fixed: true\n) {\n  @include disable-mouse-outline;\n\n  @if $fixed == true {\n    position: fixed;\n  }\n  @else {\n    position: absolute;\n  }\n\n  // Set the off-canvas z-index.\n  z-index: $offcanvas-push-zindex;\n\n  // Increase CSS specificity\n  &.is-transition-push {\n    z-index: $offcanvas-push-zindex;\n  }\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\n\n  // Hide inactive off-canvas within the content that have the same position\n  &.is-closed {\n    visibility: hidden;\n  }\n\n  // Overlap only styles.\n  &.is-transition-overlap {\n    z-index: $offcanvas-overlap-zindex;\n\n    &.is-open {\n      box-shadow: $offcanvas-shadow;\n    }\n  }\n\n  // Sets transform to 0 to show an off-canvas panel.\n  &.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles to position an off-canvas panel to the left/right/top/bottom.\n@mixin off-canvas-position(\n  $position: left,\n  $orientation: horizontal,\n  $sizes: if($orientation == horizontal, $offcanvas-sizes, $offcanvas-vertical-sizes)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX(-$size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY(-$size);\n          }\n        }\n      }\n    }\n  }\n\n  // If $offcanvas-inner-shadow-size is set, add inner box-shadow.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-inner-shadow-size {\n    &.is-transition-push {\n      @if $position == left {\n        @include inner-side-shadow(right, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == right {\n        @include inner-side-shadow(left, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == top {\n        @include inner-side-shadow(bottom, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == bottom {\n        @include inner-side-shadow(top, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n    }\n  }\n\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transform: none;\n  backface-visibility: hidden;\n\n  // Bind to has-transition-X class to prevent transition for transform:none\n  &.has-transition-overlap,\n  &.has-transition-push {\n    transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  }\n\n  // Transform scope until the element is closed (makes sure transitionend gets triggered)\n  &.has-transition-push {\n    transform: translate(0, 0);\n  }\n\n  // Consider element & content, nested in another content\n  .off-canvas.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles that reveal an off-canvas panel.\n@mixin off-canvas-reveal(\n$position: left,\n$zindex: $offcanvas-reveal-zindex,\n$content: $maincontent-class,\n$breakpoint: small\n) {\n  transform: none;\n  z-index: $zindex;\n  transition: none;\n  visibility: visible;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  .close-button {\n    display: none;\n  }\n\n  // Consider revealed element is nested in content\n  .#{$maincontent-class} & {\n    transform: none;\n  }\n\n  @at-root .#{$content}.has-reveal-#{$position} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n\n  // backwards compatibility (prior to v6.4)\n  & ~ .#{$content} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n}\n\n/// Overrides the off-canvas styles\n@mixin in-canvas() {\n  visibility: visible;\n  height: auto;\n  position: static;\n  background: none;\n  width: auto;\n  overflow: visible;\n  transition: none;\n\n  // Increase CSS specificity\n  &.position-left,\n  &.position-right,\n  &.position-top,\n  &.position-bottom {\n    box-shadow: none;\n    transform: none;\n  }\n\n  .close-button {\n    display: none;\n  }\n}\n\n@mixin foundation-off-canvas {\n  @include off-canvas-basics;\n\n  // Off-canvas wrapper\n  .off-canvas-wrapper {\n    @include off-canvas-wrapper;\n  }\n\n  // Off-canvas container\n  .off-canvas {\n    @include off-canvas-base;\n\n    // Force position absolute for nested off-canvas because fixed doesn't work for push transition within the transform scope.\n    @at-root .#{$maincontent-class} & {\n      // NOTE: since overlap transition is currently forced if nested, there's no need to force position absolute until nested push transition is supported.\n      // position: absolute;\n    }\n  }\n\n  // Off-canvas container with absolute position\n  .off-canvas-absolute {\n    @include off-canvas-base($fixed: false);\n  }\n\n  // Off-canvas position classes\n  .position-left    { @include off-canvas-position(left,   horizontal); }\n  .position-right   { @include off-canvas-position(right,  horizontal); }\n  .position-top     { @include off-canvas-position(top,    vertical); }\n  .position-bottom  { @include off-canvas-position(bottom, vertical); }\n\n  .off-canvas-content {\n    @include off-canvas-content;\n  }\n\n  // Reveal off-canvas panel on larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .position-left.reveal-for-#{$name} {\n          @include off-canvas-reveal(left, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(bottom, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n      }\n    }\n  }\n\n  // Move in-canvas for larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .off-canvas.in-canvas-for-#{$name} {\n          @include in-canvas;\n        }\n      }\n    }\n  }\n}\n\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n@mixin foundation-sticky {\n  .sticky-container {\n    position: relative;\n  }\n\n  .sticky {\n    position: relative;\n    z-index: 0;\n    transform: translate3d(0, 0, 0);\n  }\n\n  .sticky.is-stuck {\n    position: fixed;\n    z-index: 5;\n    width: 100%;\n\n    &.is-at-top {\n      top: 0;\n    }\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n\n  .sticky.is-anchored {\n    position: relative;\n    right: auto;\n    left: auto;\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group title-bar\n////\n\n/// Background color of a title bar.\n/// @type Color\n$titlebar-background: $black !default;\n\n/// Color of text inside a title bar.\n/// @type Color\n$titlebar-color: $white !default;\n\n/// Padding inside a title bar.\n/// @type Length\n$titlebar-padding: 0.5rem !default;\n\n/// Font weight of text inside a title bar.\n/// @type Weight\n$titlebar-text-font-weight: bold !default;\n\n/// Color of menu icons inside a title bar.\n/// @type Color\n$titlebar-icon-color: $white !default;\n\n/// Color of menu icons inside a title bar on hover.\n/// @type Color\n$titlebar-icon-color-hover: $medium-gray !default;\n\n/// Spacing between the menu icon and text inside a title bar.\n/// @type Length\n$titlebar-icon-spacing: 0.25rem !default;\n\n@mixin foundation-title-bar {\n  .title-bar {\n    padding: $titlebar-padding;\n    background: $titlebar-background;\n    color: $titlebar-color;\n\n    @if $global-flexbox {\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n    }\n    @else {\n      @include clearfix;\n    }\n\n    .menu-icon {\n      margin-#{$global-left}: $titlebar-icon-spacing;\n      margin-#{$global-right}: $titlebar-icon-spacing;\n    }\n  }\n\n  @if $global-flexbox {\n    .title-bar-left,\n    .title-bar-right {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n\n    .title-bar-right {\n      text-align: right;\n    }\n  }\n  @else {\n    .title-bar-left {\n      float: left;\n    }\n\n    .title-bar-right {\n      float: right;\n      text-align: right;\n    }\n  }\n\n  .title-bar-title {\n    display: inline-block;\n    vertical-align: middle;\n    font-weight: $titlebar-text-font-weight;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group top-bar\n////\n\n/// Padding for the top bar.\n/// @type Number\n$topbar-padding: 0.5rem !default;\n\n/// Background color for the top bar. This color also cascades to menus within the top bar.\n/// @type Color\n$topbar-background: $light-gray !default;\n\n/// Background color submenus within the top bar. Usefull if $topbar-background is transparent.\n/// @type Color\n$topbar-submenu-background: $topbar-background !default;\n\n/// Spacing for the top bar title.\n/// @type Number\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0 !default;\n\n/// Maximum width of `<input>` elements inside the top bar.\n/// @type Number\n$topbar-input-width: 200px !default;\n\n/// Breakpoint at which top bar switches from mobile to desktop view.\n/// @type Breakpoint\n$topbar-unstack-breakpoint: medium !default;\n\n/// Adds styles for a top bar container.\n@mixin top-bar-container {\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    justify-content: space-between;\n    align-items: center;\n  }\n  @else {\n    @include clearfix;\n  }\n\n  padding: $topbar-padding;\n\n  &,\n  ul {\n    background-color: $topbar-background;\n  }\n\n  // Check if $topbar-background is differnt from $topbar-background-submenu\n  @if ($topbar-background != $topbar-submenu-background) {\n    ul ul {\n      background-color: $topbar-submenu-background;\n    }\n  }\n\n  // Restrain width of inputs by default to make them easier to arrange\n  input {\n    max-width: $topbar-input-width;\n    margin-#{$global-right}: 1rem;\n  }\n\n  // The above styles shouldn't apply to input group fields\n  .input-group-field {\n    width: 100%;\n    margin-#{$global-right}: 0;\n  }\n\n  input.button { // sass-lint:disable-line no-qualifying-elements\n    width: auto;\n  }\n}\n\n/// Makes sections of a top bar stack on top of each other.\n@mixin top-bar-stacked {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 100%;\n      max-width: 100%;\n    }\n  }\n  @else {\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      width: 100%;\n    }\n  }\n}\n\n/// Undoes the CSS applied by the `top-bar-stacked()` mixin.\n@mixin top-bar-unstack {\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n\n    .top-bar-left {\n      flex: 1 1 auto;\n      margin-right: auto;\n    }\n\n    .top-bar-right {\n      flex: 0 1 auto;\n      margin-left: auto;\n    }\n  }\n  @else {\n    .top-bar-left,\n    .top-bar-right {\n      width: auto;\n    }\n  }\n}\n\n@mixin foundation-top-bar {\n  // Top bar container\n  .top-bar {\n    @include top-bar-container;\n\n    // Stack on small screens by default\n    @include top-bar-stacked;\n\n    @include breakpoint($topbar-unstack-breakpoint) {\n      @include top-bar-unstack;\n    }\n\n    // Generate classes for stacking on each screen size (defined in $breakpoint-classes)\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        &.stacked-for-#{$size} {\n          @include breakpoint($size down) {\n            @include top-bar-stacked;\n          }\n        }\n      }\n    }\n  }\n\n  // Sub-sections\n  @if $global-flexbox {\n    .top-bar-title {\n      flex: 0 0 auto;\n      margin: $topbar-title-spacing;\n    }\n\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 auto;\n    }\n  }\n  @else {\n    .top-bar-title {\n      display: inline-block;\n      float: left;\n      padding: $topbar-title-spacing;\n\n      .menu-icon {\n        bottom: 2px;\n      }\n    }\n\n    .top-bar-left {\n      float: left;\n    }\n\n    .top-bar-right {\n      float: right;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group float\n////\n\n@mixin foundation-float-classes {\n  .float-left {\n    float: left !important;\n  }\n\n  .float-right {\n    float: right !important;\n  }\n\n  .float-center {\n    display: block;\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .clearfix {\n    @include clearfix;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group Flexbox Utilities\n////\n//\n/// Default value for the count of source ordering`\n/// @type Number\n$flex-source-ordering-count: 6 !default;\n\n/// Quickly disable/enable Responsive breakpoints for Vanilla Flex Helpers.\n/// @type Boolean\n$flexbox-responsive-breakpoints: true !default;\n\n@mixin flex-helpers {\n  .flex-container {\n    @include flex;\n  }\n\n  .flex-child-auto {\n    flex: 1 1 auto;\n  }\n\n  .flex-child-grow {\n    flex: 1 0 auto;\n  }\n\n  .flex-child-shrink {\n    flex: 0 1 auto;\n  }\n\n  @each $dir, $prop in $-zf-flex-direction {\n    .flex-dir-#{$dir} {\n      @include flex-direction($prop);\n    }\n  }\n\n  @if ($flexbox-responsive-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-flex-container {\n            @include flex;\n          }\n\n          .#{$size}-flex-child-auto {\n            flex: 1 1 auto;\n          }\n\n          .#{$size}-flex-child-grow {\n            flex: 1 0 auto;\n          }\n\n          .#{$size}-flex-child-shrink {\n            flex: 0 1 auto;\n          }\n\n          @each $dir, $prop in $-zf-flex-direction {\n            .#{$size}-flex-dir-#{$dir} {\n              @include flex-direction($prop);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in $-zf-flex-justify {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\n    }\n  }\n  \n  // Horizontal alignment Specifically for Vertical Menu\n  @each $hdir, $prop in map-remove($-zf-flex-justify, 'justify', 'spaced') {\n    .align-#{$hdir} {\n      &.vertical {\n        &.menu > li > a {\n          @include flex-align($x: $hdir);\n        }\n      }\n    }\n  }\n\n  // Vertical alignment using align-items and align-self\n  @each $vdir, $prop in $-zf-flex-align {\n    .align-#{$vdir} {\n      @include flex-align($y: $vdir);\n    }\n\n    .align-self-#{$vdir} {\n      @include flex-align-self($y: $vdir);\n    }\n  }\n\n  // Central alignment of content\n  .align-center-middle {\n    @include flex-align($x: center, $y: middle);\n    align-content: center;\n  }\n\n  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $flex-source-ordering-count {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n  }\n\n  // Vanilla Flexbox Helpers\n  @include flex-helpers;\n}\n","@function -zf-flex-justify($text-direction){\n  $-zf-flex-justify: (\n    'left': if($text-direction == rtl, flex-end, flex-start),\n    'right': if($text-direction == rtl, flex-start, flex-end),\n    'center': center,\n    'justify': space-between,\n    'spaced': space-around,\n  );\n\n  @return $-zf-flex-justify;\n}\n\n\n$-zf-flex-align: (\n  'top': flex-start,\n  'bottom': flex-end,\n  'middle': center,\n  'stretch': stretch,\n);\n\n$-zf-flex-direction: (\n  'row': row,\n  'row-reverse': row-reverse,\n  'column': column,\n  'column-reverse': column-reverse,\n);\n\n/// Enables flexbox by adding `display: flex` to the element.\n@mixin flex {\n  display: flex;\n}\n\n/// Horizontally or vertically aligns the items within a flex container.\n///\n/// @param {Keyword} $x [null] - Horizontal alignment to use. Can be `left`, `right`, `center`, `justify`, or `spaced`. Or, set it to `null` (the default) to not set horizontal alignment.\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align($x: null, $y: null) {\n  @if $x {\n    @if map-has-key($-zf-flex-justify, $x) {\n      $x: map-get($-zf-flex-justify, $x);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$x} is not a valid value for horizontal alignment. Use left, right, center, justify, or spaced.';\n    }\n  }\n\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$y} is not a valid value for vertical alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  justify-content: $x;\n  align-items: $y;\n}\n\n/// Vertically align a single column within a flex row. Apply this mixin to a flex column.\n///\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align-self($y: null) {\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-column-align(): #{$y} is not a valid value for alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  align-self: $y;\n}\n\n/// Changes the source order of a flex child. Children with lower numbers appear first in the layout.\n/// @param {Number} $order [0] - Order number to apply.\n@mixin flex-order($order: 0) {\n  order: $order;\n}\n\n/// Change flex-direction\n/// @param {Keyword} $direction [row] - Flex direction to use. Can be\n///   - row (default): same as text direction\n///   - row-reverse: opposite to text direction\n///   - column: same as row but top to bottom\n///   - column-reverse: same as row-reverse top to bottom\n@mixin flex-direction($direction: row) {\n  flex-direction: $direction;\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n/// Hide an element by default, only displaying it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for($size) {\n  $size: map-get($breakpoints, $size);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/foundation/foundation-sites/issues/11313\n  $size: -zf-bp-to-em($size) - .00125;\n\n  @include breakpoint($size down) {\n    display: none !important;\n  }\n}\n\n/// Hide an element by default, only displaying it within a certain breakpoint.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for-only($size) {\n  $lower-bound-size: map-get($breakpoints, $size);\n  $upper-bound-size: -zf-map-next($breakpoints, $size);\n\n  // more often than not this will be correct, just one time round the loop it won't so set in scope here\n  $lower-bound: -zf-bp-to-em($lower-bound-size) - .00125;\n  // test actual lower-bound-size, if 0 set it to 0em\n  @if strip-unit($lower-bound-size) == 0 {\n    $lower-bound: -zf-bp-to-em($lower-bound-size);\n  }\n\n  @if $upper-bound-size == null {\n    @media screen and (max-width: $lower-bound) {\n      display: none !important;\n    }\n  }\n  @else {\n    $upper-bound: -zf-bp-to-em($upper-bound-size);\n\n    @media screen and (max-width: $lower-bound), screen and (min-width: $upper-bound) {\n      display: none !important;\n    }\n  }\n}\n\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for($size) {\n  @include breakpoint($size) {\n    display: none !important;\n  }\n}\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for-only($size) {\n  @include breakpoint($size only) {\n    display: none !important;\n  }\n}\n\n@mixin foundation-visibility-classes {\n  // Basic hiding classes\n  .hide {\n    display: none !important;\n  }\n\n  .invisible {\n    visibility: hidden;\n  }\n\n  // Responsive visibility classes\n  @each $size in $breakpoint-classes {\n    @if $size != $-zf-zero-breakpoint {\n      .hide-for-#{$size} {\n        @include hide-for($size);\n      }\n\n      .show-for-#{$size} {\n        @include show-for($size);\n      }\n    }\n\n    .hide-for-#{$size}-only {\n      @include hide-for-only($size);\n    }\n\n    .show-for-#{$size}-only {\n      @include show-for-only($size);\n    }\n  }\n\n  // Screen reader visibility classes\n  // Need a \"hide-for-sr\" class? Add aria-hidden='true' to the element\n  .show-for-sr,\n  .show-on-focus {\n    @include element-invisible;\n  }\n\n  // Only display the element when it's focused\n  .show-on-focus {\n    &:active,\n    &:focus {\n      @include element-invisible-off;\n    }\n  }\n\n  // Landscape and portrait visibility\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n\n    @include breakpoint(landscape) {\n      display: block !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: none !important;\n    }\n  }\n\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n\n    @include breakpoint(landscape) {\n      display: none !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: block !important;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-utilities\n////\n\n/// Responsive breakpoints for text utilities\n/// @type Boolean\n$prototype-utilities-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default Value for `text-overflow` variable\n/// @type String\n$prototype-text-overflow: ellipsis !default;\n\n/// Image Replacement utility. `text-hide`\n@mixin text-hide {\n  font: 0/0 a !important;\n  color: transparent !important;\n  text-shadow: none !important;\n  background-color: transparent !important;\n  border: 0 !important;\n}\n\n/// Truncating the text, elipsis by default.\n/// @param {String} $overflow [$prototype-text-overflow] Text Truncate\n@mixin text-truncate(\n  $overflow: $prototype-text-overflow\n) {\n  max-width: 100% !important;\n  overflow: hidden !important;\n  text-overflow: $overflow; \n  white-space: nowrap !important;\n}\n\n/// No wrapping of the text. `text-nowrap`\n@mixin text-nowrap {\n  white-space: nowrap !important;\n}\n\n/// Wrapping of the text. `text-wrap`\n@mixin text-wrap {\n  word-wrap: break-word !important;\n}\n\n@mixin foundation-prototype-text-utilities {\n  .text-hide {\n    @include text-hide;\n  }\n\n  .text-truncate {\n    @include text-truncate;\n  }\n\n  .text-nowrap {\n    @include text-nowrap;\n  }\n\n  .text-wrap {\n    @include text-wrap;\n  }\n\n  @if ($prototype-utilities-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-hide {\n            @include text-hide;\n          }\n\n          .#{$size}-text-truncate {\n            @include text-truncate;\n          }\n\n          .#{$size}-text-nowrap {\n            @include text-nowrap;\n          }\n\n          .#{$size}-text-wrap {\n            @include text-wrap;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-transformation\n////\n\n/// Responsive breakpoints for text transformation classes\n/// @type Boolean\n$prototype-transformation-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `text-transformation` classes\n/// @type Map\n$prototype-text-transformation: (\n  lowercase,\n  uppercase,\n  capitalize\n) !default;\n\n/// Text Transformation, by default coming through a map `$prototype-text-transformation`\n/// @param {String} $transformation [] Text Transformation\n@mixin text-transform($transformation) {\n  text-transform: $transformation !important;\n}\n\n@mixin foundation-prototype-text-transformation {\n  @each $transformation in $prototype-text-transformation {\n    .text-#{$transformation} {\n      @include text-transform($transformation);\n    }\n  }\n\n  @if ($prototype-transformation-breakpoints) {\n    // Loop through Responsive Breakpoints\n  \t@each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $transformation in $prototype-text-transformation {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-text-#{$transformation} {\n  \t\t\t      @include text-transform($transformation);\n  \t\t\t    }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-decoration\n////\n\n/// Responsive breakpoints for text decoration classes\n/// @type Boolean\n$prototype-decoration-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `text-decoration` classes\n/// @type Map\n$prototype-text-decoration: (\n  overline,\n  underline,\n  line-through,\n) !default;\n\n/// Text Decoration, by default coming through a map `$prototype-text-decoration`\n/// @param {String} $decoration [] Text Decoration\n@mixin text-decoration($decoration) {\n  text-decoration: $decoration !important;\n}\n\n@mixin foundation-prototype-text-decoration {\n  @each $decoration in $prototype-text-decoration {\n    .text-#{$decoration} {\n      @include text-decoration($decoration);\n    }\n  }\n\n  @if ($prototype-decoration-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $decoration in $prototype-text-decoration {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-text-#{$decoration} {\n              @include text-decoration($decoration);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-font-styling\n////\n\n/// Responsive breakpoints for font styling types\n/// @type Boolean\n$prototype-font-breakpoints: $global-prototype-breakpoints !default;\n\n/// Letter spacing for `.font-wide`\n/// @type Number\n$prototype-wide-letter-spacing: rem-calc(4) !default;\n\n/// Default weight for `.font-normal`, defaulted to `global-weight-normal`\n/// @type Number\n$prototype-font-normal: $global-weight-normal !default;\n\n/// Default weight for `.font-bold`, defaulted to `global-weight-bold`\n/// @type Number\n$prototype-font-bold: $global-weight-bold !default;\n\n/// Font wide letter spacing!\n/// @param {Number} $letter-spacing [$prototype-wide-letter-spacing] Wide letter spacing for the font\n@mixin font-wide(\n  $letter-spacing: $prototype-wide-letter-spacing\n) {\n  letter-spacing: $letter-spacing;\n}\n\n/// Font Weight Normal, default value coming through `global-weight-normal`\n/// @param {Number} $weight [$prototype-font-normal] Weight of the font (normal)\n@mixin font-normal(\n  $weight: $prototype-font-normal\n) {\n  font-weight: $weight;\n}\n\n/// Font Weight Bold, default value coming through `global-weight-bold`\n/// @param {Number} $weight [$prototype-font-bold] Weight of the font (bold)\n@mixin font-bold(\n  $weight: $prototype-font-bold\n) {\n  font-weight: $weight;\n}\n\n/// Font Style Italic\n@mixin font-italic {\n  font-style: italic !important;\n}\n\n@mixin foundation-prototype-font-styling {\n  .font-wide{\n    @include font-wide;\n  }\n\n  .font-normal {\n    @include font-normal;\n  }\n\n  .font-bold {\n    @include font-bold;\n  }\n\n  .font-italic {\n    @include font-italic;\n  }\n\n  @if ($prototype-font-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-font-wide{\n            @include font-wide;\n          }\n\n          .#{$size}-font-normal {\n            @include font-normal;\n          }\n\n          .#{$size}-font-bold {\n            @include font-bold;\n          }\n\n          .#{$size}-font-italic {\n            @include font-italic;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-list-style-type\n////\n\n/// Responsive breakpoints for list styling types\n/// @type Boolean\n$prototype-list-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `style-type-unordered` classes\n/// @type Map\n$prototype-style-type-unordered: (\n  disc,\n  circle,\n  square\n) !default;\n\n/// Map containing all the `style-type-ordered` classes\n/// @type Map\n$prototype-style-type-ordered: (\n  decimal,\n  lower-alpha,\n  lower-latin,\n  lower-roman,\n  upper-alpha,\n  upper-latin,\n  upper-roman\n) !default;\n\n\n/// Style type for unordered Lists, by default coming through a map `$prototype-style-type-unordered`\n/// @param {String} $style-type-unordered [] Style type for unordered Lists\n@mixin style-type-unordered($style-type-unordered) {\n  list-style-type: $style-type-unordered !important;\n}\n\n/// Style type for ordered Lists, by default coming through a map `$prototype-style-type-ordered`\n/// @param {String} $style-type-ordered [] Style type for ordered Lists\n@mixin style-type-ordered($style-type-ordered) {\n  list-style-type: $style-type-ordered !important;\n}\n\n@mixin list-unordered {\n  @each $style-type-unordered in $prototype-style-type-unordered {\n    ul.list-#{$style-type-unordered} {\n      @include style-type-unordered($style-type-unordered);\n    }\n  }\n\n  @if ($prototype-list-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $style-type-unordered in $prototype-style-type-unordered {\n          @if $size != $-zf-zero-breakpoint {\n            ul.#{$size}-list-#{$style-type-unordered} {\n              @include style-type-unordered($style-type-unordered);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin list-ordered {\n  @each $style-type-ordered in $prototype-style-type-ordered {\n    ol.list-#{$style-type-ordered} {\n      @include style-type-ordered($style-type-ordered);\n    }\n  }\n\n  @if ($prototype-list-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $style-type-ordered in $prototype-style-type-ordered {\n          @if $size != $-zf-zero-breakpoint {\n            ol.#{$size}-list-#{$style-type-ordered} {\n              @include style-type-ordered($style-type-ordered);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-prototype-list-style-type {\n  @include list-unordered;\n  @include list-ordered;\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-rounded\n////\n\n/// Responsive breakpoints for rounded utility.\n/// @type Boolean\n$prototype-rounded-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-border-radius`\n/// @type Number\n$prototype-border-radius: rem-calc(3) !default;\n\n/// Rounded utility (all corners): Adds radius corners (all corners) to an element by default.\n/// @param {Number} $radius [$prototype-border-radius] Border radius (all corners)\n@mixin border-radius(\n  $radius: $prototype-border-radius\n) {\n  border-radius: $radius;\n}\n\n/// Rounded square utility or rectangle utility (all corners): Rounds all corners to an element by default to make a pill shape.\n@mixin border-rounded {\n  border-radius: 5000px !important;\n}\n\n@mixin foundation-prototype-rounded {\n  .rounded {\n    @include border-rounded;\n\n    .switch-paddle {\n      @include border-rounded;\n      &:after {\n        border-radius: 50%; // For switches\n      }\n    }\n  }\n\n  .radius {\n    @include border-radius;\n  }\n\n  @if ($prototype-rounded-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-rounded {\n            @include border-rounded;\n          }\n          .#{$size}-radius {\n            @include border-radius;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-bordered\n////\n\n/// Responsive breakpoints for bordered utility.\n/// @type Boolean\n$prototype-bordered-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-border-width`\n/// @type Number\n$prototype-border-width: rem-calc(1) !default;\n\n/// Default value for `prototype-border-type`\n/// @type String\n$prototype-border-type: solid !default;\n\n/// Default value for `prototype-border-color` defaulted to `medium-gray`\n/// @type Color\n$prototype-border-color: $medium-gray !default;\n\n/// Bordered Utility: Adds a light border to an element by default.\n/// @param {Number} $width [$prototype-border-width] Width of the border\n/// @param {String} $type [$prototype-border-type] Type of the border\n/// @param {Color} $color [$prototype-border-color] Color of the border\n@mixin bordered(\n  $width: $prototype-border-width,\n  $type: $prototype-border-type,\n  $color: $prototype-border-color\n) {\n  border: $width $type $color;\n}\n\n@mixin foundation-prototype-bordered {\n  .bordered {\n    @include bordered;\n  }\n\n  @if ($prototype-bordered-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-bordered {\n            @include bordered;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-shadow\n////\n\n/// Responsive breakpoints for shadow utility.\n/// @type Boolean\n$prototype-shadow-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-box-shadow`\n/// @type Number\n$prototype-box-shadow: 0 2px 5px 0 rgba(0,0,0,.16),\n                       0 2px 10px 0 rgba(0,0,0,.12) !default;\n\n/// Shadow Utility: Adds a light box shadow to an element by default.\n/// @param {Number} $shadow [$prototype-box-shadow] Box Shadow of a component\n@mixin shadow(\n  $shadow: $prototype-box-shadow\n) {\n  box-shadow: $shadow;\n}\n\n@mixin foundation-prototype-shadow {\n  .shadow {\n    @include shadow;\n  }\n\n  @if ($prototype-shadow-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-shadow {\n            @include shadow;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-arrow\n////\n\n/// Map containing all the `arrow` direction\n/// @type Map\n$prototype-arrow-directions: (\n  down,\n  up,\n  right,\n  left\n) !default;\n\n/// Width of the Arrow, `0.4375rem` by default.\n/// @type Number\n$prototype-arrow-size: 0.4375rem;\n\n/// Color of the Arrow, `$black` by default.\n/// @type Color\n$prototype-arrow-color: $black;\n\n@mixin foundation-prototype-arrow {\n  @each $prototype-arrow-direction in $prototype-arrow-directions {\n    .arrow-#{$prototype-arrow-direction} {\n      @include css-triangle(\n        $prototype-arrow-size, \n        $prototype-arrow-color, \n        $prototype-arrow-direction\n      );\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-separator\n////\n\n/// Responsive breakpoints for separator.\n/// @type Boolean\n$prototype-separator-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default alignment of a separator.\n/// @type String\n$prototype-separator-align: center !default;\n\n/// Height of a separator.\n/// @type Number\n$prototype-separator-height: rem-calc(2) !default;\n\n/// Width of a separator.\n/// @type Number\n$prototype-separator-width: 3rem !default;\n\n/// Default color of a separator.\n/// @type Color\n$prototype-separator-background: $primary-color !default;\n\n/// Top Margin of a separator.\n/// @type Number\n$prototype-separator-margin-top: $global-margin !default;\n\n/// Title separator Utility, mostly used to style the main heading of a section\n/// @param {String} $align [$prototype-separator-align] - separator Alignment\n/// @param {Number} $height [$prototype-separator-height] - Width\n/// @param {Number} $width [$prototype-separator-width] - Height\n/// @param {Color} $background [$prototype-separator-background] - Background\n/// @param {Number} $top [$prototype-separator-margin-top] - Margin Top\n@mixin separator (\n  $align: $prototype-separator-align,\n  $height: $prototype-separator-height,\n  $width: $prototype-separator-width,\n  $background: $prototype-separator-background,\n  $top: $prototype-separator-margin-top\n) {\n  text-align: $align !important;\n\t@include clearfix;\n\n  &::after {\n    @include position(relative);\n    width: $width;\n    border-bottom: $height solid $background;\n    margin: $top auto 0;\n\n    @if $align == left {\n      margin-left: 0 !important;\n    }\n\n    @if $align == right {\n      margin-right: 0 !important;\n    }\n  }\n}\n\n@mixin foundation-prototype-separator {\n\t.separator-center {\n\t\t@include separator(center);\n\t}\n\n  .separator-left {\n    @include separator(left);\n  }\n\n  .separator-right {\n    @include separator(right);\n  }\n\n\t@if ($prototype-separator-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-separator-center {\n            @include separator(center);\n          }\n          .#{$size}-separator-left {\n            @include separator(left);\n          }\n          .#{$size}-separator-right {\n            @include separator(right);\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-position\n////\n\n/// Responsive breakpoints for position helpers\n/// @type Boolean\n$prototype-position-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `position` classes\n/// @type Map\n$prototype-position: (\n  static,\n  relative,\n  absolute,\n  fixed\n) !default;\n\n/// z-index for fixed positioning\n/// @type Number\n$prototype-position-z-index: 975 !default;\n\n/// Position classes, by default coming through a map `$prototype-position`, whereas all the offset values are multiplied by `$global-position` which by default is equal to `1rem`.\n/// @param {String} $position [] Position classes, Either `static`, `relative`, `absolute` or `fixed`\n/// @param {Number} $top [null] - Top offset\n/// @param {Number} $right [null] - Right offset\n/// @param {Number} $bottom [null] - Bottom offset\n/// @param {Number} $left [null] - Left offset\n@mixin position(\n  $position,\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  position: $position !important;\n  @if $top != null {\n    top: $top * $global-position !important;\n  }\n  @if $right != null {\n    right: $right * $global-position !important;\n  }\n  @if $bottom != null {\n    bottom: $bottom * $global-position !important;\n  }\n  @if $left != null {\n    left: $left * $global-position !important;\n  }\n}\n\n/// Position Fixed on top corners\n/// @param {Number} $z-index [$prototype-position-z-index] z-index for `position-fixed-top`\n@mixin position-fixed-top(\n  $z-index: $prototype-position-z-index\n) {\n  @include position(fixed, 0, 0, null, 0);\n  z-index: $z-index;\n}\n\n/// Position Fixed on bottom corners\n/// @param {Number} $z-index [$prototype-position-z-index] z-index for `position-fixed-bottom`\n@mixin position-fixed-bottom(\n  $z-index: $prototype-position-z-index\n) {\n  @include position(fixed, null, 0, 0, 0);\n  z-index: $z-index;\n}\n\n@mixin foundation-prototype-position {\n  // Position: Static, Relative, Fixed, Absolute\n  @each $position in $prototype-position {\n    .position-#{$position} {\n      @include position($position);\n    }\n  }\n\n  // Position: Fixed Top, Fixed Bottom\n  .position-fixed-top {\n    @include position-fixed-top;\n  }\n  .position-fixed-bottom {\n    @include position-fixed-bottom;\n  }\n\n  @if ($prototype-position-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        // Position: Static, Relative, Fixed, Absolute\n        @each $position in $prototype-position {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-position-#{$position} {\n              @include position($position);\n            }\n          }\n        }\n\n        // Position: Fixed Top, Fixed Bottom\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-position-fixed-top {\n            @include position-fixed-top;\n          }\n\n          .#{$size}-position-fixed-bottom {\n            @include position-fixed-bottom;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-overflow\n////\n\n/// Responsive breakpoints for overflow helper classes\n/// @type Boolean\n$prototype-overflow-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `overflow` classes\n/// @type Map\n$prototype-overflow: (\n  visible,\n  hidden,\n  scroll\n) !default;\n\n/// Overflow classes, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes\n@mixin overflow($overflow) {\n  overflow: $overflow !important;\n}\n\n/// Overflow classes on horizontal axis, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes (horizontal axis)\n@mixin overflow-x($overflow) {\n  overflow-x: $overflow !important;\n}\n\n/// Overflow classes on vertical axis, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes (vertical axis)\n@mixin overflow-y($overflow) {\n  overflow-y: $overflow !important;\n}\n\n@mixin foundation-prototype-overflow {\n  @each $overflow in $prototype-overflow {\n    .overflow-#{$overflow} {\n      @include overflow($overflow);\n    }\n    .overflow-x-#{$overflow} {\n      @include overflow-x($overflow);\n    }\n    .overflow-y-#{$overflow} {\n      @include overflow-y($overflow);\n    }\n  }\n\n  @if ($prototype-overflow-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $overflow in $prototype-overflow {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-overflow-#{$overflow} {\n              @include overflow($overflow);\n            }\n            .#{$size}-overflow-x-#{$overflow} {\n              @include overflow-x($overflow);\n            }\n            .#{$size}-overflow-y-#{$overflow} {\n              @include overflow-y($overflow);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-display\n////\n\n/// Responsive breakpoints for display classes\n/// @type Boolean\n$prototype-display-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `display` classes\n/// @type Map\n$prototype-display: (\n  inline,\n  inline-block,\n  block,\n  table,\n  table-cell\n) !default;\n\n/// Display classes, by default coming through a map `$prototype-display`\n/// @param {String} $display [] Display classes\n@mixin display($display) {\n  display: $display !important;\n}\n\n@mixin foundation-prototype-display {\n  @each $display in $prototype-display {\n    .display-#{$display} {\n      @include display($display);\n    }\n  }\n\n  @if ($prototype-display-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $display in $prototype-display {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-display-#{$display} {\n              @include display($display);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-border-box\n////\n\n/// Responsive breakpoints for border box.\n/// @type Boolean\n$prototype-border-box-breakpoints: $global-prototype-breakpoints !default;\n\n/// Border box utility\n@mixin border-box {\n  box-sizing: border-box !important;\n}\n\n@mixin foundation-prototype-border-box {\n  .border-box {\n    @include border-box;\n  }\n\n  @if ($prototype-border-box-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-border-box {\n            @include border-box;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-border-none\n////\n\n/// Responsive breakpoints for border none.\n/// @type Boolean\n$prototype-border-none-breakpoints: $global-prototype-breakpoints !default;\n\n/// Border none utility\n@mixin border-none {\n  border: none !important;\n}\n\n@mixin foundation-prototype-border-none {\n  .border-none {\n    @include border-none;\n  }\n\n  @if ($prototype-border-none-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-border-none {\n            @include border-none;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-sizing\n////\n\n/// Responsive breakpoints for spacing classes (margin and padding)\n/// @type Boolean\n$prototype-sizing-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `sizing` classes\n/// @type Map\n$prototype-sizing: (\n  width,\n  height\n) !default;\n\n/// Map containing all the sizes.\n/// @type Map\n$prototype-sizes: (\n  25: 25%,\n  50: 50%,\n  75: 75%,\n  100: 100%\n) !default;\n\n/// Max Width 100 utility.\n@mixin max-width-100 {\n  max-width: 100% !important;\n}\n\n/// Max Height 100 utility.\n@mixin max-height-100 {\n  max-height: 100% !important;\n}\n\n@mixin foundation-prototype-sizing {\n  // Element Sizing\n  @each $sizing in $prototype-sizing {\n    @each $length, $percentage in $prototype-sizes {\n      .#{$sizing}-#{$length} {\n        #{$sizing}: $percentage !important;\n      }\n    }\n  }\n\n  // Max width & height\n  .max-width-100 {\n    @include max-width-100;\n  }\n  .max-height-100 {\n    @include max-height-100;\n  }\n\n  @if ($prototype-sizing-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          @each $sizing in $prototype-sizing {\n            @each $length, $percentage in $prototype-sizes {\n              .#{$size}-#{$sizing}-#{$length} {\n                #{$sizing}: $percentage !important;\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-spacing\n////\n\n/// Responsive breakpoints for spacing classes (margin and padding)\n/// @type Boolean\n$prototype-spacing-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default number of spacers count (margin and padding)\n/// @type Number\n$prototype-spacers-count: 3 !default;\n\n/// Margin helper mixin, all the values are multiplied by `$global-margin` which by default is equal to `1rem`\n/// @param {Number} $top [null] - Margin Top\n/// @param {Number} $right [null] - Margin Right\n/// @param {Number} $bottom [null] - Margin Bottom\n/// @param {Number} $left [null] - Margin Left\n@mixin margin(\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  @if $top != null {\n    margin-top: $top * $global-margin !important;\n  }\n  @if $right != null {\n    margin-right: $right * $global-margin !important;\n  }\n  @if $bottom != null {\n    margin-bottom: $bottom * $global-margin !important;\n  }\n  @if $left != null {\n    margin-left: $left * $global-margin !important;\n  }\n}\n\n/// Padding helper mixin, all the values are multiplied by `$global-padding` which by default is equal to `1rem`\n/// @param {Number} $top [null] - Padding Top\n/// @param {Number} $right [null] - Padding Right\n/// @param {Number} $bottom [null] - Padding Bottom\n/// @param {Number} $left [null] - Padding Left\n@mixin padding(\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  @if $top != null {\n    padding-top: $top * $global-padding !important;\n  }\n  @if $right != null {\n    padding-right: $right * $global-padding !important;\n  }\n  @if $bottom != null {\n    padding-bottom: $bottom * $global-padding !important;\n  }\n  @if $left != null {\n    padding-left: $left * $global-padding !important;\n  }\n}\n\n/// Margin classes for specific direction properties\n/// @param {String} $dir [] Direction\n/// @param {Number} $spacer [] Spacer\n@mixin margin-direction($dir, $spacer) {\n  @if ($dir == top) { \n    @include margin($top: $spacer); \n  }\n  @else if ($dir == right) { \n    @include margin($right: $spacer); \n  }\n  @else if ($dir == bottom) { \n    @include margin($bottom: $spacer); \n  }\n  @else if ($dir == left) { \n    @include margin($left: $spacer); \n  }\n  @else if ($dir == horizontal) { \n    @include margin($right: $spacer, $left: $spacer); \n  }\n  @else if ($dir == vertical) { \n    @include margin($top: $spacer, $bottom: $spacer); \n  }\n}\n\n/// Padding classes for specific direction properties\n/// @param {String} $dir [] Direction\n/// @param {Number} $spacer [] Spacer\n@mixin padding-direction($dir, $spacer) {\n  @if ($dir == top) { \n    @include padding($top: $spacer); \n  }\n  @else if ($dir == right) { \n    @include padding($right: $spacer); \n  }\n  @else if ($dir == bottom) { \n    @include padding($bottom: $spacer); \n  }\n  @else if ($dir == left) { \n    @include padding($left: $spacer); \n  }\n  @else if ($dir == horizontal) { \n    @include padding($right: $spacer, $left: $spacer); \n  }\n  @else if ($dir == vertical) { \n    @include padding($top: $spacer, $bottom: $spacer); \n  }\n}\n\n@mixin foundation-prototype-spacing {\n  @for $spacer from 0 through $prototype-spacers-count {\n    \n    @each $prop in (margin, padding) {\n      // All Sides\n      .#{$prop}-#{$spacer} {\n        @if ($prop == margin) { \n          margin: $spacer * $global-margin !important;\n        }\n        @else if ($prop == padding) { \n          padding: $spacer * $global-padding !important;\n        }\n      }\n\n      @each $dir in (top, right, bottom, left, horizontal, vertical) {\n        // Top Side\n        .#{$prop}-#{$dir}-#{$spacer} {\n          @if ($prop == margin) { \n            @include margin-direction($dir, $spacer);\n          }\n          @else if ($prop == padding) {\n            @include padding-direction($dir, $spacer);\n          }\n        }\n      }\n    }\n  }\n\n  @if ($prototype-spacing-breakpoints) {\n    @for $spacer from 0 through $prototype-spacers-count {\n    // Loop through Responsive Breakpoints\n      @each $size in $breakpoint-classes {\n        @include breakpoint($size) {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size} {\n              @each $prop in (margin, padding) {\n                // All Sides\n                &-#{$prop}-#{$spacer} {\n                  @if ($prop == margin) { \n                    margin: $spacer * $global-margin !important;\n                  }\n                  @else if ($prop == padding) { \n                    padding: $spacer * $global-padding !important;\n                  }\n                }\n\n                @each $dir in (top, right, bottom, left, horizontal, vertical) {\n                  // Top Side\n                  &-#{$prop}-#{$dir}-#{$spacer} {\n                    @if ($prop == margin) { \n                      @include margin-direction($dir, $spacer);\n                    }\n                    @else if ($prop == padding) { \n                      @include padding-direction($dir, $spacer);\n                    }\n                  }\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","/// Applies basic transition settings to an element.\n/// @param {Duration} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin transition-basics(\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  @include -motion-ui-defaults;\n  transition-duration: $duration;\n  transition-timing-function: $timing;\n  transition-delay: $delay;\n}\n\n/// Wraps the content in the setup class for a transition.\n/// @param {Keyword} $dir - State to setup for transition.\n@mixin transition-start($dir) {\n  $selector: -mui-build-selector(map-get($motion-ui-states, $dir));\n\n  @at-root {\n    #{$selector} {\n      @content;\n    }\n  }\n}\n\n/// Wraps the content in the active class for a transition.\n/// @param {Keyword} $dir - State to activate a transition on.\n@mixin transition-end($dir) {\n  $selector: -mui-build-selector(map-get($motion-ui-states, $dir), true);\n\n  @at-root {\n    #{$selector} {\n      @content;\n    }\n  }\n}\n\n/// Adds styles for a stagger animation, which can be used with Angular's `ng-repeat`.\n/// @param {Duration} $delay-amount - Amount of time in seconds or milliseconds to add between each item's animation.\n@mixin stagger($delay-amount) {\n  transition-delay: $delay-amount;\n  transition-duration: 0; // Prevent accidental CSS inheritance\n}\n","// scss-lint:disable ImportantRule, SpaceAfterComma, SingleLinePerProperty\n\n@mixin -motion-ui-defaults {\n  transition-duration: map-get($motion-ui-speeds, default);\n  transition-timing-function: map-get($motion-ui-easings, default);\n}\n\n// Transitions\n// - - - - - - - - - - - - - - -\n@mixin motion-ui-transitions {\n  // Slide\n  .slide-in-down    { @include mui-slide(in,  down); }\n  .slide-in-left    { @include mui-slide(in,  right); }\n  .slide-in-up      { @include mui-slide(in,  up); }\n  .slide-in-right   { @include mui-slide(in,  left); }\n  .slide-out-down   { @include mui-slide(out, down); }\n  .slide-out-right  { @include mui-slide(out, right); }\n  .slide-out-up     { @include mui-slide(out, up); }\n  .slide-out-left   { @include mui-slide(out, left); }\n\n  // Fade\n  .fade-in  { @include mui-fade(in,  0, 1); }\n  .fade-out { @include mui-fade(out, 1, 0); }\n\n  // Hinge\n  .hinge-in-from-top      { @include mui-hinge(in,  top); }\n  .hinge-in-from-right    { @include mui-hinge(in,  right); }\n  .hinge-in-from-bottom   { @include mui-hinge(in,  bottom); }\n  .hinge-in-from-left     { @include mui-hinge(in,  left); }\n  .hinge-in-from-middle-x  { @include mui-hinge(in,  top,   center); }\n  .hinge-in-from-middle-y  { @include mui-hinge(in,  right, center); }\n  .hinge-out-from-top     { @include mui-hinge(out, top); }\n  .hinge-out-from-right   { @include mui-hinge(out, right); }\n  .hinge-out-from-bottom  { @include mui-hinge(out, bottom); }\n  .hinge-out-from-left    { @include mui-hinge(out, left); }\n  .hinge-out-from-middle-x { @include mui-hinge(out, top,   center); }\n  .hinge-out-from-middle-y { @include mui-hinge(out, right, center); }\n\n  // Scale\n  .scale-in-up    { @include mui-zoom(in,  0.5, 1); }\n  .scale-in-down  { @include mui-zoom(in,  1.5, 1); }\n  .scale-out-up   { @include mui-zoom(out, 1, 1.5); }\n  .scale-out-down { @include mui-zoom(out, 1, 0.5); }\n\n  // Spin\n  .spin-in     { @include mui-spin(in,  cw); }\n  .spin-out    { @include mui-spin(out, cw); }\n  .spin-in-ccw  { @include mui-spin(in,  ccw); }\n  .spin-out-ccw { @include mui-spin(out, ccw); }\n\n  // Transition Modifiers\n  // - - - - - - - - - - - - - - -\n\n  @each $name, $value in $motion-ui-speeds {\n    @if $name != default {\n      .#{$name} { transition-duration: $value !important; }\n    }\n  }\n\n  @each $name, $value in $motion-ui-easings {\n    @if $name != default {\n      .#{$name} { transition-timing-function: $value !important; }\n    }\n  }\n\n  @each $name, $value in $motion-ui-delays {\n    @if $name != default {\n      .#{$name}-delay { transition-delay: $value !important; }\n    }\n  }\n}\n\n// Animations\n// - - - - - - - - - - - - - - -\n@mixin motion-ui-animations {\n  .shake    { @include mui-animation(shake); }\n  .spin-cw  { @include mui-animation(spin); }\n  .spin-ccw { @include mui-animation(spin(ccw)); }\n  .wiggle   { @include mui-animation(wiggle); }\n\n  .shake,\n  .spin-cw,\n  .spin-ccw,\n  .wiggle {\n    animation-duration: map-get($motion-ui-speeds, default);\n  }\n\n  // Animation Modifiers\n  // - - - - - - - - - - - - - - -\n  .infinite { animation-iteration-count: infinite; }\n\n  @each $name, $value in $motion-ui-speeds {\n    @if $name != default {\n      .#{$name} { animation-duration: $value !important; }\n    }\n  }\n\n  @each $name, $value in $motion-ui-easings {\n    @if $name != default {\n      .#{$name} { animation-timing-function: $value !important; }\n    }\n  }\n\n  @each $name, $value in $motion-ui-delays {\n    @if $name != default {\n      .#{$name}-delay { animation-delay: $value !important; }\n    }\n  }\n}\n","/// Format for CSS classes created with Motion UI.\n/// @type Map\n/// @prop {Boolean} append [true] - Defines if selectors are chained to the selector (`.class.enter`), or appended as a new class (`.class-enter`).\n/// @prop {String} prefix ['mui-'] - Prefix to add before the state of a class. Enter an empty string to use no prefix.\n/// @prop {String} prefix ['-active'] - Suffix to add to the active state class.\n$motion-ui-classes: (\n  chain: true,\n  prefix: 'mui-',\n  active: '-active',\n) !default;\n\n/// State names to reference when writing motion classes. To use multiple class names for one state, enter a list of strings instead of one string.\n/// @type Map\n$motion-ui-states: (\n  in: 'enter',\n  out: 'leave',\n) !default;\n\n/// Default speed that transitions and animations play at, along with values for modifier classes to change the speed.\n/// @type Map\n$motion-ui-speeds: (\n  default: 500ms,\n  slow: 750ms,\n  fast: 250ms,\n) !default;\n\n/// Default delay to add before motion, along with values for modifier classes to change the delay.\n/// @type Map\n$motion-ui-delays: (\n  default: 0,\n  short: 300ms,\n  long: 700ms,\n) !default;\n\n/// Default easing for transitions and animations, along with values for modifier classes to change the easing.\n/// @type Map\n$motion-ui-easings: (\n  default: linear,\n  linear: linear,\n  ease: ease,\n  ease-in: ease-in,\n  ease-out: ease-out,\n  ease-in-out: ease-in-out,\n  bounce-in: cubic-bezier(0.485, 0.155, 0.24, 1.245),\n  bounce-out: cubic-bezier(0.485, 0.155, 0.515, 0.845),\n  bounce-in-out: cubic-bezier(0.76, -0.245, 0.24, 1.245),\n) !default;\n\n/// Miscellaneous settings related to Motion UI.\n/// @type Map\n/// @prop {Boolean} slide-and-fade [false] - Defines if slide motions should also fade in/out.\n/// @prop {Boolean} slide-and-fade [true] - Defines if hinge motions should also fade in/out.\n/// @prop {Boolean} slide-and-fade [true] - Defines if scale motions should also fade in/out.\n/// @prop {Boolean} slide-and-fade [true] - Defines if spin motions should also fade in/out.\n$motion-ui-settings: (\n  slide-and-fade: false,\n  hinge-and-fade: true,\n  scale-and-fade: true,\n  spin-and-fade: true,\n  pause-queue-class: 'is-paused',\n  activate-queue-class: 'is-animating',\n) !default;\n","// Internal counter for creating unique keyframe names\n$-mui-custom: 0;\n\n/// Creates a keyframe from one or more effect functions. Use this function instead of `mui-animation` if you want to create a keyframe animation *without* automatically assigning it to the element.\n/// @param {String} $name - Name of the keyframe.\n/// @param {Arglist} $effects... - One or more effect functions to build the keyframe with.\n@mixin mui-keyframes($name, $effects...) {\n  $obj: -mui-process-args($effects...);\n  $obj: map-remove($obj, name);\n\n  @keyframes #{$name} {\n    // Now iterate through each keyframe percentage\n    @each $pct, $props in $obj {\n      #{-mui-keyframe-pct($pct)} {\n        // Lastly, iterate through each CSS property within a percentage and print it out\n        @each $prop, $value in $props {\n          #{$prop}: #{$value};\n        }\n      }\n    }\n  }\n}\n\n/// Creates a string for a CSS keyframe, by converting a list of numbers to a comma-separated list of percentage values.\n/// @param {Number|List} $input - List of numbers to use.\n/// @return {String} A set of comma-separated percentage values.\n/// @access private\n@function -mui-keyframe-pct($input) {\n  $output: ();\n\n  @if type-of($input) == 'number' {\n    $output: ($input * 1%);\n  } @else if type-of($input) == 'list' {\n    @each $i in $input {\n      $output: append($output, ($i * 1%), comma);\n    }\n  }\n\n  @return \"#{$output}\";\n}\n\n/// Prints the CSS properties from a specific key in a keyframes map. Used to borrow CSS from keyframe functions for use in transitions.\n/// @param {Map} $kf - Keyframe map to extract from.\n/// @param {Number} $key - Key in the map to print the CSS of.\n/// @access private\n@mixin -mui-keyframe-get($kf, $key) {\n  $map: map-get($kf, $key);\n\n  @each $prop, $value in $map or () {\n    // Some keyframe maps store transforms as quoted strings\n    @if type-of($value) == 'string' {\n      $value: unquote($value);\n    }\n    #{$prop}: $value;\n  }\n}\n\n/// Reformats a map containing keys with a list of values, so that each key is a single value.\n/// @param {Map} $map - Map to split up.\n/// @return {Map} A reformatted map.\n/// @access private\n@function -mui-keyframe-split($map) {\n  $new-map: ();\n\n  // Split keys with multiple values into individual keys\n  @each $key, $item in $map {\n    $key-type: type-of($key);\n\n    @if $key-type == 'number' {\n      $new-map: map-merge($new-map, ($key: $item));\n    } @else if $key-type == 'list' {\n      @each $k in $key {\n        $new-map: map-merge($new-map, ($k: $item));\n      }\n    }\n  }\n\n  @return $new-map;\n}\n\n/// Combines a series of keyframe objects into one.\n/// @param {Arglist} $maps... - A series of maps to merge, as individual parameters.\n/// @return {Map} A combined keyframe object.\n/// @access private\n@function -mui-keyframe-combine($maps...) {\n  $new-map: ();\n\n  // Iterate through each map passed in\n  @each $map in $maps {\n    @if -mui-is-function($map) {\n      $map: -mui-safe-call($map);\n    }\n\n    $map: -mui-keyframe-split($map);\n\n    // Iterate through each keyframe in the map\n    // $key is the keyframe percentage\n    // $value is a map of CSS properties\n    @each $key, $value in $map {\n      $new-value: ();\n\n      @if map-has-key($new-map, $key) {\n        // If the map already has the keyframe %, append the new property\n        $new-value: -mui-merge-properties(map-get($new-map, $key), $value);\n      } @else {\n        // Otherwise, create a new map with the new property\n        $new-value: $value;\n      }\n\n      // Finally, merge the modified keyframe value into the output map\n      $new-map: map-merge($new-map, ($key: $new-value));\n    }\n  }\n\n  // Make a name for the keyframes\n  $-mui-custom: $-mui-custom + 1 !global;\n  $map-name: (name: 'custom-#{$-mui-custom}');\n  $new-map: map-merge($new-map, $map-name);\n\n  @return $new-map;\n}\n\n/// Combines two maps of CSS properties into one map. If both maps have a transform property, the values from each will be combined into one property.\n/// @param {Map} $one - First map to merge.\n/// @param {Map} $two - Second map to merge.\n/// @return {Map} A combined map.\n/// @access private\n@function -mui-merge-properties($one, $two) {\n  @if map-has-key($one, transform) and map-has-key($two, transform) {\n    $transform: join(map-get($one, transform), map-get($two, transform));\n    $one: map-merge($one, (transform: $transform));\n    $two: map-remove($two, transform);\n  }\n\n  @return map-merge($one, $two);\n}\n","/// Creates a sliding transition by translating the element horizontally or vertically.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Keyword} $direction [null] - Direction to slide to. Can be `up`, `right`, `down`, or `left`. By default `left` and `right` for `in` and `out` states respectively.\n/// @param {Length} $amount [100%] - Length of the slide as a percentage value.\n/// @param {Boolean} $fade [false] - Set to `true` to fade the element in or out simultaneously.\n/// @param {Duration} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin mui-slide (\n  $state: in,\n  $direction: null,\n  $amount: 100%,\n  $fade: map-get($motion-ui-settings, slide-and-fade),\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  $direction: if($direction != null, $direction, if($state == in, left, right));\n  $slide: slide($state, $direction, $amount);\n\n  // CSS Output\n  @include transition-start($state) {\n    @include transition-basics($duration, $timing, $delay);\n    @include -mui-keyframe-get($slide, 0);\n\n    @if $fade {\n      transition-property: transform, opacity;\n      opacity: if($state == in, 0, 1);\n    } @else {\n      transition-property: transform, opacity;\n    }\n\n    backface-visibility: hidden;\n  }\n\n  @include transition-end($state) {\n    @include -mui-keyframe-get($slide, 100);\n\n    @if $fade {\n      opacity: if($state == in, 1, 0);\n    }\n  }\n}\n","/// Creates a fade transition by adjusting the opacity of the element.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Number} $from [null] - Opacity to start at. Must be a number between 0 and 1. By default `0` and `1` for `in` and `out` states respectively.\n/// @param {Number} $to [null] - Opacity to end on. By default `1` and `0` for `in` and `out` states respectively.\n/// @param {Keyword} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin mui-fade(\n  $state: in,\n  $from: null,\n  $to: null,\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  $from: if($from != null, $from, if($state == in, 0, 1));\n  $to: if($to != null, $to, if($state == in, 1, 0));\n  $fade: fade($from, $to);\n\n  @include transition-start($state) {\n    @include transition-basics($duration, $timing, $delay);\n    @include -mui-keyframe-get($fade, 0);\n\n    transition-property: opacity;\n  }\n\n  @include transition-end($state) {\n    @include -mui-keyframe-get($fade, 100);\n  }\n}\n","/// Creates a hinge effect by rotating the element.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Keyword} $from [left] - Edge of the element to rotate from. Can be `top`, `right`, `bottom`, or `left`.\n/// @param {Keyword} $axis [edge] - Axis of the element to rotate on. Can be `edge` or `center`.\n/// @param {Number} $perspective [2000px] - Perceived distance between the viewer and the element. A higher number will make the rotation effect more pronounced.\n/// @param {Keyword} $turn-origin [null] - Side of the element to start the rotation from. Can be `from-back` or `from-front`. By default `from-back` and `from-front` for `in` and `out` states respectively.\n@function hinge (\n  $state: in,\n  $from: left,\n  $axis: edge,\n  $perspective: 2000px,\n  $turn-origin: null\n) {\n  // Rotation directions when hinging from back vs. front\n  $rotation-amount: 90deg;\n  $rotations-back: (\n    top: rotateX($rotation-amount * -1),\n    right: rotateY($rotation-amount * -1),\n    bottom: rotateX($rotation-amount),\n    left: rotateY($rotation-amount),\n  );\n  $rotations-from: (\n    top: rotateX($rotation-amount),\n    right: rotateY($rotation-amount),\n    bottom: rotateX($rotation-amount * -1),\n    left: rotateY($rotation-amount * -1),\n  );\n\n  // Rotation origin\n  $turn-origin: if($turn-origin != null, $turn-origin, if($state == in, from-back, from-front));\n  $rotation: '';\n  @if $turn-origin == from-front {\n    $rotation: map-get($rotations-from, $from);\n  } @else if $turn-origin == from-back {\n    $rotation: map-get($rotations-back, $from);\n  } @else {\n    @warn '$turn-origin must be either \"from-back\" or \"from-front\"';\n  }\n\n  // Start and end state\n  $start: '';\n  $end: '';\n  @if $state == in {\n    $start: perspective($perspective) $rotation;\n    $end: perspective($perspective) rotate(0deg);\n  } @else {\n    $start: perspective($perspective) rotate(0deg);\n    $end: perspective($perspective) $rotation;\n  }\n\n  // Turn axis\n  $origin: '';\n  @if $axis == edge {\n    $origin: $from;\n  } @else {\n    $origin: center;\n  }\n\n  $keyframes: (\n    name: -mui-string-safe('hinge-#{$state}-#{$from}-#{$axis}-#{$turn-origin}'),\n    0: (transform: $start, transform-origin: $origin),\n    100: (transform: $end),\n  );\n\n  @return $keyframes;\n}\n","/// Creates a hinge transition by rotating the element.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Keyword} $from [left] - Edge of the element to rotate from. Can be `top`, `right`, `bottom`, or `left`.\n/// @param {Keyword} $axis [edge] - Axis of the element to rotate on. Can be `edge` or `center`.\n/// @param {Length} $perspective [2000px] - Perceived distance between the viewer and the element. A higher number will make the rotation effect more pronounced.\n/// @param {Keyword} $turn-origin [null] - Side of the element to start the rotation from. Can be `from-back` or `from-front`. By default `from-back` and `from-front` for `in` and `out` states respectively.\n/// @param {Boolean} $fade [true] - Set to `true` to fade the element in or out simultaneously.\n/// @param {Duration} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin mui-hinge (\n  $state: in,\n  $from: left,\n  $axis: edge,\n  $perspective: 2000px,\n  $turn-origin: null,\n  $fade: map-get($motion-ui-settings, hinge-and-fade),\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  $turn-origin: if($turn-origin != null, $turn-origin, if($state == in, from-back, from-front));\n  $hinge: hinge($state, $from, $axis, $perspective, $turn-origin);\n\n  @include transition-start($state) {\n    @include transition-basics($duration, $timing, $delay);\n    @include -mui-keyframe-get($hinge, 0);\n\n    @if $fade {\n      transition-property: transform, opacity;\n      opacity: if($state == in, 0, 1);\n    } @else {\n      transition-property: transform, opacity;\n    }\n  }\n\n  @include transition-end($state) {\n    @include -mui-keyframe-get($hinge, 100);\n\n    @if $fade {\n      opacity: if($state == in, 1, 0);\n    }\n  }\n}\n","/// Creates a scaling transition. A scale of `1` means the element is the same size. Larger numbers make the element bigger, while numbers less than 1 make the element smaller.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Number} $from [null] - Size to start at. By default `0` and `1` for `in` and `out` states respectively.\n/// @param {Number} $to [null] - Size to end at. By default `1` and `0` for `in` and `out` states respectively.\n/// @param {Boolean} $fade [true] - Set to `true` to fade the element in or out simultaneously.\n/// @param {Duration} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin mui-zoom(\n  $state: in,\n  $from: null,\n  $to: null,\n  $fade: map-get($motion-ui-settings, scale-and-fade),\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  $from: if($from != null, $from, if($state == in, 0, 1));\n  $to: if($to != null, $to, if($state == in, 1, 0));\n  $scale: zoom($from, $to);\n\n  @include transition-start($state) {\n    @include transition-basics($duration, $timing, $delay);\n    @include -mui-keyframe-get($scale, 0);\n\n    @if $fade {\n      transition-property: transform, opacity;\n      opacity: if($state == in, 0, 1);\n    } @else {\n      transition-property: transform, opacity;\n    }\n  }\n\n  @include transition-end($state) {\n    @include -mui-keyframe-get($scale, 100);\n\n    @if $fade {\n      opacity: if($state == in, 1, 0);\n    }\n  }\n}\n","/// Creates a spinning transition by rotating the element. The `turn` unit is used to specify how far to rotate. `1turn` is equal to a 360-degree spin.\n/// @param {Keyword} $state [in] - State to transition to.\n/// @param {Keyword} $direction [null] - Direction to spin. Should be `cw` (clockwise) or `ccw` (counterclockwise). By default `cw` and `ccw` for `in` and `out` states respectively.\n/// @param {Number} $amount [0.75turn] - Amount to element the element.\n/// @param {Boolean} $fade [false] - Set to `true` to fade the element in or out simultaneously.\n/// @param {Duration} $duration [null] - Length (speed) of the transition.\n/// @param {Keyword|Function} $timing [null] - Easing of the transition.\n/// @param {Duration} $delay [null] - Delay in seconds or milliseconds before the transition starts.\n@mixin mui-spin(\n  $state: in,\n  $direction: cw,\n  $amount: 0.75turn,\n  $fade: map-get($motion-ui-settings, spin-and-fade),\n  $duration: null,\n  $timing: null,\n  $delay: null\n) {\n  $direction: if($direction != null, $direction, if($state == in, cw, ccw));\n  $spin: spin($state, $direction, $amount);\n\n  @include transition-start($state) {\n    @include transition-basics($duration, $timing, $delay);\n    @include -mui-keyframe-get($spin, 0);\n\n    @if $fade {\n      transition-property: transform, opacity;\n      opacity: if($state == in, 0, 1);\n    } @else {\n      transition-property: transform, opacity;\n    }\n  }\n\n  @include transition-end($state) {\n    @include -mui-keyframe-get($spin, 100);\n\n    @if $fade {\n      opacity: if($state == in, 1, 0);\n    }\n  }\n}\n","/// Creates a keyframe from one or more effect functions and assigns it to the element by adding the `animation-name` property.\n/// @param {Arglist} $effects... - One or more effect functions to build the keyframe with.\n@mixin mui-animation($args...) {\n  $name: map-get(-mui-process-args($args...), name);\n  @include mui-keyframes($name, $args...);\n  animation-name: unquote($name);\n}\n","@import 'util/mixins';\n\ndiv.card {\n    @include border-radius($radius);\n   \n    @include overflow(hidden);\n    }\n\n\ndiv.responsive-side-box {\n    background: $white;\n    @include breakpoint(small) {\n        @include padding(1,0,0,0);\n    }\n    @include breakpoint(medium) {\n        @include padding(1,1,1,1);\n    }\n    @include breakpoint(large) {\n        @include padding(2,2,2,2);\n    }\n}"," $header-styles-media: (\n  small: (\n    'h1': ('font-size': 21),\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': 16),\n    'h2': ('font-size': 15),\n    'h3': ('font-size': 14),\n    'h4': ('font-size': 14),\n    'h5': ('font-size': 14),\n    'h6': ('font-size': 14),\n  ),\n) !default;\n$header-styles-articlerow: (\n  small: (\n  'h1': ('font-size': 16),\n    'h2': ('font-size': 15),\n    'h3': ('font-size': 14),\n    'h4': ('font-size': 14),\n    'h5': ('font-size': 14),\n    'h6': ('font-size': 14),\n  ),\n  medium: (\n    'h1': ('font-size': 16),\n    'h2': ('font-size': 15),\n    'h3': ('font-size': 14),\n    'h4': ('font-size': 14),\n    'h5': ('font-size': 14),\n    'h6': ('font-size': 14),\n  ),\n) !default;\n \n @each $size, $headers in $header-styles-media {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        div.media-object-section > #{$header}, .#{$header} {\n            \n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n\n\n @each $size, $headers in $header-styles-articlerow {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        div.article-row-content > #{$header}, .#{$header} {\n            font-weight: bold;\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\n\n\n","$news-hero-height: 50vh !default;\n$news-hero-large-height: 70vh !default;\n\n.news-hero {\n    @include border-radius($radius);\n    @include margin(1,null,1,null);\n    @include breakpoint(small) {\n        height: $news-hero-height*0.6;\n    }\n    @include breakpoint(medium) {\n        height: $news-hero-height*0.8;\n    }\n    @include breakpoint(large) {\n        height: $news-hero-height*1;\n    }\n}\n.news-hero-large {\n    height: 100%;\n    \n    @include breakpoint(small) {\n        min-height: $news-hero-large-height*0.5;\n    }\n    @include breakpoint(medium) {\n        min-height: $news-hero-large-height 0.7;\n    }\n    @include breakpoint(large) {\n        min-height: $news-hero-large-height;\n    }\n}\n.news-hero, .news-hero-large {\n    background: url('https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg') 50% no-repeat;\n    background-color: #444;\n    position: relative;\n    background-size: cover;\n    align-items: center;\n    justify-content: center;\n    vertical-align: middle;\n    text-align: left;\n    display: flex;\n    width:100%;\n\n  .news-hero-text {\n    position: absolute;\n    bottom: 15%;\n    @include breakpoint(small) {\n        left: 5%;\n    }\n    @include breakpoint(medium) {\n        left: 10%;\n    }\n    @include breakpoint(large) {\n        left: 20%;\n    }\n    color: $white;\n    text-shadow: 1px 1px 2px $black;\n  }\n}\n\n\n $header-styles-news-hero: (\n  small: (\n    'h1': ('font-size': 21),\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': 24),\n    'h2': ('font-size': 22),\n    'h3': ('font-size': 21),\n    'h4': ('font-size': 18),\n    'h5': ('font-size': 16),\n    'h6': ('font-size': 15),\n  ),\n) !default;\n \n @each $size, $headers in  $header-styles-news-hero {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        div.news-hero-text > .article-title > #{$header}, .#{$header} {\n            font-weight: bold;\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",".date-box {\n    @include flex;\n    @include flex-align(left,middle);\n    height: 71px;\n    background-color: #FFF;\n    @include padding(0,0,0,1)\n    \n    .date-badge {\n        width:41px; \n        height: 41px;\n        padding-top: 8px;  \n        .date-badge-day {\n            font-size:20px;\n            line-height:1em;\n            font-weight:bold;\n        }\n        .date-badge-month {\n            font-size:12px;\n            position:relative; \n            top:-7px;\n        }\n    }\n    .date-text {\n        @include margin(0,0,0,1)\n\n    }\n    @include margin(0,0,1,0)\n}\n","$news-card-label-background: $primary-color;\n$news-card-label-background-hover: scale-color($news-card-label-background, $lightness: -15%);\n\n.news-card-tag {\n  margin-bottom: 0.5rem;\n\n  .label {\n    border-radius: 0.125rem;\n    background-color: $news-card-label-background;\n    color: $white;\n\n    a {\n      background-color: inherit;\n      color: inherit;\n    }\n\n    &:hover,\n    &:focus {\n      background-color: $news-card-label-background-hover;\n\n      a {\n        background-color: inherit;\n        color: inherit;\n      }\n    }\n  }\n}\n\n.news-card {\n  background-color: $white;\n  font-weight: 400;\n  margin-bottom: 1.6rem;\n  border-radius: 0.125rem;\n  box-shadow: 0 1px 3px rgba(0,0,0, 0.12), 0 1px 2px rgba(0,0,0, 0.24);\n\n  .card-section {\n    background-color: inherit;\n\n    .news-card-date {\n      font-size: 1em;\n      color: $dark-gray;\n    }\n\n    .news-card-article {\n      background-color: inherit;\n\n      .news-card-title {\n        line-height: 1.3;\n        font-weight: bold;\n\n        a {\n          text-decoration: none;\n          color: $dark-gray;\n          transition: color 0.5s ease;\n\n          &:hover {\n            color: $primary-color;\n          }\n        }\n      }\n\n      .news-card-description {\n        color: $dark-gray;\n      }\n    }\n\n    .news-card-author {\n      overflow: hidden;\n      padding-bottom: 1.6rem;\n\n      .news-card-author-image {\n        display: inline-block;\n        vertical-align: middle;\n\n        img {\n          border-radius: 50%;\n          margin-right: 0.6em;\n        }\n      }\n\n      .news-card-author-name {\n        display: inline-block;\n        vertical-align: middle;\n      }\n    }\n  }\n}\n","// Default colors, Change as per your requirement.\n$color-1: $primary-color; \n$color-2: darken($primary-color, 10%);\n$color-3: darken($primary-color, 20%);\n\n$responsive-hidden-nav-min-width: 240px;\n\n/*! CSS for Responsive Hidden Nav */\n.responsive-hidden-nav-container {\n  min-width: $responsive-hidden-nav-min-width;\n  background: $color-1;\n  padding: .5rem 1rem;\n  height: 80vh;\n}\n\n.responsive-hidden-nav {\n  margin: 0;\n  padding: 0;\n  background-color: $white;\n  position: relative;\n  min-width: $responsive-hidden-nav-min-width;\n  background: $white;\n  \n  a {\n    display: block;\n    padding: 1.25rem 2rem;\n    background: $white;\n    font-size: 1.1em;\n    color: $color-1;\n    text-decoration: none;\n    \n    &:hover {\n      color: $color-3;\n    }\n  }\n  \n  button {\n    position: absolute;\n    height: 100%;\n    right: 0;\n    padding: 0 1rem;\n    border: 0;\n    outline: none;\n    background-color: $color-2;\n    color: $white;\n    cursor: pointer;\n    \n    &:hover {\n      background-color: $color-3;\n    }\n    \n    &::after {\n      content: attr(count);\n      position: absolute;\n      width: 2rem;\n      height: 2rem;\n      left: -1rem;\n      top: .75rem;\n      text-align: center;\n      background-color: $color-3;\n      color: $white;\n      font-size: .9em;\n      line-height: 1.6;\n      border-radius: 50%;\n      border: .25rem solid $white;\n      font-weight: bold;\n    }\n    \n    &:hover::after {\n      transform: scale(1.075);\n    }\n  }\n  \n  .hamburger {\n    @include hamburger(\n      $color: $white,\n      $color-hover: $white\n    );\n  }\n  \n  .visible-links {\n    display: inline-table;\n    margin: 0;\n    padding: 0;\n    \n    li {\n      display: table-cell;\n      border-left: 1px solid $color-1;\n\n      &:first-child {\n        font-weight: bold;\n        a { \n          color: $color-1 !important; \n        }\n      }\n    }\n  }\n  \n  .hidden-links {\n    position: absolute;\n    right: 0;\n    top: 100%;\n    margin: 0;\n    padding: 0;\n    \n    li {\n      display: block;\n      border-top: .0625rem solid $color-2;\n    }\n  }\n    \n  .hidden {\n    visibility: hidden;\n  }\n}\n","$topbar-responsive-bg: #2c3840;\n$topbar-responsive-animation-type: fade-in; // or use slide-down or none\n\n.topbar-responsive {\n  background: $topbar-responsive-bg;\n  padding: 1rem 1.5rem;\n\n  .topbar-responsive-logo {\n    color: $white;\n    vertical-align: middle;\n  }\n\n  .menu {\n    background: $topbar-responsive-bg;\n\n    li:last-of-type {\n      margin-right: 0;\n    }\n\n    a {\n      color: $white;\n      transition: color 0.15s ease-in;\n\n      &:hover {\n        color: lighten($topbar-responsive-bg, 60%);\n      }\n\n      @media screen and (max-width: 39.9375em) {\n        padding: 0.875rem 0;\n      }\n    }\n\n    .topbar-responsive-button {\n      color: $white;\n      border-color: $white;\n      border-radius: 5000px;\n      transition: color 0.15s ease-in, border-color 0.15s ease-in;\n\n      &:hover {\n        color: lighten($topbar-responsive-bg, 60%);\n        border-color: lighten($topbar-responsive-bg, 60%);\n      }\n\n      @media screen and (max-width: 39.9375em) {\n        width: 100%;\n        margin: 0.875rem 0;\n      }\n    }\n  }\n\n   @media screen and (max-width: 39.9375em) {\n     padding: 0.75rem;\n\n    .top-bar-title {\n      position: relative;\n      width: 100%;\n\n      span {\n        position: absolute;\n        right: 0;\n        border: 1px solid $white;\n        border-radius: 5px;\n        padding: 0.25rem 0.45rem;\n        top: 50%;\n        transform: translateY(-50%);\n\n        .menu-icon {\n          margin-bottom: 4px;\n        }\n      }\n    }\n  }\n}\n\n@keyframes fadeIn {\n  from {\n    opacity:0;\n  } to {\n    opacity:1;\n  }\n}\n\n@keyframes slideDown {\n  0% {\n    transform: translateY(-100%);\n  }\n  100% {\n    transform: translateY(0%);\n  }\n}\n\n@include breakpoint(small only) {\n  .topbar-responsive-links {\n    animation-fill-mode: both;\n    animation-duration: 0.5s;\n    width: 100%;\n\n    @if $topbar-responsive-animation-type == slide-down {\n      animation: slideDown 1s ease-in;\n    } @else if $topbar-responsive-animation-type == fade-in {\n      animation: fadeIn 1s ease-in;\n    } @else {\n      animation: none;\n    }\n  }\n}\n","$comment-form-bg: $light-gray;\n$comment-section-bg: $white;\n$comment-section-padding: $global-padding;\n\n.comment-section-container {\n  background-color: $comment-section-bg;\n  padding: $global-padding;\n}\n\n.comment-section-author {\n  display: flex;\n  align-items: center;\n  margin-bottom: 1rem;\n\n  .comment-section-name {\n    margin-left: 1rem;\n\n    p {\n      margin-bottom: 0;\n    }\n  }\n}\n\n.comment-section-box {\n  background-color: $comment-form-bg;\n  padding: $global-padding;\n}\n","// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$about-the-author-text-transform: uppercase;\n$about-the-author-separator-width: 5rem;\n$about-the-author-separator-thickness: 0.125rem;\n\n.about-the-author {\n  background-color: $white;\n  padding: 1rem;\n  border: 1px solid $medium-gray;\n\n  .separator-left {\n    text-align: left;\n    @include clearfix;\n\n    &::after {\n      position: relative;\n      width: $about-the-author-separator-width;\n      border-bottom: $about-the-author-separator-thickness solid $primary-color;\n      margin: 0.3rem auto 0;\n      margin-left: 0;\n    }\n  }\n\n  .author-title {\n    text-transform: $about-the-author-text-transform;\n  }\n\n  .author-social {\n    text-align: center;\n    margin-top: 0.7rem;\n    margin-bottom: 0.7rem;\n\n    .fa-stack {\n      display: inline-block;\n\n      &.facebook {\n        color: lighten($social-brand-facebook, 10%);\n\n        &:hover,\n        &:focus {\n          color: $social-brand-facebook;\n        }\n      }\n\n      &.twitter {\n        color: lighten($social-brand-twitter, 10%);\n\n        &:hover,\n        &:focus {\n          color: $social-brand-twitter;\n        }\n      }\n\n      &.linkedin {\n        color: lighten($social-brand-linkedin, 10%);\n\n        &:hover,\n        &:focus {\n          color: $social-brand-linkedin;\n        }\n      }\n    }\n  }\n\n  .author-image {\n    border: 1px solid $medium-gray;\n  }\n}\n","// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-comments: $dark-gray;\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$social-brand-google-plus: #dd4b39;\n\n.wide-article-link {\n  background-color: $white;\n  padding: 1rem 1rem 0.5rem;\n  border: 1px solid $medium-gray;\n  margin-bottom: 1rem;\n\n  .article-title {\n    a {\n      color: $black;\n\n      &:hover,\n      &:focus {\n        color: $primary-color;\n      }\n    }\n  }\n\n  .article-elipsis {\n    .read-more {\n      font-weight: bold;\n    }\n  }\n\n  .article-title,\n  .article-author,\n  .article-elipsis {\n    margin-bottom: 0.25rem;\n  }\n\n  .article-social {\n    margin-top: 0.75rem;\n\n    .social {\n      margin-right: 0.25rem;\n\n      &.comments {\n        @include button-style($social-comments, auto, $white);\n      }\n      &.facebook {\n        @include button-style($social-brand-facebook, auto, $white);\n      }\n      &.twitter {\n        @include button-style($social-brand-twitter, auto, $white);\n      }\n      &.linkedin {\n        @include button-style($social-brand-linkedin, auto, $white);\n      }\n      &.google-plus {\n        @include button-style($social-brand-google-plus, auto, $white);\n      }\n\n      > .fa {\n        color: $white;\n\n        &.fa-comments-o {\n          margin-right: 0.25rem;\n        }\n      }\n    }\n  }\n}\n","$large-article-header-bg: url('https://unsplash.it/1024/500/?blur') !default;\n$large-article-header-color: $black !default;\n$large-article-header-bg-color: $white !default;\n$large-article-header-height: rem-calc(500) !default;\n\n.large-article-header {\n  background: $large-article-header-bg $large-article-header-bg-color no-repeat center;\n  background-size: cover;\n  background-color: $large-article-header-bg-color;\n  height: $large-article-header-height;\n  position: relative;\n\n  @include breakpoint(small only) {\n    height: ($large-article-header-height / 1.5);\n  }\n}\n\n.large-article-header-content {\n  display: flex;\n  flex-direction: column;\n  position: absolute;\n  bottom: rem-calc(50);\n  left: 0;\n  right: 0;\n text-shadow: 1px 1px 2px $black;\n  @include breakpoint(small only) {\n    bottom: rem-calc(20);\n  }\n\n  .center-container {\n    width: 50%;\n    margin: 0 auto;\n\n    @include breakpoint(small only) {\n      width: 100%;\n      padding: 0 rem-calc(20);\n    }\n  }\n\n  .article-date {\n    color: $large-article-header-color;\n  }\n  .article-title {\n    h1 {\n      line-height: rem-calc(50);\n      color: $large-article-header-color;\n      font-weight: 600;\n\n      @include breakpoint(small only) {\n        line-height: rem-calc(30);\n      }\n    }\n  }\n  .article-details {\n    display: flex;\n    align-items: center;\n    justify-content: space-between;\n\n    a {\n      color: $large-article-header-color;\n    }\n  }\n  .article-author {\n    display: flex;\n    align-items: center;\n    margin: $global-margin 0;\n    img {\n      border-radius: rem-calc(50);\n    }\n    a {\n      margin-left: $global-margin;\n    }\n  }\n}\n","$article-title-case: uppercase;\n\n// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$social-brand-google-plus: #dd4b39;\n\n.simple-article-header {\n  background: $white;\n  padding: 1.3rem 2rem .7rem;\n  border: 1px solid $medium-gray;\n  margin-bottom: 1rem;\n\n  .article-date-read {\n    color: $dark-gray;\n  }\n\n  .article-title {\n    text-transform: $article-title-case;\n\n    a {\n      color: $black;\n\n      &:hover,\n      &:focus {\n        color: $primary-color;\n      }\n    }\n  }\n\n  .article-author-comments {\n    a.article-comments {\n      color: $dark-gray;\n\n      &:hover,\n      &:focus {\n        color: $primary-color;\n      }\n    }\n  }\n\n  .article-date-read,\n  .article-title,\n  .article-author-comments,\n  .article-social,\n  .article-post-image,\n  .article-post-content {\n    margin-bottom: 0.25rem;\n  }\n\n  .article-social {\n    margin-top: 0.75rem;\n\n    .social {\n      margin-right: 0.25rem;\n\n      &.facebook {\n        @include button-style($social-brand-facebook, auto, $white);\n      }\n      &.twitter {\n        @include button-style($social-brand-twitter, auto, $white);\n      }\n      &.linkedin {\n        @include button-style($social-brand-linkedin, auto, $white);\n      }\n      &.google-plus {\n        @include button-style($social-brand-google-plus, auto, $white);\n      }\n\n      > .fa {\n        color: $white;\n\n        &.fa-comments-o {\n          margin-right: 0.25rem;\n        }\n      }\n    }\n  }\n}\n",".blockquote-container {\n  &.blockquote-left {\n    float: left;\n    width: 35%;\n    margin-right: $global-margin;\n\n    @include breakpoint (small only) {\n      float: none;\n      margin: 0;\n      width: 100%;\n    }\n  }\n\n  &.blockquote-right {\n    float: right;\n    width: 35%;\n    margin-left: $global-margin;\n  }\n\n  .callout {\n    .blockquote-title {\n      margin-left: 1rem;\n    }\n\n    blockquote {\n      quotes: \"“\"\"”\"\"‘\"\"’  \";\n      border-left: none;\n\n      &:before {\n        content: open-quote;\n        color: $dark-gray;\n        font-size: 4em;\n        line-height: 0.1em;\n        vertical-align: -0.4em;\n      }\n\n      &:after {\n        content: close-quote;\n        color: $dark-gray;\n        font-size: 4em;\n        line-height: 0.1em;\n        vertical-align: -0.6em;\n      }\n\n      .blockquote-content {\n        display: inline;\n        color: $black;\n      }\n    }\n  }\n}\n","$caption-font-size: .9rem;\n\n.flexible-article-image-full {\n  .thumbnail {\n    width: 100%;\n\n    img {\n      width: 100%;\n    }\n  }\n\n  .caption {\n    font-size: $caption-font-size;\n  }\n}\n\n.flexible-article-image-left {\n  float: left;\n  margin: 1rem 1.5rem 0 0;\n  max-width: rem-calc(200);\n\n  .caption {\n    font-size: $caption-font-size;\n  }\n\n  @include breakpoint (small only) {\n    float: none;\n    max-width: 100%;\n    margin: 0;\n\n    .thumbnail {\n      width:100%;\n\n      img {\n        width:100%;\n      }\n    }\n  }\n}\n\n.flexible-article-image-right {\n  float: right;\n  margin: 0 0 1rem 1.5rem;\n  max-width: rem-calc(200);\n\n  .caption {\n    font-size: $caption-font-size;\n  }\n\n  @include breakpoint (small only) {\n    float: none;\n    max-width: 100%;\n    margin: 0;\n\n    .thumbnail {\n      width:100%;\n\n      img {\n        width:100%;\n      }\n    }\n  }\n}\n","$featured-article-text-color: $white;\n$featured-article-border: rem-calc(1) solid $white;\n$featured-article-links-border: rem-calc(1) solid $light-gray;\n$featured-article-side-links-height: rem-calc(450);\n\n// big feature\n$featured-article-big-bg: url('https://placehold.it/600?text=Big+Feature') no-repeat center center;\n$featured-article-title-size-big: rem-calc(28);\n$featured-article-author-size-big: rem-calc(18);\n\n// small feature\n$featured-article-small-bg: url('https://placehold.it/200?text=Small+Feature') no-repeat center center;\n$featured-article-title-size-small: rem-calc(16);\n$featured-article-author-size-small: rem-calc(12);\n\n.featured-article-big {\n  background: $featured-article-big-bg;\n  background-size: cover;\n  height: $featured-article-side-links-height;\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  padding: rem-calc(10);\n  border-right: $featured-article-border;\n\n  .featured-article-text {\n    .featured-article-title {\n      font-size: $featured-article-title-size-big;\n      font-weight: bold;\n      line-height: rem-calc(30);\n      .author {\n        font-size: $featured-article-author-size-big;\n      }\n    }\n    p {\n      color: $featured-article-text-color;\n      margin-bottom: 0;\n    }\n  }\n}\n\n.featured-article-small-container {\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: $featured-article-side-links-height;\n\n  :last-child .featured-article-small {\n    border-bottom: 0;\n  }\n}\n\n.featured-article-small {\n  background: $featured-article-small-bg;\n  height: $featured-article-side-links-height / 3;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  padding: rem-calc(10);\n  border-bottom: $featured-article-border;\n\n  :last-child {\n    border-bottom: 0;\n  }\n\n  .featured-article-text {\n    .featured-article-title {\n      font-size: $featured-article-title-size-small;\n      font-weight: bold;\n      line-height: rem-calc(15);\n      max-height: rem-calc(45);\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n    p {\n      color: $featured-article-text-color;\n      margin-bottom: 0;\n    }\n  }\n}\n\n.featured-article-links-container {\n  border: $featured-article-links-border;\n  background-color: $white;\n  height: $featured-article-side-links-height;\n  overflow: scroll;\n}\n\n.featured-article-links,\n.featured-article-links-header {\n  padding: rem-calc(10);\n  border-bottom: $featured-article-links-border;\n\n  &:last-child {\n    border-bottom: 0;\n  }\n}\n\n.featured-article-links-header {\n  font-weight: 600;\n  text-transform: uppercase;\n}\n","/// Defatul bottom margin of the panel\n/// @type List\n$panel-margin: rem-calc(20 10);\n/// Default background color of the panel\n/// @type Color\n$panel-container-background-color: $white !default;\n\n/// Default radius of the panel\n/// @type List\n$panel-container-radius: $global-radius !default;\n\n/// Default bottom border width of the panel's header\n/// @type Number\n$panel-header-border-bottom-width: rem-calc(4) !default;\n\n/// Default bottom border color of the panel's header\n/// @type Color\n$panel-header-border-bottom-color: $light-gray !default;\n\n/// Default font color of the panel's title\n/// @type Color\n$panel-header-color: $dark-gray;\n\n/// Default font size of the panel's title\n/// @type Number\n$panel-header-font-size: rem-calc(26) !default;\n\n/// Default bottom border color of the post\n/// @type Color\n$post-item-border-bottom-color: $light-gray !default;\n\n/// Default bottom border width of the post\n/// @type Number\n$post-item-border-bottom-width: rem-calc(1) !default;\n\n/// Adds styles for post-list's elements in small screen and it also could be used for bigger screen in small areas\n@mixin small-posts-list {\n  .posts-list{\n    .post-title{\n      font-size: rem-calc(18);\n    }\n\n    .post-meta{\n      font-size: rem-calc(12);\n    }\n\n    .post-summary{\n      font-size: rem-calc(12);\n    }\n    .post-read-more{\n      display: none;\n    }\n  }\n}\n\n\n.posts-panel{\n  @include grid-col-row();\n  float: none !important;\n  margin: $panel-margin;\n  background-color: $panel-container-background-color;\n  border-radius: $panel-container-radius;\n  box-shadow: rem-calc(0 0 4 0) rgba(0,0,0,.2);\n\n  .panel-header{\n    @include grid-col-row();\n    border-bottom: $panel-header-border-bottom-width solid $panel-header-border-bottom-color;\n\n    .panel-title{\n      margin: 0;\n      padding: rem-calc(15 0);\n      color: $panel-header-color;\n      font-size: $panel-header-font-size;\n    }\n  }\n\n  .panel-content{\n    padding: rem-calc(15 0);\n  }\n\n  .pinned-post, .posts-list{\n    @include grid-col-row($gutters: 0);\n  }\n\n  .posts-list{\n    .post-item:not(:last-child){\n      border-bottom: $post-item-border-bottom-width solid $post-item-border-bottom-color;\n    }\n  }\n\n  .post-item{\n    @include grid-row();\n    padding: rem-calc(15 0);\n\n    .post-thumbnail{\n      display: block;\n      @include grid-column($columns: 4);\n\n      img{\n        width: 100%;\n        height: auto;\n      }\n    }\n\n    .post-text{\n      @include grid-column($columns: 8);\n\n      p{\n        margin: 0;\n      }\n    }\n    .post-title{\n      font-size: rem-calc(26);\n    }\n    .post-meta{\n      color: $dark-gray;\n      font-size: rem-calc(14);\n    }\n    .meta{\n      display: inline-block;\n      margin-#{$global-right}: rem-calc(15);\n    }\n    .meta-icon, .meta-text{\n      display: inline-block;\n      padding-#{$global-right}: rem-calc(5);\n    }\n\n    .post-summary{\n\n    }\n\n    .post-read-more{\n      display: block;\n      font-size: rem-calc(14);\n\n      .fa{\n        padding: rem-calc(0 5)\n      }\n    }\n  }\n\n  .pinned-post{\n    .post-item{\n      border-bottom: $post-item-border-bottom-width solid $post-item-border-bottom-color;\n    }\n    .post-thumbnail{\n      display: block;\n      @include grid-col-row();\n      img{\n        width: 100%;\n        height: auto;\n      }\n    }\n\n    .post-text{\n      @include grid-col-row();\n      margin-top: rem-calc(15);\n    }\n  }\n\n  @include breakpoint(small only){\n    @include small-posts-list;\n  }\n\n  @include breakpoint(medium only){\n    .posts-list{\n      .post-title{\n        font-size: rem-calc(20);\n      }\n\n      .post-meta{\n        font-size: rem-calc(14);\n      }\n\n      .post-summary{\n        font-size: rem-calc(14);\n      }\n    }\n  }\n\n  // Grid styles\n  &.grid{\n    .pinned-post, .posts-list{\n      @include grid-column($columns: 6, $gutters: 0);\n\n      @include breakpoint(small only){\n        @include grid-col-row($gutters: 0);\n      }\n    }\n\n    .pinned-post{\n      .post-item{\n        border: 0;\n      }\n    }\n\n    @include small-posts-list;\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Set the width of a grid column.\n///\n/// @param {Number|List} $width [$grid-column-count] - Width to make the column. You can pass in any value accepted by the `grid-column()` function, such as `6`, `50%`, or `1 of 2`.\n@mixin grid-column-size(\n  $columns: $grid-column-count\n) {\n  width: grid-column($columns);\n}\n\n/// Shorthand for `grid-column-size()`.\n/// @alias grid-column-size\n@mixin grid-col-size(\n  $columns: $grid-column-count\n) {\n  @include grid-column-size($columns);\n}\n","// Foundation for Sites\n// https://get.foundation\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  @return fraction-to-percentage($columns, $denominator: $grid-column-count);\n}\n\n/// Creates a grid column.\n///\n/// @param {Mixed} $columns [$grid-column-count] - Width of the column. Refer to the `grid-column()` function to see possible values.\n/// @param {Mixed} $gutters [$grid-column-gutter] - Spacing between columns. Refer to the `grid-column-gutter()` function to see possible values.\n@mixin grid-column(\n  $columns: $grid-column-count,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-size($columns);\n  float: $global-left;\n\n  // Gutters\n  @include grid-column-gutter($gutters: $gutters);\n\n  // Position\n  @include grid-col-pos(auto);\n}\n\n/// Creates a grid column row. This is the equivalent of adding `.row` and `.column` to the same element.\n///\n/// @param {Mixed} $gutters [$grid-column-gutter] - Width of the gutters on either side of the column row. Refer to the `grid-column-gutter()` function to see possible values.\n@mixin grid-column-row(\n  $gutters: $grid-column-gutter\n) {\n  @include grid-row;\n  @include grid-column($gutters: $gutters);\n\n  &,\n  &:last-child {\n    float: none;\n  }\n}\n\n/// Shorthand for `grid-column()`.\n/// @alias grid-column\n@function grid-col(\n  $columns: $grid-column-count\n) {\n  @return grid-column($columns);\n}\n\n/// Shorthand for `grid-column()`.\n/// @alias grid-column\n@mixin grid-col(\n  $columns: $grid-column-count,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column($columns, $gutters);\n}\n\n/// Shorthand for `grid-column-row()`.\n/// @alias grid-column-row\n@mixin grid-col-row(\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-row($gutters);\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Set the gutters on a column\n/// @param {Number|Keyword} $gutter [auto]\n///   Spacing between columns, accepts multiple values:\n///   - A single value will make the gutter that exact size.\n///   - A breakpoint name will make the gutter the corresponding size in the $gutters map.\n///   - \"auto\" will make the gutter responsive, using the $gutters map values.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use. Responsive gutter settings by default.\n@mixin grid-column-gutter(\n  $gutter: auto,\n  $gutters: $grid-column-gutter\n) {\n  @include -zf-breakpoint-value($gutter, $gutters) {\n    $padding: rem-calc($-zf-bp-value) / 2;\n\n    padding-right: $padding;\n    padding-left: $padding;\n  }\n}\n\n/// Collapse the gutters on a column by removing the padding. **Note:** only use this mixin within a breakpoint. To collapse a column's gutters on all screen sizes, use the `$gutter` parameter of the `grid-column()` mixin instead.\n@mixin grid-column-collapse {\n  @include grid-column-gutter(0);\n}\n\n/// Shorthand for `grid-column-gutter()`.\n/// @alias grid-column-gutter\n@mixin grid-col-gutter(\n  $gutter: auto,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-gutter($gutter, $gutters);\n}\n\n/// Shorthand for `grid-column-collapse()`.\n/// @alias grid-column-collapse\n@mixin grid-col-collapse {\n  @include grid-column-collapse;\n}\n\n/// Sets bottom margin on grid columns to match gutters\n/// @param {Number|Keyword} $margin [auto]\n///   The bottom margin on grid columns, accepts multiple values:\n///   - A single value will make the margin that exact size.\n///   - A breakpoint name will make the margin the corresponding size in the $margins map.\n///   - \"auto\" will make the margin responsive, using the $margins map values.\n/// @param {Number|Map} $margins [$grid-column-gutter] - Map or single value to use. Responsive gutter settings by default.\n@mixin grid-column-margin (\n  $margin: auto,\n  $margins: $grid-column-gutter\n) {\n  @include -zf-breakpoint-value($margin, $margins) {\n    $margin-bottom: rem-calc($-zf-bp-value);\n    margin-bottom: $margin-bottom;\n\n    > :last-child {\n      margin-bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Reposition a column.\n///\n/// @param {Number|Keyword} $position - It can be:\n///   * A number: The column will move equal to the width of the column count\n///     specified. A positive number will push the column to the right, while\n///     a negative number will pull it to the left.\n///   * `center`: Column will be centered\n///   * `auto`: Column will be pushed to the left (or to the right for the last column).\n@mixin grid-column-position($position) {\n  // Auto positioning\n  @if $position == auto {\n    &, &:last-child:not(:first-child) {\n      float: $global-left;\n      clear: none;\n    }\n\n    // Last column alignment\n    @if $grid-column-align-edge {\n      &:last-child:not(:first-child) {\n        float: $global-right;\n      }\n    }\n  }\n\n  // Push/pull\n  @else if type-of($position) == 'number' {\n    $offset: percentage($position / $grid-column-count);\n\n    position: relative;\n    #{$global-left}: $offset;\n  }\n\n  // Center positioning\n  @else if $position == center {\n    &, &:last-child:not(:first-child) {\n      float: none;\n      clear: both;\n    }\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  @else {\n    @warn 'Wrong syntax for grid-column-position(). Enter a positive or negative number, \"center\" or \"auto\".';\n  }\n}\n\n/// Reset a position definition.\n@mixin grid-column-unposition {\n  @include grid-column-position(auto);\n  position: static;\n  margin-right: 0;\n  margin-left: 0;\n}\n\n/// Offsets a column to the right by `$n` columns.\n/// @param {Number|List} $n - Width to offset by. You can pass in any value accepted by the `grid-column()` mixin, such as `6`, `50%`, or `1 of 2`.\n@mixin grid-column-offset($n) {\n  margin-#{$global-left}: grid-column($n);\n}\n\n/// Disable the default behavior of the last column in a row aligning to the opposite edge.\n@mixin grid-column-end {\n  // This extra specificity is required for the property to be applied\n  &:last-child:last-child {\n    float: $global-left;\n  }\n}\n\n/// Shorthand for `grid-column-position()`.\n/// @alias grid-column-position\n@mixin grid-col-pos($position) {\n  @include grid-column-position($position);\n}\n\n/// Shorthand for `grid-column-unposition()`.\n/// @alias grid-column-unposition\n@mixin grid-col-unpos {\n  @include grid-column-unposition;\n}\n\n/// Shorthand for `grid-column-offset()`.\n/// @alias grid-column-offset\n@mixin grid-col-off($n) {\n  @include grid-column-offset($n);\n}\n\n/// Shorthand for `grid-column-end()`.\n/// @alias grid-column-end\n@mixin grid-col-end {\n  @include grid-column-end;\n}\n","$social-bar-position: left; // Change this value to `right` for changing sidebar's position.\n$social-bar-transformation: rem-calc(140);\n$social-bar-width: rem-calc(180);\n$social-bar-background: #333333;\n$social-icon-color: $white;\n$social-icon-transition: all 0.3s ease-in-out;\n$social-icon-font-size: 1.1rem;\n$social-icon-padding: 0.5rem;\n\n// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$social-brand-youtube: #bb0000;\n$social-brand-instagram: #125688;\n$social-brand-pinterest: #cb2027;\n\n.sticky-social-bar {\n  padding: 0;\n  margin: 0; \n  top: 50%;\n  transform: translateY(-50%);\n  width: $social-bar-width;\n  background-color: $social-bar-background;\n  position: fixed;\n\t\n  @if $social-bar-position == left {\n\t  left: $social-bar-transformation * -1;\n  }\n  @if $social-bar-position == right {\n\t  right: $social-bar-transformation * -1;\n  }\n\n  .social-icon {\n    list-style-type: none;\n    color: $social-icon-color;\n    background-color: inherit;\n    margin: 0;\n    transition: $social-icon-transition;\n    cursor: pointer;\n    font-size: $social-icon-font-size;\n    padding: 0.25rem 0.25rem 0.5rem;\n\n    &:first-of-type {\n\t    padding-top: 0.375rem;\n    }\n    &:last-of-type {\n\t    padding-bottom: 0.625rem;\n    }\n\n    > a {\n      color: inherit;\n      background-color: inherit;\n\n      > .fa {\n        padding: $social-icon-padding;\n        width: 2rem;\n        height: 2rem;\n\n        @if $social-bar-position == left {\n          float: right;\n          margin-left: 0.5rem;\n        }\n        @if $social-bar-position == right {\n          float: left;\n          margin-right: 0.5rem;\n        }\n\n        &.fa-facebook {\n          background-color: $social-brand-facebook;\n        }\n        &.fa-twitter {\n          background-color: $social-brand-twitter;\n        }\n        &.fa-linkedin {\n          background-color: $social-brand-linkedin;\n        }\n        &.fa-youtube {\n          background-color: $social-brand-youtube;\n        }\n        &.fa-instagram {\n          background-color: $social-brand-instagram;\n        }\n        &.fa-pinterest-p {\n          background-color: $social-brand-pinterest;\n        }\n      }\n\n      > .social-icon-text {\n        font-size: 80%;\n        color: $social-icon-color;\n        text-transform: uppercase;\n\n        @if $social-bar-position == left {\n          margin-right: 0.5rem;\n        }\n        @if $social-bar-position == right {\n          margin-left: 0.5rem;\n        }\n      }\n    }\n\n    &:hover {\n\n      @if $social-bar-position == left {\n        transform:translateX($social-bar-transformation * 1);\n      }\n      @if $social-bar-position == right {\n        transform:translateX($social-bar-transformation * -1);\n      }\n\n      > a {\n        color: inherit;\n        background-color: inherit;\n      }\n    }\n  }\n}\n",".ecommerce-footer {\n  background-color: $white;\n  padding: 70px 20px 40px 20px;\n}\n\n.ecommerce-footer-links {\n\n  h5 {\n    color: $black;\n    font-size: 1.2rem;\n    font-weight: 600;\n  }\n\n  .menu > li > a {\n    line-height: 1.5em;\n    padding: 0.5rem 0rem;\n  }\n\n  a {\n    color: lighten($black, 40%);\n    font-size: 1rem;\n    transition: all 0.5s ease;\n  }\n\n  a:hover {\n    color: $black;\n    transition: all 0.5s ease;\n  }\n\n  .more-categories {\n    margin-top: 2rem;\n\n    @include breakpoint(small down) {\n      margin-top: 2rem;\n    }\n  }\n\n  .ecommerce-footer-links-block {\n\n    @include breakpoint(medium down) {\n      margin-bottom: 3rem;\n    }\n  }\n}\n\n.ecommerce-footer-bottom-bar {\n  border-top: 1px solid $light-gray;\n  margin-top: 40px;\n  padding-bottom: 80px;\n  padding-top: 30px;\n\n  .menu > li > a {\n    line-height: 1.2em;\n    padding: 10px 0;\n  }\n\n  a {\n    color: $dark-gray;\n    font-size: 0.9rem;\n    transition: all 0.5s ease;\n  }\n\n  a:hover {\n    color: $black;\n    transition: all 0.5s ease;\n  }\n\n  ul {\n    @include breakpoint(small down) {\n      text-align: center;\n    }\n  }\n\n  li {\n    display: inline;\n  }\n\n  .bottom-links {\n    margin-top: 0.65rem;\n    margin-left: 0;\n  }\n\n  .bottom-links li {\n    padding-right: 2rem;\n\n    @include breakpoint(small down) {\n      text-align: center;\n    }\n  }\n\n  .ecommerce-footer-logomark {\n    text-align: center;\n\n    @include breakpoint(small down) {\n      padding-top: 1rem;\n      margin-bottom: 1rem;\n    }\n  }\n\n  .bottom-copyright {\n    color: $dark-gray;\n    font-size: 0.9rem;\n    line-height: 1.2em; \n    padding-top: 1rem;\n    text-align: right;\n\n    @include breakpoint(small down) {\n      text-align: center; \n    }\n  }\n}\n","$pagination-circular-size: 18px; // controls font and circle size\n$pagination-circular-color: $primary-color;\n$pagination-circular-disabled-color: $medium-gray;\n$pagination-circular-border-thickness: 1px;\n\n\n.pagination-circular li.current {\n  border: $pagination-circular-border-thickness solid $pagination-circular-color;\n  border-radius: 5000px;\n  padding: 0.285em 0.8em;\n  font-size: $pagination-circular-size;\n}\n\n.pagination-circular li.disabled {\n  border: $pagination-circular-border-thickness solid $pagination-circular-disabled-color;\n  padding: 0.285em 0.8em;\n  border-radius: 5000px;\n  font-size: $pagination-circular-size;\n}\n\n.pagination-circular a {\n  border-radius: 5000px;\n  padding: 0.285em 0.8em;\n  border: $pagination-circular-border-thickness solid $pagination-circular-color;\n  font-size: $pagination-circular-size;\n}\n\n.pagination-circular li:not(.disabled):hover a {\n  background: $pagination-circular-color;\n  color: $white;\n}\n\n.pagination-circular li a {\n  transition: background 0.15s ease-in, color 0.15s ease-in;\n}\n","$white: #fff;\n$pagination-primary-color: #2c3840;\n$pagination-current-color: dodgerblue;\n$pagination-radius: 4px;\n\n.pagination-pointed {\n  .pagination-pointed-button {\n    position: relative;\n    display: inline-block;\n    padding: 6px 12px;\n    margin-bottom: 0;\n    text-align: center;\n    white-space: nowrap;\n    vertical-align: middle;\n    cursor: pointer;\n    background-image: none;\n    border: 1px solid transparent;\n    border-radius: $pagination-radius;\n    background-color: $pagination-primary-color;\n    color: $white;\n    outline: 0;\n    text-decoration: none;\n    transition: all 0.2s linear;\n\n    &:hover {\n      background-color: lighten($pagination-primary-color, 10%);\n    }\n  }\n\n  .current {\n    @extend .pagination-pointed-button;\n    background: $pagination-current-color;\n\n    &:hover {\n      background-color: darken($pagination-current-color, 10%);\n    }\n  }\n\n  .pagination-next a {\n    border-radius: $pagination-radius 0 0 $pagination-radius;\n    margin-right: 18px;\n\n    &:hover::after {\n      border-left: 17px solid lighten($pagination-primary-color, 10%);\n    }\n\n    &::after {\n      content: \"\";\n      position: absolute;\n      top: 0;\n      right: -18px;\n      width: 0;\n      height: 0;\n      border-top: 17px solid transparent;\n      border-bottom: 17px solid transparent;\n      border-left: 17px solid $pagination-primary-color;\n      transition: all 0.2s linear;\n    }\n  }\n\n  .pagination-previous {\n    @extend .pagination-pointed-button;\n    border-radius: 0 $pagination-radius $pagination-radius 0;\n    margin-left: 18px;\n\n    &:hover::after {\n      border-right: 17px solid lighten($pagination-primary-color, 10%);\n    }\n\n    &::before {\n      content: \"\"; //removes the arrow\n    }\n\n    &::after {\n      content: \"\";\n      position: absolute;\n      top: 0;\n      left: -18px;\n      width: 0;\n      height: 0;\n      border-bottom: 17px solid transparent;\n      border-top: 17px solid transparent;\n      border-right: 17px solid $pagination-primary-color;\n      transition: all 0.2s linear;\n    }\n  }\n}\n","$tag-cloud-tag-color: #2c3840;\n$tag-cloud-type-color: $light-gray;\n$tag-cloud-separator-color: $medium-gray;\n$tag-cloud-section-bg: lighten($tag-cloud-tag-color, 35%);\n$tag-cloud-section-width: 800px;\n\n.tag-cloud-section {\n  background: $tag-cloud-section-bg;\n  padding: 4rem;\n  max-width: $tag-cloud-section-width;\n  margin: 0 auto;\n}\n\n.tag-cloud-title {\n  text-align: center;\n  text-transform: uppercase;\n  font-weight: bold;\n  color: $tag-cloud-type-color;\n  border-bottom: 1px solid $tag-cloud-separator-color;\n  padding: 1rem 0;\n  margin-bottom: 1rem;\n}\n\n.tag-cloud {\n  margin: 1rem;\n  text-align: center;\n  list-style: none;\n\n  .tag-cloud-individual-tag {\n    @include label;\n    border-radius: 5000px;\n    background: $tag-cloud-tag-color;\n    display: inline-block;\n    color: $tag-cloud-type-color;\n    margin: 3px;\n    text-transform: uppercase;\n    font-weight: bold;\n\n    .fa {\n      margin-left: 7px;\n      color: $tag-cloud-type-color;\n    }\n\n    &:hover {\n      background: darken($tag-cloud-tag-color, 25%);\n      transition: background-color .2s ease-in;\n    }\n  }\n}\n","// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$social-brand-youtube: #bb0000;\n$social-brand-instagram: #125688;\n$social-brand-pinterest: #cb2027;\n$social-brand-google-plus: #dd4b39;\n$social-brand-github: #000000;\n$social-brand-tumblr: #32506d;\n\n.social {\n  margin-right: .25rem;\n\n  &.facebook {\n    @include button-style($social-brand-facebook, auto, $white);\n  }\n  &.twitter {\n    @include button-style($social-brand-twitter, auto, $white);\n  }\n  &.linkedin {\n    @include button-style($social-brand-linkedin, auto, $white);\n  }\n  &.youtube {\n    @include button-style($social-brand-youtube, auto, $white);\n  }\n  &.instagram {\n    @include button-style($social-brand-instagram, auto, $white);\n  }\n  &.pinterest {\n    @include button-style($social-brand-pinterest, auto, $white);\n  }\n  &.google-plus {\n    @include button-style($social-brand-google-plus, auto, $white);\n  }\n  &.github {\n    @include button-style($social-brand-github, auto, $white);\n  }\n  &.tumblr {\n    @include button-style($social-brand-tumblr, auto, $white);\n  }\n\n  > .fa {\n    color: $white;\n    margin-right: .25rem;\n  }\n}\n","$polls-question-label-color: $primary-color;\n$polls-submit-button-transform: uppercase;\n\n.polls {\n  margin-bottom: 1rem;\n  .polls-question {\n    margin-bottom: .5rem;\n    .polls-question-label {\n      color: $polls-question-label-color;\n      font-weight: 500;\n      margin-right: .25rem;\n    }\n  }\n\n  .polls-submit {\n    margin-top: .3rem;\n    .button {\n      margin-right: .5rem;\n      text-transform: $polls-submit-button-transform;\n    }\n  }\n}\n","$social-button-size: 2.5rem;\n$social-button-border-width: .125rem;\n$social-button-font-size: 1.25rem;\n$social-button-line-height: 1.8em;\n$social-button-border-radius: 1.6875rem;\n$social-button-transition: 0.5s ease all;\n$social-button-margin: .25rem;\n\n// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-linkedin: #007bb5;\n$social-brand-google-plus: #dd4b39;\n\n@mixin social-button($brand-color, $brand-icon) {\n  background: $brand-color;\n\n  &:before {\n    font-family: \"FontAwesome\";\n    content: $brand-icon;\n  }\n  &:hover,\n  &:focus {\n    color: $brand-color;\n    background: $white;\n    border-color: $brand-color;\n  }\n}\n\n.news-image-gallery-container {\n  background-color: $white;\n  padding: 2rem 1.5rem 1rem;\n  \n  .rounded-social-buttons {\n    text-align: left;\n\n    .social-button {\n      display: inline-block;\n      position: relative;\n      cursor: pointer;\n      width: $social-button-size;\n      height: $social-button-size;\n      border: $social-button-border-width solid transparent;\n      padding: 0;\n      text-decoration: none;\n      text-align: center;\n      color: $white;\n      font-size: $social-button-font-size;\n      font-weight: normal;\n      line-height: $social-button-line-height;\n      border-radius: $social-button-border-radius;\n      transition: $social-button-transition;\n      margin-right: $social-button-margin;\n      margin-bottom: $social-button-margin;\n\n      &:hover,\n      &:focus {\n        transform: rotate(360deg);\n      }\n\n      &.facebook {\n        @include social-button($social-brand-facebook, \"\\f09a\")\n      }\n      &.twitter {\n        @include social-button($social-brand-twitter, \"\\f099\")\n      }\n      &.linkedin {\n        @include social-button($social-brand-linkedin, \"\\f0e1\")\n      }\n      &.google-plus {\n        @include social-button($social-brand-google-plus, \"\\f0d5\")\n      }\n    }\n  }\n\n  .news-image-gallery-title {\n    margin-top: .5rem;\n  }\n\n  .read-more {\n    color: $dark-gray;\n  }\n}\n","$quote-inline-width: rem-calc(350);\n\n.quote-inline-wrap-article-content {\n  max-width: 100%;\n  position: relative;\n}\n\n.quote-inline-wrap {\n  float: left;\n  max-width: $quote-inline-width;\n  padding: 0 1rem 1rem 0;\n\n  .quote-inline-marks {\n    font-size: rem-calc(100);\n    color: $dark-gray;\n    line-height: 1rem;\n  }\n\n  .quote-inline-testimonial {\n    border-radius: 5px;\n\n    p {\n      font-weight: 300;\n    }\n  }\n\n  .quote-inline-person {\n    margin-bottom: 1.5rem;\n\n    .quote-inline-photo img {\n      border-radius: 50%;\n      width: rem-calc(70);\n      height: rem-calc(70);\n      float: left;\n      margin-right: 1rem;\n    }\n\n    p {\n      position: relative;\n      top: 5px;\n\n      &:nth-child(2) {\n        font-size: 1rem;\n        font-weight: 500;\n        margin-bottom: 0;\n      }\n\n      &:nth-child(3) {\n        font-size: 0.875rem;\n        font-weight: 400;\n        color: $dark-gray;\n      }\n    }\n  }\n\n  @include breakpoint(medium down) {\n    width: 100%;\n    float: none;\n    display: block;\n  }\n}\n","$social-button-size: 3.125rem;\n$social-button-border-width: 0.125rem;\n$social-button-font-size: 1.5625rem;\n$social-button-line-height: 2em;\n$social-button-border-radius: 1.6875rem;\n$social-button-transition: all 0.5s ease;\n$social-button-margin: 0.75rem;\n\n// Source: https://designpieces.com/2012/12/social-media-colours-hex-and-rgb/\n$social-brand-facebook: #3b5998;\n$social-brand-twitter: #55acee;\n$social-brand-google-plus: #dd4b39;\n\n@mixin social-button($brand-color, $brand-icon) {\n  background: $brand-color;\n\n  &:before {\n    font-family: \"FontAwesome\";\n    content: $brand-icon;\n  }\n\n  &:hover,\n  &:focus {\n    color: $brand-color;\n    background: $white;\n    border-color: $brand-color;\n  }\n}\n\n\n.neat-article-container {\n  margin-top: 1.5rem;\n\n  .neat-article-header {\n    width: 100%;\n    display: flex;\n    align-items: flex-start;\n\n    .article-header-avatar {\n      padding-right: 0.5rem;\n      padding-left: 0.5rem;\n\n      .header-avatar {\n        width: rem-calc(60);\n        height: rem-calc(60);\n        border-radius: 50%;\n      }\n    }\n\n    .article-header-author {\n      flex: 1 0 0;\n\n      .author-name {\n        color: $black;\n        margin-bottom: 0;\n      }\n\n      .author-description,\n      .article-date-read {\n        color: $dark-gray;\n        margin-bottom: 0;\n        font-size: 0.85em;\n      }\n    }\n  }\n\n  .neat-article-title {\n    margin-top: 1rem;\n\n    .article-title {\n      color: $black;\n      font-weight: 600;\n    }\n  }\n\n  .neat-article-image {\n    margin-top: 1.5rem;\n\n    .article-image {\n      width: 100%;\n      height: 100vh;\n\n      @include breakpoint(medium only) {\n        height: 65vh;\n      }\n\n      @include breakpoint(small only) {\n        height: 45vh;\n      }\n    }\n  }\n\n  .neat-article-content {\n    margin-top: 2rem;\n\n    .article-social {\n      .rounded-social-buttons {\n        text-align: center;\n\n        .social-button {\n          display: block;\n          position: relative;\n          cursor: pointer;\n          width: $social-button-size;\n          height: $social-button-size;\n          border: $social-button-border-width solid transparent;\n          padding: 0;\n          text-decoration: none;\n          text-align: center;\n          color: $white;\n          font-size: $social-button-font-size;\n          font-weight: normal;\n          line-height: $social-button-line-height;\n          border-radius: $social-button-border-radius;\n          transition: $social-button-transition;\n          margin-right: $social-button-margin;\n          margin-bottom: $social-button-margin;\n\n          &:hover,\n          &:focus {\n            transform: rotate(360deg);\n          }\n\n          &.facebook {\n            @include social-button($social-brand-facebook, \"\\f09a\")\n          }\n\n          &.twitter {\n            @include social-button($social-brand-twitter, \"\\f099\")\n          }\n\n          &.google-plus {\n            @include social-button($social-brand-google-plus, \"\\f0d5\")\n          }\n        }\n      }\n    }\n\n    .article-content {\n      color: $black;\n    }\n  }\n}\n\n\n",".article-row-section {\n  @include flex-grid-row(null, $global-width, 12);\n  justify-content: left;\n}\n\n.article-row-section-inner {\n  @include flex-grid-column(12);\n\n  @include breakpoint(medium) {\n    @include flex-grid-column(10);\n  }\n}\n\n.article-row-section-header {\n  padding: 1.5rem 0;\n  margin: 0;\n  line-height: 1;\n}\n\n.article-row {\n  display: flex;\n  flex-direction: column;\n // border-top: 1px solid $light-gray;\n  padding: 1.5rem 0;\n\n   @include breakpoint(medium) {\n    flex-direction: row;\n  }\n}\n\n.article-row-img img {\n  width: 100%;\n\n  @include breakpoint(medium) {\n    max-width: none;\n    width: auto;\n  }\n}\n\n.article-row-content {\n  padding: 1.5rem 0 0;\n  color: $body-font-color;\n\n  @include breakpoint(medium) {\n    padding: 0 0 0 1.5rem;\n  }\n}\n\n.article-row-header {\n  padding: 1.5rem 0 0;\n  color: $body-font-color;\n\n  @include breakpoint(medium) {\n    padding: 0 0 0 1.5rem;\n  }\n}\n\n.article-row-content-header {\n  font-size: 1.5rem;\n}\n\n.article-row-content-description {\n  font-size: 1.25rem;\n}\n\n.article-row-content-author,\n.article-row-content-time {\n  font-size: 0.875rem;\n  margin-bottom: 0;\n  color: $dark-gray;\n}\n\n.article-row-reversed {\n  .article-row-content {\n    order: 2;\n    padding: 0 1.5rem 0 0;\n  }\n\n  .article-row-img {\n    order: 1;\n    padding: 0 0 1.5rem 0;\n  }\n\n  @include breakpoint(medium) {\n    .article-row-content {\n      order: 1;\n    }\n\n    .article-row-img {\n      order: 2;\n    }\n  }\n}\n","// Foundation for Sites\n// https://get.foundation\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 {Boolean} $wrap [true] - Set to `false` to have row wrapping behavior set to nowrap\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: 0;\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      .row {\n        margin-right: auto;\n        margin-left: auto;\n      }\n    }\n\n    &:not(.expanded) .row {\n      @include grid-row-size(expand);\n    }\n\n    &.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  @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    // 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      // 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","$hero-height: 60vh;\n\n\n$hero-height: 60vh;\n\n.hero-section {\n  background: url('https://static.pexels.com/photos/248064/pexels-photo-248064.jpeg') 50% no-repeat;\n  background-size: cover;\n  height: $hero-height;\n  text-align: center;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n\n  .hero-section-text {\n    color: $white;\n    text-shadow: 1px 1px 2px $black;\n  }\n}\n\n"]} */ diff --git a/static/app.js b/static/app.js new file mode 100644 index 0000000..b675dd4 --- /dev/null +++ b/static/app.js @@ -0,0 +1,22644 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = ""; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 1); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./node_modules/foundation-sites/dist/js/foundation.esm.js": +/*!*****************************************************************!*\ + !*** ./node_modules/foundation-sites/dist/js/foundation.esm.js ***! + \*****************************************************************/ +/*! exports provided: default, Abide, Accordion, AccordionMenu, Box, Core, CoreUtils, Drilldown, Dropdown, DropdownMenu, Equalizer, Foundation, Interchange, Keyboard, Magellan, MediaQuery, Motion, Move, Nest, OffCanvas, Orbit, ResponsiveAccordionTabs, ResponsiveMenu, ResponsiveToggle, Reveal, Slider, SmoothScroll, Sticky, Tabs, Timer, Toggler, Tooltip, Touch, Triggers, onImagesLoaded */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Abide", function() { return Abide; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Accordion", function() { return Accordion; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AccordionMenu", function() { return AccordionMenu; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Box", function() { return Box; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Core", function() { return Foundation; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CoreUtils", function() { return foundation_core_utils; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Drilldown", function() { return Drilldown; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Dropdown", function() { return Dropdown; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DropdownMenu", function() { return DropdownMenu; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Equalizer", function() { return Equalizer; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return Foundation; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Interchange", function() { return Interchange; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Keyboard", function() { return Keyboard; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Magellan", function() { return Magellan; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return MediaQuery; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Motion", function() { return Motion; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Move", function() { return Move; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Nest", function() { return Nest; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OffCanvas", function() { return OffCanvas; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Orbit", function() { return Orbit; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveAccordionTabs", function() { return ResponsiveAccordionTabs; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveMenu", function() { return ResponsiveMenu; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveToggle", function() { return ResponsiveToggle; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Reveal", function() { return Reveal; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Slider", function() { return Slider; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SmoothScroll", function() { return SmoothScroll; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Sticky", function() { return Sticky; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tabs", function() { return Tabs; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return Timer; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Toggler", function() { return Toggler; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tooltip", function() { return Tooltip; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Touch", function() { return Touch; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onImagesLoaded", function() { return onImagesLoaded; }); +/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "./node_modules/jquery/dist/jquery.js"); +/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__); +function _typeof2(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); } + + + +function _typeof(obj) { + if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") { + _typeof = function _typeof(obj) { + return _typeof2(obj); + }; + } else { + _typeof = function _typeof(obj) { + return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj); + }; + } + + return _typeof(obj); +} + +function _classCallCheck(instance, Constructor) { + if (!(instance instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } +} + +function _defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } +} + +function _createClass(Constructor, protoProps, staticProps) { + if (protoProps) _defineProperties(Constructor.prototype, protoProps); + if (staticProps) _defineProperties(Constructor, staticProps); + return Constructor; +} + +function _inherits(subClass, superClass) { + if (typeof superClass !== "function" && superClass !== null) { + throw new TypeError("Super expression must either be null or a function"); + } + + subClass.prototype = Object.create(superClass && superClass.prototype, { + constructor: { + value: subClass, + writable: true, + configurable: true + } + }); + if (superClass) _setPrototypeOf(subClass, superClass); +} + +function _getPrototypeOf(o) { + _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { + return o.__proto__ || Object.getPrototypeOf(o); + }; + return _getPrototypeOf(o); +} + +function _setPrototypeOf(o, p) { + _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { + o.__proto__ = p; + return o; + }; + + return _setPrototypeOf(o, p); +} + +function _assertThisInitialized(self) { + if (self === void 0) { + throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); + } + + return self; +} + +function _possibleConstructorReturn(self, call) { + if (call && (_typeof2(call) === "object" || typeof call === "function")) { + return call; + } + + return _assertThisInitialized(self); +} + +function _superPropBase(object, property) { + while (!Object.prototype.hasOwnProperty.call(object, property)) { + object = _getPrototypeOf(object); + if (object === null) break; + } + + return object; +} + +function _get(target, property, receiver) { + if (typeof Reflect !== "undefined" && Reflect.get) { + _get = Reflect.get; + } else { + _get = function _get(target, property, receiver) { + var base = _superPropBase(target, property); + + if (!base) return; + var desc = Object.getOwnPropertyDescriptor(base, property); + + if (desc.get) { + return desc.get.call(receiver); + } + + return desc.value; + }; + } + + return _get(target, property, receiver || target); +} + +function _slicedToArray(arr, i) { + return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest(); +} + +function _arrayWithHoles(arr) { + if (Array.isArray(arr)) return arr; +} + +function _iterableToArrayLimit(arr, i) { + var _arr = []; + var _n = true; + var _d = false; + var _e = undefined; + + try { + for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { + _arr.push(_s.value); + + if (i && _arr.length === i) break; + } + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i["return"] != null) _i["return"](); + } finally { + if (_d) throw _e; + } + } + + return _arr; +} + +function _nonIterableRest() { + throw new TypeError("Invalid attempt to destructure non-iterable instance"); +} +/** + * Returns a boolean for RTL support + */ + + +function rtl() { + return jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').attr('dir') === 'rtl'; +} +/** + * returns a random base-36 uid with namespacing + * @function + * @param {Number} length - number of random base-36 digits desired. Increase for more random strings. + * @param {String} namespace - name of plugin to be incorporated in uid, optional. + * @default {String} '' - if no plugin name is provided, nothing is appended to the uid. + * @returns {String} - unique id + */ + + +function GetYoDigits() { + var length = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 6; + var namespace = arguments.length > 1 ? arguments[1] : undefined; + var str = ''; + var chars = '0123456789abcdefghijklmnopqrstuvwxyz'; + var charsLength = chars.length; + + for (var i = 0; i < length; i++) { + str += chars[Math.floor(Math.random() * charsLength)]; + } + + return namespace ? "".concat(str, "-").concat(namespace) : str; +} +/** + * Escape a string so it can be used as a regexp pattern + * @function + * @see https://stackoverflow.com/a/9310752/4317384 + * + * @param {String} str - string to escape. + * @returns {String} - escaped string + */ + + +function RegExpEscape(str) { + return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&'); +} + +function transitionend($elem) { + var transitions = { + 'transition': 'transitionend', + 'WebkitTransition': 'webkitTransitionEnd', + 'MozTransition': 'transitionend', + 'OTransition': 'otransitionend' + }; + var elem = document.createElement('div'), + end; + + for (var transition in transitions) { + if (typeof elem.style[transition] !== 'undefined') { + end = transitions[transition]; + } + } + + if (end) { + return end; + } else { + setTimeout(function () { + $elem.triggerHandler('transitionend', [$elem]); + }, 1); + return 'transitionend'; + } +} +/** + * Return an event type to listen for window load. + * + * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered. + * If `handler` is passed, attach it to the event on `$elem`. + * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself. + * @function + * + * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed. + * @param {Function} [] handler - function to attach to the event. + * @returns {String} - event type that should or will be triggered. + */ + + +function onLoad($elem, handler) { + var didLoad = document.readyState === 'complete'; + var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad'; + + var cb = function cb() { + return $elem.triggerHandler(eventType); + }; + + if ($elem) { + if (handler) $elem.one(eventType, handler); + if (didLoad) setTimeout(cb);else jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', cb); + } + + return eventType; +} +/** + * Retuns an handler for the `mouseleave` that ignore disappeared mouses. + * + * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410), + * the event is ignored. + * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window + * (like by switching to an other window with [Alt]+[Tab]). + * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document + * outside of the element it left. + * + * @function + * + * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch. + * @param {Object} [] options - object of options: + * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows. + * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left. + * @returns {Function} - filtered handler to use to listen on the `mouseleave` event. + */ + + +function ignoreMousedisappear(handler) { + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow, + ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo, + _ref$ignoreReappear = _ref.ignoreReappear, + ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear; + + return function leaveEventHandler(eLeave) { + for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + rest[_key - 1] = arguments[_key]; + } + + var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere + + if (eLeave.relatedTarget !== null) { + return callback(); + } // Otherwise, check if the mouse actually left the window. + // In firefox if the user switched between windows, the window sill have the focus by the time + // the event is triggered. We have to debounce the event to test this case. + + + setTimeout(function leaveEventDebouncer() { + if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) { + return callback(); + } // Otherwise, wait for the mouse to reeapear outside of the element, + + + if (!ignoreReappear) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).one('mouseenter', function reenterEventHandler(eReenter) { + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(eLeave.currentTarget).has(eReenter.target).length) { + // Fill where the mouse finally entered. + eLeave.relatedTarget = eReenter.target; + callback(); + } + }); + } + }, 0); + }; +} + +var foundation_core_utils = /*#__PURE__*/Object.freeze({ + rtl: rtl, + GetYoDigits: GetYoDigits, + RegExpEscape: RegExpEscape, + transitionend: transitionend, + onLoad: onLoad, + ignoreMousedisappear: ignoreMousedisappear +}); // Authors & copyright © 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license + +/* eslint-disable */ + +window.matchMedia || (window.matchMedia = function () { + var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium + + if (!styleMedia) { + var style = document.createElement('style'), + script = document.getElementsByTagName('script')[0], + info = null; + style.type = 'text/css'; + style.id = 'matchmediajs-test'; + + if (!script) { + document.head.appendChild(style); + } else { + script.parentNode.insertBefore(style, script); + } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers + + + info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle; + styleMedia = { + matchMedium: function matchMedium(media) { + var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers + + if (style.styleSheet) { + style.styleSheet.cssText = text; + } else { + style.textContent = text; + } // Test if media query is true or false + + + return info.width === '1px'; + } + }; + } + + return function (media) { + return { + matches: styleMedia.matchMedium(media || 'all'), + media: media || 'all' + }; + }; +}()); +/* eslint-enable */ + +var MediaQuery = { + queries: [], + current: '', + + /** + * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher. + * @function + * @private + */ + _init: function _init() { + // make sure the initialization is only done once when calling _init() several times + if (this.isInitialized === true) { + return; + } else { + this.isInitialized = true; + } + + var self = this; + var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq'); + + if (!$meta.length) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('').appendTo(document.head); + } + + var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family'); + var namedQueries; + namedQueries = parseStyleToObject(extractedStyles); + self.queries = []; // reset + + for (var key in namedQueries) { + if (namedQueries.hasOwnProperty(key)) { + self.queries.push({ + name: key, + value: "only screen and (min-width: ".concat(namedQueries[key], ")") + }); + } + } + + this.current = this._getCurrentSize(); + + this._watcher(); + }, + + /** + * Reinitializes the media query helper. + * Useful if your CSS breakpoint configuration has just been loaded or has changed since the initialization. + * @function + * @private + */ + _reInit: function _reInit() { + this.isInitialized = false; + + this._init(); + }, + + /** + * Checks if the screen is at least as wide as a breakpoint. + * @function + * @param {String} size - Name of the breakpoint to check. + * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller. + */ + atLeast: function atLeast(size) { + var query = this.get(size); + + if (query) { + return window.matchMedia(query).matches; + } + + return false; + }, + + /** + * Checks if the screen is within the given breakpoint. + * If smaller than the breakpoint of larger than its upper limit it returns false. + * @function + * @param {String} size - Name of the breakpoint to check. + * @returns {Boolean} `true` if the breakpoint matches, `false` otherwise. + */ + only: function only(size) { + return size === this._getCurrentSize(); + }, + + /** + * Checks if the screen is within a breakpoint or smaller. + * @function + * @param {String} size - Name of the breakpoint to check. + * @returns {Boolean} `true` if the breakpoint matches, `false` if it's larger. + */ + upTo: function upTo(size) { + var nextSize = this.next(size); // If the next breakpoint does not match, the screen is smaller than + // the upper limit of this breakpoint. + + if (nextSize) { + return !this.atLeast(nextSize); + } // If there is no next breakpoint, the "size" breakpoint does not have + // an upper limit and the screen will always be within it or smaller. + + + return true; + }, + + /** + * Checks if the screen matches to a breakpoint. + * @function + * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method. + * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not. + */ + is: function is(size) { + var parts = size.trim().split(' ').filter(function (p) { + return !!p.length; + }); + + var _parts = _slicedToArray(parts, 2), + bpSize = _parts[0], + _parts$ = _parts[1], + bpModifier = _parts$ === void 0 ? '' : _parts$; // Only the breakpont + + + if (bpModifier === 'only') { + return this.only(bpSize); + } // At least the breakpoint (included) + + + if (!bpModifier || bpModifier === 'up') { + return this.atLeast(bpSize); + } // Up to the breakpoint (included) + + + if (bpModifier === 'down') { + return this.upTo(bpSize); + } + + throw new Error("\n Invalid breakpoint passed to MediaQuery.is().\n Expected a breakpoint name formatted like \" \", got \"".concat(size, "\".\n ")); + }, + + /** + * Gets the media query of a breakpoint. + * @function + * @param {String} size - Name of the breakpoint to get. + * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist. + */ + get: function get(size) { + for (var i in this.queries) { + if (this.queries.hasOwnProperty(i)) { + var query = this.queries[i]; + if (size === query.name) return query.value; + } + } + + return null; + }, + + /** + * Get the breakpoint following the given breakpoint. + * @function + * @param {String} size - Name of the breakpoint. + * @returns {String|null} - The name of the following breakpoint, or `null` if the passed breakpoint was the last one. + */ + next: function next(size) { + var _this = this; + + var queryIndex = this.queries.findIndex(function (q) { + return _this._getQueryName(q) === size; + }); + + if (queryIndex === -1) { + throw new Error("\n Unknown breakpoint \"".concat(size, "\" passed to MediaQuery.next().\n Ensure it is present in your Sass \"$breakpoints\" setting.\n ")); + } + + var nextQuery = this.queries[queryIndex + 1]; + return nextQuery ? nextQuery.name : null; + }, + + /** + * Returns the name of the breakpoint related to the given value. + * @function + * @private + * @param {String|Object} value - Breakpoint name or query object. + * @returns {String} Name of the breakpoint. + */ + _getQueryName: function _getQueryName(value) { + if (typeof value === 'string') return value; + if (_typeof(value) === 'object') return value.name; + throw new TypeError("\n Invalid value passed to MediaQuery._getQueryName().\n Expected a breakpoint name (String) or a breakpoint query (Object), got \"".concat(value, "\" (").concat(_typeof(value), ")\n ")); + }, + + /** + * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one). + * @function + * @private + * @returns {String} Name of the current breakpoint. + */ + _getCurrentSize: function _getCurrentSize() { + var matched; + + for (var i = 0; i < this.queries.length; i++) { + var query = this.queries[i]; + + if (window.matchMedia(query.value).matches) { + matched = query; + } + } + + return matched && this._getQueryName(matched); + }, + + /** + * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes. + * @function + * @private + */ + _watcher: function _watcher() { + var _this2 = this; + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () { + var newSize = _this2._getCurrentSize(), + currentSize = _this2.current; + + if (newSize !== currentSize) { + // Change the current media query + _this2.current = newSize; // Broadcast the media query change on the window + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]); + } + }); + } +}; // Thank you: https://github.com/sindresorhus/query-string + +function parseStyleToObject(str) { + var styleObject = {}; + + if (typeof str !== 'string') { + return styleObject; + } + + str = str.trim().slice(1, -1); // browsers re-quote string style values + + if (!str) { + return styleObject; + } + + styleObject = str.split('&').reduce(function (ret, param) { + var parts = param.replace(/\+/g, ' ').split('='); + var key = parts[0]; + var val = parts[1]; + key = decodeURIComponent(key); // missing `=` should be `null`: + // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters + + val = typeof val === 'undefined' ? null : decodeURIComponent(val); + + if (!ret.hasOwnProperty(key)) { + ret[key] = val; + } else if (Array.isArray(ret[key])) { + ret[key].push(val); + } else { + ret[key] = [ret[key], val]; + } + + return ret; + }, {}); + return styleObject; +} + +var FOUNDATION_VERSION = '6.6.3'; // Global Foundation object +// This is attached to the window, or used as a module for AMD/Browserify + +var Foundation = { + version: FOUNDATION_VERSION, + + /** + * Stores initialized plugins. + */ + _plugins: {}, + + /** + * Stores generated unique ids for plugin instances + */ + _uuids: [], + + /** + * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing. + * @param {Object} plugin - The constructor of the plugin. + */ + plugin: function plugin(_plugin, name) { + // Object key to use when adding to global Foundation object + // Examples: Foundation.Reveal, Foundation.OffCanvas + var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin + // Examples: data-reveal, data-off-canvas + + var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing) + + this._plugins[attrName] = this[className] = _plugin; + }, + + /** + * @function + * Populates the _uuids array with pointers to each individual plugin instance. + * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls. + * Also fires the initialization event for each plugin, consolidating repetitive code. + * @param {Object} plugin - an instance of a plugin, usually `this` in context. + * @param {String} name - the name of the plugin, passed as a camelCased string. + * @fires Plugin#init + */ + registerPlugin: function registerPlugin(plugin, name) { + var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase(); + plugin.uuid = GetYoDigits(6, pluginName); + + if (!plugin.$element.attr("data-".concat(pluginName))) { + plugin.$element.attr("data-".concat(pluginName), plugin.uuid); + } + + if (!plugin.$element.data('zfPlugin')) { + plugin.$element.data('zfPlugin', plugin); + } + /** + * Fires when the plugin has initialized. + * @event Plugin#init + */ + + + plugin.$element.trigger("init.zf.".concat(pluginName)); + + this._uuids.push(plugin.uuid); + + return; + }, + + /** + * @function + * Removes the plugins uuid from the _uuids array. + * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute. + * Also fires the destroyed event for the plugin, consolidating repetitive code. + * @param {Object} plugin - an instance of a plugin, usually `this` in context. + * @fires Plugin#destroyed + */ + unregisterPlugin: function unregisterPlugin(plugin) { + var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor)); + + this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1); + + plugin.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin') + /** + * Fires when the plugin has been destroyed. + * @event Plugin#destroyed + */ + .trigger("destroyed.zf.".concat(pluginName)); + + for (var prop in plugin) { + plugin[prop] = null; //clean up script to prep for garbage collection. + } + + return; + }, + + /** + * @function + * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc. + * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'` + * @default If no argument is passed, reflow all currently active plugins. + */ + reInit: function reInit(plugins) { + var isJQ = plugins instanceof jquery__WEBPACK_IMPORTED_MODULE_0___default.a; + + try { + if (isJQ) { + plugins.each(function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('zfPlugin')._init(); + }); + } else { + var type = _typeof(plugins), + _this = this, + fns = { + 'object': function object(plgs) { + plgs.forEach(function (p) { + p = hyphenate(p); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + p + ']').foundation('_init'); + }); + }, + 'string': function string() { + plugins = hyphenate(plugins); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + plugins + ']').foundation('_init'); + }, + 'undefined': function undefined$1() { + this['object'](Object.keys(_this._plugins)); + } + }; + + fns[type](plugins); + } + } catch (err) { + console.error(err); + } finally { + return plugins; + } + }, + + /** + * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized. + * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object. + * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything. + */ + reflow: function reflow(elem, plugins) { + // If plugins is undefined, just grab everything + if (typeof plugins === 'undefined') { + plugins = Object.keys(this._plugins); + } // If plugins is a string, convert it to an array with one item + else if (typeof plugins === 'string') { + plugins = [plugins]; + } + + var _this = this; // Iterate through each plugin + + + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(plugins, function (i, name) { + // Get the current plugin + var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document + + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']').filter(function () { + return typeof jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data("zfPlugin") === 'undefined'; + }); // For each plugin found, initialize it + + $elem.each(function () { + var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + opts = { + reflow: true + }; + + if ($el.attr('data-options')) { + $el.attr('data-options').split(';').forEach(function (option, _index) { + var opt = option.split(':').map(function (el) { + return el.trim(); + }); + if (opt[0]) opts[opt[0]] = parseValue(opt[1]); + }); + } + + try { + $el.data('zfPlugin', new plugin(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), opts)); + } catch (er) { + console.error(er); + } finally { + return; + } + }); + }); + }, + getFnName: functionName, + addToJquery: function addToJquery($) { + // TODO: consider not making this a jQuery function + // TODO: need way to reflow vs. re-initialize + + /** + * The Foundation jQuery method. + * @param {String|Array} method - An action to perform on the current jQuery object. + */ + var foundation = function foundation(method) { + var type = _typeof(method), + $noJS = $('.no-js'); + + if ($noJS.length) { + $noJS.removeClass('no-js'); + } + + if (type === 'undefined') { + //needs to initialize the Foundation object, or an individual plugin. + MediaQuery._init(); + + Foundation.reflow(this); + } else if (type === 'string') { + //an individual method to invoke on a plugin or group of plugins + var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary + + var plugClass = this.data('zfPlugin'); //determine the class of plugin + + if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') { + //make sure both the class and method exist + if (this.length === 1) { + //if there's only one, call it directly. + plugClass[method].apply(plugClass, args); + } else { + this.each(function (i, el) { + //otherwise loop through the jQuery collection and invoke the method on each + plugClass[method].apply($(el).data('zfPlugin'), args); + }); + } + } else { + //error for no class or no method + throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.'); + } + } else { + //error for invalid argument type + throw new TypeError("We're sorry, ".concat(type, " is not a valid parameter. You must use a string representing the method you wish to invoke.")); + } + + return this; + }; + + $.fn.foundation = foundation; + return $; + } +}; +Foundation.util = { + /** + * Function for applying a debounce effect to a function call. + * @function + * @param {Function} func - Function to be called at end of timeout. + * @param {Number} delay - Time in ms to delay the call of `func`. + * @returns function + */ + throttle: function throttle(func, delay) { + var timer = null; + return function () { + var context = this, + args = arguments; + + if (timer === null) { + timer = setTimeout(function () { + func.apply(context, args); + timer = null; + }, delay); + } + }; + } +}; +window.Foundation = Foundation; // Polyfill for requestAnimationFrame + +(function () { + if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () { + return new Date().getTime(); + }; + var vendors = ['webkit', 'moz']; + + for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) { + var vp = vendors[i]; + window.requestAnimationFrame = window[vp + 'RequestAnimationFrame']; + window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame']; + } + + if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) { + var lastTime = 0; + + window.requestAnimationFrame = function (callback) { + var now = Date.now(); + var nextTime = Math.max(lastTime + 16, now); + return setTimeout(function () { + callback(lastTime = nextTime); + }, nextTime - now); + }; + + window.cancelAnimationFrame = clearTimeout; + } + /** + * Polyfill for performance.now, required by rAF + */ + + + if (!window.performance || !window.performance.now) { + window.performance = { + start: Date.now(), + now: function now() { + return Date.now() - this.start; + } + }; + } +})(); + +if (!Function.prototype.bind) { + Function.prototype.bind = function (oThis) { + if (typeof this !== 'function') { + // closest thing possible to the ECMAScript 5 + // internal IsCallable function + throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable'); + } + + var aArgs = Array.prototype.slice.call(arguments, 1), + fToBind = this, + fNOP = function fNOP() {}, + fBound = function fBound() { + return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments))); + }; + + if (this.prototype) { + // native functions don't have a prototype + fNOP.prototype = this.prototype; + } + + fBound.prototype = new fNOP(); + return fBound; + }; +} // Polyfill to get the name of a function in IE9 + + +function functionName(fn) { + if (typeof Function.prototype.name === 'undefined') { + var funcNameRegex = /function\s([^(]{1,})\(/; + var results = funcNameRegex.exec(fn.toString()); + return results && results.length > 1 ? results[1].trim() : ""; + } else if (typeof fn.prototype === 'undefined') { + return fn.constructor.name; + } else { + return fn.prototype.constructor.name; + } +} + +function parseValue(str) { + if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str); + return str; +} // Convert PascalCase to kebab-case +// Thank you: http://stackoverflow.com/a/8955580 + + +function hyphenate(str) { + return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); +} + +var Box = { + ImNotTouchingYou: ImNotTouchingYou, + OverlapArea: OverlapArea, + GetDimensions: GetDimensions, + GetExplicitOffsets: GetExplicitOffsets + /** + * Compares the dimensions of an element to a container and determines collision events with container. + * @function + * @param {jQuery} element - jQuery object to test for collisions. + * @param {jQuery} parent - jQuery object to use as bounding container. + * @param {Boolean} lrOnly - set to true to check left and right values only. + * @param {Boolean} tbOnly - set to true to check top and bottom values only. + * @default if no parent object passed, detects collisions with `window`. + * @returns {Boolean} - true if collision free, false if a collision in any direction. + */ + +}; + +function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) { + return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0; +} + +function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) { + var eleDims = GetDimensions(element), + topOver, + bottomOver, + leftOver, + rightOver; + + if (parent) { + var parDims = GetDimensions(parent); + bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height); + topOver = eleDims.offset.top - parDims.offset.top; + leftOver = eleDims.offset.left - parDims.offset.left; + rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width); + } else { + bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height); + topOver = eleDims.offset.top - eleDims.windowDims.offset.top; + leftOver = eleDims.offset.left - eleDims.windowDims.offset.left; + rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width); + } + + bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0); + topOver = Math.min(topOver, 0); + leftOver = Math.min(leftOver, 0); + rightOver = Math.min(rightOver, 0); + + if (lrOnly) { + return leftOver + rightOver; + } + + if (tbOnly) { + return topOver + bottomOver; + } // use sum of squares b/c we care about overlap area. + + + return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver); +} +/** + * Uses native methods to return an object of dimension values. + * @function + * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window. + * @returns {Object} - nested object of integer pixel values + * TODO - if element is window, return only those values. + */ + + +function GetDimensions(elem) { + elem = elem.length ? elem[0] : elem; + + if (elem === window || elem === document) { + throw new Error("I'm sorry, Dave. I'm afraid I can't do that."); + } + + var rect = elem.getBoundingClientRect(), + parRect = elem.parentNode.getBoundingClientRect(), + winRect = document.body.getBoundingClientRect(), + winY = window.pageYOffset, + winX = window.pageXOffset; + return { + width: rect.width, + height: rect.height, + offset: { + top: rect.top + winY, + left: rect.left + winX + }, + parentDims: { + width: parRect.width, + height: parRect.height, + offset: { + top: parRect.top + winY, + left: parRect.left + winX + } + }, + windowDims: { + width: winRect.width, + height: winRect.height, + offset: { + top: winY, + left: winX + } + } + }; +} +/** + * Returns an object of top and left integer pixel values for dynamically rendered elements, + * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where + * you don't know alignment, but generally from + * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment. + * @function + * @param {jQuery} element - jQuery object for the element being positioned. + * @param {jQuery} anchor - jQuery object for the element's anchor point. + * @param {String} position - a string relating to the desired position of the element, relative to it's anchor + * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element. + * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element. + * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset. + * TODO alter/rewrite to work with `em` values as well/instead of pixels + */ + + +function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) { + var $eleDims = GetDimensions(element), + $anchorDims = anchor ? GetDimensions(anchor) : null; + var topVal, leftVal; + + if ($anchorDims !== null) { + // set position related attribute + switch (position) { + case 'top': + topVal = $anchorDims.offset.top - ($eleDims.height + vOffset); + break; + + case 'bottom': + topVal = $anchorDims.offset.top + $anchorDims.height + vOffset; + break; + + case 'left': + leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset); + break; + + case 'right': + leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset; + break; + } // set alignment related attribute + + + switch (position) { + case 'top': + case 'bottom': + switch (alignment) { + case 'left': + leftVal = $anchorDims.offset.left + hOffset; + break; + + case 'right': + leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset; + break; + + case 'center': + leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset; + break; + } + + break; + + case 'right': + case 'left': + switch (alignment) { + case 'bottom': + topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height; + break; + + case 'top': + topVal = $anchorDims.offset.top + vOffset; + break; + + case 'center': + topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2; + break; + } + + break; + } + } + + return { + top: topVal, + left: leftVal + }; +} +/** + * Runs a callback function when images are fully loaded. + * @param {Object} images - Image(s) to check if loaded. + * @param {Func} callback - Function to execute when image is fully loaded. + */ + + +function onImagesLoaded(images, callback) { + var unloaded = images.length; + + if (unloaded === 0) { + callback(); + } + + images.each(function () { + // Check if image is loaded + if (this.complete && typeof this.naturalWidth !== 'undefined') { + singleImageLoaded(); + } else { + // If the above check failed, simulate loading on detached element. + var image = new Image(); // Still count image as loaded if it finalizes with an error. + + var events = "load.zf.images error.zf.images"; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(image).one(events, function me(event) { + // Unbind the event listeners. We're using 'one' but only one of the two events will have fired. + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off(events, me); + singleImageLoaded(); + }); + image.src = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('src'); + } + }); + + function singleImageLoaded() { + unloaded--; + + if (unloaded === 0) { + callback(); + } + } +} +/******************************************* + * * + * This util was created by Marius Olbertz * + * Please thank Marius on GitHub /owlbertz * + * or the web http://www.mariusolbertz.de/ * + * * + ******************************************/ + + +var keyCodes = { + 9: 'TAB', + 13: 'ENTER', + 27: 'ESCAPE', + 32: 'SPACE', + 35: 'END', + 36: 'HOME', + 37: 'ARROW_LEFT', + 38: 'ARROW_UP', + 39: 'ARROW_RIGHT', + 40: 'ARROW_DOWN' +}; +var commands = {}; // Functions pulled out to be referenceable from internals + +function findFocusable($element) { + if (!$element) { + return false; + } + + return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () { + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':visible') || jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('tabindex') < 0) { + return false; + } //only have visible elements and those that have a tabindex greater or equal 0 + + + return true; + }); +} + +function parseKey(event) { + var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events + + key = key.replace(/\W+/, ''); + if (event.shiftKey) key = "SHIFT_".concat(key); + if (event.ctrlKey) key = "CTRL_".concat(key); + if (event.altKey) key = "ALT_".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`) + + key = key.replace(/_$/, ''); + return key; +} + +var Keyboard = { + keys: getKeyCodes(keyCodes), + + /** + * Parses the (keyboard) event and returns a String that represents its key + * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE + * @param {Event} event - the event generated by the event handler + * @return String key - String that represents the key pressed + */ + parseKey: parseKey, + + /** + * Handles the given (keyboard) event + * @param {Event} event - the event generated by the event handler + * @param {String} component - Foundation component's name, e.g. Slider or Reveal + * @param {Objects} functions - collection of functions that are to be executed + */ + handleKey: function handleKey(event, component, functions) { + var commandList = commands[component], + keyCode = this.parseKey(event), + cmds, + command, + fn; + if (!commandList) return console.warn('Component not defined!'); // Ignore the event if it was already handled + + if (event.zfIsKeyHandled === true) return; // This component does not differentiate between ltr and rtl + + if (typeof commandList.ltr === 'undefined') { + cmds = commandList; // use plain list + } else { + // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa + if (rtl()) cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.rtl, commandList.ltr); + } + + command = cmds[keyCode]; + fn = functions[command]; // Execute the handler if found + + if (fn && typeof fn === 'function') { + var returnValue = fn.apply(); // Mark the event as "handled" to prevent future handlings + + event.zfIsKeyHandled = true; // Execute function when event was handled + + if (functions.handled || typeof functions.handled === 'function') { + functions.handled(returnValue); + } + } else { + // Execute function when event was not handled + if (functions.unhandled || typeof functions.unhandled === 'function') { + functions.unhandled(); + } + } + }, + + /** + * Finds all focusable elements within the given `$element` + * @param {jQuery} $element - jQuery object to search within + * @return {jQuery} $focusable - all focusable elements within `$element` + */ + findFocusable: findFocusable, + + /** + * Returns the component name name + * @param {Object} component - Foundation component, e.g. Slider or Reveal + * @return String componentName + */ + register: function register(componentName, cmds) { + commands[componentName] = cmds; + }, + // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context? + // + + /** + * Traps the focus in the given element. + * @param {jQuery} $element jQuery object to trap the foucs into. + */ + trapFocus: function trapFocus($element) { + var $focusable = findFocusable($element), + $firstFocusable = $focusable.eq(0), + $lastFocusable = $focusable.eq(-1); + $element.on('keydown.zf.trapfocus', function (event) { + if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') { + event.preventDefault(); + $firstFocusable.focus(); + } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') { + event.preventDefault(); + $lastFocusable.focus(); + } + }); + }, + + /** + * Releases the trapped focus from the given element. + * @param {jQuery} $element jQuery object to release the focus for. + */ + releaseFocus: function releaseFocus($element) { + $element.off('keydown.zf.trapfocus'); + } +}; +/* + * Constants for easier comparing. + * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE + */ + +function getKeyCodes(kcs) { + var k = {}; + + for (var kc in kcs) { + k[kcs[kc]] = kcs[kc]; + } + + return k; +} +/** + * Motion module. + * @module foundation.motion + */ + + +var initClasses = ['mui-enter', 'mui-leave']; +var activeClasses = ['mui-enter-active', 'mui-leave-active']; +var Motion = { + animateIn: function animateIn(element, animation, cb) { + animate(true, element, animation, cb); + }, + animateOut: function animateOut(element, animation, cb) { + animate(false, element, animation, cb); + } +}; + +function Move(duration, elem, fn) { + var anim, + prog, + start = null; // console.log('called'); + + if (duration === 0) { + fn.apply(elem); + elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]); + return; + } + + function move(ts) { + if (!start) start = ts; // console.log(start, ts); + + prog = ts - start; + fn.apply(elem); + + if (prog < duration) { + anim = window.requestAnimationFrame(move, elem); + } else { + window.cancelAnimationFrame(anim); + elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]); + } + } + + anim = window.requestAnimationFrame(move); +} +/** + * Animates an element in or out using a CSS transition class. + * @function + * @private + * @param {Boolean} isIn - Defines if the animation is in or out. + * @param {Object} element - jQuery or HTML object to animate. + * @param {String} animation - CSS class to use. + * @param {Function} cb - Callback to run when animation is finished. + */ + + +function animate(isIn, element, animation, cb) { + element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element).eq(0); + if (!element.length) return; + var initClass = isIn ? initClasses[0] : initClasses[1]; + var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation + + reset(); + element.addClass(animation).css('transition', 'none'); + requestAnimationFrame(function () { + element.addClass(initClass); + if (isIn) element.show(); + }); // Start the animation + + requestAnimationFrame(function () { + // will trigger the browser to synchronously calculate the style and layout + // also called reflow or layout thrashing + // see https://gist.github.com/paulirish/5d52fb081b3570c81e3a + element[0].offsetWidth; + element.css('transition', '').addClass(activeClass); + }); // Clean up the animation when it finishes + + element.one(transitionend(element), finish); // Hides the element (for out animations), resets the element, and runs a callback + + function finish() { + if (!isIn) element.hide(); + reset(); + if (cb) cb.apply(element); + } // Resets transitions and removes motion-specific classes + + + function reset() { + element[0].style.transitionDuration = 0; + element.removeClass("".concat(initClass, " ").concat(activeClass, " ").concat(animation)); + } +} + +var Nest = { + Feather: function Feather(menu) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf'; + menu.attr('role', 'menubar'); + menu.find('a').attr({ + 'role': 'menuitem' + }); + var items = menu.find('li').attr({ + 'role': 'none' + }), + subMenuClass = "is-".concat(type, "-submenu"), + subItemClass = "".concat(subMenuClass, "-item"), + hasSubClass = "is-".concat(type, "-submenu-parent"), + applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes. + + items.each(function () { + var $item = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $sub = $item.children('ul'); + + if ($sub.length) { + $item.addClass(hasSubClass); + + if (applyAria) { + $item.attr({ + 'aria-haspopup': true, + 'aria-label': $item.children('a:first').text() + }); // Note: Drilldowns behave differently in how they hide, and so need + // additional attributes. We should look if this possibly over-generalized + // utility (Nest) is appropriate when we rework menus in 6.4 + + if (type === 'drilldown') { + $item.attr({ + 'aria-expanded': false + }); + } + } + + $sub.addClass("submenu ".concat(subMenuClass)).attr({ + 'data-submenu': '', + 'role': 'menubar' + }); + + if (type === 'drilldown') { + $sub.attr({ + 'aria-hidden': true + }); + } + } + + if ($item.parent('[data-submenu]').length) { + $item.addClass("is-submenu-item ".concat(subItemClass)); + } + }); + return; + }, + Burn: function Burn(menu, type) { + var //items = menu.find('li'), + subMenuClass = "is-".concat(type, "-submenu"), + subItemClass = "".concat(subMenuClass, "-item"), + hasSubClass = "is-".concat(type, "-submenu-parent"); + menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass("".concat(subMenuClass, " ").concat(subItemClass, " ").concat(hasSubClass, " is-submenu-item submenu is-active")).removeAttr('data-submenu').css('display', ''); + } +}; + +function Timer(elem, options, cb) { + var _this = this, + duration = options.duration, + //options is an object for easily adding features later. + nameSpace = Object.keys(elem.data())[0] || 'timer', + remain = -1, + start, + timer; + + this.isPaused = false; + + this.restart = function () { + remain = -1; + clearTimeout(timer); + this.start(); + }; + + this.start = function () { + this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things. + + clearTimeout(timer); + remain = remain <= 0 ? duration : remain; + elem.data('paused', false); + start = Date.now(); + timer = setTimeout(function () { + if (options.infinite) { + _this.restart(); //rerun the timer. + + } + + if (cb && typeof cb === 'function') { + cb(); + } + }, remain); + elem.trigger("timerstart.zf.".concat(nameSpace)); + }; + + this.pause = function () { + this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things. + + clearTimeout(timer); + elem.data('paused', true); + var end = Date.now(); + remain = remain - (end - start); + elem.trigger("timerpaused.zf.".concat(nameSpace)); + }; +} + +var Touch = {}; +var startPosX, + startPosY, + startTime, + elapsedTime, + startEvent, + isMoving = false, + didMoved = false; + +function onTouchEnd(e) { + this.removeEventListener('touchmove', onTouchMove); + this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a "tap" + + if (!didMoved) { + var tapEvent = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('tap', startEvent || e); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(tapEvent); + } + + startEvent = null; + isMoving = false; + didMoved = false; +} + +function onTouchMove(e) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.preventDefault) { + e.preventDefault(); + } + + if (isMoving) { + var x = e.touches[0].pageX; + var y = e.touches[0].pageY; + var dx = startPosX - x; + var dir; + didMoved = true; + elapsedTime = new Date().getTime() - startTime; + + if (Math.abs(dx) >= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.moveThreshold && elapsedTime <= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.timeThreshold) { + dir = dx > 0 ? 'left' : 'right'; + } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) { + // dir = dy > 0 ? 'down' : 'up'; + // } + + + if (dir) { + e.preventDefault(); + onTouchEnd.apply(this, arguments); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('swipe', Object.assign({}, e)), dir).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event("swipe".concat(dir), Object.assign({}, e))); + } + } +} + +function onTouchStart(e) { + if (e.touches.length == 1) { + startPosX = e.touches[0].pageX; + startPosY = e.touches[0].pageY; + startEvent = e; + isMoving = true; + didMoved = false; + startTime = new Date().getTime(); + this.addEventListener('touchmove', onTouchMove, false); + this.addEventListener('touchend', onTouchEnd, false); + } +} + +function init() { + this.addEventListener && this.addEventListener('touchstart', onTouchStart, false); +} + +var SpotSwipe = /*#__PURE__*/function () { + function SpotSwipe($) { + _classCallCheck(this, SpotSwipe); + + this.version = '1.0.0'; + this.enabled = 'ontouchstart' in document.documentElement; + this.preventDefault = false; + this.moveThreshold = 75; + this.timeThreshold = 200; + this.$ = $; + + this._init(); + } + + _createClass(SpotSwipe, [{ + key: "_init", + value: function _init() { + var $ = this.$; + $.event.special.swipe = { + setup: init + }; + $.event.special.tap = { + setup: init + }; + $.each(['left', 'up', 'down', 'right'], function () { + $.event.special["swipe".concat(this)] = { + setup: function setup() { + $(this).on('swipe', $.noop); + } + }; + }); + } + }]); + + return SpotSwipe; +}(); +/**************************************************** + * As far as I can tell, both setupSpotSwipe and * + * setupTouchHandler should be idempotent, * + * because they directly replace functions & * + * values, and do not add event handlers directly. * + ****************************************************/ + + +Touch.setupSpotSwipe = function ($) { + $.spotSwipe = new SpotSwipe($); +}; +/**************************************************** + * Method for adding pseudo drag events to elements * + ***************************************************/ + + +Touch.setupTouchHandler = function ($) { + $.fn.addTouch = function () { + this.each(function (i, el) { + $(el).bind('touchstart touchmove touchend touchcancel', function (event) { + //we pass the original event object because the jQuery event + //object is normalized to w3c specs and does not provide the TouchList + handleTouch(event); + }); + }); + + var handleTouch = function handleTouch(event) { + var touches = event.changedTouches, + first = touches[0], + eventTypes = { + touchstart: 'mousedown', + touchmove: 'mousemove', + touchend: 'mouseup' + }, + type = eventTypes[event.type], + simulatedEvent; + + if ('MouseEvent' in window && typeof window.MouseEvent === 'function') { + simulatedEvent = new window.MouseEvent(type, { + 'bubbles': true, + 'cancelable': true, + 'screenX': first.screenX, + 'screenY': first.screenY, + 'clientX': first.clientX, + 'clientY': first.clientY + }); + } else { + simulatedEvent = document.createEvent('MouseEvent'); + simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0 + /*left*/ + , null); + } + + first.target.dispatchEvent(simulatedEvent); + }; + }; +}; + +Touch.init = function ($) { + if (typeof $.spotSwipe === 'undefined') { + Touch.setupSpotSwipe($); + Touch.setupTouchHandler($); + } +}; + +var MutationObserver = function () { + var prefixes = ['WebKit', 'Moz', 'O', 'Ms', '']; + + for (var i = 0; i < prefixes.length; i++) { + if ("".concat(prefixes[i], "MutationObserver") in window) { + return window["".concat(prefixes[i], "MutationObserver")]; + } + } + + return false; +}(); + +var triggers = function triggers(el, type) { + el.data(type).split(' ').forEach(function (id) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]); + }); +}; + +var Triggers = { + Listeners: { + Basic: {}, + Global: {} + }, + Initializers: {} +}; +Triggers.Listeners.Basic = { + openListener: function openListener() { + triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open'); + }, + closeListener: function closeListener() { + var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close'); + + if (id) { + triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close'); + } else { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger'); + } + }, + toggleListener: function toggleListener() { + var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle'); + + if (id) { + triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle'); + } else { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger'); + } + }, + closeableListener: function closeableListener(e) { + var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable'); // Only close the first closable element. See https://git.io/zf-7833 + + e.stopPropagation(); + + if (animation !== '') { + Motion.animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf'); + }); + } else { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf'); + } + }, + toggleFocusListener: function toggleFocusListener() { + var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]); + } +}; // Elements with [data-open] will reveal a plugin that supports it when clicked. + +Triggers.Initializers.addOpenListener = function ($elem) { + $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener); + $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener); +}; // Elements with [data-close] will close a plugin that supports it when clicked. +// If used without a value on [data-close], the event will bubble, allowing it to close a parent component. + + +Triggers.Initializers.addCloseListener = function ($elem) { + $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener); + $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener); +}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked. + + +Triggers.Initializers.addToggleListener = function ($elem) { + $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener); + $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener); +}; // Elements with [data-closable] will respond to close.zf.trigger events. + + +Triggers.Initializers.addCloseableListener = function ($elem) { + $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener); + $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener); +}; // Elements with [data-toggle-focus] will respond to coming in and out of focus + + +Triggers.Initializers.addToggleFocusListener = function ($elem) { + $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener); + $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener); +}; // More Global/complex listeners and triggers + + +Triggers.Listeners.Global = { + resizeListener: function resizeListener($nodes) { + if (!MutationObserver) { + //fallback for IE 9 + $nodes.each(function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger'); + }); + } //trigger all listening elements and signal a resize event + + + $nodes.attr('data-events', "resize"); + }, + scrollListener: function scrollListener($nodes) { + if (!MutationObserver) { + //fallback for IE 9 + $nodes.each(function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger'); + }); + } //trigger all listening elements and signal a scroll event + + + $nodes.attr('data-events', "scroll"); + }, + closeMeListener: function closeMeListener(e, pluginId) { + var plugin = e.namespace.split('.')[0]; + var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]")); + plugins.each(function () { + var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this); + + _this.triggerHandler('close.zf.trigger', [_this]); + }); + } // Global, parses whole document. + +}; + +Triggers.Initializers.addClosemeListener = function (pluginName) { + var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'), + plugNames = ['dropdown', 'tooltip', 'reveal']; + + if (pluginName) { + if (typeof pluginName === 'string') { + plugNames.push(pluginName); + } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') { + plugNames = plugNames.concat(pluginName); + } else { + console.error('Plugin names must be strings'); + } + } + + if (yetiBoxes.length) { + var listeners = plugNames.map(function (name) { + return "closeme.zf.".concat(name); + }).join(' '); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener); + } +}; + +function debounceGlobalListener(debounce, trigger, listener) { + var timer, + args = Array.prototype.slice.call(arguments, 3); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) { + if (timer) { + clearTimeout(timer); + } + + timer = setTimeout(function () { + listener.apply(null, args); + }, debounce || 10); //default time to emit scroll event + }); +} + +Triggers.Initializers.addResizeListener = function (debounce) { + var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]'); + + if ($nodes.length) { + debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes); + } +}; + +Triggers.Initializers.addScrollListener = function (debounce) { + var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]'); + + if ($nodes.length) { + debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes); + } +}; + +Triggers.Initializers.addMutationEventsListener = function ($elem) { + if (!MutationObserver) { + return false; + } + + var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback + + var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) { + var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type + + switch (mutationRecordsList[0].type) { + case "attributes": + if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") { + $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]); + } + + if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") { + $target.triggerHandler('resizeme.zf.trigger', [$target]); + } + + if (mutationRecordsList[0].attributeName === "style") { + $target.closest("[data-mutate]").attr("data-events", "mutate"); + $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]); + } + + break; + + case "childList": + $target.closest("[data-mutate]").attr("data-events", "mutate"); + $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]); + break; + + default: + return false; + //nothing + } + }; + + if ($nodes.length) { + //for each element that needs to listen for resizing, scrolling, or mutation add a single observer + for (var i = 0; i <= $nodes.length - 1; i++) { + var elementObserver = new MutationObserver(listeningElementsMutation); + elementObserver.observe($nodes[i], { + attributes: true, + childList: true, + characterData: false, + subtree: true, + attributeFilter: ["data-events", "style"] + }); + } + } +}; + +Triggers.Initializers.addSimpleListeners = function () { + var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document); + Triggers.Initializers.addOpenListener($document); + Triggers.Initializers.addCloseListener($document); + Triggers.Initializers.addToggleListener($document); + Triggers.Initializers.addCloseableListener($document); + Triggers.Initializers.addToggleFocusListener($document); +}; + +Triggers.Initializers.addGlobalListeners = function () { + var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document); + Triggers.Initializers.addMutationEventsListener($document); + Triggers.Initializers.addResizeListener(); + Triggers.Initializers.addScrollListener(); + Triggers.Initializers.addClosemeListener(); +}; + +Triggers.init = function ($, Foundation) { + onLoad($(window), function () { + if ($.triggersInitialized !== true) { + Triggers.Initializers.addSimpleListeners(); + Triggers.Initializers.addGlobalListeners(); + $.triggersInitialized = true; + } + }); + + if (Foundation) { + Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now. + + Foundation.IHearYou = Triggers.Initializers.addGlobalListeners; + } +}; // {function} _setup (replaces previous constructor), +// {function} _destroy (replaces previous destroy) + + +var Plugin = /*#__PURE__*/function () { + function Plugin(element, options) { + _classCallCheck(this, Plugin); + + this._setup(element, options); + + var pluginName = getPluginName(this); + this.uuid = GetYoDigits(6, pluginName); + + if (!this.$element.attr("data-".concat(pluginName))) { + this.$element.attr("data-".concat(pluginName), this.uuid); + } + + if (!this.$element.data('zfPlugin')) { + this.$element.data('zfPlugin', this); + } + /** + * Fires when the plugin has initialized. + * @event Plugin#init + */ + + + this.$element.trigger("init.zf.".concat(pluginName)); + } + + _createClass(Plugin, [{ + key: "destroy", + value: function destroy() { + this._destroy(); + + var pluginName = getPluginName(this); + this.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin') + /** + * Fires when the plugin has been destroyed. + * @event Plugin#destroyed + */ + .trigger("destroyed.zf.".concat(pluginName)); + + for (var prop in this) { + this[prop] = null; //clean up script to prep for garbage collection. + } + } + }]); + + return Plugin; +}(); // Convert PascalCase to kebab-case +// Thank you: http://stackoverflow.com/a/8955580 + + +function hyphenate$1(str) { + return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); +} + +function getPluginName(obj) { + return hyphenate$1(obj.className); +} +/** + * Abide module. + * @module foundation.abide + */ + + +var Abide = /*#__PURE__*/function (_Plugin) { + _inherits(Abide, _Plugin); + + function Abide() { + _classCallCheck(this, Abide); + + return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments)); + } + + _createClass(Abide, [{ + key: "_setup", + + /** + * Creates a new instance of Abide. + * @class + * @name Abide + * @fires Abide#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options); + this.isEnabled = true; + this.formnovalidate = null; + this.className = 'Abide'; // ie9 back compat + + this._init(); + } + /** + * Initializes the Abide plugin and calls functions to get Abide functioning on load. + * @private + */ + + }, { + key: "_init", + value: function _init() { + var _this2 = this; + + this.$inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.merge( // Consider as input to validate: + this.$element.find('input').not('[type="submit"]'), // * all input fields expect submit + this.$element.find('textarea, select') // * all textareas and select fields + ); + this.$submits = this.$element.find('[type="submit"]'); + var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields + + if (this.options.a11yAttributes) { + this.$inputs.each(function (i, input) { + return _this2.addA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(input)); + }); + $globalErrors.each(function (i, error) { + return _this2.addGlobalErrorA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(error)); + }); + } + + this._events(); + } + /** + * Initializes events for Abide. + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this3 = this; + + this.$element.off('.abide').on('reset.zf.abide', function () { + _this3.resetForm(); + }).on('submit.zf.abide', function () { + return _this3.validateForm(); + }); + this.$submits.off('click.zf.abide keydown.zf.abide').on('click.zf.abide keydown.zf.abide', function (e) { + if (!e.key || e.key === ' ' || e.key === 'Enter') { + e.preventDefault(); + _this3.formnovalidate = e.target.getAttribute('formnovalidate') !== null; + + _this3.$element.submit(); + } + }); + + if (this.options.validateOn === 'fieldChange') { + this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) { + _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target)); + }); + } + + if (this.options.liveValidate) { + this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) { + _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target)); + }); + } + + if (this.options.validateOnBlur) { + this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) { + _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target)); + }); + } + } + /** + * Calls necessary functions to update Abide upon DOM change + * @private + */ + + }, { + key: "_reflow", + value: function _reflow() { + this._init(); + } + /** + * Checks whether the submitted form should be validated or not, consodering formnovalidate and isEnabled + * @returns {Boolean} + * @private + */ + + }, { + key: "_validationIsDisabled", + value: function _validationIsDisabled() { + if (this.isEnabled === false) { + // whole validation disabled + return true; + } else if (typeof this.formnovalidate === 'boolean') { + // triggered by $submit + return this.formnovalidate; + } // triggered by Enter in non-submit input + + + return this.$submits.length ? this.$submits[0].getAttribute('formnovalidate') !== null : false; + } + /** + * Enables the whole validation + */ + + }, { + key: "enableValidation", + value: function enableValidation() { + this.isEnabled = true; + } + /** + * Disables the whole validation + */ + + }, { + key: "disableValidation", + value: function disableValidation() { + this.isEnabled = false; + } + /** + * Checks whether or not a form element has the required attribute and if it's checked or not + * @param {Object} element - jQuery object to check for required attribute + * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty + */ + + }, { + key: "requiredCheck", + value: function requiredCheck($el) { + if (!$el.attr('required')) return true; + var isGood = true; + + switch ($el[0].type) { + case 'checkbox': + isGood = $el[0].checked; + break; + + case 'select': + case 'select-one': + case 'select-multiple': + var opt = $el.find('option:selected'); + if (!opt.length || !opt.val()) isGood = false; + break; + + default: + if (!$el.val() || !$el.val().length) isGood = false; + } + + return isGood; + } + /** + * Get: + * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order: + * 1. The element's direct sibling('s). + * 2. The element's parent's children. + * - Element(s) with the attribute `[data-form-error-for]` set with the element's id. + * + * This allows for multiple form errors per input, though if none are found, no form errors will be shown. + * + * @param {Object} $el - jQuery object to use as reference to find the form error selector. + * @param {String[]} [failedValidators] - List of failed validators. + * @returns {Object} jQuery object with the selector. + */ + + }, { + key: "findFormError", + value: function findFormError($el, failedValidators) { + var _this4 = this; + + var id = $el.length ? $el[0].id : ''; + var $error = $el.siblings(this.options.formErrorSelector); + + if (!$error.length) { + $error = $el.parent().find(this.options.formErrorSelector); + } + + if (id) { + $error = $error.add(this.$element.find("[data-form-error-for=\"".concat(id, "\"]"))); + } + + if (!!failedValidators) { + $error = $error.not('[data-form-error-on]'); + failedValidators.forEach(function (v) { + $error = $error.add($el.siblings("[data-form-error-on=\"".concat(v, "\"]"))); + $error = $error.add(_this4.$element.find("[data-form-error-for=\"".concat(id, "\"][data-form-error-on=\"").concat(v, "\"]"))); + }); + } + + return $error; + } + /** + * Get the first element in this order: + * 2. The with the attribute `[for="someInputId"]` + * 3. The `.closest()` + * + * @param {Object} $el - jQuery object to check for required attribute + * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty + */ + + }, { + key: "findLabel", + value: function findLabel($el) { + var id = $el[0].id; + var $label = this.$element.find("label[for=\"".concat(id, "\"]")); + + if (!$label.length) { + return $el.closest('label'); + } + + return $label; + } + /** + * Get the set of labels associated with a set of radio els in this order + * 2. The with the attribute `[for="someInputId"]` + * 3. The `.closest()` + * + * @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 _this5 = this; + + var labels = $els.map(function (i, el) { + var id = el.id; + + var $label = _this5.$element.find("label[for=\"".concat(id, "\"]")); + + if (!$label.length) { + $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label'); + } + + return $label[0]; + }); + return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels); + } + /** + * Get the set of labels associated with a set of checkbox els in this order + * 2. The with the attribute `[for="someInputId"]` + * 3. The `.closest()` + * + * @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: "findCheckboxLabels", + value: function findCheckboxLabels($els) { + var _this6 = this; + + var labels = $els.map(function (i, el) { + var id = el.id; + + var $label = _this6.$element.find("label[for=\"".concat(id, "\"]")); + + if (!$label.length) { + $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label'); + } + + return $label[0]; + }); + return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels); + } + /** + * Adds the CSS error class as specified by the Abide settings to the label, input, and the form + * @param {Object} $el - jQuery object to add the class to + * @param {String[]} [failedValidators] - List of failed validators. + */ + + }, { + key: "addErrorClasses", + value: function addErrorClasses($el, failedValidators) { + var $label = this.findLabel($el); + var $formError = this.findFormError($el, failedValidators); + + if ($label.length) { + $label.addClass(this.options.labelErrorClass); + } + + if ($formError.length) { + $formError.addClass(this.options.formErrorClass); + } + + $el.addClass(this.options.inputErrorClass).attr({ + 'data-invalid': '', + 'aria-invalid': true + }); + } + /** + * Adds [for] and [role=alert] attributes to all form error targetting $el, + * and [aria-describedby] attribute to $el toward the first form error. + * @param {Object} $el - jQuery object + */ + + }, { + key: "addA11yAttributes", + value: function addA11yAttributes($el) { + var $errors = this.findFormError($el); + var $labels = $errors.filter('label'); + var $error = $errors.first(); + if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set + + if (typeof $el.attr('aria-describedby') === 'undefined') { + // Get the first error ID or create one + var errorId = $error.attr('id'); + + if (typeof errorId === 'undefined') { + errorId = GetYoDigits(6, 'abide-error'); + $error.attr('id', errorId); + } + + $el.attr('aria-describedby', errorId); + } + + if ($labels.filter('[for]').length < $labels.length) { + // Get the input ID or create one + var elemId = $el.attr('id'); + + if (typeof elemId === 'undefined') { + elemId = GetYoDigits(6, 'abide-input'); + $el.attr('id', elemId); + } // For each label targeting $el, set [for] if it is not set. + + + $labels.each(function (i, label) { + var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label); + if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId); + }); + } // For each error targeting $el, set [role=alert] if it is not set. + + + $errors.each(function (i, label) { + var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label); + if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert'); + }).end(); + } + /** + * Adds [aria-live] attribute to the given global form error $el. + * @param {Object} $el - jQuery object to add the attribute to + */ + + }, { + key: "addGlobalErrorA11yAttributes", + value: function addGlobalErrorA11yAttributes($el) { + if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel); + } + /** + * Remove CSS error classes etc from an entire radio button group + * @param {String} groupName - A string that specifies the name of a radio button group + * + */ + + }, { + key: "removeRadioErrorClasses", + value: function removeRadioErrorClasses(groupName) { + var $els = this.$element.find(":radio[name=\"".concat(groupName, "\"]")); + var $labels = this.findRadioLabels($els); + var $formErrors = this.findFormError($els); + + if ($labels.length) { + $labels.removeClass(this.options.labelErrorClass); + } + + if ($formErrors.length) { + $formErrors.removeClass(this.options.formErrorClass); + } + + $els.removeClass(this.options.inputErrorClass).attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + } + /** + * Remove CSS error classes etc from an entire checkbox group + * @param {String} groupName - A string that specifies the name of a checkbox group + * + */ + + }, { + key: "removeCheckboxErrorClasses", + value: function removeCheckboxErrorClasses(groupName) { + var $els = this.$element.find(":checkbox[name=\"".concat(groupName, "\"]")); + var $labels = this.findCheckboxLabels($els); + var $formErrors = this.findFormError($els); + + if ($labels.length) { + $labels.removeClass(this.options.labelErrorClass); + } + + if ($formErrors.length) { + $formErrors.removeClass(this.options.formErrorClass); + } + + $els.removeClass(this.options.inputErrorClass).attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + } + /** + * Removes CSS error class as specified by the Abide settings from the label, input, and the form + * @param {Object} $el - jQuery object to remove the class from + */ + + }, { + key: "removeErrorClasses", + value: function removeErrorClasses($el) { + // radios need to clear all of the els + if ($el[0].type == 'radio') { + return this.removeRadioErrorClasses($el.attr('name')); + } // checkboxes need to clear all of the els + else if ($el[0].type == 'checkbox') { + return this.removeCheckboxErrorClasses($el.attr('name')); + } + + var $label = this.findLabel($el); + var $formError = this.findFormError($el); + + if ($label.length) { + $label.removeClass(this.options.labelErrorClass); + } + + if ($formError.length) { + $formError.removeClass(this.options.formErrorClass); + } + + $el.removeClass(this.options.inputErrorClass).attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + } + /** + * Goes through a form to find inputs and proceeds to validate them in ways specific to their type. + * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set + * @fires Abide#invalid + * @fires Abide#valid + * @param {Object} element - jQuery object to validate, should be an HTML input + * @returns {Boolean} goodToGo - If the input is valid or not. + */ + + }, { + key: "validateInput", + value: function validateInput($el) { + var _this7 = this; + + var clearRequire = this.requiredCheck($el), + validator = $el.attr('data-validator'), + failedValidators = [], + manageErrorClasses = true; // skip validation if disabled + + if (this._validationIsDisabled()) { + return 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': + this.validateRadio($el.attr('name')) || failedValidators.push('required'); + break; + + case 'checkbox': + this.validateCheckbox($el.attr('name')) || failedValidators.push('required'); // validateCheckbox() adds/removes error classes + + manageErrorClasses = false; + break; + + case 'select': + case 'select-one': + case 'select-multiple': + clearRequire || failedValidators.push('required'); + break; + + default: + clearRequire || failedValidators.push('required'); + this.validateText($el) || failedValidators.push('pattern'); + } + + if (validator) { + var required = $el.attr('required') ? true : false; + validator.split(' ').forEach(function (v) { + _this7.options.validators[v]($el, required, $el.parent()) || failedValidators.push(v); + }); + } + + if ($el.attr('data-equalto')) { + this.options.validators.equalTo($el) || failedValidators.push('equalTo'); + } + + var goodToGo = failedValidators.length === 0; + var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide'; + + if (goodToGo) { + // Re-validate inputs that depend on this one with equalto + var dependentElements = this.$element.find("[data-equalto=\"".concat($el.attr('id'), "\"]")); + + if (dependentElements.length) { + var _this = this; + + dependentElements.each(function () { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()) { + _this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)); + } + }); + } + } + + if (manageErrorClasses) { + this.removeErrorClasses($el); + + if (!goodToGo) { + this.addErrorClasses($el, failedValidators); + } + } + /** + * 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 _this8 = this; + + var acc = []; + + var _this = this; + + var checkboxGroupName; // Remember first form submission to prevent specific checkbox validation (more than one required) until form got initially submitted + + if (!this.initialized) { + this.initialized = true; + } // skip validation if disabled + + + if (this._validationIsDisabled()) { + this.formnovalidate = null; + return true; + } + + this.$inputs.each(function () { + // Only use one checkbox per group since validateCheckbox() iterates over all associated checkboxes + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].type === 'checkbox') { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('name') === checkboxGroupName) return true; + checkboxGroupName = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('name'); + } + + acc.push(_this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this))); + }); + var noError = acc.indexOf(false) === -1; + this.$element.find('[data-abide-error]').each(function (i, elem) { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem); // Ensure a11y attributes are set + + if (_this8.options.a11yAttributes) _this8.addGlobalErrorA11yAttributes($elem); // Show or hide the error + + $elem.css('display', noError ? 'none' : 'block'); + }); + /** + * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`. + * Trigger includes the element of the form. + * @event Abide#formvalid + * @event Abide#forminvalid + */ + + this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]); + return noError; + } + /** + * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true. + * @param {Object} $el - jQuery object to validate, should be a text input HTML element + * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns + * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified + */ + + }, { + key: "validateText", + value: function validateText($el, pattern) { + // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute + pattern = pattern || $el.attr('data-pattern') || $el.attr('pattern') || $el.attr('type'); + var inputText = $el.val(); + var valid = true; + + 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); + } + } + + 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 ``, it validates by checking the `required` and `checked` properties of all radio buttons in its group. + * @param {String} groupName - A string that specifies the name of a radio button group + * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required) + */ + + }, { + key: "validateRadio", + value: function validateRadio(groupName) { + // If at least one radio in the group has the `required` attribute, the group is considered required + // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice + var $group = this.$element.find(":radio[name=\"".concat(groupName, "\"]")); + var valid = false, + required = false; // For the group to be required, at least one radio needs to be required + + $group.each(function (i, e) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) { + required = true; + } + }); + if (!required) valid = true; + + if (!valid) { + // For the group to be valid, at least one radio needs to be checked + $group.each(function (i, e) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) { + valid = true; + } + }); + } + + return valid; + } + /** + * Determines whether or a not a checkbox input is valid based on whether or not it is required and checked. Although the function targets a single ``, it validates by checking the `required` and `checked` properties of all checkboxes in its group. + * @param {String} groupName - A string that specifies the name of a checkbox group + * @returns {Boolean} Boolean value depends on whether or not at least one checkbox input has been checked (if it's required) + */ + + }, { + key: "validateCheckbox", + value: function validateCheckbox(groupName) { + var _this9 = this; // If at least one checkbox in the group has the `required` attribute, the group is considered required + // Per W3C spec, all checkboxes in a group should have `required`, but we're being nice + + + var $group = this.$element.find(":checkbox[name=\"".concat(groupName, "\"]")); + var valid = false, + required = false, + minRequired = 1, + checked = 0; // For the group to be required, at least one checkbox needs to be required + + $group.each(function (i, e) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) { + required = true; + } + }); + if (!required) valid = true; + + if (!valid) { + // Count checked checkboxes within the group + // Use data-min-required if available (default: 1) + $group.each(function (i, e) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) { + checked++; + } + + if (typeof jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('data-min-required') !== 'undefined') { + minRequired = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('data-min-required')); + } + }); // For the group to be valid, the minRequired amount of checkboxes have to be checked + + if (checked >= minRequired) { + valid = true; + } + } // Skip validation if more than 1 checkbox have to be checked AND if the form hasn't got submitted yet (otherwise it will already show an error during the first fill in) + + + if (this.initialized !== true && minRequired > 1) { + return true; + } // Refresh error class for all input + + + $group.each(function (i, e) { + if (!valid) { + _this9.addErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e), ['required']); + } else { + _this9.removeErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e)); + } + }); + 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 _this10 = this; + + required = required ? true : false; + var clear = validators.split(' ').map(function (v) { + return _this10.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; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass); + jquery__WEBPACK_IMPORTED_MODULE_0___default()("".concat(opts.formErrorSelector, ".").concat(opts.formErrorClass)).removeClass(opts.formErrorClass); + $form.find('[data-abide-error]').css('display', 'none'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({ + 'data-invalid': null, + 'aria-invalid': null + }); + /** + * Fires when the form has been reset. + * @event Abide#formreset + */ + + $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(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)); + }); + this.$submits.off('.abide'); + } + }]); + + return Abide; +}(Plugin); +/** + * Default settings for plugin + */ + + +Abide.defaults = { + /** + * The default event to validate inputs. Checkboxes and radios validate immediately. + * Remove or change this value for manual validation. + * @option + * @type {?string} + * @default 'fieldChange' + */ + validateOn: 'fieldChange', + + /** + * Class to be applied to input labels on failed validation. + * @option + * @type {string} + * @default 'is-invalid-label' + */ + labelErrorClass: 'is-invalid-label', + + /** + * Class to be applied to inputs on failed validation. + * @option + * @type {string} + * @default 'is-invalid-input' + */ + inputErrorClass: 'is-invalid-input', + + /** + * Class selector to use to target Form Errors for show/hide. + * @option + * @type {string} + * @default '.form-error' + */ + formErrorSelector: '.form-error', + + /** + * Class added to Form Errors on failed validation. + * @option + * @type {string} + * @default 'is-visible' + */ + formErrorClass: 'is-visible', + + /** + * If true, automatically insert when possible: + * - `[aria-describedby]` on fields + * - `[role=alert]` on form errors and `[for]` on form error labels + * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`). + * @option + * @type {boolean} + * @default true + */ + a11yAttributes: true, + + /** + * [aria-live] attribute value to be applied on global errors `[data-abide-error]`. + * Options are: 'assertive', 'polite' and 'off'/null + * @option + * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions + * @type {string} + * @default 'assertive' + */ + a11yErrorLevel: 'assertive', + + /** + * Set to true to validate text inputs on any value change. + * @option + * @type {boolean} + * @default false + */ + liveValidate: false, + + /** + * Set to true to validate inputs on blur. + * @option + * @type {boolean} + * @default false + */ + validateOnBlur: false, + patterns: { + alpha: /^[a-zA-Z]+$/, + alpha_numeric: /^[a-zA-Z0-9]+$/, + integer: /^[-+]?\d+$/, + number: /^[-+]?\d*(?:[\.\,]\d+)?$/, + // amex, visa, diners + card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/, + cvv: /^([0-9]){3,4}$/, + // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address + email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/, + // From CommonRegexJS (@talyssonoc) + // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76 + // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex. + url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/, + // abc.de + domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/, + datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/, + // YYYY-MM-DD + date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/, + // HH:MM:SS + time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/, + dateISO: /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/, + // MM/DD/YYYY + month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/, + // DD/MM/YYYY + day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/, + // #FFF or #FFFFFF + color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/, + // Domain || URL + website: { + test: function test(text) { + return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text); + } + } + }, + + /** + * Optional validation functions to be used. `equalTo` being the only default included function. + * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments: + * el : The jQuery element to validate. + * required : Boolean value of the required attribute be present or not. + * parent : The direct parent of the input. + * @option + */ + validators: { + equalTo: function equalTo(el, required, parent) { + return jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(el.attr('data-equalto'))).val() === el.val(); + } + } +}; +/** + * Accordion module. + * @module foundation.accordion + * @requires foundation.util.keyboard + */ + +var Accordion = /*#__PURE__*/function (_Plugin) { + _inherits(Accordion, _Plugin); + + function Accordion() { + _classCallCheck(this, Accordion); + + return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments)); + } + + _createClass(Accordion, [{ + key: "_setup", + + /** + * Creates a new instance of an accordion. + * @class + * @name Accordion + * @fires Accordion#init + * @param {jQuery} element - jQuery object to make into an accordion. + * @param {Object} options - a plain object with settings to override the default options. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Accordion.defaults, this.$element.data(), options); + this.className = 'Accordion'; // ie9 back compat + + this._init(); + + Keyboard.register('Accordion', { + 'ENTER': 'toggle', + 'SPACE': 'toggle', + 'ARROW_DOWN': 'next', + 'ARROW_UP': 'previous' + }); + } + /** + * Initializes the accordion by animating the preset active pane(s). + * @private + */ + + }, { + key: "_init", + value: function _init() { + var _this2 = this; + + this._isInitializing = true; + this.$element.attr('role', 'tablist'); + this.$tabs = this.$element.children('[data-accordion-item]'); + this.$tabs.attr({ + 'role': 'presentation' + }); + this.$tabs.each(function (idx, el) { + var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el), + $content = $el.children('[data-tab-content]'), + id = $content[0].id || GetYoDigits(6, 'accordion'), + linkId = el.id ? "".concat(el.id, "-label") : "".concat(id, "-label"); + $el.find('a:first').attr({ + 'aria-controls': id, + 'role': 'tab', + 'id': linkId, + 'aria-expanded': false, + 'aria-selected': false + }); + $content.attr({ + 'role': 'tabpanel', + 'aria-labelledby': linkId, + 'aria-hidden': true, + 'id': id + }); + }); + var $initActive = this.$element.find('.is-active').children('[data-tab-content]'); + + if ($initActive.length) { + // Save up the initial hash to return to it later when going back in history + this._initialAnchor = $initActive.prev('a').attr('href'); + + this._openSingleTab($initActive); + } + + this._checkDeepLink = function () { + var anchor = window.location.hash; + + if (!anchor.length) { + // If we are still initializing and there is no anchor, then there is nothing to do + if (_this2._isInitializing) return; // Otherwise, move to the initial anchor + + if (_this2._initialAnchor) anchor = _this2._initialAnchor; + } + + var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor); + + var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"]")); // Whether the anchor element that has been found is part of this element + + + var isOwnAnchor = !!($anchor.length && $link.length); + + if (isOwnAnchor) { + // If there is an anchor for the hash, open it (if not already active) + if ($anchor && $link && $link.length) { + if (!$link.parent('[data-accordion-item]').hasClass('is-active')) { + _this2._openSingleTab($anchor); + } + } // Otherwise, close everything + else { + _this2._closeAllTabs(); + } // Roll up a little to show the titles + + + if (_this2.options.deepLinkSmudge) { + onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + var offset = _this2.$element.offset(); + + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({ + scrollTop: offset.top - _this2.options.deepLinkSmudgeOffset + }, _this2.options.deepLinkSmudgeDelay); + }); + } + /** + * Fires when the plugin has deeplinked at pageload + * @event Accordion#deeplink + */ + + + _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]); + } + }; //use browser to open a tab, if it exists in this tabset + + + if (this.options.deepLink) { + this._checkDeepLink(); + } + + this._events(); + + this._isInitializing = false; + } + /** + * Adds event handlers for items within the accordion. + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; + + this.$tabs.each(function () { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this); + var $tabContent = $elem.children('[data-tab-content]'); + + if ($tabContent.length) { + $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) { + e.preventDefault(); + + _this.toggle($tabContent); + }).on('keydown.zf.accordion', function (e) { + 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(); + } + }); + }); + } + }); + + if (this.options.deepLink) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink); + } + } + /** + * Toggles the selected content pane's open/close state. + * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`). + * @function + */ + + }, { + key: "toggle", + value: function toggle($target) { + if ($target.closest('[data-accordion]').is('[disabled]')) { + console.info('Cannot toggle an accordion that is disabled.'); + return; + } + + if ($target.parent().hasClass('is-active')) { + this.up($target); + } else { + this.down($target); + } //either replace or update browser history + + + if (this.options.deepLink) { + var anchor = $target.prev('a').attr('href'); + + if (this.options.updateHistory) { + history.pushState({}, '', anchor); + } else { + history.replaceState({}, '', anchor); + } + } + } + /** + * Opens the accordion tab defined by `$target`. + * @param {jQuery} $target - Accordion pane to open (`.accordion-content`). + * @fires Accordion#down + * @function + */ + + }, { + key: "down", + value: function down($target) { + if ($target.closest('[data-accordion]').is('[disabled]')) { + console.info('Cannot call down on an accordion that is disabled.'); + return; + } + + if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target); + } + /** + * Closes the tab defined by `$target`. + * It may be ignored if the Accordion options don't allow it. + * + * @param {jQuery} $target - Accordion tab to close (`.accordion-content`). + * @fires Accordion#up + * @function + */ + + }, { + key: "up", + value: function up($target) { + if (this.$element.is('[disabled]')) { + console.info('Cannot call up on an accordion that is disabled.'); + return; + } // Don't close the item if it is already closed + + + var $targetItem = $target.parent(); + if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`) + + var $othersItems = $targetItem.siblings(); + if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return; + + this._closeTab($target); + } + /** + * Make the tab defined by `$target` the only opened tab, closing all others tabs. + * @param {jQuery} $target - Accordion tab to open (`.accordion-content`). + * @function + * @private + */ + + }, { + key: "_openSingleTab", + value: function _openSingleTab($target) { + // Close all the others active tabs. + var $activeContents = this.$element.children('.is-active').children('[data-tab-content]'); + + if ($activeContents.length) { + this._closeTab($activeContents.not($target)); + } // Then open the target. + + + this._openTab($target); + } + /** + * Opens the tab defined by `$target`. + * @param {jQuery} $target - Accordion tab to open (`.accordion-content`). + * @fires Accordion#down + * @function + * @private + */ + + }, { + key: "_openTab", + value: function _openTab($target) { + var _this3 = this; + + var $targetItem = $target.parent(); + var targetContentId = $target.attr('aria-labelledby'); + $target.attr('aria-hidden', false); + $targetItem.addClass('is-active'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({ + 'aria-expanded': true, + 'aria-selected': true + }); + $target.finish().slideDown(this.options.slideSpeed, function () { + /** + * Fires when the tab is done opening. + * @event Accordion#down + */ + _this3.$element.trigger('down.zf.accordion', [$target]); + }); + } + /** + * Closes the tab defined by `$target`. + * @param {jQuery} $target - Accordion tab to close (`.accordion-content`). + * @fires Accordion#up + * @function + * @private + */ + + }, { + key: "_closeTab", + value: function _closeTab($target) { + var _this4 = this; + + var $targetItem = $target.parent(); + var targetContentId = $target.attr('aria-labelledby'); + $target.attr('aria-hidden', true); + $targetItem.removeClass('is-active'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({ + 'aria-expanded': false, + 'aria-selected': false + }); + $target.finish().slideUp(this.options.slideSpeed, function () { + /** + * Fires when the tab is done collapsing up. + * @event Accordion#up + */ + _this4.$element.trigger('up.zf.accordion', [$target]); + }); + } + /** + * Closes all active tabs + * @fires Accordion#up + * @function + * @private + */ + + }, { + key: "_closeAllTabs", + value: function _closeAllTabs() { + var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]'); + + if ($activeTabs.length) { + this._closeTab($activeTabs); + } + } + /** + * Destroys an instance of an accordion. + * @fires Accordion#destroyed + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', ''); + this.$element.find('a').off('.zf.accordion'); + + if (this.options.deepLink) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink); + } + } + }]); + + return Accordion; +}(Plugin); + +Accordion.defaults = { + /** + * Amount of time to animate the opening of an accordion pane. + * @option + * @type {number} + * @default 250 + */ + slideSpeed: 250, + + /** + * Allow the accordion to have multiple open panes. + * @option + * @type {boolean} + * @default false + */ + multiExpand: false, + + /** + * Allow the accordion to close all panes. + * @option + * @type {boolean} + * @default false + */ + allowAllClosed: false, + + /** + * Link the location hash to the open pane. + * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes. + * @option + * @type {boolean} + * @default false + */ + deepLink: false, + + /** + * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible + * @option + * @type {boolean} + * @default false + */ + deepLinkSmudge: false, + + /** + * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment + * @option + * @type {number} + * @default 300 + */ + deepLinkSmudgeDelay: 300, + + /** + * If `deepLinkSmudge` is enabled, the offset for scrollToTtop to prevent overlap by a sticky element at the top of the page + * @option + * @type {number} + * @default 0 + */ + deepLinkSmudgeOffset: 0, + + /** + * If `deepLink` is enabled, update the browser history with the open accordion + * @option + * @type {boolean} + * @default false + */ + updateHistory: false +}; +/** + * AccordionMenu module. + * @module foundation.accordionMenu + * @requires foundation.util.keyboard + * @requires foundation.util.nest + */ + +var AccordionMenu = /*#__PURE__*/function (_Plugin) { + _inherits(AccordionMenu, _Plugin); + + function AccordionMenu() { + _classCallCheck(this, AccordionMenu); + + return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments)); + } + + _createClass(AccordionMenu, [{ + key: "_setup", + + /** + * Creates a new instance of an accordion menu. + * @class + * @name AccordionMenu + * @fires AccordionMenu#init + * @param {jQuery} element - jQuery object to make into an accordion menu. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options); + this.className = 'AccordionMenu'; // ie9 back compat + + this._init(); + + Keyboard.register('AccordionMenu', { + 'ENTER': 'toggle', + 'SPACE': 'toggle', + 'ARROW_RIGHT': 'open', + 'ARROW_UP': 'up', + 'ARROW_DOWN': 'down', + 'ARROW_LEFT': 'close', + 'ESCAPE': 'closeAll' + }); + } + /** + * Initializes the accordion menu by hiding all nested menus. + * @private + */ + + }, { + key: "_init", + value: function _init() { + Nest.Feather(this.$element, 'accordion'); + + var _this = this; + + this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem'); + + this.$element.attr({ + 'role': 'tree', + 'aria-multiselectable': this.options.multiOpen + }); + this.$menuLinks = this.$element.find('.is-accordion-submenu-parent'); + this.$menuLinks.each(function () { + var linkId = this.id || GetYoDigits(6, 'acc-menu-link'), + $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $sub = $elem.children('[data-submenu]'), + subId = $sub[0].id || GetYoDigits(6, 'acc-menu'), + isActive = $sub.hasClass('is-active'); + + if (_this.options.parentLink) { + var $anchor = $elem.children('a'); + $anchor.clone().prependTo($sub).wrap(''); + } + + if (_this.options.submenuToggle) { + $elem.addClass('has-submenu-toggle'); + $elem.children('a').after('' + _this.options.submenuToggleText + ''); + } else { + $elem.attr({ + 'aria-controls': subId, + 'aria-expanded': isActive, + 'id': linkId + }); + } + + $sub.attr({ + 'aria-labelledby': linkId, + 'aria-hidden': !isActive, + 'role': 'group', + 'id': subId + }); + }); + this.$element.find('li').attr({ + 'role': 'treeitem' + }); + var initPanes = this.$element.find('.is-active'); + + if (initPanes.length) { + initPanes.each(function () { + _this.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(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 = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]'); + + if ($submenu.length) { + if (_this.options.submenuToggle) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) { + _this.toggle($submenu); + }); + } else { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) { + e.preventDefault(); + + _this.toggle($submenu); + }); + } + } + }).on('keydown.zf.accordionMenu', function (e) { + var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $elements = $element.parent('ul').children('li'), + $prevElement, + $nextElement, + $target = $element.children('[data-submenu]'); + $elements.each(function (i) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) { + $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first(); + $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first(); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]:visible').length) { + // has open sub menu + $nextElement = $element.find('li:first-child').find('a').first(); + } + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':first-child')) { + // is first element of sub menu + $prevElement = $element.parents('li').first().find('a').first(); + } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { + // if previous element has open sub menu + $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first(); + } + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':last-child')) { + // is last element of sub menu + $nextElement = $element.parents('li').first().next('li').find('a').first(); + } + + return; + } + }); + Keyboard.handleKey(e, 'AccordionMenu', { + open: function open() { + if ($target.is(':hidden')) { + _this.down($target); + + $target.find('li').first().find('a').first().focus(); + } + }, + close: function close() { + if ($target.length && !$target.is(':hidden')) { + // close active sub of this item + _this.up($target); + } else if ($element.parent('[data-submenu]').length) { + // close currently open sub + _this.up($element.parent('[data-submenu]')); + + $element.parents('li').first().find('a').first().focus(); + } + }, + up: function up() { + $prevElement.focus(); + return true; + }, + down: function down() { + $nextElement.focus(); + return true; + }, + toggle: function toggle() { + if (_this.options.submenuToggle) { + return false; + } + + if ($element.children('[data-submenu]').length) { + _this.toggle($element.children('[data-submenu]')); + + return true; + } + }, + closeAll: function closeAll() { + _this.hideAll(); + }, + handled: function handled(preventDefault) { + if (preventDefault) { + e.preventDefault(); + } + } + }); + }); //.attr('tabindex', 0); + } + /** + * Closes all panes of the menu. + * @function + */ + + }, { + key: "hideAll", + value: function hideAll() { + this.up(this.$element.find('[data-submenu]')); + } + /** + * Opens all panes of the menu. + * @function + */ + + }, { + key: "showAll", + value: function showAll() { + this.down(this.$element.find('[data-submenu]')); + } + /** + * Toggles the open/close state of a submenu. + * @function + * @param {jQuery} $target - the submenu to toggle + */ + + }, { + key: "toggle", + value: function toggle($target) { + if (!$target.is(':animated')) { + if (!$target.is(':hidden')) { + this.up($target); + } else { + this.down($target); + } + } + } + /** + * Opens the sub-menu defined by `$target`. + * @param {jQuery} $target - Sub-menu to open. + * @fires AccordionMenu#down + */ + + }, { + key: "down", + value: function down($target) { + var _this2 = this; // If having multiple submenus active is disabled, close all the submenus + // that are not parents or children of the targeted submenu. + + + if (!this.options.multiOpen) { + // The "branch" of the targetted submenu, from the component root to + // the active submenus nested in it. + var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch. + + var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch); + this.up($othersActiveSubmenus); + } + + $target.addClass('is-active').attr({ + 'aria-hidden': false + }); + + if (this.options.submenuToggle) { + $target.prev('.submenu-toggle').attr({ + 'aria-expanded': true + }); + } else { + $target.parent('.is-accordion-submenu-parent').attr({ + 'aria-expanded': true + }); + } + + $target.slideDown(this.options.slideSpeed, function () { + /** + * Fires when the menu is done opening. + * @event AccordionMenu#down + */ + _this2.$element.trigger('down.zf.accordionMenu', [$target]); + }); + } + /** + * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well. + * @param {jQuery} $target - Sub-menu to close. + * @fires AccordionMenu#up + */ + + }, { + key: "up", + value: function up($target) { + var _this3 = this; + + var $submenus = $target.find('[data-submenu]'); + var $allmenus = $target.add($submenus); + $submenus.slideUp(0); + $allmenus.removeClass('is-active').attr('aria-hidden', true); + + if (this.options.submenuToggle) { + $allmenus.prev('.submenu-toggle').attr('aria-expanded', false); + } else { + $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false); + } + + $target.slideUp(this.options.slideSpeed, function () { + /** + * Fires when the menu is done collapsing up. + * @event AccordionMenu#up + */ + _this3.$element.trigger('up.zf.accordionMenu', [$target]); + }); + } + /** + * Destroys an instance of accordion menu. + * @fires AccordionMenu#destroyed + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.find('[data-submenu]').slideDown(0).css('display', ''); + this.$element.find('a').off('click.zf.accordionMenu'); + this.$element.find('[data-is-parent-link]').detach(); + + if (this.options.submenuToggle) { + this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle'); + this.$element.find('.submenu-toggle').remove(); + } + + Nest.Burn(this.$element, 'accordion'); + } + }]); + + return AccordionMenu; +}(Plugin); + +AccordionMenu.defaults = { + /** + * Adds the parent link to the submenu. + * @option + * @type {boolean} + * @default false + */ + parentLink: false, + + /** + * Amount of time to animate the opening of a submenu in ms. + * @option + * @type {number} + * @default 250 + */ + slideSpeed: 250, + + /** + * Adds a separate submenu toggle button. This allows the parent item to have a link. + * @option + * @example true + */ + submenuToggle: false, + + /** + * The text used for the submenu toggle if enabled. This is used for screen readers only. + * @option + * @example true + */ + submenuToggleText: 'Toggle menu', + + /** + * Allow the menu to have multiple open panes. + * @option + * @type {boolean} + * @default true + */ + multiOpen: true +}; +/** + * Drilldown module. + * @module foundation.drilldown + * @requires foundation.util.keyboard + * @requires foundation.util.nest + * @requires foundation.util.box + */ + +var Drilldown = /*#__PURE__*/function (_Plugin) { + _inherits(Drilldown, _Plugin); + + function Drilldown() { + _classCallCheck(this, Drilldown); + + return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments)); + } + + _createClass(Drilldown, [{ + key: "_setup", + + /** + * Creates a new instance of a drilldown menu. + * @class + * @name Drilldown + * @param {jQuery} element - jQuery object to make into an accordion menu. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Drilldown.defaults, this.$element.data(), options); + this.className = 'Drilldown'; // ie9 back compat + + this._init(); + + Keyboard.register('Drilldown', { + 'ENTER': 'open', + 'SPACE': 'open', + 'ARROW_RIGHT': 'next', + 'ARROW_UP': 'up', + 'ARROW_DOWN': 'down', + 'ARROW_LEFT': 'previous', + 'ESCAPE': 'close', + 'TAB': 'down', + 'SHIFT_TAB': 'up' + }); + } + /** + * Initializes the drilldown by creating jQuery collections of elements + * @private + */ + + }, { + key: "_init", + value: function _init() { + Nest.Feather(this.$element, 'drilldown'); + + if (this.options.autoApplyClass) { + this.$element.addClass('drilldown'); + } + + this.$element.attr({ + 'role': 'tree', + 'aria-multiselectable': false + }); + this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a'); + this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group'); + this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected) + // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu + + this.$currentMenu = this.$element; + this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')); + + this._prepareMenu(); + + this._registerEvents(); + + this._keyboardEvents(); + } + /** + * prepares drilldown menu by setting attributes to links and elements + * sets a min height to prevent content jumping + * wraps the element if not already wrapped + * @private + * @function + */ + + }, { + key: "_prepareMenu", + value: function _prepareMenu() { + var _this = this; // if(!this.options.holdOpen){ + // this._menuLinkEvents(); + // } + + + this.$submenuAnchors.each(function () { + var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this); + var $sub = $link.parent(); + + if (_this.options.parentLink) { + $link.clone().prependTo($sub.children('[data-submenu]')).wrap(''); + } + + $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0); + $link.children('[data-submenu]').attr({ + 'aria-hidden': true, + 'tabindex': 0, + 'role': 'group' + }); + + _this._events($link); + }); + this.$submenus.each(function () { + var $menu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $back = $menu.find('.js-drilldown-back'); + + if (!$back.length) { + switch (_this.options.backButtonPosition) { + case "bottom": + $menu.append(_this.options.backButton); + break; + + case "top": + $menu.prepend(_this.options.backButton); + break; + + default: + console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'"); + } + } + + _this._back($menu); + }); + this.$submenus.addClass('invisible'); + + if (!this.options.autoHeight) { + this.$submenus.addClass('drilldown-submenu-cover-previous'); + } // create a wrapper on element if it doesn't exist. + + + if (!this.$element.parent().hasClass('is-drilldown')) { + this.$wrapper = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.wrapper).addClass('is-drilldown'); + if (this.options.animateHeight) this.$wrapper.addClass('animate-height'); + this.$element.wrap(this.$wrapper); + } // set wrapper + + + 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 (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) { + e.preventDefault(); + } // if(e.target !== e.currentTarget.firstElementChild){ + // return false; + // } + + + _this._show($elem.parent('li')); + + if (_this.options.closeOnClick) { + var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body'); + $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) { + if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target)) { + return; + } + + e.preventDefault(); + + _this._hideAll(); + + $body.off('.zf.drilldown'); + }); + } + }); + } + /** + * Adds event handlers to the menu element. + * @function + * @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 close.zf.drilldown closed.zf.drilldown', this._bindHandler); + } + + this.$element.on('mutateme.zf.trigger', this._resize.bind(this)); + } + /** + * Scroll to Top of Element or data-scroll-top-element + * @function + * @fires Drilldown#scrollme + */ + + }, { + key: "_scrollTop", + value: function _scrollTop() { + var _this = this; + + var $scrollTopElement = _this.options.scrollTopElement != '' ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(_this.options.scrollTopElement) : _this.$element, + scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({ + scrollTop: scrollPos + }, _this.options.animationDuration, _this.options.animationEasing, function () { + /** + * Fires after the menu has scrolled + * @event Drilldown#scrollme + */ + if (this === jquery__WEBPACK_IMPORTED_MODULE_0___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown'); + }); + } + /** + * Adds keydown event listener to `li`'s in the menu. + * @private + */ + + }, { + key: "_keyboardEvents", + 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 = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $elements = $element.parent('li').parent('ul').children('li').children('a'), + $prevElement, + $nextElement; + $elements.each(function (i) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) { + $prevElement = $elements.eq(Math.max(0, i - 1)); + $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)); + return; + } + }); + Keyboard.handleKey(e, 'Drilldown', { + next: function next() { + if ($element.is(_this.$submenuAnchors)) { + _this._show($element.parent('li')); + + $element.parent('li').one(transitionend($element), function () { + $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus(); + }); + return true; + } + }, + previous: function previous() { + _this._hide($element.parent('li').parent('ul')); + + $element.parent('li').parent('ul').one(transitionend($element), function () { + setTimeout(function () { + $element.parent('li').parent('ul').parent('li').children('a').first().focus(); + }, 1); + }); + return true; + }, + up: function up() { + $prevElement.focus(); // Don't tap focus on first element in root ul + + return !$element.is(_this.$element.find('> li:first-child > a')); + }, + down: function down() { + $nextElement.focus(); // Don't tap focus on last element in root ul + + return !$element.is(_this.$element.find('> li:last-child > a')); + }, + close: function close() { + // Don't close on element in root ul + if (!$element.is(_this.$element.find('> li > a'))) { + _this._hide($element.parent().parent()); + + $element.parent().parent().siblings('a').focus(); + } + }, + open: function open() { + if (_this.options.parentLink && $element.attr('href')) { + // Link with href + return false; + } else if (!$element.is(_this.$menuItems)) { + // not menu item means back button + _this._hide($element.parent('li').parent('ul')); + + $element.parent('li').parent('ul').one(transitionend($element), function () { + setTimeout(function () { + $element.parent('li').parent('ul').parent('li').children('a').first().focus(); + }, 1); + }); + return true; + } else if ($element.is(_this.$submenuAnchors)) { + // Sub menu item + _this._show($element.parent('li')); + + $element.parent('li').one(transitionend($element), function () { + $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus(); + }); + return true; + } + }, + handled: function handled(preventDefault) { + if (preventDefault) { + e.preventDefault(); + } + } + }); + }); // end keyboardAccess + } + /** + * Closes all open elements, and returns to root menu. + * @function + * @fires Drilldown#close + * @fires Drilldown#closed + */ + + }, { + key: "_hideAll", + value: function _hideAll() { + var _this2 = this; + + var $elem = this.$element.find('.is-drilldown-submenu.is-active'); + $elem.addClass('is-closing'); + + if (this.options.autoHeight) { + var calcHeight = $elem.parent().closest('ul').data('calcHeight'); + this.$wrapper.css({ + height: calcHeight + }); + } + /** + * Fires when the menu is closing. + * @event Drilldown#close + */ + + + this.$element.trigger('close.zf.drilldown'); + $elem.one(transitionend($elem), function () { + $elem.removeClass('is-active is-closing'); + /** + * Fires when the menu is fully closed. + * @event Drilldown#closed + */ + + _this2.$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) { + // 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) { + setTimeout(function () { + _this._hideAll(); + }, 0); + }); + } + /** + * Sets the CSS classes for submenu to show it. + * @function + * @private + * @param {jQuery} $elem - the target submenu (`ul` tag) + * @param {boolean} trigger - trigger drilldown event + */ + + }, { + key: "_setShowSubMenuClasses", + value: function _setShowSubMenuClasses($elem, trigger) { + $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false); + $elem.parent('li').attr('aria-expanded', true); + + if (trigger === true) { + this.$element.trigger('open.zf.drilldown', [$elem]); + } + } + /** + * Sets the CSS classes for submenu to hide it. + * @function + * @private + * @param {jQuery} $elem - the target submenu (`ul` tag) + * @param {boolean} trigger - trigger drilldown event + */ + + }, { + key: "_setHideSubMenuClasses", + value: function _setHideSubMenuClasses($elem, trigger) { + $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true); + $elem.parent('li').attr('aria-expanded', false); + + if (trigger === true) { + $elem.trigger('hide.zf.drilldown', [$elem]); + } + } + /** + * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible. + * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it. + * @function + * @fires Drilldown#open + * @param {jQuery} $elem - the target (sub)menu (`ul` tag) + * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused + */ + + }, { + key: "_showMenu", + value: function _showMenu($elem, autoFocus) { + var _this = this; // Reset drilldown + + + var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]'); + $expandedSubmenus.each(function (index) { + _this._setHideSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)); + }); // Save the menu as the currently displayed one. + + this.$currentMenu = $elem; // If target menu is root, focus first link & exit + + if ($elem.is('[data-drilldown]')) { + if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus(); + if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight')); + return; + } // Find all submenus on way to root incl. the element itself + + + var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root + + $submenus.each(function (index) { + // Update height of first child (target menu) if autoHeight option true + if (index === 0 && _this.options.autoHeight) { + _this.$wrapper.css('height', jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight')); + } + + var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link + // Last child makes sure the event gets always triggered even if going through several menus + + if (isLastChild === true) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).one(transitionend(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)), function () { + if (autoFocus === true) { + $elem.find('li[role="treeitem"] > a').first().focus(); + } + }); + } + + _this._setShowSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), isLastChild); + }); + } + /** + * Opens a submenu. + * @function + * @fires Drilldown#open + * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag. + */ + + }, { + key: "_show", + value: function _show($elem) { + var $submenu = $elem.children('[data-submenu]'); + $elem.attr('aria-expanded', true); + this.$currentMenu = $submenu; + $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false); + + if (this.options.autoHeight) { + this.$wrapper.css({ + height: $submenu.data('calcHeight') + }); + } + /** + * Fires when the submenu has opened. + * @event Drilldown#open + */ + + + this.$element.trigger('open.zf.drilldown', [$elem]); + } + /** + * Hides a submenu + * @function + * @fires Drilldown#hide + * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag. + */ + + }, { + key: "_hide", + value: function _hide($elem) { + if (this.options.autoHeight) this.$wrapper.css({ + height: $elem.parent().closest('ul').data('calcHeight') + }); + $elem.parent('li').attr('aria-expanded', false); + $elem.attr('aria-hidden', true); + $elem.addClass('is-closing').one(transitionend($elem), function () { + $elem.removeClass('is-active is-closing'); + $elem.blur().addClass('invisible'); + }); + /** + * Fires when the submenu has closed. + * @event Drilldown#hide + */ + + $elem.trigger('hide.zf.drilldown', [$elem]); + } + /** + * Iterates through the nested menus to calculate the min-height, and max-width for the menu. + * Prevents content jumping. + * @function + * @private + */ + + }, { + key: "_getMaxDims", + value: function _getMaxDims() { + var maxHeight = 0, + result = {}, + _this = this; // Recalculate menu heights and total max height + + + this.$submenus.add(this.$element).each(function () { + var numOfElems = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('li').length; + var height = Box.GetDimensions(this).height; + maxHeight = height > maxHeight ? height : maxHeight; + + if (_this.options.autoHeight) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight', height); + } + }); + if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = "".concat(maxHeight, "px"); + result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px"); + return result; + } + /** + * Destroys the Drilldown Menu + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler); + + this._hideAll(); + + this.$element.off('mutateme.zf.trigger'); + Nest.Burn(this.$element, 'drilldown'); + this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role'); + this.$submenuAnchors.each(function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off('.zf.drilldown'); + }); + this.$element.find('[data-is-parent-link]').detach(); + this.$submenus.removeClass('drilldown-submenu-cover-previous invisible'); + this.$element.find('a').each(function () { + var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this); + $link.removeAttr('tabindex'); + + if ($link.data('savedHref')) { + $link.attr('href', $link.data('savedHref')).removeData('savedHref'); + } else { + return; + } + }); + } + }]); + + return Drilldown; +}(Plugin); + +Drilldown.defaults = { + /** + * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are + * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization. + * @option + * @type {boolean} + * @default true + */ + autoApplyClass: true, + + /** + * Markup used for JS generated back button. Prepended or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting. + * @option + * @type {string} + * @default 'Back' + */ + backButton: 'Back', + + /** + * 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 '' + */ + wrapper: '', + + /** + * Adds the parent link to the submenu. + * @option + * @type {boolean} + * @default false + */ + parentLink: false, + + /** + * Allow the menu to return to root list on body click. + * @option + * @type {boolean} + * @default false + */ + closeOnClick: false, + + /** + * Allow the menu to auto adjust height. + * @option + * @type {boolean} + * @default false + */ + autoHeight: false, + + /** + * Animate the auto adjust height. + * @option + * @type {boolean} + * @default false + */ + animateHeight: false, + + /** + * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button + * @option + * @type {boolean} + * @default false + */ + scrollTop: false, + + /** + * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken + * @option + * @type {string} + * @default '' + */ + scrollTopElement: '', + + /** + * ScrollTop offset + * @option + * @type {number} + * @default 0 + */ + scrollTopOffset: 0, + + /** + * Scroll animation duration + * @option + * @type {number} + * @default 500 + */ + animationDuration: 500, + + /** + * Scroll animation easing. Can be `'swing'` or `'linear'`. + * @option + * @type {string} + * @see {@link https://api.jquery.com/animate|JQuery animate} + * @default 'swing' + */ + animationEasing: 'swing' // holdOpen: false + +}; +var POSITIONS = ['left', 'right', 'top', 'bottom']; +var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center']; +var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center']; +var ALIGNMENTS = { + 'left': VERTICAL_ALIGNMENTS, + 'right': VERTICAL_ALIGNMENTS, + 'top': HORIZONTAL_ALIGNMENTS, + 'bottom': HORIZONTAL_ALIGNMENTS +}; + +function nextItem(item, array) { + var currentIdx = array.indexOf(item); + + if (currentIdx === array.length - 1) { + return array[0]; + } else { + return array[currentIdx + 1]; + } +} + +var Positionable = /*#__PURE__*/function (_Plugin) { + _inherits(Positionable, _Plugin); + + function Positionable() { + _classCallCheck(this, Positionable); + + return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments)); + } + + _createClass(Positionable, [{ + key: "_init", + + /** + * Abstract class encapsulating the tether-like explicit positioning logic + * including repositioning based on overlap. + * Expects classes to define defaults for vOffset, hOffset, position, + * alignment, allowOverlap, and allowBottomOverlap. They can do this by + * extending the defaults, or (for now recommended due to the way docs are + * generated) by explicitly declaring them. + * + **/ + value: function _init() { + this.triedPositions = {}; + this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position; + this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment; + this.originalPosition = this.position; + this.originalAlignment = this.alignment; + } + }, { + key: "_getDefaultPosition", + value: function _getDefaultPosition() { + return 'bottom'; + } + }, { + key: "_getDefaultAlignment", + value: function _getDefaultAlignment() { + switch (this.position) { + case 'bottom': + case 'top': + return rtl() ? 'right' : 'left'; + + case 'left': + case 'right': + return 'bottom'; + } + } + /** + * Adjusts the positionable possible positions by iterating through alignments + * and positions. + * @function + * @private + */ + + }, { + key: "_reposition", + value: function _reposition() { + if (this._alignmentsExhausted(this.position)) { + this.position = nextItem(this.position, POSITIONS); + this.alignment = ALIGNMENTS[this.position][0]; + } else { + this._realign(); + } + } + /** + * Adjusts the dropdown pane possible positions by iterating through alignments + * on the current position. + * @function + * @private + */ + + }, { + key: "_realign", + value: function _realign() { + this._addTriedPosition(this.position, this.alignment); + + this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]); + } + }, { + key: "_addTriedPosition", + value: function _addTriedPosition(position, alignment) { + this.triedPositions[position] = this.triedPositions[position] || []; + this.triedPositions[position].push(alignment); + } + }, { + key: "_positionsExhausted", + value: function _positionsExhausted() { + var isExhausted = true; + + for (var i = 0; i < POSITIONS.length; i++) { + isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]); + } + + return isExhausted; + } + }, { + key: "_alignmentsExhausted", + value: function _alignmentsExhausted(position) { + return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length; + } // When we're trying to center, we don't want to apply offset that's going to + // take us just off center, so wrap around to return 0 for the appropriate + // offset in those alignments. TODO: Figure out if we want to make this + // configurable behavior... it feels more intuitive, especially for tooltips, but + // it's possible someone might actually want to start from center and then nudge + // slightly off. + + }, { + key: "_getVOffset", + value: function _getVOffset() { + return this.options.vOffset; + } + }, { + key: "_getHOffset", + value: function _getHOffset() { + return this.options.hOffset; + } + }, { + key: "_setPosition", + value: function _setPosition($anchor, $element, $parent) { + if ($anchor.attr('aria-expanded') === 'false') { + return false; + } + + if (!this.options.allowOverlap) { + // restore original position & alignment before checking overlap + this.position = this.originalPosition; + this.alignment = this.originalAlignment; + } + + $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); + + if (!this.options.allowOverlap) { + var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better + + var minCoordinates = { + position: this.position, + alignment: this.alignment + }; + + while (!this._positionsExhausted()) { + var overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap); + + if (overlap === 0) { + return; + } + + if (overlap < minOverlap) { + minOverlap = overlap; + minCoordinates = { + position: this.position, + alignment: this.alignment + }; + } + + this._reposition(); + + $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); + } // If we get through the entire loop, there was no non-overlapping + // position available. Pick the version with least overlap. + + + this.position = minCoordinates.position; + this.alignment = minCoordinates.alignment; + $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset())); + } + } + }]); + + return Positionable; +}(Plugin); + +Positionable.defaults = { + /** + * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto. + * @option + * @type {string} + * @default 'auto' + */ + position: 'auto', + + /** + * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto. + * @option + * @type {string} + * @default 'auto' + */ + alignment: 'auto', + + /** + * Allow overlap of container/window. If false, dropdown positionable first + * try to position as defined by data-position and data-alignment, but + * reposition if it would cause an overflow. + * @option + * @type {boolean} + * @default false + */ + allowOverlap: false, + + /** + * Allow overlap of only the bottom of the container. This is the most common + * behavior for dropdowns, allowing the dropdown to extend the bottom of the + * screen but not otherwise influence or break out of the container. + * @option + * @type {boolean} + * @default true + */ + allowBottomOverlap: true, + + /** + * Number of pixels the positionable should be separated vertically from anchor + * @option + * @type {number} + * @default 0 + */ + vOffset: 0, + + /** + * Number of pixels the positionable should be separated horizontally from anchor + * @option + * @type {number} + * @default 0 + */ + hOffset: 0 +}; +/** + * Dropdown module. + * @module foundation.dropdown + * @requires foundation.util.keyboard + * @requires foundation.util.box + * @requires foundation.util.touch + * @requires foundation.util.triggers + */ + +var Dropdown = /*#__PURE__*/function (_Positionable) { + _inherits(Dropdown, _Positionable); + + function Dropdown() { + _classCallCheck(this, Dropdown); + + return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments)); + } + + _createClass(Dropdown, [{ + key: "_setup", + + /** + * Creates a new instance of a dropdown. + * @class + * @name Dropdown + * @param {jQuery} element - jQuery object to make into a dropdown. + * Object should be of the dropdown panel, rather than its anchor. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Dropdown.defaults, this.$element.data(), options); + this.className = 'Dropdown'; // ie9 back compat + // Touch and Triggers init are idempotent, just need to make sure they are initialized + + Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + + Keyboard.register('Dropdown', { + 'ENTER': 'toggle', + 'SPACE': 'toggle', + 'ESCAPE': 'close' + }); + } + /** + * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + var $id = this.$element.attr('id'); + this.$anchors = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat($id, "\"]")); + this.$anchors.attr({ + 'aria-controls': $id, + 'data-is-focus': false, + 'data-yeti-box': $id, + 'aria-haspopup': true, + 'aria-expanded': false + }); + + this._setCurrentAnchor(this.$anchors.first()); + + if (this.options.parentClass) { + this.$parent = this.$element.parents('.' + this.options.parentClass); + } else { + this.$parent = null; + } // Set [aria-labelledby] on the Dropdown if it is not set + + + if (typeof this.$element.attr('aria-labelledby') === 'undefined') { + // Get the anchor ID or create one + if (typeof this.$currentAnchor.attr('id') === 'undefined') { + this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor')); + } + + this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id')); + } + + this.$element.attr({ + 'aria-hidden': 'true', + 'data-yeti-box': $id, + 'data-resize': $id + }); + + _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this); + + this._events(); + } + }, { + key: "_getDefaultPosition", + value: function _getDefaultPosition() { + // handle legacy classnames + var position = this.$element[0].className.match(/(top|left|right|bottom)/g); + + if (position) { + return position[0]; + } else { + return 'bottom'; + } + } + }, { + key: "_getDefaultAlignment", + value: function _getDefaultAlignment() { + // handle legacy float approach + var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class')); + + if (horizontalPosition) { + return horizontalPosition[1]; + } + + return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this); + } + /** + * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true. + * Recursively calls itself if a collision is detected, with a new position class. + * @function + * @private + */ + + }, { + key: "_setPosition", + value: function _setPosition() { + this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment)); + + _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent); + + this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment)); + } + /** + * Make it a current anchor. + * Current anchor as the reference for the position of Dropdown panes. + * @param {HTML} el - DOM element of the anchor. + * @function + * @private + */ + + }, { + key: "_setCurrentAnchor", + value: function _setCurrentAnchor(el) { + this.$currentAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el); + } + /** + * Adds event listeners to the element utilizing the triggers utility library. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this, + hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined'; + + this.$element.on({ + 'open.zf.trigger': this.open.bind(this), + 'close.zf.trigger': this.close.bind(this), + 'toggle.zf.trigger': this.toggle.bind(this), + 'resizeme.zf.trigger': this._setPosition.bind(this) + }); + this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function (e) { + _this._setCurrentAnchor(this); + + if ( // if forceFollow false, always prevent default action + _this.options.forceFollow === false || // if forceFollow true and hover option true, only prevent default action on 1st click + // on 2nd click (dropown opened) the default action (e.g. follow a href) gets executed + hasTouch && _this.options.hover && _this.$element.hasClass('is-open') === false) { + e.preventDefault(); + } + }); + + if (this.options.hover) { + this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () { + _this._setCurrentAnchor(this); + + var bodyData = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').data(); + + if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') { + clearTimeout(_this.timeout); + _this.timeout = setTimeout(function () { + _this.open(); + + _this.$anchors.data('hover', true); + }, _this.options.hoverDelay); + } + }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () { + clearTimeout(_this.timeout); + _this.timeout = setTimeout(function () { + _this.close(); + + _this.$anchors.data('hover', false); + }, _this.options.hoverDelay); + })); + + if (this.options.hoverPane) { + this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () { + clearTimeout(_this.timeout); + }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () { + clearTimeout(_this.timeout); + _this.timeout = setTimeout(function () { + _this.close(); + + _this.$anchors.data('hover', false); + }, _this.options.hoverDelay); + })); + } + } + + this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) { + var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + visibleFocusableElements = Keyboard.findFocusable(_this.$element); + Keyboard.handleKey(e, 'Dropdown', { + open: function open() { + if ($target.is(_this.$anchors) && !$target.is('input, textarea')) { + _this.open(); + + _this.$element.attr('tabindex', -1).focus(); + + e.preventDefault(); + } + }, + close: function close() { + _this.close(); + + _this.$anchors.focus(); + } + }); + }); + } + /** + * Adds an event handler to the body to close any dropdowns on a click. + * @function + * @private + */ + + }, { + key: "_addBodyHandler", + value: function _addBodyHandler() { + var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).not(this.$element), + _this = this; + + $body.off('click.zf.dropdown tap.zf.dropdown').on('click.zf.dropdown tap.zf.dropdown', function (e) { + if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) { + return; + } + + if (_this.$element.is(e.target) || _this.$element.find(e.target).length) { + return; + } + + _this.close(); + + $body.off('click.zf.dropdown tap.zf.dropdown'); + }); + } + /** + * Opens the dropdown pane, and fires a bubbling event to close other dropdowns. + * @function + * @fires Dropdown#closeme + * @fires Dropdown#show + */ + + }, { + key: "open", + value: function open() { + // var _this = this; + + /** + * Fires to close other open dropdowns, typically when dropdown is opening + * @event Dropdown#closeme + */ + this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id')); + this.$anchors.addClass('hover').attr({ + 'aria-expanded': true + }); // this.$element/*.show()*/; + + this.$element.addClass('is-opening'); + + this._setPosition(); + + this.$element.removeClass('is-opening').addClass('is-open').attr({ + 'aria-hidden': false + }); + + if (this.options.autoFocus) { + var $focusable = Keyboard.findFocusable(this.$element); + + if ($focusable.length) { + $focusable.eq(0).focus(); + } + } + + if (this.options.closeOnClick) { + this._addBodyHandler(); + } + + if (this.options.trapFocus) { + Keyboard.trapFocus(this.$element); + } + /** + * Fires once the dropdown is visible. + * @event Dropdown#show + */ + + + this.$element.trigger('show.zf.dropdown', [this.$element]); + } + /** + * Closes the open dropdown pane. + * @function + * @fires Dropdown#hide + */ + + }, { + key: "close", + value: function close() { + if (!this.$element.hasClass('is-open')) { + return false; + } + + this.$element.removeClass('is-open').attr({ + 'aria-hidden': true + }); + this.$anchors.removeClass('hover').attr('aria-expanded', false); + /** + * Fires once the dropdown is no longer visible. + * @event Dropdown#hide + */ + + this.$element.trigger('hide.zf.dropdown', [this.$element]); + + if (this.options.trapFocus) { + Keyboard.releaseFocus(this.$element); + } + } + /** + * Toggles the dropdown pane's visibility. + * @function + */ + + }, { + key: "toggle", + value: function toggle() { + if (this.$element.hasClass('is-open')) { + if (this.$anchors.data('hover')) return; + this.close(); + } else { + this.open(); + } + } + /** + * Destroys the dropdown. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('.zf.trigger').hide(); + this.$anchors.off('.zf.dropdown'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdown tap.zf.dropdown'); + } + }]); + + return Dropdown; +}(Positionable); + +Dropdown.defaults = { + /** + * Class that designates bounding container of Dropdown (default: window) + * @option + * @type {?string} + * @default null + */ + parentClass: null, + + /** + * Amount of time to delay opening a submenu on hover event. + * @option + * @type {number} + * @default 250 + */ + hoverDelay: 250, + + /** + * Allow submenus to open on hover events + * @option + * @type {boolean} + * @default false + */ + hover: false, + + /** + * Don't close dropdown when hovering over dropdown pane + * @option + * @type {boolean} + * @default false + */ + hoverPane: false, + + /** + * Number of pixels between the dropdown pane and the triggering element on open. + * @option + * @type {number} + * @default 0 + */ + vOffset: 0, + + /** + * Number of pixels between the dropdown pane and the triggering element on open. + * @option + * @type {number} + * @default 0 + */ + hOffset: 0, + + /** + * Position of dropdown. Can be left, right, bottom, top, or auto. + * @option + * @type {string} + * @default 'auto' + */ + position: 'auto', + + /** + * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto. + * @option + * @type {string} + * @default 'auto' + */ + alignment: 'auto', + + /** + * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow. + * @option + * @type {boolean} + * @default false + */ + allowOverlap: false, + + /** + * Allow overlap of only the bottom of the container. This is the most common + * behavior for dropdowns, allowing the dropdown to extend the bottom of the + * screen but not otherwise influence or break out of the container. + * @option + * @type {boolean} + * @default true + */ + allowBottomOverlap: true, + + /** + * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands. + * @option + * @type {boolean} + * @default false + */ + trapFocus: false, + + /** + * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening. + * @option + * @type {boolean} + * @default false + */ + autoFocus: false, + + /** + * Allows a click on the body to close the dropdown. + * @option + * @type {boolean} + * @default false + */ + closeOnClick: false, + + /** + * If true the default action of the toggle (e.g. follow a link with href) gets executed on click. If hover option is also true the default action gets prevented on first click for mobile / touch devices and executed on second click. + * @option + * @type {boolean} + * @default true + */ + forceFollow: true +}; +/** + * DropdownMenu module. + * @module foundation.dropdownMenu + * @requires foundation.util.keyboard + * @requires foundation.util.box + * @requires foundation.util.nest + * @requires foundation.util.touch + */ + +var DropdownMenu = /*#__PURE__*/function (_Plugin) { + _inherits(DropdownMenu, _Plugin); + + function DropdownMenu() { + _classCallCheck(this, DropdownMenu); + + return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments)); + } + + _createClass(DropdownMenu, [{ + key: "_setup", + + /** + * Creates a new instance of DropdownMenu. + * @class + * @name DropdownMenu + * @fires DropdownMenu#init + * @param {jQuery} element - jQuery object to make into a dropdown menu. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options); + this.className = 'DropdownMenu'; // ie9 back compat + + Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied. + + this._init(); + + Keyboard.register('DropdownMenu', { + 'ENTER': 'open', + 'SPACE': 'open', + 'ARROW_RIGHT': 'next', + 'ARROW_UP': 'up', + 'ARROW_DOWN': 'down', + 'ARROW_LEFT': 'previous', + 'ESCAPE': 'close' + }); + } + /** + * Initializes the plugin, and calls _prepareMenu + * @private + * @function + */ + + }, { + key: "_init", + value: function _init() { + Nest.Feather(this.$element, 'dropdown'); + var subs = this.$element.find('li.is-dropdown-submenu-parent'); + this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub'); + this.$menuItems = this.$element.find('li[role="none"]'); + this.$tabs = this.$element.children('li[role="none"]'); + this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass); + + if (this.options.alignment === 'auto') { + if (this.$element.hasClass(this.options.rightClass) || rtl() || this.$element.parents('.top-bar-right').is('*')) { + this.options.alignment = 'right'; + subs.addClass('opens-left'); + } else { + this.options.alignment = 'left'; + subs.addClass('opens-right'); + } + } else { + if (this.options.alignment === 'right') { + subs.addClass('opens-left'); + } else { + subs.addClass('opens-right'); + } + } + + this.changed = false; + + this._events(); + } + }, { + key: "_isVertical", + value: function _isVertical() { + return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column'; + } + }, { + key: "_isRtl", + value: function _isRtl() { + return this.$element.hasClass('align-right') || rtl() && !this.$element.hasClass('align-left'); + } + /** + * Adds event listeners to elements within the menu + * @private + * @function + */ + + }, { + key: "_events", + value: function _events() { + var _this = this, + hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined', + parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers + + + var handleClickFn = function handleClickFn(e) { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', ".".concat(parClass)), + hasSub = $elem.hasClass(parClass), + hasClicked = $elem.attr('data-is-click') === 'true', + $sub = $elem.children('.is-dropdown-submenu'); + + 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.stopImmediatePropagation(); + e.preventDefault(); + + _this._show($sub); + + $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true); + } + } + }; + + if (this.options.clickOpen || hasTouch) { + this.$menuItems.on('click.zf.dropdownMenu touchstart.zf.dropdownMenu', handleClickFn); + } // Handle Leaf element Clicks + + + if (_this.options.closeOnClickInside) { + this.$menuItems.on('click.zf.dropdownMenu', function (e) { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + hasSub = $elem.hasClass(parClass); + + if (!hasSub) { + _this._hide(); + } + }); + } + + if (!this.options.disableHover) { + this.$menuItems.on('mouseenter.zf.dropdownMenu', function (e) { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + hasSub = $elem.hasClass(parClass); + + if (hasSub) { + clearTimeout($elem.data('_delay')); + $elem.data('_delay', setTimeout(function () { + _this._show($elem.children('.is-dropdown-submenu')); + }, _this.options.hoverDelay)); + } + }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + hasSub = $elem.hasClass(parClass); + + if (hasSub && _this.options.autoclose) { + if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { + return false; + } + + clearTimeout($elem.data('_delay')); + $elem.data('_delay', setTimeout(function () { + _this._hide($elem); + }, _this.options.closingTime)); + } + })); + } + + this.$menuItems.on('keydown.zf.dropdownMenu', function (e) { + var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', '[role="none"]'), + isTab = _this.$tabs.index($element) > -1, + $elements = isTab ? _this.$tabs : $element.siblings('li').add($element), + $prevElement, + $nextElement; + $elements.each(function (i) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) { + $prevElement = $elements.eq(i - 1); + $nextElement = $elements.eq(i + 1); + return; + } + }); + + var nextSibling = function nextSibling() { + $nextElement.children('a:first').focus(); + e.preventDefault(); + }, + prevSibling = function prevSibling() { + $prevElement.children('a:first').focus(); + e.preventDefault(); + }, + openSub = function openSub() { + var $sub = $element.children('ul.is-dropdown-submenu'); + + if ($sub.length) { + _this._show($sub); + + $element.find('li > a:first').focus(); + e.preventDefault(); + } else { + return; + } + }, + closeSub = function closeSub() { + //if ($element.is(':first-child')) { + var close = $element.parent('ul').parent('li'); + close.children('a:first').focus(); + + _this._hide(close); + + e.preventDefault(); //} + }; + + var functions = { + open: openSub, + close: function close() { + _this._hide(_this.$element); + + _this.$menuItems.eq(0).children('a').focus(); // focus to first element + + + e.preventDefault(); + } + }; + + if (isTab) { + if (_this._isVertical()) { + // vertical menu + if (_this._isRtl()) { + // right aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + down: nextSibling, + up: prevSibling, + next: closeSub, + previous: openSub + }); + } else { + // left aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + down: nextSibling, + up: prevSibling, + next: openSub, + previous: closeSub + }); + } + } else { + // horizontal menu + if (_this._isRtl()) { + // right aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + next: prevSibling, + previous: nextSibling, + down: openSub, + up: closeSub + }); + } else { + // left aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + next: nextSibling, + previous: prevSibling, + down: openSub, + up: closeSub + }); + } + } + } else { + // not tabs -> one sub + if (_this._isRtl()) { + // right aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + next: closeSub, + previous: openSub, + down: nextSibling, + up: prevSibling + }); + } else { + // left aligned + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, { + next: openSub, + previous: closeSub, + down: nextSibling, + up: prevSibling + }); + } + } + + Keyboard.handleKey(e, 'DropdownMenu', functions); + }); + } + /** + * Adds an event handler to the body to close any dropdowns on a click. + * @function + * @private + */ + + }, { + key: "_addBodyHandler", + value: function _addBodyHandler() { + var _this2 = this; + + var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body); + + this._removeBodyHandler(); + + $body.on('click.zf.dropdownMenu tap.zf.dropdownMenu', function (e) { + var isItself = !!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).closest(_this2.$element).length; + if (isItself) return; + + _this2._hide(); + + _this2._removeBodyHandler(); + }); + } + /** + * Remove the body event handler. See `_addBodyHandler`. + * @function + * @private + */ + + }, { + key: "_removeBodyHandler", + value: function _removeBodyHandler() { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdownMenu tap.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 jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).find($sub).length > 0; + })); + var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent'); + + this._hide($sibs, idx); + + $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active'); + var clear = Box.ImNotTouchingYou($sub, null, true); + + if (!clear) { + var oldClass = this.options.alignment === 'left' ? '-right' : '-left', + $parentLi = $sub.parent('.is-dropdown-submenu-parent'); + $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment)); + clear = Box.ImNotTouchingYou($sub, null, true); + + if (!clear) { + $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner'); + } + + this.changed = true; + } + + $sub.css('visibility', ''); + + if (this.options.closeOnClick) { + this._addBodyHandler(); + } + /** + * Fires when the new dropdown pane is visible. + * @event DropdownMenu#show + */ + + + this.$element.trigger('show.zf.dropdownMenu', [$sub]); + } + /** + * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything. + * @function + * @param {jQuery} $elem - element with a submenu to hide + * @param {Number} idx - index of the $tabs collection to hide + * @fires DropdownMenu#hide + * @private + */ + + }, { + key: "_hide", + value: function _hide($elem, idx) { + var $toClose; + + if ($elem && $elem.length) { + $toClose = $elem; + } else if (typeof idx !== 'undefined') { + $toClose = this.$tabs.not(function (i, el) { + return i === idx; + }); + } else { + $toClose = this.$element; + } + + var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0; + + if (somethingToClose) { + var $activeItem = $toClose.find('li.is-active'); + $activeItem.add($toClose).attr({ + 'data-is-click': false + }).removeClass('is-active'); + $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active'); + + if (this.changed || $toClose.find('opens-inner').length) { + var oldClass = this.options.alignment === 'left' ? 'right' : 'left'; + $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass)); + this.changed = false; + } + + clearTimeout($activeItem.data('_delay')); + + this._removeBodyHandler(); + /** + * 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'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('.zf.dropdownMenu'); + Nest.Burn(this.$element, 'dropdown'); + } + }]); + + return DropdownMenu; +}(Plugin); +/** + * Default settings for plugin + */ + + +DropdownMenu.defaults = { + /** + * Disallows hover events from opening submenus + * @option + * @type {boolean} + * @default false + */ + disableHover: false, + + /** + * Allow a submenu to automatically close on a mouseleave event, if not clicked open. + * @option + * @type {boolean} + * @default true + */ + autoclose: true, + + /** + * Amount of time to delay opening a submenu on hover event. + * @option + * @type {number} + * @default 50 + */ + hoverDelay: 50, + + /** + * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu. + * @option + * @type {boolean} + * @default false + */ + clickOpen: false, + + /** + * Amount of time to delay closing a submenu on a mouseleave event. + * @option + * @type {number} + * @default 500 + */ + closingTime: 500, + + /** + * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`. + * @option + * @type {string} + * @default 'auto' + */ + alignment: 'auto', + + /** + * Allow clicks on the body to close any open submenus. + * @option + * @type {boolean} + * @default true + */ + closeOnClick: true, + + /** + * Allow clicks on leaf anchor links to close any open submenus. + * @option + * @type {boolean} + * @default true + */ + closeOnClickInside: true, + + /** + * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class. + * @option + * @type {string} + * @default 'vertical' + */ + verticalClass: 'vertical', + + /** + * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class. + * @option + * @type {string} + * @default 'align-right' + */ + rightClass: 'align-right', + + /** + * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile. + * @option + * @type {boolean} + * @default true + */ + forceFollow: true +}; +/** + * Equalizer module. + * @module foundation.equalizer + * @requires foundation.util.mediaQuery + * @requires foundation.util.imageLoader if equalizer contains images + */ + +var Equalizer = /*#__PURE__*/function (_Plugin) { + _inherits(Equalizer, _Plugin); + + function Equalizer() { + _classCallCheck(this, Equalizer); + + return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments)); + } + + _createClass(Equalizer, [{ + key: "_setup", + + /** + * Creates a new instance of Equalizer. + * @class + * @name Equalizer + * @fires Equalizer#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Equalizer.defaults, this.$element.data(), options); + this.className = 'Equalizer'; // ie9 back compat + + this._init(); + } + /** + * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load. + * @private + */ + + }, { + key: "_init", + value: function _init() { + var eqId = this.$element.attr('data-equalizer') || ''; + var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]")); + + MediaQuery._init(); + + this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]'); + this.$element.attr('data-resize', eqId || GetYoDigits(6, 'eq')); + this.$element.attr('data-mutate', eqId || GetYoDigits(6, 'eq')); + this.hasNested = this.$element.find('[data-equalizer]').length > 0; + this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0; + this.isOn = false; + this._bindHandler = { + onResizeMeBound: this._onResizeMe.bind(this), + onPostEqualizedBound: this._onPostEqualized.bind(this) + }; + var imgs = this.$element.find('img'); + var tooSmall; + + if (this.options.equalizeOn) { + tooSmall = this._checkMQ(); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this)); + } else { + this._events(); + } + + if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') { + if (imgs.length) { + onImagesLoaded(imgs, this._reflow.bind(this)); + } else { + this._reflow(); + } + } + } + /** + * Removes event listeners if the breakpoint is too small. + * @private + */ + + }, { + key: "_pauseEvents", + value: function _pauseEvents() { + this.isOn = false; + this.$element.off({ + '.zf.equalizer': this._bindHandler.onPostEqualizedBound, + 'resizeme.zf.trigger': this._bindHandler.onResizeMeBound, + 'mutateme.zf.trigger': this._bindHandler.onResizeMeBound + }); + } + /** + * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound + * @private + */ + + }, { + key: "_onResizeMe", + value: function _onResizeMe(e) { + this._reflow(); + } + /** + * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound + * @private + */ + + }, { + key: "_onPostEqualized", + value: function _onPostEqualized(e) { + if (e.target !== this.$element[0]) { + this._reflow(); + } + } + /** + * Initializes events for Equalizer. + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._pauseEvents(); + + if (this.hasNested) { + this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound); + } else { + this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound); + this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound); + } + + this.isOn = true; + } + /** + * Checks the current breakpoint to the minimum required size. + * @private + */ + + }, { + key: "_checkMQ", + value: function _checkMQ() { + var tooSmall = !MediaQuery.is(this.options.equalizeOn); + + if (tooSmall) { + if (this.isOn) { + this._pauseEvents(); + + this.$watched.css('height', 'auto'); + } + } else { + if (!this.isOn) { + this._events(); + } + } + + return tooSmall; + } + /** + * A noop version for the plugin + * @private + */ + + }, { + key: "_killswitch", + value: function _killswitch() { + return; + } + /** + * Calls necessary functions to update Equalizer upon DOM change + * @private + */ + + }, { + key: "_reflow", + value: function _reflow() { + if (!this.options.equalizeOnStack) { + if (this._isStacked()) { + this.$watched.css('height', 'auto'); + return false; + } + } + + if (this.options.equalizeByRow) { + this.getHeightsByRow(this.applyHeightByRow.bind(this)); + } else { + this.getHeights(this.applyHeight.bind(this)); + } + } + /** + * Manually determines if the first 2 elements are *NOT* stacked. + * @private + */ + + }, { + key: "_isStacked", + value: function _isStacked() { + if (!this.$watched[0] || !this.$watched[1]) { + return true; + } + + return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top; + } + /** + * Finds the outer heights of children contained within an Equalizer parent and returns them in an array + * @param {Function} cb - A non-optional callback to return the heights array to. + * @returns {Array} heights - An array of heights of children within Equalizer container + */ + + }, { + key: "getHeights", + value: function getHeights(cb) { + var heights = []; + + for (var i = 0, len = this.$watched.length; i < len; i++) { + this.$watched[i].style.height = 'auto'; + heights.push(this.$watched[i].offsetHeight); + } + + cb(heights); + } + /** + * Finds the outer heights of children contained within an Equalizer parent and returns them in an array + * @param {Function} cb - A non-optional callback to return the heights array to. + * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child + */ + + }, { + key: "getHeightsByRow", + value: function getHeightsByRow(cb) { + var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0, + groups = [], + group = 0; //group by Row + + groups[group] = []; + + for (var i = 0, len = this.$watched.length; i < len; i++) { + this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop + + var elOffsetTop = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$watched[i]).offset().top; + + if (elOffsetTop != lastElTopOffset) { + group++; + groups[group] = []; + lastElTopOffset = elOffsetTop; + } + + groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]); + } + + for (var j = 0, ln = groups.length; j < ln; j++) { + var heights = jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[j]).map(function () { + return this[1]; + }).get(); + var max = Math.max.apply(null, heights); + groups[j].push(max); + } + + cb(groups); + } + /** + * Changes the CSS height property of each child in an Equalizer parent to match the tallest + * @param {array} heights - An array of heights of children within Equalizer container + * @fires Equalizer#preequalized + * @fires Equalizer#postequalized + */ + + }, { + key: "applyHeight", + value: function applyHeight(heights) { + var max = Math.max.apply(null, heights); + /** + * Fires before the heights are applied + * @event Equalizer#preequalized + */ + + this.$element.trigger('preequalized.zf.equalizer'); + this.$watched.css('height', max); + /** + * Fires when the heights have been applied + * @event Equalizer#postequalized + */ + + this.$element.trigger('postequalized.zf.equalizer'); + } + /** + * 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) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][0][0]).css({ + 'height': 'auto' + }); + continue; + } + /** + * Fires before the heights per row are applied + * @event Equalizer#preequalizedrow + */ + + + this.$element.trigger('preequalizedrow.zf.equalizer'); + + for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][j][0]).css({ + 'height': max + }); + } + /** + * Fires when the heights per row have been applied + * @event Equalizer#postequalizedrow + */ + + + this.$element.trigger('postequalizedrow.zf.equalizer'); + } + /** + * Fires when the heights have been applied + */ + + + this.$element.trigger('postequalized.zf.equalizer'); + } + /** + * Destroys an instance of Equalizer. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this._pauseEvents(); + + this.$watched.css('height', 'auto'); + } + }]); + + return Equalizer; +}(Plugin); +/** + * Default settings for plugin + */ + + +Equalizer.defaults = { + /** + * Enable height equalization when stacked on smaller screens. + * @option + * @type {boolean} + * @default false + */ + equalizeOnStack: false, + + /** + * Enable height equalization row by row. + * @option + * @type {boolean} + * @default false + */ + equalizeByRow: false, + + /** + * String representing the minimum breakpoint size the plugin should equalize heights on. + * @option + * @type {string} + * @default '' + */ + equalizeOn: '' +}; +/** + * Interchange module. + * @module foundation.interchange + * @requires foundation.util.mediaQuery + */ + +var Interchange = /*#__PURE__*/function (_Plugin) { + _inherits(Interchange, _Plugin); + + function Interchange() { + _classCallCheck(this, Interchange); + + return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments)); + } + + _createClass(Interchange, [{ + key: "_setup", + + /** + * Creates a new instance of Interchange. + * @class + * @name Interchange + * @fires Interchange#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Interchange.defaults, this.$element.data(), options); + this.rules = []; + this.currentPath = ''; + this.className = 'Interchange'; // ie9 back compat + // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + + this._events(); + } + /** + * Initializes the Interchange plugin and calls functions to get interchange functioning on load. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); + + var id = this.$element[0].id || GetYoDigits(6, 'interchange'); + this.$element.attr({ + 'data-resize': id, + 'id': id + }); + + this._parseOptions(); + + this._addBreakpoints(); + + this._generateRules(); + + this._reflow(); + } + /** + * Initializes events for Interchange. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; + + this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () { + return _this._reflow(); + }); + } + /** + * Calls necessary functions to update Interchange upon DOM change + * @function + * @private + */ + + }, { + key: "_reflow", + value: function _reflow() { + var match; // Iterate through each rule, but only save the last match + + for (var i in this.rules) { + if (this.rules.hasOwnProperty(i)) { + var rule = this.rules[i]; + + if (window.matchMedia(rule.query).matches) { + match = rule; + } + } + } + + if (match) { + this.replace(match.path); + } + } + /** + * Check options valifity and set defaults for: + * - `data-interchange-type`: if set, enforce the type of replacement (auto, src, background or html) + * @function + * @private + */ + + }, { + key: "_parseOptions", + value: function _parseOptions() { + var types = ['auto', 'src', 'background', 'html']; + if (typeof this.options.type === 'undefined') this.options.type = 'auto';else if (types.indexOf(this.options.type) === -1) { + console.log("Warning: invalid value \"".concat(this.options.type, "\" for Interchange option \"type\"")); + this.options.type = 'auto'; + } + } + /** + * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object. + * @function + * @private + */ + + }, { + key: "_addBreakpoints", + value: function _addBreakpoints() { + for (var i in MediaQuery.queries) { + if (MediaQuery.queries.hasOwnProperty(i)) { + var query = MediaQuery.queries[i]; + Interchange.SPECIAL_QUERIES[query.name] = query.value; + } + } + } + /** + * Checks the Interchange element for the provided media query + content pairings + * @function + * @private + * @param {Object} element - jQuery object that is an Interchange instance + * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys + */ + + }, { + key: "_generateRules", + value: function _generateRules(element) { + var rulesList = []; + var rules; + + if (this.options.rules) { + rules = this.options.rules; + } else { + rules = this.$element.data('interchange'); + } + + rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules; + + for (var i in rules) { + if (rules.hasOwnProperty(i)) { + var rule = rules[i].slice(1, -1).split(', '); + var path = rule.slice(0, -1).join(''); + var query = rule[rule.length - 1]; + + if (Interchange.SPECIAL_QUERIES[query]) { + query = Interchange.SPECIAL_QUERIES[query]; + } + + rulesList.push({ + path: path, + query: query + }); + } + } + + this.rules = rulesList; + } + /** + * Update the `src` property of an image, or change the HTML of a container, to the specified path. + * @function + * @param {String} path - Path to the image or HTML partial. + * @fires Interchange#replaced + */ + + }, { + key: "replace", + value: function replace(path) { + var _this2 = this; + + if (this.currentPath === path) return; + var trigger = 'replaced.zf.interchange'; + var type = this.options.type; + + if (type === 'auto') { + if (this.$element[0].nodeName === 'IMG') type = 'src';else if (path.match(/\.(gif|jpe?g|png|svg|tiff)([?#].*)?/i)) type = 'background';else type = 'html'; + } // Replacing images + + + if (type === 'src') { + this.$element.attr('src', path).on('load', function () { + _this2.currentPath = path; + }).trigger(trigger); + } // Replacing background images + else if (type === 'background') { + path = path.replace(/\(/g, '%28').replace(/\)/g, '%29'); + this.$element.css({ + 'background-image': 'url(' + path + ')' + }).trigger(trigger); + } // Replacing HTML + else if (type === 'html') { + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.get(path, function (response) { + _this2.$element.html(response).trigger(trigger); + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(response).foundation(); + _this2.currentPath = path; + }); + } + /** + * Fires when content in an Interchange element is done being loaded. + * @event Interchange#replaced + */ + // this.$element.trigger('replaced.zf.interchange'); + + } + /** + * Destroys an instance of interchange. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('resizeme.zf.trigger'); + } + }]); + + return Interchange; +}(Plugin); +/** + * Default settings for plugin + */ + + +Interchange.defaults = { + /** + * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation. + * @option + * @type {?array} + * @default null + */ + rules: null, + + /** + * Type of the responsive ressource to replace. It can take the following options: + * - `auto` (default): choose the type according to the element tag or the ressource extension, + * - `src`: replace the `[src]` attribute, recommended for images ``. + * - `background`: replace the `background-image` CSS property. + * - `html`: replace the element content. + * @option + * @type {string} + * @default 'auto' + */ + type: 'auto' +}; +Interchange.SPECIAL_QUERIES = { + 'landscape': 'screen and (orientation: landscape)', + 'portrait': 'screen and (orientation: portrait)', + 'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)' +}; +/** + * SmoothScroll module. + * @module foundation.smoothScroll + */ + +var SmoothScroll = /*#__PURE__*/function (_Plugin) { + _inherits(SmoothScroll, _Plugin); + + function SmoothScroll() { + _classCallCheck(this, SmoothScroll); + + return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments)); + } + + _createClass(SmoothScroll, [{ + key: "_setup", + + /** + * Creates a new instance of SmoothScroll. + * @class + * @name SmoothScroll + * @fires SmoothScroll#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options); + this.className = 'SmoothScroll'; // ie9 back compat + + this._init(); + } + /** + * Initialize the SmoothScroll plugin + * @private + */ + + }, { + key: "_init", + value: function _init() { + var id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll'); + this.$element.attr({ + id: id + }); + + this._events(); + } + /** + * Initializes events for SmoothScroll. + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._linkClickListener = this._handleLinkClick.bind(this); + this.$element.on('click.zf.smoothScroll', this._linkClickListener); + this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener); + } + /** + * Handle the given event to smoothly scroll to the anchor pointed by the event target. + * @param {*} e - event + * @function + * @private + */ + + }, { + key: "_handleLinkClick", + value: function _handleLinkClick(e) { + var _this = this; // Follow the link if it does not point to an anchor. + + + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget).is('a[href^="#"]')) return; + var arrival = e.currentTarget.getAttribute('href'); + this._inTransition = true; + SmoothScroll.scrollToLoc(arrival, this.options, function () { + _this._inTransition = false; + }); + e.preventDefault(); + } + }, { + key: "_destroy", + + /** + * Destroys the SmoothScroll instance. + * @function + */ + value: function _destroy() { + this.$element.off('click.zf.smoothScroll', this._linkClickListener); + this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener); + } + }], [{ + key: "scrollToLoc", + + /** + * Function to scroll to a given location on the page. + * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo' + * @param {Object} options - The options to use. + * @param {Function} callback - The callback function. + * @static + * @function + */ + value: function scrollToLoc(loc) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults; + var callback = arguments.length > 2 ? arguments[2] : undefined; + var $loc = jquery__WEBPACK_IMPORTED_MODULE_0___default()(loc); // Do nothing if target does not exist to prevent errors + + if (!$loc.length) return false; + var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({ + scrollTop: scrollPos + }, options.animationDuration, options.animationEasing, function () { + if (typeof callback === 'function') { + callback(); + } + }); + } + }]); + + return SmoothScroll; +}(Plugin); +/** + * Default settings for plugin. + */ + + +SmoothScroll.defaults = { + /** + * Amount of time, in ms, the animated scrolling should take between locations. + * @option + * @type {number} + * @default 500 + */ + animationDuration: 500, + + /** + * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`. + * @option + * @type {string} + * @default 'linear' + * @see {@link https://api.jquery.com/animate|Jquery animate} + */ + animationEasing: 'linear', + + /** + * Number of pixels to use as a marker for location changes. + * @option + * @type {number} + * @default 50 + */ + threshold: 50, + + /** + * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar. + * @option + * @type {number} + * @default 0 + */ + offset: 0 +}; +/** + * Magellan module. + * @module foundation.magellan + * @requires foundation.smoothScroll + * @requires foundation.util.triggers + */ + +var Magellan = /*#__PURE__*/function (_Plugin) { + _inherits(Magellan, _Plugin); + + function Magellan() { + _classCallCheck(this, Magellan); + + return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments)); + } + + _createClass(Magellan, [{ + key: "_setup", + + /** + * Creates a new instance of Magellan. + * @class + * @name Magellan + * @fires Magellan#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Magellan.defaults, this.$element.data(), options); + this.className = 'Magellan'; // ie9 back compat + // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + + this.calcPoints(); + } + /** + * Initializes the Magellan plugin and calls functions to get equalizer functioning on load. + * @private + */ + + }, { + key: "_init", + value: function _init() { + var id = this.$element[0].id || GetYoDigits(6, 'magellan'); + this.$targets = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-magellan-target]'); + this.$links = this.$element.find('a'); + this.$element.attr({ + 'data-resize': id, + 'data-scroll': id, + 'id': id + }); + this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + this.scrollPos = parseInt(window.pageYOffset, 10); + + this._events(); + } + /** + * 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 = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + pt = Math.round($tar.offset().top - _this.options.threshold); + $tar.targetPoint = pt; + + _this.points.push(pt); + }); + } + /** + * Initializes events for Magellan. + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', function () { + if (_this.options.deepLinking) { + if (location.hash) { + _this.scrollToLoc(location.hash); + } + } + + _this.calcPoints(); + + _this._updateActive(); + }); + _this.onLoadListener = onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + _this.$element.on({ + 'resizeme.zf.trigger': _this.reflow.bind(_this), + 'scrollme.zf.trigger': _this._updateActive.bind(_this) + }).on('click.zf.magellan', 'a[href^="#"]', function (e) { + e.preventDefault(); + var arrival = this.getAttribute('href'); + + _this.scrollToLoc(arrival); + }); + }); + + this._deepLinkScroll = function (e) { + if (_this.options.deepLinking) { + _this.scrollToLoc(window.location.hash); + } + }; + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._deepLinkScroll); + } + /** + * Function to scroll to a given location on the page. + * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo' + * @function + */ + + }, { + key: "scrollToLoc", + value: function scrollToLoc(loc) { + this._inTransition = true; + + var _this = this; + + var options = { + animationEasing: this.options.animationEasing, + animationDuration: this.options.animationDuration, + threshold: this.options.threshold, + offset: this.options.offset + }; + SmoothScroll.scrollToLoc(loc, options, function () { + _this._inTransition = false; + }); + } + /** + * Calls necessary functions to update Magellan upon DOM change + * @function + */ + + }, { + key: "reflow", + value: function reflow() { + this.calcPoints(); + + this._updateActive(); + } + /** + * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled. + * @private + * @function + * @fires Magellan#update + */ + + }, { + key: "_updateActive", + value: function _updateActive() + /*evt, elem, scrollPos*/ + { + var _this2 = this; + + if (this._inTransition) return; + var newScrollPos = parseInt(window.pageYOffset, 10); + var isScrollingUp = this.scrollPos > newScrollPos; + this.scrollPos = newScrollPos; + var activeIdx; // Before the first point: no link + + if (newScrollPos < this.points[0]) ; + /* do nothing */ + // At the bottom of the page: last link + else if (newScrollPos + this.winHeight === this.docHeight) { + activeIdx = this.points.length - 1; + } // Otherwhise, use the last visible link + else { + var visibleLinks = this.points.filter(function (p, i) { + return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos; + }); + activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0; + } // Get the new active link + + var $oldActive = this.$active; + var activeHash = ''; + + if (typeof activeIdx !== 'undefined') { + this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]'); + if (this.$active.length) activeHash = this.$active[0].getAttribute('href'); + } else { + this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + } + + var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive); + var isNewHash = activeHash !== window.location.hash; // Update the active link element + + if (isNewActive) { + $oldActive.removeClass(this.options.activeClass); + this.$active.addClass(this.options.activeClass); + } // Update the hash (it may have changed with the same active link) + + + if (this.options.deepLinking && isNewHash) { + if (window.history.pushState) { + // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384 + var url = activeHash ? activeHash : window.location.pathname + window.location.search; + + if (this.options.updateHistory) { + window.history.pushState({}, '', url); + } else { + window.history.replaceState({}, '', url); + } + } else { + window.location.hash = activeHash; + } + } + + if (isNewActive) { + /** + * Fires when magellan is finished updating to the new active element. + * @event Magellan#update + */ + this.$element.trigger('update.zf.magellan', [this.$active]); + } + } + /** + * Destroys an instance of Magellan and resets the url of the window. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass); + + if (this.options.deepLinking) { + var hash = this.$active[0].getAttribute('href'); + window.location.hash.replace(hash, ''); + } + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._deepLinkScroll); + if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener); + } + }]); + + return Magellan; +}(Plugin); +/** + * Default settings for plugin + */ + + +Magellan.defaults = { + /** + * Amount of time, in ms, the animated scrolling should take between locations. + * @option + * @type {number} + * @default 500 + */ + animationDuration: 500, + + /** + * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`. + * @option + * @type {string} + * @default 'linear' + * @see {@link https://api.jquery.com/animate|Jquery animate} + */ + animationEasing: 'linear', + + /** + * Number of pixels to use as a marker for location changes. + * @option + * @type {number} + * @default 50 + */ + threshold: 50, + + /** + * Class applied to the active locations link on the magellan container. + * @option + * @type {string} + * @default 'is-active' + */ + activeClass: 'is-active', + + /** + * Allows the script to manipulate the url of the current page, and if supported, alter the history. + * @option + * @type {boolean} + * @default false + */ + deepLinking: false, + + /** + * Update the browser history with the active link, if deep linking is enabled. + * @option + * @type {boolean} + * @default false + */ + updateHistory: false, + + /** + * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar. + * @option + * @type {number} + * @default 0 + */ + offset: 0 +}; +/** + * OffCanvas module. + * @module foundation.offCanvas + * @requires foundation.util.keyboard + * @requires foundation.util.mediaQuery + * @requires foundation.util.triggers + */ + +var OffCanvas = /*#__PURE__*/function (_Plugin) { + _inherits(OffCanvas, _Plugin); + + function OffCanvas() { + _classCallCheck(this, OffCanvas); + + return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments)); + } + + _createClass(OffCanvas, [{ + key: "_setup", + + /** + * Creates a new instance of an off-canvas wrapper. + * @class + * @name OffCanvas + * @fires OffCanvas#init + * @param {Object} element - jQuery object to initialize. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + var _this2 = this; + + this.className = 'OffCanvas'; // ie9 back compat + + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options); + this.contentClasses = { + base: [], + reveal: [] + }; + this.$lastTrigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + this.position = 'left'; + this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + this.nested = !!this.options.nested; + this.$sticky = jquery__WEBPACK_IMPORTED_MODULE_0___default()(); + this.isInCanvas = false; // Defines the CSS transition/position classes of the off-canvas content container. + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(['push', 'overlap']).each(function (index, val) { + _this2.contentClasses.base.push('has-transition-' + val); + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) { + _this2.contentClasses.base.push('has-position-' + val); + + _this2.contentClasses.reveal.push('has-reveal-' + val); + }); // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + MediaQuery._init(); + + this._init(); + + this._events(); + + Keyboard.register('OffCanvas', { + 'ESCAPE': 'close' + }); + } + /** + * Initializes the off-canvas wrapper by adding the exit overlay (if needed). + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + var id = this.$element.attr('id'); + this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback) + + if (this.options.contentId) { + this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + this.options.contentId); + } else if (this.$element.siblings('[data-off-canvas-content]').length) { + this.$content = this.$element.siblings('[data-off-canvas-content]').first(); + } else { + this.$content = this.$element.closest('[data-off-canvas-content]').first(); + } + + if (!this.options.contentId) { + // Assume that the off-canvas element is nested if it isn't a sibling of the content + this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0; + } else if (this.options.contentId && this.options.nested === null) { + // Warning if using content ID without setting the nested option + // Once the element is nested it is required to work properly in this case + console.warn('Remember to use the nested option if using the content ID option!'); + } + + if (this.nested === true) { + // Force transition overlap if nested + this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup + + this.$element.removeClass('is-transition-push'); + } + + this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them + + this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class + + this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary + + if (this.options.contentOverlay === true) { + var overlay = document.createElement('div'); + var overlayPosition = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute'; + overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition); + this.$overlay = jquery__WEBPACK_IMPORTED_MODULE_0___default()(overlay); + + if (overlayPosition === 'is-overlay-fixed') { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$overlay).insertAfter(this.$element); + } else { + this.$content.append(this.$overlay); + } + } // Get the revealOn option from the class. + + + var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\s]+)', 'g'); + var revealOnClass = revealOnRegExp.exec(this.$element[0].className); + + if (revealOnClass) { + this.options.isRevealed = true; + this.options.revealOn = this.options.revealOn || revealOnClass[1]; + } // Ensure the `reveal-on-*` class is set. + + + if (this.options.isRevealed === true && this.options.revealOn) { + this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn)); + + this._setMQChecker(); + } + + if (this.options.transitionTime) { + this.$element.css('transition-duration', this.options.transitionTime); + } // Find fixed elements that should stay fixed while off-canvas is opened + + + this.$sticky = this.$content.find('[data-off-canvas-sticky]'); + + if (this.$sticky.length > 0 && this.options.transition === 'push') { + // If there's at least one match force contentScroll:false because the absolute top value doesn't get recalculated on scroll + // Limit to push transition since there's no transform scope for overlap + this.options.contentScroll = false; + } + + var inCanvasFor = this.$element.attr('class').match(/\bin-canvas-for-(\w+)/); + + if (inCanvasFor && inCanvasFor.length === 2) { + // Set `inCanvasOn` option if found in-canvas-for-[BREAKPONT] CSS class + this.options.inCanvasOn = inCanvasFor[1]; + } else if (this.options.inCanvasOn) { + // Ensure the CSS class is set + this.$element.addClass("in-canvas-for-".concat(this.options.inCanvasOn)); + } + + if (this.options.inCanvasOn) { + this._checkInCanvas(); + } // Initally remove all transition/position CSS classes from off-canvas content container. + + + this._removeContentClasses(); + } + /** + * Adds event handlers to the off-canvas wrapper and the exit overlay. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this3 = this; + + this.$element.off('.zf.trigger .zf.offCanvas').on({ + 'open.zf.trigger': this.open.bind(this), + 'close.zf.trigger': this.close.bind(this), + 'toggle.zf.trigger': this.toggle.bind(this), + 'keydown.zf.offCanvas': this._handleKeyboard.bind(this) + }); + + if (this.options.closeOnClick === true) { + var $target = this.options.contentOverlay ? this.$overlay : this.$content; + $target.on({ + 'click.zf.offCanvas': this.close.bind(this) + }); + } + + if (this.options.inCanvasOn) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () { + _this3._checkInCanvas(); + }); + } + } + /** + * Applies event listener for elements that will reveal at certain breakpoints. + * @private + */ + + }, { + key: "_setMQChecker", + value: function _setMQChecker() { + var _this = this; + + this.onLoadListener = onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + if (MediaQuery.atLeast(_this.options.revealOn)) { + _this.reveal(true); + } + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () { + if (MediaQuery.atLeast(_this.options.revealOn)) { + _this.reveal(true); + } else { + _this.reveal(false); + } + }); + } + /** + * Checks if InCanvas on current breakpoint and adjust off-canvas accordingly + * @private + */ + + }, { + key: "_checkInCanvas", + value: function _checkInCanvas() { + this.isInCanvas = MediaQuery.atLeast(this.options.inCanvasOn); + + if (this.isInCanvas === true) { + this.close(); + } + } + /** + * Removes the CSS transition/position classes of the off-canvas content container. + * Removing the classes is important when another off-canvas gets opened that uses the same content container. + * @param {Boolean} hasReveal - true if related off-canvas element is revealed. + * @private + */ + + }, { + key: "_removeContentClasses", + value: function _removeContentClasses(hasReveal) { + if (typeof hasReveal !== 'boolean') { + this.$content.removeClass(this.contentClasses.base.join(' ')); + } else if (hasReveal === false) { + this.$content.removeClass("has-reveal-".concat(this.position)); + } + } + /** + * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element. + * Beforehand any transition/position class gets removed. + * @param {Boolean} hasReveal - true if related off-canvas element is revealed. + * @private + */ + + }, { + key: "_addContentClasses", + value: function _addContentClasses(hasReveal) { + this._removeContentClasses(hasReveal); + + if (typeof hasReveal !== 'boolean') { + this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position)); + } else if (hasReveal === true) { + this.$content.addClass("has-reveal-".concat(this.position)); + } + } + /** + * Preserves the fixed behavior of sticky elements on opening an off-canvas with push transition. + * Since the off-canvas container has got a transform scope in such a case, it is done by calculating position absolute values. + * @private + */ + + }, { + key: "_fixStickyElements", + value: function _fixStickyElements() { + this.$sticky.each(function (_, el) { + var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el); // If sticky element is currently fixed, adjust its top value to match absolute position due to transform scope + // Limit to push transition because postion:fixed works without problems for overlap (no transform scope) + + if ($el.css('position') === 'fixed') { + // Save current inline styling to restore it if undoing the absolute fixing + var topVal = parseInt($el.css('top'), 10); + $el.data('offCanvasSticky', { + top: topVal + }); + var absoluteTopVal = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).scrollTop() + topVal; + $el.css({ + top: "".concat(absoluteTopVal, "px"), + width: '100%', + transition: 'none' + }); + } + }); + } + /** + * Restores the original fixed styling of sticky elements after having closed an off-canvas that got pseudo fixed beforehand. + * This reverts the changes of _fixStickyElements() + * @private + */ + + }, { + key: "_unfixStickyElements", + value: function _unfixStickyElements() { + this.$sticky.each(function (_, el) { + var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el); + var stickyData = $el.data('offCanvasSticky'); // If sticky element has got data object with prior values (meaning it was originally fixed) restore these values once off-canvas is closed + + if (_typeof(stickyData) === 'object') { + $el.css({ + top: "".concat(stickyData.top, "px"), + width: '', + transition: '' + }); + $el.data('offCanvasSticky', ''); + } + }); + } + /** + * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open. + * @param {Boolean} isRevealed - true if element should be revealed. + * @function + */ + + }, { + key: "reveal", + value: function reveal(isRevealed) { + if (isRevealed) { + this.close(); + this.isRevealed = true; + this.$element.attr('aria-hidden', 'false'); + this.$element.off('open.zf.trigger toggle.zf.trigger'); + this.$element.removeClass('is-closed'); + } else { + this.isRevealed = false; + this.$element.attr('aria-hidden', 'true'); + this.$element.off('open.zf.trigger toggle.zf.trigger').on({ + 'open.zf.trigger': this.open.bind(this), + 'toggle.zf.trigger': this.toggle.bind(this) + }); + this.$element.addClass('is-closed'); + } + + this._addContentClasses(isRevealed); + } + /** + * Stops scrolling of the body when OffCanvas is open on mobile Safari and other troublesome browsers. + * @function + * @private + */ + + }, { + key: "_stopScrolling", + value: function _stopScrolling(event) { + return false; + } + /** + * Tag the element given as context whether it can be scrolled up and down. + * Used to allow or prevent it to scroll. See `_stopScrollPropagation`. + * + * 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. + * + * @function + * @private + */ + + }, { + 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; + } + /** + * Prevent the given event propagation if the element given as context can scroll. + * Used to preserve the element scrolling on mobile (`touchmove`) when the document + * scrolling is prevented. See https://git.io/zf-9707. + * @function + * @private + */ + + }, { + key: "_stopScrollPropagation", + value: function _stopScrollPropagation(event) { + var elem = this; // called from event handler context with this as elem + + var parent; // off-canvas elem if called from inner scrollbox + + var up = event.pageY < elem.lastY; + var down = !up; + elem.lastY = event.pageY; + + if (up && elem.allowUp || down && elem.allowDown) { + // It is not recommended to stop event propagation (the user cannot watch it), + // but in this case this is the only solution we have. + event.stopPropagation(); // If elem is inner scrollbox we are scrolling the outer off-canvas down/up once the box end has been reached + // This lets the user continue to touch move the off-canvas without the need to place the finger outside the scrollbox + + if (elem.hasAttribute('data-off-canvas-scrollbox')) { + parent = elem.closest('[data-off-canvas], [data-off-canvas-scrollbox-outer]'); + + if (elem.scrollTop <= 1 && parent.scrollTop > 0) { + parent.scrollTop--; + } else if (elem.scrollTop >= elem.scrollHeight - elem.clientHeight - 1 && parent.scrollTop < parent.scrollHeight - parent.clientHeight) { + parent.scrollTop++; + } + } + } else { + event.preventDefault(); + } + } + /** + * Opens the off-canvas menu. + * @function + * @param {Object} event - Event object passed from listener. + * @param {jQuery} trigger - element that triggered the off-canvas to open. + * @fires OffCanvas#opened + * @todo also trigger 'open' event? + */ + + }, { + key: "open", + value: function open(event, trigger) { + var _this4 = this; + + if (this.$element.hasClass('is-open') || this.isRevealed || this.isInCanvas) { + return; + } + + var _this = this; + + if (trigger) { + this.$lastTrigger = trigger; + } + + if (this.options.forceTo === 'top') { + window.scrollTo(0, 0); + } else if (this.options.forceTo === 'bottom') { + window.scrollTo(0, document.body.scrollHeight); + } + + if (this.options.transitionTime && this.options.transition !== 'overlap') { + this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime); + } else { + this.$element.siblings('[data-off-canvas-content]').css('transition-duration', ''); + } + + this.$element.addClass('is-open').removeClass('is-closed'); + this.$triggers.attr('aria-expanded', 'true'); + this.$element.attr('aria-hidden', 'false'); + this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices. + + if (this.options.contentScroll === false) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling); + this.$element.on('touchstart', this._recordScrollable); + this.$element.on('touchmove', this._stopScrollPropagation); + this.$element.on('touchstart', '[data-off-canvas-scrollbox]', this._recordScrollable); + this.$element.on('touchmove', '[data-off-canvas-scrollbox]', this._stopScrollPropagation); + } + + if (this.options.contentOverlay === true) { + this.$overlay.addClass('is-visible'); + } + + if (this.options.closeOnClick === true && this.options.contentOverlay === true) { + this.$overlay.addClass('is-closable'); + } + + if (this.options.autoFocus === true) { + this.$element.one(transitionend(this.$element), function () { + if (!_this.$element.hasClass('is-open')) { + return; // exit if prematurely closed + } + + var canvasFocus = _this.$element.find('[data-autofocus]'); + + if (canvasFocus.length) { + canvasFocus.eq(0).focus(); + } else { + _this.$element.find('a, button').eq(0).focus(); + } + }); + } + + if (this.options.trapFocus === true) { + this.$content.attr('tabindex', '-1'); + Keyboard.trapFocus(this.$element); + } + + if (this.options.transition === 'push') { + this._fixStickyElements(); + } + + this._addContentClasses(); + /** + * Fires when the off-canvas menu opens. + * @event OffCanvas#opened + */ + + + this.$element.trigger('opened.zf.offCanvas'); + /** + * Fires when the off-canvas menu open transition is done. + * @event OffCanvas#openedEnd + */ + + this.$element.one(transitionend(this.$element), function () { + _this4.$element.trigger('openedEnd.zf.offCanvas'); + }); + } + /** + * Closes the off-canvas menu. + * @function + * @param {Function} cb - optional cb to fire after closure. + * @fires OffCanvas#close + * @fires OffCanvas#closed + */ + + }, { + key: "close", + value: function close(cb) { + var _this5 = this; + + if (!this.$element.hasClass('is-open') || this.isRevealed) { + return; + } + /** + * Fires when the off-canvas menu closes. + * @event OffCanvas#close + */ + + + this.$element.trigger('close.zf.offCanvas'); + this.$element.removeClass('is-open'); + this.$element.attr('aria-hidden', 'true'); + this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); + + 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'); // Listen to transitionEnd: add class, re-enable scrolling and release focus when done. + + this.$element.one(transitionend(this.$element), function (e) { + _this5.$element.addClass('is-closed'); + + _this5._removeContentClasses(); + + if (_this5.options.transition === 'push') { + _this5._unfixStickyElements(); + } // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices. + + + if (_this5.options.contentScroll === false) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').removeClass('is-off-canvas-open').off('touchmove', _this5._stopScrolling); + + _this5.$element.off('touchstart', _this5._recordScrollable); + + _this5.$element.off('touchmove', _this5._stopScrollPropagation); + + _this5.$element.off('touchstart', '[data-off-canvas-scrollbox]', _this5._recordScrollable); + + _this5.$element.off('touchmove', '[data-off-canvas-scrollbox]', _this5._stopScrollPropagation); + } + + if (_this5.options.trapFocus === true) { + _this5.$content.removeAttr('tabindex'); + + Keyboard.releaseFocus(_this5.$element); + } + /** + * Fires when the off-canvas menu close transition is done. + * @event OffCanvas#closed + */ + + + _this5.$element.trigger('closed.zf.offCanvas'); + }); + } + /** + * 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 _this6 = this; + + Keyboard.handleKey(e, 'OffCanvas', { + close: function close() { + _this6.close(); + + _this6.$lastTrigger.focus(); + + return true; + }, + handled: function handled() { + e.preventDefault(); + } + }); + } + /** + * Destroys the OffCanvas plugin. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.close(); + this.$element.off('.zf.trigger .zf.offCanvas'); + this.$overlay.off('.zf.offCanvas'); + if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener); + } + }]); + + return OffCanvas; +}(Plugin); + +OffCanvas.defaults = { + /** + * Allow the user to click outside of the menu to close it. + * @option + * @type {boolean} + * @default true + */ + closeOnClick: true, + + /** + * Adds an overlay on top of `[data-off-canvas-content]`. + * @option + * @type {boolean} + * @default true + */ + contentOverlay: true, + + /** + * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken. + * @option + * @type {?string} + * @default null + */ + contentId: null, + + /** + * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element. + * @option + * @type {boolean} + * @default null + */ + nested: null, + + /** + * Enable/disable scrolling of the main content when an off canvas panel is open. + * @option + * @type {boolean} + * @default true + */ + contentScroll: true, + + /** + * Amount of time the open and close transition requires, including the appropriate milliseconds (`ms`) or seconds (`s`) unit (e.g. `500ms`, `.75s`) If none selected, pulls from body style. + * @option + * @type {string} + * @default null + */ + transitionTime: null, + + /** + * Type of transition for the OffCanvas menu. Options are 'push', 'detached' or 'slide'. + * @option + * @type {string} + * @default push + */ + transition: 'push', + + /** + * Force the page to scroll to top or bottom on open. + * @option + * @type {?string} + * @default null + */ + forceTo: null, + + /** + * Allow the OffCanvas to remain open for certain breakpoints. + * @option + * @type {boolean} + * @default false + */ + isRevealed: false, + + /** + * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option. + * @option + * @type {?string} + * @default null + */ + revealOn: null, + + /** + * Breakpoint at which the off-canvas gets moved into canvas content and acts as regular page element. + * @option + * @type {?string} + * @default null + */ + inCanvasOn: null, + + /** + * Force focus to the offcanvas on open. If true, will focus the opening trigger on close. + * @option + * @type {boolean} + * @default true + */ + autoFocus: true, + + /** + * Class used to force an OffCanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`. + * @option + * @type {string} + * @default reveal-for- + * @todo improve the regex testing for this. + */ + revealClass: 'reveal-for-', + + /** + * Triggers optional focus trapping when opening an OffCanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes. + * @option + * @type {boolean} + * @default false + */ + trapFocus: false +}; +/** + * Orbit module. + * @module foundation.orbit + * @requires foundation.util.keyboard + * @requires foundation.util.motion + * @requires foundation.util.timer + * @requires foundation.util.imageLoader + * @requires foundation.util.touch + */ + +var Orbit = /*#__PURE__*/function (_Plugin) { + _inherits(Orbit, _Plugin); + + function Orbit() { + _classCallCheck(this, Orbit); + + return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments)); + } + + _createClass(Orbit, [{ + key: "_setup", + + /** + * Creates a new instance of an orbit carousel. + * @class + * @name Orbit + * @param {jQuery} element - jQuery object to make into an Orbit Carousel. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Orbit.defaults, this.$element.data(), options); + this.className = 'Orbit'; // ie9 back compat + + Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied. + + this._init(); + + Keyboard.register('Orbit', { + 'ltr': { + 'ARROW_RIGHT': 'next', + 'ARROW_LEFT': 'previous' + }, + 'rtl': { + 'ARROW_LEFT': 'next', + 'ARROW_RIGHT': 'previous' + } + }); + } + /** + * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide + this._reset(); + + this.$wrapper = this.$element.find(".".concat(this.options.containerClass)); + this.$slides = this.$element.find(".".concat(this.options.slideClass)); + var $images = this.$element.find('img'), + initActive = this.$slides.filter('.is-active'), + id = this.$element[0].id || GetYoDigits(6, 'orbit'); + this.$element.attr({ + 'data-resize': id, + 'id': id + }); + + if (!initActive.length) { + this.$slides.eq(0).addClass('is-active'); + } + + if (!this.options.useMUI) { + this.$slides.addClass('no-motionui'); + } + + if ($images.length) { + onImagesLoaded($images, this._prepareForOrbit.bind(this)); + } else { + this._prepareForOrbit(); //hehe + + } + + if (this.options.bullets) { + this._loadBullets(); + } + + this._events(); + + if (this.options.autoPlay && this.$slides.length > 1) { + this.geoSync(); + } + + if (this.options.accessible) { + // allow wrapper to be focusable to enable arrow navigation + this.$wrapper.attr('tabindex', 0); + } + } + /** + * Creates a jQuery collection of bullets, if they are being used. + * @function + * @private + */ + + }, { + key: "_loadBullets", + value: function _loadBullets() { + this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button'); + } + /** + * Sets a `timer` object on the orbit, and starts the counter for the next slide. + * @function + */ + + }, { + key: "geoSync", + value: function geoSync() { + var _this = this; + + this.timer = new Timer(this.$element, { + duration: this.options.timerDelay, + infinite: false + }, function () { + _this.changeSlide(true); + }); + this.timer.start(); + } + /** + * Sets wrapper and slide heights for the orbit. + * @function + * @private + */ + + }, { + key: "_prepareForOrbit", + value: function _prepareForOrbit() { + this._setWrapperHeight(); + } + /** + * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height. + * @function + * @private + * @param {Function} cb - a callback function to fire when complete. + */ + + }, { + key: "_setWrapperHeight", + value: function _setWrapperHeight(cb) { + //rewrite this to `for` loop + var max = 0, + temp, + counter = 0, + _this = this; + + this.$slides.each(function () { + temp = this.getBoundingClientRect().height; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('data-slide', counter); // hide all slides but the active one + + if (!/mui/g.test(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css({ + 'display': 'none' + }); + } + + 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 () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css('max-height', height); + }); + } + /** + * Adds event listeners to basically everything within the element. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; //*************************************** + //**Now using custom event - thanks to:** + //** Yohai Ararat of Toronto ** + //*************************************** + // + + + this.$element.off('.resizeme.zf.trigger').on({ + 'resizeme.zf.trigger': this._prepareForOrbit.bind(this) + }); + + if (this.$slides.length > 1) { + if (this.options.swipe) { + this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) { + e.preventDefault(); + + _this.changeSlide(true); + }).on('swiperight.zf.orbit', function (e) { + e.preventDefault(); + + _this.changeSlide(false); + }); + } //*************************************** + + + if (this.options.autoPlay) { + this.$slides.on('click.zf.orbit', function () { + _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true); + + _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start'](); + }); + + if (this.options.pauseOnHover) { + this.$element.on('mouseenter.zf.orbit', function () { + _this.timer.pause(); + }).on('mouseleave.zf.orbit', function () { + if (!_this.$element.data('clickedOn')) { + _this.timer.start(); + } + }); + } + } + + if (this.options.navButtons) { + var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass)); + $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses + .on('click.zf.orbit touchend.zf.orbit', function (e) { + e.preventDefault(); + + _this.changeSlide(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hasClass(_this.options.nextClass)); + }); + } + + if (this.options.bullets) { + this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () { + if (/is-active/g.test(this.className)) { + return false; + } //if this is active, kick out of function. + + + var idx = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('slide'), + ltr = idx > _this.$slides.filter('.is-active').data('slide'), + $slide = _this.$slides.eq(idx); + + _this.changeSlide(ltr, $slide, idx); + }); + } + + if (this.options.accessible) { + this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) { + // handle keyboard event with keyboard util + Keyboard.handleKey(e, 'Orbit', { + next: function next() { + _this.changeSlide(true); + }, + previous: function previous() { + _this.changeSlide(false); + }, + handled: function handled() { + // if bullet is focused, make sure focus moves + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is(_this.$bullets)) { + _this.$bullets.filter('.is-active').focus(); + } + } + }); + }); + } + } + } + /** + * 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) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide(); + }); // Show the first slide + + this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating + + this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present + + if (this.options.bullets) { + this._updateBullets(0); + } + } + } + /** + * Changes the current slide to a new one. + * @function + * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right. + * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected. + * @param {Number} idx - the index of the new slide in its collection, if one chosen. + * @fires Orbit#slidechange + */ + + }, { + key: "changeSlide", + value: function changeSlide(isLTR, chosenSlide, idx) { + if (!this.$slides) { + return; + } // Don't freak out if we're in the middle of cleanup + + + var $curSlide = this.$slides.filter('.is-active').eq(0); + + if (/mui/g.test($curSlide[0].className)) { + return false; + } //if the slide is currently animating, kick out of the function + + + var $firstSlide = this.$slides.first(), + $lastSlide = this.$slides.last(), + dirIn = isLTR ? 'Right' : 'Left', + dirOut = isLTR ? 'Left' : 'Right', + _this = this, + $newSlide; + + if (!chosenSlide) { + //most of the time, this will be auto played or clicked from the navButtons. + $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!! + this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) : //pick next slide if moving left to right + this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left + } else { + $newSlide = chosenSlide; + } + + if ($newSlide.length) { + /** + * Triggers before the next slide starts animating in and only if a next slide has been found. + * @event Orbit#beforeslidechange + */ + this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]); + + if (this.options.bullets) { + idx = idx || this.$slides.index($newSlide); //grab index to update bullets + + this._updateBullets(idx); + } + + if (this.options.useMUI && !this.$element.is(':hidden')) { + Motion.animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () { + $newSlide.css({ + 'display': 'block' + }).attr('aria-live', 'polite'); + }); + Motion.animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () { + $curSlide.removeAttr('aria-live'); + + if (_this.options.autoPlay && !_this.timer.isPaused) { + _this.timer.restart(); + } //do stuff? + + }); + } else { + $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide(); + $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show(); + + if (this.options.autoPlay && !this.timer.isPaused) { + this.timer.restart(); + } + } + /** + * Triggers when the slide has finished animating in. + * @event Orbit#slidechange + */ + + + this.$element.trigger('slidechange.zf.orbit', [$newSlide]); + } + } + /** + * Updates the active state of the bullets, if displayed. + * Move the descriptor of the current slide `[data-slide-active-label]` to the newly active bullet. + * If no `[data-slide-active-label]` is set, will move the exceeding `span` element. + * + * @function + * @private + * @param {Number} idx - the index of the current slide. + */ + + }, { + key: "_updateBullets", + value: function _updateBullets(idx) { + var $oldBullet = this.$bullets.filter('.is-active'); + var $othersBullets = this.$bullets.not('.is-active'); + var $newBullet = this.$bullets.eq(idx); + $oldBullet.removeClass('is-active').blur(); + $newBullet.addClass('is-active'); // Find the descriptor for the current slide to move it to the new slide button + + var activeStateDescriptor = $oldBullet.children('[data-slide-active-label]').last(); // If not explicitely given, search for the last "exceeding" span element (compared to others bullets). + + if (!activeStateDescriptor.length) { + var spans = $oldBullet.children('span'); + var spanCountInOthersBullets = $othersBullets.toArray().map(function (b) { + return jquery__WEBPACK_IMPORTED_MODULE_0___default()(b).children('span').length; + }); // If there is an exceeding span element, use it as current slide descriptor + + if (spanCountInOthersBullets.every(function (count) { + return count < spans.length; + })) { + activeStateDescriptor = spans.last(); + activeStateDescriptor.attr('data-slide-active-label', ''); + } + } // Move the current slide descriptor to the new slide button + + + if (activeStateDescriptor.length) { + activeStateDescriptor.detach(); + $newBullet.append(activeStateDescriptor); + } + } + /** + * Destroys the carousel and hides the element. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide(); + } + }]); + + return Orbit; +}(Plugin); + +Orbit.defaults = { + /** + * Tells the JS to look for and loadBullets. + * @option + * @type {boolean} + * @default true + */ + bullets: true, + + /** + * Tells the JS to apply event listeners to nav buttons + * @option + * @type {boolean} + * @default true + */ + navButtons: true, + + /** + * motion-ui animation class to apply + * @option + * @type {string} + * @default 'slide-in-right' + */ + animInFromRight: 'slide-in-right', + + /** + * motion-ui animation class to apply + * @option + * @type {string} + * @default 'slide-out-right' + */ + animOutToRight: 'slide-out-right', + + /** + * motion-ui animation class to apply + * @option + * @type {string} + * @default 'slide-in-left' + * + */ + animInFromLeft: 'slide-in-left', + + /** + * motion-ui animation class to apply + * @option + * @type {string} + * @default 'slide-out-left' + */ + animOutToLeft: 'slide-out-left', + + /** + * Allows Orbit to automatically animate on page load. + * @option + * @type {boolean} + * @default true + */ + autoPlay: true, + + /** + * Amount of time, in ms, between slide transitions + * @option + * @type {number} + * @default 5000 + */ + timerDelay: 5000, + + /** + * Allows Orbit to infinitely loop through the slides + * @option + * @type {boolean} + * @default true + */ + infiniteWrap: true, + + /** + * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library + * @option + * @type {boolean} + * @default true + */ + swipe: true, + + /** + * Allows the timing function to pause animation on hover. + * @option + * @type {boolean} + * @default true + */ + pauseOnHover: true, + + /** + * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys + * @option + * @type {boolean} + * @default true + */ + accessible: true, + + /** + * Class applied to the container of Orbit + * @option + * @type {string} + * @default 'orbit-container' + */ + containerClass: 'orbit-container', + + /** + * Class applied to individual slides. + * @option + * @type {string} + * @default 'orbit-slide' + */ + slideClass: 'orbit-slide', + + /** + * Class applied to the bullet container. You're welcome. + * @option + * @type {string} + * @default 'orbit-bullets' + */ + boxOfBullets: 'orbit-bullets', + + /** + * Class applied to the `next` navigation button. + * @option + * @type {string} + * @default 'orbit-next' + */ + nextClass: 'orbit-next', + + /** + * Class applied to the `previous` navigation button. + * @option + * @type {string} + * @default 'orbit-previous' + */ + prevClass: 'orbit-previous', + + /** + * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility. + * @option + * @type {boolean} + * @default true + */ + useMUI: true +}; +var MenuPlugins = { + dropdown: { + cssClass: 'dropdown', + plugin: DropdownMenu + }, + drilldown: { + cssClass: 'drilldown', + plugin: Drilldown + }, + accordion: { + cssClass: 'accordion-menu', + plugin: AccordionMenu + } +}; // import "foundation.util.triggers.js"; + +/** + * ResponsiveMenu module. + * @module foundation.responsiveMenu + * @requires foundation.util.triggers + * @requires foundation.util.mediaQuery + */ + +var ResponsiveMenu = /*#__PURE__*/function (_Plugin) { + _inherits(ResponsiveMenu, _Plugin); + + function ResponsiveMenu() { + _classCallCheck(this, ResponsiveMenu); + + return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments)); + } + + _createClass(ResponsiveMenu, [{ + key: "_setup", + + /** + * Creates a new instance of a responsive menu. + * @class + * @name ResponsiveMenu + * @fires ResponsiveMenu#init + * @param {jQuery} element - jQuery object to make into a dropdown menu. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element); + this.rules = this.$element.data('responsive-menu'); + this.currentMq = null; + this.currentPlugin = null; + this.className = 'ResponsiveMenu'; // ie9 back compat + + this._init(); + + this._events(); + } + /** + * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules + + + if (typeof this.rules === 'string') { + var rulesTree = {}; // Parse rules from "classes" pulled from data attribute + + var rules = this.rules.split(' '); // Iterate through every rule found + + for (var i = 0; i < rules.length; i++) { + var rule = rules[i].split('-'); + var ruleSize = rule.length > 1 ? rule[0] : 'small'; + var rulePlugin = rule.length > 1 ? rule[1] : rule[0]; + + if (MenuPlugins[rulePlugin] !== null) { + rulesTree[ruleSize] = MenuPlugins[rulePlugin]; + } + } + + this.rules = rulesTree; + } + + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) { + this._checkMediaQueries(); + } // Add data-mutate since children may need it. + + + this.$element.attr('data-mutate', this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')); + } + /** + * Initializes events for the Menu. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; + + jquery__WEBPACK_IMPORTED_MODULE_0___default()(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 + + + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) { + if (MediaQuery.atLeast(key)) { + matchedMq = key; + } + }); // No match? No dice + + if (!matchedMq) return; // Plugin already initialized? We good + + if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes + + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) { + _this.$element.removeClass(value.cssClass); + }); // Add the CSS class for the new plugin + + this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin + + if (this.currentPlugin) this.currentPlugin.destroy(); + this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {}); + } + /** + * 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(); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('.zf.ResponsiveMenu'); + } + }]); + + return ResponsiveMenu; +}(Plugin); + +ResponsiveMenu.defaults = {}; +/** + * ResponsiveToggle module. + * @module foundation.responsiveToggle + * @requires foundation.util.mediaQuery + * @requires foundation.util.motion + */ + +var ResponsiveToggle = /*#__PURE__*/function (_Plugin) { + _inherits(ResponsiveToggle, _Plugin); + + function ResponsiveToggle() { + _classCallCheck(this, ResponsiveToggle); + + return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments)); + } + + _createClass(ResponsiveToggle, [{ + key: "_setup", + + /** + * Creates a new instance of Tab Bar. + * @class + * @name ResponsiveToggle + * @fires ResponsiveToggle#init + * @param {jQuery} element - jQuery object to attach tab bar functionality to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element); + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options); + this.className = 'ResponsiveToggle'; // ie9 back compat + + this._init(); + + this._events(); + } + /** + * Initializes the tab bar by finding the target element, toggling element, and running update(). + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); + + var targetID = this.$element.data('responsive-toggle'); + + if (!targetID) { + console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.'); + } + + this.$targetMenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetID)); + this.$toggler = this.$element.find('[data-toggle]').filter(function () { + var target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle'); + return target === targetID || target === ""; + }); + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes + + if (this.options.animate) { + var input = this.options.animate.split(' '); + this.animationIn = input[0]; + this.animationOut = input[1] || null; + } + + this._update(); + } + /** + * Adds necessary event handlers for the tab bar to work. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._updateMqHandler = this._update.bind(this); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._updateMqHandler); + this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this)); + } + /** + * Checks the current media query to determine if the tab bar should be visible or hidden. + * @function + * @private + */ + + }, { + key: "_update", + value: function _update() { + // Mobile + if (!MediaQuery.atLeast(this.options.hideFor)) { + this.$element.show(); + this.$targetMenu.hide(); + } // Desktop + else { + this.$element.hide(); + this.$targetMenu.show(); + } + } + /** + * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it. + * @function + * @fires ResponsiveToggle#toggled + */ + + }, { + key: "toggleMenu", + value: function toggleMenu() { + var _this2 = this; + + if (!MediaQuery.atLeast(this.options.hideFor)) { + /** + * Fires when the element attached to the tab bar toggles. + * @event ResponsiveToggle#toggled + */ + if (this.options.animate) { + if (this.$targetMenu.is(':hidden')) { + Motion.animateIn(this.$targetMenu, this.animationIn, function () { + _this2.$element.trigger('toggled.zf.responsiveToggle'); + + _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger'); + }); + } else { + Motion.animateOut(this.$targetMenu, this.animationOut, function () { + _this2.$element.trigger('toggled.zf.responsiveToggle'); + }); + } + } else { + this.$targetMenu.toggle(0); + this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger'); + this.$element.trigger('toggled.zf.responsiveToggle'); + } + } + } + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('.zf.responsiveToggle'); + this.$toggler.off('.zf.responsiveToggle'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._updateMqHandler); + } + }]); + + return ResponsiveToggle; +}(Plugin); + +ResponsiveToggle.defaults = { + /** + * The breakpoint after which the menu is always shown, and the tab bar is hidden. + * @option + * @type {string} + * @default 'medium' + */ + hideFor: 'medium', + + /** + * To decide if the toggle should be animated or not. + * @option + * @type {boolean} + * @default false + */ + animate: false +}; +/** + * Reveal module. + * @module foundation.reveal + * @requires foundation.util.keyboard + * @requires foundation.util.touch + * @requires foundation.util.triggers + * @requires foundation.util.mediaQuery + * @requires foundation.util.motion if using animations + */ + +var Reveal = /*#__PURE__*/function (_Plugin) { + _inherits(Reveal, _Plugin); + + function Reveal() { + _classCallCheck(this, Reveal); + + return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments)); + } + + _createClass(Reveal, [{ + key: "_setup", + + /** + * Creates a new instance of Reveal. + * @class + * @name Reveal + * @param {jQuery} element - jQuery object to use for the modal. + * @param {Object} options - optional parameters. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Reveal.defaults, this.$element.data(), options); + this.className = 'Reveal'; // ie9 back compat + + this._init(); // Touch and Triggers init are idempotent, just need to make sure they are initialized + + + Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + Keyboard.register('Reveal', { + 'ESCAPE': 'close' + }); + } + /** + * Initializes the modal by adding the overlay and close buttons, (if selected). + * @private + */ + + }, { + key: "_init", + value: function _init() { + var _this2 = this; + + MediaQuery._init(); + + this.id = this.$element.attr('id'); + this.isActive = false; + this.cached = { + mq: MediaQuery.current + }; + this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat(this.id, "\"]")); + this.$anchor.attr({ + 'aria-controls': this.id, + 'aria-haspopup': true, + 'tabindex': 0 + }); + + if (this.options.fullScreen || this.$element.hasClass('full')) { + this.options.fullScreen = true; + this.options.overlay = false; + } + + if (this.options.overlay && !this.$overlay) { + this.$overlay = this._makeOverlay(this.id); + } + + this.$element.attr({ + 'role': 'dialog', + 'aria-hidden': true, + 'data-yeti-box': this.id, + 'data-resize': this.id + }); + + if (this.$overlay) { + this.$element.detach().appendTo(this.$overlay); + } else { + this.$element.detach().appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); + this.$element.addClass('without-overlay'); + } + + this._events(); + + if (this.options.deepLink && window.location.hash === "#".concat(this.id)) { + this.onLoadListener = onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + return _this2.open(); + }); + } + } + /** + * Creates an overlay div to display behind the modal. + * @private + */ + + }, { + key: "_makeOverlay", + value: function _makeOverlay() { + var additionalOverlayClasses = ''; + + if (this.options.additionalOverlayClasses) { + additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses; + } + + return jquery__WEBPACK_IMPORTED_MODULE_0___default()('').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo); + } + /** + * Updates position of modal + * TODO: Figure out if we actually need to cache these values or if it doesn't matter + * @private + */ + + }, { + key: "_updatePosition", + value: function _updatePosition() { + var width = this.$element.outerWidth(); + var outerWidth = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).width(); + var height = this.$element.outerHeight(); + var outerHeight = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height(); + var left, + top = null; + + if (this.options.hOffset === 'auto') { + left = parseInt((outerWidth - width) / 2, 10); + } else { + left = parseInt(this.options.hOffset, 10); + } + + if (this.options.vOffset === 'auto') { + if (height > outerHeight) { + top = parseInt(Math.min(100, outerHeight / 10), 10); + } else { + top = parseInt((outerHeight - height) / 4, 10); + } + } else if (this.options.vOffset !== null) { + top = parseInt(this.options.vOffset, 10); + } + + if (top !== null) { + this.$element.css({ + top: top + 'px' + }); + } // only worry about left if we don't have an overlay or we have a horizontal offset, + // otherwise we're perfectly in the middle + + + if (!this.$overlay || this.options.hOffset !== 'auto') { + this.$element.css({ + left: left + 'px' + }); + this.$element.css({ + margin: '0px' + }); + } + } + /** + * Adds event handlers for the modal. + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this3 = this; + + var _this = this; + + this.$element.on({ + 'open.zf.trigger': this.open.bind(this), + 'close.zf.trigger': function closeZfTrigger(event, $element) { + if (event.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default()(event.target).parents('[data-closable]')[0] === $element) { + // only close reveal when it's explicitly called + return _this3.close.apply(_this3); + } + }, + 'toggle.zf.trigger': this.toggle.bind(this), + 'resizeme.zf.trigger': function resizemeZfTrigger() { + _this._updatePosition(); + } + }); + + if (this.options.closeOnClick && this.options.overlay) { + this.$overlay.off('.zf.reveal').on('click.zf.dropdown tap.zf.dropdown', function (e) { + if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) { + return; + } + + _this.close(); + }); + } + + if (this.options.deepLink) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this)); + } + } + /** + * Handles modal methods on back/forward button clicks or any other event that triggers hashchange. + * @private + */ + + }, { + key: "_handleState", + value: function _handleState(e) { + if (window.location.hash === '#' + this.id && !this.isActive) { + this.open(); + } else { + this.close(); + } + } + /** + * Disables the scroll when Reveal is shown to prevent the background from shifting + * @param {number} scrollTop - Scroll to visually apply, window current scroll by default + */ + + }, { + key: "_disableScroll", + value: function _disableScroll(scrollTop) { + scrollTop = scrollTop || jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", -scrollTop); + } + } + /** + * Reenables the scroll when Reveal closes + * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`) + */ + + }, { + key: "_enableScroll", + value: function _enableScroll(scrollTop) { + scrollTop = scrollTop || parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top")); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", ""); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(-scrollTop); + } + } + /** + * Opens the modal controlled by `this.$anchor`, and closes all others by default. + * @function + * @fires Reveal#closeme + * @fires Reveal#open + */ + + }, { + key: "open", + value: function open() { + var _this4 = this; // either update or replace browser history + + + var hash = "#".concat(this.id); + + if (this.options.deepLink && window.location.hash !== hash) { + if (window.history.pushState) { + if (this.options.updateHistory) { + window.history.pushState({}, '', hash); + } else { + window.history.replaceState({}, '', hash); + } + } else { + window.location.hash = hash; + } + } // Remember anchor that opened it to set focus back later, have general anchors as fallback + + + this.$activeAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement).is(this.$anchor) ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement) : this.$anchor; + this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning + + this.$element.css({ + 'visibility': 'hidden' + }).show().scrollTop(0); + + if (this.options.overlay) { + this.$overlay.css({ + 'visibility': 'hidden' + }).show(); + } + + this._updatePosition(); + + this.$element.hide().css({ + 'visibility': '' + }); + + if (this.$overlay) { + this.$overlay.css({ + 'visibility': '' + }).hide(); + + if (this.$element.hasClass('fast')) { + this.$overlay.addClass('fast'); + } else if (this.$element.hasClass('slow')) { + this.$overlay.addClass('slow'); + } + } + + if (!this.options.multipleOpened) { + /** + * Fires immediately before the modal opens. + * Closes any other modals that are currently open + * @event Reveal#closeme + */ + this.$element.trigger('closeme.zf.reveal', this.id); + } + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) { + this._disableScroll(); + } + + var _this = this; // Motion UI method of reveal + + + if (this.options.animationIn) { + var afterAnimation = function afterAnimation() { + _this.$element.attr({ + 'aria-hidden': false, + 'tabindex': -1 + }).focus(); + + _this._addGlobalClasses(); + + Keyboard.trapFocus(_this.$element); + }; + + if (this.options.overlay) { + Motion.animateIn(this.$overlay, 'fade-in'); + } + + Motion.animateIn(this.$element, this.options.animationIn, function () { + if (_this4.$element) { + // protect against object having been removed + _this4.focusableElements = Keyboard.findFocusable(_this4.$element); + afterAnimation(); + } + }); + } // jQuery method of reveal + else { + if (this.options.overlay) { + this.$overlay.show(0); + } + + this.$element.show(this.options.showDelay); + } // handle accessibility + + + this.$element.attr({ + 'aria-hidden': false, + 'tabindex': -1 + }).focus(); + Keyboard.trapFocus(this.$element); + + this._addGlobalClasses(); + + this._addGlobalListeners(); + /** + * Fires when the modal has successfully opened. + * @event Reveal#open + */ + + + this.$element.trigger('open.zf.reveal'); + } + /** + * Adds classes and listeners on document required by open modals. + * + * The following classes are added and updated: + * - `.is-reveal-open` - Prevents the scroll on document + * - `.zf-has-scroll` - Displays a disabled scrollbar on document if required like if the + * scroll was not disabled. This prevent a "shift" of the page content due + * the scrollbar disappearing when the modal opens. + * + * @private + */ + + }, { + key: "_addGlobalClasses", + value: function _addGlobalClasses() { + var updateScrollbarClass = function updateScrollbarClass() { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').toggleClass('zf-has-scroll', !!(jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height())); + }; + + this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () { + return updateScrollbarClass(); + }); + updateScrollbarClass(); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').addClass('is-reveal-open'); + } + /** + * Removes classes and listeners on document that were required by open modals. + * @private + */ + + }, { + key: "_removeGlobalClasses", + value: function _removeGlobalClasses() { + this.$element.off('resizeme.zf.trigger.revealScrollbarListener'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('is-reveal-open'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('zf-has-scroll'); + } + /** + * Adds extra event handlers for the body and window if necessary. + * @private + */ + + }, { + key: "_addGlobalListeners", + value: function _addGlobalListeners() { + var _this = this; + + if (!this.$element) { + return; + } // If we're in the middle of cleanup, don't freak out + + + this.focusableElements = Keyboard.findFocusable(this.$element); + + if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('click.zf.dropdown tap.zf.dropdown', function (e) { + if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) { + return; + } + + _this.close(); + }); + } + + if (this.options.closeOnEsc) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('keydown.zf.reveal', function (e) { + Keyboard.handleKey(e, 'Reveal', { + close: function close() { + if (_this.options.closeOnEsc) { + _this.close(); + } + } + }); + }); + } + } + /** + * Closes the modal. + * @function + * @fires Reveal#closed + */ + + }, { + key: "close", + value: function close() { + if (!this.isActive || !this.$element.is(':visible')) { + return false; + } + + var _this = this; // Motion UI method of hiding + + + if (this.options.animationOut) { + if (this.options.overlay) { + Motion.animateOut(this.$overlay, 'fade-out'); + } + + Motion.animateOut(this.$element, this.options.animationOut, finishUp); + } // jQuery method of hiding + else { + this.$element.hide(this.options.hideDelay); + + if (this.options.overlay) { + this.$overlay.hide(0, finishUp); + } else { + finishUp(); + } + } // Conditionals to remove extra event listeners added on open + + + if (this.options.closeOnEsc) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('keydown.zf.reveal'); + } + + if (!this.options.overlay && this.options.closeOnClick) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').off('click.zf.dropdown tap.zf.dropdown'); + } + + this.$element.off('keydown.zf.reveal'); + + function finishUp() { + // Get the current top before the modal is closed and restore the scroll after. + // TODO: use component properties instead of HTML properties + // See https://github.com/foundation/foundation-sites/pull/10786 + var scrollTop = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top")); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) { + _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal + + } + + Keyboard.releaseFocus(_this.$element); + + _this.$element.attr('aria-hidden', true); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) { + _this._enableScroll(scrollTop); + } + /** + * Fires when the modal is done closing. + * @event Reveal#closed + */ + + + _this.$element.trigger('closed.zf.reveal'); + } + /** + * Resets the modal content + * This prevents a running video to keep going in the background + */ + + + if (this.options.resetOnClose) { + this.$element.html(this.$element.html()); + } + + this.isActive = false; // If deepLink and we did not switched to an other modal... + + if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) { + // Remove the history hash + if (window.history.replaceState) { + var urlWithoutHash = window.location.pathname + window.location.search; + + if (this.options.updateHistory) { + window.history.pushState({}, '', urlWithoutHash); // remove the hash + } else { + window.history.replaceState('', document.title, urlWithoutHash); + } + } else { + window.location.hash = ''; + } + } + + this.$activeAnchor.focus(); + } + /** + * Toggles the open/closed state of a modal. + * @function + */ + + }, { + key: "toggle", + value: function toggle() { + if (this.isActive) { + this.close(); + } else { + this.open(); + } + } + }, { + key: "_destroy", + + /** + * Destroys an instance of a modal. + * @function + */ + value: function _destroy() { + if (this.options.overlay) { + this.$element.appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin() + + this.$overlay.hide().off().remove(); + } + + this.$element.hide().off(); + this.$anchor.off('.zf'); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(".zf.reveal:".concat(this.id)); + if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener); + + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) { + this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal + + } + } + }]); + + return Reveal; +}(Plugin); + +Reveal.defaults = { + /** + * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide. + * @option + * @type {string} + * @default '' + */ + animationIn: '', + + /** + * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide. + * @option + * @type {string} + * @default '' + */ + animationOut: '', + + /** + * Time, in ms, to delay the opening of a modal after a click if no animation used. + * @option + * @type {number} + * @default 0 + */ + showDelay: 0, + + /** + * Time, in ms, to delay the closing of a modal after a click if no animation used. + * @option + * @type {number} + * @default 0 + */ + hideDelay: 0, + + /** + * Allows a click on the body/overlay to close the modal. + * @option + * @type {boolean} + * @default true + */ + closeOnClick: true, + + /** + * Allows the modal to close if the user presses the `ESCAPE` key. + * @option + * @type {boolean} + * @default true + */ + closeOnEsc: true, + + /** + * If true, allows multiple modals to be displayed at once. + * @option + * @type {boolean} + * @default false + */ + multipleOpened: false, + + /** + * Distance, in pixels, the modal should push down from the top of the screen. + * @option + * @type {number|string} + * @default auto + */ + vOffset: 'auto', + + /** + * Distance, in pixels, the modal should push in from the side of the screen. + * @option + * @type {number|string} + * @default auto + */ + hOffset: 'auto', + + /** + * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well. + * @option + * @type {boolean} + * @default false + */ + fullScreen: false, + + /** + * Allows the modal to generate an overlay div, which will cover the view when modal opens. + * @option + * @type {boolean} + * @default true + */ + overlay: true, + + /** + * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background. + * @option + * @type {boolean} + * @default false + */ + resetOnClose: false, + + /** + * Link the location hash to the modal. + * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes. + * @option + * @type {boolean} + * @default false + */ + deepLink: false, + + /** + * If `deepLink` is enabled, update the browser history with the open modal + * @option + * @default false + */ + updateHistory: false, + + /** + * Allows the modal to append to custom div. + * @option + * @type {string} + * @default "body" + */ + appendTo: "body", + + /** + * Allows adding additional class names to the reveal overlay. + * @option + * @type {string} + * @default '' + */ + additionalOverlayClasses: '' +}; +/** + * Slider module. + * @module foundation.slider + * @requires foundation.util.motion + * @requires foundation.util.triggers + * @requires foundation.util.keyboard + * @requires foundation.util.touch + */ + +var Slider = /*#__PURE__*/function (_Plugin) { + _inherits(Slider, _Plugin); + + function Slider() { + _classCallCheck(this, Slider); + + return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments)); + } + + _createClass(Slider, [{ + key: "_setup", + + /** + * Creates a new instance of a slider control. + * @class + * @name Slider + * @param {jQuery} element - jQuery object to make into a slider control. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Slider.defaults, this.$element.data(), options); + this.className = 'Slider'; // ie9 back compat + // Touch and Triggers inits are idempotent, we just need to make sure it's initialied. + + Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + + Keyboard.register('Slider', { + 'ltr': { + 'ARROW_RIGHT': 'increase', + 'ARROW_UP': 'increase', + 'ARROW_DOWN': 'decrease', + 'ARROW_LEFT': 'decrease', + 'SHIFT_ARROW_RIGHT': 'increase_fast', + 'SHIFT_ARROW_UP': 'increase_fast', + 'SHIFT_ARROW_DOWN': 'decrease_fast', + 'SHIFT_ARROW_LEFT': 'decrease_fast', + 'HOME': 'min', + 'END': 'max' + }, + 'rtl': { + 'ARROW_LEFT': 'increase', + 'ARROW_RIGHT': 'decrease', + 'SHIFT_ARROW_LEFT': 'increase_fast', + 'SHIFT_ARROW_RIGHT': 'decrease_fast' + } + }); + } + /** + * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s). + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + this.inputs = this.$element.find('input'); + this.handles = this.$element.find('[data-slider-handle]'); + this.$handle = this.handles.eq(0); + this.$input = this.inputs.length ? this.inputs.eq(0) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle.attr('aria-controls'))); + this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0); + + 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 = jquery__WEBPACK_IMPORTED_MODULE_0___default()().add(this.$input); + this.options.binding = true; + } + + this._setInitAttr(0); + + if (this.handles[1]) { + this.options.doubleSided = true; + this.$handle2 = this.handles.eq(1); + this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle2.attr('aria-controls'))); + + if (!this.inputs[1]) { + this.inputs = this.inputs.add(this.$input2); + } // this.$handle.triggerHandler('click.zf.slider'); + + + this._setInitAttr(1); + } // Set handle positions + + + this.setHandles(); + + this._events(); + } + }, { + key: "setHandles", + value: function setHandles() { + var _this2 = this; + + if (this.handles[1]) { + this._setHandlePos(this.$handle, this.inputs.eq(0).val(), function () { + _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val()); + }); + } else { + this._setHandlePos(this.$handle, this.inputs.eq(0).val()); + } + } + }, { + 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; + + if (this.options.vertical) { + // linear interpolation which is working with negative values for start + // https://math.stackexchange.com/a/1019084 + value = parseFloat(this.options.end) + pctOfBar * (this.options.start - this.options.end); + } else { + value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start); + } + + return value; + } + /** + * @function + * @private + * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function + */ + + }, { + key: "_logTransform", + value: function _logTransform(value) { + return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1); + } + /** + * @function + * @private + * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function + */ + + }, { + key: "_powTransform", + value: function _powTransform(value) { + return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1); + } + /** + * Sets the position of the selected handle and fill bar. + * @function + * @private + * @param {jQuery} $hndl - the selected handle to move. + * @param {Number} location - floating point between the start and end values of the slider bar. + * @param {Function} cb - callback function to fire on completion. + * @fires Slider#moved + * @fires Slider#changed + */ + + }, { + key: "_setHandlePos", + value: function _setHandlePos($hndl, location, 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; + } + } + + var _this = this, + vert = this.options.vertical, + hOrW = vert ? 'height' : 'width', + lOrT = vert ? 'top' : 'left', + handleDim = $hndl[0].getBoundingClientRect()[hOrW], + elemDim = this.$element[0].getBoundingClientRect()[hOrW], + //percentage of bar min/max value based on click or drag point + pctOfBar = this._pctOfBar(location), + //number of actual pixels to shift the handle, based on the percentage obtained above + pxToMove = (elemDim - handleDim) * pctOfBar, + //percentage of bar to shift the handle + movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value + + + location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders + + var css = {}; + + this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs?? + + + if (isDbl) { + var isLeftHndl = this.handles.index($hndl) === 0, + //empty variable, will be used for min-height/width for fill bar + dim, + //percentage w/h of the handle compared to the slider bar + handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar + + if (isLeftHndl) { + //left or top percentage value to apply to the fill bar. + css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar. + + dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider + //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future. + + if (cb && typeof cb === 'function') { + cb(); + } //this is only needed for the initialization of 2 handled sliders + + } else { + //just caching the value of the left/bottom handle's left/top property + var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0 + //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself + + dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct; + } // assign the min-height/width to our css object + + + css["min-".concat(hOrW)] = "".concat(dim, "%"); + } + + this.$element.one('finished.zf.animate', function () { + /** + * Fires when the handle is done moving. + * @event Slider#moved + */ + _this.$element.trigger('moved.zf.slider', [$hndl]); + }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move. + + var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime; + Move(moveTime, $hndl, function () { + // adjusting the left/top property of the handle, based on the percentage calculated above + // if movement isNaN, that is because the slider is hidden and we cannot determine handle width, + // fall back to next best guess. + if (isNaN(movement)) { + $hndl.css(lOrT, "".concat(pctOfBar * 100, "%")); + } else { + $hndl.css(lOrT, "".concat(movement, "%")); + } + + if (!_this.options.doubleSided) { + //if single-handled, a simple method to expand the fill bar + _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%")); + } else { + //otherwise, use the css object we created above + _this.$fill.css(css); + } + }); + /** + * Fires when the value has not been change for a given time. + * @event Slider#changed + */ + + clearTimeout(_this.timeout); + _this.timeout = setTimeout(function () { + _this.$element.trigger('changed.zf.slider', [$hndl]); + }, _this.options.changedDelay); + } + /** + * Sets the initial attribute for the slider element. + * @function + * @private + * @param {Number} idx - index of the current handle/input to use. + */ + + }, { + key: "_setInitAttr", + value: function _setInitAttr(idx) { + var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd; + var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider'); + this.inputs.eq(idx).attr({ + 'id': id, + 'max': this.options.end, + 'min': this.options.start, + 'step': this.options.step + }); + this.inputs.eq(idx).val(initVal); + this.handles.eq(idx).attr({ + 'role': 'slider', + 'aria-controls': id, + 'aria-valuemax': this.options.end, + 'aria-valuemin': this.options.start, + 'aria-valuenow': initVal, + 'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal', + 'tabindex': 0 + }); + } + /** + * Sets the input and `aria-valuenow` values for the slider element. + * @function + * @private + * @param {jQuery} $handle - the currently selected handle. + * @param {Number} val - floating point of the new value. + */ + + }, { + key: "_setValues", + value: function _setValues($handle, val) { + var idx = this.options.doubleSided ? this.handles.index($handle) : 0; + this.inputs.eq(idx).val(val); + $handle.attr('aria-valuenow', val); + } + /** + * Handles events on the slider element. + * Calculates the new location of the current handle. + * If there are two handles and the bar was clicked, it determines which handle to move. + * @function + * @private + * @param {Object} e - the `event` object passed from the listener. + * @param {jQuery} $handle - the current handle to calculate for, if selected. + * @param {Number} val - floating point number for the new value of the slider. + * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn. + */ + + }, { + key: "_handleEvent", + value: function _handleEvent(e, $handle, val) { + var value; + + 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, + barDim = this.$element[0].getBoundingClientRect()[param], + windowScroll = vertical ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop() : jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollLeft(); + + var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates... + // best way to guess this is simulated is if clientY == pageY + + if (e.clientY === e.pageY) { + eventOffset = eventOffset + windowScroll; + } + + var eventFromBar = eventOffset - elemOffset; + var barXY; + + if (eventFromBar < 0) { + barXY = 0; + } else if (eventFromBar > barDim) { + barXY = barDim; + } else { + barXY = eventFromBar; + } + + var offsetPct = percent(barXY, barDim); + value = this._value(offsetPct); // turn everything around for RTL, yay math! + + if (rtl() && !this.options.vertical) { + value = this.options.end - value; + } + + value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders + + 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); + } + + this._setHandlePos($handle, value); + } + /** + * Adjustes value for handle in regard to step value. returns adjusted value + * @function + * @private + * @param {jQuery} $handle - the selected handle. + * @param {Number} value - value to adjust. used if $handle is falsy + */ + + }, { + key: "_adjustValue", + value: function _adjustValue($handle, value) { + var val, + step = this.options.step, + div = parseFloat(step / 2), + left, + prev_val, + next_val; + + if (!!$handle) { + val = parseFloat($handle.attr('aria-valuenow')); + } else { + val = value; + } + + if (val >= 0) { + left = val % step; + } else { + left = step + val % step; + } + + prev_val = val - left; + next_val = prev_val + step; + + if (left === 0) { + return val; + } + + val = val >= prev_val + div ? next_val : prev_val; + return val; + } + /** + * Adds event listeners to the slider elements. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._eventsForHandle(this.$handle); + + if (this.handles[1]) { + this._eventsForHandle(this.$handle2); + } + } + /** + * Adds event listeners a particular handle + * @function + * @private + * @param {jQuery} $handle - the current handle to apply listeners to. + */ + + }, { + key: "_eventsForHandle", + value: function _eventsForHandle($handle) { + var _this = this, + curHandle; + + var handleChangeEvent = function handleChangeEvent(e) { + var idx = _this.inputs.index(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)); + + _this._handleEvent(e, _this.handles.eq(idx), jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()); + }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification + // listen for the enter key and trigger a change + // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events + + + this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) { + if (e.keyCode == 13) handleChangeEvent.call(this, e); + }); + this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent); + + if (this.options.clickSelect) { + this.$element.off('click.zf.slider').on('click.zf.slider', function (e) { + if (_this.$element.data('dragging')) { + return false; + } + + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is('[data-slider-handle]')) { + if (_this.options.doubleSided) { + _this._handleEvent(e); + } else { + _this._handleEvent(e, _this.$handle); + } + } + }); + } + + if (this.options.draggable) { + this.handles.addTouch(); + var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body'); + $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) { + $handle.addClass('is-dragging'); + + _this.$fill.addClass('is-dragging'); // + + + _this.$element.data('dragging', true); + + curHandle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget); + $body.on('mousemove.zf.slider', function (e) { + e.preventDefault(); + + _this._handleEvent(e, curHandle); + }).on('mouseup.zf.slider', function (e) { + _this._handleEvent(e, curHandle); + + $handle.removeClass('is-dragging'); + + _this.$fill.removeClass('is-dragging'); + + _this.$element.data('dragging', false); + + $body.off('mousemove.zf.slider mouseup.zf.slider'); + }); + }) // prevent events triggered by touch + .on('selectstart.zf.slider touchmove.zf.slider', function (e) { + e.preventDefault(); + }); + } + + $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) { + var _$handle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0, + oldValue = parseFloat(_this.inputs.eq(idx).val()), + newValue; // handle keyboard event with keyboard util + + + Keyboard.handleKey(e, 'Slider', { + decrease: function decrease() { + newValue = oldValue - _this.options.step; + }, + increase: function increase() { + newValue = oldValue + _this.options.step; + }, + decrease_fast: function decrease_fast() { + newValue = oldValue - _this.options.step * 10; + }, + increase_fast: function increase_fast() { + newValue = oldValue + _this.options.step * 10; + }, + min: function min() { + newValue = _this.options.start; + }, + max: function max() { + newValue = _this.options.end; + }, + handled: function handled() { + // only set handle pos when event was handled specially + e.preventDefault(); + + _this._setHandlePos(_$handle, newValue); + } + }); + /*if (newValue) { // if pressed key has special function, update value + e.preventDefault(); + _this._setHandlePos(_$handle, newValue); + }*/ + }); + } + /** + * Destroys the slider plugin. + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.handles.off('.zf.slider'); + this.inputs.off('.zf.slider'); + this.$element.off('.zf.slider'); + clearTimeout(this.timeout); + } + }]); + + return Slider; +}(Plugin); + +Slider.defaults = { + /** + * Minimum value for the slider scale. + * @option + * @type {number} + * @default 0 + */ + start: 0, + + /** + * Maximum value for the slider scale. + * @option + * @type {number} + * @default 100 + */ + end: 100, + + /** + * Minimum value change per change event. + * @option + * @type {number} + * @default 1 + */ + step: 1, + + /** + * Value at which the handle/input *(left handle/first input)* should be set to on initialization. + * @option + * @type {number} + * @default 0 + */ + initialStart: 0, + + /** + * Value at which the right handle/second input should be set to on initialization. + * @option + * @type {number} + * @default 100 + */ + initialEnd: 100, + + /** + * Allows the input to be located outside the container and visible. Set to by the JS + * @option + * @type {boolean} + * @default false + */ + binding: false, + + /** + * Allows the user to click/tap on the slider bar to select a value. + * @option + * @type {boolean} + * @default true + */ + clickSelect: true, + + /** + * Set to true and use the `vertical` class to change alignment to vertical. + * @option + * @type {boolean} + * @default false + */ + vertical: false, + + /** + * Allows the user to drag the slider handle(s) to select a value. + * @option + * @type {boolean} + * @default true + */ + draggable: true, + + /** + * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`. + * @option + * @type {boolean} + * @default false + */ + disabled: false, + + /** + * Allows the use of two handles. Double checked by the JS. Changes some logic handling. + * @option + * @type {boolean} + * @default false + */ + doubleSided: false, + + /** + * Potential future feature. + */ + // steps: 100, + + /** + * Number of decimal places the plugin should go to for floating point precision. + * @option + * @type {number} + * @default 2 + */ + decimal: 2, + + /** + * Time delay for dragged elements. + */ + // dragDelay: 0, + + /** + * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings. + * @option + * @type {number} + * @default 200 + */ + moveTime: 200, + //update this if changing the transition time in the sass + + /** + * Class applied to disabled sliders. + * @option + * @type {string} + * @default 'disabled' + */ + disabledClass: 'disabled', + + /** + * Will invert the default layout for a vertical slider. + * @option + * @type {boolean} + * @default false + */ + invertVertical: false, + + /** + * Milliseconds before the `changed.zf-slider` event is triggered after value change. + * @option + * @type {number} + * @default 500 + */ + changedDelay: 500, + + /** + * Basevalue for non-linear sliders + * @option + * @type {number} + * @default 5 + */ + nonLinearBase: 5, + + /** + * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting. + * @option + * @type {string} + * @default 'linear' + */ + positionValueFunction: 'linear' +}; + +function percent(frac, num) { + return frac / num; +} + +function absPosition($handle, dir, clickPos, param) { + return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos); +} + +function baseLog(base, value) { + return Math.log(value) / Math.log(base); +} +/** + * Sticky module. + * @module foundation.sticky + * @requires foundation.util.triggers + * @requires foundation.util.mediaQuery + */ + + +var Sticky = /*#__PURE__*/function (_Plugin) { + _inherits(Sticky, _Plugin); + + function Sticky() { + _classCallCheck(this, Sticky); + + return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments)); + } + + _createClass(Sticky, [{ + key: "_setup", + + /** + * Creates a new instance of a sticky thing. + * @class + * @name Sticky + * @param {jQuery} element - jQuery object to make sticky. + * @param {Object} options - options object passed when creating the element programmatically. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Sticky.defaults, this.$element.data(), options); + this.className = 'Sticky'; // ie9 back compat + // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + } + /** + * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); + + var $parent = this.$element.parent('[data-sticky-container]'), + id = this.$element[0].id || GetYoDigits(6, 'sticky'), + _this = this; + + if ($parent.length) { + this.$container = $parent; + } else { + this.wasWrapped = true; + this.$element.wrap(this.options.container); + this.$container = this.$element.parent(); + } + + this.$container.addClass(this.options.containerClass); + this.$element.addClass(this.options.stickyClass).attr({ + 'data-resize': id, + 'data-mutate': id + }); + + if (this.options.anchor !== '') { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor).attr({ + 'data-mutate': id + }); + } + + this.scrollCount = this.options.checkEvery; + this.isStuck = false; + this.onLoadListener = onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + //We calculate the container height to have correct values for anchor points offset calculation. + _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height; + + _this.$container.css('height', _this.containerHeight); + + _this.elemHeight = _this.containerHeight; + + if (_this.options.anchor !== '') { + _this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor); + } else { + _this._parsePoints(); + } + + _this._setSizes(function () { + var scroll = window.pageYOffset; + + _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set. + + + if (!_this.isStuck) { + _this._removeSticky(scroll >= _this.topPoint ? false : true); + } + }); + + _this._events(id.split('-').reverse().join('-')); + }); + } + /** + * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on. + * @function + * @private + */ + + }, { + key: "_parsePoints", + value: function _parsePoints() { + var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor, + btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor, + pts = [top, btm], + breaks = {}; + + for (var i = 0, len = pts.length; i < len && pts[i]; i++) { + var pt; + + if (typeof pts[i] === 'number') { + pt = pts[i]; + } else { + var place = pts[i].split(':'), + anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(place[0])); + pt = anchor.offset().top; + + if (place[1] && place[1].toLowerCase() === 'bottom') { + pt += anchor[0].getBoundingClientRect().height; + } + } + + breaks[i] = pt; + } + + this.points = breaks; + return; + } + /** + * Adds event handlers for the scrolling element. + * @private + * @param {String} id - pseudo-random id for unique scroll event listener. + */ + + }, { + key: "_events", + value: function _events(id) { + var _this = this, + scrollListener = this.scrollListener = "scroll.zf.".concat(id); + + if (this.isOn) { + return; + } + + if (this.canStick) { + this.isOn = true; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener).on(scrollListener, function (e) { + if (_this.scrollCount === 0) { + _this.scrollCount = _this.options.checkEvery; + + _this._setSizes(function () { + _this._calc(false, window.pageYOffset); + }); + } else { + _this.scrollCount--; + + _this._calc(false, window.pageYOffset); + } + }); + } + + this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) { + _this._eventsHandler(id); + }); + this.$element.on('mutateme.zf.trigger', function (e, el) { + _this._eventsHandler(id); + }); + + if (this.$anchor) { + this.$anchor.on('mutateme.zf.trigger', function (e, el) { + _this._eventsHandler(id); + }); + } + } + /** + * Handler for events. + * @private + * @param {String} id - pseudo-random id for unique scroll event listener. + */ + + }, { + key: "_eventsHandler", + value: function _eventsHandler(id) { + var _this = this, + scrollListener = this.scrollListener = "scroll.zf.".concat(id); + + _this._setSizes(function () { + _this._calc(false); + + if (_this.canStick) { + if (!_this.isOn) { + _this._events(id); + } + } else if (_this.isOn) { + _this._pauseListeners(scrollListener); + } + }); + } + /** + * Removes event handlers for scroll and change events on anchor. + * @fires Sticky#pause + * @param {String} scrollListener - unique, namespaced scroll listener attached to `window` + */ + + }, { + key: "_pauseListeners", + value: function _pauseListeners(scrollListener) { + this.isOn = false; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener); + /** + * Fires when the plugin is paused due to resize event shrinking the view. + * @event Sticky#pause + * @private + */ + + this.$element.trigger('pause.zf.sticky'); + } + /** + * Called on every `scroll` event and on `_init` + * fires functions based on booleans and cached values + * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints. + * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`. + */ + + }, { + key: "_calc", + value: function _calc(checkSizes, scroll) { + if (checkSizes) { + this._setSizes(); + } + + if (!this.canStick) { + if (this.isStuck) { + this._removeSticky(true); + } + + return false; + } + + if (!scroll) { + scroll = window.pageYOffset; + } + + if (scroll >= this.topPoint) { + if (scroll <= this.bottomPoint) { + if (!this.isStuck) { + this._setSticky(); + } + } else { + if (this.isStuck) { + this._removeSticky(false); + } + } + } else { + if (this.isStuck) { + this._removeSticky(true); + } + } + } + /** + * Causes the $element to become stuck. + * Adds `position: fixed;`, and helper classes. + * @fires Sticky#stuckto + * @function + * @private + */ + + }, { + key: "_setSticky", + value: function _setSticky() { + var _this = this, + stickTo = this.options.stickTo, + mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom', + notStuckTo = stickTo === 'top' ? 'bottom' : 'top', + css = {}; + + css[mrgn] = "".concat(this.options[mrgn], "em"); + css[stickTo] = 0; + css[notStuckTo] = 'auto'; + this.isStuck = true; + this.$element.removeClass("is-anchored is-at-".concat(notStuckTo)).addClass("is-stuck is-at-".concat(stickTo)).css(css) + /** + * Fires when the $element has become `position: fixed;` + * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top` + * @event Sticky#stuckto + */ + .trigger("sticky.zf.stuckto:".concat(stickTo)); + this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () { + _this._setSizes(); + }); + } + /** + * Causes the $element to become unstuck. + * Removes `position: fixed;`, and helper classes. + * Adds other helper classes. + * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element. + * @fires Sticky#unstuckfrom + * @private + */ + + }, { + key: "_removeSticky", + value: function _removeSticky(isTop) { + var stickTo = this.options.stickTo, + stickToTop = stickTo === 'top', + css = {}, + anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight, + mrgn = stickToTop ? 'marginTop' : 'marginBottom', + topOrBottom = isTop ? 'top' : 'bottom'; + css[mrgn] = 0; + css['bottom'] = 'auto'; + + if (isTop) { + css['top'] = 0; + } else { + css['top'] = anchorPt; + } + + this.isStuck = false; + this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css) + /** + * Fires when the $element has become anchored. + * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom` + * @event Sticky#unstuckfrom + */ + .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom)); + } + /** + * Sets the $element and $container sizes for plugin. + * Calls `_setBreakPoints`. + * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`. + * @private + */ + + }, { + key: "_setSizes", + value: function _setSizes(cb) { + this.canStick = MediaQuery.is(this.options.stickyOn); + + if (!this.canStick) { + if (cb && typeof cb === 'function') { + cb(); + } + } + + var newElemWidth = this.$container[0].getBoundingClientRect().width, + comp = window.getComputedStyle(this.$container[0]), + pdngl = parseInt(comp['padding-left'], 10), + pdngr = parseInt(comp['padding-right'], 10); + + if (this.$anchor && this.$anchor.length) { + this.anchorHeight = this.$anchor[0].getBoundingClientRect().height; + } else { + this._parsePoints(); + } + + this.$element.css({ + 'max-width': "".concat(newElemWidth - pdngl - pdngr, "px") + }); // Recalculate the height only if it is "dynamic" + + if (this.options.dynamicHeight || !this.containerHeight) { + // Get the sticked element height and apply it to the container to "hold the place" + var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight; + newContainerHeight = this.$element.css("display") == "none" ? 0 : newContainerHeight; + this.$container.css('height', newContainerHeight); + this.containerHeight = newContainerHeight; + } + + this.elemHeight = this.containerHeight; + + if (!this.isStuck) { + if (this.$element.hasClass('is-at-bottom')) { + var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight; + this.$element.css('top', anchorPt); + } + } + + this._setBreakPoints(this.containerHeight, function () { + if (cb && typeof cb === 'function') { + cb(); + } + }); + } + /** + * Sets the upper and lower breakpoints for the element to become sticky/unsticky. + * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`. + * @param {Function} cb - optional callback function to be called on completion. + * @private + */ + + }, { + key: "_setBreakPoints", + value: function _setBreakPoints(elemHeight, cb) { + if (!this.canStick) { + if (cb && typeof cb === 'function') { + cb(); + } else { + return false; + } + } + + var mTop = emCalc(this.options.marginTop), + mBtm = emCalc(this.options.marginBottom), + topPoint = this.points ? this.points[0] : this.$anchor.offset().top, + bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight, + // topPoint = this.$anchor.offset().top || this.points[0], + // bottomPoint = topPoint + this.anchorHeight || this.points[1], + winHeight = window.innerHeight; + + if (this.options.stickTo === 'top') { + topPoint -= mTop; + bottomPoint -= elemHeight + mTop; + } else if (this.options.stickTo === 'bottom') { + topPoint -= winHeight - (elemHeight + mBtm); + bottomPoint -= winHeight - mBtm; + } + + this.topPoint = topPoint; + this.bottomPoint = bottomPoint; + + if (cb && typeof cb === 'function') { + cb(); + } + } + /** + * Destroys the current sticky element. + * Resets the element to the top position first. + * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this._removeSticky(true); + + this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({ + height: '', + top: '', + bottom: '', + 'max-width': '' + }).off('resizeme.zf.trigger').off('mutateme.zf.trigger'); + + if (this.$anchor && this.$anchor.length) { + this.$anchor.off('change.zf.sticky'); + } + + if (this.scrollListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.scrollListener); + if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener); + + if (this.wasWrapped) { + this.$element.unwrap(); + } else { + this.$container.removeClass(this.options.containerClass).css({ + height: '' + }); + } + } + }]); + + return Sticky; +}(Plugin); + +Sticky.defaults = { + /** + * Customizable container template. Add your own classes for styling and sizing. + * @option + * @type {string} + * @default '<div data-sticky-container></div>' + */ + container: '', + + /** + * Location in the view the element sticks to. Can be `'top'` or `'bottom'`. + * @option + * @type {string} + * @default 'top' + */ + stickTo: 'top', + + /** + * If anchored to a single element, the id of that element. + * @option + * @type {string} + * @default '' + */ + anchor: '', + + /** + * If using more than one element as anchor points, the id of the top anchor. + * @option + * @type {string} + * @default '' + */ + topAnchor: '', + + /** + * If using more than one element as anchor points, the id of the bottom anchor. + * @option + * @type {string} + * @default '' + */ + btmAnchor: '', + + /** + * Margin, in `em`'s to apply to the top of the element when it becomes sticky. + * @option + * @type {number} + * @default 1 + */ + marginTop: 1, + + /** + * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky. + * @option + * @type {number} + * @default 1 + */ + marginBottom: 1, + + /** + * Breakpoint string that is the minimum screen size an element should become sticky. + * @option + * @type {string} + * @default 'medium' + */ + stickyOn: 'medium', + + /** + * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`. + * @option + * @type {string} + * @default 'sticky' + */ + stickyClass: 'sticky', + + /** + * Class applied to sticky container. Foundation defaults to `sticky-container`. + * @option + * @type {string} + * @default 'sticky-container' + */ + containerClass: 'sticky-container', + + /** + * If true (by default), keep the sticky container the same height as the element. Otherwise, the container height is set once and does not change. + * @option + * @type {boolean} + * @default true + */ + dynamicHeight: true, + + /** + * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll. + * @option + * @type {number} + * @default -1 + */ + checkEvery: -1 +}; +/** + * Helper function to calculate em values + * @param Number {em} - number of em's to calculate into pixels + */ + +function emCalc(em) { + return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em; +} +/** + * Tabs module. + * @module foundation.tabs + * @requires foundation.util.keyboard + * @requires foundation.util.imageLoader if tabs contain images + */ + + +var Tabs = /*#__PURE__*/function (_Plugin) { + _inherits(Tabs, _Plugin); + + function Tabs() { + _classCallCheck(this, Tabs); + + return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments)); + } + + _createClass(Tabs, [{ + key: "_setup", + + /** + * Creates a new instance of tabs. + * @class + * @name Tabs + * @fires Tabs#init + * @param {jQuery} element - jQuery object to make into tabs. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tabs.defaults, this.$element.data(), options); + this.className = 'Tabs'; // ie9 back compat + + this._init(); + + Keyboard.register('Tabs', { + 'ENTER': 'open', + 'SPACE': 'open', + 'ARROW_RIGHT': 'next', + 'ARROW_UP': 'previous', + 'ARROW_DOWN': 'next', + 'ARROW_LEFT': 'previous' // 'TAB': 'next', + // 'SHIFT_TAB': 'previous' + + }); + } + /** + * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab. + * @private + */ + + }, { + key: "_init", + value: function _init() { + var _this2 = this; + + var _this = this; + + this._isInitializing = true; + this.$element.attr({ + 'role': 'tablist' + }); + this.$tabTitles = this.$element.find(".".concat(this.options.linkClass)); + this.$tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-tabs-content=\"".concat(this.$element[0].id, "\"]")); + this.$tabTitles.each(function () { + var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $link = $elem.find('a'), + isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)), + hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1), + linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"), + $tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(hash)); + $elem.attr({ + 'role': 'presentation' + }); + $link.attr({ + 'role': 'tab', + 'aria-controls': hash, + 'aria-selected': isActive, + 'id': linkId, + 'tabindex': isActive ? '0' : '-1' + }); + $tabContent.attr({ + 'role': 'tabpanel', + 'aria-labelledby': linkId + }); // Save up the initial hash to return to it later when going back in history + + if (isActive) { + _this._initialAnchor = "#".concat(hash); + } + + if (!isActive) { + $tabContent.attr('aria-hidden', 'true'); + } + + if (isActive && _this.options.autoFocus) { + _this.onLoadListener = onLoad(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () { + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({ + scrollTop: $elem.offset().top + }, _this.options.deepLinkSmudgeDelay, function () { + $link.focus(); + }); + }); + } + }); + + if (this.options.matchHeight) { + var $images = this.$tabContent.find('img'); + + if ($images.length) { + onImagesLoaded($images, this._setHeight.bind(this)); + } else { + this._setHeight(); + } + } // Current context-bound function to open tabs on page load or history hashchange + + + this._checkDeepLink = function () { + var anchor = window.location.hash; + + if (!anchor.length) { + // If we are still initializing and there is no anchor, then there is nothing to do + if (_this2._isInitializing) return; // Otherwise, move to the initial anchor + + if (_this2._initialAnchor) anchor = _this2._initialAnchor; + } + + var anchorNoHash = anchor.indexOf('#') >= 0 ? anchor.slice(1) : anchor; + var $anchor = anchorNoHash && jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(anchorNoHash)); + + var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"],[data-tabs-target=\"").concat(anchorNoHash, "\"]")).first(); // Whether the anchor element that has been found is part of this element + + + var isOwnAnchor = !!($anchor.length && $link.length); + + if (isOwnAnchor) { + // If there is an anchor for the hash, select it + if ($anchor && $anchor.length && $link && $link.length) { + _this2.selectTab($anchor, true); + } // Otherwise, collapse everything + else { + _this2._collapse(); + } // Roll up a little to show the titles + + + if (_this2.options.deepLinkSmudge) { + var offset = _this2.$element.offset(); + + jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({ + scrollTop: offset.top + }, _this2.options.deepLinkSmudgeDelay); + } + /** + * Fires when the plugin has deeplinked at pageload + * @event Tabs#deeplink + */ + + + _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]); + } + }; //use browser to open a tab, if it exists in this tabset + + + if (this.options.deepLink) { + this._checkDeepLink(); + } + + this._events(); + + this._isInitializing = false; + } + /** + * Adds event handlers for items within the tabs. + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._addKeyHandler(); + + this._addClickHandler(); + + this._setHeightMqHandler = null; + + if (this.options.matchHeight) { + this._setHeightMqHandler = this._setHeight.bind(this); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler); + } + + if (this.options.deepLink) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink); + } + } + /** + * Adds click handlers for items within the tabs. + * @private + */ + + }, { + key: "_addClickHandler", + value: function _addClickHandler() { + var _this = this; + + this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) { + e.preventDefault(); + + _this._handleTabChange(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)); + }); + } + /** + * Adds keyboard event handlers for items within the tabs. + * @private + */ + + }, { + key: "_addKeyHandler", + value: function _addKeyHandler() { + var _this = this; + + this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) { + if (e.which === 9) return; + var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + $elements = $element.parent('ul').children('li'), + $prevElement, + $nextElement; + $elements.each(function (i) { + if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) { + if (_this.options.wrapOnKeys) { + $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1); + $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1); + } else { + $prevElement = $elements.eq(Math.max(0, i - 1)); + $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)); + } + + return; + } + }); // handle keyboard event with keyboard util + + 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.preventDefault(); + } + }); + }); + } + /** + * Opens the tab `$targetContent` defined by `$target`. Collapses active tab. + * @param {jQuery} $target - Tab to open. + * @param {boolean} historyHandled - browser has already handled a history update + * @fires Tabs#change + * @function + */ + + }, { + key: "_handleTabChange", + value: function _handleTabChange($target, historyHandled) { + // With `activeCollapse`, if the target is the active Tab, collapse it. + if ($target.hasClass("".concat(this.options.linkActiveClass))) { + if (this.options.activeCollapse) { + this._collapse(); + } + + return; + } + + var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)), + $tabLink = $target.find('[role="tab"]'), + target = $tabLink.attr('data-tabs-target'), + anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash, + $targetContent = this.$tabContent.find(anchor); //close old tab + + this._collapseTab($oldTab); //open new tab + + + this._openTab($target); //either replace or update browser history + + + if (this.options.deepLink && !historyHandled) { + if (this.options.updateHistory) { + history.pushState({}, '', anchor); + } else { + history.replaceState({}, '', anchor); + } + } + /** + * Fires when the plugin has successfully changed tabs. + * @event Tabs#change + */ + + + this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event + + $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger"); + } + /** + * Opens the tab `$targetContent` defined by `$target`. + * @param {jQuery} $target - Tab to open. + * @function + */ + + }, { + key: "_openTab", + value: function _openTab($target) { + var $tabLink = $target.find('[role="tab"]'), + hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1), + $targetContent = this.$tabContent.find("#".concat(hash)); + $target.addClass("".concat(this.options.linkActiveClass)); + $tabLink.attr({ + 'aria-selected': 'true', + 'tabindex': '0' + }); + $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden'); + } + /** + * Collapses `$targetContent` defined by `$target`. + * @param {jQuery} $target - Tab to collapse. + * @function + */ + + }, { + key: "_collapseTab", + value: function _collapseTab($target) { + var $target_anchor = $target.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({ + 'aria-selected': 'false', + 'tabindex': -1 + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat($target_anchor.attr('aria-controls'))).removeClass("".concat(this.options.panelActiveClass)).attr({ + 'aria-hidden': 'true' + }); + } + /** + * Collapses the active Tab. + * @fires Tabs#collapse + * @function + */ + + }, { + key: "_collapse", + value: function _collapse() { + var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)); + + if ($activeTab.length) { + this._collapseTab($activeTab); + /** + * Fires when the plugin has successfully collapsed tabs. + * @event Tabs#collapse + */ + + + this.$element.trigger('collapse.zf.tabs', [$activeTab]); + } + } + /** + * Public method for selecting a content pane to display. + * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display. + * @param {boolean} historyHandled - browser has already handled a history update + * @function + */ + + }, { + key: "selectTab", + value: function selectTab(elem, historyHandled) { + var idStr, hashIdStr; + + if (_typeof(elem) === 'object') { + idStr = elem[0].id; + } else { + idStr = elem; + } + + if (idStr.indexOf('#') < 0) { + hashIdStr = "#".concat(idStr); + } else { + hashIdStr = idStr; + idStr = idStr.slice(1); + } + + var $target = this.$tabTitles.has("[href$=\"".concat(hashIdStr, "\"],[data-tabs-target=\"").concat(idStr, "\"]")).first(); + + this._handleTabChange($target, historyHandled); + } + }, { + key: "_setHeight", + + /** + * Sets the height of each panel to the height of the tallest panel. + * If enabled in options, gets called on media query change. + * If loading content via external source, can be called directly or with _reflow. + * If enabled with `data-match-height="true"`, tabs sets to equal height + * @function + * @private + */ + value: function _setHeight() { + var max = 0, + _this = this; // Lock down the `this` value for the root tabs object + + + this.$tabContent.find(".".concat(this.options.panelClass)).css('height', '').each(function () { + var panel = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), + isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child + + if (!isActive) { + panel.css({ + 'visibility': 'hidden', + 'display': 'block' + }); + } + + var temp = this.getBoundingClientRect().height; + + if (!isActive) { + panel.css({ + 'visibility': '', + 'display': '' + }); + } + + max = temp > max ? temp : max; + }).css('height', "".concat(max, "px")); + } + /** + * Destroys an instance of tabs. + * @fires Tabs#destroyed + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide(); + + if (this.options.matchHeight) { + if (this._setHeightMqHandler != null) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler); + } + } + + if (this.options.deepLink) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink); + } + + if (this.onLoadListener) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener); + } + } + }]); + + return Tabs; +}(Plugin); + +Tabs.defaults = { + /** + * Link the location hash to the active pane. + * Set the location hash when the active pane changes, and open the corresponding pane when the location changes. + * @option + * @type {boolean} + * @default false + */ + deepLink: false, + + /** + * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible + * @option + * @type {boolean} + * @default false + */ + deepLinkSmudge: false, + + /** + * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment + * @option + * @type {number} + * @default 300 + */ + deepLinkSmudgeDelay: 300, + + /** + * If `deepLink` is enabled, update the browser history with the open tab + * @option + * @type {boolean} + * @default false + */ + updateHistory: false, + + /** + * Allows the window to scroll to content of active pane on load. + * Not recommended if more than one tab panel per page. + * @option + * @type {boolean} + * @default false + */ + autoFocus: false, + + /** + * Allows keyboard input to 'wrap' around the tab links. + * @option + * @type {boolean} + * @default true + */ + wrapOnKeys: true, + + /** + * Allows the tab content panes to match heights if set to true. + * @option + * @type {boolean} + * @default false + */ + matchHeight: false, + + /** + * Allows active tabs to collapse when clicked. + * @option + * @type {boolean} + * @default false + */ + activeCollapse: false, + + /** + * Class applied to `li`'s in tab link list. + * @option + * @type {string} + * @default 'tabs-title' + */ + linkClass: 'tabs-title', + + /** + * Class applied to the active `li` in tab link list. + * @option + * @type {string} + * @default 'is-active' + */ + linkActiveClass: 'is-active', + + /** + * Class applied to the content containers. + * @option + * @type {string} + * @default 'tabs-panel' + */ + panelClass: 'tabs-panel', + + /** + * Class applied to the active content container. + * @option + * @type {string} + * @default 'is-active' + */ + panelActiveClass: 'is-active' +}; +/** + * Toggler module. + * @module foundation.toggler + * @requires foundation.util.motion + * @requires foundation.util.triggers + */ + +var Toggler = /*#__PURE__*/function (_Plugin) { + _inherits(Toggler, _Plugin); + + function Toggler() { + _classCallCheck(this, Toggler); + + return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments)); + } + + _createClass(Toggler, [{ + key: "_setup", + + /** + * Creates a new instance of Toggler. + * @class + * @name Toggler + * @fires Toggler#init + * @param {Object} element - jQuery object to add the trigger to. + * @param {Object} options - Overrides to the default plugin settings. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Toggler.defaults, element.data(), options); + this.className = ''; + this.className = 'Toggler'; // ie9 back compat + // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + + this._events(); + } + /** + * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + // Collect triggers to set ARIA attributes to + var id = this.$element[0].id, + $triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); + var input; // Parse animation classes if they were set + + if (this.options.animate) { + input = this.options.animate.split(' '); + this.animationIn = input[0]; + this.animationOut = input[1] || null; // - aria-expanded: according to the element visibility. + + $triggers.attr('aria-expanded', !this.$element.is(':hidden')); + } // Otherwise, parse toggle class + else { + input = this.options.toggler; + + if (typeof input !== 'string' || !input.length) { + throw new Error("The 'toogler' option containing the target class is required, got \"".concat(input, "\"")); + } // Allow for a . at the beginning of the string + + + this.className = input[0] === '.' ? input.slice(1) : input; // - aria-expanded: according to the elements class set. + + $triggers.attr('aria-expanded', this.$element.hasClass(this.className)); + } // - aria-controls: adding the element id to it if not already in it. + + + $triggers.each(function (index, trigger) { + var $trigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(trigger); + var controls = $trigger.attr('aria-controls') || ''; + var containsId = new RegExp("\\b".concat(RegExpEscape(id), "\\b")).test(controls); + if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id); + }); + } + /** + * Initializes events for the toggle trigger. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this)); + } + /** + * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off". + * @function + * @fires Toggler#on + * @fires Toggler#off + */ + + }, { + key: "toggle", + value: function toggle() { + this[this.options.animate ? '_toggleAnimate' : '_toggleClass'](); + } + }, { + key: "_toggleClass", + value: function _toggleClass() { + this.$element.toggleClass(this.className); + var isOn = this.$element.hasClass(this.className); + + if (isOn) { + /** + * Fires if the target element has the class after a toggle. + * @event Toggler#on + */ + this.$element.trigger('on.zf.toggler'); + } else { + /** + * Fires if the target element does not have the class after a toggle. + * @event Toggler#off + */ + this.$element.trigger('off.zf.toggler'); + } + + this._updateARIA(isOn); + + this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger'); + } + }, { + key: "_toggleAnimate", + value: function _toggleAnimate() { + var _this = this; + + if (this.$element.is(':hidden')) { + Motion.animateIn(this.$element, this.animationIn, function () { + _this._updateARIA(true); + + this.trigger('on.zf.toggler'); + this.find('[data-mutate]').trigger('mutateme.zf.trigger'); + }); + } else { + Motion.animateOut(this.$element, this.animationOut, function () { + _this._updateARIA(false); + + this.trigger('off.zf.toggler'); + this.find('[data-mutate]').trigger('mutateme.zf.trigger'); + }); + } + } + }, { + key: "_updateARIA", + value: function _updateARIA(isOn) { + var id = this.$element[0].id; + jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(id, "\"], [data-close=\"").concat(id, "\"], [data-toggle=\"").concat(id, "\"]")).attr({ + 'aria-expanded': isOn ? true : false + }); + } + /** + * Destroys the instance of Toggler on the element. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.off('.zf.toggler'); + } + }]); + + return Toggler; +}(Plugin); + +Toggler.defaults = { + /** + * Class of the element to toggle. It can be provided with or without "." + * @option + * @type {string} + */ + toggler: undefined, + + /** + * Tells the plugin if the element should animated when toggled. + * @option + * @type {boolean} + * @default false + */ + animate: false +}; +/** + * Tooltip module. + * @module foundation.tooltip + * @requires foundation.util.box + * @requires foundation.util.mediaQuery + * @requires foundation.util.triggers + */ + +var Tooltip = /*#__PURE__*/function (_Positionable) { + _inherits(Tooltip, _Positionable); + + function Tooltip() { + _classCallCheck(this, Tooltip); + + return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments)); + } + + _createClass(Tooltip, [{ + key: "_setup", + + /** + * Creates a new instance of a Tooltip. + * @class + * @name Tooltip + * @fires Tooltip#init + * @param {jQuery} element - jQuery object to attach a tooltip to. + * @param {Object} options - object to extend the default configuration. + */ + value: function _setup(element, options) { + this.$element = element; + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tooltip.defaults, this.$element.data(), options); + this.className = 'Tooltip'; // ie9 back compat + + this.isActive = false; + this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized + + Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); + + this._init(); + } + /** + * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor. + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); + + var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip'); + this.options.tipText = this.options.tipText || this.$element.attr('title'); + this.template = this.options.template ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.template) : this._buildTemplate(elemId); + + if (this.options.allowHtml) { + this.template.appendTo(document.body).html(this.options.tipText).hide(); + } else { + this.template.appendTo(document.body).text(this.options.tipText).hide(); + } + + this.$element.attr({ + 'title': '', + 'aria-describedby': elemId, + 'data-yeti-box': elemId, + 'data-toggle': elemId, + 'data-resize': elemId + }).addClass(this.options.triggerClass); + + _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this); + + this._events(); + } + }, { + key: "_getDefaultPosition", + value: function _getDefaultPosition() { + // handle legacy classnames + var elementClassName = this.$element[0].className; + + if (this.$element[0] instanceof SVGElement) { + elementClassName = elementClassName.baseVal; + } + + var position = elementClassName.match(/\b(top|left|right|bottom)\b/g); + return position ? position[0] : 'top'; + } + }, { + key: "_getDefaultAlignment", + value: function _getDefaultAlignment() { + return 'center'; + } + }, { + key: "_getHOffset", + value: function _getHOffset() { + if (this.position === 'left' || this.position === 'right') { + return this.options.hOffset + this.options.tooltipWidth; + } else { + return this.options.hOffset; + } + } + }, { + key: "_getVOffset", + value: function _getVOffset() { + if (this.position === 'top' || this.position === 'bottom') { + return this.options.vOffset + this.options.tooltipHeight; + } else { + return this.options.vOffset; + } + } + /** + * builds the tooltip element, adds attributes, and returns the template. + * @private + */ + + }, { + key: "_buildTemplate", + value: function _buildTemplate(id) { + var templateClasses = "".concat(this.options.tooltipClass, " ").concat(this.options.templateClasses).trim(); + var $template = jquery__WEBPACK_IMPORTED_MODULE_0___default()('').addClass(templateClasses).attr({ + 'role': 'tooltip', + 'aria-hidden': true, + 'data-is-active': false, + 'data-is-focus': false, + 'id': id + }); + return $template; + } + /** + * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding. + * if the tooltip is larger than the screen width, default to full width - any user selected margin + * @private + */ + + }, { + key: "_setPosition", + value: function _setPosition() { + _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template); + } + /** + * reveals the tooltip, and fires an event to close any other open tooltips on the page + * @fires Tooltip#closeme + * @fires Tooltip#show + * @function + */ + + }, { + key: "show", + value: function show() { + if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) { + // console.error('The screen is too small to display this tooltip'); + return false; + } + + var _this = this; + + this.template.css('visibility', 'hidden').show(); + + this._setPosition(); + + this.template.removeClass('top bottom left right').addClass(this.position); + this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment); + /** + * Fires to close all other open tooltips on the page + * @event Closeme#tooltip + */ + + this.$element.trigger('closeme.zf.tooltip', this.template.attr('id')); + this.template.attr({ + 'data-is-active': true, + 'aria-hidden': false + }); + _this.isActive = true; // console.log(this.template); + + this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff? + }); + /** + * Fires when the tooltip is shown + * @event Tooltip#show + */ + + this.$element.trigger('show.zf.tooltip'); + } + /** + * Hides the current tooltip, and resets the positioning class if it was changed due to collision + * @fires Tooltip#hide + * @function + */ + + }, { + key: "hide", + value: function hide() { + // console.log('hiding', this.$element.data('yeti-box')); + var _this = this; + + this.template.stop().attr({ + 'aria-hidden': true, + 'data-is-active': false + }).fadeOut(this.options.fadeOutDuration, function () { + _this.isActive = false; + _this.isClick = false; + }); + /** + * fires when the tooltip is hidden + * @event Tooltip#hide + */ + + this.$element.trigger('hide.zf.tooltip'); + } + /** + * adds event listeners for the tooltip and its anchor + * TODO combine some of the listeners like focus and mouseenter, etc. + * @private + */ + + }, { + key: "_events", + value: function _events() { + var _this = this; + + var hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined'; + var $template = this.template; + var isFocus = false; // `disableForTouch: Fully disable the tooltip on touch devices + + if (hasTouch && this.options.disableForTouch) return; + + if (!this.options.disableHover) { + this.$element.on('mouseenter.zf.tooltip', function (e) { + if (!_this.isActive) { + _this.timeout = setTimeout(function () { + _this.show(); + }, _this.options.hoverDelay); + } + }).on('mouseleave.zf.tooltip', ignoreMousedisappear(function (e) { + clearTimeout(_this.timeout); + + if (!isFocus || _this.isClick && !_this.options.clickOpen) { + _this.hide(); + } + })); + } + + if (hasTouch) { + this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) { + _this.isActive ? _this.hide() : _this.show(); + }); + } + + if (this.options.clickOpen) { + this.$element.on('mousedown.zf.tooltip', function (e) { + if (_this.isClick) ;else { + _this.isClick = true; + + if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) { + _this.show(); + } + } + }); + } else { + this.$element.on('mousedown.zf.tooltip', function (e) { + _this.isClick = true; + }); + } + + this.$element.on({ + // 'toggle.zf.trigger': this.toggle.bind(this), + // 'close.zf.trigger': this.hide.bind(this) + 'close.zf.trigger': this.hide.bind(this) + }); + this.$element.on('focus.zf.tooltip', function (e) { + isFocus = true; + + if (_this.isClick) { + // If we're not showing open on clicks, we need to pretend a click-launched focus isn't + // a real focus, otherwise on hover and come back we get bad behavior + if (!_this.options.clickOpen) { + isFocus = false; + } + + return false; + } else { + _this.show(); + } + }).on('focusout.zf.tooltip', function (e) { + isFocus = false; + _this.isClick = false; + + _this.hide(); + }).on('resizeme.zf.trigger', function () { + if (_this.isActive) { + _this._setPosition(); + } + }); + } + /** + * adds a toggle method, in addition to the static show() & hide() functions + * @function + */ + + }, { + key: "toggle", + value: function toggle() { + if (this.isActive) { + this.hide(); + } else { + this.show(); + } + } + /** + * Destroys an instance of tooltip, removes template element from the view. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box'); + this.template.remove(); + } + }]); + + return Tooltip; +}(Positionable); + +Tooltip.defaults = { + /** + * 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, + + /** + * Disable the tooltip for touch devices. + * This can be useful to make elements with a tooltip on it trigger their + * action on the first tap instead of displaying the tooltip. + * @option + * @type {booelan} + * @default false + */ + disableForTouch: false, + + /** + * Optional addtional classes to apply to the tooltip template on init. + * @option + * @type {string} + * @default '' + */ + templateClasses: '', + + /** + * Non-optional class added to tooltip templates. Foundation default is 'tooltip'. + * @option + * @type {string} + * @default 'tooltip' + */ + tooltipClass: 'tooltip', + + /** + * Class applied to the tooltip anchor element. + * @option + * @type {string} + * @default 'has-tip' + */ + triggerClass: 'has-tip', + + /** + * Minimum breakpoint size at which to open the tooltip. + * @option + * @type {string} + * @default 'small' + */ + showOn: 'small', + + /** + * Custom template to be used to generate markup for tooltip. + * @option + * @type {string} + * @default '' + */ + template: '', + + /** + * Text displayed in the tooltip template on open. + * @option + * @type {string} + * @default '' + */ + tipText: '', + touchCloseText: 'Tap to close.', + + /** + * Allows the tooltip to remain open if triggered with a click or touch event. + * @option + * @type {boolean} + * @default true + */ + clickOpen: true, + + /** + * Position of tooltip. Can be left, right, bottom, top, or auto. + * @option + * @type {string} + * @default 'auto' + */ + position: 'auto', + + /** + * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto. + * @option + * @type {string} + * @default 'auto' + */ + alignment: 'auto', + + /** + * Allow overlap of container/window. If false, tooltip will first try to + * position as defined by data-position and data-alignment, but reposition if + * it would cause an overflow. @option + * @type {boolean} + * @default false + */ + allowOverlap: false, + + /** + * Allow overlap of only the bottom of the container. This is the most common + * behavior for dropdowns, allowing the dropdown to extend the bottom of the + * screen but not otherwise influence or break out of the container. + * Less common for tooltips. + * @option + * @type {boolean} + * @default false + */ + allowBottomOverlap: false, + + /** + * Distance, in pixels, the template should push away from the anchor on the Y axis. + * @option + * @type {number} + * @default 0 + */ + vOffset: 0, + + /** + * Distance, in pixels, the template should push away from the anchor on the X axis + * @option + * @type {number} + * @default 0 + */ + hOffset: 0, + + /** + * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip + * @option + * @type {number} + * @default 14 + */ + tooltipHeight: 14, + + /** + * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip + * @option + * @type {number} + * @default 12 + */ + tooltipWidth: 12, + + /** + * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips, + * allowing HTML may open yourself up to XSS attacks. + * @option + * @type {boolean} + * @default false + */ + allowHtml: false +}; +var MenuPlugins$1 = { + tabs: { + cssClass: 'tabs', + plugin: Tabs, + open: function open(plugin, target) { + return plugin.selectTab(target); + }, + close: null + /* not supported */ + , + toggle: null + /* not supported */ + + }, + accordion: { + cssClass: 'accordion', + plugin: Accordion, + open: function open(plugin, target) { + return plugin.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(target)); + }, + close: function close(plugin, target) { + return plugin.up(jquery__WEBPACK_IMPORTED_MODULE_0___default()(target)); + }, + toggle: function toggle(plugin, target) { + return plugin.toggle(jquery__WEBPACK_IMPORTED_MODULE_0___default()(target)); + } + } +}; +/** + * ResponsiveAccordionTabs module. + * @module foundation.responsiveAccordionTabs + * @requires foundation.util.motion + * @requires foundation.accordion + * @requires foundation.tabs + */ + +var ResponsiveAccordionTabs = /*#__PURE__*/function (_Plugin) { + _inherits(ResponsiveAccordionTabs, _Plugin); + + function ResponsiveAccordionTabs(element, options) { + var _this2; + + _classCallCheck(this, ResponsiveAccordionTabs); + + _this2 = _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).call(this, element, options)); + return _possibleConstructorReturn(_this2, _this2.options.reflow && _this2.storezfData || _assertThisInitialized(_this2)); + } + /** + * Creates a new instance of a responsive accordion tabs. + * @class + * @name ResponsiveAccordionTabs + * @fires ResponsiveAccordionTabs#init + * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs. + * @param {Object} options - Overrides to the default plugin settings. + */ + + + _createClass(ResponsiveAccordionTabs, [{ + key: "_setup", + value: function _setup(element, options) { + this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element); + this.$element.data('zfPluginBase', this); + this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveAccordionTabs.defaults, this.$element.data(), options); + this.rules = this.$element.data('responsive-accordion-tabs'); + this.currentMq = null; + this.currentRule = null; + this.currentPlugin = null; + this.className = 'ResponsiveAccordionTabs'; // ie9 back compat + + if (!this.$element.attr('id')) { + this.$element.attr('id', GetYoDigits(6, 'responsiveaccordiontabs')); + } + + this._init(); + + this._events(); + } + /** + * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element. + * @function + * @private + */ + + }, { + key: "_init", + value: function _init() { + MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules + + + if (typeof this.rules === 'string') { + var rulesTree = {}; // Parse rules from "classes" pulled from data attribute + + var rules = this.rules.split(' '); // Iterate through every rule found + + for (var i = 0; i < rules.length; i++) { + var rule = rules[i].split('-'); + var ruleSize = rule.length > 1 ? rule[0] : 'small'; + var rulePlugin = rule.length > 1 ? rule[1] : rule[0]; + + if (MenuPlugins$1[rulePlugin] !== null) { + rulesTree[ruleSize] = MenuPlugins$1[rulePlugin]; + } + } + + this.rules = rulesTree; + } + + this._getAllOptions(); + + if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) { + this._checkMediaQueries(); + } + } + }, { + key: "_getAllOptions", + value: function _getAllOptions() { + //get all defaults and options + var _this = this; + + _this.allOptions = {}; + + for (var key in MenuPlugins$1) { + if (MenuPlugins$1.hasOwnProperty(key)) { + var obj = MenuPlugins$1[key]; + + try { + var dummyPlugin = jquery__WEBPACK_IMPORTED_MODULE_0___default()(''); + var tmpPlugin = new obj.plugin(dummyPlugin, _this.options); + + for (var keyKey in tmpPlugin.options) { + if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') { + var objObj = tmpPlugin.options[keyKey]; + _this.allOptions[keyKey] = objObj; + } + } + + tmpPlugin.destroy(); + } catch (e) {} + } + } + } + /** + * Initializes events for the Menu. + * @function + * @private + */ + + }, { + key: "_events", + value: function _events() { + this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler); + } + /** + * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out. + * @function + * @private + */ + + }, { + key: "_checkMediaQueries", + value: function _checkMediaQueries() { + var matchedMq, + _this = this; // Iterate through each rule and find the last matching rule + + + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) { + if (MediaQuery.atLeast(key)) { + matchedMq = key; + } + }); // No match? No dice + + if (!matchedMq) return; // Plugin already initialized? We good + + if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes + + jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins$1, function (key, value) { + _this.$element.removeClass(value.cssClass); + }); // Add the CSS class for the new plugin + + this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin + + if (this.currentPlugin) { + //don't know why but on nested elements data zfPlugin get's lost + if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData); + this.currentPlugin.destroy(); + } + + this._handleMarkup(this.rules[matchedMq].cssClass); + + this.currentRule = this.rules[matchedMq]; + this.currentPlugin = new this.currentRule.plugin(this.$element, this.options); + this.storezfData = this.currentPlugin.$element.data('zfPlugin'); + } + }, { + key: "_handleMarkup", + value: function _handleMarkup(toSet) { + var _this = this, + fromString = 'accordion'; + + var $panels = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + this.$element.attr('id') + ']'); + if ($panels.length) fromString = 'tabs'; + + if (fromString === toSet) { + return; + } + + var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title'; + var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel'; + this.$element.removeAttr('role'); + var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item'); + var $liHeadsA = $liHeads.children('a').removeClass('accordion-title'); + + 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) { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({ + height: '' + }); + jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('').detach(); + $liHeads.addClass('accordion-item').attr('data-accordion-item', ''); + $liHeadsA.addClass('accordion-title'); + }); + } else if (toSet === 'tabs') { + var $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']'); + var $placeholder = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#tabs-placeholder-' + _this.$element.attr('id')); + + if ($placeholder.length) { + $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id')); + $placeholder.remove(); + } else { + $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id')); + } + + $panels.each(function (key, value) { + var tempValue = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($tabsContent).addClass(tabsPanel); + var hash = $liHeadsA.get(key).hash.slice(1); + var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id') || GetYoDigits(6, 'accordion'); + + if (hash !== id) { + if (hash !== '') { + jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash); + } else { + hash = id; + jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash); + jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href', jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash); + } + } + + var isActive = jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeads.get(key)).hasClass('is-active'); + + if (isActive) { + tempValue.addClass('is-active'); + } + }); + $liHeads.addClass(tabsTitle); + } + } + /** + * Opens the plugin pane defined by `target`. + * @param {jQuery | String} target - jQuery object or string of the id of the pane to open. + * @see Accordion.down + * @see Tabs.selectTab + * @function + */ + + }, { + key: "open", + value: function open(_target) { + if (this.currentRule && typeof this.currentRule.open === 'function') { + var _this$currentRule; + + return (_this$currentRule = this.currentRule).open.apply(_this$currentRule, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); + } + } + /** + * Closes the plugin pane defined by `target`. Not availaible for Tabs. + * @param {jQuery | String} target - jQuery object or string of the id of the pane to close. + * @see Accordion.up + * @function + */ + + }, { + key: "close", + value: function close(_target) { + if (this.currentRule && typeof this.currentRule.close === 'function') { + var _this$currentRule2; + + return (_this$currentRule2 = this.currentRule).close.apply(_this$currentRule2, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); + } + } + /** + * Toggles the plugin pane defined by `target`. Not availaible for Tabs. + * @param {jQuery | String} target - jQuery object or string of the id of the pane to toggle. + * @see Accordion.toggle + * @function + */ + + }, { + key: "toggle", + value: function toggle(_target) { + if (this.currentRule && typeof this.currentRule.toggle === 'function') { + var _this$currentRule3; + + return (_this$currentRule3 = this.currentRule).toggle.apply(_this$currentRule3, [this.currentPlugin].concat(Array.prototype.slice.call(arguments))); + } + } + /** + * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out. + * @function + */ + + }, { + key: "_destroy", + value: function _destroy() { + if (this.currentPlugin) this.currentPlugin.destroy(); + jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler); + } + }]); + + return ResponsiveAccordionTabs; +}(Plugin); + +ResponsiveAccordionTabs.defaults = {}; +Foundation.addToJquery(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Add Foundation Utils to Foundation global namespace for backwards +// compatibility. + +Foundation.rtl = rtl; +Foundation.GetYoDigits = GetYoDigits; +Foundation.transitionend = transitionend; +Foundation.RegExpEscape = RegExpEscape; +Foundation.onLoad = onLoad; +Foundation.Box = Box; +Foundation.onImagesLoaded = onImagesLoaded; +Foundation.Keyboard = Keyboard; +Foundation.MediaQuery = MediaQuery; +Foundation.Motion = Motion; +Foundation.Move = Move; +Foundation.Nest = Nest; +Foundation.Timer = Timer; // Touch and Triggers previously were almost purely sede effect driven, +// so no need to add it to Foundation, just init them. + +Touch.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); +Triggers.init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a, Foundation); + +MediaQuery._init(); + +Foundation.plugin(Abide, 'Abide'); +Foundation.plugin(Accordion, 'Accordion'); +Foundation.plugin(AccordionMenu, 'AccordionMenu'); +Foundation.plugin(Drilldown, 'Drilldown'); +Foundation.plugin(Dropdown, 'Dropdown'); +Foundation.plugin(DropdownMenu, 'DropdownMenu'); +Foundation.plugin(Equalizer, 'Equalizer'); +Foundation.plugin(Interchange, 'Interchange'); +Foundation.plugin(Magellan, 'Magellan'); +Foundation.plugin(OffCanvas, 'OffCanvas'); +Foundation.plugin(Orbit, 'Orbit'); +Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu'); +Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle'); +Foundation.plugin(Reveal, 'Reveal'); +Foundation.plugin(Slider, 'Slider'); +Foundation.plugin(SmoothScroll, 'SmoothScroll'); +Foundation.plugin(Sticky, 'Sticky'); +Foundation.plugin(Tabs, 'Tabs'); +Foundation.plugin(Toggler, 'Toggler'); +Foundation.plugin(Tooltip, 'Tooltip'); +Foundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs'); +/* harmony default export */ __webpack_exports__["default"] = (Foundation); + + +/***/ }), + +/***/ "./node_modules/jquery/dist/jquery.js": +/*!********************************************!*\ + !*** ./node_modules/jquery/dist/jquery.js ***! + \********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(module) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } + +/*! + * jQuery JavaScript Library v3.5.0 + * https://jquery.com/ + * + * Includes Sizzle.js + * https://sizzlejs.com/ + * + * Copyright JS Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2020-04-10T15:07Z + */ +(function (global, factory) { + "use strict"; + + if (( false ? undefined : _typeof(module)) === "object" && _typeof(module.exports) === "object") { + // For CommonJS and CommonJS-like environments where a proper `window` + // is present, execute the factory and get jQuery. + // For environments that do not have a `window` with a `document` + // (such as Node.js), expose a factory as module.exports. + // This accentuates the need for the creation of a real `window`. + // e.g. var jQuery = require("jquery")(window); + // See ticket #14549 for more info. + module.exports = global.document ? factory(global, true) : function (w) { + if (!w.document) { + throw new Error("jQuery requires a window with a document"); + } + + return factory(w); + }; + } else { + factory(global); + } // Pass this if window is not defined yet + +})(typeof window !== "undefined" ? window : this, function (window, noGlobal) { + // Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1 + // throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode + // arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common + // enough that all such attempts are guarded in a try block. + "use strict"; + + var arr = []; + var getProto = Object.getPrototypeOf; + var _slice = arr.slice; + var flat = arr.flat ? function (array) { + return arr.flat.call(array); + } : function (array) { + return arr.concat.apply([], array); + }; + var push = arr.push; + var indexOf = arr.indexOf; + var class2type = {}; + var toString = class2type.toString; + var hasOwn = class2type.hasOwnProperty; + var fnToString = hasOwn.toString; + var ObjectFunctionString = fnToString.call(Object); + var support = {}; + + var isFunction = function isFunction(obj) { + // Support: Chrome <=57, Firefox <=52 + // In some browsers, typeof returns "function" for HTML elements + // (i.e., `typeof document.createElement( "object" ) === "function"`). + // We don't want to classify *any* DOM node as a function. + return typeof obj === "function" && typeof obj.nodeType !== "number"; + }; + + var isWindow = function isWindow(obj) { + return obj != null && obj === obj.window; + }; + + var document = window.document; + var preservedScriptAttributes = { + type: true, + src: true, + nonce: true, + noModule: true + }; + + function DOMEval(code, node, doc) { + doc = doc || document; + var i, + val, + script = doc.createElement("script"); + script.text = code; + + if (node) { + for (i in preservedScriptAttributes) { + // Support: Firefox 64+, Edge 18+ + // Some browsers don't support the "nonce" property on scripts. + // On the other hand, just using `getAttribute` is not enough as + // the `nonce` attribute is reset to an empty string whenever it + // becomes browsing-context connected. + // See https://github.com/whatwg/html/issues/2369 + // See https://html.spec.whatwg.org/#nonce-attributes + // The `node.getAttribute` check was added for the sake of + // `jQuery.globalEval` so that it can fake a nonce-containing node + // via an object. + val = node[i] || node.getAttribute && node.getAttribute(i); + + if (val) { + script.setAttribute(i, val); + } + } + } + + doc.head.appendChild(script).parentNode.removeChild(script); + } + + function toType(obj) { + if (obj == null) { + return obj + ""; + } // Support: Android <=2.3 only (functionish RegExp) + + + return _typeof(obj) === "object" || typeof obj === "function" ? class2type[toString.call(obj)] || "object" : _typeof(obj); + } + /* global Symbol */ + // Defining this global in .eslintrc.json would create a danger of using the global + // unguarded in another place, it seems safer to define global only for this module + + + var version = "3.5.0", + // Define a local copy of jQuery + jQuery = function jQuery(selector, context) { + // The jQuery object is actually just the init constructor 'enhanced' + // Need init if jQuery is called (just allow error to be thrown if not included) + return new jQuery.fn.init(selector, context); + }; + + jQuery.fn = jQuery.prototype = { + // The current version of jQuery being used + jquery: version, + constructor: jQuery, + // The default length of a jQuery object is 0 + length: 0, + toArray: function toArray() { + return _slice.call(this); + }, + // Get the Nth element in the matched element set OR + // Get the whole matched element set as a clean array + get: function get(num) { + // Return all the elements in a clean array + if (num == null) { + return _slice.call(this); + } // Return just the one element from the set + + + return num < 0 ? this[num + this.length] : this[num]; + }, + // Take an array of elements and push it onto the stack + // (returning the new matched element set) + pushStack: function pushStack(elems) { + // Build a new jQuery matched element set + var ret = jQuery.merge(this.constructor(), elems); // Add the old object onto the stack (as a reference) + + ret.prevObject = this; // Return the newly-formed element set + + return ret; + }, + // Execute a callback for every element in the matched set. + each: function each(callback) { + return jQuery.each(this, callback); + }, + map: function map(callback) { + return this.pushStack(jQuery.map(this, function (elem, i) { + return callback.call(elem, i, elem); + })); + }, + slice: function slice() { + return this.pushStack(_slice.apply(this, arguments)); + }, + first: function first() { + return this.eq(0); + }, + last: function last() { + return this.eq(-1); + }, + even: function even() { + return this.pushStack(jQuery.grep(this, function (_elem, i) { + return (i + 1) % 2; + })); + }, + odd: function odd() { + return this.pushStack(jQuery.grep(this, function (_elem, i) { + return i % 2; + })); + }, + eq: function eq(i) { + var len = this.length, + j = +i + (i < 0 ? len : 0); + return this.pushStack(j >= 0 && j < len ? [this[j]] : []); + }, + end: function end() { + return this.prevObject || this.constructor(); + }, + // For internal use only. + // Behaves like an Array's method, not like a jQuery method. + push: push, + sort: arr.sort, + splice: arr.splice + }; + + jQuery.extend = jQuery.fn.extend = function () { + var options, + name, + src, + copy, + copyIsArray, + clone, + target = arguments[0] || {}, + i = 1, + length = arguments.length, + deep = false; // Handle a deep copy situation + + if (typeof target === "boolean") { + deep = target; // Skip the boolean and the target + + target = arguments[i] || {}; + i++; + } // Handle case when target is a string or something (possible in deep copy) + + + if (_typeof(target) !== "object" && !isFunction(target)) { + target = {}; + } // Extend jQuery itself if only one argument is passed + + + if (i === length) { + target = this; + i--; + } + + for (; i < length; i++) { + // Only deal with non-null/undefined values + if ((options = arguments[i]) != null) { + // Extend the base object + for (name in options) { + copy = options[name]; // Prevent Object.prototype pollution + // Prevent never-ending loop + + if (name === "__proto__" || target === copy) { + continue; + } // Recurse if we're merging plain objects or arrays + + + if (deep && copy && (jQuery.isPlainObject(copy) || (copyIsArray = Array.isArray(copy)))) { + src = target[name]; // Ensure proper type for the source value + + if (copyIsArray && !Array.isArray(src)) { + clone = []; + } else if (!copyIsArray && !jQuery.isPlainObject(src)) { + clone = {}; + } else { + clone = src; + } + + copyIsArray = false; // Never move original objects, clone them + + target[name] = jQuery.extend(deep, clone, copy); // Don't bring in undefined values + } else if (copy !== undefined) { + target[name] = copy; + } + } + } + } // Return the modified object + + + return target; + }; + + jQuery.extend({ + // Unique for each copy of jQuery on the page + expando: "jQuery" + (version + Math.random()).replace(/\D/g, ""), + // Assume jQuery is ready without the ready module + isReady: true, + error: function error(msg) { + throw new Error(msg); + }, + noop: function noop() {}, + isPlainObject: function isPlainObject(obj) { + var proto, Ctor; // Detect obvious negatives + // Use toString instead of jQuery.type to catch host objects + + if (!obj || toString.call(obj) !== "[object Object]") { + return false; + } + + proto = getProto(obj); // Objects with no prototype (e.g., `Object.create( null )`) are plain + + if (!proto) { + return true; + } // Objects with prototype are plain iff they were constructed by a global Object function + + + Ctor = hasOwn.call(proto, "constructor") && proto.constructor; + return typeof Ctor === "function" && fnToString.call(Ctor) === ObjectFunctionString; + }, + isEmptyObject: function isEmptyObject(obj) { + var name; + + for (name in obj) { + return false; + } + + return true; + }, + // Evaluates a script in a provided context; falls back to the global one + // if not specified. + globalEval: function globalEval(code, options, doc) { + DOMEval(code, { + nonce: options && options.nonce + }, doc); + }, + each: function each(obj, callback) { + var length, + i = 0; + + if (isArrayLike(obj)) { + length = obj.length; + + for (; i < length; i++) { + if (callback.call(obj[i], i, obj[i]) === false) { + break; + } + } + } else { + for (i in obj) { + if (callback.call(obj[i], i, obj[i]) === false) { + break; + } + } + } + + return obj; + }, + // results is for internal usage only + makeArray: function makeArray(arr, results) { + var ret = results || []; + + if (arr != null) { + if (isArrayLike(Object(arr))) { + jQuery.merge(ret, typeof arr === "string" ? [arr] : arr); + } else { + push.call(ret, arr); + } + } + + return ret; + }, + inArray: function inArray(elem, arr, i) { + return arr == null ? -1 : indexOf.call(arr, elem, i); + }, + // Support: Android <=4.0 only, PhantomJS 1 only + // push.apply(_, arraylike) throws on ancient WebKit + merge: function merge(first, second) { + var len = +second.length, + j = 0, + i = first.length; + + for (; j < len; j++) { + first[i++] = second[j]; + } + + first.length = i; + return first; + }, + grep: function grep(elems, callback, invert) { + var callbackInverse, + matches = [], + i = 0, + length = elems.length, + callbackExpect = !invert; // Go through the array, only saving the items + // that pass the validator function + + for (; i < length; i++) { + callbackInverse = !callback(elems[i], i); + + if (callbackInverse !== callbackExpect) { + matches.push(elems[i]); + } + } + + return matches; + }, + // arg is for internal usage only + map: function map(elems, callback, arg) { + var length, + value, + i = 0, + ret = []; // Go through the array, translating each of the items to their new values + + if (isArrayLike(elems)) { + length = elems.length; + + for (; i < length; i++) { + value = callback(elems[i], i, arg); + + if (value != null) { + ret.push(value); + } + } // Go through every key on the object, + + } else { + for (i in elems) { + value = callback(elems[i], i, arg); + + if (value != null) { + ret.push(value); + } + } + } // Flatten any nested arrays + + + return flat(ret); + }, + // A global GUID counter for objects + guid: 1, + // jQuery.support is not used in Core but other projects attach their + // properties to it so it needs to exist. + support: support + }); + + if (typeof Symbol === "function") { + jQuery.fn[Symbol.iterator] = arr[Symbol.iterator]; + } // Populate the class2type map + + + jQuery.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function (_i, name) { + class2type["[object " + name + "]"] = name.toLowerCase(); + }); + + function isArrayLike(obj) { + // Support: real iOS 8.2 only (not reproducible in simulator) + // `in` check used to prevent JIT error (gh-2145) + // hasOwn isn't used here due to false negatives + // regarding Nodelist length in IE + var length = !!obj && "length" in obj && obj.length, + type = toType(obj); + + if (isFunction(obj) || isWindow(obj)) { + return false; + } + + return type === "array" || length === 0 || typeof length === "number" && length > 0 && length - 1 in obj; + } + + var Sizzle = + /*! + * Sizzle CSS Selector Engine v2.3.5 + * https://sizzlejs.com/ + * + * Copyright JS Foundation and other contributors + * Released under the MIT license + * https://js.foundation/ + * + * Date: 2020-03-14 + */ + function (window) { + var i, + support, + Expr, + getText, + isXML, + tokenize, + compile, + select, + outermostContext, + sortInput, + hasDuplicate, + // Local document vars + setDocument, + document, + docElem, + documentIsHTML, + rbuggyQSA, + rbuggyMatches, + matches, + contains, + // Instance-specific data + expando = "sizzle" + 1 * new Date(), + preferredDoc = window.document, + dirruns = 0, + done = 0, + classCache = createCache(), + tokenCache = createCache(), + compilerCache = createCache(), + nonnativeSelectorCache = createCache(), + sortOrder = function sortOrder(a, b) { + if (a === b) { + hasDuplicate = true; + } + + return 0; + }, + // Instance methods + hasOwn = {}.hasOwnProperty, + arr = [], + pop = arr.pop, + pushNative = arr.push, + push = arr.push, + slice = arr.slice, + // Use a stripped-down indexOf as it's faster than native + // https://jsperf.com/thor-indexof-vs-for/5 + indexOf = function indexOf(list, elem) { + var i = 0, + len = list.length; + + for (; i < len; i++) { + if (list[i] === elem) { + return i; + } + } + + return -1; + }, + booleans = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|" + "ismap|loop|multiple|open|readonly|required|scoped", + // Regular expressions + // http://www.w3.org/TR/css3-selectors/#whitespace + whitespace = "[\\x20\\t\\r\\n\\f]", + // https://www.w3.org/TR/css-syntax-3/#ident-token-diagram + identifier = "(?:\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+", + // Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors + attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace + // Operator (capture 2) + "*([*^$|!~]?=)" + whitespace + // "Attribute values must be CSS identifiers [capture 5] + // or strings [capture 3 or capture 4]" + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + whitespace + "*\\]", + pseudos = ":(" + identifier + ")(?:\\((" + // To reduce the number of selectors needing tokenize in the preFilter, prefer arguments: + // 1. quoted (capture 3; capture 4 or capture 5) + "('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|" + // 2. simple (capture 6) + "((?:\\\\.|[^\\\\()[\\]]|" + attributes + ")*)|" + // 3. anything else (capture 2) + ".*" + ")\\)|)", + // Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter + rwhitespace = new RegExp(whitespace + "+", "g"), + rtrim = new RegExp("^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g"), + rcomma = new RegExp("^" + whitespace + "*," + whitespace + "*"), + rcombinators = new RegExp("^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + "*"), + rdescend = new RegExp(whitespace + "|>"), + rpseudo = new RegExp(pseudos), + ridentifier = new RegExp("^" + identifier + "$"), + matchExpr = { + "ID": new RegExp("^#(" + identifier + ")"), + "CLASS": new RegExp("^\\.(" + identifier + ")"), + "TAG": new RegExp("^(" + identifier + "|[*])"), + "ATTR": new RegExp("^" + attributes), + "PSEUDO": new RegExp("^" + pseudos), + "CHILD": new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i"), + "bool": new RegExp("^(?:" + booleans + ")$", "i"), + // For use in libraries implementing .is() + // We use this for POS matching in `select` + "needsContext": new RegExp("^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i") + }, + rhtml = /HTML$/i, + rinputs = /^(?:input|select|textarea|button)$/i, + rheader = /^h\d$/i, + rnative = /^[^{]+\{\s*\[native \w/, + // Easily-parseable/retrievable ID or TAG or CLASS selectors + rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, + rsibling = /[+~]/, + // CSS escapes + // http://www.w3.org/TR/CSS21/syndata.html#escaped-characters + runescape = new RegExp("\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\([^\\r\\n\\f])", "g"), + funescape = function funescape(escape, nonHex) { + var high = "0x" + escape.slice(1) - 0x10000; + return nonHex ? // Strip the backslash prefix from a non-hex escape sequence + nonHex : // Replace a hexadecimal escape sequence with the encoded Unicode code point + // Support: IE <=11+ + // For values outside the Basic Multilingual Plane (BMP), manually construct a + // surrogate pair + high < 0 ? String.fromCharCode(high + 0x10000) : String.fromCharCode(high >> 10 | 0xD800, high & 0x3FF | 0xDC00); + }, + // CSS string/identifier serialization + // https://drafts.csswg.org/cssom/#common-serializing-idioms + rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g, + fcssescape = function fcssescape(ch, asCodePoint) { + if (asCodePoint) { + // U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER + if (ch === "\0") { + return "\uFFFD"; + } // Control characters and (dependent upon position) numbers get escaped as code points + + + return ch.slice(0, -1) + "\\" + ch.charCodeAt(ch.length - 1).toString(16) + " "; + } // Other potentially-special ASCII characters get backslash-escaped + + + return "\\" + ch; + }, + // Used for iframes + // See setDocument() + // Removing the function wrapper causes a "Permission Denied" + // error in IE + unloadHandler = function unloadHandler() { + setDocument(); + }, + inDisabledFieldset = addCombinator(function (elem) { + return elem.disabled === true && elem.nodeName.toLowerCase() === "fieldset"; + }, { + dir: "parentNode", + next: "legend" + }); // Optimize for push.apply( _, NodeList ) + + + try { + push.apply(arr = slice.call(preferredDoc.childNodes), preferredDoc.childNodes); // Support: Android<4.0 + // Detect silently failing push.apply + // eslint-disable-next-line no-unused-expressions + + arr[preferredDoc.childNodes.length].nodeType; + } catch (e) { + push = { + apply: arr.length ? // Leverage slice if possible + function (target, els) { + pushNative.apply(target, slice.call(els)); + } : // Support: IE<9 + // Otherwise append directly + function (target, els) { + var j = target.length, + i = 0; // Can't trust NodeList.length + + while (target[j++] = els[i++]) {} + + target.length = j - 1; + } + }; + } + + function Sizzle(selector, context, results, seed) { + var m, + i, + elem, + nid, + match, + groups, + newSelector, + newContext = context && context.ownerDocument, + // nodeType defaults to 9, since context defaults to document + nodeType = context ? context.nodeType : 9; + results = results || []; // Return early from calls with invalid selector or context + + if (typeof selector !== "string" || !selector || nodeType !== 1 && nodeType !== 9 && nodeType !== 11) { + return results; + } // Try to shortcut find operations (as opposed to filters) in HTML documents + + + if (!seed) { + setDocument(context); + context = context || document; + + if (documentIsHTML) { + // If the selector is sufficiently simple, try using a "get*By*" DOM method + // (excepting DocumentFragment context, where the methods don't exist) + if (nodeType !== 11 && (match = rquickExpr.exec(selector))) { + // ID selector + if (m = match[1]) { + // Document context + if (nodeType === 9) { + if (elem = context.getElementById(m)) { + // Support: IE, Opera, Webkit + // TODO: identify versions + // getElementById can match elements by name instead of ID + if (elem.id === m) { + results.push(elem); + return results; + } + } else { + return results; + } // Element context + + } else { + // Support: IE, Opera, Webkit + // TODO: identify versions + // getElementById can match elements by name instead of ID + if (newContext && (elem = newContext.getElementById(m)) && contains(context, elem) && elem.id === m) { + results.push(elem); + return results; + } + } // Type selector + + } else if (match[2]) { + push.apply(results, context.getElementsByTagName(selector)); + return results; // Class selector + } else if ((m = match[3]) && support.getElementsByClassName && context.getElementsByClassName) { + push.apply(results, context.getElementsByClassName(m)); + return results; + } + } // Take advantage of querySelectorAll + + + if (support.qsa && !nonnativeSelectorCache[selector + " "] && (!rbuggyQSA || !rbuggyQSA.test(selector)) && ( // Support: IE 8 only + // Exclude object elements + nodeType !== 1 || context.nodeName.toLowerCase() !== "object")) { + newSelector = selector; + newContext = context; // qSA considers elements outside a scoping root when evaluating child or + // descendant combinators, which is not what we want. + // In such cases, we work around the behavior by prefixing every selector in the + // list with an ID selector referencing the scope context. + // The technique has to be used as well when a leading combinator is used + // as such selectors are not recognized by querySelectorAll. + // Thanks to Andrew Dupont for this technique. + + if (nodeType === 1 && (rdescend.test(selector) || rcombinators.test(selector))) { + // Expand context for sibling selectors + newContext = rsibling.test(selector) && testContext(context.parentNode) || context; // We can use :scope instead of the ID hack if the browser + // supports it & if we're not changing the context. + + if (newContext !== context || !support.scope) { + // Capture the context ID, setting it first if necessary + if (nid = context.getAttribute("id")) { + nid = nid.replace(rcssescape, fcssescape); + } else { + context.setAttribute("id", nid = expando); + } + } // Prefix every selector in the list + + + groups = tokenize(selector); + i = groups.length; + + while (i--) { + groups[i] = (nid ? "#" + nid : ":scope") + " " + toSelector(groups[i]); + } + + newSelector = groups.join(","); + } + + try { + push.apply(results, newContext.querySelectorAll(newSelector)); + return results; + } catch (qsaError) { + nonnativeSelectorCache(selector, true); + } finally { + if (nid === expando) { + context.removeAttribute("id"); + } + } + } + } + } // All others + + + return select(selector.replace(rtrim, "$1"), context, results, seed); + } + /** + * Create key-value caches of limited size + * @returns {function(string, object)} Returns the Object data after storing it on itself with + * property name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength) + * deleting the oldest entry + */ + + + function createCache() { + var keys = []; + + function cache(key, value) { + // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) + if (keys.push(key + " ") > Expr.cacheLength) { + // Only keep the most recent entries + delete cache[keys.shift()]; + } + + return cache[key + " "] = value; + } + + return cache; + } + /** + * Mark a function for special use by Sizzle + * @param {Function} fn The function to mark + */ + + + function markFunction(fn) { + fn[expando] = true; + return fn; + } + /** + * Support testing using an element + * @param {Function} fn Passed the created element and returns a boolean result + */ + + + function assert(fn) { + var el = document.createElement("fieldset"); + + try { + return !!fn(el); + } catch (e) { + return false; + } finally { + // Remove from its parent by default + if (el.parentNode) { + el.parentNode.removeChild(el); + } // release memory in IE + + + el = null; + } + } + /** + * Adds the same handler for all of the specified attrs + * @param {String} attrs Pipe-separated list of attributes + * @param {Function} handler The method that will be applied + */ + + + function addHandle(attrs, handler) { + var arr = attrs.split("|"), + i = arr.length; + + while (i--) { + Expr.attrHandle[arr[i]] = handler; + } + } + /** + * Checks document order of two siblings + * @param {Element} a + * @param {Element} b + * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b + */ + + + function siblingCheck(a, b) { + var cur = b && a, + diff = cur && a.nodeType === 1 && b.nodeType === 1 && a.sourceIndex - b.sourceIndex; // Use IE sourceIndex if available on both nodes + + if (diff) { + return diff; + } // Check if b follows a + + + if (cur) { + while (cur = cur.nextSibling) { + if (cur === b) { + return -1; + } + } + } + + return a ? 1 : -1; + } + /** + * Returns a function to use in pseudos for input types + * @param {String} type + */ + + + function createInputPseudo(type) { + return function (elem) { + var name = elem.nodeName.toLowerCase(); + return name === "input" && elem.type === type; + }; + } + /** + * Returns a function to use in pseudos for buttons + * @param {String} type + */ + + + function createButtonPseudo(type) { + return function (elem) { + var name = elem.nodeName.toLowerCase(); + return (name === "input" || name === "button") && elem.type === type; + }; + } + /** + * Returns a function to use in pseudos for :enabled/:disabled + * @param {Boolean} disabled true for :disabled; false for :enabled + */ + + + function createDisabledPseudo(disabled) { + // Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable + return function (elem) { + // Only certain elements can match :enabled or :disabled + // https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled + // https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled + if ("form" in elem) { + // Check for inherited disabledness on relevant non-disabled elements: + // * listed form-associated elements in a disabled fieldset + // https://html.spec.whatwg.org/multipage/forms.html#category-listed + // https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled + // * option elements in a disabled optgroup + // https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled + // All such elements have a "form" property. + if (elem.parentNode && elem.disabled === false) { + // Option elements defer to a parent optgroup if present + if ("label" in elem) { + if ("label" in elem.parentNode) { + return elem.parentNode.disabled === disabled; + } else { + return elem.disabled === disabled; + } + } // Support: IE 6 - 11 + // Use the isDisabled shortcut property to check for disabled fieldset ancestors + + + return elem.isDisabled === disabled || // Where there is no isDisabled, check manually + + /* jshint -W018 */ + elem.isDisabled !== !disabled && inDisabledFieldset(elem) === disabled; + } + + return elem.disabled === disabled; // Try to winnow out elements that can't be disabled before trusting the disabled property. + // Some victims get caught in our net (label, legend, menu, track), but it shouldn't + // even exist on them, let alone have a boolean value. + } else if ("label" in elem) { + return elem.disabled === disabled; + } // Remaining elements are neither :enabled nor :disabled + + + return false; + }; + } + /** + * Returns a function to use in pseudos for positionals + * @param {Function} fn + */ + + + function createPositionalPseudo(fn) { + return markFunction(function (argument) { + argument = +argument; + return markFunction(function (seed, matches) { + var j, + matchIndexes = fn([], seed.length, argument), + i = matchIndexes.length; // Match elements found at the specified indexes + + while (i--) { + if (seed[j = matchIndexes[i]]) { + seed[j] = !(matches[j] = seed[j]); + } + } + }); + }); + } + /** + * Checks a node for validity as a Sizzle context + * @param {Element|Object=} context + * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value + */ + + + function testContext(context) { + return context && typeof context.getElementsByTagName !== "undefined" && context; + } // Expose support vars for convenience + + + support = Sizzle.support = {}; + /** + * Detects XML nodes + * @param {Element|Object} elem An element or a document + * @returns {Boolean} True iff elem is a non-HTML XML node + */ + + isXML = Sizzle.isXML = function (elem) { + var namespace = elem.namespaceURI, + docElem = (elem.ownerDocument || elem).documentElement; // Support: IE <=8 + // Assume HTML when documentElement doesn't yet exist, such as inside loading iframes + // https://bugs.jquery.com/ticket/4833 + + return !rhtml.test(namespace || docElem && docElem.nodeName || "HTML"); + }; + /** + * Sets document-related variables once based on the current document + * @param {Element|Object} [doc] An element or document object to use to set the document + * @returns {Object} Returns the current document + */ + + + setDocument = Sizzle.setDocument = function (node) { + var hasCompare, + subWindow, + doc = node ? node.ownerDocument || node : preferredDoc; // Return early if doc is invalid or already selected + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + + if (doc == document || doc.nodeType !== 9 || !doc.documentElement) { + return document; + } // Update global variables + + + document = doc; + docElem = document.documentElement; + documentIsHTML = !isXML(document); // Support: IE 9 - 11+, Edge 12 - 18+ + // Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936) + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + + if (preferredDoc != document && (subWindow = document.defaultView) && subWindow.top !== subWindow) { + // Support: IE 11, Edge + if (subWindow.addEventListener) { + subWindow.addEventListener("unload", unloadHandler, false); // Support: IE 9 - 10 only + } else if (subWindow.attachEvent) { + subWindow.attachEvent("onunload", unloadHandler); + } + } // Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only, + // Safari 4 - 5 only, Opera <=11.6 - 12.x only + // IE/Edge & older browsers don't support the :scope pseudo-class. + // Support: Safari 6.0 only + // Safari 6.0 supports :scope but it's an alias of :root there. + + + support.scope = assert(function (el) { + docElem.appendChild(el).appendChild(document.createElement("div")); + return typeof el.querySelectorAll !== "undefined" && !el.querySelectorAll(":scope fieldset div").length; + }); + /* Attributes + ---------------------------------------------------------------------- */ + // Support: IE<8 + // Verify that getAttribute really returns attributes and not properties + // (excepting IE8 booleans) + + support.attributes = assert(function (el) { + el.className = "i"; + return !el.getAttribute("className"); + }); + /* getElement(s)By* + ---------------------------------------------------------------------- */ + // Check if getElementsByTagName("*") returns only elements + + support.getElementsByTagName = assert(function (el) { + el.appendChild(document.createComment("")); + return !el.getElementsByTagName("*").length; + }); // Support: IE<9 + + support.getElementsByClassName = rnative.test(document.getElementsByClassName); // Support: IE<10 + // Check if getElementById returns elements by name + // The broken getElementById methods don't pick up programmatically-set names, + // so use a roundabout getElementsByName test + + support.getById = assert(function (el) { + docElem.appendChild(el).id = expando; + return !document.getElementsByName || !document.getElementsByName(expando).length; + }); // ID filter and find + + if (support.getById) { + Expr.filter["ID"] = function (id) { + var attrId = id.replace(runescape, funescape); + return function (elem) { + return elem.getAttribute("id") === attrId; + }; + }; + + Expr.find["ID"] = function (id, context) { + if (typeof context.getElementById !== "undefined" && documentIsHTML) { + var elem = context.getElementById(id); + return elem ? [elem] : []; + } + }; + } else { + Expr.filter["ID"] = function (id) { + var attrId = id.replace(runescape, funescape); + return function (elem) { + var node = typeof elem.getAttributeNode !== "undefined" && elem.getAttributeNode("id"); + return node && node.value === attrId; + }; + }; // Support: IE 6 - 7 only + // getElementById is not reliable as a find shortcut + + + Expr.find["ID"] = function (id, context) { + if (typeof context.getElementById !== "undefined" && documentIsHTML) { + var node, + i, + elems, + elem = context.getElementById(id); + + if (elem) { + // Verify the id attribute + node = elem.getAttributeNode("id"); + + if (node && node.value === id) { + return [elem]; + } // Fall back on getElementsByName + + + elems = context.getElementsByName(id); + i = 0; + + while (elem = elems[i++]) { + node = elem.getAttributeNode("id"); + + if (node && node.value === id) { + return [elem]; + } + } + } + + return []; + } + }; + } // Tag + + + Expr.find["TAG"] = support.getElementsByTagName ? function (tag, context) { + if (typeof context.getElementsByTagName !== "undefined") { + return context.getElementsByTagName(tag); // DocumentFragment nodes don't have gEBTN + } else if (support.qsa) { + return context.querySelectorAll(tag); + } + } : function (tag, context) { + var elem, + tmp = [], + i = 0, + // By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too + results = context.getElementsByTagName(tag); // Filter out possible comments + + if (tag === "*") { + while (elem = results[i++]) { + if (elem.nodeType === 1) { + tmp.push(elem); + } + } + + return tmp; + } + + return results; + }; // Class + + Expr.find["CLASS"] = support.getElementsByClassName && function (className, context) { + if (typeof context.getElementsByClassName !== "undefined" && documentIsHTML) { + return context.getElementsByClassName(className); + } + }; + /* QSA/matchesSelector + ---------------------------------------------------------------------- */ + // QSA and matchesSelector support + // matchesSelector(:active) reports false when true (IE9/Opera 11.5) + + + rbuggyMatches = []; // qSa(:focus) reports false when true (Chrome 21) + // We allow this because of a bug in IE8/9 that throws an error + // whenever `document.activeElement` is accessed on an iframe + // So, we allow :focus to pass through QSA all the time to avoid the IE error + // See https://bugs.jquery.com/ticket/13378 + + rbuggyQSA = []; + + if (support.qsa = rnative.test(document.querySelectorAll)) { + // Build QSA regex + // Regex strategy adopted from Diego Perini + assert(function (el) { + var input; // Select is set to empty string on purpose + // This is to test IE's treatment of not explicitly + // setting a boolean content attribute, + // since its presence should be enough + // https://bugs.jquery.com/ticket/12359 + + docElem.appendChild(el).innerHTML = "" + "" + ""; // Support: IE8, Opera 11-12.16 + // Nothing should be selected when empty strings follow ^= or $= or *= + // The test attribute must be unknown in Opera but "safe" for WinRT + // https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section + + if (el.querySelectorAll("[msallowcapture^='']").length) { + rbuggyQSA.push("[*^$]=" + whitespace + "*(?:''|\"\")"); + } // Support: IE8 + // Boolean attributes and "value" are not treated correctly + + + if (!el.querySelectorAll("[selected]").length) { + rbuggyQSA.push("\\[" + whitespace + "*(?:value|" + booleans + ")"); + } // Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+ + + + if (!el.querySelectorAll("[id~=" + expando + "-]").length) { + rbuggyQSA.push("~="); + } // Support: IE 11+, Edge 15 - 18+ + // IE 11/Edge don't find elements on a `[name='']` query in some cases. + // Adding a temporary attribute to the document before the selection works + // around the issue. + // Interestingly, IE 10 & older don't seem to have the issue. + + + input = document.createElement("input"); + input.setAttribute("name", ""); + el.appendChild(input); + + if (!el.querySelectorAll("[name='']").length) { + rbuggyQSA.push("\\[" + whitespace + "*name" + whitespace + "*=" + whitespace + "*(?:''|\"\")"); + } // Webkit/Opera - :checked should return selected option elements + // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked + // IE8 throws error here and will not see later tests + + + if (!el.querySelectorAll(":checked").length) { + rbuggyQSA.push(":checked"); + } // Support: Safari 8+, iOS 8+ + // https://bugs.webkit.org/show_bug.cgi?id=136851 + // In-page `selector#id sibling-combinator selector` fails + + + if (!el.querySelectorAll("a#" + expando + "+*").length) { + rbuggyQSA.push(".#.+[+~]"); + } // Support: Firefox <=3.6 - 5 only + // Old Firefox doesn't throw on a badly-escaped identifier. + + + el.querySelectorAll("\\\f"); + rbuggyQSA.push("[\\r\\n\\f]"); + }); + assert(function (el) { + el.innerHTML = "" + ""; // Support: Windows 8 Native Apps + // The type and name attributes are restricted during .innerHTML assignment + + var input = document.createElement("input"); + input.setAttribute("type", "hidden"); + el.appendChild(input).setAttribute("name", "D"); // Support: IE8 + // Enforce case-sensitivity of name attribute + + if (el.querySelectorAll("[name=d]").length) { + rbuggyQSA.push("name" + whitespace + "*[*^$|!~]?="); + } // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) + // IE8 throws error here and will not see later tests + + + if (el.querySelectorAll(":enabled").length !== 2) { + rbuggyQSA.push(":enabled", ":disabled"); + } // Support: IE9-11+ + // IE's :disabled selector does not pick up the children of disabled fieldsets + + + docElem.appendChild(el).disabled = true; + + if (el.querySelectorAll(":disabled").length !== 2) { + rbuggyQSA.push(":enabled", ":disabled"); + } // Support: Opera 10 - 11 only + // Opera 10-11 does not throw on post-comma invalid pseudos + + + el.querySelectorAll("*,:x"); + rbuggyQSA.push(",.*:"); + }); + } + + if (support.matchesSelector = rnative.test(matches = docElem.matches || docElem.webkitMatchesSelector || docElem.mozMatchesSelector || docElem.oMatchesSelector || docElem.msMatchesSelector)) { + assert(function (el) { + // Check to see if it's possible to do matchesSelector + // on a disconnected node (IE 9) + support.disconnectedMatch = matches.call(el, "*"); // This should fail with an exception + // Gecko does not error, returns false instead + + matches.call(el, "[s!='']:x"); + rbuggyMatches.push("!=", pseudos); + }); + } + + rbuggyQSA = rbuggyQSA.length && new RegExp(rbuggyQSA.join("|")); + rbuggyMatches = rbuggyMatches.length && new RegExp(rbuggyMatches.join("|")); + /* Contains + ---------------------------------------------------------------------- */ + + hasCompare = rnative.test(docElem.compareDocumentPosition); // Element contains another + // Purposefully self-exclusive + // As in, an element does not contain itself + + contains = hasCompare || rnative.test(docElem.contains) ? function (a, b) { + var adown = a.nodeType === 9 ? a.documentElement : a, + bup = b && b.parentNode; + return a === bup || !!(bup && bup.nodeType === 1 && (adown.contains ? adown.contains(bup) : a.compareDocumentPosition && a.compareDocumentPosition(bup) & 16)); + } : function (a, b) { + if (b) { + while (b = b.parentNode) { + if (b === a) { + return true; + } + } + } + + return false; + }; + /* Sorting + ---------------------------------------------------------------------- */ + // Document order sorting + + sortOrder = hasCompare ? function (a, b) { + // Flag for duplicate removal + if (a === b) { + hasDuplicate = true; + return 0; + } // Sort on method existence if only one input has compareDocumentPosition + + + var compare = !a.compareDocumentPosition - !b.compareDocumentPosition; + + if (compare) { + return compare; + } // Calculate position if both inputs belong to the same document + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + + + compare = (a.ownerDocument || a) == (b.ownerDocument || b) ? a.compareDocumentPosition(b) : // Otherwise we know they are disconnected + 1; // Disconnected nodes + + if (compare & 1 || !support.sortDetached && b.compareDocumentPosition(a) === compare) { + // Choose the first element that is related to our preferred document + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + if (a == document || a.ownerDocument == preferredDoc && contains(preferredDoc, a)) { + return -1; + } // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + + + if (b == document || b.ownerDocument == preferredDoc && contains(preferredDoc, b)) { + return 1; + } // Maintain original order + + + return sortInput ? indexOf(sortInput, a) - indexOf(sortInput, b) : 0; + } + + return compare & 4 ? -1 : 1; + } : function (a, b) { + // Exit early if the nodes are identical + if (a === b) { + hasDuplicate = true; + return 0; + } + + var cur, + i = 0, + aup = a.parentNode, + bup = b.parentNode, + ap = [a], + bp = [b]; // Parentless nodes are either documents or disconnected + + if (!aup || !bup) { + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + + /* eslint-disable eqeqeq */ + return a == document ? -1 : b == document ? 1 : + /* eslint-enable eqeqeq */ + aup ? -1 : bup ? 1 : sortInput ? indexOf(sortInput, a) - indexOf(sortInput, b) : 0; // If the nodes are siblings, we can do a quick check + } else if (aup === bup) { + return siblingCheck(a, b); + } // Otherwise we need full lists of their ancestors for comparison + + + cur = a; + + while (cur = cur.parentNode) { + ap.unshift(cur); + } + + cur = b; + + while (cur = cur.parentNode) { + bp.unshift(cur); + } // Walk down the tree looking for a discrepancy + + + while (ap[i] === bp[i]) { + i++; + } + + return i ? // Do a sibling check if the nodes have a common ancestor + siblingCheck(ap[i], bp[i]) : // Otherwise nodes in our document sort first + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + + /* eslint-disable eqeqeq */ + ap[i] == preferredDoc ? -1 : bp[i] == preferredDoc ? 1 : + /* eslint-enable eqeqeq */ + 0; + }; + return document; + }; + + Sizzle.matches = function (expr, elements) { + return Sizzle(expr, null, null, elements); + }; + + Sizzle.matchesSelector = function (elem, expr) { + setDocument(elem); + + if (support.matchesSelector && documentIsHTML && !nonnativeSelectorCache[expr + " "] && (!rbuggyMatches || !rbuggyMatches.test(expr)) && (!rbuggyQSA || !rbuggyQSA.test(expr))) { + try { + var ret = matches.call(elem, expr); // IE 9's matchesSelector returns false on disconnected nodes + + if (ret || support.disconnectedMatch || // As well, disconnected nodes are said to be in a document + // fragment in IE 9 + elem.document && elem.document.nodeType !== 11) { + return ret; + } + } catch (e) { + nonnativeSelectorCache(expr, true); + } + } + + return Sizzle(expr, document, null, [elem]).length > 0; + }; + + Sizzle.contains = function (context, elem) { + // Set document vars if needed + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + if ((context.ownerDocument || context) != document) { + setDocument(context); + } + + return contains(context, elem); + }; + + Sizzle.attr = function (elem, name) { + // Set document vars if needed + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + if ((elem.ownerDocument || elem) != document) { + setDocument(elem); + } + + var fn = Expr.attrHandle[name.toLowerCase()], + // Don't get fooled by Object.prototype properties (jQuery #13807) + val = fn && hasOwn.call(Expr.attrHandle, name.toLowerCase()) ? fn(elem, name, !documentIsHTML) : undefined; + return val !== undefined ? val : support.attributes || !documentIsHTML ? elem.getAttribute(name) : (val = elem.getAttributeNode(name)) && val.specified ? val.value : null; + }; + + Sizzle.escape = function (sel) { + return (sel + "").replace(rcssescape, fcssescape); + }; + + Sizzle.error = function (msg) { + throw new Error("Syntax error, unrecognized expression: " + msg); + }; + /** + * Document sorting and removing duplicates + * @param {ArrayLike} results + */ + + + Sizzle.uniqueSort = function (results) { + var elem, + duplicates = [], + j = 0, + i = 0; // Unless we *know* we can detect duplicates, assume their presence + + hasDuplicate = !support.detectDuplicates; + sortInput = !support.sortStable && results.slice(0); + results.sort(sortOrder); + + if (hasDuplicate) { + while (elem = results[i++]) { + if (elem === results[i]) { + j = duplicates.push(i); + } + } + + while (j--) { + results.splice(duplicates[j], 1); + } + } // Clear input after sorting to release objects + // See https://github.com/jquery/sizzle/pull/225 + + + sortInput = null; + return results; + }; + /** + * Utility function for retrieving the text value of an array of DOM nodes + * @param {Array|Element} elem + */ + + + getText = Sizzle.getText = function (elem) { + var node, + ret = "", + i = 0, + nodeType = elem.nodeType; + + if (!nodeType) { + // If no nodeType, this is expected to be an array + while (node = elem[i++]) { + // Do not traverse comment nodes + ret += getText(node); + } + } else if (nodeType === 1 || nodeType === 9 || nodeType === 11) { + // Use textContent for elements + // innerText usage removed for consistency of new lines (jQuery #11153) + if (typeof elem.textContent === "string") { + return elem.textContent; + } else { + // Traverse its children + for (elem = elem.firstChild; elem; elem = elem.nextSibling) { + ret += getText(elem); + } + } + } else if (nodeType === 3 || nodeType === 4) { + return elem.nodeValue; + } // Do not include comment or processing instruction nodes + + + return ret; + }; + + Expr = Sizzle.selectors = { + // Can be adjusted by the user + cacheLength: 50, + createPseudo: markFunction, + match: matchExpr, + attrHandle: {}, + find: {}, + relative: { + ">": { + dir: "parentNode", + first: true + }, + " ": { + dir: "parentNode" + }, + "+": { + dir: "previousSibling", + first: true + }, + "~": { + dir: "previousSibling" + } + }, + preFilter: { + "ATTR": function ATTR(match) { + match[1] = match[1].replace(runescape, funescape); // Move the given value to match[3] whether quoted or unquoted + + match[3] = (match[3] || match[4] || match[5] || "").replace(runescape, funescape); + + if (match[2] === "~=") { + match[3] = " " + match[3] + " "; + } + + return match.slice(0, 4); + }, + "CHILD": function CHILD(match) { + /* matches from matchExpr["CHILD"] + 1 type (only|nth|...) + 2 what (child|of-type) + 3 argument (even|odd|\d*|\d*n([+-]\d+)?|...) + 4 xn-component of xn+y argument ([+-]?\d*n|) + 5 sign of xn-component + 6 x of xn-component + 7 sign of y-component + 8 y of y-component + */ + match[1] = match[1].toLowerCase(); + + if (match[1].slice(0, 3) === "nth") { + // nth-* requires argument + if (!match[3]) { + Sizzle.error(match[0]); + } // numeric x and y parameters for Expr.filter.CHILD + // remember that false/true cast respectively to 0/1 + + + match[4] = +(match[4] ? match[5] + (match[6] || 1) : 2 * (match[3] === "even" || match[3] === "odd")); + match[5] = +(match[7] + match[8] || match[3] === "odd"); // other types prohibit arguments + } else if (match[3]) { + Sizzle.error(match[0]); + } + + return match; + }, + "PSEUDO": function PSEUDO(match) { + var excess, + unquoted = !match[6] && match[2]; + + if (matchExpr["CHILD"].test(match[0])) { + return null; + } // Accept quoted arguments as-is + + + if (match[3]) { + match[2] = match[4] || match[5] || ""; // Strip excess characters from unquoted arguments + } else if (unquoted && rpseudo.test(unquoted) && ( // Get excess from tokenize (recursively) + excess = tokenize(unquoted, true)) && ( // advance to the next closing parenthesis + excess = unquoted.indexOf(")", unquoted.length - excess) - unquoted.length)) { + // excess is a negative index + match[0] = match[0].slice(0, excess); + match[2] = unquoted.slice(0, excess); + } // Return only captures needed by the pseudo filter method (type and argument) + + + return match.slice(0, 3); + } + }, + filter: { + "TAG": function TAG(nodeNameSelector) { + var nodeName = nodeNameSelector.replace(runescape, funescape).toLowerCase(); + return nodeNameSelector === "*" ? function () { + return true; + } : function (elem) { + return elem.nodeName && elem.nodeName.toLowerCase() === nodeName; + }; + }, + "CLASS": function CLASS(className) { + var pattern = classCache[className + " "]; + return pattern || (pattern = new RegExp("(^|" + whitespace + ")" + className + "(" + whitespace + "|$)")) && classCache(className, function (elem) { + return pattern.test(typeof elem.className === "string" && elem.className || typeof elem.getAttribute !== "undefined" && elem.getAttribute("class") || ""); + }); + }, + "ATTR": function ATTR(name, operator, check) { + return function (elem) { + var result = Sizzle.attr(elem, name); + + if (result == null) { + return operator === "!="; + } + + if (!operator) { + return true; + } + + result += ""; + /* eslint-disable max-len */ + + return operator === "=" ? result === check : operator === "!=" ? result !== check : operator === "^=" ? check && result.indexOf(check) === 0 : operator === "*=" ? check && result.indexOf(check) > -1 : operator === "$=" ? check && result.slice(-check.length) === check : operator === "~=" ? (" " + result.replace(rwhitespace, " ") + " ").indexOf(check) > -1 : operator === "|=" ? result === check || result.slice(0, check.length + 1) === check + "-" : false; + /* eslint-enable max-len */ + }; + }, + "CHILD": function CHILD(type, what, _argument, first, last) { + var simple = type.slice(0, 3) !== "nth", + forward = type.slice(-4) !== "last", + ofType = what === "of-type"; + return first === 1 && last === 0 ? // Shortcut for :nth-*(n) + function (elem) { + return !!elem.parentNode; + } : function (elem, _context, xml) { + var cache, + uniqueCache, + outerCache, + node, + nodeIndex, + start, + dir = simple !== forward ? "nextSibling" : "previousSibling", + parent = elem.parentNode, + name = ofType && elem.nodeName.toLowerCase(), + useCache = !xml && !ofType, + diff = false; + + if (parent) { + // :(first|last|only)-(child|of-type) + if (simple) { + while (dir) { + node = elem; + + while (node = node[dir]) { + if (ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1) { + return false; + } + } // Reverse direction for :only-* (if we haven't yet done so) + + + start = dir = type === "only" && !start && "nextSibling"; + } + + return true; + } + + start = [forward ? parent.firstChild : parent.lastChild]; // non-xml :nth-child(...) stores cache data on `parent` + + if (forward && useCache) { + // Seek `elem` from a previously-cached index + // ...in a gzip-friendly way + node = parent; + outerCache = node[expando] || (node[expando] = {}); // Support: IE <9 only + // Defend against cloned attroperties (jQuery gh-1709) + + uniqueCache = outerCache[node.uniqueID] || (outerCache[node.uniqueID] = {}); + cache = uniqueCache[type] || []; + nodeIndex = cache[0] === dirruns && cache[1]; + diff = nodeIndex && cache[2]; + node = nodeIndex && parent.childNodes[nodeIndex]; + + while (node = ++nodeIndex && node && node[dir] || ( // Fallback to seeking `elem` from the start + diff = nodeIndex = 0) || start.pop()) { + // When found, cache indexes on `parent` and break + if (node.nodeType === 1 && ++diff && node === elem) { + uniqueCache[type] = [dirruns, nodeIndex, diff]; + break; + } + } + } else { + // Use previously-cached element index if available + if (useCache) { + // ...in a gzip-friendly way + node = elem; + outerCache = node[expando] || (node[expando] = {}); // Support: IE <9 only + // Defend against cloned attroperties (jQuery gh-1709) + + uniqueCache = outerCache[node.uniqueID] || (outerCache[node.uniqueID] = {}); + cache = uniqueCache[type] || []; + nodeIndex = cache[0] === dirruns && cache[1]; + diff = nodeIndex; + } // xml :nth-child(...) + // or :nth-last-child(...) or :nth(-last)?-of-type(...) + + + if (diff === false) { + // Use the same loop as above to seek `elem` from the start + while (node = ++nodeIndex && node && node[dir] || (diff = nodeIndex = 0) || start.pop()) { + if ((ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1) && ++diff) { + // Cache the index of each encountered element + if (useCache) { + outerCache = node[expando] || (node[expando] = {}); // Support: IE <9 only + // Defend against cloned attroperties (jQuery gh-1709) + + uniqueCache = outerCache[node.uniqueID] || (outerCache[node.uniqueID] = {}); + uniqueCache[type] = [dirruns, diff]; + } + + if (node === elem) { + break; + } + } + } + } + } // Incorporate the offset, then check against cycle size + + + diff -= last; + return diff === first || diff % first === 0 && diff / first >= 0; + } + }; + }, + "PSEUDO": function PSEUDO(pseudo, argument) { + // pseudo-class names are case-insensitive + // http://www.w3.org/TR/selectors/#pseudo-classes + // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters + // Remember that setFilters inherits from pseudos + var args, + fn = Expr.pseudos[pseudo] || Expr.setFilters[pseudo.toLowerCase()] || Sizzle.error("unsupported pseudo: " + pseudo); // The user may use createPseudo to indicate that + // arguments are needed to create the filter function + // just as Sizzle does + + if (fn[expando]) { + return fn(argument); + } // But maintain support for old signatures + + + if (fn.length > 1) { + args = [pseudo, pseudo, "", argument]; + return Expr.setFilters.hasOwnProperty(pseudo.toLowerCase()) ? markFunction(function (seed, matches) { + var idx, + matched = fn(seed, argument), + i = matched.length; + + while (i--) { + idx = indexOf(seed, matched[i]); + seed[idx] = !(matches[idx] = matched[i]); + } + }) : function (elem) { + return fn(elem, 0, args); + }; + } + + return fn; + } + }, + pseudos: { + // Potentially complex pseudos + "not": markFunction(function (selector) { + // Trim the selector passed to compile + // to avoid treating leading and trailing + // spaces as combinators + var input = [], + results = [], + matcher = compile(selector.replace(rtrim, "$1")); + return matcher[expando] ? markFunction(function (seed, matches, _context, xml) { + var elem, + unmatched = matcher(seed, null, xml, []), + i = seed.length; // Match elements unmatched by `matcher` + + while (i--) { + if (elem = unmatched[i]) { + seed[i] = !(matches[i] = elem); + } + } + }) : function (elem, _context, xml) { + input[0] = elem; + matcher(input, null, xml, results); // Don't keep the element (issue #299) + + input[0] = null; + return !results.pop(); + }; + }), + "has": markFunction(function (selector) { + return function (elem) { + return Sizzle(selector, elem).length > 0; + }; + }), + "contains": markFunction(function (text) { + text = text.replace(runescape, funescape); + return function (elem) { + return (elem.textContent || getText(elem)).indexOf(text) > -1; + }; + }), + // "Whether an element is represented by a :lang() selector + // is based solely on the element's language value + // being equal to the identifier C, + // or beginning with the identifier C immediately followed by "-". + // The matching of C against the element's language value is performed case-insensitively. + // The identifier C does not have to be a valid language name." + // http://www.w3.org/TR/selectors/#lang-pseudo + "lang": markFunction(function (lang) { + // lang value must be a valid identifier + if (!ridentifier.test(lang || "")) { + Sizzle.error("unsupported lang: " + lang); + } + + lang = lang.replace(runescape, funescape).toLowerCase(); + return function (elem) { + var elemLang; + + do { + if (elemLang = documentIsHTML ? elem.lang : elem.getAttribute("xml:lang") || elem.getAttribute("lang")) { + elemLang = elemLang.toLowerCase(); + return elemLang === lang || elemLang.indexOf(lang + "-") === 0; + } + } while ((elem = elem.parentNode) && elem.nodeType === 1); + + return false; + }; + }), + // Miscellaneous + "target": function target(elem) { + var hash = window.location && window.location.hash; + return hash && hash.slice(1) === elem.id; + }, + "root": function root(elem) { + return elem === docElem; + }, + "focus": function focus(elem) { + return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); + }, + // Boolean properties + "enabled": createDisabledPseudo(false), + "disabled": createDisabledPseudo(true), + "checked": function checked(elem) { + // In CSS3, :checked should return both checked and selected elements + // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked + var nodeName = elem.nodeName.toLowerCase(); + return nodeName === "input" && !!elem.checked || nodeName === "option" && !!elem.selected; + }, + "selected": function selected(elem) { + // Accessing this property makes selected-by-default + // options in Safari work properly + if (elem.parentNode) { + // eslint-disable-next-line no-unused-expressions + elem.parentNode.selectedIndex; + } + + return elem.selected === true; + }, + // Contents + "empty": function empty(elem) { + // http://www.w3.org/TR/selectors/#empty-pseudo + // :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5), + // but not by others (comment: 8; processing instruction: 7; etc.) + // nodeType < 6 works because attributes (2) do not appear as children + for (elem = elem.firstChild; elem; elem = elem.nextSibling) { + if (elem.nodeType < 6) { + return false; + } + } + + return true; + }, + "parent": function parent(elem) { + return !Expr.pseudos["empty"](elem); + }, + // Element/input types + "header": function header(elem) { + return rheader.test(elem.nodeName); + }, + "input": function input(elem) { + return rinputs.test(elem.nodeName); + }, + "button": function button(elem) { + var name = elem.nodeName.toLowerCase(); + return name === "input" && elem.type === "button" || name === "button"; + }, + "text": function text(elem) { + var attr; + return elem.nodeName.toLowerCase() === "input" && elem.type === "text" && ( // Support: IE<8 + // New HTML5 attribute values (e.g., "search") appear with elem.type === "text" + (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === "text"); + }, + // Position-in-collection + "first": createPositionalPseudo(function () { + return [0]; + }), + "last": createPositionalPseudo(function (_matchIndexes, length) { + return [length - 1]; + }), + "eq": createPositionalPseudo(function (_matchIndexes, length, argument) { + return [argument < 0 ? argument + length : argument]; + }), + "even": createPositionalPseudo(function (matchIndexes, length) { + var i = 0; + + for (; i < length; i += 2) { + matchIndexes.push(i); + } + + return matchIndexes; + }), + "odd": createPositionalPseudo(function (matchIndexes, length) { + var i = 1; + + for (; i < length; i += 2) { + matchIndexes.push(i); + } + + return matchIndexes; + }), + "lt": createPositionalPseudo(function (matchIndexes, length, argument) { + var i = argument < 0 ? argument + length : argument > length ? length : argument; + + for (; --i >= 0;) { + matchIndexes.push(i); + } + + return matchIndexes; + }), + "gt": createPositionalPseudo(function (matchIndexes, length, argument) { + var i = argument < 0 ? argument + length : argument; + + for (; ++i < length;) { + matchIndexes.push(i); + } + + return matchIndexes; + }) + } + }; + Expr.pseudos["nth"] = Expr.pseudos["eq"]; // Add button/input type pseudos + + for (i in { + radio: true, + checkbox: true, + file: true, + password: true, + image: true + }) { + Expr.pseudos[i] = createInputPseudo(i); + } + + for (i in { + submit: true, + reset: true + }) { + Expr.pseudos[i] = createButtonPseudo(i); + } // Easy API for creating new setFilters + + + function setFilters() {} + + setFilters.prototype = Expr.filters = Expr.pseudos; + Expr.setFilters = new setFilters(); + + tokenize = Sizzle.tokenize = function (selector, parseOnly) { + var matched, + match, + tokens, + type, + soFar, + groups, + preFilters, + cached = tokenCache[selector + " "]; + + if (cached) { + return parseOnly ? 0 : cached.slice(0); + } + + soFar = selector; + groups = []; + preFilters = Expr.preFilter; + + while (soFar) { + // Comma and first run + if (!matched || (match = rcomma.exec(soFar))) { + if (match) { + // Don't consume trailing commas as valid + soFar = soFar.slice(match[0].length) || soFar; + } + + groups.push(tokens = []); + } + + matched = false; // Combinators + + if (match = rcombinators.exec(soFar)) { + matched = match.shift(); + tokens.push({ + value: matched, + // Cast descendant combinators to space + type: match[0].replace(rtrim, " ") + }); + soFar = soFar.slice(matched.length); + } // Filters + + + for (type in Expr.filter) { + if ((match = matchExpr[type].exec(soFar)) && (!preFilters[type] || (match = preFilters[type](match)))) { + matched = match.shift(); + tokens.push({ + value: matched, + type: type, + matches: match + }); + soFar = soFar.slice(matched.length); + } + } + + if (!matched) { + break; + } + } // Return the length of the invalid excess + // if we're just parsing + // Otherwise, throw an error or return tokens + + + return parseOnly ? soFar.length : soFar ? Sizzle.error(selector) : // Cache the tokens + tokenCache(selector, groups).slice(0); + }; + + function toSelector(tokens) { + var i = 0, + len = tokens.length, + selector = ""; + + for (; i < len; i++) { + selector += tokens[i].value; + } + + return selector; + } + + function addCombinator(matcher, combinator, base) { + var dir = combinator.dir, + skip = combinator.next, + key = skip || dir, + checkNonElements = base && key === "parentNode", + doneName = done++; + return combinator.first ? // Check against closest ancestor/preceding element + function (elem, context, xml) { + while (elem = elem[dir]) { + if (elem.nodeType === 1 || checkNonElements) { + return matcher(elem, context, xml); + } + } + + return false; + } : // Check against all ancestor/preceding elements + function (elem, context, xml) { + var oldCache, + uniqueCache, + outerCache, + newCache = [dirruns, doneName]; // We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching + + if (xml) { + while (elem = elem[dir]) { + if (elem.nodeType === 1 || checkNonElements) { + if (matcher(elem, context, xml)) { + return true; + } + } + } + } else { + while (elem = elem[dir]) { + if (elem.nodeType === 1 || checkNonElements) { + outerCache = elem[expando] || (elem[expando] = {}); // Support: IE <9 only + // Defend against cloned attroperties (jQuery gh-1709) + + uniqueCache = outerCache[elem.uniqueID] || (outerCache[elem.uniqueID] = {}); + + if (skip && skip === elem.nodeName.toLowerCase()) { + elem = elem[dir] || elem; + } else if ((oldCache = uniqueCache[key]) && oldCache[0] === dirruns && oldCache[1] === doneName) { + // Assign to newCache so results back-propagate to previous elements + return newCache[2] = oldCache[2]; + } else { + // Reuse newcache so results back-propagate to previous elements + uniqueCache[key] = newCache; // A match means we're done; a fail means we have to keep checking + + if (newCache[2] = matcher(elem, context, xml)) { + return true; + } + } + } + } + } + + return false; + }; + } + + function elementMatcher(matchers) { + return matchers.length > 1 ? function (elem, context, xml) { + var i = matchers.length; + + while (i--) { + if (!matchers[i](elem, context, xml)) { + return false; + } + } + + return true; + } : matchers[0]; + } + + function multipleContexts(selector, contexts, results) { + var i = 0, + len = contexts.length; + + for (; i < len; i++) { + Sizzle(selector, contexts[i], results); + } + + return results; + } + + function condense(unmatched, map, filter, context, xml) { + var elem, + newUnmatched = [], + i = 0, + len = unmatched.length, + mapped = map != null; + + for (; i < len; i++) { + if (elem = unmatched[i]) { + if (!filter || filter(elem, context, xml)) { + newUnmatched.push(elem); + + if (mapped) { + map.push(i); + } + } + } + } + + return newUnmatched; + } + + function setMatcher(preFilter, selector, matcher, postFilter, postFinder, postSelector) { + if (postFilter && !postFilter[expando]) { + postFilter = setMatcher(postFilter); + } + + if (postFinder && !postFinder[expando]) { + postFinder = setMatcher(postFinder, postSelector); + } + + return markFunction(function (seed, results, context, xml) { + var temp, + i, + elem, + preMap = [], + postMap = [], + preexisting = results.length, + // Get initial elements from seed or context + elems = seed || multipleContexts(selector || "*", context.nodeType ? [context] : context, []), + // Prefilter to get matcher input, preserving a map for seed-results synchronization + matcherIn = preFilter && (seed || !selector) ? condense(elems, preMap, preFilter, context, xml) : elems, + matcherOut = matcher ? // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, + postFinder || (seed ? preFilter : preexisting || postFilter) ? // ...intermediate processing is necessary + [] : // ...otherwise use results directly + results : matcherIn; // Find primary matches + + if (matcher) { + matcher(matcherIn, matcherOut, context, xml); + } // Apply postFilter + + + if (postFilter) { + temp = condense(matcherOut, postMap); + postFilter(temp, [], context, xml); // Un-match failing elements by moving them back to matcherIn + + i = temp.length; + + while (i--) { + if (elem = temp[i]) { + matcherOut[postMap[i]] = !(matcherIn[postMap[i]] = elem); + } + } + } + + if (seed) { + if (postFinder || preFilter) { + if (postFinder) { + // Get the final matcherOut by condensing this intermediate into postFinder contexts + temp = []; + i = matcherOut.length; + + while (i--) { + if (elem = matcherOut[i]) { + // Restore matcherIn since elem is not yet a final match + temp.push(matcherIn[i] = elem); + } + } + + postFinder(null, matcherOut = [], temp, xml); + } // Move matched elements from seed to results to keep them synchronized + + + i = matcherOut.length; + + while (i--) { + if ((elem = matcherOut[i]) && (temp = postFinder ? indexOf(seed, elem) : preMap[i]) > -1) { + seed[temp] = !(results[temp] = elem); + } + } + } // Add elements to results, through postFinder if defined + + } else { + matcherOut = condense(matcherOut === results ? matcherOut.splice(preexisting, matcherOut.length) : matcherOut); + + if (postFinder) { + postFinder(null, results, matcherOut, xml); + } else { + push.apply(results, matcherOut); + } + } + }); + } + + function matcherFromTokens(tokens) { + var checkContext, + matcher, + j, + len = tokens.length, + leadingRelative = Expr.relative[tokens[0].type], + implicitRelative = leadingRelative || Expr.relative[" "], + i = leadingRelative ? 1 : 0, + // The foundational matcher ensures that elements are reachable from top-level context(s) + matchContext = addCombinator(function (elem) { + return elem === checkContext; + }, implicitRelative, true), + matchAnyContext = addCombinator(function (elem) { + return indexOf(checkContext, elem) > -1; + }, implicitRelative, true), + matchers = [function (elem, context, xml) { + var ret = !leadingRelative && (xml || context !== outermostContext) || ((checkContext = context).nodeType ? matchContext(elem, context, xml) : matchAnyContext(elem, context, xml)); // Avoid hanging onto element (issue #299) + + checkContext = null; + return ret; + }]; + + for (; i < len; i++) { + if (matcher = Expr.relative[tokens[i].type]) { + matchers = [addCombinator(elementMatcher(matchers), matcher)]; + } else { + matcher = Expr.filter[tokens[i].type].apply(null, tokens[i].matches); // Return special upon seeing a positional matcher + + if (matcher[expando]) { + // Find the next relative operator (if any) for proper handling + j = ++i; + + for (; j < len; j++) { + if (Expr.relative[tokens[j].type]) { + break; + } + } + + return setMatcher(i > 1 && elementMatcher(matchers), i > 1 && toSelector( // If the preceding token was a descendant combinator, insert an implicit any-element `*` + tokens.slice(0, i - 1).concat({ + value: tokens[i - 2].type === " " ? "*" : "" + })).replace(rtrim, "$1"), matcher, i < j && matcherFromTokens(tokens.slice(i, j)), j < len && matcherFromTokens(tokens = tokens.slice(j)), j < len && toSelector(tokens)); + } + + matchers.push(matcher); + } + } + + return elementMatcher(matchers); + } + + function matcherFromGroupMatchers(elementMatchers, setMatchers) { + var bySet = setMatchers.length > 0, + byElement = elementMatchers.length > 0, + superMatcher = function superMatcher(seed, context, xml, results, outermost) { + var elem, + j, + matcher, + matchedCount = 0, + i = "0", + unmatched = seed && [], + setMatched = [], + contextBackup = outermostContext, + // We must always have either seed elements or outermost context + elems = seed || byElement && Expr.find["TAG"]("*", outermost), + // Use integer dirruns iff this is the outermost matcher + dirrunsUnique = dirruns += contextBackup == null ? 1 : Math.random() || 0.1, + len = elems.length; + + if (outermost) { + // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + outermostContext = context == document || context || outermost; + } // Add elements passing elementMatchers directly to results + // Support: IE<9, Safari + // Tolerate NodeList properties (IE: "length"; Safari: ) matching elements by id + + + for (; i !== len && (elem = elems[i]) != null; i++) { + if (byElement && elem) { + j = 0; // Support: IE 11+, Edge 17 - 18+ + // IE/Edge sometimes throw a "Permission denied" error when strict-comparing + // two documents; shallow comparisons work. + // eslint-disable-next-line eqeqeq + + if (!context && elem.ownerDocument != document) { + setDocument(elem); + xml = !documentIsHTML; + } + + while (matcher = elementMatchers[j++]) { + if (matcher(elem, context || document, xml)) { + results.push(elem); + break; + } + } + + if (outermost) { + dirruns = dirrunsUnique; + } + } // Track unmatched elements for set filters + + + if (bySet) { + // They will have gone through all possible matchers + if (elem = !matcher && elem) { + matchedCount--; + } // Lengthen the array for every element, matched or not + + + if (seed) { + unmatched.push(elem); + } + } + } // `i` is now the count of elements visited above, and adding it to `matchedCount` + // makes the latter nonnegative. + + + matchedCount += i; // Apply set filters to unmatched elements + // NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount` + // equals `i`), unless we didn't visit _any_ elements in the above loop because we have + // no element matchers and no seed. + // Incrementing an initially-string "0" `i` allows `i` to remain a string only in that + // case, which will result in a "00" `matchedCount` that differs from `i` but is also + // numerically zero. + + if (bySet && i !== matchedCount) { + j = 0; + + while (matcher = setMatchers[j++]) { + matcher(unmatched, setMatched, context, xml); + } + + if (seed) { + // Reintegrate element matches to eliminate the need for sorting + if (matchedCount > 0) { + while (i--) { + if (!(unmatched[i] || setMatched[i])) { + setMatched[i] = pop.call(results); + } + } + } // Discard index placeholder values to get only actual matches + + + setMatched = condense(setMatched); + } // Add matches to results + + + push.apply(results, setMatched); // Seedless set matches succeeding multiple successful matchers stipulate sorting + + if (outermost && !seed && setMatched.length > 0 && matchedCount + setMatchers.length > 1) { + Sizzle.uniqueSort(results); + } + } // Override manipulation of globals by nested matchers + + + if (outermost) { + dirruns = dirrunsUnique; + outermostContext = contextBackup; + } + + return unmatched; + }; + + return bySet ? markFunction(superMatcher) : superMatcher; + } + + compile = Sizzle.compile = function (selector, match + /* Internal Use Only */ + ) { + var i, + setMatchers = [], + elementMatchers = [], + cached = compilerCache[selector + " "]; + + if (!cached) { + // Generate a function of recursive functions that can be used to check each element + if (!match) { + match = tokenize(selector); + } + + i = match.length; + + while (i--) { + cached = matcherFromTokens(match[i]); + + if (cached[expando]) { + setMatchers.push(cached); + } else { + elementMatchers.push(cached); + } + } // Cache the compiled function + + + cached = compilerCache(selector, matcherFromGroupMatchers(elementMatchers, setMatchers)); // Save selector and tokenization + + cached.selector = selector; + } + + return cached; + }; + /** + * A low-level selection function that works with Sizzle's compiled + * selector functions + * @param {String|Function} selector A selector or a pre-compiled + * selector function built with Sizzle.compile + * @param {Element} context + * @param {Array} [results] + * @param {Array} [seed] A set of elements to match against + */ + + + select = Sizzle.select = function (selector, context, results, seed) { + var i, + tokens, + token, + type, + find, + compiled = typeof selector === "function" && selector, + match = !seed && tokenize(selector = compiled.selector || selector); + results = results || []; // Try to minimize operations if there is only one selector in the list and no seed + // (the latter of which guarantees us context) + + if (match.length === 1) { + // Reduce context if the leading compound selector is an ID + tokens = match[0] = match[0].slice(0); + + if (tokens.length > 2 && (token = tokens[0]).type === "ID" && context.nodeType === 9 && documentIsHTML && Expr.relative[tokens[1].type]) { + context = (Expr.find["ID"](token.matches[0].replace(runescape, funescape), context) || [])[0]; + + if (!context) { + return results; // Precompiled matchers will still verify ancestry, so step up a level + } else if (compiled) { + context = context.parentNode; + } + + selector = selector.slice(tokens.shift().value.length); + } // Fetch a seed set for right-to-left matching + + + i = matchExpr["needsContext"].test(selector) ? 0 : tokens.length; + + while (i--) { + token = tokens[i]; // Abort if we hit a combinator + + if (Expr.relative[type = token.type]) { + break; + } + + if (find = Expr.find[type]) { + // Search, expanding context for leading sibling combinators + if (seed = find(token.matches[0].replace(runescape, funescape), rsibling.test(tokens[0].type) && testContext(context.parentNode) || context)) { + // If seed is empty or no tokens remain, we can return early + tokens.splice(i, 1); + selector = seed.length && toSelector(tokens); + + if (!selector) { + push.apply(results, seed); + return results; + } + + break; + } + } + } + } // Compile and execute a filtering function if one is not provided + // Provide `match` to avoid retokenization if we modified the selector above + + + (compiled || compile(selector, match))(seed, context, !documentIsHTML, results, !context || rsibling.test(selector) && testContext(context.parentNode) || context); + return results; + }; // One-time assignments + // Sort stability + + + support.sortStable = expando.split("").sort(sortOrder).join("") === expando; // Support: Chrome 14-35+ + // Always assume duplicates if they aren't passed to the comparison function + + support.detectDuplicates = !!hasDuplicate; // Initialize against the default document + + setDocument(); // Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27) + // Detached nodes confoundingly follow *each other* + + support.sortDetached = assert(function (el) { + // Should return 1, but returns 4 (following) + return el.compareDocumentPosition(document.createElement("fieldset")) & 1; + }); // Support: IE<8 + // Prevent attribute/property "interpolation" + // https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx + + if (!assert(function (el) { + el.innerHTML = ""; + return el.firstChild.getAttribute("href") === "#"; + })) { + addHandle("type|href|height|width", function (elem, name, isXML) { + if (!isXML) { + return elem.getAttribute(name, name.toLowerCase() === "type" ? 1 : 2); + } + }); + } // Support: IE<9 + // Use defaultValue in place of getAttribute("value") + + + if (!support.attributes || !assert(function (el) { + el.innerHTML = ""; + el.firstChild.setAttribute("value", ""); + return el.firstChild.getAttribute("value") === ""; + })) { + addHandle("value", function (elem, _name, isXML) { + if (!isXML && elem.nodeName.toLowerCase() === "input") { + return elem.defaultValue; + } + }); + } // Support: IE<9 + // Use getAttributeNode to fetch booleans when getAttribute lies + + + if (!assert(function (el) { + return el.getAttribute("disabled") == null; + })) { + addHandle(booleans, function (elem, name, isXML) { + var val; + + if (!isXML) { + return elem[name] === true ? name.toLowerCase() : (val = elem.getAttributeNode(name)) && val.specified ? val.value : null; + } + }); + } + + return Sizzle; + }(window); + + jQuery.find = Sizzle; + jQuery.expr = Sizzle.selectors; // Deprecated + + jQuery.expr[":"] = jQuery.expr.pseudos; + jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort; + jQuery.text = Sizzle.getText; + jQuery.isXMLDoc = Sizzle.isXML; + jQuery.contains = Sizzle.contains; + jQuery.escapeSelector = Sizzle.escape; + + var dir = function dir(elem, _dir, until) { + var matched = [], + truncate = until !== undefined; + + while ((elem = elem[_dir]) && elem.nodeType !== 9) { + if (elem.nodeType === 1) { + if (truncate && jQuery(elem).is(until)) { + break; + } + + matched.push(elem); + } + } + + return matched; + }; + + var _siblings = function siblings(n, elem) { + var matched = []; + + for (; n; n = n.nextSibling) { + if (n.nodeType === 1 && n !== elem) { + matched.push(n); + } + } + + return matched; + }; + + var rneedsContext = jQuery.expr.match.needsContext; + + function nodeName(elem, name) { + return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); + } + + ; + var rsingleTag = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i; // Implement the identical functionality for filter and not + + function winnow(elements, qualifier, not) { + if (isFunction(qualifier)) { + return jQuery.grep(elements, function (elem, i) { + return !!qualifier.call(elem, i, elem) !== not; + }); + } // Single element + + + if (qualifier.nodeType) { + return jQuery.grep(elements, function (elem) { + return elem === qualifier !== not; + }); + } // Arraylike of elements (jQuery, arguments, Array) + + + if (typeof qualifier !== "string") { + return jQuery.grep(elements, function (elem) { + return indexOf.call(qualifier, elem) > -1 !== not; + }); + } // Filtered directly for both simple and complex selectors + + + return jQuery.filter(qualifier, elements, not); + } + + jQuery.filter = function (expr, elems, not) { + var elem = elems[0]; + + if (not) { + expr = ":not(" + expr + ")"; + } + + if (elems.length === 1 && elem.nodeType === 1) { + return jQuery.find.matchesSelector(elem, expr) ? [elem] : []; + } + + return jQuery.find.matches(expr, jQuery.grep(elems, function (elem) { + return elem.nodeType === 1; + })); + }; + + jQuery.fn.extend({ + find: function find(selector) { + var i, + ret, + len = this.length, + self = this; + + if (typeof selector !== "string") { + return this.pushStack(jQuery(selector).filter(function () { + for (i = 0; i < len; i++) { + if (jQuery.contains(self[i], this)) { + return true; + } + } + })); + } + + ret = this.pushStack([]); + + for (i = 0; i < len; i++) { + jQuery.find(selector, self[i], ret); + } + + return len > 1 ? jQuery.uniqueSort(ret) : ret; + }, + filter: function filter(selector) { + return this.pushStack(winnow(this, selector || [], false)); + }, + not: function not(selector) { + return this.pushStack(winnow(this, selector || [], true)); + }, + is: function is(selector) { + return !!winnow(this, // If this is a positional/relative selector, check membership in the returned set + // so $("p:first").is("p:last") won't return true for a doc with two "p". + typeof selector === "string" && rneedsContext.test(selector) ? jQuery(selector) : selector || [], false).length; + } + }); // Initialize a jQuery object + // A central reference to the root jQuery(document) + + var rootjQuery, + // A simple way to check for HTML strings + // Prioritize #id over to avoid XSS via location.hash (#9521) + // Strict HTML recognition (#11290: must start with <) + // Shortcut simple #id case for speed + rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/, + init = jQuery.fn.init = function (selector, context, root) { + var match, elem; // HANDLE: $(""), $(null), $(undefined), $(false) + + if (!selector) { + return this; + } // Method init() accepts an alternate rootjQuery + // so migrate can support jQuery.sub (gh-2101) + + + root = root || rootjQuery; // Handle HTML strings + + if (typeof selector === "string") { + if (selector[0] === "<" && selector[selector.length - 1] === ">" && selector.length >= 3) { + // Assume that strings that start and end with <> are HTML and skip the regex check + match = [null, selector, null]; + } else { + match = rquickExpr.exec(selector); + } // Match html or make sure no context is specified for #id + + + if (match && (match[1] || !context)) { + // HANDLE: $(html) -> $(array) + if (match[1]) { + context = context instanceof jQuery ? context[0] : context; // Option to run scripts is true for back-compat + // Intentionally let the error be thrown if parseHTML is not present + + jQuery.merge(this, jQuery.parseHTML(match[1], context && context.nodeType ? context.ownerDocument || context : document, true)); // HANDLE: $(html, props) + + if (rsingleTag.test(match[1]) && jQuery.isPlainObject(context)) { + for (match in context) { + // Properties of context are called as methods if possible + if (isFunction(this[match])) { + this[match](context[match]); // ...and otherwise set as attributes + } else { + this.attr(match, context[match]); + } + } + } + + return this; // HANDLE: $(#id) + } else { + elem = document.getElementById(match[2]); + + if (elem) { + // Inject the element directly into the jQuery object + this[0] = elem; + this.length = 1; + } + + return this; + } // HANDLE: $(expr, $(...)) + + } else if (!context || context.jquery) { + return (context || root).find(selector); // HANDLE: $(expr, context) + // (which is just equivalent to: $(context).find(expr) + } else { + return this.constructor(context).find(selector); + } // HANDLE: $(DOMElement) + + } else if (selector.nodeType) { + this[0] = selector; + this.length = 1; + return this; // HANDLE: $(function) + // Shortcut for document ready + } else if (isFunction(selector)) { + return root.ready !== undefined ? root.ready(selector) : // Execute immediately if ready is not present + selector(jQuery); + } + + return jQuery.makeArray(selector, this); + }; // Give the init function the jQuery prototype for later instantiation + + + init.prototype = jQuery.fn; // Initialize central reference + + rootjQuery = jQuery(document); + var rparentsprev = /^(?:parents|prev(?:Until|All))/, + // Methods guaranteed to produce a unique set when starting from a unique set + guaranteedUnique = { + children: true, + contents: true, + next: true, + prev: true + }; + jQuery.fn.extend({ + has: function has(target) { + var targets = jQuery(target, this), + l = targets.length; + return this.filter(function () { + var i = 0; + + for (; i < l; i++) { + if (jQuery.contains(this, targets[i])) { + return true; + } + } + }); + }, + closest: function closest(selectors, context) { + var cur, + i = 0, + l = this.length, + matched = [], + targets = typeof selectors !== "string" && jQuery(selectors); // Positional selectors never match, since there's no _selection_ context + + if (!rneedsContext.test(selectors)) { + for (; i < l; i++) { + for (cur = this[i]; cur && cur !== context; cur = cur.parentNode) { + // Always skip document fragments + if (cur.nodeType < 11 && (targets ? targets.index(cur) > -1 : // Don't pass non-elements to Sizzle + cur.nodeType === 1 && jQuery.find.matchesSelector(cur, selectors))) { + matched.push(cur); + break; + } + } + } + } + + return this.pushStack(matched.length > 1 ? jQuery.uniqueSort(matched) : matched); + }, + // Determine the position of an element within the set + index: function index(elem) { + // No argument, return index in parent + if (!elem) { + return this[0] && this[0].parentNode ? this.first().prevAll().length : -1; + } // Index in selector + + + if (typeof elem === "string") { + return indexOf.call(jQuery(elem), this[0]); + } // Locate the position of the desired element + + + return indexOf.call(this, // If it receives a jQuery object, the first element is used + elem.jquery ? elem[0] : elem); + }, + add: function add(selector, context) { + return this.pushStack(jQuery.uniqueSort(jQuery.merge(this.get(), jQuery(selector, context)))); + }, + addBack: function addBack(selector) { + return this.add(selector == null ? this.prevObject : this.prevObject.filter(selector)); + } + }); + + function sibling(cur, dir) { + while ((cur = cur[dir]) && cur.nodeType !== 1) {} + + return cur; + } + + jQuery.each({ + parent: function parent(elem) { + var parent = elem.parentNode; + return parent && parent.nodeType !== 11 ? parent : null; + }, + parents: function parents(elem) { + return dir(elem, "parentNode"); + }, + parentsUntil: function parentsUntil(elem, _i, until) { + return dir(elem, "parentNode", until); + }, + next: function next(elem) { + return sibling(elem, "nextSibling"); + }, + prev: function prev(elem) { + return sibling(elem, "previousSibling"); + }, + nextAll: function nextAll(elem) { + return dir(elem, "nextSibling"); + }, + prevAll: function prevAll(elem) { + return dir(elem, "previousSibling"); + }, + nextUntil: function nextUntil(elem, _i, until) { + return dir(elem, "nextSibling", until); + }, + prevUntil: function prevUntil(elem, _i, until) { + return dir(elem, "previousSibling", until); + }, + siblings: function siblings(elem) { + return _siblings((elem.parentNode || {}).firstChild, elem); + }, + children: function children(elem) { + return _siblings(elem.firstChild); + }, + contents: function contents(elem) { + if (elem.contentDocument != null && // Support: IE 11+ + // elements with no `data` attribute has an object + // `contentDocument` with a `null` prototype. + getProto(elem.contentDocument)) { + return elem.contentDocument; + } // Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only + // Treat the template element as a regular one in browsers that + // don't support it. + + + if (nodeName(elem, "template")) { + elem = elem.content || elem; + } + + return jQuery.merge([], elem.childNodes); + } + }, function (name, fn) { + jQuery.fn[name] = function (until, selector) { + var matched = jQuery.map(this, fn, until); + + if (name.slice(-5) !== "Until") { + selector = until; + } + + if (selector && typeof selector === "string") { + matched = jQuery.filter(selector, matched); + } + + if (this.length > 1) { + // Remove duplicates + if (!guaranteedUnique[name]) { + jQuery.uniqueSort(matched); + } // Reverse order for parents* and prev-derivatives + + + if (rparentsprev.test(name)) { + matched.reverse(); + } + } + + return this.pushStack(matched); + }; + }); + var rnothtmlwhite = /[^\x20\t\r\n\f]+/g; // Convert String-formatted options into Object-formatted ones + + function createOptions(options) { + var object = {}; + jQuery.each(options.match(rnothtmlwhite) || [], function (_, flag) { + object[flag] = true; + }); + return object; + } + /* + * Create a callback list using the following parameters: + * + * options: an optional list of space-separated options that will change how + * the callback list behaves or a more traditional option object + * + * By default a callback list will act like an event callback list and can be + * "fired" multiple times. + * + * Possible options: + * + * once: will ensure the callback list can only be fired once (like a Deferred) + * + * memory: will keep track of previous values and will call any callback added + * after the list has been fired right away with the latest "memorized" + * values (like a Deferred) + * + * unique: will ensure a callback can only be added once (no duplicate in the list) + * + * stopOnFalse: interrupt callings when a callback returns false + * + */ + + + jQuery.Callbacks = function (options) { + // Convert options from String-formatted to Object-formatted if needed + // (we check in cache first) + options = typeof options === "string" ? createOptions(options) : jQuery.extend({}, options); + + var // Flag to know if list is currently firing + firing, + // Last fire value for non-forgettable lists + memory, + // Flag to know if list was already fired + _fired, + // Flag to prevent firing + _locked, + // Actual callback list + list = [], + // Queue of execution data for repeatable lists + queue = [], + // Index of currently firing callback (modified by add/remove as needed) + firingIndex = -1, + // Fire callbacks + fire = function fire() { + // Enforce single-firing + _locked = _locked || options.once; // Execute callbacks for all pending executions, + // respecting firingIndex overrides and runtime changes + + _fired = firing = true; + + for (; queue.length; firingIndex = -1) { + memory = queue.shift(); + + while (++firingIndex < list.length) { + // Run callback and check for early termination + if (list[firingIndex].apply(memory[0], memory[1]) === false && options.stopOnFalse) { + // Jump to end and forget the data so .add doesn't re-fire + firingIndex = list.length; + memory = false; + } + } + } // Forget the data if we're done with it + + + if (!options.memory) { + memory = false; + } + + firing = false; // Clean up if we're done firing for good + + if (_locked) { + // Keep an empty list if we have data for future add calls + if (memory) { + list = []; // Otherwise, this object is spent + } else { + list = ""; + } + } + }, + // Actual Callbacks object + self = { + // Add a callback or a collection of callbacks to the list + add: function add() { + if (list) { + // If we have memory from a past run, we should fire after adding + if (memory && !firing) { + firingIndex = list.length - 1; + queue.push(memory); + } + + (function add(args) { + jQuery.each(args, function (_, arg) { + if (isFunction(arg)) { + if (!options.unique || !self.has(arg)) { + list.push(arg); + } + } else if (arg && arg.length && toType(arg) !== "string") { + // Inspect recursively + add(arg); + } + }); + })(arguments); + + if (memory && !firing) { + fire(); + } + } + + return this; + }, + // Remove a callback from the list + remove: function remove() { + jQuery.each(arguments, function (_, arg) { + var index; + + while ((index = jQuery.inArray(arg, list, index)) > -1) { + list.splice(index, 1); // Handle firing indexes + + if (index <= firingIndex) { + firingIndex--; + } + } + }); + return this; + }, + // Check if a given callback is in the list. + // If no argument is given, return whether or not list has callbacks attached. + has: function has(fn) { + return fn ? jQuery.inArray(fn, list) > -1 : list.length > 0; + }, + // Remove all callbacks from the list + empty: function empty() { + if (list) { + list = []; + } + + return this; + }, + // Disable .fire and .add + // Abort any current/pending executions + // Clear all callbacks and values + disable: function disable() { + _locked = queue = []; + list = memory = ""; + return this; + }, + disabled: function disabled() { + return !list; + }, + // Disable .fire + // Also disable .add unless we have memory (since it would have no effect) + // Abort any pending executions + lock: function lock() { + _locked = queue = []; + + if (!memory && !firing) { + list = memory = ""; + } + + return this; + }, + locked: function locked() { + return !!_locked; + }, + // Call all callbacks with the given context and arguments + fireWith: function fireWith(context, args) { + if (!_locked) { + args = args || []; + args = [context, args.slice ? args.slice() : args]; + queue.push(args); + + if (!firing) { + fire(); + } + } + + return this; + }, + // Call all the callbacks with the given arguments + fire: function fire() { + self.fireWith(this, arguments); + return this; + }, + // To know if the callbacks have already been called at least once + fired: function fired() { + return !!_fired; + } + }; + + return self; + }; + + function Identity(v) { + return v; + } + + function Thrower(ex) { + throw ex; + } + + function adoptValue(value, resolve, reject, noValue) { + var method; + + try { + // Check for promise aspect first to privilege synchronous behavior + if (value && isFunction(method = value.promise)) { + method.call(value).done(resolve).fail(reject); // Other thenables + } else if (value && isFunction(method = value.then)) { + method.call(value, resolve, reject); // Other non-thenables + } else { + // Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer: + // * false: [ value ].slice( 0 ) => resolve( value ) + // * true: [ value ].slice( 1 ) => resolve() + resolve.apply(undefined, [value].slice(noValue)); + } // For Promises/A+, convert exceptions into rejections + // Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in + // Deferred#then to conditionally suppress rejection. + + } catch (value) { + // Support: Android 4.0 only + // Strict mode functions invoked without .call/.apply get global-object context + reject.apply(undefined, [value]); + } + } + + jQuery.extend({ + Deferred: function Deferred(func) { + var tuples = [// action, add listener, callbacks, + // ... .then handlers, argument index, [final state] + ["notify", "progress", jQuery.Callbacks("memory"), jQuery.Callbacks("memory"), 2], ["resolve", "done", jQuery.Callbacks("once memory"), jQuery.Callbacks("once memory"), 0, "resolved"], ["reject", "fail", jQuery.Callbacks("once memory"), jQuery.Callbacks("once memory"), 1, "rejected"]], + _state = "pending", + _promise = { + state: function state() { + return _state; + }, + always: function always() { + deferred.done(arguments).fail(arguments); + return this; + }, + "catch": function _catch(fn) { + return _promise.then(null, fn); + }, + // Keep pipe for back-compat + pipe: function pipe() + /* fnDone, fnFail, fnProgress */ + { + var fns = arguments; + return jQuery.Deferred(function (newDefer) { + jQuery.each(tuples, function (_i, tuple) { + // Map tuples (progress, done, fail) to arguments (done, fail, progress) + var fn = isFunction(fns[tuple[4]]) && fns[tuple[4]]; // deferred.progress(function() { bind to newDefer or newDefer.notify }) + // deferred.done(function() { bind to newDefer or newDefer.resolve }) + // deferred.fail(function() { bind to newDefer or newDefer.reject }) + + deferred[tuple[1]](function () { + var returned = fn && fn.apply(this, arguments); + + if (returned && isFunction(returned.promise)) { + returned.promise().progress(newDefer.notify).done(newDefer.resolve).fail(newDefer.reject); + } else { + newDefer[tuple[0] + "With"](this, fn ? [returned] : arguments); + } + }); + }); + fns = null; + }).promise(); + }, + then: function then(onFulfilled, onRejected, onProgress) { + var maxDepth = 0; + + function resolve(depth, deferred, handler, special) { + return function () { + var that = this, + args = arguments, + mightThrow = function mightThrow() { + var returned, then; // Support: Promises/A+ section 2.3.3.3.3 + // https://promisesaplus.com/#point-59 + // Ignore double-resolution attempts + + if (depth < maxDepth) { + return; + } + + returned = handler.apply(that, args); // Support: Promises/A+ section 2.3.1 + // https://promisesaplus.com/#point-48 + + if (returned === deferred.promise()) { + throw new TypeError("Thenable self-resolution"); + } // Support: Promises/A+ sections 2.3.3.1, 3.5 + // https://promisesaplus.com/#point-54 + // https://promisesaplus.com/#point-75 + // Retrieve `then` only once + + + then = returned && ( // Support: Promises/A+ section 2.3.4 + // https://promisesaplus.com/#point-64 + // Only check objects and functions for thenability + _typeof(returned) === "object" || typeof returned === "function") && returned.then; // Handle a returned thenable + + if (isFunction(then)) { + // Special processors (notify) just wait for resolution + if (special) { + then.call(returned, resolve(maxDepth, deferred, Identity, special), resolve(maxDepth, deferred, Thrower, special)); // Normal processors (resolve) also hook into progress + } else { + // ...and disregard older resolution values + maxDepth++; + then.call(returned, resolve(maxDepth, deferred, Identity, special), resolve(maxDepth, deferred, Thrower, special), resolve(maxDepth, deferred, Identity, deferred.notifyWith)); + } // Handle all other returned values + + } else { + // Only substitute handlers pass on context + // and multiple values (non-spec behavior) + if (handler !== Identity) { + that = undefined; + args = [returned]; + } // Process the value(s) + // Default process is resolve + + + (special || deferred.resolveWith)(that, args); + } + }, + // Only normal processors (resolve) catch and reject exceptions + process = special ? mightThrow : function () { + try { + mightThrow(); + } catch (e) { + if (jQuery.Deferred.exceptionHook) { + jQuery.Deferred.exceptionHook(e, process.stackTrace); + } // Support: Promises/A+ section 2.3.3.3.4.1 + // https://promisesaplus.com/#point-61 + // Ignore post-resolution exceptions + + + if (depth + 1 >= maxDepth) { + // Only substitute handlers pass on context + // and multiple values (non-spec behavior) + if (handler !== Thrower) { + that = undefined; + args = [e]; + } + + deferred.rejectWith(that, args); + } + } + }; // Support: Promises/A+ section 2.3.3.3.1 + // https://promisesaplus.com/#point-57 + // Re-resolve promises immediately to dodge false rejection from + // subsequent errors + + + if (depth) { + process(); + } else { + // Call an optional hook to record the stack, in case of exception + // since it's otherwise lost when execution goes async + if (jQuery.Deferred.getStackHook) { + process.stackTrace = jQuery.Deferred.getStackHook(); + } + + window.setTimeout(process); + } + }; + } + + return jQuery.Deferred(function (newDefer) { + // progress_handlers.add( ... ) + tuples[0][3].add(resolve(0, newDefer, isFunction(onProgress) ? onProgress : Identity, newDefer.notifyWith)); // fulfilled_handlers.add( ... ) + + tuples[1][3].add(resolve(0, newDefer, isFunction(onFulfilled) ? onFulfilled : Identity)); // rejected_handlers.add( ... ) + + tuples[2][3].add(resolve(0, newDefer, isFunction(onRejected) ? onRejected : Thrower)); + }).promise(); + }, + // Get a promise for this deferred + // If obj is provided, the promise aspect is added to the object + promise: function promise(obj) { + return obj != null ? jQuery.extend(obj, _promise) : _promise; + } + }, + deferred = {}; // Add list-specific methods + + jQuery.each(tuples, function (i, tuple) { + var list = tuple[2], + stateString = tuple[5]; // promise.progress = list.add + // promise.done = list.add + // promise.fail = list.add + + _promise[tuple[1]] = list.add; // Handle state + + if (stateString) { + list.add(function () { + // state = "resolved" (i.e., fulfilled) + // state = "rejected" + _state = stateString; + }, // rejected_callbacks.disable + // fulfilled_callbacks.disable + tuples[3 - i][2].disable, // rejected_handlers.disable + // fulfilled_handlers.disable + tuples[3 - i][3].disable, // progress_callbacks.lock + tuples[0][2].lock, // progress_handlers.lock + tuples[0][3].lock); + } // progress_handlers.fire + // fulfilled_handlers.fire + // rejected_handlers.fire + + + list.add(tuple[3].fire); // deferred.notify = function() { deferred.notifyWith(...) } + // deferred.resolve = function() { deferred.resolveWith(...) } + // deferred.reject = function() { deferred.rejectWith(...) } + + deferred[tuple[0]] = function () { + deferred[tuple[0] + "With"](this === deferred ? undefined : this, arguments); + return this; + }; // deferred.notifyWith = list.fireWith + // deferred.resolveWith = list.fireWith + // deferred.rejectWith = list.fireWith + + + deferred[tuple[0] + "With"] = list.fireWith; + }); // Make the deferred a promise + + _promise.promise(deferred); // Call given func if any + + + if (func) { + func.call(deferred, deferred); + } // All done! + + + return deferred; + }, + // Deferred helper + when: function when(singleValue) { + var // count of uncompleted subordinates + remaining = arguments.length, + // count of unprocessed arguments + i = remaining, + // subordinate fulfillment data + resolveContexts = Array(i), + resolveValues = _slice.call(arguments), + // the master Deferred + master = jQuery.Deferred(), + // subordinate callback factory + updateFunc = function updateFunc(i) { + return function (value) { + resolveContexts[i] = this; + resolveValues[i] = arguments.length > 1 ? _slice.call(arguments) : value; + + if (! --remaining) { + master.resolveWith(resolveContexts, resolveValues); + } + }; + }; // Single- and empty arguments are adopted like Promise.resolve + + + if (remaining <= 1) { + adoptValue(singleValue, master.done(updateFunc(i)).resolve, master.reject, !remaining); // Use .then() to unwrap secondary thenables (cf. gh-3000) + + if (master.state() === "pending" || isFunction(resolveValues[i] && resolveValues[i].then)) { + return master.then(); + } + } // Multiple arguments are aggregated like Promise.all array elements + + + while (i--) { + adoptValue(resolveValues[i], updateFunc(i), master.reject); + } + + return master.promise(); + } + }); // These usually indicate a programmer mistake during development, + // warn about them ASAP rather than swallowing them by default. + + var rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/; + + jQuery.Deferred.exceptionHook = function (error, stack) { + // Support: IE 8 - 9 only + // Console exists when dev tools are open, which can happen at any time + if (window.console && window.console.warn && error && rerrorNames.test(error.name)) { + window.console.warn("jQuery.Deferred exception: " + error.message, error.stack, stack); + } + }; + + jQuery.readyException = function (error) { + window.setTimeout(function () { + throw error; + }); + }; // The deferred used on DOM ready + + + var readyList = jQuery.Deferred(); + + jQuery.fn.ready = function (fn) { + readyList.then(fn) // Wrap jQuery.readyException in a function so that the lookup + // happens at the time of error handling instead of callback + // registration. + .catch(function (error) { + jQuery.readyException(error); + }); + return this; + }; + + jQuery.extend({ + // Is the DOM ready to be used? Set to true once it occurs. + isReady: false, + // A counter to track how many items to wait for before + // the ready event fires. See #6781 + readyWait: 1, + // Handle when the DOM is ready + ready: function ready(wait) { + // Abort if there are pending holds or we're already ready + if (wait === true ? --jQuery.readyWait : jQuery.isReady) { + return; + } // Remember that the DOM is ready + + + jQuery.isReady = true; // If a normal DOM Ready event fired, decrement, and wait if need be + + if (wait !== true && --jQuery.readyWait > 0) { + return; + } // If there are functions bound, to execute + + + readyList.resolveWith(document, [jQuery]); + } + }); + jQuery.ready.then = readyList.then; // The ready event handler and self cleanup method + + function completed() { + document.removeEventListener("DOMContentLoaded", completed); + window.removeEventListener("load", completed); + jQuery.ready(); + } // Catch cases where $(document).ready() is called + // after the browser event has already occurred. + // Support: IE <=9 - 10 only + // Older IE sometimes signals "interactive" too soon + + + if (document.readyState === "complete" || document.readyState !== "loading" && !document.documentElement.doScroll) { + // Handle it asynchronously to allow scripts the opportunity to delay ready + window.setTimeout(jQuery.ready); + } else { + // Use the handy event callback + document.addEventListener("DOMContentLoaded", completed); // A fallback to window.onload, that will always work + + window.addEventListener("load", completed); + } // Multifunctional method to get and set values of a collection + // The value/s can optionally be executed if it's a function + + + var access = function access(elems, fn, key, value, chainable, emptyGet, raw) { + var i = 0, + len = elems.length, + bulk = key == null; // Sets many values + + if (toType(key) === "object") { + chainable = true; + + for (i in key) { + access(elems, fn, i, key[i], true, emptyGet, raw); + } // Sets one value + + } else if (value !== undefined) { + chainable = true; + + if (!isFunction(value)) { + raw = true; + } + + if (bulk) { + // Bulk operations run against the entire set + if (raw) { + fn.call(elems, value); + fn = null; // ...except when executing function values + } else { + bulk = fn; + + fn = function fn(elem, _key, value) { + return bulk.call(jQuery(elem), value); + }; + } + } + + if (fn) { + for (; i < len; i++) { + fn(elems[i], key, raw ? value : value.call(elems[i], i, fn(elems[i], key))); + } + } + } + + if (chainable) { + return elems; + } // Gets + + + if (bulk) { + return fn.call(elems); + } + + return len ? fn(elems[0], key) : emptyGet; + }; // Matches dashed string for camelizing + + + var rmsPrefix = /^-ms-/, + rdashAlpha = /-([a-z])/g; // Used by camelCase as callback to replace() + + function fcamelCase(_all, letter) { + return letter.toUpperCase(); + } // Convert dashed to camelCase; used by the css and data modules + // Support: IE <=9 - 11, Edge 12 - 15 + // Microsoft forgot to hump their vendor prefix (#9572) + + + function camelCase(string) { + return string.replace(rmsPrefix, "ms-").replace(rdashAlpha, fcamelCase); + } + + var acceptData = function acceptData(owner) { + // Accepts only: + // - Node + // - Node.ELEMENT_NODE + // - Node.DOCUMENT_NODE + // - Object + // - Any + return owner.nodeType === 1 || owner.nodeType === 9 || !+owner.nodeType; + }; + + function Data() { + this.expando = jQuery.expando + Data.uid++; + } + + Data.uid = 1; + Data.prototype = { + cache: function cache(owner) { + // Check if the owner object already has a cache + var value = owner[this.expando]; // If not, create one + + if (!value) { + value = Object.create(null); // We can accept data for non-element nodes in modern browsers, + // but we should not, see #8335. + // Always return an empty object. + + if (acceptData(owner)) { + // If it is a node unlikely to be stringify-ed or looped over + // use plain assignment + if (owner.nodeType) { + owner[this.expando] = value; // Otherwise secure it in a non-enumerable property + // configurable must be true to allow the property to be + // deleted when data is removed + } else { + Object.defineProperty(owner, this.expando, { + value: value, + configurable: true + }); + } + } + } + + return value; + }, + set: function set(owner, data, value) { + var prop, + cache = this.cache(owner); // Handle: [ owner, key, value ] args + // Always use camelCase key (gh-2257) + + if (typeof data === "string") { + cache[camelCase(data)] = value; // Handle: [ owner, { properties } ] args + } else { + // Copy the properties one-by-one to the cache object + for (prop in data) { + cache[camelCase(prop)] = data[prop]; + } + } + + return cache; + }, + get: function get(owner, key) { + return key === undefined ? this.cache(owner) : // Always use camelCase key (gh-2257) + owner[this.expando] && owner[this.expando][camelCase(key)]; + }, + access: function access(owner, key, value) { + // In cases where either: + // + // 1. No key was specified + // 2. A string key was specified, but no value provided + // + // Take the "read" path and allow the get method to determine + // which value to return, respectively either: + // + // 1. The entire cache object + // 2. The data stored at the key + // + if (key === undefined || key && typeof key === "string" && value === undefined) { + return this.get(owner, key); + } // When the key is not a string, or both a key and value + // are specified, set or extend (existing objects) with either: + // + // 1. An object of properties + // 2. A key and value + // + + + this.set(owner, key, value); // Since the "set" path can have two possible entry points + // return the expected data based on which path was taken[*] + + return value !== undefined ? value : key; + }, + remove: function remove(owner, key) { + var i, + cache = owner[this.expando]; + + if (cache === undefined) { + return; + } + + if (key !== undefined) { + // Support array or space separated string of keys + if (Array.isArray(key)) { + // If key is an array of keys... + // We always set camelCase keys, so remove that. + key = key.map(camelCase); + } else { + key = camelCase(key); // If a key with the spaces exists, use it. + // Otherwise, create an array by matching non-whitespace + + key = key in cache ? [key] : key.match(rnothtmlwhite) || []; + } + + i = key.length; + + while (i--) { + delete cache[key[i]]; + } + } // Remove the expando if there's no more data + + + if (key === undefined || jQuery.isEmptyObject(cache)) { + // Support: Chrome <=35 - 45 + // Webkit & Blink performance suffers when deleting properties + // from DOM nodes, so set to undefined instead + // https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted) + if (owner.nodeType) { + owner[this.expando] = undefined; + } else { + delete owner[this.expando]; + } + } + }, + hasData: function hasData(owner) { + var cache = owner[this.expando]; + return cache !== undefined && !jQuery.isEmptyObject(cache); + } + }; + var dataPriv = new Data(); + var dataUser = new Data(); // Implementation Summary + // + // 1. Enforce API surface and semantic compatibility with 1.9.x branch + // 2. Improve the module's maintainability by reducing the storage + // paths to a single mechanism. + // 3. Use the same single mechanism to support "private" and "user" data. + // 4. _Never_ expose "private" data to user code (TODO: Drop _data, _removeData) + // 5. Avoid exposing implementation details on user objects (eg. expando properties) + // 6. Provide a clear path for implementation upgrade to WeakMap in 2014 + + var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, + rmultiDash = /[A-Z]/g; + + function getData(data) { + if (data === "true") { + return true; + } + + if (data === "false") { + return false; + } + + if (data === "null") { + return null; + } // Only convert to a number if it doesn't change the string + + + if (data === +data + "") { + return +data; + } + + if (rbrace.test(data)) { + return JSON.parse(data); + } + + return data; + } + + function dataAttr(elem, key, data) { + var name; // If nothing was found internally, try to fetch any + // data from the HTML5 data-* attribute + + if (data === undefined && elem.nodeType === 1) { + name = "data-" + key.replace(rmultiDash, "-$&").toLowerCase(); + data = elem.getAttribute(name); + + if (typeof data === "string") { + try { + data = getData(data); + } catch (e) {} // Make sure we set the data so it isn't changed later + + + dataUser.set(elem, key, data); + } else { + data = undefined; + } + } + + return data; + } + + jQuery.extend({ + hasData: function hasData(elem) { + return dataUser.hasData(elem) || dataPriv.hasData(elem); + }, + data: function data(elem, name, _data) { + return dataUser.access(elem, name, _data); + }, + removeData: function removeData(elem, name) { + dataUser.remove(elem, name); + }, + // TODO: Now that all calls to _data and _removeData have been replaced + // with direct calls to dataPriv methods, these can be deprecated. + _data: function _data(elem, name, data) { + return dataPriv.access(elem, name, data); + }, + _removeData: function _removeData(elem, name) { + dataPriv.remove(elem, name); + } + }); + jQuery.fn.extend({ + data: function data(key, value) { + var i, + name, + data, + elem = this[0], + attrs = elem && elem.attributes; // Gets all values + + if (key === undefined) { + if (this.length) { + data = dataUser.get(elem); + + if (elem.nodeType === 1 && !dataPriv.get(elem, "hasDataAttrs")) { + i = attrs.length; + + while (i--) { + // Support: IE 11 only + // The attrs elements can be null (#14894) + if (attrs[i]) { + name = attrs[i].name; + + if (name.indexOf("data-") === 0) { + name = camelCase(name.slice(5)); + dataAttr(elem, name, data[name]); + } + } + } + + dataPriv.set(elem, "hasDataAttrs", true); + } + } + + return data; + } // Sets multiple values + + + if (_typeof(key) === "object") { + return this.each(function () { + dataUser.set(this, key); + }); + } + + return access(this, function (value) { + var data; // The calling jQuery object (element matches) is not empty + // (and therefore has an element appears at this[ 0 ]) and the + // `value` parameter was not undefined. An empty jQuery object + // will result in `undefined` for elem = this[ 0 ] which will + // throw an exception if an attempt to read a data cache is made. + + if (elem && value === undefined) { + // Attempt to get data from the cache + // The key will always be camelCased in Data + data = dataUser.get(elem, key); + + if (data !== undefined) { + return data; + } // Attempt to "discover" the data in + // HTML5 custom data-* attrs + + + data = dataAttr(elem, key); + + if (data !== undefined) { + return data; + } // We tried really hard, but the data doesn't exist. + + + return; + } // Set the data... + + + this.each(function () { + // We always store the camelCased key + dataUser.set(this, key, value); + }); + }, null, value, arguments.length > 1, null, true); + }, + removeData: function removeData(key) { + return this.each(function () { + dataUser.remove(this, key); + }); + } + }); + jQuery.extend({ + queue: function queue(elem, type, data) { + var queue; + + if (elem) { + type = (type || "fx") + "queue"; + queue = dataPriv.get(elem, type); // Speed up dequeue by getting out quickly if this is just a lookup + + if (data) { + if (!queue || Array.isArray(data)) { + queue = dataPriv.access(elem, type, jQuery.makeArray(data)); + } else { + queue.push(data); + } + } + + return queue || []; + } + }, + dequeue: function dequeue(elem, type) { + type = type || "fx"; + + var queue = jQuery.queue(elem, type), + startLength = queue.length, + fn = queue.shift(), + hooks = jQuery._queueHooks(elem, type), + next = function next() { + jQuery.dequeue(elem, type); + }; // If the fx queue is dequeued, always remove the progress sentinel + + + if (fn === "inprogress") { + fn = queue.shift(); + startLength--; + } + + if (fn) { + // Add a progress sentinel to prevent the fx queue from being + // automatically dequeued + if (type === "fx") { + queue.unshift("inprogress"); + } // Clear up the last queue stop function + + + delete hooks.stop; + fn.call(elem, next, hooks); + } + + if (!startLength && hooks) { + hooks.empty.fire(); + } + }, + // Not public - generate a queueHooks object, or return the current one + _queueHooks: function _queueHooks(elem, type) { + var key = type + "queueHooks"; + return dataPriv.get(elem, key) || dataPriv.access(elem, key, { + empty: jQuery.Callbacks("once memory").add(function () { + dataPriv.remove(elem, [type + "queue", key]); + }) + }); + } + }); + jQuery.fn.extend({ + queue: function queue(type, data) { + var setter = 2; + + if (typeof type !== "string") { + data = type; + type = "fx"; + setter--; + } + + if (arguments.length < setter) { + return jQuery.queue(this[0], type); + } + + return data === undefined ? this : this.each(function () { + var queue = jQuery.queue(this, type, data); // Ensure a hooks for this queue + + jQuery._queueHooks(this, type); + + if (type === "fx" && queue[0] !== "inprogress") { + jQuery.dequeue(this, type); + } + }); + }, + dequeue: function dequeue(type) { + return this.each(function () { + jQuery.dequeue(this, type); + }); + }, + clearQueue: function clearQueue(type) { + return this.queue(type || "fx", []); + }, + // Get a promise resolved when queues of a certain type + // are emptied (fx is the type by default) + promise: function promise(type, obj) { + var tmp, + count = 1, + defer = jQuery.Deferred(), + elements = this, + i = this.length, + resolve = function resolve() { + if (! --count) { + defer.resolveWith(elements, [elements]); + } + }; + + if (typeof type !== "string") { + obj = type; + type = undefined; + } + + type = type || "fx"; + + while (i--) { + tmp = dataPriv.get(elements[i], type + "queueHooks"); + + if (tmp && tmp.empty) { + count++; + tmp.empty.add(resolve); + } + } + + resolve(); + return defer.promise(obj); + } + }); + var pnum = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source; + var rcssNum = new RegExp("^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i"); + var cssExpand = ["Top", "Right", "Bottom", "Left"]; + var documentElement = document.documentElement; + + var isAttached = function isAttached(elem) { + return jQuery.contains(elem.ownerDocument, elem); + }, + composed = { + composed: true + }; // Support: IE 9 - 11+, Edge 12 - 18+, iOS 10.0 - 10.2 only + // Check attachment across shadow DOM boundaries when possible (gh-3504) + // Support: iOS 10.0-10.2 only + // Early iOS 10 versions support `attachShadow` but not `getRootNode`, + // leading to errors. We need to check for `getRootNode`. + + + if (documentElement.getRootNode) { + isAttached = function isAttached(elem) { + return jQuery.contains(elem.ownerDocument, elem) || elem.getRootNode(composed) === elem.ownerDocument; + }; + } + + var isHiddenWithinTree = function isHiddenWithinTree(elem, el) { + // isHiddenWithinTree might be called from jQuery#filter function; + // in that case, element will be second argument + elem = el || elem; // Inline style trumps all + + return elem.style.display === "none" || elem.style.display === "" && // Otherwise, check computed style + // Support: Firefox <=43 - 45 + // Disconnected elements can have computed display: none, so first confirm that elem is + // in the document. + isAttached(elem) && jQuery.css(elem, "display") === "none"; + }; + + function adjustCSS(elem, prop, valueParts, tween) { + var adjusted, + scale, + maxIterations = 20, + currentValue = tween ? function () { + return tween.cur(); + } : function () { + return jQuery.css(elem, prop, ""); + }, + initial = currentValue(), + unit = valueParts && valueParts[3] || (jQuery.cssNumber[prop] ? "" : "px"), + // Starting value computation is required for potential unit mismatches + initialInUnit = elem.nodeType && (jQuery.cssNumber[prop] || unit !== "px" && +initial) && rcssNum.exec(jQuery.css(elem, prop)); + + if (initialInUnit && initialInUnit[3] !== unit) { + // Support: Firefox <=54 + // Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144) + initial = initial / 2; // Trust units reported by jQuery.css + + unit = unit || initialInUnit[3]; // Iteratively approximate from a nonzero starting point + + initialInUnit = +initial || 1; + + while (maxIterations--) { + // Evaluate and update our best guess (doubling guesses that zero out). + // Finish if the scale equals or crosses 1 (making the old*new product non-positive). + jQuery.style(elem, prop, initialInUnit + unit); + + if ((1 - scale) * (1 - (scale = currentValue() / initial || 0.5)) <= 0) { + maxIterations = 0; + } + + initialInUnit = initialInUnit / scale; + } + + initialInUnit = initialInUnit * 2; + jQuery.style(elem, prop, initialInUnit + unit); // Make sure we update the tween properties later on + + valueParts = valueParts || []; + } + + if (valueParts) { + initialInUnit = +initialInUnit || +initial || 0; // Apply relative offset (+=/-=) if specified + + adjusted = valueParts[1] ? initialInUnit + (valueParts[1] + 1) * valueParts[2] : +valueParts[2]; + + if (tween) { + tween.unit = unit; + tween.start = initialInUnit; + tween.end = adjusted; + } + } + + return adjusted; + } + + var defaultDisplayMap = {}; + + function getDefaultDisplay(elem) { + var temp, + doc = elem.ownerDocument, + nodeName = elem.nodeName, + display = defaultDisplayMap[nodeName]; + + if (display) { + return display; + } + + temp = doc.body.appendChild(doc.createElement(nodeName)); + display = jQuery.css(temp, "display"); + temp.parentNode.removeChild(temp); + + if (display === "none") { + display = "block"; + } + + defaultDisplayMap[nodeName] = display; + return display; + } + + function showHide(elements, show) { + var display, + elem, + values = [], + index = 0, + length = elements.length; // Determine new display value for elements that need to change + + for (; index < length; index++) { + elem = elements[index]; + + if (!elem.style) { + continue; + } + + display = elem.style.display; + + if (show) { + // Since we force visibility upon cascade-hidden elements, an immediate (and slow) + // check is required in this first loop unless we have a nonempty display value (either + // inline or about-to-be-restored) + if (display === "none") { + values[index] = dataPriv.get(elem, "display") || null; + + if (!values[index]) { + elem.style.display = ""; + } + } + + if (elem.style.display === "" && isHiddenWithinTree(elem)) { + values[index] = getDefaultDisplay(elem); + } + } else { + if (display !== "none") { + values[index] = "none"; // Remember what we're overwriting + + dataPriv.set(elem, "display", display); + } + } + } // Set the display of the elements in a second loop to avoid constant reflow + + + for (index = 0; index < length; index++) { + if (values[index] != null) { + elements[index].style.display = values[index]; + } + } + + return elements; + } + + jQuery.fn.extend({ + show: function show() { + return showHide(this, true); + }, + hide: function hide() { + return showHide(this); + }, + toggle: function toggle(state) { + if (typeof state === "boolean") { + return state ? this.show() : this.hide(); + } + + return this.each(function () { + if (isHiddenWithinTree(this)) { + jQuery(this).show(); + } else { + jQuery(this).hide(); + } + }); + } + }); + var rcheckableType = /^(?:checkbox|radio)$/i; + var rtagName = /<([a-z][^\/\0>\x20\t\r\n\f]*)/i; + var rscriptType = /^$|^module$|\/(?:java|ecma)script/i; + + (function () { + var fragment = document.createDocumentFragment(), + div = fragment.appendChild(document.createElement("div")), + input = document.createElement("input"); // Support: Android 4.0 - 4.3 only + // Check state lost if the name is set (#11217) + // Support: Windows Web Apps (WWA) + // `name` and `type` must use .setAttribute for WWA (#14901) + + input.setAttribute("type", "radio"); + input.setAttribute("checked", "checked"); + input.setAttribute("name", "t"); + div.appendChild(input); // Support: Android <=4.1 only + // Older WebKit doesn't clone checked state correctly in fragments + + support.checkClone = div.cloneNode(true).cloneNode(true).lastChild.checked; // Support: IE <=11 only + // Make sure textarea (and checkbox) defaultValue is properly cloned + + div.innerHTML = "x"; + support.noCloneChecked = !!div.cloneNode(true).lastChild.defaultValue; // Support: IE <=9 only + // IE <=9 replaces tags with their contents when inserted outside of + // the select element. + + div.innerHTML = ""; + support.option = !!div.lastChild; + })(); // We have to close these tags to support XHTML (#13200) + + + var wrapMap = { + // XHTML parsers do not magically insert elements in the + // same way that tag soup parsers do. So we cannot shorten + // this by omitting or other required elements. + thead: [1, "", ""], + col: [2, "", ""], + tr: [2, "", ""], + td: [3, "", ""], + _default: [0, "", ""] + }; + wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; + wrapMap.th = wrapMap.td; // Support: IE <=9 only + + if (!support.option) { + wrapMap.optgroup = wrapMap.option = [1, "", ""]; + } + + function getAll(context, tag) { + // Support: IE <=9 - 11 only + // Use typeof to avoid zero-argument method invocation on host objects (#15151) + var ret; + + if (typeof context.getElementsByTagName !== "undefined") { + ret = context.getElementsByTagName(tag || "*"); + } else if (typeof context.querySelectorAll !== "undefined") { + ret = context.querySelectorAll(tag || "*"); + } else { + ret = []; + } + + if (tag === undefined || tag && nodeName(context, tag)) { + return jQuery.merge([context], ret); + } + + return ret; + } // Mark scripts as having already been evaluated + + + function setGlobalEval(elems, refElements) { + var i = 0, + l = elems.length; + + for (; i < l; i++) { + dataPriv.set(elems[i], "globalEval", !refElements || dataPriv.get(refElements[i], "globalEval")); + } + } + + var rhtml = /<|?\w+;/; + + function buildFragment(elems, context, scripts, selection, ignored) { + var elem, + tmp, + tag, + wrap, + attached, + j, + fragment = context.createDocumentFragment(), + nodes = [], + i = 0, + l = elems.length; + + for (; i < l; i++) { + elem = elems[i]; + + if (elem || elem === 0) { + // Add nodes directly + if (toType(elem) === "object") { + // Support: Android <=4.0 only, PhantomJS 1 only + // push.apply(_, arraylike) throws on ancient WebKit + jQuery.merge(nodes, elem.nodeType ? [elem] : elem); // Convert non-html into a text node + } else if (!rhtml.test(elem)) { + nodes.push(context.createTextNode(elem)); // Convert html into DOM nodes + } else { + tmp = tmp || fragment.appendChild(context.createElement("div")); // Deserialize a standard representation + + tag = (rtagName.exec(elem) || ["", ""])[1].toLowerCase(); + wrap = wrapMap[tag] || wrapMap._default; + tmp.innerHTML = wrap[1] + jQuery.htmlPrefilter(elem) + wrap[2]; // Descend through wrappers to the right content + + j = wrap[0]; + + while (j--) { + tmp = tmp.lastChild; + } // Support: Android <=4.0 only, PhantomJS 1 only + // push.apply(_, arraylike) throws on ancient WebKit + + + jQuery.merge(nodes, tmp.childNodes); // Remember the top-level container + + tmp = fragment.firstChild; // Ensure the created nodes are orphaned (#12392) + + tmp.textContent = ""; + } + } + } // Remove wrapper from fragment + + + fragment.textContent = ""; + i = 0; + + while (elem = nodes[i++]) { + // Skip elements already in the context collection (trac-4087) + if (selection && jQuery.inArray(elem, selection) > -1) { + if (ignored) { + ignored.push(elem); + } + + continue; + } + + attached = isAttached(elem); // Append to fragment + + tmp = getAll(fragment.appendChild(elem), "script"); // Preserve script evaluation history + + if (attached) { + setGlobalEval(tmp); + } // Capture executables + + + if (scripts) { + j = 0; + + while (elem = tmp[j++]) { + if (rscriptType.test(elem.type || "")) { + scripts.push(elem); + } + } + } + } + + return fragment; + } + + var rkeyEvent = /^key/, + rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, + rtypenamespace = /^([^.]*)(?:\.(.+)|)/; + + function returnTrue() { + return true; + } + + function returnFalse() { + return false; + } // Support: IE <=9 - 11+ + // focus() and blur() are asynchronous, except when they are no-op. + // So expect focus to be synchronous when the element is already active, + // and blur to be synchronous when the element is not already active. + // (focus and blur are always synchronous in other supported browsers, + // this just defines when we can count on it). + + + function expectSync(elem, type) { + return elem === safeActiveElement() === (type === "focus"); + } // Support: IE <=9 only + // Accessing document.activeElement can throw unexpectedly + // https://bugs.jquery.com/ticket/13393 + + + function safeActiveElement() { + try { + return document.activeElement; + } catch (err) {} + } + + function _on(elem, types, selector, data, fn, one) { + var origFn, type; // Types can be a map of types/handlers + + if (_typeof(types) === "object") { + // ( types-Object, selector, data ) + if (typeof selector !== "string") { + // ( types-Object, data ) + data = data || selector; + selector = undefined; + } + + for (type in types) { + _on(elem, type, selector, data, types[type], one); + } + + return elem; + } + + if (data == null && fn == null) { + // ( types, fn ) + fn = selector; + data = selector = undefined; + } else if (fn == null) { + if (typeof selector === "string") { + // ( types, selector, fn ) + fn = data; + data = undefined; + } else { + // ( types, data, fn ) + fn = data; + data = selector; + selector = undefined; + } + } + + if (fn === false) { + fn = returnFalse; + } else if (!fn) { + return elem; + } + + if (one === 1) { + origFn = fn; + + fn = function fn(event) { + // Can use an empty set, since event contains the info + jQuery().off(event); + return origFn.apply(this, arguments); + }; // Use same guid so caller can remove using origFn + + + fn.guid = origFn.guid || (origFn.guid = jQuery.guid++); + } + + return elem.each(function () { + jQuery.event.add(this, types, fn, data, selector); + }); + } + /* + * Helper functions for managing events -- not part of the public interface. + * Props to Dean Edwards' addEvent library for many of the ideas. + */ + + + jQuery.event = { + global: {}, + add: function add(elem, types, handler, data, selector) { + var handleObjIn, + eventHandle, + tmp, + events, + t, + handleObj, + special, + handlers, + type, + namespaces, + origType, + elemData = dataPriv.get(elem); // Only attach events to objects that accept data + + if (!acceptData(elem)) { + return; + } // Caller can pass in an object of custom data in lieu of the handler + + + if (handler.handler) { + handleObjIn = handler; + handler = handleObjIn.handler; + selector = handleObjIn.selector; + } // Ensure that invalid selectors throw exceptions at attach time + // Evaluate against documentElement in case elem is a non-element node (e.g., document) + + + if (selector) { + jQuery.find.matchesSelector(documentElement, selector); + } // Make sure that the handler has a unique ID, used to find/remove it later + + + if (!handler.guid) { + handler.guid = jQuery.guid++; + } // Init the element's event structure and main handler, if this is the first + + + if (!(events = elemData.events)) { + events = elemData.events = Object.create(null); + } + + if (!(eventHandle = elemData.handle)) { + eventHandle = elemData.handle = function (e) { + // Discard the second event of a jQuery.event.trigger() and + // when an event is called after a page has unloaded + return typeof jQuery !== "undefined" && jQuery.event.triggered !== e.type ? jQuery.event.dispatch.apply(elem, arguments) : undefined; + }; + } // Handle multiple events separated by a space + + + types = (types || "").match(rnothtmlwhite) || [""]; + t = types.length; + + while (t--) { + tmp = rtypenamespace.exec(types[t]) || []; + type = origType = tmp[1]; + namespaces = (tmp[2] || "").split(".").sort(); // There *must* be a type, no attaching namespace-only handlers + + if (!type) { + continue; + } // If event changes its type, use the special event handlers for the changed type + + + special = jQuery.event.special[type] || {}; // If selector defined, determine special event api type, otherwise given type + + type = (selector ? special.delegateType : special.bindType) || type; // Update special based on newly reset type + + special = jQuery.event.special[type] || {}; // handleObj is passed to all event handlers + + handleObj = jQuery.extend({ + type: type, + origType: origType, + data: data, + handler: handler, + guid: handler.guid, + selector: selector, + needsContext: selector && jQuery.expr.match.needsContext.test(selector), + namespace: namespaces.join(".") + }, handleObjIn); // Init the event handler queue if we're the first + + if (!(handlers = events[type])) { + handlers = events[type] = []; + handlers.delegateCount = 0; // Only use addEventListener if the special events handler returns false + + if (!special.setup || special.setup.call(elem, data, namespaces, eventHandle) === false) { + if (elem.addEventListener) { + elem.addEventListener(type, eventHandle); + } + } + } + + if (special.add) { + special.add.call(elem, handleObj); + + if (!handleObj.handler.guid) { + handleObj.handler.guid = handler.guid; + } + } // Add to the element's handler list, delegates in front + + + if (selector) { + handlers.splice(handlers.delegateCount++, 0, handleObj); + } else { + handlers.push(handleObj); + } // Keep track of which events have ever been used, for event optimization + + + jQuery.event.global[type] = true; + } + }, + // Detach an event or set of events from an element + remove: function remove(elem, types, handler, selector, mappedTypes) { + var j, + origCount, + tmp, + events, + t, + handleObj, + special, + handlers, + type, + namespaces, + origType, + elemData = dataPriv.hasData(elem) && dataPriv.get(elem); + + if (!elemData || !(events = elemData.events)) { + return; + } // Once for each type.namespace in types; type may be omitted + + + types = (types || "").match(rnothtmlwhite) || [""]; + t = types.length; + + while (t--) { + tmp = rtypenamespace.exec(types[t]) || []; + type = origType = tmp[1]; + namespaces = (tmp[2] || "").split(".").sort(); // Unbind all events (on this namespace, if provided) for the element + + if (!type) { + for (type in events) { + jQuery.event.remove(elem, type + types[t], handler, selector, true); + } + + continue; + } + + special = jQuery.event.special[type] || {}; + type = (selector ? special.delegateType : special.bindType) || type; + handlers = events[type] || []; + tmp = tmp[2] && new RegExp("(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)"); // Remove matching events + + origCount = j = handlers.length; + + while (j--) { + handleObj = handlers[j]; + + if ((mappedTypes || origType === handleObj.origType) && (!handler || handler.guid === handleObj.guid) && (!tmp || tmp.test(handleObj.namespace)) && (!selector || selector === handleObj.selector || selector === "**" && handleObj.selector)) { + handlers.splice(j, 1); + + if (handleObj.selector) { + handlers.delegateCount--; + } + + if (special.remove) { + special.remove.call(elem, handleObj); + } + } + } // Remove generic event handler if we removed something and no more handlers exist + // (avoids potential for endless recursion during removal of special event handlers) + + + if (origCount && !handlers.length) { + if (!special.teardown || special.teardown.call(elem, namespaces, elemData.handle) === false) { + jQuery.removeEvent(elem, type, elemData.handle); + } + + delete events[type]; + } + } // Remove data and the expando if it's no longer used + + + if (jQuery.isEmptyObject(events)) { + dataPriv.remove(elem, "handle events"); + } + }, + dispatch: function dispatch(nativeEvent) { + var i, + j, + ret, + matched, + handleObj, + handlerQueue, + args = new Array(arguments.length), + // Make a writable jQuery.Event from the native event object + event = jQuery.event.fix(nativeEvent), + handlers = (dataPriv.get(this, "events") || Object.create(null))[event.type] || [], + special = jQuery.event.special[event.type] || {}; // Use the fix-ed jQuery.Event rather than the (read-only) native event + + args[0] = event; + + for (i = 1; i < arguments.length; i++) { + args[i] = arguments[i]; + } + + event.delegateTarget = this; // Call the preDispatch hook for the mapped type, and let it bail if desired + + if (special.preDispatch && special.preDispatch.call(this, event) === false) { + return; + } // Determine handlers + + + handlerQueue = jQuery.event.handlers.call(this, event, handlers); // Run delegates first; they may want to stop propagation beneath us + + i = 0; + + while ((matched = handlerQueue[i++]) && !event.isPropagationStopped()) { + event.currentTarget = matched.elem; + j = 0; + + while ((handleObj = matched.handlers[j++]) && !event.isImmediatePropagationStopped()) { + // If the event is namespaced, then each handler is only invoked if it is + // specially universal or its namespaces are a superset of the event's. + if (!event.rnamespace || handleObj.namespace === false || event.rnamespace.test(handleObj.namespace)) { + event.handleObj = handleObj; + event.data = handleObj.data; + ret = ((jQuery.event.special[handleObj.origType] || {}).handle || handleObj.handler).apply(matched.elem, args); + + if (ret !== undefined) { + if ((event.result = ret) === false) { + event.preventDefault(); + event.stopPropagation(); + } + } + } + } + } // Call the postDispatch hook for the mapped type + + + if (special.postDispatch) { + special.postDispatch.call(this, event); + } + + return event.result; + }, + handlers: function handlers(event, _handlers) { + var i, + handleObj, + sel, + matchedHandlers, + matchedSelectors, + handlerQueue = [], + delegateCount = _handlers.delegateCount, + cur = event.target; // Find delegate handlers + + if (delegateCount && // Support: IE <=9 + // Black-hole SVG instance trees (trac-13180) + cur.nodeType && // Support: Firefox <=42 + // Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861) + // https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click + // Support: IE 11 only + // ...but not arrow key "clicks" of radio inputs, which can have `button` -1 (gh-2343) + !(event.type === "click" && event.button >= 1)) { + for (; cur !== this; cur = cur.parentNode || this) { + // Don't check non-elements (#13208) + // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) + if (cur.nodeType === 1 && !(event.type === "click" && cur.disabled === true)) { + matchedHandlers = []; + matchedSelectors = {}; + + for (i = 0; i < delegateCount; i++) { + handleObj = _handlers[i]; // Don't conflict with Object.prototype properties (#13203) + + sel = handleObj.selector + " "; + + if (matchedSelectors[sel] === undefined) { + matchedSelectors[sel] = handleObj.needsContext ? jQuery(sel, this).index(cur) > -1 : jQuery.find(sel, this, null, [cur]).length; + } + + if (matchedSelectors[sel]) { + matchedHandlers.push(handleObj); + } + } + + if (matchedHandlers.length) { + handlerQueue.push({ + elem: cur, + handlers: matchedHandlers + }); + } + } + } + } // Add the remaining (directly-bound) handlers + + + cur = this; + + if (delegateCount < _handlers.length) { + handlerQueue.push({ + elem: cur, + handlers: _handlers.slice(delegateCount) + }); + } + + return handlerQueue; + }, + addProp: function addProp(name, hook) { + Object.defineProperty(jQuery.Event.prototype, name, { + enumerable: true, + configurable: true, + get: isFunction(hook) ? function () { + if (this.originalEvent) { + return hook(this.originalEvent); + } + } : function () { + if (this.originalEvent) { + return this.originalEvent[name]; + } + }, + set: function set(value) { + Object.defineProperty(this, name, { + enumerable: true, + configurable: true, + writable: true, + value: value + }); + } + }); + }, + fix: function fix(originalEvent) { + return originalEvent[jQuery.expando] ? originalEvent : new jQuery.Event(originalEvent); + }, + special: { + load: { + // Prevent triggered image.load events from bubbling to window.load + noBubble: true + }, + click: { + // Utilize native event to ensure correct state for checkable inputs + setup: function setup(data) { + // For mutual compressibility with _default, replace `this` access with a local var. + // `|| data` is dead code meant only to preserve the variable through minification. + var el = this || data; // Claim the first handler + + if (rcheckableType.test(el.type) && el.click && nodeName(el, "input")) { + // dataPriv.set( el, "click", ... ) + leverageNative(el, "click", returnTrue); + } // Return false to allow normal processing in the caller + + + return false; + }, + trigger: function trigger(data) { + // For mutual compressibility with _default, replace `this` access with a local var. + // `|| data` is dead code meant only to preserve the variable through minification. + var el = this || data; // Force setup before triggering a click + + if (rcheckableType.test(el.type) && el.click && nodeName(el, "input")) { + leverageNative(el, "click"); + } // Return non-false to allow normal event-path propagation + + + return true; + }, + // For cross-browser consistency, suppress native .click() on links + // Also prevent it if we're currently inside a leveraged native-event stack + _default: function _default(event) { + var target = event.target; + return rcheckableType.test(target.type) && target.click && nodeName(target, "input") && dataPriv.get(target, "click") || nodeName(target, "a"); + } + }, + beforeunload: { + postDispatch: function postDispatch(event) { + // Support: Firefox 20+ + // Firefox doesn't alert if the returnValue field is not set. + if (event.result !== undefined && event.originalEvent) { + event.originalEvent.returnValue = event.result; + } + } + } + } + }; // Ensure the presence of an event listener that handles manually-triggered + // synthetic events by interrupting progress until reinvoked in response to + // *native* events that it fires directly, ensuring that state changes have + // already occurred before other listeners are invoked. + + function leverageNative(el, type, expectSync) { + // Missing expectSync indicates a trigger call, which must force setup through jQuery.event.add + if (!expectSync) { + if (dataPriv.get(el, type) === undefined) { + jQuery.event.add(el, type, returnTrue); + } + + return; + } // Register the controller as a special universal handler for all event namespaces + + + dataPriv.set(el, type, false); + jQuery.event.add(el, type, { + namespace: false, + handler: function handler(event) { + var notAsync, + result, + saved = dataPriv.get(this, type); + + if (event.isTrigger & 1 && this[type]) { + // Interrupt processing of the outer synthetic .trigger()ed event + // Saved data should be false in such cases, but might be a leftover capture object + // from an async native handler (gh-4350) + if (!saved.length) { + // Store arguments for use when handling the inner native event + // There will always be at least one argument (an event object), so this array + // will not be confused with a leftover capture object. + saved = _slice.call(arguments); + dataPriv.set(this, type, saved); // Trigger the native event and capture its result + // Support: IE <=9 - 11+ + // focus() and blur() are asynchronous + + notAsync = expectSync(this, type); + this[type](); + result = dataPriv.get(this, type); + + if (saved !== result || notAsync) { + dataPriv.set(this, type, false); + } else { + result = {}; + } + + if (saved !== result) { + // Cancel the outer synthetic event + event.stopImmediatePropagation(); + event.preventDefault(); + return result.value; + } // If this is an inner synthetic event for an event with a bubbling surrogate + // (focus or blur), assume that the surrogate already propagated from triggering the + // native event and prevent that from happening again here. + // This technically gets the ordering wrong w.r.t. to `.trigger()` (in which the + // bubbling surrogate propagates *after* the non-bubbling base), but that seems + // less bad than duplication. + + } else if ((jQuery.event.special[type] || {}).delegateType) { + event.stopPropagation(); + } // If this is a native event triggered above, everything is now in order + // Fire an inner synthetic event with the original arguments + + } else if (saved.length) { + // ...and capture the result + dataPriv.set(this, type, { + value: jQuery.event.trigger( // Support: IE <=9 - 11+ + // Extend with the prototype to reset the above stopImmediatePropagation() + jQuery.extend(saved[0], jQuery.Event.prototype), saved.slice(1), this) + }); // Abort handling of the native event + + event.stopImmediatePropagation(); + } + } + }); + } + + jQuery.removeEvent = function (elem, type, handle) { + // This "if" is needed for plain objects + if (elem.removeEventListener) { + elem.removeEventListener(type, handle); + } + }; + + jQuery.Event = function (src, props) { + // Allow instantiation without the 'new' keyword + if (!(this instanceof jQuery.Event)) { + return new jQuery.Event(src, props); + } // Event object + + + if (src && src.type) { + this.originalEvent = src; + this.type = src.type; // Events bubbling up the document may have been marked as prevented + // by a handler lower down the tree; reflect the correct value. + + this.isDefaultPrevented = src.defaultPrevented || src.defaultPrevented === undefined && // Support: Android <=2.3 only + src.returnValue === false ? returnTrue : returnFalse; // Create target properties + // Support: Safari <=6 - 7 only + // Target should not be a text node (#504, #13143) + + this.target = src.target && src.target.nodeType === 3 ? src.target.parentNode : src.target; + this.currentTarget = src.currentTarget; + this.relatedTarget = src.relatedTarget; // Event type + } else { + this.type = src; + } // Put explicitly provided properties onto the event object + + + if (props) { + jQuery.extend(this, props); + } // Create a timestamp if incoming event doesn't have one + + + this.timeStamp = src && src.timeStamp || Date.now(); // Mark it as fixed + + this[jQuery.expando] = true; + }; // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding + // https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html + + + jQuery.Event.prototype = { + constructor: jQuery.Event, + isDefaultPrevented: returnFalse, + isPropagationStopped: returnFalse, + isImmediatePropagationStopped: returnFalse, + isSimulated: false, + preventDefault: function preventDefault() { + var e = this.originalEvent; + this.isDefaultPrevented = returnTrue; + + if (e && !this.isSimulated) { + e.preventDefault(); + } + }, + stopPropagation: function stopPropagation() { + var e = this.originalEvent; + this.isPropagationStopped = returnTrue; + + if (e && !this.isSimulated) { + e.stopPropagation(); + } + }, + stopImmediatePropagation: function stopImmediatePropagation() { + var e = this.originalEvent; + this.isImmediatePropagationStopped = returnTrue; + + if (e && !this.isSimulated) { + e.stopImmediatePropagation(); + } + + this.stopPropagation(); + } + }; // Includes all common event props including KeyEvent and MouseEvent specific props + + jQuery.each({ + altKey: true, + bubbles: true, + cancelable: true, + changedTouches: true, + ctrlKey: true, + detail: true, + eventPhase: true, + metaKey: true, + pageX: true, + pageY: true, + shiftKey: true, + view: true, + "char": true, + code: true, + charCode: true, + key: true, + keyCode: true, + button: true, + buttons: true, + clientX: true, + clientY: true, + offsetX: true, + offsetY: true, + pointerId: true, + pointerType: true, + screenX: true, + screenY: true, + targetTouches: true, + toElement: true, + touches: true, + which: function which(event) { + var button = event.button; // Add which for key events + + if (event.which == null && rkeyEvent.test(event.type)) { + return event.charCode != null ? event.charCode : event.keyCode; + } // Add which for click: 1 === left; 2 === middle; 3 === right + + + if (!event.which && button !== undefined && rmouseEvent.test(event.type)) { + if (button & 1) { + return 1; + } + + if (button & 2) { + return 3; + } + + if (button & 4) { + return 2; + } + + return 0; + } + + return event.which; + } + }, jQuery.event.addProp); + jQuery.each({ + focus: "focusin", + blur: "focusout" + }, function (type, delegateType) { + jQuery.event.special[type] = { + // Utilize native event if possible so blur/focus sequence is correct + setup: function setup() { + // Claim the first handler + // dataPriv.set( this, "focus", ... ) + // dataPriv.set( this, "blur", ... ) + leverageNative(this, type, expectSync); // Return false to allow normal processing in the caller + + return false; + }, + trigger: function trigger() { + // Force setup before trigger + leverageNative(this, type); // Return non-false to allow normal event-path propagation + + return true; + }, + delegateType: delegateType + }; + }); // Create mouseenter/leave events using mouseover/out and event-time checks + // so that event delegation works in jQuery. + // Do the same for pointerenter/pointerleave and pointerover/pointerout + // + // Support: Safari 7 only + // Safari sends mouseenter too often; see: + // https://bugs.chromium.org/p/chromium/issues/detail?id=470258 + // for the description of the bug (it existed in older Chrome versions as well). + + jQuery.each({ + mouseenter: "mouseover", + mouseleave: "mouseout", + pointerenter: "pointerover", + pointerleave: "pointerout" + }, function (orig, fix) { + jQuery.event.special[orig] = { + delegateType: fix, + bindType: fix, + handle: function handle(event) { + var ret, + target = this, + related = event.relatedTarget, + handleObj = event.handleObj; // For mouseenter/leave call the handler if related is outside the target. + // NB: No relatedTarget if the mouse left/entered the browser window + + if (!related || related !== target && !jQuery.contains(target, related)) { + event.type = handleObj.origType; + ret = handleObj.handler.apply(this, arguments); + event.type = fix; + } + + return ret; + } + }; + }); + jQuery.fn.extend({ + on: function on(types, selector, data, fn) { + return _on(this, types, selector, data, fn); + }, + one: function one(types, selector, data, fn) { + return _on(this, types, selector, data, fn, 1); + }, + off: function off(types, selector, fn) { + var handleObj, type; + + if (types && types.preventDefault && types.handleObj) { + // ( event ) dispatched jQuery.Event + handleObj = types.handleObj; + jQuery(types.delegateTarget).off(handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, handleObj.selector, handleObj.handler); + return this; + } + + if (_typeof(types) === "object") { + // ( types-object [, selector] ) + for (type in types) { + this.off(type, selector, types[type]); + } + + return this; + } + + if (selector === false || typeof selector === "function") { + // ( types [, fn] ) + fn = selector; + selector = undefined; + } + + if (fn === false) { + fn = returnFalse; + } + + return this.each(function () { + jQuery.event.remove(this, types, fn, selector); + }); + } + }); + var // Support: IE <=10 - 11, Edge 12 - 13 only + // In IE/Edge using regex groups here causes severe slowdowns. + // See https://connect.microsoft.com/IE/feedback/details/1736512/ + rnoInnerhtml = / + + {% block head %} + {% endblock %} + + + + + + + + + + + + Home + Aktuelles + Info + Team + + + + + + +{% block content %} +{% endblock %} + + + + {% block scr %} + {% endblock %} + +