<!DOCTYPE html>
<html>
<head><meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0">

<title>demo_tetris</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script>




<style type="text/css">
    pre { line-height: 125%; }
td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
.highlight .hll { background-color: var(--jp-cell-editor-active-background) }
.highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) }
.highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */
.highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */
.highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */
.highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */
.highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */
.highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */
.highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */
.highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */
.highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */
.highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */
.highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */
.highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */
.highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */
.highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */
.highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */
.highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */
.highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */
.highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */
.highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */
.highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */
.highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */
.highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */
.highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */
.highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */
.highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */
.highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */
.highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */
.highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */
.highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */
.highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */
.highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */
.highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */
.highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */
.highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */
.highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */
.highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */
.highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */
.highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */
.highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */
.highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */
  </style>



<style type="text/css">
/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*
 * Mozilla scrollbar styling
 */

/* use standard opaque scrollbars for most nodes */
[data-jp-theme-scrollbars='true'] {
  scrollbar-color: rgb(var(--jp-scrollbar-thumb-color))
    var(--jp-scrollbar-background-color);
}

/* for code nodes, use a transparent style of scrollbar. These selectors
 * will match lower in the tree, and so will override the above */
[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar,
[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar {
  scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
}

/* tiny scrollbar */

.jp-scrollbar-tiny {
  scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
  scrollbar-width: thin;
}

/*
 * Webkit scrollbar styling
 */

/* use standard opaque scrollbars for most nodes */

[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar,
[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-corner {
  background: var(--jp-scrollbar-background-color);
}

[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-thumb {
  background: rgb(var(--jp-scrollbar-thumb-color));
  border: var(--jp-scrollbar-thumb-margin) solid transparent;
  background-clip: content-box;
  border-radius: var(--jp-scrollbar-thumb-radius);
}

[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:horizontal {
  border-left: var(--jp-scrollbar-endpad) solid
    var(--jp-scrollbar-background-color);
  border-right: var(--jp-scrollbar-endpad) solid
    var(--jp-scrollbar-background-color);
}

[data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:vertical {
  border-top: var(--jp-scrollbar-endpad) solid
    var(--jp-scrollbar-background-color);
  border-bottom: var(--jp-scrollbar-endpad) solid
    var(--jp-scrollbar-background-color);
}

/* for code nodes, use a transparent style of scrollbar */

[data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar::-webkit-scrollbar,
[data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar::-webkit-scrollbar,
[data-jp-theme-scrollbars='true']
  .CodeMirror-hscrollbar::-webkit-scrollbar-corner,
[data-jp-theme-scrollbars='true']
  .CodeMirror-vscrollbar::-webkit-scrollbar-corner {
  background-color: transparent;
}

[data-jp-theme-scrollbars='true']
  .CodeMirror-hscrollbar::-webkit-scrollbar-thumb,
[data-jp-theme-scrollbars='true']
  .CodeMirror-vscrollbar::-webkit-scrollbar-thumb {
  background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
  border: var(--jp-scrollbar-thumb-margin) solid transparent;
  background-clip: content-box;
  border-radius: var(--jp-scrollbar-thumb-radius);
}

[data-jp-theme-scrollbars='true']
  .CodeMirror-hscrollbar::-webkit-scrollbar-track:horizontal {
  border-left: var(--jp-scrollbar-endpad) solid transparent;
  border-right: var(--jp-scrollbar-endpad) solid transparent;
}

[data-jp-theme-scrollbars='true']
  .CodeMirror-vscrollbar::-webkit-scrollbar-track:vertical {
  border-top: var(--jp-scrollbar-endpad) solid transparent;
  border-bottom: var(--jp-scrollbar-endpad) solid transparent;
}

/* tiny scrollbar */

.jp-scrollbar-tiny::-webkit-scrollbar,
.jp-scrollbar-tiny::-webkit-scrollbar-corner {
  background-color: transparent;
  height: 4px;
  width: 4px;
}

.jp-scrollbar-tiny::-webkit-scrollbar-thumb {
  background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
}

.jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal {
  border-left: 0px solid transparent;
  border-right: 0px solid transparent;
}

.jp-scrollbar-tiny::-webkit-scrollbar-track:vertical {
  border-top: 0px solid transparent;
  border-bottom: 0px solid transparent;
}

/*
 * Phosphor
 */

.lm-ScrollBar[data-orientation='horizontal'] {
  min-height: 16px;
  max-height: 16px;
  min-width: 45px;
  border-top: 1px solid #a0a0a0;
}

.lm-ScrollBar[data-orientation='vertical'] {
  min-width: 16px;
  max-width: 16px;
  min-height: 45px;
  border-left: 1px solid #a0a0a0;
}

.lm-ScrollBar-button {
  background-color: #f0f0f0;
  background-position: center center;
  min-height: 15px;
  max-height: 15px;
  min-width: 15px;
  max-width: 15px;
}

.lm-ScrollBar-button:hover {
  background-color: #dadada;
}

.lm-ScrollBar-button.lm-mod-active {
  background-color: #cdcdcd;
}

.lm-ScrollBar-track {
  background: #f0f0f0;
}

.lm-ScrollBar-thumb {
  background: #cdcdcd;
}

.lm-ScrollBar-thumb:hover {
  background: #bababa;
}

.lm-ScrollBar-thumb.lm-mod-active {
  background: #a0a0a0;
}

.lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb {
  height: 100%;
  min-width: 15px;
  border-left: 1px solid #a0a0a0;
  border-right: 1px solid #a0a0a0;
}

.lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb {
  width: 100%;
  min-height: 15px;
  border-top: 1px solid #a0a0a0;
  border-bottom: 1px solid #a0a0a0;
}

.lm-ScrollBar[data-orientation='horizontal']
  .lm-ScrollBar-button[data-action='decrement'] {
  background-image: var(--jp-icon-caret-left);
  background-size: 17px;
}

.lm-ScrollBar[data-orientation='horizontal']
  .lm-ScrollBar-button[data-action='increment'] {
  background-image: var(--jp-icon-caret-right);
  background-size: 17px;
}

.lm-ScrollBar[data-orientation='vertical']
  .lm-ScrollBar-button[data-action='decrement'] {
  background-image: var(--jp-icon-caret-up);
  background-size: 17px;
}

.lm-ScrollBar[data-orientation='vertical']
  .lm-ScrollBar-button[data-action='increment'] {
  background-image: var(--jp-icon-caret-down);
  background-size: 17px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-Widget, /* </DEPRECATED> */
.lm-Widget {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  cursor: default;
}


/* <DEPRECATED> */ .p-Widget.p-mod-hidden, /* </DEPRECATED> */
.lm-Widget.lm-mod-hidden {
  display: none !important;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-CommandPalette, /* </DEPRECATED> */
.lm-CommandPalette {
  display: flex;
  flex-direction: column;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}


/* <DEPRECATED> */ .p-CommandPalette-search, /* </DEPRECATED> */
.lm-CommandPalette-search {
  flex: 0 0 auto;
}


/* <DEPRECATED> */ .p-CommandPalette-content, /* </DEPRECATED> */
.lm-CommandPalette-content {
  flex: 1 1 auto;
  margin: 0;
  padding: 0;
  min-height: 0;
  overflow: auto;
  list-style-type: none;
}


/* <DEPRECATED> */ .p-CommandPalette-header, /* </DEPRECATED> */
.lm-CommandPalette-header {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}


/* <DEPRECATED> */ .p-CommandPalette-item, /* </DEPRECATED> */
.lm-CommandPalette-item {
  display: flex;
  flex-direction: row;
}


/* <DEPRECATED> */ .p-CommandPalette-itemIcon, /* </DEPRECATED> */
.lm-CommandPalette-itemIcon {
  flex: 0 0 auto;
}


/* <DEPRECATED> */ .p-CommandPalette-itemContent, /* </DEPRECATED> */
.lm-CommandPalette-itemContent {
  flex: 1 1 auto;
  overflow: hidden;
}


/* <DEPRECATED> */ .p-CommandPalette-itemShortcut, /* </DEPRECATED> */
.lm-CommandPalette-itemShortcut {
  flex: 0 0 auto;
}


/* <DEPRECATED> */ .p-CommandPalette-itemLabel, /* </DEPRECATED> */
.lm-CommandPalette-itemLabel {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.lm-close-icon {
	border:1px solid transparent;
  background-color: transparent;
  position: absolute;
	z-index:1;
	right:3%;
	top: 0;
	bottom: 0;
	margin: auto;
	padding: 7px 0;
	display: none;
	vertical-align: middle;
  outline: 0;
  cursor: pointer;
}
.lm-close-icon:after {
	content: "X";
	display: block;
	width: 15px;
	height: 15px;
	text-align: center;
	color:#000;
	font-weight: normal;
	font-size: 12px;
	cursor: pointer;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-DockPanel, /* </DEPRECATED> */
.lm-DockPanel {
  z-index: 0;
}


/* <DEPRECATED> */ .p-DockPanel-widget, /* </DEPRECATED> */
.lm-DockPanel-widget {
  z-index: 0;
}


/* <DEPRECATED> */ .p-DockPanel-tabBar, /* </DEPRECATED> */
.lm-DockPanel-tabBar {
  z-index: 1;
}


/* <DEPRECATED> */ .p-DockPanel-handle, /* </DEPRECATED> */
.lm-DockPanel-handle {
  z-index: 2;
}


/* <DEPRECATED> */ .p-DockPanel-handle.p-mod-hidden, /* </DEPRECATED> */
.lm-DockPanel-handle.lm-mod-hidden {
  display: none !important;
}


/* <DEPRECATED> */ .p-DockPanel-handle:after, /* </DEPRECATED> */
.lm-DockPanel-handle:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
}


/* <DEPRECATED> */
.p-DockPanel-handle[data-orientation='horizontal'],
/* </DEPRECATED> */
.lm-DockPanel-handle[data-orientation='horizontal'] {
  cursor: ew-resize;
}


/* <DEPRECATED> */
.p-DockPanel-handle[data-orientation='vertical'],
/* </DEPRECATED> */
.lm-DockPanel-handle[data-orientation='vertical'] {
  cursor: ns-resize;
}


/* <DEPRECATED> */
.p-DockPanel-handle[data-orientation='horizontal']:after,
/* </DEPRECATED> */
.lm-DockPanel-handle[data-orientation='horizontal']:after {
  left: 50%;
  min-width: 8px;
  transform: translateX(-50%);
}


/* <DEPRECATED> */
.p-DockPanel-handle[data-orientation='vertical']:after,
/* </DEPRECATED> */
.lm-DockPanel-handle[data-orientation='vertical']:after {
  top: 50%;
  min-height: 8px;
  transform: translateY(-50%);
}


/* <DEPRECATED> */ .p-DockPanel-overlay, /* </DEPRECATED> */
.lm-DockPanel-overlay {
  z-index: 3;
  box-sizing: border-box;
  pointer-events: none;
}


/* <DEPRECATED> */ .p-DockPanel-overlay.p-mod-hidden, /* </DEPRECATED> */
.lm-DockPanel-overlay.lm-mod-hidden {
  display: none !important;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-Menu, /* </DEPRECATED> */
.lm-Menu {
  z-index: 10000;
  position: absolute;
  white-space: nowrap;
  overflow-x: hidden;
  overflow-y: auto;
  outline: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}


/* <DEPRECATED> */ .p-Menu-content, /* </DEPRECATED> */
.lm-Menu-content {
  margin: 0;
  padding: 0;
  display: table;
  list-style-type: none;
}


/* <DEPRECATED> */ .p-Menu-item, /* </DEPRECATED> */
.lm-Menu-item {
  display: table-row;
}


/* <DEPRECATED> */
.p-Menu-item.p-mod-hidden,
.p-Menu-item.p-mod-collapsed,
/* </DEPRECATED> */
.lm-Menu-item.lm-mod-hidden,
.lm-Menu-item.lm-mod-collapsed {
  display: none !important;
}


/* <DEPRECATED> */
.p-Menu-itemIcon,
.p-Menu-itemSubmenuIcon,
/* </DEPRECATED> */
.lm-Menu-itemIcon,
.lm-Menu-itemSubmenuIcon {
  display: table-cell;
  text-align: center;
}


/* <DEPRECATED> */ .p-Menu-itemLabel, /* </DEPRECATED> */
.lm-Menu-itemLabel {
  display: table-cell;
  text-align: left;
}


/* <DEPRECATED> */ .p-Menu-itemShortcut, /* </DEPRECATED> */
.lm-Menu-itemShortcut {
  display: table-cell;
  text-align: right;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-MenuBar, /* </DEPRECATED> */
.lm-MenuBar {
  outline: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}


/* <DEPRECATED> */ .p-MenuBar-content, /* </DEPRECATED> */
.lm-MenuBar-content {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  list-style-type: none;
}


/* <DEPRECATED> */ .p--MenuBar-item, /* </DEPRECATED> */
.lm-MenuBar-item {
  box-sizing: border-box;
}


/* <DEPRECATED> */
.p-MenuBar-itemIcon,
.p-MenuBar-itemLabel,
/* </DEPRECATED> */
.lm-MenuBar-itemIcon,
.lm-MenuBar-itemLabel {
  display: inline-block;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-ScrollBar, /* </DEPRECATED> */
.lm-ScrollBar {
  display: flex;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}


/* <DEPRECATED> */
.p-ScrollBar[data-orientation='horizontal'],
/* </DEPRECATED> */
.lm-ScrollBar[data-orientation='horizontal'] {
  flex-direction: row;
}


/* <DEPRECATED> */
.p-ScrollBar[data-orientation='vertical'],
/* </DEPRECATED> */
.lm-ScrollBar[data-orientation='vertical'] {
  flex-direction: column;
}


/* <DEPRECATED> */ .p-ScrollBar-button, /* </DEPRECATED> */
.lm-ScrollBar-button {
  box-sizing: border-box;
  flex: 0 0 auto;
}


/* <DEPRECATED> */ .p-ScrollBar-track, /* </DEPRECATED> */
.lm-ScrollBar-track {
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  flex: 1 1 auto;
}


/* <DEPRECATED> */ .p-ScrollBar-thumb, /* </DEPRECATED> */
.lm-ScrollBar-thumb {
  box-sizing: border-box;
  position: absolute;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-SplitPanel-child, /* </DEPRECATED> */
.lm-SplitPanel-child {
  z-index: 0;
}


/* <DEPRECATED> */ .p-SplitPanel-handle, /* </DEPRECATED> */
.lm-SplitPanel-handle {
  z-index: 1;
}


/* <DEPRECATED> */ .p-SplitPanel-handle.p-mod-hidden, /* </DEPRECATED> */
.lm-SplitPanel-handle.lm-mod-hidden {
  display: none !important;
}


/* <DEPRECATED> */ .p-SplitPanel-handle:after, /* </DEPRECATED> */
.lm-SplitPanel-handle:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
}


/* <DEPRECATED> */
.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle,
/* </DEPRECATED> */
.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle {
  cursor: ew-resize;
}


/* <DEPRECATED> */
.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle,
/* </DEPRECATED> */
.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle {
  cursor: ns-resize;
}


/* <DEPRECATED> */
.p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle:after,
/* </DEPRECATED> */
.lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after {
  left: 50%;
  min-width: 8px;
  transform: translateX(-50%);
}


/* <DEPRECATED> */
.p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle:after,
/* </DEPRECATED> */
.lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after {
  top: 50%;
  min-height: 8px;
  transform: translateY(-50%);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-TabBar, /* </DEPRECATED> */
.lm-TabBar {
  display: flex;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}


/* <DEPRECATED> */ .p-TabBar[data-orientation='horizontal'], /* </DEPRECATED> */
.lm-TabBar[data-orientation='horizontal'] {
  flex-direction: row;
}


/* <DEPRECATED> */ .p-TabBar[data-orientation='vertical'], /* </DEPRECATED> */
.lm-TabBar[data-orientation='vertical'] {
  flex-direction: column;
}


/* <DEPRECATED> */ .p-TabBar-content, /* </DEPRECATED> */
.lm-TabBar-content {
  margin: 0;
  padding: 0;
  display: flex;
  flex: 1 1 auto;
  list-style-type: none;
}


/* <DEPRECATED> */
.p-TabBar[data-orientation='horizontal'] > .p-TabBar-content,
/* </DEPRECATED> */
.lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content {
  flex-direction: row;
}


/* <DEPRECATED> */
.p-TabBar[data-orientation='vertical'] > .p-TabBar-content,
/* </DEPRECATED> */
.lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content {
  flex-direction: column;
}


/* <DEPRECATED> */ .p-TabBar-tab, /* </DEPRECATED> */
.lm-TabBar-tab {
  display: flex;
  flex-direction: row;
  box-sizing: border-box;
  overflow: hidden;
}


/* <DEPRECATED> */
.p-TabBar-tabIcon,
.p-TabBar-tabCloseIcon,
/* </DEPRECATED> */
.lm-TabBar-tabIcon,
.lm-TabBar-tabCloseIcon {
  flex: 0 0 auto;
}


/* <DEPRECATED> */ .p-TabBar-tabLabel, /* </DEPRECATED> */
.lm-TabBar-tabLabel {
  flex: 1 1 auto;
  overflow: hidden;
  white-space: nowrap;
}


.lm-TabBar-tabInput {
  user-select: all;
  width: 100%;
  box-sizing : border-box;
}


/* <DEPRECATED> */ .p-TabBar-tab.p-mod-hidden, /* </DEPRECATED> */
.lm-TabBar-tab.lm-mod-hidden {
  display: none !important;
}


/* <DEPRECATED> */ .p-TabBar.p-mod-dragging .p-TabBar-tab, /* </DEPRECATED> */
.lm-TabBar.lm-mod-dragging .lm-TabBar-tab {
  position: relative;
}


/* <DEPRECATED> */
.p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab,
/* </DEPRECATED> */
.lm-TabBar.lm-mod-dragging[data-orientation='horizontal'] .lm-TabBar-tab {
  left: 0;
  transition: left 150ms ease;
}


/* <DEPRECATED> */
.p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab,
/* </DEPRECATED> */
.lm-TabBar.lm-mod-dragging[data-orientation='vertical'] .lm-TabBar-tab {
  top: 0;
  transition: top 150ms ease;
}


/* <DEPRECATED> */
.p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging,
/* </DEPRECATED> */
.lm-TabBar.lm-mod-dragging .lm-TabBar-tab.lm-mod-dragging {
  transition: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ .p-TabPanel-tabBar, /* </DEPRECATED> */
.lm-TabPanel-tabBar {
  z-index: 1;
}


/* <DEPRECATED> */ .p-TabPanel-stackedPanel, /* </DEPRECATED> */
.lm-TabPanel-stackedPanel {
  z-index: 0;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/

@charset "UTF-8";
html{
  -webkit-box-sizing:border-box;
          box-sizing:border-box; }

*,
*::before,
*::after{
  -webkit-box-sizing:inherit;
          box-sizing:inherit; }

body{
  font-size:14px;
  font-weight:400;
  letter-spacing:0;
  line-height:1.28581;
  text-transform:none;
  color:#182026;
  font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; }

p{
  margin-bottom:10px;
  margin-top:0; }

small{
  font-size:12px; }

strong{
  font-weight:600; }

::-moz-selection{
  background:rgba(125, 188, 255, 0.6); }

::selection{
  background:rgba(125, 188, 255, 0.6); }
.bp3-heading{
  color:#182026;
  font-weight:600;
  margin:0 0 10px;
  padding:0; }
  .bp3-dark .bp3-heading{
    color:#f5f8fa; }

h1.bp3-heading, .bp3-running-text h1{
  font-size:36px;
  line-height:40px; }

h2.bp3-heading, .bp3-running-text h2{
  font-size:28px;
  line-height:32px; }

h3.bp3-heading, .bp3-running-text h3{
  font-size:22px;
  line-height:25px; }

h4.bp3-heading, .bp3-running-text h4{
  font-size:18px;
  line-height:21px; }

h5.bp3-heading, .bp3-running-text h5{
  font-size:16px;
  line-height:19px; }

h6.bp3-heading, .bp3-running-text h6{
  font-size:14px;
  line-height:16px; }
.bp3-ui-text{
  font-size:14px;
  font-weight:400;
  letter-spacing:0;
  line-height:1.28581;
  text-transform:none; }

.bp3-monospace-text{
  font-family:monospace;
  text-transform:none; }

.bp3-text-muted{
  color:#5c7080; }
  .bp3-dark .bp3-text-muted{
    color:#a7b6c2; }

.bp3-text-disabled{
  color:rgba(92, 112, 128, 0.6); }
  .bp3-dark .bp3-text-disabled{
    color:rgba(167, 182, 194, 0.6); }

.bp3-text-overflow-ellipsis{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  word-wrap:normal; }
.bp3-running-text{
  font-size:14px;
  line-height:1.5; }
  .bp3-running-text h1{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h1{
      color:#f5f8fa; }
  .bp3-running-text h2{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h2{
      color:#f5f8fa; }
  .bp3-running-text h3{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h3{
      color:#f5f8fa; }
  .bp3-running-text h4{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h4{
      color:#f5f8fa; }
  .bp3-running-text h5{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h5{
      color:#f5f8fa; }
  .bp3-running-text h6{
    color:#182026;
    font-weight:600;
    margin-bottom:20px;
    margin-top:40px; }
    .bp3-dark .bp3-running-text h6{
      color:#f5f8fa; }
  .bp3-running-text hr{
    border:none;
    border-bottom:1px solid rgba(16, 22, 26, 0.15);
    margin:20px 0; }
    .bp3-dark .bp3-running-text hr{
      border-color:rgba(255, 255, 255, 0.15); }
  .bp3-running-text p{
    margin:0 0 10px;
    padding:0; }

.bp3-text-large{
  font-size:16px; }

.bp3-text-small{
  font-size:12px; }
a{
  color:#106ba3;
  text-decoration:none; }
  a:hover{
    color:#106ba3;
    cursor:pointer;
    text-decoration:underline; }
  a .bp3-icon, a .bp3-icon-standard, a .bp3-icon-large{
    color:inherit; }
  a code,
  .bp3-dark a code{
    color:inherit; }
  .bp3-dark a,
  .bp3-dark a:hover{
    color:#48aff0; }
    .bp3-dark a .bp3-icon, .bp3-dark a .bp3-icon-standard, .bp3-dark a .bp3-icon-large,
    .bp3-dark a:hover .bp3-icon,
    .bp3-dark a:hover .bp3-icon-standard,
    .bp3-dark a:hover .bp3-icon-large{
      color:inherit; }
.bp3-running-text code, .bp3-code{
  font-family:monospace;
  text-transform:none;
  background:rgba(255, 255, 255, 0.7);
  border-radius:3px;
  -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2);
          box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2);
  color:#5c7080;
  font-size:smaller;
  padding:2px 5px; }
  .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{
    background:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
    color:#a7b6c2; }
  .bp3-running-text a > code, a > .bp3-code{
    color:#137cbd; }
    .bp3-dark .bp3-running-text a > code, .bp3-running-text .bp3-dark a > code, .bp3-dark a > .bp3-code{
      color:inherit; }

.bp3-running-text pre, .bp3-code-block{
  font-family:monospace;
  text-transform:none;
  background:rgba(255, 255, 255, 0.7);
  border-radius:3px;
  -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
          box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
  color:#182026;
  display:block;
  font-size:13px;
  line-height:1.4;
  margin:10px 0;
  padding:13px 15px 12px;
  word-break:break-all;
  word-wrap:break-word; }
  .bp3-dark .bp3-running-text pre, .bp3-running-text .bp3-dark pre, .bp3-dark .bp3-code-block{
    background:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }
  .bp3-running-text pre > code, .bp3-code-block > code{
    background:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    color:inherit;
    font-size:inherit;
    padding:0; }

.bp3-running-text kbd, .bp3-key{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  background:#ffffff;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
  color:#5c7080;
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex;
  font-family:inherit;
  font-size:12px;
  height:24px;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  line-height:24px;
  min-width:24px;
  padding:3px 6px;
  vertical-align:middle; }
  .bp3-running-text kbd .bp3-icon, .bp3-key .bp3-icon, .bp3-running-text kbd .bp3-icon-standard, .bp3-key .bp3-icon-standard, .bp3-running-text kbd .bp3-icon-large, .bp3-key .bp3-icon-large{
    margin-right:5px; }
  .bp3-dark .bp3-running-text kbd, .bp3-running-text .bp3-dark kbd, .bp3-dark .bp3-key{
    background:#394b59;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
    color:#a7b6c2; }
.bp3-running-text blockquote, .bp3-blockquote{
  border-left:solid 4px rgba(167, 182, 194, 0.5);
  margin:0 0 10px;
  padding:0 20px; }
  .bp3-dark .bp3-running-text blockquote, .bp3-running-text .bp3-dark blockquote, .bp3-dark .bp3-blockquote{
    border-color:rgba(115, 134, 148, 0.5); }
.bp3-running-text ul,
.bp3-running-text ol, .bp3-list{
  margin:10px 0;
  padding-left:30px; }
  .bp3-running-text ul li:not(:last-child), .bp3-running-text ol li:not(:last-child), .bp3-list li:not(:last-child){
    margin-bottom:5px; }
  .bp3-running-text ul ol, .bp3-running-text ol ol, .bp3-list ol,
  .bp3-running-text ul ul,
  .bp3-running-text ol ul,
  .bp3-list ul{
    margin-top:5px; }

.bp3-list-unstyled{
  list-style:none;
  margin:0;
  padding:0; }
  .bp3-list-unstyled li{
    padding:0; }
.bp3-rtl{
  text-align:right; }

.bp3-dark{
  color:#f5f8fa; }

:focus{
  outline:rgba(19, 124, 189, 0.6) auto 2px;
  outline-offset:2px;
  -moz-outline-radius:6px; }

.bp3-focus-disabled :focus{
  outline:none !important; }
  .bp3-focus-disabled :focus ~ .bp3-control-indicator{
    outline:none !important; }

.bp3-alert{
  max-width:400px;
  padding:20px; }

.bp3-alert-body{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex; }
  .bp3-alert-body .bp3-icon{
    font-size:40px;
    margin-right:20px;
    margin-top:0; }

.bp3-alert-contents{
  word-break:break-word; }

.bp3-alert-footer{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:reverse;
      -ms-flex-direction:row-reverse;
          flex-direction:row-reverse;
  margin-top:10px; }
  .bp3-alert-footer .bp3-button{
    margin-left:10px; }
.bp3-breadcrumbs{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  cursor:default;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-wrap:wrap;
      flex-wrap:wrap;
  height:30px;
  list-style:none;
  margin:0;
  padding:0; }
  .bp3-breadcrumbs > li{
    -webkit-box-align:center;
        -ms-flex-align:center;
            align-items:center;
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex; }
    .bp3-breadcrumbs > li::after{
      background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.71 7.29l-4-4a1.003 1.003 0 00-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 001.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e");
      content:"";
      display:block;
      height:16px;
      margin:0 5px;
      width:16px; }
    .bp3-breadcrumbs > li:last-of-type::after{
      display:none; }

.bp3-breadcrumb,
.bp3-breadcrumb-current,
.bp3-breadcrumbs-collapsed{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex;
  font-size:16px; }

.bp3-breadcrumb,
.bp3-breadcrumbs-collapsed{
  color:#5c7080; }

.bp3-breadcrumb:hover{
  text-decoration:none; }

.bp3-breadcrumb.bp3-disabled{
  color:rgba(92, 112, 128, 0.6);
  cursor:not-allowed; }

.bp3-breadcrumb .bp3-icon{
  margin-right:5px; }

.bp3-breadcrumb-current{
  color:inherit;
  font-weight:600; }
  .bp3-breadcrumb-current .bp3-input{
    font-size:inherit;
    font-weight:inherit;
    vertical-align:baseline; }

.bp3-breadcrumbs-collapsed{
  background:#ced9e0;
  border:none;
  border-radius:3px;
  cursor:pointer;
  margin-right:2px;
  padding:1px 5px;
  vertical-align:text-bottom; }
  .bp3-breadcrumbs-collapsed::before{
    background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cg fill='%235C7080'%3e%3ccircle cx='2' cy='8.03' r='2'/%3e%3ccircle cx='14' cy='8.03' r='2'/%3e%3ccircle cx='8' cy='8.03' r='2'/%3e%3c/g%3e%3c/svg%3e") center no-repeat;
    content:"";
    display:block;
    height:16px;
    width:16px; }
  .bp3-breadcrumbs-collapsed:hover{
    background:#bfccd6;
    color:#182026;
    text-decoration:none; }

.bp3-dark .bp3-breadcrumb,
.bp3-dark .bp3-breadcrumbs-collapsed{
  color:#a7b6c2; }

.bp3-dark .bp3-breadcrumbs > li::after{
  color:#a7b6c2; }

.bp3-dark .bp3-breadcrumb.bp3-disabled{
  color:rgba(167, 182, 194, 0.6); }

.bp3-dark .bp3-breadcrumb-current{
  color:#f5f8fa; }

.bp3-dark .bp3-breadcrumbs-collapsed{
  background:rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-breadcrumbs-collapsed:hover{
    background:rgba(16, 22, 26, 0.6);
    color:#f5f8fa; }
.bp3-button{
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  border:none;
  border-radius:3px;
  cursor:pointer;
  font-size:14px;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  padding:5px 10px;
  text-align:left;
  vertical-align:middle;
  min-height:30px;
  min-width:30px; }
  .bp3-button > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-button > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-button::before,
  .bp3-button > *{
    margin-right:7px; }
  .bp3-button:empty::before,
  .bp3-button > :last-child{
    margin-right:0; }
  .bp3-button:empty{
    padding:0 !important; }
  .bp3-button:disabled, .bp3-button.bp3-disabled{
    cursor:not-allowed; }
  .bp3-button.bp3-fill{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    width:100%; }
  .bp3-button.bp3-align-right,
  .bp3-align-right .bp3-button{
    text-align:right; }
  .bp3-button.bp3-align-left,
  .bp3-align-left .bp3-button{
    text-align:left; }
  .bp3-button:not([class*="bp3-intent-"]){
    background-color:#f5f8fa;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
    color:#182026; }
    .bp3-button:not([class*="bp3-intent-"]):hover{
      background-clip:padding-box;
      background-color:#ebf1f5;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
    .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{
      background-color:#d8e1e8;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
      background-color:rgba(206, 217, 224, 0.5);
      background-image:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed;
      outline:none; }
      .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active:hover, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active:hover{
        background:rgba(206, 217, 224, 0.7); }
  .bp3-button.bp3-intent-primary{
    background-color:#137cbd;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
    .bp3-button.bp3-intent-primary:hover, .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{
      color:#ffffff; }
    .bp3-button.bp3-intent-primary:hover{
      background-color:#106ba3;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{
      background-color:#0e5a8a;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{
      background-color:rgba(19, 124, 189, 0.5);
      background-image:none;
      border-color:transparent;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(255, 255, 255, 0.6); }
  .bp3-button.bp3-intent-success{
    background-color:#0f9960;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
    .bp3-button.bp3-intent-success:hover, .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{
      color:#ffffff; }
    .bp3-button.bp3-intent-success:hover{
      background-color:#0d8050;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{
      background-color:#0a6640;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{
      background-color:rgba(15, 153, 96, 0.5);
      background-image:none;
      border-color:transparent;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(255, 255, 255, 0.6); }
  .bp3-button.bp3-intent-warning{
    background-color:#d9822b;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
    .bp3-button.bp3-intent-warning:hover, .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{
      color:#ffffff; }
    .bp3-button.bp3-intent-warning:hover{
      background-color:#bf7326;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{
      background-color:#a66321;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{
      background-color:rgba(217, 130, 43, 0.5);
      background-image:none;
      border-color:transparent;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(255, 255, 255, 0.6); }
  .bp3-button.bp3-intent-danger{
    background-color:#db3737;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
    .bp3-button.bp3-intent-danger:hover, .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{
      color:#ffffff; }
    .bp3-button.bp3-intent-danger:hover{
      background-color:#c23030;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{
      background-color:#a82a2a;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{
      background-color:rgba(219, 55, 55, 0.5);
      background-image:none;
      border-color:transparent;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(255, 255, 255, 0.6); }
  .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{
    stroke:#ffffff; }
  .bp3-button.bp3-large,
  .bp3-large .bp3-button{
    min-height:40px;
    min-width:40px;
    font-size:16px;
    padding:5px 15px; }
    .bp3-button.bp3-large::before,
    .bp3-button.bp3-large > *,
    .bp3-large .bp3-button::before,
    .bp3-large .bp3-button > *{
      margin-right:10px; }
    .bp3-button.bp3-large:empty::before,
    .bp3-button.bp3-large > :last-child,
    .bp3-large .bp3-button:empty::before,
    .bp3-large .bp3-button > :last-child{
      margin-right:0; }
  .bp3-button.bp3-small,
  .bp3-small .bp3-button{
    min-height:24px;
    min-width:24px;
    padding:0 7px; }
  .bp3-button.bp3-loading{
    position:relative; }
    .bp3-button.bp3-loading[class*="bp3-icon-"]::before{
      visibility:hidden; }
    .bp3-button.bp3-loading .bp3-button-spinner{
      margin:0;
      position:absolute; }
    .bp3-button.bp3-loading > :not(.bp3-button-spinner){
      visibility:hidden; }
  .bp3-button[class*="bp3-icon-"]::before{
    font-family:"Icons16", sans-serif;
    font-size:16px;
    font-style:normal;
    font-weight:400;
    line-height:1;
    -moz-osx-font-smoothing:grayscale;
    -webkit-font-smoothing:antialiased;
    color:#5c7080; }
  .bp3-button .bp3-icon, .bp3-button .bp3-icon-standard, .bp3-button .bp3-icon-large{
    color:#5c7080; }
    .bp3-button .bp3-icon.bp3-align-right, .bp3-button .bp3-icon-standard.bp3-align-right, .bp3-button .bp3-icon-large.bp3-align-right{
      margin-left:7px; }
  .bp3-button .bp3-icon:first-child:last-child,
  .bp3-button .bp3-spinner + .bp3-icon:last-child{
    margin:0 -7px; }
  .bp3-dark .bp3-button:not([class*="bp3-intent-"]){
    background-color:#394b59;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover, .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{
      color:#f5f8fa; }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover{
      background-color:#30404d;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{
      background-color:#202b33;
      background-image:none;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
      background-color:rgba(57, 75, 89, 0.5);
      background-image:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(167, 182, 194, 0.6); }
      .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active{
        background:rgba(57, 75, 89, 0.7); }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-button-spinner .bp3-spinner-head{
      background:rgba(16, 22, 26, 0.5);
      stroke:#8a9ba8; }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"])[class*="bp3-icon-"]::before{
      color:#a7b6c2; }
    .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-large{
      color:#a7b6c2; }
  .bp3-dark .bp3-button[class*="bp3-intent-"]{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-button[class*="bp3-intent-"]:hover{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-button[class*="bp3-intent-"]:active, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-active{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-dark .bp3-button[class*="bp3-intent-"]:disabled, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-disabled{
      background-image:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(255, 255, 255, 0.3); }
    .bp3-dark .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{
      stroke:#8a9ba8; }
  .bp3-button:disabled::before,
  .bp3-button:disabled .bp3-icon, .bp3-button:disabled .bp3-icon-standard, .bp3-button:disabled .bp3-icon-large, .bp3-button.bp3-disabled::before,
  .bp3-button.bp3-disabled .bp3-icon, .bp3-button.bp3-disabled .bp3-icon-standard, .bp3-button.bp3-disabled .bp3-icon-large, .bp3-button[class*="bp3-intent-"]::before,
  .bp3-button[class*="bp3-intent-"] .bp3-icon, .bp3-button[class*="bp3-intent-"] .bp3-icon-standard, .bp3-button[class*="bp3-intent-"] .bp3-icon-large{
    color:inherit !important; }
  .bp3-button.bp3-minimal{
    background:none;
    -webkit-box-shadow:none;
            box-shadow:none; }
    .bp3-button.bp3-minimal:hover{
      background:rgba(167, 182, 194, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026;
      text-decoration:none; }
    .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{
      background:rgba(115, 134, 148, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026; }
    .bp3-button.bp3-minimal:disabled, .bp3-button.bp3-minimal:disabled:hover, .bp3-button.bp3-minimal.bp3-disabled, .bp3-button.bp3-minimal.bp3-disabled:hover{
      background:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
      .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{
        background:rgba(115, 134, 148, 0.3); }
    .bp3-dark .bp3-button.bp3-minimal{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:inherit; }
      .bp3-dark .bp3-button.bp3-minimal:hover, .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-button.bp3-minimal:hover{
        background:rgba(138, 155, 168, 0.15); }
      .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{
        background:rgba(138, 155, 168, 0.3);
        color:#f5f8fa; }
      .bp3-dark .bp3-button.bp3-minimal:disabled, .bp3-dark .bp3-button.bp3-minimal:disabled:hover, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover{
        background:none;
        color:rgba(167, 182, 194, 0.6);
        cursor:not-allowed; }
        .bp3-dark .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{
          background:rgba(138, 155, 168, 0.3); }
    .bp3-button.bp3-minimal.bp3-intent-primary{
      color:#106ba3; }
      .bp3-button.bp3-minimal.bp3-intent-primary:hover, .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#106ba3; }
      .bp3-button.bp3-minimal.bp3-intent-primary:hover{
        background:rgba(19, 124, 189, 0.15);
        color:#106ba3; }
      .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
        background:rgba(19, 124, 189, 0.3);
        color:#106ba3; }
      .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{
        background:none;
        color:rgba(16, 107, 163, 0.5); }
        .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{
          background:rgba(19, 124, 189, 0.3); }
      .bp3-button.bp3-minimal.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
        stroke:#106ba3; }
      .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary{
        color:#48aff0; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:hover{
          background:rgba(19, 124, 189, 0.2);
          color:#48aff0; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
          background:rgba(19, 124, 189, 0.3);
          color:#48aff0; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{
          background:none;
          color:rgba(72, 175, 240, 0.5); }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{
            background:rgba(19, 124, 189, 0.3); }
    .bp3-button.bp3-minimal.bp3-intent-success{
      color:#0d8050; }
      .bp3-button.bp3-minimal.bp3-intent-success:hover, .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#0d8050; }
      .bp3-button.bp3-minimal.bp3-intent-success:hover{
        background:rgba(15, 153, 96, 0.15);
        color:#0d8050; }
      .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
        background:rgba(15, 153, 96, 0.3);
        color:#0d8050; }
      .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{
        background:none;
        color:rgba(13, 128, 80, 0.5); }
        .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{
          background:rgba(15, 153, 96, 0.3); }
      .bp3-button.bp3-minimal.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
        stroke:#0d8050; }
      .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success{
        color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:hover{
          background:rgba(15, 153, 96, 0.2);
          color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
          background:rgba(15, 153, 96, 0.3);
          color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{
          background:none;
          color:rgba(61, 204, 145, 0.5); }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{
            background:rgba(15, 153, 96, 0.3); }
    .bp3-button.bp3-minimal.bp3-intent-warning{
      color:#bf7326; }
      .bp3-button.bp3-minimal.bp3-intent-warning:hover, .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#bf7326; }
      .bp3-button.bp3-minimal.bp3-intent-warning:hover{
        background:rgba(217, 130, 43, 0.15);
        color:#bf7326; }
      .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
        background:rgba(217, 130, 43, 0.3);
        color:#bf7326; }
      .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{
        background:none;
        color:rgba(191, 115, 38, 0.5); }
        .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{
          background:rgba(217, 130, 43, 0.3); }
      .bp3-button.bp3-minimal.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
        stroke:#bf7326; }
      .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning{
        color:#ffb366; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:hover{
          background:rgba(217, 130, 43, 0.2);
          color:#ffb366; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
          background:rgba(217, 130, 43, 0.3);
          color:#ffb366; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{
          background:none;
          color:rgba(255, 179, 102, 0.5); }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{
            background:rgba(217, 130, 43, 0.3); }
    .bp3-button.bp3-minimal.bp3-intent-danger{
      color:#c23030; }
      .bp3-button.bp3-minimal.bp3-intent-danger:hover, .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#c23030; }
      .bp3-button.bp3-minimal.bp3-intent-danger:hover{
        background:rgba(219, 55, 55, 0.15);
        color:#c23030; }
      .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
        background:rgba(219, 55, 55, 0.3);
        color:#c23030; }
      .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{
        background:none;
        color:rgba(194, 48, 48, 0.5); }
        .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{
          background:rgba(219, 55, 55, 0.3); }
      .bp3-button.bp3-minimal.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
        stroke:#c23030; }
      .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger{
        color:#ff7373; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:hover{
          background:rgba(219, 55, 55, 0.2);
          color:#ff7373; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
          background:rgba(219, 55, 55, 0.3);
          color:#ff7373; }
        .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{
          background:none;
          color:rgba(255, 115, 115, 0.5); }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{
            background:rgba(219, 55, 55, 0.3); }
  .bp3-button.bp3-outlined{
    background:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    border:1px solid rgba(24, 32, 38, 0.2);
    -webkit-box-sizing:border-box;
            box-sizing:border-box; }
    .bp3-button.bp3-outlined:hover{
      background:rgba(167, 182, 194, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026;
      text-decoration:none; }
    .bp3-button.bp3-outlined:active, .bp3-button.bp3-outlined.bp3-active{
      background:rgba(115, 134, 148, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026; }
    .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined.bp3-disabled:hover{
      background:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
      .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{
        background:rgba(115, 134, 148, 0.3); }
    .bp3-dark .bp3-button.bp3-outlined{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:inherit; }
      .bp3-dark .bp3-button.bp3-outlined:hover, .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-button.bp3-outlined:hover{
        background:rgba(138, 155, 168, 0.15); }
      .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{
        background:rgba(138, 155, 168, 0.3);
        color:#f5f8fa; }
      .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{
        background:none;
        color:rgba(167, 182, 194, 0.6);
        cursor:not-allowed; }
        .bp3-dark .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{
          background:rgba(138, 155, 168, 0.3); }
    .bp3-button.bp3-outlined.bp3-intent-primary{
      color:#106ba3; }
      .bp3-button.bp3-outlined.bp3-intent-primary:hover, .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#106ba3; }
      .bp3-button.bp3-outlined.bp3-intent-primary:hover{
        background:rgba(19, 124, 189, 0.15);
        color:#106ba3; }
      .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
        background:rgba(19, 124, 189, 0.3);
        color:#106ba3; }
      .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
        background:none;
        color:rgba(16, 107, 163, 0.5); }
        .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{
          background:rgba(19, 124, 189, 0.3); }
      .bp3-button.bp3-outlined.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
        stroke:#106ba3; }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{
        color:#48aff0; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:hover{
          background:rgba(19, 124, 189, 0.2);
          color:#48aff0; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
          background:rgba(19, 124, 189, 0.3);
          color:#48aff0; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
          background:none;
          color:rgba(72, 175, 240, 0.5); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{
            background:rgba(19, 124, 189, 0.3); }
    .bp3-button.bp3-outlined.bp3-intent-success{
      color:#0d8050; }
      .bp3-button.bp3-outlined.bp3-intent-success:hover, .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#0d8050; }
      .bp3-button.bp3-outlined.bp3-intent-success:hover{
        background:rgba(15, 153, 96, 0.15);
        color:#0d8050; }
      .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
        background:rgba(15, 153, 96, 0.3);
        color:#0d8050; }
      .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
        background:none;
        color:rgba(13, 128, 80, 0.5); }
        .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{
          background:rgba(15, 153, 96, 0.3); }
      .bp3-button.bp3-outlined.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
        stroke:#0d8050; }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{
        color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:hover{
          background:rgba(15, 153, 96, 0.2);
          color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
          background:rgba(15, 153, 96, 0.3);
          color:#3dcc91; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
          background:none;
          color:rgba(61, 204, 145, 0.5); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{
            background:rgba(15, 153, 96, 0.3); }
    .bp3-button.bp3-outlined.bp3-intent-warning{
      color:#bf7326; }
      .bp3-button.bp3-outlined.bp3-intent-warning:hover, .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#bf7326; }
      .bp3-button.bp3-outlined.bp3-intent-warning:hover{
        background:rgba(217, 130, 43, 0.15);
        color:#bf7326; }
      .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
        background:rgba(217, 130, 43, 0.3);
        color:#bf7326; }
      .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
        background:none;
        color:rgba(191, 115, 38, 0.5); }
        .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{
          background:rgba(217, 130, 43, 0.3); }
      .bp3-button.bp3-outlined.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
        stroke:#bf7326; }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{
        color:#ffb366; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:hover{
          background:rgba(217, 130, 43, 0.2);
          color:#ffb366; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
          background:rgba(217, 130, 43, 0.3);
          color:#ffb366; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
          background:none;
          color:rgba(255, 179, 102, 0.5); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{
            background:rgba(217, 130, 43, 0.3); }
    .bp3-button.bp3-outlined.bp3-intent-danger{
      color:#c23030; }
      .bp3-button.bp3-outlined.bp3-intent-danger:hover, .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#c23030; }
      .bp3-button.bp3-outlined.bp3-intent-danger:hover{
        background:rgba(219, 55, 55, 0.15);
        color:#c23030; }
      .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
        background:rgba(219, 55, 55, 0.3);
        color:#c23030; }
      .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
        background:none;
        color:rgba(194, 48, 48, 0.5); }
        .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{
          background:rgba(219, 55, 55, 0.3); }
      .bp3-button.bp3-outlined.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
        stroke:#c23030; }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{
        color:#ff7373; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:hover{
          background:rgba(219, 55, 55, 0.2);
          color:#ff7373; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
          background:rgba(219, 55, 55, 0.3);
          color:#ff7373; }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
          background:none;
          color:rgba(255, 115, 115, 0.5); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{
            background:rgba(219, 55, 55, 0.3); }
    .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled:hover{
      border-color:rgba(92, 112, 128, 0.1); }
    .bp3-dark .bp3-button.bp3-outlined{
      border-color:rgba(255, 255, 255, 0.4); }
      .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{
        border-color:rgba(255, 255, 255, 0.2); }
    .bp3-button.bp3-outlined.bp3-intent-primary{
      border-color:rgba(16, 107, 163, 0.6); }
      .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
        border-color:rgba(16, 107, 163, 0.2); }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{
        border-color:rgba(72, 175, 240, 0.6); }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
          border-color:rgba(72, 175, 240, 0.2); }
    .bp3-button.bp3-outlined.bp3-intent-success{
      border-color:rgba(13, 128, 80, 0.6); }
      .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
        border-color:rgba(13, 128, 80, 0.2); }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{
        border-color:rgba(61, 204, 145, 0.6); }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
          border-color:rgba(61, 204, 145, 0.2); }
    .bp3-button.bp3-outlined.bp3-intent-warning{
      border-color:rgba(191, 115, 38, 0.6); }
      .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
        border-color:rgba(191, 115, 38, 0.2); }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{
        border-color:rgba(255, 179, 102, 0.6); }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
          border-color:rgba(255, 179, 102, 0.2); }
    .bp3-button.bp3-outlined.bp3-intent-danger{
      border-color:rgba(194, 48, 48, 0.6); }
      .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
        border-color:rgba(194, 48, 48, 0.2); }
      .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{
        border-color:rgba(255, 115, 115, 0.6); }
        .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
          border-color:rgba(255, 115, 115, 0.2); }

a.bp3-button{
  text-align:center;
  text-decoration:none;
  -webkit-transition:none;
  transition:none; }
  a.bp3-button, a.bp3-button:hover, a.bp3-button:active{
    color:#182026; }
  a.bp3-button.bp3-disabled{
    color:rgba(92, 112, 128, 0.6); }

.bp3-button-text{
  -webkit-box-flex:0;
      -ms-flex:0 1 auto;
          flex:0 1 auto; }

.bp3-button.bp3-align-left .bp3-button-text, .bp3-button.bp3-align-right .bp3-button-text,
.bp3-button-group.bp3-align-left .bp3-button-text,
.bp3-button-group.bp3-align-right .bp3-button-text{
  -webkit-box-flex:1;
      -ms-flex:1 1 auto;
          flex:1 1 auto; }
.bp3-button-group{
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex; }
  .bp3-button-group .bp3-button{
    -webkit-box-flex:0;
        -ms-flex:0 0 auto;
            flex:0 0 auto;
    position:relative;
    z-index:4; }
    .bp3-button-group .bp3-button:focus{
      z-index:5; }
    .bp3-button-group .bp3-button:hover{
      z-index:6; }
    .bp3-button-group .bp3-button:active, .bp3-button-group .bp3-button.bp3-active{
      z-index:7; }
    .bp3-button-group .bp3-button:disabled, .bp3-button-group .bp3-button.bp3-disabled{
      z-index:3; }
    .bp3-button-group .bp3-button[class*="bp3-intent-"]{
      z-index:9; }
      .bp3-button-group .bp3-button[class*="bp3-intent-"]:focus{
        z-index:10; }
      .bp3-button-group .bp3-button[class*="bp3-intent-"]:hover{
        z-index:11; }
      .bp3-button-group .bp3-button[class*="bp3-intent-"]:active, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-active{
        z-index:12; }
      .bp3-button-group .bp3-button[class*="bp3-intent-"]:disabled, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-disabled{
        z-index:8; }
  .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:first-child) .bp3-button,
  .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:first-child){
    border-bottom-left-radius:0;
    border-top-left-radius:0; }
  .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
  .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){
    border-bottom-right-radius:0;
    border-top-right-radius:0;
    margin-right:-1px; }
  .bp3-button-group.bp3-minimal .bp3-button{
    background:none;
    -webkit-box-shadow:none;
            box-shadow:none; }
    .bp3-button-group.bp3-minimal .bp3-button:hover{
      background:rgba(167, 182, 194, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026;
      text-decoration:none; }
    .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
      background:rgba(115, 134, 148, 0.3);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#182026; }
    .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{
      background:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
      .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{
        background:rgba(115, 134, 148, 0.3); }
    .bp3-dark .bp3-button-group.bp3-minimal .bp3-button{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:inherit; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover{
        background:rgba(138, 155, 168, 0.15); }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
        background:rgba(138, 155, 168, 0.3);
        color:#f5f8fa; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{
        background:none;
        color:rgba(167, 182, 194, 0.6);
        cursor:not-allowed; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{
          background:rgba(138, 155, 168, 0.3); }
    .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{
      color:#106ba3; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#106ba3; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{
        background:rgba(19, 124, 189, 0.15);
        color:#106ba3; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
        background:rgba(19, 124, 189, 0.3);
        color:#106ba3; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{
        background:none;
        color:rgba(16, 107, 163, 0.5); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{
          background:rgba(19, 124, 189, 0.3); }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
        stroke:#106ba3; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{
        color:#48aff0; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{
          background:rgba(19, 124, 189, 0.2);
          color:#48aff0; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
          background:rgba(19, 124, 189, 0.3);
          color:#48aff0; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{
          background:none;
          color:rgba(72, 175, 240, 0.5); }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{
            background:rgba(19, 124, 189, 0.3); }
    .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{
      color:#0d8050; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#0d8050; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{
        background:rgba(15, 153, 96, 0.15);
        color:#0d8050; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
        background:rgba(15, 153, 96, 0.3);
        color:#0d8050; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{
        background:none;
        color:rgba(13, 128, 80, 0.5); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{
          background:rgba(15, 153, 96, 0.3); }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
        stroke:#0d8050; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{
        color:#3dcc91; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{
          background:rgba(15, 153, 96, 0.2);
          color:#3dcc91; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
          background:rgba(15, 153, 96, 0.3);
          color:#3dcc91; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{
          background:none;
          color:rgba(61, 204, 145, 0.5); }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{
            background:rgba(15, 153, 96, 0.3); }
    .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{
      color:#bf7326; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#bf7326; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{
        background:rgba(217, 130, 43, 0.15);
        color:#bf7326; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
        background:rgba(217, 130, 43, 0.3);
        color:#bf7326; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{
        background:none;
        color:rgba(191, 115, 38, 0.5); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{
          background:rgba(217, 130, 43, 0.3); }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
        stroke:#bf7326; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{
        color:#ffb366; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{
          background:rgba(217, 130, 43, 0.2);
          color:#ffb366; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
          background:rgba(217, 130, 43, 0.3);
          color:#ffb366; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{
          background:none;
          color:rgba(255, 179, 102, 0.5); }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{
            background:rgba(217, 130, 43, 0.3); }
    .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{
      color:#c23030; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#c23030; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{
        background:rgba(219, 55, 55, 0.15);
        color:#c23030; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
        background:rgba(219, 55, 55, 0.3);
        color:#c23030; }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{
        background:none;
        color:rgba(194, 48, 48, 0.5); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{
          background:rgba(219, 55, 55, 0.3); }
      .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
        stroke:#c23030; }
      .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{
        color:#ff7373; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{
          background:rgba(219, 55, 55, 0.2);
          color:#ff7373; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
          background:rgba(219, 55, 55, 0.3);
          color:#ff7373; }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{
          background:none;
          color:rgba(255, 115, 115, 0.5); }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{
            background:rgba(219, 55, 55, 0.3); }
  .bp3-button-group .bp3-popover-wrapper,
  .bp3-button-group .bp3-popover-target{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto; }
  .bp3-button-group.bp3-fill{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    width:100%; }
  .bp3-button-group .bp3-button.bp3-fill,
  .bp3-button-group.bp3-fill .bp3-button:not(.bp3-fixed){
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto; }
  .bp3-button-group.bp3-vertical{
    -webkit-box-align:stretch;
        -ms-flex-align:stretch;
            align-items:stretch;
    -webkit-box-orient:vertical;
    -webkit-box-direction:normal;
        -ms-flex-direction:column;
            flex-direction:column;
    vertical-align:top; }
    .bp3-button-group.bp3-vertical.bp3-fill{
      height:100%;
      width:unset; }
    .bp3-button-group.bp3-vertical .bp3-button{
      margin-right:0 !important;
      width:100%; }
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:first-child .bp3-button,
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:first-child{
      border-radius:3px 3px 0 0; }
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:last-child .bp3-button,
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:last-child{
      border-radius:0 0 3px 3px; }
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
    .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:not(:last-child){
      margin-bottom:-1px; }
  .bp3-button-group.bp3-align-left .bp3-button{
    text-align:left; }
  .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
  .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){
    margin-right:1px; }
  .bp3-dark .bp3-button-group.bp3-vertical > .bp3-popover-wrapper:not(:last-child) .bp3-button,
  .bp3-dark .bp3-button-group.bp3-vertical > .bp3-button:not(:last-child){
    margin-bottom:1px; }
.bp3-callout{
  font-size:14px;
  line-height:1.5;
  background-color:rgba(138, 155, 168, 0.15);
  border-radius:3px;
  padding:10px 12px 9px;
  position:relative;
  width:100%; }
  .bp3-callout[class*="bp3-icon-"]{
    padding-left:40px; }
    .bp3-callout[class*="bp3-icon-"]::before{
      font-family:"Icons20", sans-serif;
      font-size:20px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased;
      color:#5c7080;
      left:10px;
      position:absolute;
      top:10px; }
  .bp3-callout.bp3-callout-icon{
    padding-left:40px; }
    .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{
      color:#5c7080;
      left:10px;
      position:absolute;
      top:10px; }
  .bp3-callout .bp3-heading{
    line-height:20px;
    margin-bottom:5px;
    margin-top:0; }
    .bp3-callout .bp3-heading:last-child{
      margin-bottom:0; }
  .bp3-dark .bp3-callout{
    background-color:rgba(138, 155, 168, 0.2); }
    .bp3-dark .bp3-callout[class*="bp3-icon-"]::before{
      color:#a7b6c2; }
  .bp3-callout.bp3-intent-primary{
    background-color:rgba(19, 124, 189, 0.15); }
    .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before,
    .bp3-callout.bp3-intent-primary > .bp3-icon:first-child,
    .bp3-callout.bp3-intent-primary .bp3-heading{
      color:#106ba3; }
    .bp3-dark .bp3-callout.bp3-intent-primary{
      background-color:rgba(19, 124, 189, 0.25); }
      .bp3-dark .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before,
      .bp3-dark .bp3-callout.bp3-intent-primary > .bp3-icon:first-child,
      .bp3-dark .bp3-callout.bp3-intent-primary .bp3-heading{
        color:#48aff0; }
  .bp3-callout.bp3-intent-success{
    background-color:rgba(15, 153, 96, 0.15); }
    .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before,
    .bp3-callout.bp3-intent-success > .bp3-icon:first-child,
    .bp3-callout.bp3-intent-success .bp3-heading{
      color:#0d8050; }
    .bp3-dark .bp3-callout.bp3-intent-success{
      background-color:rgba(15, 153, 96, 0.25); }
      .bp3-dark .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before,
      .bp3-dark .bp3-callout.bp3-intent-success > .bp3-icon:first-child,
      .bp3-dark .bp3-callout.bp3-intent-success .bp3-heading{
        color:#3dcc91; }
  .bp3-callout.bp3-intent-warning{
    background-color:rgba(217, 130, 43, 0.15); }
    .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before,
    .bp3-callout.bp3-intent-warning > .bp3-icon:first-child,
    .bp3-callout.bp3-intent-warning .bp3-heading{
      color:#bf7326; }
    .bp3-dark .bp3-callout.bp3-intent-warning{
      background-color:rgba(217, 130, 43, 0.25); }
      .bp3-dark .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before,
      .bp3-dark .bp3-callout.bp3-intent-warning > .bp3-icon:first-child,
      .bp3-dark .bp3-callout.bp3-intent-warning .bp3-heading{
        color:#ffb366; }
  .bp3-callout.bp3-intent-danger{
    background-color:rgba(219, 55, 55, 0.15); }
    .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before,
    .bp3-callout.bp3-intent-danger > .bp3-icon:first-child,
    .bp3-callout.bp3-intent-danger .bp3-heading{
      color:#c23030; }
    .bp3-dark .bp3-callout.bp3-intent-danger{
      background-color:rgba(219, 55, 55, 0.25); }
      .bp3-dark .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before,
      .bp3-dark .bp3-callout.bp3-intent-danger > .bp3-icon:first-child,
      .bp3-dark .bp3-callout.bp3-intent-danger .bp3-heading{
        color:#ff7373; }
  .bp3-running-text .bp3-callout{
    margin:20px 0; }
.bp3-card{
  background-color:#ffffff;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
  padding:20px;
  -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-card.bp3-dark,
  .bp3-dark .bp3-card{
    background-color:#30404d;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }

.bp3-elevation-0{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }
  .bp3-elevation-0.bp3-dark,
  .bp3-dark .bp3-elevation-0{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }

.bp3-elevation-1{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-elevation-1.bp3-dark,
  .bp3-dark .bp3-elevation-1{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }

.bp3-elevation-2{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); }
  .bp3-elevation-2.bp3-dark,
  .bp3-dark .bp3-elevation-2{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); }

.bp3-elevation-3{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); }
  .bp3-elevation-3.bp3-dark,
  .bp3-dark .bp3-elevation-3{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }

.bp3-elevation-4{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); }
  .bp3-elevation-4.bp3-dark,
  .bp3-dark .bp3-elevation-4{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); }

.bp3-card.bp3-interactive:hover{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
  cursor:pointer; }
  .bp3-card.bp3-interactive:hover.bp3-dark,
  .bp3-dark .bp3-card.bp3-interactive:hover{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }

.bp3-card.bp3-interactive:active{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
  opacity:0.9;
  -webkit-transition-duration:0;
          transition-duration:0; }
  .bp3-card.bp3-interactive:active.bp3-dark,
  .bp3-dark .bp3-card.bp3-interactive:active{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }

.bp3-collapse{
  height:0;
  overflow-y:hidden;
  -webkit-transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-collapse .bp3-collapse-body{
    -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-collapse .bp3-collapse-body[aria-hidden="true"]{
      display:none; }

.bp3-context-menu .bp3-popover-target{
  display:block; }

.bp3-context-menu-popover-target{
  position:fixed; }

.bp3-divider{
  border-bottom:1px solid rgba(16, 22, 26, 0.15);
  border-right:1px solid rgba(16, 22, 26, 0.15);
  margin:5px; }
  .bp3-dark .bp3-divider{
    border-color:rgba(16, 22, 26, 0.4); }
.bp3-dialog-container{
  opacity:1;
  -webkit-transform:scale(1);
          transform:scale(1);
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  min-height:100%;
  pointer-events:none;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none;
  width:100%; }
  .bp3-dialog-container.bp3-overlay-enter > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear > .bp3-dialog{
    opacity:0;
    -webkit-transform:scale(0.5);
            transform:scale(0.5); }
  .bp3-dialog-container.bp3-overlay-enter-active > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear-active > .bp3-dialog{
    opacity:1;
    -webkit-transform:scale(1);
            transform:scale(1);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:opacity, -webkit-transform;
    transition-property:opacity, -webkit-transform;
    transition-property:opacity, transform;
    transition-property:opacity, transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
  .bp3-dialog-container.bp3-overlay-exit > .bp3-dialog{
    opacity:1;
    -webkit-transform:scale(1);
            transform:scale(1); }
  .bp3-dialog-container.bp3-overlay-exit-active > .bp3-dialog{
    opacity:0;
    -webkit-transform:scale(0.5);
            transform:scale(0.5);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:opacity, -webkit-transform;
    transition-property:opacity, -webkit-transform;
    transition-property:opacity, transform;
    transition-property:opacity, transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }

.bp3-dialog{
  background:#ebf1f5;
  border-radius:6px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  margin:30px 0;
  padding-bottom:20px;
  pointer-events:all;
  -webkit-user-select:text;
     -moz-user-select:text;
      -ms-user-select:text;
          user-select:text;
  width:500px; }
  .bp3-dialog:focus{
    outline:0; }
  .bp3-dialog.bp3-dark,
  .bp3-dark .bp3-dialog{
    background:#293742;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }

.bp3-dialog-header{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  background:#ffffff;
  border-radius:6px 6px 0 0;
  -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
          box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  min-height:40px;
  padding-left:20px;
  padding-right:5px; }
  .bp3-dialog-header .bp3-icon-large,
  .bp3-dialog-header .bp3-icon{
    color:#5c7080;
    -webkit-box-flex:0;
        -ms-flex:0 0 auto;
            flex:0 0 auto;
    margin-right:10px; }
  .bp3-dialog-header .bp3-heading{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    word-wrap:normal;
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto;
    line-height:inherit;
    margin:0; }
    .bp3-dialog-header .bp3-heading:last-child{
      margin-right:20px; }
  .bp3-dark .bp3-dialog-header{
    background:#30404d;
    -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
            box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-dialog-header .bp3-icon-large,
    .bp3-dark .bp3-dialog-header .bp3-icon{
      color:#a7b6c2; }

.bp3-dialog-body{
  -webkit-box-flex:1;
      -ms-flex:1 1 auto;
          flex:1 1 auto;
  line-height:18px;
  margin:20px; }

.bp3-dialog-footer{
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  margin:0 20px; }

.bp3-dialog-footer-actions{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:end;
      -ms-flex-pack:end;
          justify-content:flex-end; }
  .bp3-dialog-footer-actions .bp3-button{
    margin-left:10px; }
.bp3-drawer{
  background:#ffffff;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  margin:0;
  padding:0; }
  .bp3-drawer:focus{
    outline:0; }
  .bp3-drawer.bp3-position-top{
    height:50%;
    left:0;
    right:0;
    top:0; }
    .bp3-drawer.bp3-position-top.bp3-overlay-enter, .bp3-drawer.bp3-position-top.bp3-overlay-appear{
      -webkit-transform:translateY(-100%);
              transform:translateY(-100%); }
    .bp3-drawer.bp3-position-top.bp3-overlay-enter-active, .bp3-drawer.bp3-position-top.bp3-overlay-appear-active{
      -webkit-transform:translateY(0);
              transform:translateY(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer.bp3-position-top.bp3-overlay-exit{
      -webkit-transform:translateY(0);
              transform:translateY(0); }
    .bp3-drawer.bp3-position-top.bp3-overlay-exit-active{
      -webkit-transform:translateY(-100%);
              transform:translateY(-100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer.bp3-position-bottom{
    bottom:0;
    height:50%;
    left:0;
    right:0; }
    .bp3-drawer.bp3-position-bottom.bp3-overlay-enter, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear{
      -webkit-transform:translateY(100%);
              transform:translateY(100%); }
    .bp3-drawer.bp3-position-bottom.bp3-overlay-enter-active, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear-active{
      -webkit-transform:translateY(0);
              transform:translateY(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer.bp3-position-bottom.bp3-overlay-exit{
      -webkit-transform:translateY(0);
              transform:translateY(0); }
    .bp3-drawer.bp3-position-bottom.bp3-overlay-exit-active{
      -webkit-transform:translateY(100%);
              transform:translateY(100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer.bp3-position-left{
    bottom:0;
    left:0;
    top:0;
    width:50%; }
    .bp3-drawer.bp3-position-left.bp3-overlay-enter, .bp3-drawer.bp3-position-left.bp3-overlay-appear{
      -webkit-transform:translateX(-100%);
              transform:translateX(-100%); }
    .bp3-drawer.bp3-position-left.bp3-overlay-enter-active, .bp3-drawer.bp3-position-left.bp3-overlay-appear-active{
      -webkit-transform:translateX(0);
              transform:translateX(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer.bp3-position-left.bp3-overlay-exit{
      -webkit-transform:translateX(0);
              transform:translateX(0); }
    .bp3-drawer.bp3-position-left.bp3-overlay-exit-active{
      -webkit-transform:translateX(-100%);
              transform:translateX(-100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer.bp3-position-right{
    bottom:0;
    right:0;
    top:0;
    width:50%; }
    .bp3-drawer.bp3-position-right.bp3-overlay-enter, .bp3-drawer.bp3-position-right.bp3-overlay-appear{
      -webkit-transform:translateX(100%);
              transform:translateX(100%); }
    .bp3-drawer.bp3-position-right.bp3-overlay-enter-active, .bp3-drawer.bp3-position-right.bp3-overlay-appear-active{
      -webkit-transform:translateX(0);
              transform:translateX(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer.bp3-position-right.bp3-overlay-exit{
      -webkit-transform:translateX(0);
              transform:translateX(0); }
    .bp3-drawer.bp3-position-right.bp3-overlay-exit-active{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
  .bp3-position-right):not(.bp3-vertical){
    bottom:0;
    right:0;
    top:0;
    width:50%; }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear{
      -webkit-transform:translateX(100%);
              transform:translateX(100%); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear-active{
      -webkit-transform:translateX(0);
              transform:translateX(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit{
      -webkit-transform:translateX(0);
              transform:translateX(0); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit-active{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
  .bp3-position-right).bp3-vertical{
    bottom:0;
    height:50%;
    left:0;
    right:0; }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-appear{
      -webkit-transform:translateY(100%);
              transform:translateY(100%); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-appear-active{
      -webkit-transform:translateY(0);
              transform:translateY(0);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-exit{
      -webkit-transform:translateY(0);
              transform:translateY(0); }
    .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
    .bp3-position-right).bp3-vertical.bp3-overlay-exit-active{
      -webkit-transform:translateY(100%);
              transform:translateY(100%);
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:100ms;
              transition-duration:100ms;
      -webkit-transition-property:-webkit-transform;
      transition-property:-webkit-transform;
      transition-property:transform;
      transition-property:transform, -webkit-transform;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-drawer.bp3-dark,
  .bp3-dark .bp3-drawer{
    background:#30404d;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }

.bp3-drawer-header{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  border-radius:0;
  -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
          box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  min-height:40px;
  padding:5px;
  padding-left:20px;
  position:relative; }
  .bp3-drawer-header .bp3-icon-large,
  .bp3-drawer-header .bp3-icon{
    color:#5c7080;
    -webkit-box-flex:0;
        -ms-flex:0 0 auto;
            flex:0 0 auto;
    margin-right:10px; }
  .bp3-drawer-header .bp3-heading{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    word-wrap:normal;
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto;
    line-height:inherit;
    margin:0; }
    .bp3-drawer-header .bp3-heading:last-child{
      margin-right:20px; }
  .bp3-dark .bp3-drawer-header{
    -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
            box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-drawer-header .bp3-icon-large,
    .bp3-dark .bp3-drawer-header .bp3-icon{
      color:#a7b6c2; }

.bp3-drawer-body{
  -webkit-box-flex:1;
      -ms-flex:1 1 auto;
          flex:1 1 auto;
  line-height:18px;
  overflow:auto; }

.bp3-drawer-footer{
  -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
          box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  padding:10px 20px;
  position:relative; }
  .bp3-dark .bp3-drawer-footer{
    -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4);
            box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); }
.bp3-editable-text{
  cursor:text;
  display:inline-block;
  max-width:100%;
  position:relative;
  vertical-align:top;
  white-space:nowrap; }
  .bp3-editable-text::before{
    bottom:-3px;
    left:-3px;
    position:absolute;
    right:-3px;
    top:-3px;
    border-radius:3px;
    content:"";
    -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-editable-text:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
  .bp3-editable-text.bp3-editable-text-editing::before{
    background-color:#ffffff;
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-editable-text.bp3-disabled::before{
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-editable-text.bp3-intent-primary .bp3-editable-text-input,
  .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{
    color:#137cbd; }
  .bp3-editable-text.bp3-intent-primary:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); }
  .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-editable-text.bp3-intent-success .bp3-editable-text-input,
  .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{
    color:#0f9960; }
  .bp3-editable-text.bp3-intent-success:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4);
            box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); }
  .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-editable-text.bp3-intent-warning .bp3-editable-text-input,
  .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{
    color:#d9822b; }
  .bp3-editable-text.bp3-intent-warning:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4);
            box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); }
  .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-editable-text.bp3-intent-danger .bp3-editable-text-input,
  .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{
    color:#db3737; }
  .bp3-editable-text.bp3-intent-danger:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4);
            box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); }
  .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-editable-text:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); }
  .bp3-dark .bp3-editable-text.bp3-editable-text-editing::before{
    background-color:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-disabled::before{
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-dark .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{
    color:#48aff0; }
  .bp3-dark .bp3-editable-text.bp3-intent-primary:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4);
            box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{
    color:#3dcc91; }
  .bp3-dark .bp3-editable-text.bp3-intent-success:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4);
            box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{
    color:#ffb366; }
  .bp3-dark .bp3-editable-text.bp3-intent-warning:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4);
            box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{
    color:#ff7373; }
  .bp3-dark .bp3-editable-text.bp3-intent-danger:hover::before{
    -webkit-box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4);
            box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); }
  .bp3-dark .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{
    -webkit-box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }

.bp3-editable-text-input,
.bp3-editable-text-content{
  color:inherit;
  display:inherit;
  font:inherit;
  letter-spacing:inherit;
  max-width:inherit;
  min-width:inherit;
  position:relative;
  resize:none;
  text-transform:inherit;
  vertical-align:top; }

.bp3-editable-text-input{
  background:none;
  border:none;
  -webkit-box-shadow:none;
          box-shadow:none;
  padding:0;
  white-space:pre-wrap;
  width:100%; }
  .bp3-editable-text-input::-webkit-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-editable-text-input::-moz-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-editable-text-input:-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-editable-text-input::-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-editable-text-input::placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-editable-text-input:focus{
    outline:none; }
  .bp3-editable-text-input::-ms-clear{
    display:none; }

.bp3-editable-text-content{
  overflow:hidden;
  padding-right:2px;
  text-overflow:ellipsis;
  white-space:pre; }
  .bp3-editable-text-editing > .bp3-editable-text-content{
    left:0;
    position:absolute;
    visibility:hidden; }
  .bp3-editable-text-placeholder > .bp3-editable-text-content{
    color:rgba(92, 112, 128, 0.6); }
    .bp3-dark .bp3-editable-text-placeholder > .bp3-editable-text-content{
      color:rgba(167, 182, 194, 0.6); }

.bp3-editable-text.bp3-multiline{
  display:block; }
  .bp3-editable-text.bp3-multiline .bp3-editable-text-content{
    overflow:auto;
    white-space:pre-wrap;
    word-wrap:break-word; }
.bp3-divider{
  border-bottom:1px solid rgba(16, 22, 26, 0.15);
  border-right:1px solid rgba(16, 22, 26, 0.15);
  margin:5px; }
  .bp3-dark .bp3-divider{
    border-color:rgba(16, 22, 26, 0.4); }
.bp3-control-group{
  -webkit-transform:translateZ(0);
          transform:translateZ(0);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:stretch;
      -ms-flex-align:stretch;
          align-items:stretch; }
  .bp3-control-group > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-control-group > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-control-group .bp3-button,
  .bp3-control-group .bp3-html-select,
  .bp3-control-group .bp3-input,
  .bp3-control-group .bp3-select{
    position:relative; }
  .bp3-control-group .bp3-input{
    border-radius:inherit;
    z-index:2; }
    .bp3-control-group .bp3-input:focus{
      border-radius:3px;
      z-index:14; }
    .bp3-control-group .bp3-input[class*="bp3-intent"]{
      z-index:13; }
      .bp3-control-group .bp3-input[class*="bp3-intent"]:focus{
        z-index:15; }
    .bp3-control-group .bp3-input[readonly], .bp3-control-group .bp3-input:disabled, .bp3-control-group .bp3-input.bp3-disabled{
      z-index:1; }
  .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input{
    z-index:13; }
    .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input:focus{
      z-index:15; }
  .bp3-control-group .bp3-button,
  .bp3-control-group .bp3-html-select select,
  .bp3-control-group .bp3-select select{
    -webkit-transform:translateZ(0);
            transform:translateZ(0);
    border-radius:inherit;
    z-index:4; }
    .bp3-control-group .bp3-button:focus,
    .bp3-control-group .bp3-html-select select:focus,
    .bp3-control-group .bp3-select select:focus{
      z-index:5; }
    .bp3-control-group .bp3-button:hover,
    .bp3-control-group .bp3-html-select select:hover,
    .bp3-control-group .bp3-select select:hover{
      z-index:6; }
    .bp3-control-group .bp3-button:active,
    .bp3-control-group .bp3-html-select select:active,
    .bp3-control-group .bp3-select select:active{
      z-index:7; }
    .bp3-control-group .bp3-button[readonly], .bp3-control-group .bp3-button:disabled, .bp3-control-group .bp3-button.bp3-disabled,
    .bp3-control-group .bp3-html-select select[readonly],
    .bp3-control-group .bp3-html-select select:disabled,
    .bp3-control-group .bp3-html-select select.bp3-disabled,
    .bp3-control-group .bp3-select select[readonly],
    .bp3-control-group .bp3-select select:disabled,
    .bp3-control-group .bp3-select select.bp3-disabled{
      z-index:3; }
    .bp3-control-group .bp3-button[class*="bp3-intent"],
    .bp3-control-group .bp3-html-select select[class*="bp3-intent"],
    .bp3-control-group .bp3-select select[class*="bp3-intent"]{
      z-index:9; }
      .bp3-control-group .bp3-button[class*="bp3-intent"]:focus,
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:focus,
      .bp3-control-group .bp3-select select[class*="bp3-intent"]:focus{
        z-index:10; }
      .bp3-control-group .bp3-button[class*="bp3-intent"]:hover,
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:hover,
      .bp3-control-group .bp3-select select[class*="bp3-intent"]:hover{
        z-index:11; }
      .bp3-control-group .bp3-button[class*="bp3-intent"]:active,
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:active,
      .bp3-control-group .bp3-select select[class*="bp3-intent"]:active{
        z-index:12; }
      .bp3-control-group .bp3-button[class*="bp3-intent"][readonly], .bp3-control-group .bp3-button[class*="bp3-intent"]:disabled, .bp3-control-group .bp3-button[class*="bp3-intent"].bp3-disabled,
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"][readonly],
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:disabled,
      .bp3-control-group .bp3-html-select select[class*="bp3-intent"].bp3-disabled,
      .bp3-control-group .bp3-select select[class*="bp3-intent"][readonly],
      .bp3-control-group .bp3-select select[class*="bp3-intent"]:disabled,
      .bp3-control-group .bp3-select select[class*="bp3-intent"].bp3-disabled{
        z-index:8; }
  .bp3-control-group .bp3-input-group > .bp3-icon,
  .bp3-control-group .bp3-input-group > .bp3-button,
  .bp3-control-group .bp3-input-group > .bp3-input-action{
    z-index:16; }
  .bp3-control-group .bp3-select::after,
  .bp3-control-group .bp3-html-select::after,
  .bp3-control-group .bp3-select > .bp3-icon,
  .bp3-control-group .bp3-html-select > .bp3-icon{
    z-index:17; }
  .bp3-control-group .bp3-select:focus-within{
    z-index:5; }
  .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){
    margin-right:-1px; }
  .bp3-control-group:not(.bp3-vertical) > .bp3-divider:not(:first-child){
    margin-left:6px; }
  .bp3-dark .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){
    margin-right:0; }
  .bp3-dark .bp3-control-group:not(.bp3-vertical) > .bp3-button + .bp3-button{
    margin-left:1px; }
  .bp3-control-group .bp3-popover-wrapper,
  .bp3-control-group .bp3-popover-target{
    border-radius:inherit; }
  .bp3-control-group > :first-child{
    border-radius:3px 0 0 3px; }
  .bp3-control-group > :last-child{
    border-radius:0 3px 3px 0;
    margin-right:0; }
  .bp3-control-group > :only-child{
    border-radius:3px;
    margin-right:0; }
  .bp3-control-group .bp3-input-group .bp3-button{
    border-radius:3px; }
  .bp3-control-group .bp3-numeric-input:not(:first-child) .bp3-input-group{
    border-bottom-left-radius:0;
    border-top-left-radius:0; }
  .bp3-control-group.bp3-fill{
    width:100%; }
  .bp3-control-group > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto; }
  .bp3-control-group.bp3-fill > *:not(.bp3-fixed){
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto; }
  .bp3-control-group.bp3-vertical{
    -webkit-box-orient:vertical;
    -webkit-box-direction:normal;
        -ms-flex-direction:column;
            flex-direction:column; }
    .bp3-control-group.bp3-vertical > *{
      margin-top:-1px; }
    .bp3-control-group.bp3-vertical > :first-child{
      border-radius:3px 3px 0 0;
      margin-top:0; }
    .bp3-control-group.bp3-vertical > :last-child{
      border-radius:0 0 3px 3px; }
.bp3-control{
  cursor:pointer;
  display:block;
  margin-bottom:10px;
  position:relative;
  text-transform:none; }
  .bp3-control input:checked ~ .bp3-control-indicator{
    background-color:#137cbd;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
  .bp3-control:hover input:checked ~ .bp3-control-indicator{
    background-color:#106ba3;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
  .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
    background:#0e5a8a;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-control input:disabled:checked ~ .bp3-control-indicator{
    background:rgba(19, 124, 189, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-dark .bp3-control input:checked ~ .bp3-control-indicator{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control:hover input:checked ~ .bp3-control-indicator{
    background-color:#106ba3;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
    background-color:#0e5a8a;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{
    background:rgba(14, 90, 138, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-control:not(.bp3-align-right){
    padding-left:26px; }
    .bp3-control:not(.bp3-align-right) .bp3-control-indicator{
      margin-left:-26px; }
  .bp3-control.bp3-align-right{
    padding-right:26px; }
    .bp3-control.bp3-align-right .bp3-control-indicator{
      margin-right:-26px; }
  .bp3-control.bp3-disabled{
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed; }
  .bp3-control.bp3-inline{
    display:inline-block;
    margin-right:20px; }
  .bp3-control input{
    left:0;
    opacity:0;
    position:absolute;
    top:0;
    z-index:-1; }
  .bp3-control .bp3-control-indicator{
    background-clip:padding-box;
    background-color:#f5f8fa;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
    border:none;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
    cursor:pointer;
    display:inline-block;
    font-size:16px;
    height:1em;
    margin-right:10px;
    margin-top:-3px;
    position:relative;
    -webkit-user-select:none;
       -moz-user-select:none;
        -ms-user-select:none;
            user-select:none;
    vertical-align:middle;
    width:1em; }
    .bp3-control .bp3-control-indicator::before{
      content:"";
      display:block;
      height:1em;
      width:1em; }
  .bp3-control:hover .bp3-control-indicator{
    background-color:#ebf1f5; }
  .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
    background:#d8e1e8;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-control input:disabled ~ .bp3-control-indicator{
    background:rgba(206, 217, 224, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none;
    cursor:not-allowed; }
  .bp3-control input:focus ~ .bp3-control-indicator{
    outline:rgba(19, 124, 189, 0.6) auto 2px;
    outline-offset:2px;
    -moz-outline-radius:6px; }
  .bp3-control.bp3-align-right .bp3-control-indicator{
    float:right;
    margin-left:10px;
    margin-top:1px; }
  .bp3-control.bp3-large{
    font-size:16px; }
    .bp3-control.bp3-large:not(.bp3-align-right){
      padding-left:30px; }
      .bp3-control.bp3-large:not(.bp3-align-right) .bp3-control-indicator{
        margin-left:-30px; }
    .bp3-control.bp3-large.bp3-align-right{
      padding-right:30px; }
      .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{
        margin-right:-30px; }
    .bp3-control.bp3-large .bp3-control-indicator{
      font-size:20px; }
    .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{
      margin-top:0; }
  .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{
    background-color:#137cbd;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
    color:#ffffff; }
  .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{
    background-color:#106ba3;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
  .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
    background:#0e5a8a;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
    background:rgba(19, 124, 189, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-dark .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{
    background-color:#106ba3;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
    background-color:#0e5a8a;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
    background:rgba(14, 90, 138, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-control.bp3-checkbox .bp3-control-indicator{
    border-radius:3px; }
  .bp3-control.bp3-checkbox input:checked ~ .bp3-control-indicator::before{
    background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 5c-.28 0-.53.11-.71.29L7 9.59l-2.29-2.3a1.003 1.003 0 00-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0012 5z' fill='white'/%3e%3c/svg%3e"); }
  .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator::before{
    background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M11 7H5c-.55 0-1 .45-1 1s.45 1 1 1h6c.55 0 1-.45 1-1s-.45-1-1-1z' fill='white'/%3e%3c/svg%3e"); }
  .bp3-control.bp3-radio .bp3-control-indicator{
    border-radius:50%; }
  .bp3-control.bp3-radio input:checked ~ .bp3-control-indicator::before{
    background-image:radial-gradient(#ffffff, #ffffff 28%, transparent 32%); }
  .bp3-control.bp3-radio input:checked:disabled ~ .bp3-control-indicator::before{
    opacity:0.5; }
  .bp3-control.bp3-radio input:focus ~ .bp3-control-indicator{
    -moz-outline-radius:16px; }
  .bp3-control.bp3-switch input ~ .bp3-control-indicator{
    background:rgba(167, 182, 194, 0.5); }
  .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{
    background:rgba(115, 134, 148, 0.5); }
  .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{
    background:rgba(92, 112, 128, 0.5); }
  .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{
    background:rgba(206, 217, 224, 0.5); }
    .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{
      background:rgba(255, 255, 255, 0.8); }
  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{
    background:#137cbd; }
  .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{
    background:#106ba3; }
  .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{
    background:#0e5a8a; }
  .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{
    background:rgba(19, 124, 189, 0.5); }
    .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{
      background:rgba(255, 255, 255, 0.8); }
  .bp3-control.bp3-switch:not(.bp3-align-right){
    padding-left:38px; }
    .bp3-control.bp3-switch:not(.bp3-align-right) .bp3-control-indicator{
      margin-left:-38px; }
  .bp3-control.bp3-switch.bp3-align-right{
    padding-right:38px; }
    .bp3-control.bp3-switch.bp3-align-right .bp3-control-indicator{
      margin-right:-38px; }
  .bp3-control.bp3-switch .bp3-control-indicator{
    border:none;
    border-radius:1.75em;
    -webkit-box-shadow:none !important;
            box-shadow:none !important;
    min-width:1.75em;
    -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
    width:auto; }
    .bp3-control.bp3-switch .bp3-control-indicator::before{
      background:#ffffff;
      border-radius:50%;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
      height:calc(1em - 4px);
      left:0;
      margin:2px;
      position:absolute;
      -webkit-transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      width:calc(1em - 4px); }
  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{
    left:calc(100% - 1em); }
  .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right){
    padding-left:45px; }
    .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right) .bp3-control-indicator{
      margin-left:-45px; }
  .bp3-control.bp3-switch.bp3-large.bp3-align-right{
    padding-right:45px; }
    .bp3-control.bp3-switch.bp3-large.bp3-align-right .bp3-control-indicator{
      margin-right:-45px; }
  .bp3-dark .bp3-control.bp3-switch input ~ .bp3-control-indicator{
    background:rgba(16, 22, 26, 0.5); }
  .bp3-dark .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{
    background:rgba(16, 22, 26, 0.7); }
  .bp3-dark .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{
    background:rgba(16, 22, 26, 0.9); }
  .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{
    background:rgba(57, 75, 89, 0.5); }
    .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{
      background:rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{
    background:#137cbd; }
  .bp3-dark .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{
    background:#106ba3; }
  .bp3-dark .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{
    background:#0e5a8a; }
  .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{
    background:rgba(14, 90, 138, 0.5); }
    .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{
      background:rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control.bp3-switch .bp3-control-indicator::before{
    background:#394b59;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-control.bp3-switch .bp3-switch-inner-text{
    font-size:0.7em;
    text-align:center; }
  .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{
    line-height:0;
    margin-left:0.5em;
    margin-right:1.2em;
    visibility:hidden; }
  .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{
    line-height:1em;
    margin-left:1.2em;
    margin-right:0.5em;
    visibility:visible; }
  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{
    line-height:1em;
    visibility:visible; }
  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{
    line-height:0;
    visibility:hidden; }
  .bp3-dark .bp3-control{
    color:#f5f8fa; }
    .bp3-dark .bp3-control.bp3-disabled{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-control .bp3-control-indicator{
      background-color:#394b59;
      background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
      background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-control:hover .bp3-control-indicator{
      background-color:#30404d; }
    .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
      background:#202b33;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{
      background:rgba(57, 75, 89, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      cursor:not-allowed; }
    .bp3-dark .bp3-control.bp3-checkbox input:disabled:checked ~ .bp3-control-indicator, .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
      color:rgba(167, 182, 194, 0.6); }
.bp3-file-input{
  cursor:pointer;
  display:inline-block;
  height:30px;
  position:relative; }
  .bp3-file-input input{
    margin:0;
    min-width:200px;
    opacity:0; }
    .bp3-file-input input:disabled + .bp3-file-upload-input,
    .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{
      background:rgba(206, 217, 224, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed;
      resize:none; }
      .bp3-file-input input:disabled + .bp3-file-upload-input::after,
      .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{
        background-color:rgba(206, 217, 224, 0.5);
        background-image:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed;
        outline:none; }
        .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active:hover,
        .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active,
        .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active:hover{
          background:rgba(206, 217, 224, 0.7); }
      .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input, .bp3-dark
      .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{
        background:rgba(57, 75, 89, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after, .bp3-dark
        .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{
          background-color:rgba(57, 75, 89, 0.5);
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
          .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-dark
          .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active{
            background:rgba(57, 75, 89, 0.7); }
  .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{
    color:#182026; }
  .bp3-dark .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{
    color:#f5f8fa; }
  .bp3-file-input.bp3-fill{
    width:100%; }
  .bp3-file-input.bp3-large,
  .bp3-large .bp3-file-input{
    height:40px; }
  .bp3-file-input .bp3-file-upload-input-custom-text::after{
    content:attr(bp3-button-text); }

.bp3-file-upload-input{
  -webkit-appearance:none;
     -moz-appearance:none;
          appearance:none;
  background:#ffffff;
  border:none;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
  color:#182026;
  font-size:14px;
  font-weight:400;
  height:30px;
  line-height:30px;
  outline:none;
  padding:0 10px;
  -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  vertical-align:middle;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  word-wrap:normal;
  color:rgba(92, 112, 128, 0.6);
  left:0;
  padding-right:80px;
  position:absolute;
  right:0;
  top:0;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-file-upload-input::-webkit-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-file-upload-input::-moz-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-file-upload-input:-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-file-upload-input::-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-file-upload-input::placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-file-upload-input:focus, .bp3-file-upload-input.bp3-active{
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-file-upload-input[type="search"], .bp3-file-upload-input.bp3-round{
    border-radius:30px;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
    padding-left:10px; }
  .bp3-file-upload-input[readonly]{
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
  .bp3-file-upload-input:disabled, .bp3-file-upload-input.bp3-disabled{
    background:rgba(206, 217, 224, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed;
    resize:none; }
  .bp3-file-upload-input::after{
    background-color:#f5f8fa;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
    color:#182026;
    min-height:24px;
    min-width:24px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    word-wrap:normal;
    border-radius:3px;
    content:"Browse";
    line-height:24px;
    margin:3px;
    position:absolute;
    right:0;
    text-align:center;
    top:0;
    width:70px; }
    .bp3-file-upload-input::after:hover{
      background-clip:padding-box;
      background-color:#ebf1f5;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
    .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{
      background-color:#d8e1e8;
      background-image:none;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{
      background-color:rgba(206, 217, 224, 0.5);
      background-image:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed;
      outline:none; }
      .bp3-file-upload-input::after:disabled.bp3-active, .bp3-file-upload-input::after:disabled.bp3-active:hover, .bp3-file-upload-input::after.bp3-disabled.bp3-active, .bp3-file-upload-input::after.bp3-disabled.bp3-active:hover{
        background:rgba(206, 217, 224, 0.7); }
  .bp3-file-upload-input:hover::after{
    background-clip:padding-box;
    background-color:#ebf1f5;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
  .bp3-file-upload-input:active::after{
    background-color:#d8e1e8;
    background-image:none;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-large .bp3-file-upload-input{
    font-size:16px;
    height:40px;
    line-height:40px;
    padding-right:95px; }
    .bp3-large .bp3-file-upload-input[type="search"], .bp3-large .bp3-file-upload-input.bp3-round{
      padding:0 15px; }
    .bp3-large .bp3-file-upload-input::after{
      min-height:30px;
      min-width:30px;
      line-height:30px;
      margin:5px;
      width:85px; }
  .bp3-dark .bp3-file-upload-input{
    background:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa;
    color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input::-webkit-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input::-moz-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input:-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input::-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input::placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input:focus{
      -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-file-upload-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-file-upload-input:disabled, .bp3-dark .bp3-file-upload-input.bp3-disabled{
      background:rgba(57, 75, 89, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-file-upload-input::after{
      background-color:#394b59;
      background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
      background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
      color:#f5f8fa; }
      .bp3-dark .bp3-file-upload-input::after:hover, .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{
        color:#f5f8fa; }
      .bp3-dark .bp3-file-upload-input::after:hover{
        background-color:#30404d;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{
        background-color:#202b33;
        background-image:none;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{
        background-color:rgba(57, 75, 89, 0.5);
        background-image:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::after:disabled.bp3-active, .bp3-dark .bp3-file-upload-input::after.bp3-disabled.bp3-active{
          background:rgba(57, 75, 89, 0.7); }
      .bp3-dark .bp3-file-upload-input::after .bp3-button-spinner .bp3-spinner-head{
        background:rgba(16, 22, 26, 0.5);
        stroke:#8a9ba8; }
    .bp3-dark .bp3-file-upload-input:hover::after{
      background-color:#30404d;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-file-upload-input:active::after{
      background-color:#202b33;
      background-image:none;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
.bp3-file-upload-input::after{
  -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
          box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
.bp3-form-group{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  margin:0 0 15px; }
  .bp3-form-group label.bp3-label{
    margin-bottom:5px; }
  .bp3-form-group .bp3-control{
    margin-top:7px; }
  .bp3-form-group .bp3-form-helper-text{
    color:#5c7080;
    font-size:12px;
    margin-top:5px; }
  .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{
    color:#106ba3; }
  .bp3-form-group.bp3-intent-success .bp3-form-helper-text{
    color:#0d8050; }
  .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{
    color:#bf7326; }
  .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{
    color:#c23030; }
  .bp3-form-group.bp3-inline{
    -webkit-box-align:start;
        -ms-flex-align:start;
            align-items:flex-start;
    -webkit-box-orient:horizontal;
    -webkit-box-direction:normal;
        -ms-flex-direction:row;
            flex-direction:row; }
    .bp3-form-group.bp3-inline.bp3-large label.bp3-label{
      line-height:40px;
      margin:0 10px 0 0; }
    .bp3-form-group.bp3-inline label.bp3-label{
      line-height:30px;
      margin:0 10px 0 0; }
  .bp3-form-group.bp3-disabled .bp3-label,
  .bp3-form-group.bp3-disabled .bp3-text-muted,
  .bp3-form-group.bp3-disabled .bp3-form-helper-text{
    color:rgba(92, 112, 128, 0.6) !important; }
  .bp3-dark .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{
    color:#48aff0; }
  .bp3-dark .bp3-form-group.bp3-intent-success .bp3-form-helper-text{
    color:#3dcc91; }
  .bp3-dark .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{
    color:#ffb366; }
  .bp3-dark .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{
    color:#ff7373; }
  .bp3-dark .bp3-form-group .bp3-form-helper-text{
    color:#a7b6c2; }
  .bp3-dark .bp3-form-group.bp3-disabled .bp3-label,
  .bp3-dark .bp3-form-group.bp3-disabled .bp3-text-muted,
  .bp3-dark .bp3-form-group.bp3-disabled .bp3-form-helper-text{
    color:rgba(167, 182, 194, 0.6) !important; }
.bp3-input-group{
  display:block;
  position:relative; }
  .bp3-input-group .bp3-input{
    position:relative;
    width:100%; }
    .bp3-input-group .bp3-input:not(:first-child){
      padding-left:30px; }
    .bp3-input-group .bp3-input:not(:last-child){
      padding-right:30px; }
  .bp3-input-group .bp3-input-action,
  .bp3-input-group > .bp3-input-left-container,
  .bp3-input-group > .bp3-button,
  .bp3-input-group > .bp3-icon{
    position:absolute;
    top:0; }
    .bp3-input-group .bp3-input-action:first-child,
    .bp3-input-group > .bp3-input-left-container:first-child,
    .bp3-input-group > .bp3-button:first-child,
    .bp3-input-group > .bp3-icon:first-child{
      left:0; }
    .bp3-input-group .bp3-input-action:last-child,
    .bp3-input-group > .bp3-input-left-container:last-child,
    .bp3-input-group > .bp3-button:last-child,
    .bp3-input-group > .bp3-icon:last-child{
      right:0; }
  .bp3-input-group .bp3-button{
    min-height:24px;
    min-width:24px;
    margin:3px;
    padding:0 7px; }
    .bp3-input-group .bp3-button:empty{
      padding:0; }
  .bp3-input-group > .bp3-input-left-container,
  .bp3-input-group > .bp3-icon{
    z-index:1; }
  .bp3-input-group > .bp3-input-left-container > .bp3-icon,
  .bp3-input-group > .bp3-icon{
    color:#5c7080; }
    .bp3-input-group > .bp3-input-left-container > .bp3-icon:empty,
    .bp3-input-group > .bp3-icon:empty{
      font-family:"Icons16", sans-serif;
      font-size:16px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased; }
  .bp3-input-group > .bp3-input-left-container > .bp3-icon,
  .bp3-input-group > .bp3-icon,
  .bp3-input-group .bp3-input-action > .bp3-spinner{
    margin:7px; }
  .bp3-input-group .bp3-tag{
    margin:5px; }
  .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus),
  .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){
    color:#5c7080; }
    .bp3-dark .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), .bp3-dark
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){
      color:#a7b6c2; }
    .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large{
      color:#5c7080; }
  .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled,
  .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled{
    color:rgba(92, 112, 128, 0.6) !important; }
    .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-large,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-standard,
    .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-large{
      color:rgba(92, 112, 128, 0.6) !important; }
  .bp3-input-group.bp3-disabled{
    cursor:not-allowed; }
    .bp3-input-group.bp3-disabled .bp3-icon{
      color:rgba(92, 112, 128, 0.6); }
  .bp3-input-group.bp3-large .bp3-button{
    min-height:30px;
    min-width:30px;
    margin:5px; }
  .bp3-input-group.bp3-large > .bp3-input-left-container > .bp3-icon,
  .bp3-input-group.bp3-large > .bp3-icon,
  .bp3-input-group.bp3-large .bp3-input-action > .bp3-spinner{
    margin:12px; }
  .bp3-input-group.bp3-large .bp3-input{
    font-size:16px;
    height:40px;
    line-height:40px; }
    .bp3-input-group.bp3-large .bp3-input[type="search"], .bp3-input-group.bp3-large .bp3-input.bp3-round{
      padding:0 15px; }
    .bp3-input-group.bp3-large .bp3-input:not(:first-child){
      padding-left:40px; }
    .bp3-input-group.bp3-large .bp3-input:not(:last-child){
      padding-right:40px; }
  .bp3-input-group.bp3-small .bp3-button{
    min-height:20px;
    min-width:20px;
    margin:2px; }
  .bp3-input-group.bp3-small .bp3-tag{
    min-height:20px;
    min-width:20px;
    margin:2px; }
  .bp3-input-group.bp3-small > .bp3-input-left-container > .bp3-icon,
  .bp3-input-group.bp3-small > .bp3-icon,
  .bp3-input-group.bp3-small .bp3-input-action > .bp3-spinner{
    margin:4px; }
  .bp3-input-group.bp3-small .bp3-input{
    font-size:12px;
    height:24px;
    line-height:24px;
    padding-left:8px;
    padding-right:8px; }
    .bp3-input-group.bp3-small .bp3-input[type="search"], .bp3-input-group.bp3-small .bp3-input.bp3-round{
      padding:0 12px; }
    .bp3-input-group.bp3-small .bp3-input:not(:first-child){
      padding-left:24px; }
    .bp3-input-group.bp3-small .bp3-input:not(:last-child){
      padding-right:24px; }
  .bp3-input-group.bp3-fill{
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto;
    width:100%; }
  .bp3-input-group.bp3-round .bp3-button,
  .bp3-input-group.bp3-round .bp3-input,
  .bp3-input-group.bp3-round .bp3-tag{
    border-radius:30px; }
  .bp3-dark .bp3-input-group .bp3-icon{
    color:#a7b6c2; }
  .bp3-dark .bp3-input-group.bp3-disabled .bp3-icon{
    color:rgba(167, 182, 194, 0.6); }
  .bp3-input-group.bp3-intent-primary .bp3-input{
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-primary .bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-primary .bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #137cbd;
              box-shadow:inset 0 0 0 1px #137cbd; }
    .bp3-input-group.bp3-intent-primary .bp3-input:disabled, .bp3-input-group.bp3-intent-primary .bp3-input.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-input-group.bp3-intent-primary > .bp3-icon{
    color:#106ba3; }
    .bp3-dark .bp3-input-group.bp3-intent-primary > .bp3-icon{
      color:#48aff0; }
  .bp3-input-group.bp3-intent-success .bp3-input{
    -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-success .bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-success .bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #0f9960;
              box-shadow:inset 0 0 0 1px #0f9960; }
    .bp3-input-group.bp3-intent-success .bp3-input:disabled, .bp3-input-group.bp3-intent-success .bp3-input.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-input-group.bp3-intent-success > .bp3-icon{
    color:#0d8050; }
    .bp3-dark .bp3-input-group.bp3-intent-success > .bp3-icon{
      color:#3dcc91; }
  .bp3-input-group.bp3-intent-warning .bp3-input{
    -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-warning .bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-warning .bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #d9822b;
              box-shadow:inset 0 0 0 1px #d9822b; }
    .bp3-input-group.bp3-intent-warning .bp3-input:disabled, .bp3-input-group.bp3-intent-warning .bp3-input.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-input-group.bp3-intent-warning > .bp3-icon{
    color:#bf7326; }
    .bp3-dark .bp3-input-group.bp3-intent-warning > .bp3-icon{
      color:#ffb366; }
  .bp3-input-group.bp3-intent-danger .bp3-input{
    -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-danger .bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input-group.bp3-intent-danger .bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #db3737;
              box-shadow:inset 0 0 0 1px #db3737; }
    .bp3-input-group.bp3-intent-danger .bp3-input:disabled, .bp3-input-group.bp3-intent-danger .bp3-input.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-input-group.bp3-intent-danger > .bp3-icon{
    color:#c23030; }
    .bp3-dark .bp3-input-group.bp3-intent-danger > .bp3-icon{
      color:#ff7373; }
.bp3-input{
  -webkit-appearance:none;
     -moz-appearance:none;
          appearance:none;
  background:#ffffff;
  border:none;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
  color:#182026;
  font-size:14px;
  font-weight:400;
  height:30px;
  line-height:30px;
  outline:none;
  padding:0 10px;
  -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
  vertical-align:middle; }
  .bp3-input::-webkit-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input::-moz-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input:-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input::-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input::placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input:focus, .bp3-input.bp3-active{
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-input[type="search"], .bp3-input.bp3-round{
    border-radius:30px;
    -webkit-box-sizing:border-box;
            box-sizing:border-box;
    padding-left:10px; }
  .bp3-input[readonly]{
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
  .bp3-input:disabled, .bp3-input.bp3-disabled{
    background:rgba(206, 217, 224, 0.5);
    -webkit-box-shadow:none;
            box-shadow:none;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed;
    resize:none; }
  .bp3-input.bp3-large{
    font-size:16px;
    height:40px;
    line-height:40px; }
    .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{
      padding:0 15px; }
  .bp3-input.bp3-small{
    font-size:12px;
    height:24px;
    line-height:24px;
    padding-left:8px;
    padding-right:8px; }
    .bp3-input.bp3-small[type="search"], .bp3-input.bp3-small.bp3-round{
      padding:0 12px; }
  .bp3-input.bp3-fill{
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto;
    width:100%; }
  .bp3-dark .bp3-input{
    background:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }
    .bp3-dark .bp3-input::-webkit-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-input::-moz-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-input:-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-input::-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-input::placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-input:disabled, .bp3-dark .bp3-input.bp3-disabled{
      background:rgba(57, 75, 89, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(167, 182, 194, 0.6); }
  .bp3-input.bp3-intent-primary{
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-primary:focus{
      -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-primary[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #137cbd;
              box-shadow:inset 0 0 0 1px #137cbd; }
    .bp3-input.bp3-intent-primary:disabled, .bp3-input.bp3-intent-primary.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
    .bp3-dark .bp3-input.bp3-intent-primary{
      -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-primary:focus{
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-primary[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px #137cbd;
                box-shadow:inset 0 0 0 1px #137cbd; }
      .bp3-dark .bp3-input.bp3-intent-primary:disabled, .bp3-dark .bp3-input.bp3-intent-primary.bp3-disabled{
        -webkit-box-shadow:none;
                box-shadow:none; }
  .bp3-input.bp3-intent-success{
    -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-success:focus{
      -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-success[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #0f9960;
              box-shadow:inset 0 0 0 1px #0f9960; }
    .bp3-input.bp3-intent-success:disabled, .bp3-input.bp3-intent-success.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
    .bp3-dark .bp3-input.bp3-intent-success{
      -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-success:focus{
        -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-success[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px #0f9960;
                box-shadow:inset 0 0 0 1px #0f9960; }
      .bp3-dark .bp3-input.bp3-intent-success:disabled, .bp3-dark .bp3-input.bp3-intent-success.bp3-disabled{
        -webkit-box-shadow:none;
                box-shadow:none; }
  .bp3-input.bp3-intent-warning{
    -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-warning:focus{
      -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-warning[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #d9822b;
              box-shadow:inset 0 0 0 1px #d9822b; }
    .bp3-input.bp3-intent-warning:disabled, .bp3-input.bp3-intent-warning.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
    .bp3-dark .bp3-input.bp3-intent-warning{
      -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-warning:focus{
        -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-warning[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px #d9822b;
                box-shadow:inset 0 0 0 1px #d9822b; }
      .bp3-dark .bp3-input.bp3-intent-warning:disabled, .bp3-dark .bp3-input.bp3-intent-warning.bp3-disabled{
        -webkit-box-shadow:none;
                box-shadow:none; }
  .bp3-input.bp3-intent-danger{
    -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-danger:focus{
      -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-input.bp3-intent-danger[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px #db3737;
              box-shadow:inset 0 0 0 1px #db3737; }
    .bp3-input.bp3-intent-danger:disabled, .bp3-input.bp3-intent-danger.bp3-disabled{
      -webkit-box-shadow:none;
              box-shadow:none; }
    .bp3-dark .bp3-input.bp3-intent-danger{
      -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-danger:focus{
        -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-input.bp3-intent-danger[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px #db3737;
                box-shadow:inset 0 0 0 1px #db3737; }
      .bp3-dark .bp3-input.bp3-intent-danger:disabled, .bp3-dark .bp3-input.bp3-intent-danger.bp3-disabled{
        -webkit-box-shadow:none;
                box-shadow:none; }
  .bp3-input::-ms-clear{
    display:none; }
textarea.bp3-input{
  max-width:100%;
  padding:10px; }
  textarea.bp3-input, textarea.bp3-input.bp3-large, textarea.bp3-input.bp3-small{
    height:auto;
    line-height:inherit; }
  textarea.bp3-input.bp3-small{
    padding:8px; }
  .bp3-dark textarea.bp3-input{
    background:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }
    .bp3-dark textarea.bp3-input::-webkit-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark textarea.bp3-input::-moz-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark textarea.bp3-input:-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark textarea.bp3-input::-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark textarea.bp3-input::placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark textarea.bp3-input:focus{
      -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark textarea.bp3-input[readonly]{
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark textarea.bp3-input:disabled, .bp3-dark textarea.bp3-input.bp3-disabled{
      background:rgba(57, 75, 89, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(167, 182, 194, 0.6); }
label.bp3-label{
  display:block;
  margin-bottom:15px;
  margin-top:0; }
  label.bp3-label .bp3-html-select,
  label.bp3-label .bp3-input,
  label.bp3-label .bp3-select,
  label.bp3-label .bp3-slider,
  label.bp3-label .bp3-popover-wrapper{
    display:block;
    margin-top:5px;
    text-transform:none; }
  label.bp3-label .bp3-button-group{
    margin-top:5px; }
  label.bp3-label .bp3-select select,
  label.bp3-label .bp3-html-select select{
    font-weight:400;
    vertical-align:top;
    width:100%; }
  label.bp3-label.bp3-disabled,
  label.bp3-label.bp3-disabled .bp3-text-muted{
    color:rgba(92, 112, 128, 0.6); }
  label.bp3-label.bp3-inline{
    line-height:30px; }
    label.bp3-label.bp3-inline .bp3-html-select,
    label.bp3-label.bp3-inline .bp3-input,
    label.bp3-label.bp3-inline .bp3-input-group,
    label.bp3-label.bp3-inline .bp3-select,
    label.bp3-label.bp3-inline .bp3-popover-wrapper{
      display:inline-block;
      margin:0 0 0 5px;
      vertical-align:top; }
    label.bp3-label.bp3-inline .bp3-button-group{
      margin:0 0 0 5px; }
    label.bp3-label.bp3-inline .bp3-input-group .bp3-input{
      margin-left:0; }
    label.bp3-label.bp3-inline.bp3-large{
      line-height:40px; }
  label.bp3-label:not(.bp3-inline) .bp3-popover-target{
    display:block; }
  .bp3-dark label.bp3-label{
    color:#f5f8fa; }
    .bp3-dark label.bp3-label.bp3-disabled,
    .bp3-dark label.bp3-label.bp3-disabled .bp3-text-muted{
      color:rgba(167, 182, 194, 0.6); }
.bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button{
  -webkit-box-flex:1;
      -ms-flex:1 1 14px;
          flex:1 1 14px;
  min-height:0;
  padding:0;
  width:30px; }
  .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:first-child{
    border-radius:0 3px 0 0; }
  .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:last-child{
    border-radius:0 0 3px 0; }

.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:first-child{
  border-radius:3px 0 0 0; }

.bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:last-child{
  border-radius:0 0 0 3px; }

.bp3-numeric-input.bp3-large .bp3-button-group.bp3-vertical > .bp3-button{
  width:40px; }

form{
  display:block; }
.bp3-html-select select,
.bp3-select select{
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  border:none;
  border-radius:3px;
  cursor:pointer;
  font-size:14px;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  padding:5px 10px;
  text-align:left;
  vertical-align:middle;
  background-color:#f5f8fa;
  background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
  background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
  -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
          box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
  color:#182026;
  -moz-appearance:none;
  -webkit-appearance:none;
  border-radius:3px;
  height:30px;
  padding:0 25px 0 10px;
  width:100%; }
  .bp3-html-select select > *, .bp3-select select > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-html-select select > .bp3-fill, .bp3-select select > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-html-select select::before,
  .bp3-select select::before, .bp3-html-select select > *, .bp3-select select > *{
    margin-right:7px; }
  .bp3-html-select select:empty::before,
  .bp3-select select:empty::before,
  .bp3-html-select select > :last-child,
  .bp3-select select > :last-child{
    margin-right:0; }
  .bp3-html-select select:hover,
  .bp3-select select:hover{
    background-clip:padding-box;
    background-color:#ebf1f5;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
  .bp3-html-select select:active,
  .bp3-select select:active, .bp3-html-select select.bp3-active,
  .bp3-select select.bp3-active{
    background-color:#d8e1e8;
    background-image:none;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-html-select select:disabled,
  .bp3-select select:disabled, .bp3-html-select select.bp3-disabled,
  .bp3-select select.bp3-disabled{
    background-color:rgba(206, 217, 224, 0.5);
    background-image:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed;
    outline:none; }
    .bp3-html-select select:disabled.bp3-active,
    .bp3-select select:disabled.bp3-active, .bp3-html-select select:disabled.bp3-active:hover,
    .bp3-select select:disabled.bp3-active:hover, .bp3-html-select select.bp3-disabled.bp3-active,
    .bp3-select select.bp3-disabled.bp3-active, .bp3-html-select select.bp3-disabled.bp3-active:hover,
    .bp3-select select.bp3-disabled.bp3-active:hover{
      background:rgba(206, 217, 224, 0.7); }

.bp3-html-select.bp3-minimal select,
.bp3-select.bp3-minimal select{
  background:none;
  -webkit-box-shadow:none;
          box-shadow:none; }
  .bp3-html-select.bp3-minimal select:hover,
  .bp3-select.bp3-minimal select:hover{
    background:rgba(167, 182, 194, 0.3);
    -webkit-box-shadow:none;
            box-shadow:none;
    color:#182026;
    text-decoration:none; }
  .bp3-html-select.bp3-minimal select:active,
  .bp3-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal select.bp3-active,
  .bp3-select.bp3-minimal select.bp3-active{
    background:rgba(115, 134, 148, 0.3);
    -webkit-box-shadow:none;
            box-shadow:none;
    color:#182026; }
  .bp3-html-select.bp3-minimal select:disabled,
  .bp3-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal select:disabled:hover,
  .bp3-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal select.bp3-disabled,
  .bp3-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal select.bp3-disabled:hover,
  .bp3-select.bp3-minimal select.bp3-disabled:hover{
    background:none;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed; }
    .bp3-html-select.bp3-minimal select:disabled.bp3-active,
    .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active,
    .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active,
    .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active,
    .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active{
      background:rgba(115, 134, 148, 0.3); }
  .bp3-dark .bp3-html-select.bp3-minimal select, .bp3-html-select.bp3-minimal .bp3-dark select,
  .bp3-dark .bp3-select.bp3-minimal select, .bp3-select.bp3-minimal .bp3-dark select{
    background:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    color:inherit; }
    .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover,
    .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover, .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active,
    .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none; }
    .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover,
    .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover{
      background:rgba(138, 155, 168, 0.15); }
    .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active,
    .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{
      background:rgba(138, 155, 168, 0.3);
      color:#f5f8fa; }
    .bp3-dark .bp3-html-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal .bp3-dark select:disabled,
    .bp3-dark .bp3-select.bp3-minimal select:disabled, .bp3-select.bp3-minimal .bp3-dark select:disabled, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover,
    .bp3-dark .bp3-select.bp3-minimal select:disabled:hover, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover{
      background:none;
      color:rgba(167, 182, 194, 0.6);
      cursor:not-allowed; }
      .bp3-dark .bp3-html-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active{
        background:rgba(138, 155, 168, 0.3); }
  .bp3-html-select.bp3-minimal select.bp3-intent-primary,
  .bp3-select.bp3-minimal select.bp3-intent-primary{
    color:#106ba3; }
    .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover,
    .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal select.bp3-intent-primary:active,
    .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#106ba3; }
    .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover,
    .bp3-select.bp3-minimal select.bp3-intent-primary:hover{
      background:rgba(19, 124, 189, 0.15);
      color:#106ba3; }
    .bp3-html-select.bp3-minimal select.bp3-intent-primary:active,
    .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{
      background:rgba(19, 124, 189, 0.3);
      color:#106ba3; }
    .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled,
    .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled,
    .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled{
      background:none;
      color:rgba(16, 107, 163, 0.5); }
      .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active{
        background:rgba(19, 124, 189, 0.3); }
    .bp3-html-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
      stroke:#106ba3; }
    .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary{
      color:#48aff0; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover{
        background:rgba(19, 124, 189, 0.2);
        color:#48aff0; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active{
        background:rgba(19, 124, 189, 0.3);
        color:#48aff0; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled{
        background:none;
        color:rgba(72, 175, 240, 0.5); }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active{
          background:rgba(19, 124, 189, 0.3); }
  .bp3-html-select.bp3-minimal select.bp3-intent-success,
  .bp3-select.bp3-minimal select.bp3-intent-success{
    color:#0d8050; }
    .bp3-html-select.bp3-minimal select.bp3-intent-success:hover,
    .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal select.bp3-intent-success:active,
    .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#0d8050; }
    .bp3-html-select.bp3-minimal select.bp3-intent-success:hover,
    .bp3-select.bp3-minimal select.bp3-intent-success:hover{
      background:rgba(15, 153, 96, 0.15);
      color:#0d8050; }
    .bp3-html-select.bp3-minimal select.bp3-intent-success:active,
    .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{
      background:rgba(15, 153, 96, 0.3);
      color:#0d8050; }
    .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled,
    .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled,
    .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled{
      background:none;
      color:rgba(13, 128, 80, 0.5); }
      .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active{
        background:rgba(15, 153, 96, 0.3); }
    .bp3-html-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
      stroke:#0d8050; }
    .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success{
      color:#3dcc91; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover{
        background:rgba(15, 153, 96, 0.2);
        color:#3dcc91; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active{
        background:rgba(15, 153, 96, 0.3);
        color:#3dcc91; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled{
        background:none;
        color:rgba(61, 204, 145, 0.5); }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active{
          background:rgba(15, 153, 96, 0.3); }
  .bp3-html-select.bp3-minimal select.bp3-intent-warning,
  .bp3-select.bp3-minimal select.bp3-intent-warning{
    color:#bf7326; }
    .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover,
    .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal select.bp3-intent-warning:active,
    .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#bf7326; }
    .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover,
    .bp3-select.bp3-minimal select.bp3-intent-warning:hover{
      background:rgba(217, 130, 43, 0.15);
      color:#bf7326; }
    .bp3-html-select.bp3-minimal select.bp3-intent-warning:active,
    .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{
      background:rgba(217, 130, 43, 0.3);
      color:#bf7326; }
    .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled,
    .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled,
    .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled{
      background:none;
      color:rgba(191, 115, 38, 0.5); }
      .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active{
        background:rgba(217, 130, 43, 0.3); }
    .bp3-html-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
      stroke:#bf7326; }
    .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning{
      color:#ffb366; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover{
        background:rgba(217, 130, 43, 0.2);
        color:#ffb366; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active{
        background:rgba(217, 130, 43, 0.3);
        color:#ffb366; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled{
        background:none;
        color:rgba(255, 179, 102, 0.5); }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active{
          background:rgba(217, 130, 43, 0.3); }
  .bp3-html-select.bp3-minimal select.bp3-intent-danger,
  .bp3-select.bp3-minimal select.bp3-intent-danger{
    color:#c23030; }
    .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover,
    .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal select.bp3-intent-danger:active,
    .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#c23030; }
    .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover,
    .bp3-select.bp3-minimal select.bp3-intent-danger:hover{
      background:rgba(219, 55, 55, 0.15);
      color:#c23030; }
    .bp3-html-select.bp3-minimal select.bp3-intent-danger:active,
    .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active,
    .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{
      background:rgba(219, 55, 55, 0.3);
      color:#c23030; }
    .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled,
    .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled,
    .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled{
      background:none;
      color:rgba(194, 48, 48, 0.5); }
      .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active,
      .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active{
        background:rgba(219, 55, 55, 0.3); }
    .bp3-html-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
      stroke:#c23030; }
    .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger,
    .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger{
      color:#ff7373; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover{
        background:rgba(219, 55, 55, 0.2);
        color:#ff7373; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active{
        background:rgba(219, 55, 55, 0.3);
        color:#ff7373; }
      .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled,
      .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled{
        background:none;
        color:rgba(255, 115, 115, 0.5); }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active{
          background:rgba(219, 55, 55, 0.3); }

.bp3-html-select.bp3-large select,
.bp3-select.bp3-large select{
  font-size:16px;
  height:40px;
  padding-right:35px; }

.bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{
  background-color:#394b59;
  background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
  background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
  color:#f5f8fa; }
  .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover, .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{
    color:#f5f8fa; }
  .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover{
    background-color:#30404d;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{
    background-color:#202b33;
    background-image:none;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-html-select select:disabled, .bp3-dark .bp3-select select:disabled, .bp3-dark .bp3-html-select select.bp3-disabled, .bp3-dark .bp3-select select.bp3-disabled{
    background-color:rgba(57, 75, 89, 0.5);
    background-image:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-html-select select:disabled.bp3-active, .bp3-dark .bp3-select select:disabled.bp3-active, .bp3-dark .bp3-html-select select.bp3-disabled.bp3-active, .bp3-dark .bp3-select select.bp3-disabled.bp3-active{
      background:rgba(57, 75, 89, 0.7); }
  .bp3-dark .bp3-html-select select .bp3-button-spinner .bp3-spinner-head, .bp3-dark .bp3-select select .bp3-button-spinner .bp3-spinner-head{
    background:rgba(16, 22, 26, 0.5);
    stroke:#8a9ba8; }

.bp3-html-select select:disabled,
.bp3-select select:disabled{
  background-color:rgba(206, 217, 224, 0.5);
  -webkit-box-shadow:none;
          box-shadow:none;
  color:rgba(92, 112, 128, 0.6);
  cursor:not-allowed; }

.bp3-html-select .bp3-icon,
.bp3-select .bp3-icon, .bp3-select::after{
  color:#5c7080;
  pointer-events:none;
  position:absolute;
  right:7px;
  top:7px; }
  .bp3-html-select .bp3-disabled.bp3-icon,
  .bp3-select .bp3-disabled.bp3-icon, .bp3-disabled.bp3-select::after{
    color:rgba(92, 112, 128, 0.6); }
.bp3-html-select,
.bp3-select{
  display:inline-block;
  letter-spacing:normal;
  position:relative;
  vertical-align:middle; }
  .bp3-html-select select::-ms-expand,
  .bp3-select select::-ms-expand{
    display:none; }
  .bp3-html-select .bp3-icon,
  .bp3-select .bp3-icon{
    color:#5c7080; }
    .bp3-html-select .bp3-icon:hover,
    .bp3-select .bp3-icon:hover{
      color:#182026; }
    .bp3-dark .bp3-html-select .bp3-icon, .bp3-dark
    .bp3-select .bp3-icon{
      color:#a7b6c2; }
      .bp3-dark .bp3-html-select .bp3-icon:hover, .bp3-dark
      .bp3-select .bp3-icon:hover{
        color:#f5f8fa; }
  .bp3-html-select.bp3-large::after,
  .bp3-html-select.bp3-large .bp3-icon,
  .bp3-select.bp3-large::after,
  .bp3-select.bp3-large .bp3-icon{
    right:12px;
    top:12px; }
  .bp3-html-select.bp3-fill,
  .bp3-html-select.bp3-fill select,
  .bp3-select.bp3-fill,
  .bp3-select.bp3-fill select{
    width:100%; }
  .bp3-dark .bp3-html-select option, .bp3-dark
  .bp3-select option{
    background-color:#30404d;
    color:#f5f8fa; }
  .bp3-dark .bp3-html-select option:disabled, .bp3-dark
  .bp3-select option:disabled{
    color:rgba(167, 182, 194, 0.6); }
  .bp3-dark .bp3-html-select::after, .bp3-dark
  .bp3-select::after{
    color:#a7b6c2; }

.bp3-select::after{
  font-family:"Icons16", sans-serif;
  font-size:16px;
  font-style:normal;
  font-weight:400;
  line-height:1;
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-smoothing:antialiased;
  content:""; }
.bp3-running-text table, table.bp3-html-table{
  border-spacing:0;
  font-size:14px; }
  .bp3-running-text table th, table.bp3-html-table th,
  .bp3-running-text table td,
  table.bp3-html-table td{
    padding:11px;
    text-align:left;
    vertical-align:top; }
  .bp3-running-text table th, table.bp3-html-table th{
    color:#182026;
    font-weight:600; }
  
  .bp3-running-text table td,
  table.bp3-html-table td{
    color:#182026; }
  .bp3-running-text table tbody tr:first-child th, table.bp3-html-table tbody tr:first-child th,
  .bp3-running-text table tbody tr:first-child td,
  table.bp3-html-table tbody tr:first-child td{
    -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15);
            box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); }
  .bp3-dark .bp3-running-text table th, .bp3-running-text .bp3-dark table th, .bp3-dark table.bp3-html-table th{
    color:#f5f8fa; }
  .bp3-dark .bp3-running-text table td, .bp3-running-text .bp3-dark table td, .bp3-dark table.bp3-html-table td{
    color:#f5f8fa; }
  .bp3-dark .bp3-running-text table tbody tr:first-child th, .bp3-running-text .bp3-dark table tbody tr:first-child th, .bp3-dark table.bp3-html-table tbody tr:first-child th,
  .bp3-dark .bp3-running-text table tbody tr:first-child td,
  .bp3-running-text .bp3-dark table tbody tr:first-child td,
  .bp3-dark table.bp3-html-table tbody tr:first-child td{
    -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15);
            box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); }

table.bp3-html-table.bp3-html-table-condensed th,
table.bp3-html-table.bp3-html-table-condensed td, table.bp3-html-table.bp3-small th,
table.bp3-html-table.bp3-small td{
  padding-bottom:6px;
  padding-top:6px; }

table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{
  background:rgba(191, 204, 214, 0.15); }

table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){
  -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15);
          box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); }

table.bp3-html-table.bp3-html-table-bordered tbody tr td{
  -webkit-box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15);
          box-shadow:inset 0 1px 0 0 rgba(16, 22, 26, 0.15); }
  table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child){
    -webkit-box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15);
            box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); }

table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{
  -webkit-box-shadow:none;
          box-shadow:none; }
  table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:not(:first-child){
    -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15);
            box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); }

table.bp3-html-table.bp3-interactive tbody tr:hover td{
  background-color:rgba(191, 204, 214, 0.3);
  cursor:pointer; }

table.bp3-html-table.bp3-interactive tbody tr:active td{
  background-color:rgba(191, 204, 214, 0.4); }

.bp3-dark table.bp3-html-table{ }
  .bp3-dark table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{
    background:rgba(92, 112, 128, 0.15); }
  .bp3-dark table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){
    -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15);
            box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); }
  .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td{
    -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15);
            box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); }
    .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td:not(:first-child){
      -webkit-box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15);
              box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); }
  .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{
    -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15);
            box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); }
    .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:first-child{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:hover td{
    background-color:rgba(92, 112, 128, 0.3);
    cursor:pointer; }
  .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:active td{
    background-color:rgba(92, 112, 128, 0.4); }

.bp3-key-combo{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center; }
  .bp3-key-combo > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-key-combo > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-key-combo::before,
  .bp3-key-combo > *{
    margin-right:5px; }
  .bp3-key-combo:empty::before,
  .bp3-key-combo > :last-child{
    margin-right:0; }

.bp3-hotkey-dialog{
  padding-bottom:0;
  top:40px; }
  .bp3-hotkey-dialog .bp3-dialog-body{
    margin:0;
    padding:0; }
  .bp3-hotkey-dialog .bp3-hotkey-label{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1; }

.bp3-hotkey-column{
  margin:auto;
  max-height:80vh;
  overflow-y:auto;
  padding:30px; }
  .bp3-hotkey-column .bp3-heading{
    margin-bottom:20px; }
    .bp3-hotkey-column .bp3-heading:not(:first-child){
      margin-top:40px; }

.bp3-hotkey{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:justify;
      -ms-flex-pack:justify;
          justify-content:space-between;
  margin-left:0;
  margin-right:0; }
  .bp3-hotkey:not(:last-child){
    margin-bottom:10px; }
.bp3-icon{
  display:inline-block;
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  vertical-align:text-bottom; }
  .bp3-icon:not(:empty)::before{
    content:"" !important;
    content:unset !important; }
  .bp3-icon > svg{
    display:block; }
    .bp3-icon > svg:not([fill]){
      fill:currentColor; }

.bp3-icon.bp3-intent-primary, .bp3-icon-standard.bp3-intent-primary, .bp3-icon-large.bp3-intent-primary{
  color:#106ba3; }
  .bp3-dark .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-icon-large.bp3-intent-primary{
    color:#48aff0; }

.bp3-icon.bp3-intent-success, .bp3-icon-standard.bp3-intent-success, .bp3-icon-large.bp3-intent-success{
  color:#0d8050; }
  .bp3-dark .bp3-icon.bp3-intent-success, .bp3-dark .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-icon-large.bp3-intent-success{
    color:#3dcc91; }

.bp3-icon.bp3-intent-warning, .bp3-icon-standard.bp3-intent-warning, .bp3-icon-large.bp3-intent-warning{
  color:#bf7326; }
  .bp3-dark .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-icon-large.bp3-intent-warning{
    color:#ffb366; }

.bp3-icon.bp3-intent-danger, .bp3-icon-standard.bp3-intent-danger, .bp3-icon-large.bp3-intent-danger{
  color:#c23030; }
  .bp3-dark .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-icon-large.bp3-intent-danger{
    color:#ff7373; }

span.bp3-icon-standard{
  font-family:"Icons16", sans-serif;
  font-size:16px;
  font-style:normal;
  font-weight:400;
  line-height:1;
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-smoothing:antialiased;
  display:inline-block; }

span.bp3-icon-large{
  font-family:"Icons20", sans-serif;
  font-size:20px;
  font-style:normal;
  font-weight:400;
  line-height:1;
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-smoothing:antialiased;
  display:inline-block; }

span.bp3-icon:empty{
  font-family:"Icons20";
  font-size:inherit;
  font-style:normal;
  font-weight:400;
  line-height:1; }
  span.bp3-icon:empty::before{
    -moz-osx-font-smoothing:grayscale;
    -webkit-font-smoothing:antialiased; }

.bp3-icon-add::before{
  content:""; }

.bp3-icon-add-column-left::before{
  content:""; }

.bp3-icon-add-column-right::before{
  content:""; }

.bp3-icon-add-row-bottom::before{
  content:""; }

.bp3-icon-add-row-top::before{
  content:""; }

.bp3-icon-add-to-artifact::before{
  content:""; }

.bp3-icon-add-to-folder::before{
  content:""; }

.bp3-icon-airplane::before{
  content:""; }

.bp3-icon-align-center::before{
  content:""; }

.bp3-icon-align-justify::before{
  content:""; }

.bp3-icon-align-left::before{
  content:""; }

.bp3-icon-align-right::before{
  content:""; }

.bp3-icon-alignment-bottom::before{
  content:""; }

.bp3-icon-alignment-horizontal-center::before{
  content:""; }

.bp3-icon-alignment-left::before{
  content:""; }

.bp3-icon-alignment-right::before{
  content:""; }

.bp3-icon-alignment-top::before{
  content:""; }

.bp3-icon-alignment-vertical-center::before{
  content:""; }

.bp3-icon-annotation::before{
  content:""; }

.bp3-icon-application::before{
  content:""; }

.bp3-icon-applications::before{
  content:""; }

.bp3-icon-archive::before{
  content:""; }

.bp3-icon-arrow-bottom-left::before{
  content:"↙"; }

.bp3-icon-arrow-bottom-right::before{
  content:"↘"; }

.bp3-icon-arrow-down::before{
  content:"↓"; }

.bp3-icon-arrow-left::before{
  content:"←"; }

.bp3-icon-arrow-right::before{
  content:"→"; }

.bp3-icon-arrow-top-left::before{
  content:"↖"; }

.bp3-icon-arrow-top-right::before{
  content:"↗"; }

.bp3-icon-arrow-up::before{
  content:"↑"; }

.bp3-icon-arrows-horizontal::before{
  content:"↔"; }

.bp3-icon-arrows-vertical::before{
  content:"↕"; }

.bp3-icon-asterisk::before{
  content:"*"; }

.bp3-icon-automatic-updates::before{
  content:""; }

.bp3-icon-badge::before{
  content:""; }

.bp3-icon-ban-circle::before{
  content:""; }

.bp3-icon-bank-account::before{
  content:""; }

.bp3-icon-barcode::before{
  content:""; }

.bp3-icon-blank::before{
  content:""; }

.bp3-icon-blocked-person::before{
  content:""; }

.bp3-icon-bold::before{
  content:""; }

.bp3-icon-book::before{
  content:""; }

.bp3-icon-bookmark::before{
  content:""; }

.bp3-icon-box::before{
  content:""; }

.bp3-icon-briefcase::before{
  content:""; }

.bp3-icon-bring-data::before{
  content:""; }

.bp3-icon-build::before{
  content:""; }

.bp3-icon-calculator::before{
  content:""; }

.bp3-icon-calendar::before{
  content:""; }

.bp3-icon-camera::before{
  content:""; }

.bp3-icon-caret-down::before{
  content:"⌄"; }

.bp3-icon-caret-left::before{
  content:"〈"; }

.bp3-icon-caret-right::before{
  content:"〉"; }

.bp3-icon-caret-up::before{
  content:"⌃"; }

.bp3-icon-cell-tower::before{
  content:""; }

.bp3-icon-changes::before{
  content:""; }

.bp3-icon-chart::before{
  content:""; }

.bp3-icon-chat::before{
  content:""; }

.bp3-icon-chevron-backward::before{
  content:""; }

.bp3-icon-chevron-down::before{
  content:""; }

.bp3-icon-chevron-forward::before{
  content:""; }

.bp3-icon-chevron-left::before{
  content:""; }

.bp3-icon-chevron-right::before{
  content:""; }

.bp3-icon-chevron-up::before{
  content:""; }

.bp3-icon-circle::before{
  content:""; }

.bp3-icon-circle-arrow-down::before{
  content:""; }

.bp3-icon-circle-arrow-left::before{
  content:""; }

.bp3-icon-circle-arrow-right::before{
  content:""; }

.bp3-icon-circle-arrow-up::before{
  content:""; }

.bp3-icon-citation::before{
  content:""; }

.bp3-icon-clean::before{
  content:""; }

.bp3-icon-clipboard::before{
  content:""; }

.bp3-icon-cloud::before{
  content:"☁"; }

.bp3-icon-cloud-download::before{
  content:""; }

.bp3-icon-cloud-upload::before{
  content:""; }

.bp3-icon-code::before{
  content:""; }

.bp3-icon-code-block::before{
  content:""; }

.bp3-icon-cog::before{
  content:""; }

.bp3-icon-collapse-all::before{
  content:""; }

.bp3-icon-column-layout::before{
  content:""; }

.bp3-icon-comment::before{
  content:""; }

.bp3-icon-comparison::before{
  content:""; }

.bp3-icon-compass::before{
  content:""; }

.bp3-icon-compressed::before{
  content:""; }

.bp3-icon-confirm::before{
  content:""; }

.bp3-icon-console::before{
  content:""; }

.bp3-icon-contrast::before{
  content:""; }

.bp3-icon-control::before{
  content:""; }

.bp3-icon-credit-card::before{
  content:""; }

.bp3-icon-cross::before{
  content:"✗"; }

.bp3-icon-crown::before{
  content:""; }

.bp3-icon-cube::before{
  content:""; }

.bp3-icon-cube-add::before{
  content:""; }

.bp3-icon-cube-remove::before{
  content:""; }

.bp3-icon-curved-range-chart::before{
  content:""; }

.bp3-icon-cut::before{
  content:""; }

.bp3-icon-dashboard::before{
  content:""; }

.bp3-icon-data-lineage::before{
  content:""; }

.bp3-icon-database::before{
  content:""; }

.bp3-icon-delete::before{
  content:""; }

.bp3-icon-delta::before{
  content:"Δ"; }

.bp3-icon-derive-column::before{
  content:""; }

.bp3-icon-desktop::before{
  content:""; }

.bp3-icon-diagnosis::before{
  content:""; }

.bp3-icon-diagram-tree::before{
  content:""; }

.bp3-icon-direction-left::before{
  content:""; }

.bp3-icon-direction-right::before{
  content:""; }

.bp3-icon-disable::before{
  content:""; }

.bp3-icon-document::before{
  content:""; }

.bp3-icon-document-open::before{
  content:""; }

.bp3-icon-document-share::before{
  content:""; }

.bp3-icon-dollar::before{
  content:"$"; }

.bp3-icon-dot::before{
  content:"•"; }

.bp3-icon-double-caret-horizontal::before{
  content:""; }

.bp3-icon-double-caret-vertical::before{
  content:""; }

.bp3-icon-double-chevron-down::before{
  content:""; }

.bp3-icon-double-chevron-left::before{
  content:""; }

.bp3-icon-double-chevron-right::before{
  content:""; }

.bp3-icon-double-chevron-up::before{
  content:""; }

.bp3-icon-doughnut-chart::before{
  content:""; }

.bp3-icon-download::before{
  content:""; }

.bp3-icon-drag-handle-horizontal::before{
  content:""; }

.bp3-icon-drag-handle-vertical::before{
  content:""; }

.bp3-icon-draw::before{
  content:""; }

.bp3-icon-drive-time::before{
  content:""; }

.bp3-icon-duplicate::before{
  content:""; }

.bp3-icon-edit::before{
  content:"✎"; }

.bp3-icon-eject::before{
  content:"⏏"; }

.bp3-icon-endorsed::before{
  content:""; }

.bp3-icon-envelope::before{
  content:"✉"; }

.bp3-icon-equals::before{
  content:""; }

.bp3-icon-eraser::before{
  content:""; }

.bp3-icon-error::before{
  content:""; }

.bp3-icon-euro::before{
  content:"€"; }

.bp3-icon-exchange::before{
  content:""; }

.bp3-icon-exclude-row::before{
  content:""; }

.bp3-icon-expand-all::before{
  content:""; }

.bp3-icon-export::before{
  content:""; }

.bp3-icon-eye-off::before{
  content:""; }

.bp3-icon-eye-on::before{
  content:""; }

.bp3-icon-eye-open::before{
  content:""; }

.bp3-icon-fast-backward::before{
  content:""; }

.bp3-icon-fast-forward::before{
  content:""; }

.bp3-icon-feed::before{
  content:""; }

.bp3-icon-feed-subscribed::before{
  content:""; }

.bp3-icon-film::before{
  content:""; }

.bp3-icon-filter::before{
  content:""; }

.bp3-icon-filter-keep::before{
  content:""; }

.bp3-icon-filter-list::before{
  content:""; }

.bp3-icon-filter-open::before{
  content:""; }

.bp3-icon-filter-remove::before{
  content:""; }

.bp3-icon-flag::before{
  content:"⚑"; }

.bp3-icon-flame::before{
  content:""; }

.bp3-icon-flash::before{
  content:""; }

.bp3-icon-floppy-disk::before{
  content:""; }

.bp3-icon-flow-branch::before{
  content:""; }

.bp3-icon-flow-end::before{
  content:""; }

.bp3-icon-flow-linear::before{
  content:""; }

.bp3-icon-flow-review::before{
  content:""; }

.bp3-icon-flow-review-branch::before{
  content:""; }

.bp3-icon-flows::before{
  content:""; }

.bp3-icon-folder-close::before{
  content:""; }

.bp3-icon-folder-new::before{
  content:""; }

.bp3-icon-folder-open::before{
  content:""; }

.bp3-icon-folder-shared::before{
  content:""; }

.bp3-icon-folder-shared-open::before{
  content:""; }

.bp3-icon-follower::before{
  content:""; }

.bp3-icon-following::before{
  content:""; }

.bp3-icon-font::before{
  content:""; }

.bp3-icon-fork::before{
  content:""; }

.bp3-icon-form::before{
  content:""; }

.bp3-icon-full-circle::before{
  content:""; }

.bp3-icon-full-stacked-chart::before{
  content:""; }

.bp3-icon-fullscreen::before{
  content:""; }

.bp3-icon-function::before{
  content:""; }

.bp3-icon-gantt-chart::before{
  content:""; }

.bp3-icon-geolocation::before{
  content:""; }

.bp3-icon-geosearch::before{
  content:""; }

.bp3-icon-git-branch::before{
  content:""; }

.bp3-icon-git-commit::before{
  content:""; }

.bp3-icon-git-merge::before{
  content:""; }

.bp3-icon-git-new-branch::before{
  content:""; }

.bp3-icon-git-pull::before{
  content:""; }

.bp3-icon-git-push::before{
  content:""; }

.bp3-icon-git-repo::before{
  content:""; }

.bp3-icon-glass::before{
  content:""; }

.bp3-icon-globe::before{
  content:""; }

.bp3-icon-globe-network::before{
  content:""; }

.bp3-icon-graph::before{
  content:""; }

.bp3-icon-graph-remove::before{
  content:""; }

.bp3-icon-greater-than::before{
  content:""; }

.bp3-icon-greater-than-or-equal-to::before{
  content:""; }

.bp3-icon-grid::before{
  content:""; }

.bp3-icon-grid-view::before{
  content:""; }

.bp3-icon-group-objects::before{
  content:""; }

.bp3-icon-grouped-bar-chart::before{
  content:""; }

.bp3-icon-hand::before{
  content:""; }

.bp3-icon-hand-down::before{
  content:""; }

.bp3-icon-hand-left::before{
  content:""; }

.bp3-icon-hand-right::before{
  content:""; }

.bp3-icon-hand-up::before{
  content:""; }

.bp3-icon-header::before{
  content:""; }

.bp3-icon-header-one::before{
  content:""; }

.bp3-icon-header-two::before{
  content:""; }

.bp3-icon-headset::before{
  content:""; }

.bp3-icon-heart::before{
  content:"♥"; }

.bp3-icon-heart-broken::before{
  content:""; }

.bp3-icon-heat-grid::before{
  content:""; }

.bp3-icon-heatmap::before{
  content:""; }

.bp3-icon-help::before{
  content:"?"; }

.bp3-icon-helper-management::before{
  content:""; }

.bp3-icon-highlight::before{
  content:""; }

.bp3-icon-history::before{
  content:""; }

.bp3-icon-home::before{
  content:"⌂"; }

.bp3-icon-horizontal-bar-chart::before{
  content:""; }

.bp3-icon-horizontal-bar-chart-asc::before{
  content:""; }

.bp3-icon-horizontal-bar-chart-desc::before{
  content:""; }

.bp3-icon-horizontal-distribution::before{
  content:""; }

.bp3-icon-id-number::before{
  content:""; }

.bp3-icon-image-rotate-left::before{
  content:""; }

.bp3-icon-image-rotate-right::before{
  content:""; }

.bp3-icon-import::before{
  content:""; }

.bp3-icon-inbox::before{
  content:""; }

.bp3-icon-inbox-filtered::before{
  content:""; }

.bp3-icon-inbox-geo::before{
  content:""; }

.bp3-icon-inbox-search::before{
  content:""; }

.bp3-icon-inbox-update::before{
  content:""; }

.bp3-icon-info-sign::before{
  content:"ℹ"; }

.bp3-icon-inheritance::before{
  content:""; }

.bp3-icon-inner-join::before{
  content:""; }

.bp3-icon-insert::before{
  content:""; }

.bp3-icon-intersection::before{
  content:""; }

.bp3-icon-ip-address::before{
  content:""; }

.bp3-icon-issue::before{
  content:""; }

.bp3-icon-issue-closed::before{
  content:""; }

.bp3-icon-issue-new::before{
  content:""; }

.bp3-icon-italic::before{
  content:""; }

.bp3-icon-join-table::before{
  content:""; }

.bp3-icon-key::before{
  content:""; }

.bp3-icon-key-backspace::before{
  content:""; }

.bp3-icon-key-command::before{
  content:""; }

.bp3-icon-key-control::before{
  content:""; }

.bp3-icon-key-delete::before{
  content:""; }

.bp3-icon-key-enter::before{
  content:""; }

.bp3-icon-key-escape::before{
  content:""; }

.bp3-icon-key-option::before{
  content:""; }

.bp3-icon-key-shift::before{
  content:""; }

.bp3-icon-key-tab::before{
  content:""; }

.bp3-icon-known-vehicle::before{
  content:""; }

.bp3-icon-lab-test::before{
  content:""; }

.bp3-icon-label::before{
  content:""; }

.bp3-icon-layer::before{
  content:""; }

.bp3-icon-layers::before{
  content:""; }

.bp3-icon-layout::before{
  content:""; }

.bp3-icon-layout-auto::before{
  content:""; }

.bp3-icon-layout-balloon::before{
  content:""; }

.bp3-icon-layout-circle::before{
  content:""; }

.bp3-icon-layout-grid::before{
  content:""; }

.bp3-icon-layout-group-by::before{
  content:""; }

.bp3-icon-layout-hierarchy::before{
  content:""; }

.bp3-icon-layout-linear::before{
  content:""; }

.bp3-icon-layout-skew-grid::before{
  content:""; }

.bp3-icon-layout-sorted-clusters::before{
  content:""; }

.bp3-icon-learning::before{
  content:""; }

.bp3-icon-left-join::before{
  content:""; }

.bp3-icon-less-than::before{
  content:""; }

.bp3-icon-less-than-or-equal-to::before{
  content:""; }

.bp3-icon-lifesaver::before{
  content:""; }

.bp3-icon-lightbulb::before{
  content:""; }

.bp3-icon-link::before{
  content:""; }

.bp3-icon-list::before{
  content:"☰"; }

.bp3-icon-list-columns::before{
  content:""; }

.bp3-icon-list-detail-view::before{
  content:""; }

.bp3-icon-locate::before{
  content:""; }

.bp3-icon-lock::before{
  content:""; }

.bp3-icon-log-in::before{
  content:""; }

.bp3-icon-log-out::before{
  content:""; }

.bp3-icon-manual::before{
  content:""; }

.bp3-icon-manually-entered-data::before{
  content:""; }

.bp3-icon-map::before{
  content:""; }

.bp3-icon-map-create::before{
  content:""; }

.bp3-icon-map-marker::before{
  content:""; }

.bp3-icon-maximize::before{
  content:""; }

.bp3-icon-media::before{
  content:""; }

.bp3-icon-menu::before{
  content:""; }

.bp3-icon-menu-closed::before{
  content:""; }

.bp3-icon-menu-open::before{
  content:""; }

.bp3-icon-merge-columns::before{
  content:""; }

.bp3-icon-merge-links::before{
  content:""; }

.bp3-icon-minimize::before{
  content:""; }

.bp3-icon-minus::before{
  content:"−"; }

.bp3-icon-mobile-phone::before{
  content:""; }

.bp3-icon-mobile-video::before{
  content:""; }

.bp3-icon-moon::before{
  content:""; }

.bp3-icon-more::before{
  content:""; }

.bp3-icon-mountain::before{
  content:""; }

.bp3-icon-move::before{
  content:""; }

.bp3-icon-mugshot::before{
  content:""; }

.bp3-icon-multi-select::before{
  content:""; }

.bp3-icon-music::before{
  content:""; }

.bp3-icon-new-drawing::before{
  content:""; }

.bp3-icon-new-grid-item::before{
  content:""; }

.bp3-icon-new-layer::before{
  content:""; }

.bp3-icon-new-layers::before{
  content:""; }

.bp3-icon-new-link::before{
  content:""; }

.bp3-icon-new-object::before{
  content:""; }

.bp3-icon-new-person::before{
  content:""; }

.bp3-icon-new-prescription::before{
  content:""; }

.bp3-icon-new-text-box::before{
  content:""; }

.bp3-icon-ninja::before{
  content:""; }

.bp3-icon-not-equal-to::before{
  content:""; }

.bp3-icon-notifications::before{
  content:""; }

.bp3-icon-notifications-updated::before{
  content:""; }

.bp3-icon-numbered-list::before{
  content:""; }

.bp3-icon-numerical::before{
  content:""; }

.bp3-icon-office::before{
  content:""; }

.bp3-icon-offline::before{
  content:""; }

.bp3-icon-oil-field::before{
  content:""; }

.bp3-icon-one-column::before{
  content:""; }

.bp3-icon-outdated::before{
  content:""; }

.bp3-icon-page-layout::before{
  content:""; }

.bp3-icon-panel-stats::before{
  content:""; }

.bp3-icon-panel-table::before{
  content:""; }

.bp3-icon-paperclip::before{
  content:""; }

.bp3-icon-paragraph::before{
  content:""; }

.bp3-icon-path::before{
  content:""; }

.bp3-icon-path-search::before{
  content:""; }

.bp3-icon-pause::before{
  content:""; }

.bp3-icon-people::before{
  content:""; }

.bp3-icon-percentage::before{
  content:""; }

.bp3-icon-person::before{
  content:""; }

.bp3-icon-phone::before{
  content:"☎"; }

.bp3-icon-pie-chart::before{
  content:""; }

.bp3-icon-pin::before{
  content:""; }

.bp3-icon-pivot::before{
  content:""; }

.bp3-icon-pivot-table::before{
  content:""; }

.bp3-icon-play::before{
  content:""; }

.bp3-icon-plus::before{
  content:"+"; }

.bp3-icon-polygon-filter::before{
  content:""; }

.bp3-icon-power::before{
  content:""; }

.bp3-icon-predictive-analysis::before{
  content:""; }

.bp3-icon-prescription::before{
  content:""; }

.bp3-icon-presentation::before{
  content:""; }

.bp3-icon-print::before{
  content:"⎙"; }

.bp3-icon-projects::before{
  content:""; }

.bp3-icon-properties::before{
  content:""; }

.bp3-icon-property::before{
  content:""; }

.bp3-icon-publish-function::before{
  content:""; }

.bp3-icon-pulse::before{
  content:""; }

.bp3-icon-random::before{
  content:""; }

.bp3-icon-record::before{
  content:""; }

.bp3-icon-redo::before{
  content:""; }

.bp3-icon-refresh::before{
  content:""; }

.bp3-icon-regression-chart::before{
  content:""; }

.bp3-icon-remove::before{
  content:""; }

.bp3-icon-remove-column::before{
  content:""; }

.bp3-icon-remove-column-left::before{
  content:""; }

.bp3-icon-remove-column-right::before{
  content:""; }

.bp3-icon-remove-row-bottom::before{
  content:""; }

.bp3-icon-remove-row-top::before{
  content:""; }

.bp3-icon-repeat::before{
  content:""; }

.bp3-icon-reset::before{
  content:""; }

.bp3-icon-resolve::before{
  content:""; }

.bp3-icon-rig::before{
  content:""; }

.bp3-icon-right-join::before{
  content:""; }

.bp3-icon-ring::before{
  content:""; }

.bp3-icon-rotate-document::before{
  content:""; }

.bp3-icon-rotate-page::before{
  content:""; }

.bp3-icon-satellite::before{
  content:""; }

.bp3-icon-saved::before{
  content:""; }

.bp3-icon-scatter-plot::before{
  content:""; }

.bp3-icon-search::before{
  content:""; }

.bp3-icon-search-around::before{
  content:""; }

.bp3-icon-search-template::before{
  content:""; }

.bp3-icon-search-text::before{
  content:""; }

.bp3-icon-segmented-control::before{
  content:""; }

.bp3-icon-select::before{
  content:""; }

.bp3-icon-selection::before{
  content:"⦿"; }

.bp3-icon-send-to::before{
  content:""; }

.bp3-icon-send-to-graph::before{
  content:""; }

.bp3-icon-send-to-map::before{
  content:""; }

.bp3-icon-series-add::before{
  content:""; }

.bp3-icon-series-configuration::before{
  content:""; }

.bp3-icon-series-derived::before{
  content:""; }

.bp3-icon-series-filtered::before{
  content:""; }

.bp3-icon-series-search::before{
  content:""; }

.bp3-icon-settings::before{
  content:""; }

.bp3-icon-share::before{
  content:""; }

.bp3-icon-shield::before{
  content:""; }

.bp3-icon-shop::before{
  content:""; }

.bp3-icon-shopping-cart::before{
  content:""; }

.bp3-icon-signal-search::before{
  content:""; }

.bp3-icon-sim-card::before{
  content:""; }

.bp3-icon-slash::before{
  content:""; }

.bp3-icon-small-cross::before{
  content:""; }

.bp3-icon-small-minus::before{
  content:""; }

.bp3-icon-small-plus::before{
  content:""; }

.bp3-icon-small-tick::before{
  content:""; }

.bp3-icon-snowflake::before{
  content:""; }

.bp3-icon-social-media::before{
  content:""; }

.bp3-icon-sort::before{
  content:""; }

.bp3-icon-sort-alphabetical::before{
  content:""; }

.bp3-icon-sort-alphabetical-desc::before{
  content:""; }

.bp3-icon-sort-asc::before{
  content:""; }

.bp3-icon-sort-desc::before{
  content:""; }

.bp3-icon-sort-numerical::before{
  content:""; }

.bp3-icon-sort-numerical-desc::before{
  content:""; }

.bp3-icon-split-columns::before{
  content:""; }

.bp3-icon-square::before{
  content:""; }

.bp3-icon-stacked-chart::before{
  content:""; }

.bp3-icon-star::before{
  content:"★"; }

.bp3-icon-star-empty::before{
  content:"☆"; }

.bp3-icon-step-backward::before{
  content:""; }

.bp3-icon-step-chart::before{
  content:""; }

.bp3-icon-step-forward::before{
  content:""; }

.bp3-icon-stop::before{
  content:""; }

.bp3-icon-stopwatch::before{
  content:""; }

.bp3-icon-strikethrough::before{
  content:""; }

.bp3-icon-style::before{
  content:""; }

.bp3-icon-swap-horizontal::before{
  content:""; }

.bp3-icon-swap-vertical::before{
  content:""; }

.bp3-icon-symbol-circle::before{
  content:""; }

.bp3-icon-symbol-cross::before{
  content:""; }

.bp3-icon-symbol-diamond::before{
  content:""; }

.bp3-icon-symbol-square::before{
  content:""; }

.bp3-icon-symbol-triangle-down::before{
  content:""; }

.bp3-icon-symbol-triangle-up::before{
  content:""; }

.bp3-icon-tag::before{
  content:""; }

.bp3-icon-take-action::before{
  content:""; }

.bp3-icon-taxi::before{
  content:""; }

.bp3-icon-text-highlight::before{
  content:""; }

.bp3-icon-th::before{
  content:""; }

.bp3-icon-th-derived::before{
  content:""; }

.bp3-icon-th-disconnect::before{
  content:""; }

.bp3-icon-th-filtered::before{
  content:""; }

.bp3-icon-th-list::before{
  content:""; }

.bp3-icon-thumbs-down::before{
  content:""; }

.bp3-icon-thumbs-up::before{
  content:""; }

.bp3-icon-tick::before{
  content:"✓"; }

.bp3-icon-tick-circle::before{
  content:""; }

.bp3-icon-time::before{
  content:"⏲"; }

.bp3-icon-timeline-area-chart::before{
  content:""; }

.bp3-icon-timeline-bar-chart::before{
  content:""; }

.bp3-icon-timeline-events::before{
  content:""; }

.bp3-icon-timeline-line-chart::before{
  content:""; }

.bp3-icon-tint::before{
  content:""; }

.bp3-icon-torch::before{
  content:""; }

.bp3-icon-tractor::before{
  content:""; }

.bp3-icon-train::before{
  content:""; }

.bp3-icon-translate::before{
  content:""; }

.bp3-icon-trash::before{
  content:""; }

.bp3-icon-tree::before{
  content:""; }

.bp3-icon-trending-down::before{
  content:""; }

.bp3-icon-trending-up::before{
  content:""; }

.bp3-icon-truck::before{
  content:""; }

.bp3-icon-two-columns::before{
  content:""; }

.bp3-icon-unarchive::before{
  content:""; }

.bp3-icon-underline::before{
  content:"⎁"; }

.bp3-icon-undo::before{
  content:"⎌"; }

.bp3-icon-ungroup-objects::before{
  content:""; }

.bp3-icon-unknown-vehicle::before{
  content:""; }

.bp3-icon-unlock::before{
  content:""; }

.bp3-icon-unpin::before{
  content:""; }

.bp3-icon-unresolve::before{
  content:""; }

.bp3-icon-updated::before{
  content:""; }

.bp3-icon-upload::before{
  content:""; }

.bp3-icon-user::before{
  content:""; }

.bp3-icon-variable::before{
  content:""; }

.bp3-icon-vertical-bar-chart-asc::before{
  content:""; }

.bp3-icon-vertical-bar-chart-desc::before{
  content:""; }

.bp3-icon-vertical-distribution::before{
  content:""; }

.bp3-icon-video::before{
  content:""; }

.bp3-icon-volume-down::before{
  content:""; }

.bp3-icon-volume-off::before{
  content:""; }

.bp3-icon-volume-up::before{
  content:""; }

.bp3-icon-walk::before{
  content:""; }

.bp3-icon-warning-sign::before{
  content:""; }

.bp3-icon-waterfall-chart::before{
  content:""; }

.bp3-icon-widget::before{
  content:""; }

.bp3-icon-widget-button::before{
  content:""; }

.bp3-icon-widget-footer::before{
  content:""; }

.bp3-icon-widget-header::before{
  content:""; }

.bp3-icon-wrench::before{
  content:""; }

.bp3-icon-zoom-in::before{
  content:""; }

.bp3-icon-zoom-out::before{
  content:""; }

.bp3-icon-zoom-to-fit::before{
  content:""; }
.bp3-submenu > .bp3-popover-wrapper{
  display:block; }

.bp3-submenu .bp3-popover-target{
  display:block; }
  .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ }

.bp3-submenu.bp3-popover{
  -webkit-box-shadow:none;
          box-shadow:none;
  padding:0 5px; }
  .bp3-submenu.bp3-popover > .bp3-popover-content{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-submenu.bp3-popover, .bp3-submenu.bp3-popover.bp3-dark{
    -webkit-box-shadow:none;
            box-shadow:none; }
    .bp3-dark .bp3-submenu.bp3-popover > .bp3-popover-content, .bp3-submenu.bp3-popover.bp3-dark > .bp3-popover-content{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
.bp3-menu{
  background:#ffffff;
  border-radius:3px;
  color:#182026;
  list-style:none;
  margin:0;
  min-width:180px;
  padding:5px;
  text-align:left; }

.bp3-menu-divider{
  border-top:1px solid rgba(16, 22, 26, 0.15);
  display:block;
  margin:5px; }
  .bp3-dark .bp3-menu-divider{
    border-top-color:rgba(255, 255, 255, 0.15); }

.bp3-menu-item{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:start;
      -ms-flex-align:start;
          align-items:flex-start;
  border-radius:2px;
  color:inherit;
  line-height:20px;
  padding:5px 7px;
  text-decoration:none;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-menu-item > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-menu-item > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-menu-item::before,
  .bp3-menu-item > *{
    margin-right:7px; }
  .bp3-menu-item:empty::before,
  .bp3-menu-item > :last-child{
    margin-right:0; }
  .bp3-menu-item > .bp3-fill{
    word-break:break-word; }
  .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
    background-color:rgba(167, 182, 194, 0.3);
    cursor:pointer;
    text-decoration:none; }
  .bp3-menu-item.bp3-disabled{
    background-color:inherit;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed; }
  .bp3-dark .bp3-menu-item{
    color:inherit; }
    .bp3-dark .bp3-menu-item:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
      background-color:rgba(138, 155, 168, 0.15);
      color:inherit; }
    .bp3-dark .bp3-menu-item.bp3-disabled{
      background-color:inherit;
      color:rgba(167, 182, 194, 0.6); }
  .bp3-menu-item.bp3-intent-primary{
    color:#106ba3; }
    .bp3-menu-item.bp3-intent-primary .bp3-icon{
      color:inherit; }
    .bp3-menu-item.bp3-intent-primary::before, .bp3-menu-item.bp3-intent-primary::after,
    .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{
      color:#106ba3; }
    .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary.bp3-active{
      background-color:#137cbd; }
    .bp3-menu-item.bp3-intent-primary:active{
      background-color:#106ba3; }
    .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after,
    .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label,
    .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary:active, .bp3-menu-item.bp3-intent-primary:active::before, .bp3-menu-item.bp3-intent-primary:active::after,
    .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-menu-item.bp3-intent-primary.bp3-active::after,
    .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-menu-item.bp3-intent-success{
    color:#0d8050; }
    .bp3-menu-item.bp3-intent-success .bp3-icon{
      color:inherit; }
    .bp3-menu-item.bp3-intent-success::before, .bp3-menu-item.bp3-intent-success::after,
    .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{
      color:#0d8050; }
    .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success.bp3-active{
      background-color:#0f9960; }
    .bp3-menu-item.bp3-intent-success:active{
      background-color:#0d8050; }
    .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-menu-item.bp3-intent-success:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after,
    .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label,
    .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success:active, .bp3-menu-item.bp3-intent-success:active::before, .bp3-menu-item.bp3-intent-success:active::after,
    .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-menu-item.bp3-intent-success.bp3-active::after,
    .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-menu-item.bp3-intent-warning{
    color:#bf7326; }
    .bp3-menu-item.bp3-intent-warning .bp3-icon{
      color:inherit; }
    .bp3-menu-item.bp3-intent-warning::before, .bp3-menu-item.bp3-intent-warning::after,
    .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{
      color:#bf7326; }
    .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning.bp3-active{
      background-color:#d9822b; }
    .bp3-menu-item.bp3-intent-warning:active{
      background-color:#bf7326; }
    .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after,
    .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label,
    .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning:active, .bp3-menu-item.bp3-intent-warning:active::before, .bp3-menu-item.bp3-intent-warning:active::after,
    .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-menu-item.bp3-intent-warning.bp3-active::after,
    .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-menu-item.bp3-intent-danger{
    color:#c23030; }
    .bp3-menu-item.bp3-intent-danger .bp3-icon{
      color:inherit; }
    .bp3-menu-item.bp3-intent-danger::before, .bp3-menu-item.bp3-intent-danger::after,
    .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{
      color:#c23030; }
    .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger.bp3-active{
      background-color:#db3737; }
    .bp3-menu-item.bp3-intent-danger:active{
      background-color:#c23030; }
    .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after,
    .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label,
    .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger:active, .bp3-menu-item.bp3-intent-danger:active::before, .bp3-menu-item.bp3-intent-danger:active::after,
    .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-menu-item.bp3-intent-danger.bp3-active::after,
    .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-menu-item::before{
    font-family:"Icons16", sans-serif;
    font-size:16px;
    font-style:normal;
    font-weight:400;
    line-height:1;
    -moz-osx-font-smoothing:grayscale;
    -webkit-font-smoothing:antialiased;
    margin-right:7px; }
  .bp3-menu-item::before,
  .bp3-menu-item > .bp3-icon{
    color:#5c7080;
    margin-top:2px; }
  .bp3-menu-item .bp3-menu-item-label{
    color:#5c7080; }
  .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
    color:inherit; }
  .bp3-menu-item.bp3-active, .bp3-menu-item:active{
    background-color:rgba(115, 134, 148, 0.3); }
  .bp3-menu-item.bp3-disabled{
    background-color:inherit !important;
    color:rgba(92, 112, 128, 0.6) !important;
    cursor:not-allowed !important;
    outline:none !important; }
    .bp3-menu-item.bp3-disabled::before,
    .bp3-menu-item.bp3-disabled > .bp3-icon,
    .bp3-menu-item.bp3-disabled .bp3-menu-item-label{
      color:rgba(92, 112, 128, 0.6) !important; }
  .bp3-large .bp3-menu-item{
    font-size:16px;
    line-height:22px;
    padding:9px 7px; }
    .bp3-large .bp3-menu-item .bp3-icon{
      margin-top:3px; }
    .bp3-large .bp3-menu-item::before{
      font-family:"Icons20", sans-serif;
      font-size:20px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased;
      margin-right:10px;
      margin-top:1px; }

button.bp3-menu-item{
  background:none;
  border:none;
  text-align:left;
  width:100%; }
.bp3-menu-header{
  border-top:1px solid rgba(16, 22, 26, 0.15);
  display:block;
  margin:5px;
  cursor:default;
  padding-left:2px; }
  .bp3-dark .bp3-menu-header{
    border-top-color:rgba(255, 255, 255, 0.15); }
  .bp3-menu-header:first-of-type{
    border-top:none; }
  .bp3-menu-header > h6{
    color:#182026;
    font-weight:600;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    word-wrap:normal;
    line-height:17px;
    margin:0;
    padding:10px 7px 0 1px; }
    .bp3-dark .bp3-menu-header > h6{
      color:#f5f8fa; }
  .bp3-menu-header:first-of-type > h6{
    padding-top:0; }
  .bp3-large .bp3-menu-header > h6{
    font-size:18px;
    padding-bottom:5px;
    padding-top:15px; }
  .bp3-large .bp3-menu-header:first-of-type > h6{
    padding-top:0; }

.bp3-dark .bp3-menu{
  background:#30404d;
  color:#f5f8fa; }

.bp3-dark .bp3-menu-item{ }
  .bp3-dark .bp3-menu-item.bp3-intent-primary{
    color:#48aff0; }
    .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-icon{
      color:inherit; }
    .bp3-dark .bp3-menu-item.bp3-intent-primary::before, .bp3-dark .bp3-menu-item.bp3-intent-primary::after,
    .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{
      color:#48aff0; }
    .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active{
      background-color:#137cbd; }
    .bp3-dark .bp3-menu-item.bp3-intent-primary:active{
      background-color:#106ba3; }
    .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after,
    .bp3-dark .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label,
    .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label,
    .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary:active, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-dark .bp3-menu-item.bp3-intent-success{
    color:#3dcc91; }
    .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-icon{
      color:inherit; }
    .bp3-dark .bp3-menu-item.bp3-intent-success::before, .bp3-dark .bp3-menu-item.bp3-intent-success::after,
    .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{
      color:#3dcc91; }
    .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active{
      background-color:#0f9960; }
    .bp3-dark .bp3-menu-item.bp3-intent-success:active{
      background-color:#0d8050; }
    .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after,
    .bp3-dark .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label,
    .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label,
    .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success:active, .bp3-dark .bp3-menu-item.bp3-intent-success:active::before, .bp3-dark .bp3-menu-item.bp3-intent-success:active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-dark .bp3-menu-item.bp3-intent-warning{
    color:#ffb366; }
    .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-icon{
      color:inherit; }
    .bp3-dark .bp3-menu-item.bp3-intent-warning::before, .bp3-dark .bp3-menu-item.bp3-intent-warning::after,
    .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{
      color:#ffb366; }
    .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active{
      background-color:#d9822b; }
    .bp3-dark .bp3-menu-item.bp3-intent-warning:active{
      background-color:#bf7326; }
    .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after,
    .bp3-dark .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label,
    .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label,
    .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning:active, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-dark .bp3-menu-item.bp3-intent-danger{
    color:#ff7373; }
    .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-icon{
      color:inherit; }
    .bp3-dark .bp3-menu-item.bp3-intent-danger::before, .bp3-dark .bp3-menu-item.bp3-intent-danger::after,
    .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{
      color:#ff7373; }
    .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active{
      background-color:#db3737; }
    .bp3-dark .bp3-menu-item.bp3-intent-danger:active{
      background-color:#c23030; }
    .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after,
    .bp3-dark .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label,
    .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label,
    .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger:active, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::after,
    .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{
      color:#ffffff; }
  .bp3-dark .bp3-menu-item::before,
  .bp3-dark .bp3-menu-item > .bp3-icon{
    color:#a7b6c2; }
  .bp3-dark .bp3-menu-item .bp3-menu-item-label{
    color:#a7b6c2; }
  .bp3-dark .bp3-menu-item.bp3-active, .bp3-dark .bp3-menu-item:active{
    background-color:rgba(138, 155, 168, 0.3); }
  .bp3-dark .bp3-menu-item.bp3-disabled{
    color:rgba(167, 182, 194, 0.6) !important; }
    .bp3-dark .bp3-menu-item.bp3-disabled::before,
    .bp3-dark .bp3-menu-item.bp3-disabled > .bp3-icon,
    .bp3-dark .bp3-menu-item.bp3-disabled .bp3-menu-item-label{
      color:rgba(167, 182, 194, 0.6) !important; }

.bp3-dark .bp3-menu-divider,
.bp3-dark .bp3-menu-header{
  border-color:rgba(255, 255, 255, 0.15); }

.bp3-dark .bp3-menu-header > h6{
  color:#f5f8fa; }

.bp3-label .bp3-menu{
  margin-top:5px; }
.bp3-navbar{
  background-color:#ffffff;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
  height:50px;
  padding:0 15px;
  position:relative;
  width:100%;
  z-index:10; }
  .bp3-navbar.bp3-dark,
  .bp3-dark .bp3-navbar{
    background-color:#394b59; }
  .bp3-navbar.bp3-dark{
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-dark .bp3-navbar{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
  .bp3-navbar.bp3-fixed-top{
    left:0;
    position:fixed;
    right:0;
    top:0; }

.bp3-navbar-heading{
  font-size:16px;
  margin-right:15px; }

.bp3-navbar-group{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  height:50px; }
  .bp3-navbar-group.bp3-align-left{
    float:left; }
  .bp3-navbar-group.bp3-align-right{
    float:right; }

.bp3-navbar-divider{
  border-left:1px solid rgba(16, 22, 26, 0.15);
  height:20px;
  margin:0 10px; }
  .bp3-dark .bp3-navbar-divider{
    border-left-color:rgba(255, 255, 255, 0.15); }
.bp3-non-ideal-state{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  height:100%;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  text-align:center;
  width:100%; }
  .bp3-non-ideal-state > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-non-ideal-state > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-non-ideal-state::before,
  .bp3-non-ideal-state > *{
    margin-bottom:20px; }
  .bp3-non-ideal-state:empty::before,
  .bp3-non-ideal-state > :last-child{
    margin-bottom:0; }
  .bp3-non-ideal-state > *{
    max-width:400px; }

.bp3-non-ideal-state-visual{
  color:rgba(92, 112, 128, 0.6);
  font-size:60px; }
  .bp3-dark .bp3-non-ideal-state-visual{
    color:rgba(167, 182, 194, 0.6); }

.bp3-overflow-list{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-wrap:nowrap;
      flex-wrap:nowrap;
  min-width:0; }

.bp3-overflow-list-spacer{
  -ms-flex-negative:1;
      flex-shrink:1;
  width:1px; }

body.bp3-overlay-open{
  overflow:hidden; }

.bp3-overlay{
  bottom:0;
  left:0;
  position:static;
  right:0;
  top:0;
  z-index:20; }
  .bp3-overlay:not(.bp3-overlay-open){
    pointer-events:none; }
  .bp3-overlay.bp3-overlay-container{
    overflow:hidden;
    position:fixed; }
    .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{
      position:absolute; }
  .bp3-overlay.bp3-overlay-scroll-container{
    overflow:auto;
    position:fixed; }
    .bp3-overlay.bp3-overlay-scroll-container.bp3-overlay-inline{
      position:absolute; }
  .bp3-overlay.bp3-overlay-inline{
    display:inline;
    overflow:visible; }

.bp3-overlay-content{
  position:fixed;
  z-index:20; }
  .bp3-overlay-inline .bp3-overlay-content,
  .bp3-overlay-scroll-container .bp3-overlay-content{
    position:absolute; }

.bp3-overlay-backdrop{
  bottom:0;
  left:0;
  position:fixed;
  right:0;
  top:0;
  opacity:1;
  background-color:rgba(16, 22, 26, 0.7);
  overflow:auto;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none;
  z-index:20; }
  .bp3-overlay-backdrop.bp3-overlay-enter, .bp3-overlay-backdrop.bp3-overlay-appear{
    opacity:0; }
  .bp3-overlay-backdrop.bp3-overlay-enter-active, .bp3-overlay-backdrop.bp3-overlay-appear-active{
    opacity:1;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:200ms;
            transition-duration:200ms;
    -webkit-transition-property:opacity;
    transition-property:opacity;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-overlay-backdrop.bp3-overlay-exit{
    opacity:1; }
  .bp3-overlay-backdrop.bp3-overlay-exit-active{
    opacity:0;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:200ms;
            transition-duration:200ms;
    -webkit-transition-property:opacity;
    transition-property:opacity;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-overlay-backdrop:focus{
    outline:none; }
  .bp3-overlay-inline .bp3-overlay-backdrop{
    position:absolute; }
.bp3-panel-stack{
  overflow:hidden;
  position:relative; }

.bp3-panel-stack-header{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15);
          box-shadow:0 1px rgba(16, 22, 26, 0.15);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -ms-flex-negative:0;
      flex-shrink:0;
  height:30px;
  z-index:1; }
  .bp3-dark .bp3-panel-stack-header{
    -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15);
            box-shadow:0 1px rgba(255, 255, 255, 0.15); }
  .bp3-panel-stack-header > span{
    -webkit-box-align:stretch;
        -ms-flex-align:stretch;
            align-items:stretch;
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -webkit-box-flex:1;
        -ms-flex:1;
            flex:1; }
  .bp3-panel-stack-header .bp3-heading{
    margin:0 5px; }

.bp3-button.bp3-panel-stack-header-back{
  margin-left:5px;
  padding-left:0;
  white-space:nowrap; }
  .bp3-button.bp3-panel-stack-header-back .bp3-icon{
    margin:0 2px; }

.bp3-panel-stack-view{
  bottom:0;
  left:0;
  position:absolute;
  right:0;
  top:0;
  background-color:#ffffff;
  border-right:1px solid rgba(16, 22, 26, 0.15);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  margin-right:-1px;
  overflow-y:auto;
  z-index:1; }
  .bp3-dark .bp3-panel-stack-view{
    background-color:#30404d; }
  .bp3-panel-stack-view:nth-last-child(n + 4){
    display:none; }

.bp3-panel-stack-push .bp3-panel-stack-enter, .bp3-panel-stack-push .bp3-panel-stack-appear{
  -webkit-transform:translateX(100%);
          transform:translateX(100%);
  opacity:0; }

.bp3-panel-stack-push .bp3-panel-stack-enter-active, .bp3-panel-stack-push .bp3-panel-stack-appear-active{
  -webkit-transform:translate(0%);
          transform:translate(0%);
  opacity:1;
  -webkit-transition-delay:0;
          transition-delay:0;
  -webkit-transition-duration:400ms;
          transition-duration:400ms;
  -webkit-transition-property:opacity, -webkit-transform;
  transition-property:opacity, -webkit-transform;
  transition-property:transform, opacity;
  transition-property:transform, opacity, -webkit-transform;
  -webkit-transition-timing-function:ease;
          transition-timing-function:ease; }

.bp3-panel-stack-push .bp3-panel-stack-exit{
  -webkit-transform:translate(0%);
          transform:translate(0%);
  opacity:1; }

.bp3-panel-stack-push .bp3-panel-stack-exit-active{
  -webkit-transform:translateX(-50%);
          transform:translateX(-50%);
  opacity:0;
  -webkit-transition-delay:0;
          transition-delay:0;
  -webkit-transition-duration:400ms;
          transition-duration:400ms;
  -webkit-transition-property:opacity, -webkit-transform;
  transition-property:opacity, -webkit-transform;
  transition-property:transform, opacity;
  transition-property:transform, opacity, -webkit-transform;
  -webkit-transition-timing-function:ease;
          transition-timing-function:ease; }

.bp3-panel-stack-pop .bp3-panel-stack-enter, .bp3-panel-stack-pop .bp3-panel-stack-appear{
  -webkit-transform:translateX(-50%);
          transform:translateX(-50%);
  opacity:0; }

.bp3-panel-stack-pop .bp3-panel-stack-enter-active, .bp3-panel-stack-pop .bp3-panel-stack-appear-active{
  -webkit-transform:translate(0%);
          transform:translate(0%);
  opacity:1;
  -webkit-transition-delay:0;
          transition-delay:0;
  -webkit-transition-duration:400ms;
          transition-duration:400ms;
  -webkit-transition-property:opacity, -webkit-transform;
  transition-property:opacity, -webkit-transform;
  transition-property:transform, opacity;
  transition-property:transform, opacity, -webkit-transform;
  -webkit-transition-timing-function:ease;
          transition-timing-function:ease; }

.bp3-panel-stack-pop .bp3-panel-stack-exit{
  -webkit-transform:translate(0%);
          transform:translate(0%);
  opacity:1; }

.bp3-panel-stack-pop .bp3-panel-stack-exit-active{
  -webkit-transform:translateX(100%);
          transform:translateX(100%);
  opacity:0;
  -webkit-transition-delay:0;
          transition-delay:0;
  -webkit-transition-duration:400ms;
          transition-duration:400ms;
  -webkit-transition-property:opacity, -webkit-transform;
  transition-property:opacity, -webkit-transform;
  transition-property:transform, opacity;
  transition-property:transform, opacity, -webkit-transform;
  -webkit-transition-timing-function:ease;
          transition-timing-function:ease; }
.bp3-popover{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
  -webkit-transform:scale(1);
          transform:scale(1);
  border-radius:3px;
  display:inline-block;
  z-index:20; }
  .bp3-popover .bp3-popover-arrow{
    height:30px;
    position:absolute;
    width:30px; }
    .bp3-popover .bp3-popover-arrow::before{
      height:20px;
      margin:5px;
      width:20px; }
  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{
    margin-bottom:17px;
    margin-top:-17px; }
    .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{
      bottom:-11px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow svg{
        -webkit-transform:rotate(-90deg);
                transform:rotate(-90deg); }
  .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover{
    margin-left:17px; }
    .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{
      left:-11px; }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow svg{
        -webkit-transform:rotate(0);
                transform:rotate(0); }
  .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover{
    margin-top:17px; }
    .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{
      top:-11px; }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow svg{
        -webkit-transform:rotate(90deg);
                transform:rotate(90deg); }
  .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover{
    margin-left:-17px;
    margin-right:17px; }
    .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{
      right:-11px; }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow svg{
        -webkit-transform:rotate(180deg);
                transform:rotate(180deg); }
  .bp3-tether-element-attached-middle > .bp3-popover > .bp3-popover-arrow{
    top:50%;
    -webkit-transform:translateY(-50%);
            transform:translateY(-50%); }
  .bp3-tether-element-attached-center > .bp3-popover > .bp3-popover-arrow{
    right:50%;
    -webkit-transform:translateX(50%);
            transform:translateX(50%); }
  .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{
    top:-0.3934px; }
  .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{
    right:-0.3934px; }
  .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{
    left:-0.3934px; }
  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{
    bottom:-0.3934px; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-popover{
    -webkit-transform-origin:top left;
            transform-origin:top left; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-popover{
    -webkit-transform-origin:top center;
            transform-origin:top center; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-popover{
    -webkit-transform-origin:top right;
            transform-origin:top right; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-popover{
    -webkit-transform-origin:center left;
            transform-origin:center left; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-popover{
    -webkit-transform-origin:center center;
            transform-origin:center center; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-popover{
    -webkit-transform-origin:center right;
            transform-origin:center right; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-popover{
    -webkit-transform-origin:bottom left;
            transform-origin:bottom left; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-popover{
    -webkit-transform-origin:bottom center;
            transform-origin:bottom center; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-popover{
    -webkit-transform-origin:bottom right;
            transform-origin:bottom right; }
  .bp3-popover .bp3-popover-content{
    background:#ffffff;
    color:inherit; }
  .bp3-popover .bp3-popover-arrow::before{
    -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2);
            box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); }
  .bp3-popover .bp3-popover-arrow-border{
    fill:#10161a;
    fill-opacity:0.1; }
  .bp3-popover .bp3-popover-arrow-fill{
    fill:#ffffff; }
  .bp3-popover-enter > .bp3-popover, .bp3-popover-appear > .bp3-popover{
    -webkit-transform:scale(0.3);
            transform:scale(0.3); }
  .bp3-popover-enter-active > .bp3-popover, .bp3-popover-appear-active > .bp3-popover{
    -webkit-transform:scale(1);
            transform:scale(1);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
  .bp3-popover-exit > .bp3-popover{
    -webkit-transform:scale(1);
            transform:scale(1); }
  .bp3-popover-exit-active > .bp3-popover{
    -webkit-transform:scale(0.3);
            transform:scale(0.3);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
  .bp3-popover .bp3-popover-content{
    border-radius:3px;
    position:relative; }
  .bp3-popover.bp3-popover-content-sizing .bp3-popover-content{
    max-width:350px;
    padding:20px; }
  .bp3-popover-target + .bp3-overlay .bp3-popover.bp3-popover-content-sizing{
    width:350px; }
  .bp3-popover.bp3-minimal{
    margin:0 !important; }
    .bp3-popover.bp3-minimal .bp3-popover-arrow{
      display:none; }
    .bp3-popover.bp3-minimal.bp3-popover{
      -webkit-transform:scale(1);
              transform:scale(1); }
      .bp3-popover-enter > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear > .bp3-popover.bp3-minimal.bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1); }
      .bp3-popover-enter-active > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear-active > .bp3-popover.bp3-minimal.bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-popover-exit > .bp3-popover.bp3-minimal.bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1); }
      .bp3-popover-exit-active > .bp3-popover.bp3-minimal.bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-popover.bp3-dark,
  .bp3-dark .bp3-popover{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    .bp3-popover.bp3-dark .bp3-popover-content,
    .bp3-dark .bp3-popover .bp3-popover-content{
      background:#30404d;
      color:inherit; }
    .bp3-popover.bp3-dark .bp3-popover-arrow::before,
    .bp3-dark .bp3-popover .bp3-popover-arrow::before{
      -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4);
              box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); }
    .bp3-popover.bp3-dark .bp3-popover-arrow-border,
    .bp3-dark .bp3-popover .bp3-popover-arrow-border{
      fill:#10161a;
      fill-opacity:0.2; }
    .bp3-popover.bp3-dark .bp3-popover-arrow-fill,
    .bp3-dark .bp3-popover .bp3-popover-arrow-fill{
      fill:#30404d; }

.bp3-popover-arrow::before{
  border-radius:2px;
  content:"";
  display:block;
  position:absolute;
  -webkit-transform:rotate(45deg);
          transform:rotate(45deg); }

.bp3-tether-pinned .bp3-popover-arrow{
  display:none; }

.bp3-popover-backdrop{
  background:rgba(255, 255, 255, 0); }

.bp3-transition-container{
  opacity:1;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  z-index:20; }
  .bp3-transition-container.bp3-popover-enter, .bp3-transition-container.bp3-popover-appear{
    opacity:0; }
  .bp3-transition-container.bp3-popover-enter-active, .bp3-transition-container.bp3-popover-appear-active{
    opacity:1;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:100ms;
            transition-duration:100ms;
    -webkit-transition-property:opacity;
    transition-property:opacity;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-transition-container.bp3-popover-exit{
    opacity:1; }
  .bp3-transition-container.bp3-popover-exit-active{
    opacity:0;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:100ms;
            transition-duration:100ms;
    -webkit-transition-property:opacity;
    transition-property:opacity;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-transition-container:focus{
    outline:none; }
  .bp3-transition-container.bp3-popover-leave .bp3-popover-content{
    pointer-events:none; }
  .bp3-transition-container[data-x-out-of-boundaries]{
    display:none; }

span.bp3-popover-target{
  display:inline-block; }

.bp3-popover-wrapper.bp3-fill{
  width:100%; }

.bp3-portal{
  left:0;
  position:absolute;
  right:0;
  top:0; }
@-webkit-keyframes linear-progress-bar-stripes{
  from{
    background-position:0 0; }
  to{
    background-position:30px 0; } }
@keyframes linear-progress-bar-stripes{
  from{
    background-position:0 0; }
  to{
    background-position:30px 0; } }

.bp3-progress-bar{
  background:rgba(92, 112, 128, 0.2);
  border-radius:40px;
  display:block;
  height:8px;
  overflow:hidden;
  position:relative;
  width:100%; }
  .bp3-progress-bar .bp3-progress-meter{
    background:linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%);
    background-color:rgba(92, 112, 128, 0.8);
    background-size:30px 30px;
    border-radius:40px;
    height:100%;
    position:absolute;
    -webkit-transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    width:100%; }
  .bp3-progress-bar:not(.bp3-no-animation):not(.bp3-no-stripes) .bp3-progress-meter{
    animation:linear-progress-bar-stripes 300ms linear infinite reverse; }
  .bp3-progress-bar.bp3-no-stripes .bp3-progress-meter{
    background-image:none; }

.bp3-dark .bp3-progress-bar{
  background:rgba(16, 22, 26, 0.5); }
  .bp3-dark .bp3-progress-bar .bp3-progress-meter{
    background-color:#8a9ba8; }

.bp3-progress-bar.bp3-intent-primary .bp3-progress-meter{
  background-color:#137cbd; }

.bp3-progress-bar.bp3-intent-success .bp3-progress-meter{
  background-color:#0f9960; }

.bp3-progress-bar.bp3-intent-warning .bp3-progress-meter{
  background-color:#d9822b; }

.bp3-progress-bar.bp3-intent-danger .bp3-progress-meter{
  background-color:#db3737; }
@-webkit-keyframes skeleton-glow{
  from{
    background:rgba(206, 217, 224, 0.2);
    border-color:rgba(206, 217, 224, 0.2); }
  to{
    background:rgba(92, 112, 128, 0.2);
    border-color:rgba(92, 112, 128, 0.2); } }
@keyframes skeleton-glow{
  from{
    background:rgba(206, 217, 224, 0.2);
    border-color:rgba(206, 217, 224, 0.2); }
  to{
    background:rgba(92, 112, 128, 0.2);
    border-color:rgba(92, 112, 128, 0.2); } }
.bp3-skeleton{
  -webkit-animation:1000ms linear infinite alternate skeleton-glow;
          animation:1000ms linear infinite alternate skeleton-glow;
  background:rgba(206, 217, 224, 0.2);
  background-clip:padding-box !important;
  border-color:rgba(206, 217, 224, 0.2) !important;
  border-radius:2px;
  -webkit-box-shadow:none !important;
          box-shadow:none !important;
  color:transparent !important;
  cursor:default;
  pointer-events:none;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-skeleton::before, .bp3-skeleton::after,
  .bp3-skeleton *{
    visibility:hidden !important; }
.bp3-slider{
  height:40px;
  min-width:150px;
  width:100%;
  cursor:default;
  outline:none;
  position:relative;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-slider:hover{
    cursor:pointer; }
  .bp3-slider:active{
    cursor:-webkit-grabbing;
    cursor:grabbing; }
  .bp3-slider.bp3-disabled{
    cursor:not-allowed;
    opacity:0.5; }
  .bp3-slider.bp3-slider-unlabeled{
    height:16px; }

.bp3-slider-track,
.bp3-slider-progress{
  height:6px;
  left:0;
  right:0;
  top:5px;
  position:absolute; }

.bp3-slider-track{
  border-radius:3px;
  overflow:hidden; }

.bp3-slider-progress{
  background:rgba(92, 112, 128, 0.2); }
  .bp3-dark .bp3-slider-progress{
    background:rgba(16, 22, 26, 0.5); }
  .bp3-slider-progress.bp3-intent-primary{
    background-color:#137cbd; }
  .bp3-slider-progress.bp3-intent-success{
    background-color:#0f9960; }
  .bp3-slider-progress.bp3-intent-warning{
    background-color:#d9822b; }
  .bp3-slider-progress.bp3-intent-danger{
    background-color:#db3737; }

.bp3-slider-handle{
  background-color:#f5f8fa;
  background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
  background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
  -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
          box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
  color:#182026;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
  cursor:pointer;
  height:16px;
  left:0;
  position:absolute;
  top:0;
  width:16px; }
  .bp3-slider-handle:hover{
    background-clip:padding-box;
    background-color:#ebf1f5;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
  .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{
    background-color:#d8e1e8;
    background-image:none;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
  .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{
    background-color:rgba(206, 217, 224, 0.5);
    background-image:none;
    -webkit-box-shadow:none;
            box-shadow:none;
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed;
    outline:none; }
    .bp3-slider-handle:disabled.bp3-active, .bp3-slider-handle:disabled.bp3-active:hover, .bp3-slider-handle.bp3-disabled.bp3-active, .bp3-slider-handle.bp3-disabled.bp3-active:hover{
      background:rgba(206, 217, 224, 0.7); }
  .bp3-slider-handle:focus{
    z-index:1; }
  .bp3-slider-handle:hover{
    background-clip:padding-box;
    background-color:#ebf1f5;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
    cursor:-webkit-grab;
    cursor:grab;
    z-index:2; }
  .bp3-slider-handle.bp3-active{
    background-color:#d8e1e8;
    background-image:none;
    -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
            box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1);
    cursor:-webkit-grabbing;
    cursor:grabbing; }
  .bp3-disabled .bp3-slider-handle{
    background:#bfccd6;
    -webkit-box-shadow:none;
            box-shadow:none;
    pointer-events:none; }
  .bp3-dark .bp3-slider-handle{
    background-color:#394b59;
    background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
    background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
    color:#f5f8fa; }
    .bp3-dark .bp3-slider-handle:hover, .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{
      color:#f5f8fa; }
    .bp3-dark .bp3-slider-handle:hover{
      background-color:#30404d;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{
      background-color:#202b33;
      background-image:none;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{
      background-color:rgba(57, 75, 89, 0.5);
      background-image:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(167, 182, 194, 0.6); }
      .bp3-dark .bp3-slider-handle:disabled.bp3-active, .bp3-dark .bp3-slider-handle.bp3-disabled.bp3-active{
        background:rgba(57, 75, 89, 0.7); }
    .bp3-dark .bp3-slider-handle .bp3-button-spinner .bp3-spinner-head{
      background:rgba(16, 22, 26, 0.5);
      stroke:#8a9ba8; }
    .bp3-dark .bp3-slider-handle, .bp3-dark .bp3-slider-handle:hover{
      background-color:#394b59; }
    .bp3-dark .bp3-slider-handle.bp3-active{
      background-color:#293742; }
  .bp3-dark .bp3-disabled .bp3-slider-handle{
    background:#5c7080;
    border-color:#5c7080;
    -webkit-box-shadow:none;
            box-shadow:none; }
  .bp3-slider-handle .bp3-slider-label{
    background:#394b59;
    border-radius:3px;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
    color:#f5f8fa;
    margin-left:8px; }
    .bp3-dark .bp3-slider-handle .bp3-slider-label{
      background:#e1e8ed;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
      color:#394b59; }
    .bp3-disabled .bp3-slider-handle .bp3-slider-label{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-slider-handle.bp3-start, .bp3-slider-handle.bp3-end{
    width:8px; }
  .bp3-slider-handle.bp3-start{
    border-bottom-right-radius:0;
    border-top-right-radius:0; }
  .bp3-slider-handle.bp3-end{
    border-bottom-left-radius:0;
    border-top-left-radius:0;
    margin-left:8px; }
    .bp3-slider-handle.bp3-end .bp3-slider-label{
      margin-left:0; }

.bp3-slider-label{
  -webkit-transform:translate(-50%, 20px);
          transform:translate(-50%, 20px);
  display:inline-block;
  font-size:12px;
  line-height:1;
  padding:2px 5px;
  position:absolute;
  vertical-align:top; }

.bp3-slider.bp3-vertical{
  height:150px;
  min-width:40px;
  width:40px; }
  .bp3-slider.bp3-vertical .bp3-slider-track,
  .bp3-slider.bp3-vertical .bp3-slider-progress{
    bottom:0;
    height:auto;
    left:5px;
    top:0;
    width:6px; }
  .bp3-slider.bp3-vertical .bp3-slider-progress{
    top:auto; }
  .bp3-slider.bp3-vertical .bp3-slider-label{
    -webkit-transform:translate(20px, 50%);
            transform:translate(20px, 50%); }
  .bp3-slider.bp3-vertical .bp3-slider-handle{
    top:auto; }
    .bp3-slider.bp3-vertical .bp3-slider-handle .bp3-slider-label{
      margin-left:0;
      margin-top:-8px; }
    .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
      height:8px;
      margin-left:0;
      width:16px; }
    .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
      border-bottom-right-radius:3px;
      border-top-left-radius:0; }
      .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start .bp3-slider-label{
        -webkit-transform:translate(20px);
                transform:translate(20px); }
    .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end{
      border-bottom-left-radius:0;
      border-bottom-right-radius:0;
      border-top-left-radius:3px;
      margin-bottom:8px; }

@-webkit-keyframes pt-spinner-animation{
  from{
    -webkit-transform:rotate(0deg);
            transform:rotate(0deg); }
  to{
    -webkit-transform:rotate(360deg);
            transform:rotate(360deg); } }

@keyframes pt-spinner-animation{
  from{
    -webkit-transform:rotate(0deg);
            transform:rotate(0deg); }
  to{
    -webkit-transform:rotate(360deg);
            transform:rotate(360deg); } }

.bp3-spinner{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-pack:center;
      -ms-flex-pack:center;
          justify-content:center;
  overflow:visible;
  vertical-align:middle; }
  .bp3-spinner svg{
    display:block; }
  .bp3-spinner path{
    fill-opacity:0; }
  .bp3-spinner .bp3-spinner-head{
    stroke:rgba(92, 112, 128, 0.8);
    stroke-linecap:round;
    -webkit-transform-origin:center;
            transform-origin:center;
    -webkit-transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
    transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-spinner .bp3-spinner-track{
    stroke:rgba(92, 112, 128, 0.2); }

.bp3-spinner-animation{
  -webkit-animation:pt-spinner-animation 500ms linear infinite;
          animation:pt-spinner-animation 500ms linear infinite; }
  .bp3-no-spin > .bp3-spinner-animation{
    -webkit-animation:none;
            animation:none; }

.bp3-dark .bp3-spinner .bp3-spinner-head{
  stroke:#8a9ba8; }

.bp3-dark .bp3-spinner .bp3-spinner-track{
  stroke:rgba(16, 22, 26, 0.5); }

.bp3-spinner.bp3-intent-primary .bp3-spinner-head{
  stroke:#137cbd; }

.bp3-spinner.bp3-intent-success .bp3-spinner-head{
  stroke:#0f9960; }

.bp3-spinner.bp3-intent-warning .bp3-spinner-head{
  stroke:#d9822b; }

.bp3-spinner.bp3-intent-danger .bp3-spinner-head{
  stroke:#db3737; }
.bp3-tabs.bp3-vertical{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex; }
  .bp3-tabs.bp3-vertical > .bp3-tab-list{
    -webkit-box-align:start;
        -ms-flex-align:start;
            align-items:flex-start;
    -webkit-box-orient:vertical;
    -webkit-box-direction:normal;
        -ms-flex-direction:column;
            flex-direction:column; }
    .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{
      border-radius:3px;
      padding:0 10px;
      width:100%; }
      .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{
        background-color:rgba(19, 124, 189, 0.2);
        -webkit-box-shadow:none;
                box-shadow:none; }
    .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{
      background-color:rgba(19, 124, 189, 0.2);
      border-radius:3px;
      bottom:0;
      height:auto;
      left:0;
      right:0;
      top:0; }
  .bp3-tabs.bp3-vertical > .bp3-tab-panel{
    margin-top:0;
    padding-left:20px; }

.bp3-tab-list{
  -webkit-box-align:end;
      -ms-flex-align:end;
          align-items:flex-end;
  border:none;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  list-style:none;
  margin:0;
  padding:0;
  position:relative; }
  .bp3-tab-list > *:not(:last-child){
    margin-right:20px; }

.bp3-tab{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  word-wrap:normal;
  color:#182026;
  cursor:pointer;
  -webkit-box-flex:0;
      -ms-flex:0 0 auto;
          flex:0 0 auto;
  font-size:14px;
  line-height:30px;
  max-width:100%;
  position:relative;
  vertical-align:top; }
  .bp3-tab a{
    color:inherit;
    display:block;
    text-decoration:none; }
  .bp3-tab-indicator-wrapper ~ .bp3-tab{
    background-color:transparent !important;
    -webkit-box-shadow:none !important;
            box-shadow:none !important; }
  .bp3-tab[aria-disabled="true"]{
    color:rgba(92, 112, 128, 0.6);
    cursor:not-allowed; }
  .bp3-tab[aria-selected="true"]{
    border-radius:0;
    -webkit-box-shadow:inset 0 -3px 0 #106ba3;
            box-shadow:inset 0 -3px 0 #106ba3; }
  .bp3-tab[aria-selected="true"], .bp3-tab:not([aria-disabled="true"]):hover{
    color:#106ba3; }
  .bp3-tab:focus{
    -moz-outline-radius:0; }
  .bp3-large > .bp3-tab{
    font-size:16px;
    line-height:40px; }

.bp3-tab-panel{
  margin-top:20px; }
  .bp3-tab-panel[aria-hidden="true"]{
    display:none; }

.bp3-tab-indicator-wrapper{
  left:0;
  pointer-events:none;
  position:absolute;
  top:0;
  -webkit-transform:translateX(0), translateY(0);
          transform:translateX(0), translateY(0);
  -webkit-transition:height, width, -webkit-transform;
  transition:height, width, -webkit-transform;
  transition:height, transform, width;
  transition:height, transform, width, -webkit-transform;
  -webkit-transition-duration:200ms;
          transition-duration:200ms;
  -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
          transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-tab-indicator-wrapper .bp3-tab-indicator{
    background-color:#106ba3;
    bottom:0;
    height:3px;
    left:0;
    position:absolute;
    right:0; }
  .bp3-tab-indicator-wrapper.bp3-no-animation{
    -webkit-transition:none;
    transition:none; }

.bp3-dark .bp3-tab{
  color:#f5f8fa; }
  .bp3-dark .bp3-tab[aria-disabled="true"]{
    color:rgba(167, 182, 194, 0.6); }
  .bp3-dark .bp3-tab[aria-selected="true"]{
    -webkit-box-shadow:inset 0 -3px 0 #48aff0;
            box-shadow:inset 0 -3px 0 #48aff0; }
  .bp3-dark .bp3-tab[aria-selected="true"], .bp3-dark .bp3-tab:not([aria-disabled="true"]):hover{
    color:#48aff0; }

.bp3-dark .bp3-tab-indicator{
  background-color:#48aff0; }

.bp3-flex-expander{
  -webkit-box-flex:1;
      -ms-flex:1 1;
          flex:1 1; }
.bp3-tag{
  display:-webkit-inline-box;
  display:-ms-inline-flexbox;
  display:inline-flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  background-color:#5c7080;
  border:none;
  border-radius:3px;
  -webkit-box-shadow:none;
          box-shadow:none;
  color:#f5f8fa;
  font-size:12px;
  line-height:16px;
  max-width:100%;
  min-height:20px;
  min-width:20px;
  padding:2px 6px;
  position:relative; }
  .bp3-tag.bp3-interactive{
    cursor:pointer; }
    .bp3-tag.bp3-interactive:hover{
      background-color:rgba(92, 112, 128, 0.85); }
    .bp3-tag.bp3-interactive.bp3-active, .bp3-tag.bp3-interactive:active{
      background-color:rgba(92, 112, 128, 0.7); }
  .bp3-tag > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-tag > .bp3-fill{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-tag::before,
  .bp3-tag > *{
    margin-right:4px; }
  .bp3-tag:empty::before,
  .bp3-tag > :last-child{
    margin-right:0; }
  .bp3-tag:focus{
    outline:rgba(19, 124, 189, 0.6) auto 2px;
    outline-offset:0;
    -moz-outline-radius:6px; }
  .bp3-tag.bp3-round{
    border-radius:30px;
    padding-left:8px;
    padding-right:8px; }
  .bp3-dark .bp3-tag{
    background-color:#bfccd6;
    color:#182026; }
    .bp3-dark .bp3-tag.bp3-interactive{
      cursor:pointer; }
      .bp3-dark .bp3-tag.bp3-interactive:hover{
        background-color:rgba(191, 204, 214, 0.85); }
      .bp3-dark .bp3-tag.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-interactive:active{
        background-color:rgba(191, 204, 214, 0.7); }
    .bp3-dark .bp3-tag > .bp3-icon, .bp3-dark .bp3-tag .bp3-icon-standard, .bp3-dark .bp3-tag .bp3-icon-large{
      fill:currentColor; }
  .bp3-tag > .bp3-icon, .bp3-tag .bp3-icon-standard, .bp3-tag .bp3-icon-large{
    fill:#ffffff; }
  .bp3-tag.bp3-large,
  .bp3-large .bp3-tag{
    font-size:14px;
    line-height:20px;
    min-height:30px;
    min-width:30px;
    padding:5px 10px; }
    .bp3-tag.bp3-large::before,
    .bp3-tag.bp3-large > *,
    .bp3-large .bp3-tag::before,
    .bp3-large .bp3-tag > *{
      margin-right:7px; }
    .bp3-tag.bp3-large:empty::before,
    .bp3-tag.bp3-large > :last-child,
    .bp3-large .bp3-tag:empty::before,
    .bp3-large .bp3-tag > :last-child{
      margin-right:0; }
    .bp3-tag.bp3-large.bp3-round,
    .bp3-large .bp3-tag.bp3-round{
      padding-left:12px;
      padding-right:12px; }
  .bp3-tag.bp3-intent-primary{
    background:#137cbd;
    color:#ffffff; }
    .bp3-tag.bp3-intent-primary.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-intent-primary.bp3-interactive:hover{
        background-color:rgba(19, 124, 189, 0.85); }
      .bp3-tag.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-primary.bp3-interactive:active{
        background-color:rgba(19, 124, 189, 0.7); }
  .bp3-tag.bp3-intent-success{
    background:#0f9960;
    color:#ffffff; }
    .bp3-tag.bp3-intent-success.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-intent-success.bp3-interactive:hover{
        background-color:rgba(15, 153, 96, 0.85); }
      .bp3-tag.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-success.bp3-interactive:active{
        background-color:rgba(15, 153, 96, 0.7); }
  .bp3-tag.bp3-intent-warning{
    background:#d9822b;
    color:#ffffff; }
    .bp3-tag.bp3-intent-warning.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-intent-warning.bp3-interactive:hover{
        background-color:rgba(217, 130, 43, 0.85); }
      .bp3-tag.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-warning.bp3-interactive:active{
        background-color:rgba(217, 130, 43, 0.7); }
  .bp3-tag.bp3-intent-danger{
    background:#db3737;
    color:#ffffff; }
    .bp3-tag.bp3-intent-danger.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-intent-danger.bp3-interactive:hover{
        background-color:rgba(219, 55, 55, 0.85); }
      .bp3-tag.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-danger.bp3-interactive:active{
        background-color:rgba(219, 55, 55, 0.7); }
  .bp3-tag.bp3-fill{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    width:100%; }
  .bp3-tag.bp3-minimal > .bp3-icon, .bp3-tag.bp3-minimal .bp3-icon-standard, .bp3-tag.bp3-minimal .bp3-icon-large{
    fill:#5c7080; }
  .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){
    background-color:rgba(138, 155, 168, 0.2);
    color:#182026; }
    .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{
        background-color:rgba(92, 112, 128, 0.3); }
      .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{
        background-color:rgba(92, 112, 128, 0.4); }
    .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){
      color:#f5f8fa; }
      .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{
        cursor:pointer; }
        .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{
          background-color:rgba(191, 204, 214, 0.3); }
        .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{
          background-color:rgba(191, 204, 214, 0.4); }
      .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) > .bp3-icon, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-large{
        fill:#a7b6c2; }
  .bp3-tag.bp3-minimal.bp3-intent-primary{
    background-color:rgba(19, 124, 189, 0.15);
    color:#106ba3; }
    .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{
        background-color:rgba(19, 124, 189, 0.25); }
      .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{
        background-color:rgba(19, 124, 189, 0.35); }
    .bp3-tag.bp3-minimal.bp3-intent-primary > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-large{
      fill:#137cbd; }
    .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary{
      background-color:rgba(19, 124, 189, 0.25);
      color:#48aff0; }
      .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{
        cursor:pointer; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{
          background-color:rgba(19, 124, 189, 0.35); }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{
          background-color:rgba(19, 124, 189, 0.45); }
  .bp3-tag.bp3-minimal.bp3-intent-success{
    background-color:rgba(15, 153, 96, 0.15);
    color:#0d8050; }
    .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{
        background-color:rgba(15, 153, 96, 0.25); }
      .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{
        background-color:rgba(15, 153, 96, 0.35); }
    .bp3-tag.bp3-minimal.bp3-intent-success > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-large{
      fill:#0f9960; }
    .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success{
      background-color:rgba(15, 153, 96, 0.25);
      color:#3dcc91; }
      .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{
        cursor:pointer; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{
          background-color:rgba(15, 153, 96, 0.35); }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{
          background-color:rgba(15, 153, 96, 0.45); }
  .bp3-tag.bp3-minimal.bp3-intent-warning{
    background-color:rgba(217, 130, 43, 0.15);
    color:#bf7326; }
    .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{
        background-color:rgba(217, 130, 43, 0.25); }
      .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{
        background-color:rgba(217, 130, 43, 0.35); }
    .bp3-tag.bp3-minimal.bp3-intent-warning > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-large{
      fill:#d9822b; }
    .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning{
      background-color:rgba(217, 130, 43, 0.25);
      color:#ffb366; }
      .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{
        cursor:pointer; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{
          background-color:rgba(217, 130, 43, 0.35); }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{
          background-color:rgba(217, 130, 43, 0.45); }
  .bp3-tag.bp3-minimal.bp3-intent-danger{
    background-color:rgba(219, 55, 55, 0.15);
    color:#c23030; }
    .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{
      cursor:pointer; }
      .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{
        background-color:rgba(219, 55, 55, 0.25); }
      .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{
        background-color:rgba(219, 55, 55, 0.35); }
    .bp3-tag.bp3-minimal.bp3-intent-danger > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-large{
      fill:#db3737; }
    .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger{
      background-color:rgba(219, 55, 55, 0.25);
      color:#ff7373; }
      .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{
        cursor:pointer; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{
          background-color:rgba(219, 55, 55, 0.35); }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{
          background-color:rgba(219, 55, 55, 0.45); }

.bp3-tag-remove{
  background:none;
  border:none;
  color:inherit;
  cursor:pointer;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  margin-bottom:-2px;
  margin-right:-6px !important;
  margin-top:-2px;
  opacity:0.5;
  padding:2px;
  padding-left:0; }
  .bp3-tag-remove:hover{
    background:none;
    opacity:0.8;
    text-decoration:none; }
  .bp3-tag-remove:active{
    opacity:1; }
  .bp3-tag-remove:empty::before{
    font-family:"Icons16", sans-serif;
    font-size:16px;
    font-style:normal;
    font-weight:400;
    line-height:1;
    -moz-osx-font-smoothing:grayscale;
    -webkit-font-smoothing:antialiased;
    content:""; }
  .bp3-large .bp3-tag-remove{
    margin-right:-10px !important;
    padding:0 5px 0 0; }
    .bp3-large .bp3-tag-remove:empty::before{
      font-family:"Icons20", sans-serif;
      font-size:20px;
      font-style:normal;
      font-weight:400;
      line-height:1; }
.bp3-tag-input{
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  -webkit-box-orient:horizontal;
  -webkit-box-direction:normal;
      -ms-flex-direction:row;
          flex-direction:row;
  -webkit-box-align:start;
      -ms-flex-align:start;
          align-items:flex-start;
  cursor:text;
  height:auto;
  line-height:inherit;
  min-height:30px;
  padding-left:5px;
  padding-right:0; }
  .bp3-tag-input > *{
    -webkit-box-flex:0;
        -ms-flex-positive:0;
            flex-grow:0;
    -ms-flex-negative:0;
        flex-shrink:0; }
  .bp3-tag-input > .bp3-tag-input-values{
    -webkit-box-flex:1;
        -ms-flex-positive:1;
            flex-grow:1;
    -ms-flex-negative:1;
        flex-shrink:1; }
  .bp3-tag-input .bp3-tag-input-icon{
    color:#5c7080;
    margin-left:2px;
    margin-right:7px;
    margin-top:7px; }
  .bp3-tag-input .bp3-tag-input-values{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -webkit-box-orient:horizontal;
    -webkit-box-direction:normal;
        -ms-flex-direction:row;
            flex-direction:row;
    -webkit-box-align:center;
        -ms-flex-align:center;
            align-items:center;
    -ms-flex-item-align:stretch;
        align-self:stretch;
    -ms-flex-wrap:wrap;
        flex-wrap:wrap;
    margin-right:7px;
    margin-top:5px;
    min-width:0; }
    .bp3-tag-input .bp3-tag-input-values > *{
      -webkit-box-flex:0;
          -ms-flex-positive:0;
              flex-grow:0;
      -ms-flex-negative:0;
          flex-shrink:0; }
    .bp3-tag-input .bp3-tag-input-values > .bp3-fill{
      -webkit-box-flex:1;
          -ms-flex-positive:1;
              flex-grow:1;
      -ms-flex-negative:1;
          flex-shrink:1; }
    .bp3-tag-input .bp3-tag-input-values::before,
    .bp3-tag-input .bp3-tag-input-values > *{
      margin-right:5px; }
    .bp3-tag-input .bp3-tag-input-values:empty::before,
    .bp3-tag-input .bp3-tag-input-values > :last-child{
      margin-right:0; }
    .bp3-tag-input .bp3-tag-input-values:first-child .bp3-input-ghost:first-child{
      padding-left:5px; }
    .bp3-tag-input .bp3-tag-input-values > *{
      margin-bottom:5px; }
  .bp3-tag-input .bp3-tag{
    overflow-wrap:break-word; }
    .bp3-tag-input .bp3-tag.bp3-active{
      outline:rgba(19, 124, 189, 0.6) auto 2px;
      outline-offset:0;
      -moz-outline-radius:6px; }
  .bp3-tag-input .bp3-input-ghost{
    -webkit-box-flex:1;
        -ms-flex:1 1 auto;
            flex:1 1 auto;
    line-height:20px;
    width:80px; }
    .bp3-tag-input .bp3-input-ghost:disabled, .bp3-tag-input .bp3-input-ghost.bp3-disabled{
      cursor:not-allowed; }
  .bp3-tag-input .bp3-button,
  .bp3-tag-input .bp3-spinner{
    margin:3px;
    margin-left:0; }
  .bp3-tag-input .bp3-button{
    min-height:24px;
    min-width:24px;
    padding:0 7px; }
  .bp3-tag-input.bp3-large{
    height:auto;
    min-height:40px; }
    .bp3-tag-input.bp3-large::before,
    .bp3-tag-input.bp3-large > *{
      margin-right:10px; }
    .bp3-tag-input.bp3-large:empty::before,
    .bp3-tag-input.bp3-large > :last-child{
      margin-right:0; }
    .bp3-tag-input.bp3-large .bp3-tag-input-icon{
      margin-left:5px;
      margin-top:10px; }
    .bp3-tag-input.bp3-large .bp3-input-ghost{
      line-height:30px; }
    .bp3-tag-input.bp3-large .bp3-button{
      min-height:30px;
      min-width:30px;
      padding:5px 10px;
      margin:5px;
      margin-left:0; }
    .bp3-tag-input.bp3-large .bp3-spinner{
      margin:8px;
      margin-left:0; }
  .bp3-tag-input.bp3-active{
    background-color:#ffffff;
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-tag-input.bp3-active.bp3-intent-primary{
      -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-tag-input.bp3-active.bp3-intent-success{
      -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-tag-input.bp3-active.bp3-intent-warning{
      -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
    .bp3-tag-input.bp3-active.bp3-intent-danger{
      -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
  .bp3-dark .bp3-tag-input .bp3-tag-input-icon, .bp3-tag-input.bp3-dark .bp3-tag-input-icon{
    color:#a7b6c2; }
  .bp3-dark .bp3-tag-input .bp3-input-ghost, .bp3-tag-input.bp3-dark .bp3-input-ghost{
    color:#f5f8fa; }
    .bp3-dark .bp3-tag-input .bp3-input-ghost::-webkit-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-webkit-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-tag-input .bp3-input-ghost::-moz-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-moz-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-tag-input .bp3-input-ghost:-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost:-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-tag-input .bp3-input-ghost::-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-ms-input-placeholder{
      color:rgba(167, 182, 194, 0.6); }
    .bp3-dark .bp3-tag-input .bp3-input-ghost::placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::placeholder{
      color:rgba(167, 182, 194, 0.6); }
  .bp3-dark .bp3-tag-input.bp3-active, .bp3-tag-input.bp3-dark.bp3-active{
    background-color:rgba(16, 22, 26, 0.3);
    -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-primary, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-primary{
      -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-success, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-success{
      -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-warning, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-warning{
      -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-danger, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-danger{
      -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }

.bp3-input-ghost{
  background:none;
  border:none;
  -webkit-box-shadow:none;
          box-shadow:none;
  padding:0; }
  .bp3-input-ghost::-webkit-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input-ghost::-moz-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input-ghost:-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input-ghost::-ms-input-placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input-ghost::placeholder{
    color:rgba(92, 112, 128, 0.6);
    opacity:1; }
  .bp3-input-ghost:focus{
    outline:none !important; }
.bp3-toast{
  -webkit-box-align:start;
      -ms-flex-align:start;
          align-items:flex-start;
  background-color:#ffffff;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  margin:20px 0 0;
  max-width:500px;
  min-width:300px;
  pointer-events:all;
  position:relative !important; }
  .bp3-toast.bp3-toast-enter, .bp3-toast.bp3-toast-appear{
    -webkit-transform:translateY(-40px);
            transform:translateY(-40px); }
  .bp3-toast.bp3-toast-enter-active, .bp3-toast.bp3-toast-appear-active{
    -webkit-transform:translateY(0);
            transform:translateY(0);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
  .bp3-toast.bp3-toast-enter ~ .bp3-toast, .bp3-toast.bp3-toast-appear ~ .bp3-toast{
    -webkit-transform:translateY(-40px);
            transform:translateY(-40px); }
  .bp3-toast.bp3-toast-enter-active ~ .bp3-toast, .bp3-toast.bp3-toast-appear-active ~ .bp3-toast{
    -webkit-transform:translateY(0);
            transform:translateY(0);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
            transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
  .bp3-toast.bp3-toast-exit{
    opacity:1;
    -webkit-filter:blur(0);
            filter:blur(0); }
  .bp3-toast.bp3-toast-exit-active{
    opacity:0;
    -webkit-filter:blur(10px);
            filter:blur(10px);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:300ms;
            transition-duration:300ms;
    -webkit-transition-property:opacity, -webkit-filter;
    transition-property:opacity, -webkit-filter;
    transition-property:opacity, filter;
    transition-property:opacity, filter, -webkit-filter;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-toast.bp3-toast-exit ~ .bp3-toast{
    -webkit-transform:translateY(0);
            transform:translateY(0); }
  .bp3-toast.bp3-toast-exit-active ~ .bp3-toast{
    -webkit-transform:translateY(-40px);
            transform:translateY(-40px);
    -webkit-transition-delay:50ms;
            transition-delay:50ms;
    -webkit-transition-duration:100ms;
            transition-duration:100ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-toast .bp3-button-group{
    -webkit-box-flex:0;
        -ms-flex:0 0 auto;
            flex:0 0 auto;
    padding:5px;
    padding-left:0; }
  .bp3-toast > .bp3-icon{
    color:#5c7080;
    margin:12px;
    margin-right:0; }
  .bp3-toast.bp3-dark,
  .bp3-dark .bp3-toast{
    background-color:#394b59;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    .bp3-toast.bp3-dark > .bp3-icon,
    .bp3-dark .bp3-toast > .bp3-icon{
      color:#a7b6c2; }
  .bp3-toast[class*="bp3-intent-"] a{
    color:rgba(255, 255, 255, 0.7); }
    .bp3-toast[class*="bp3-intent-"] a:hover{
      color:#ffffff; }
  .bp3-toast[class*="bp3-intent-"] > .bp3-icon{
    color:#ffffff; }
  .bp3-toast[class*="bp3-intent-"] .bp3-button, .bp3-toast[class*="bp3-intent-"] .bp3-button::before,
  .bp3-toast[class*="bp3-intent-"] .bp3-button .bp3-icon, .bp3-toast[class*="bp3-intent-"] .bp3-button:active{
    color:rgba(255, 255, 255, 0.7) !important; }
  .bp3-toast[class*="bp3-intent-"] .bp3-button:focus{
    outline-color:rgba(255, 255, 255, 0.5); }
  .bp3-toast[class*="bp3-intent-"] .bp3-button:hover{
    background-color:rgba(255, 255, 255, 0.15) !important;
    color:#ffffff !important; }
  .bp3-toast[class*="bp3-intent-"] .bp3-button:active{
    background-color:rgba(255, 255, 255, 0.3) !important;
    color:#ffffff !important; }
  .bp3-toast[class*="bp3-intent-"] .bp3-button::after{
    background:rgba(255, 255, 255, 0.3) !important; }
  .bp3-toast.bp3-intent-primary{
    background-color:#137cbd;
    color:#ffffff; }
  .bp3-toast.bp3-intent-success{
    background-color:#0f9960;
    color:#ffffff; }
  .bp3-toast.bp3-intent-warning{
    background-color:#d9822b;
    color:#ffffff; }
  .bp3-toast.bp3-intent-danger{
    background-color:#db3737;
    color:#ffffff; }

.bp3-toast-message{
  -webkit-box-flex:1;
      -ms-flex:1 1 auto;
          flex:1 1 auto;
  padding:11px;
  word-break:break-word; }

.bp3-toast-container{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box !important;
  display:-ms-flexbox !important;
  display:flex !important;
  -webkit-box-orient:vertical;
  -webkit-box-direction:normal;
      -ms-flex-direction:column;
          flex-direction:column;
  left:0;
  overflow:hidden;
  padding:0 20px 20px;
  pointer-events:none;
  position:fixed;
  right:0;
  z-index:40; }
  .bp3-toast-container.bp3-toast-container-top{
    top:0; }
  .bp3-toast-container.bp3-toast-container-bottom{
    bottom:0;
    -webkit-box-orient:vertical;
    -webkit-box-direction:reverse;
        -ms-flex-direction:column-reverse;
            flex-direction:column-reverse;
    top:auto; }
  .bp3-toast-container.bp3-toast-container-left{
    -webkit-box-align:start;
        -ms-flex-align:start;
            align-items:flex-start; }
  .bp3-toast-container.bp3-toast-container-right{
    -webkit-box-align:end;
        -ms-flex-align:end;
            align-items:flex-end; }

.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active),
.bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active) ~ .bp3-toast, .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active),
.bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active) ~ .bp3-toast,
.bp3-toast-container-bottom .bp3-toast.bp3-toast-exit-active ~ .bp3-toast,
.bp3-toast-container-bottom .bp3-toast.bp3-toast-leave-active ~ .bp3-toast{
  -webkit-transform:translateY(60px);
          transform:translateY(60px); }
.bp3-tooltip{
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
  -webkit-transform:scale(1);
          transform:scale(1); }
  .bp3-tooltip .bp3-popover-arrow{
    height:22px;
    position:absolute;
    width:22px; }
    .bp3-tooltip .bp3-popover-arrow::before{
      height:14px;
      margin:4px;
      width:14px; }
  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{
    margin-bottom:11px;
    margin-top:-11px; }
    .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{
      bottom:-8px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow svg{
        -webkit-transform:rotate(-90deg);
                transform:rotate(-90deg); }
  .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip{
    margin-left:11px; }
    .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{
      left:-8px; }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow svg{
        -webkit-transform:rotate(0);
                transform:rotate(0); }
  .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip{
    margin-top:11px; }
    .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{
      top:-8px; }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow svg{
        -webkit-transform:rotate(90deg);
                transform:rotate(90deg); }
  .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip{
    margin-left:-11px;
    margin-right:11px; }
    .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{
      right:-8px; }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow svg{
        -webkit-transform:rotate(180deg);
                transform:rotate(180deg); }
  .bp3-tether-element-attached-middle > .bp3-tooltip > .bp3-popover-arrow{
    top:50%;
    -webkit-transform:translateY(-50%);
            transform:translateY(-50%); }
  .bp3-tether-element-attached-center > .bp3-tooltip > .bp3-popover-arrow{
    right:50%;
    -webkit-transform:translateX(50%);
            transform:translateX(50%); }
  .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{
    top:-0.22183px; }
  .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{
    right:-0.22183px; }
  .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{
    left:-0.22183px; }
  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{
    bottom:-0.22183px; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-tooltip{
    -webkit-transform-origin:top left;
            transform-origin:top left; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-tooltip{
    -webkit-transform-origin:top center;
            transform-origin:top center; }
  .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-tooltip{
    -webkit-transform-origin:top right;
            transform-origin:top right; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-tooltip{
    -webkit-transform-origin:center left;
            transform-origin:center left; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-tooltip{
    -webkit-transform-origin:center center;
            transform-origin:center center; }
  .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-tooltip{
    -webkit-transform-origin:center right;
            transform-origin:center right; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-tooltip{
    -webkit-transform-origin:bottom left;
            transform-origin:bottom left; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-tooltip{
    -webkit-transform-origin:bottom center;
            transform-origin:bottom center; }
  .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-tooltip{
    -webkit-transform-origin:bottom right;
            transform-origin:bottom right; }
  .bp3-tooltip .bp3-popover-content{
    background:#394b59;
    color:#f5f8fa; }
  .bp3-tooltip .bp3-popover-arrow::before{
    -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2);
            box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); }
  .bp3-tooltip .bp3-popover-arrow-border{
    fill:#10161a;
    fill-opacity:0.1; }
  .bp3-tooltip .bp3-popover-arrow-fill{
    fill:#394b59; }
  .bp3-popover-enter > .bp3-tooltip, .bp3-popover-appear > .bp3-tooltip{
    -webkit-transform:scale(0.8);
            transform:scale(0.8); }
  .bp3-popover-enter-active > .bp3-tooltip, .bp3-popover-appear-active > .bp3-tooltip{
    -webkit-transform:scale(1);
            transform:scale(1);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:100ms;
            transition-duration:100ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-popover-exit > .bp3-tooltip{
    -webkit-transform:scale(1);
            transform:scale(1); }
  .bp3-popover-exit-active > .bp3-tooltip{
    -webkit-transform:scale(0.8);
            transform:scale(0.8);
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:100ms;
            transition-duration:100ms;
    -webkit-transition-property:-webkit-transform;
    transition-property:-webkit-transform;
    transition-property:transform;
    transition-property:transform, -webkit-transform;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-tooltip .bp3-popover-content{
    padding:10px 12px; }
  .bp3-tooltip.bp3-dark,
  .bp3-dark .bp3-tooltip{
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    .bp3-tooltip.bp3-dark .bp3-popover-content,
    .bp3-dark .bp3-tooltip .bp3-popover-content{
      background:#e1e8ed;
      color:#394b59; }
    .bp3-tooltip.bp3-dark .bp3-popover-arrow::before,
    .bp3-dark .bp3-tooltip .bp3-popover-arrow::before{
      -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4);
              box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); }
    .bp3-tooltip.bp3-dark .bp3-popover-arrow-border,
    .bp3-dark .bp3-tooltip .bp3-popover-arrow-border{
      fill:#10161a;
      fill-opacity:0.2; }
    .bp3-tooltip.bp3-dark .bp3-popover-arrow-fill,
    .bp3-dark .bp3-tooltip .bp3-popover-arrow-fill{
      fill:#e1e8ed; }
  .bp3-tooltip.bp3-intent-primary .bp3-popover-content{
    background:#137cbd;
    color:#ffffff; }
  .bp3-tooltip.bp3-intent-primary .bp3-popover-arrow-fill{
    fill:#137cbd; }
  .bp3-tooltip.bp3-intent-success .bp3-popover-content{
    background:#0f9960;
    color:#ffffff; }
  .bp3-tooltip.bp3-intent-success .bp3-popover-arrow-fill{
    fill:#0f9960; }
  .bp3-tooltip.bp3-intent-warning .bp3-popover-content{
    background:#d9822b;
    color:#ffffff; }
  .bp3-tooltip.bp3-intent-warning .bp3-popover-arrow-fill{
    fill:#d9822b; }
  .bp3-tooltip.bp3-intent-danger .bp3-popover-content{
    background:#db3737;
    color:#ffffff; }
  .bp3-tooltip.bp3-intent-danger .bp3-popover-arrow-fill{
    fill:#db3737; }

.bp3-tooltip-indicator{
  border-bottom:dotted 1px;
  cursor:help; }
.bp3-tree .bp3-icon, .bp3-tree .bp3-icon-standard, .bp3-tree .bp3-icon-large{
  color:#5c7080; }
  .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-tree .bp3-icon-large.bp3-intent-primary{
    color:#137cbd; }
  .bp3-tree .bp3-icon.bp3-intent-success, .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-tree .bp3-icon-large.bp3-intent-success{
    color:#0f9960; }
  .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-tree .bp3-icon-large.bp3-intent-warning{
    color:#d9822b; }
  .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-tree .bp3-icon-large.bp3-intent-danger{
    color:#db3737; }

.bp3-tree-node-list{
  list-style:none;
  margin:0;
  padding-left:0; }

.bp3-tree-root{
  background-color:transparent;
  cursor:default;
  padding-left:0;
  position:relative; }

.bp3-tree-node-content-0{
  padding-left:0px; }

.bp3-tree-node-content-1{
  padding-left:23px; }

.bp3-tree-node-content-2{
  padding-left:46px; }

.bp3-tree-node-content-3{
  padding-left:69px; }

.bp3-tree-node-content-4{
  padding-left:92px; }

.bp3-tree-node-content-5{
  padding-left:115px; }

.bp3-tree-node-content-6{
  padding-left:138px; }

.bp3-tree-node-content-7{
  padding-left:161px; }

.bp3-tree-node-content-8{
  padding-left:184px; }

.bp3-tree-node-content-9{
  padding-left:207px; }

.bp3-tree-node-content-10{
  padding-left:230px; }

.bp3-tree-node-content-11{
  padding-left:253px; }

.bp3-tree-node-content-12{
  padding-left:276px; }

.bp3-tree-node-content-13{
  padding-left:299px; }

.bp3-tree-node-content-14{
  padding-left:322px; }

.bp3-tree-node-content-15{
  padding-left:345px; }

.bp3-tree-node-content-16{
  padding-left:368px; }

.bp3-tree-node-content-17{
  padding-left:391px; }

.bp3-tree-node-content-18{
  padding-left:414px; }

.bp3-tree-node-content-19{
  padding-left:437px; }

.bp3-tree-node-content-20{
  padding-left:460px; }

.bp3-tree-node-content{
  -webkit-box-align:center;
      -ms-flex-align:center;
          align-items:center;
  display:-webkit-box;
  display:-ms-flexbox;
  display:flex;
  height:30px;
  padding-right:5px;
  width:100%; }
  .bp3-tree-node-content:hover{
    background-color:rgba(191, 204, 214, 0.4); }

.bp3-tree-node-caret,
.bp3-tree-node-caret-none{
  min-width:30px; }

.bp3-tree-node-caret{
  color:#5c7080;
  cursor:pointer;
  padding:7px;
  -webkit-transform:rotate(0deg);
          transform:rotate(0deg);
  -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
  transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-tree-node-caret:hover{
    color:#182026; }
  .bp3-dark .bp3-tree-node-caret{
    color:#a7b6c2; }
    .bp3-dark .bp3-tree-node-caret:hover{
      color:#f5f8fa; }
  .bp3-tree-node-caret.bp3-tree-node-caret-open{
    -webkit-transform:rotate(90deg);
            transform:rotate(90deg); }
  .bp3-tree-node-caret.bp3-icon-standard::before{
    content:""; }

.bp3-tree-node-icon{
  margin-right:7px;
  position:relative; }

.bp3-tree-node-label{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  word-wrap:normal;
  -webkit-box-flex:1;
      -ms-flex:1 1 auto;
          flex:1 1 auto;
  position:relative;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-tree-node-label span{
    display:inline; }

.bp3-tree-node-secondary-label{
  padding:0 5px;
  -webkit-user-select:none;
     -moz-user-select:none;
      -ms-user-select:none;
          user-select:none; }
  .bp3-tree-node-secondary-label .bp3-popover-wrapper,
  .bp3-tree-node-secondary-label .bp3-popover-target{
    -webkit-box-align:center;
        -ms-flex-align:center;
            align-items:center;
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex; }

.bp3-tree-node.bp3-disabled .bp3-tree-node-content{
  background-color:inherit;
  color:rgba(92, 112, 128, 0.6);
  cursor:not-allowed; }

.bp3-tree-node.bp3-disabled .bp3-tree-node-caret,
.bp3-tree-node.bp3-disabled .bp3-tree-node-icon{
  color:rgba(92, 112, 128, 0.6);
  cursor:not-allowed; }

.bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{
  background-color:#137cbd; }
  .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content,
  .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-standard, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-large{
    color:#ffffff; }
  .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret::before{
    color:rgba(255, 255, 255, 0.7); }
  .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret:hover::before{
    color:#ffffff; }

.bp3-dark .bp3-tree-node-content:hover{
  background-color:rgba(92, 112, 128, 0.3); }

.bp3-dark .bp3-tree .bp3-icon, .bp3-dark .bp3-tree .bp3-icon-standard, .bp3-dark .bp3-tree .bp3-icon-large{
  color:#a7b6c2; }
  .bp3-dark .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-primary{
    color:#137cbd; }
  .bp3-dark .bp3-tree .bp3-icon.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-success{
    color:#0f9960; }
  .bp3-dark .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-warning{
    color:#d9822b; }
  .bp3-dark .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-danger{
    color:#db3737; }

.bp3-dark .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{
  background-color:#137cbd; }
.bp3-omnibar{
  -webkit-filter:blur(0);
          filter:blur(0);
  opacity:1;
  background-color:#ffffff;
  border-radius:3px;
  -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
          box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
  left:calc(50% - 250px);
  top:20vh;
  width:500px;
  z-index:21; }
  .bp3-omnibar.bp3-overlay-enter, .bp3-omnibar.bp3-overlay-appear{
    -webkit-filter:blur(20px);
            filter:blur(20px);
    opacity:0.2; }
  .bp3-omnibar.bp3-overlay-enter-active, .bp3-omnibar.bp3-overlay-appear-active{
    -webkit-filter:blur(0);
            filter:blur(0);
    opacity:1;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:200ms;
            transition-duration:200ms;
    -webkit-transition-property:opacity, -webkit-filter;
    transition-property:opacity, -webkit-filter;
    transition-property:filter, opacity;
    transition-property:filter, opacity, -webkit-filter;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-omnibar.bp3-overlay-exit{
    -webkit-filter:blur(0);
            filter:blur(0);
    opacity:1; }
  .bp3-omnibar.bp3-overlay-exit-active{
    -webkit-filter:blur(20px);
            filter:blur(20px);
    opacity:0.2;
    -webkit-transition-delay:0;
            transition-delay:0;
    -webkit-transition-duration:200ms;
            transition-duration:200ms;
    -webkit-transition-property:opacity, -webkit-filter;
    transition-property:opacity, -webkit-filter;
    transition-property:filter, opacity;
    transition-property:filter, opacity, -webkit-filter;
    -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
            transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
  .bp3-omnibar .bp3-input{
    background-color:transparent;
    border-radius:0; }
    .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{
      -webkit-box-shadow:none;
              box-shadow:none; }
  .bp3-omnibar .bp3-menu{
    background-color:transparent;
    border-radius:0;
    -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
            box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
    max-height:calc(60vh - 40px);
    overflow:auto; }
    .bp3-omnibar .bp3-menu:empty{
      display:none; }
  .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{
    background-color:#30404d;
    -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
            box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); }

.bp3-omnibar-overlay .bp3-overlay-backdrop{
  background-color:rgba(16, 22, 26, 0.2); }

.bp3-select-popover .bp3-popover-content{
  padding:5px; }

.bp3-select-popover .bp3-input-group{
  margin-bottom:0; }

.bp3-select-popover .bp3-menu{
  max-height:300px;
  max-width:400px;
  overflow:auto;
  padding:0; }
  .bp3-select-popover .bp3-menu:not(:first-child){
    padding-top:5px; }

.bp3-multi-select{
  min-width:150px; }

.bp3-multi-select-popover .bp3-menu{
  max-height:300px;
  max-width:400px;
  overflow:auto; }

.bp3-select-popover .bp3-popover-content{
  padding:5px; }

.bp3-select-popover .bp3-input-group{
  margin-bottom:0; }

.bp3-select-popover .bp3-menu{
  max-height:300px;
  max-width:400px;
  overflow:auto;
  padding:0; }
  .bp3-select-popover .bp3-menu:not(:first-child){
    padding-top:5px; }
/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */

/**
 * (DEPRECATED) Support for consuming icons as CSS background images
 */

/* Icons urls */

:root {
  --jp-icon-add: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTE5IDEzaC02djZoLTJ2LTZINXYtMmg2VjVoMnY2aDZ2MnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-bug: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTIwIDhoLTIuODFjLS40NS0uNzgtMS4wNy0xLjQ1LTEuODItMS45NkwxNyA0LjQxIDE1LjU5IDNsLTIuMTcgMi4xN0MxMi45NiA1LjA2IDEyLjQ5IDUgMTIgNWMtLjQ5IDAtLjk2LjA2LTEuNDEuMTdMOC40MSAzIDcgNC40MWwxLjYyIDEuNjNDNy44OCA2LjU1IDcuMjYgNy4yMiA2LjgxIDhINHYyaDIuMDljLS4wNS4zMy0uMDkuNjYtLjA5IDF2MUg0djJoMnYxYzAgLjM0LjA0LjY3LjA5IDFINHYyaDIuODFjMS4wNCAxLjc5IDIuOTcgMyA1LjE5IDNzNC4xNS0xLjIxIDUuMTktM0gyMHYtMmgtMi4wOWMuMDUtLjMzLjA5LS42Ni4wOS0xdi0xaDJ2LTJoLTJ2LTFjMC0uMzQtLjA0LS42Ny0uMDktMUgyMFY4em0tNiA4aC00di0yaDR2MnptMC00aC00di0yaDR2MnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-build: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIHZpZXdCb3g9IjAgMCAyNCAyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTE0LjkgMTcuNDVDMTYuMjUgMTcuNDUgMTcuMzUgMTYuMzUgMTcuMzUgMTVDMTcuMzUgMTMuNjUgMTYuMjUgMTIuNTUgMTQuOSAxMi41NUMxMy41NCAxMi41NSAxMi40NSAxMy42NSAxMi40NSAxNUMxMi40NSAxNi4zNSAxMy41NCAxNy40NSAxNC45IDE3LjQ1Wk0yMC4xIDE1LjY4TDIxLjU4IDE2Ljg0QzIxLjcxIDE2Ljk1IDIxLjc1IDE3LjEzIDIxLjY2IDE3LjI5TDIwLjI2IDE5LjcxQzIwLjE3IDE5Ljg2IDIwIDE5LjkyIDE5LjgzIDE5Ljg2TDE4LjA5IDE5LjE2QzE3LjczIDE5LjQ0IDE3LjMzIDE5LjY3IDE2LjkxIDE5Ljg1TDE2LjY0IDIxLjdDMTYuNjIgMjEuODcgMTYuNDcgMjIgMTYuMyAyMkgxMy41QzEzLjMyIDIyIDEzLjE4IDIxLjg3IDEzLjE1IDIxLjdMMTIuODkgMTkuODVDMTIuNDYgMTkuNjcgMTIuMDcgMTkuNDQgMTEuNzEgMTkuMTZMOS45NjAwMiAxOS44NkM5LjgxMDAyIDE5LjkyIDkuNjIwMDIgMTkuODYgOS41NDAwMiAxOS43MUw4LjE0MDAyIDE3LjI5QzguMDUwMDIgMTcuMTMgOC4wOTAwMiAxNi45NSA4LjIyMDAyIDE2Ljg0TDkuNzAwMDIgMTUuNjhMOS42NTAwMSAxNUw5LjcwMDAyIDE0LjMxTDguMjIwMDIgMTMuMTZDOC4wOTAwMiAxMy4wNSA4LjA1MDAyIDEyLjg2IDguMTQwMDIgMTIuNzFMOS41NDAwMiAxMC4yOUM5LjYyMDAyIDEwLjEzIDkuODEwMDIgMTAuMDcgOS45NjAwMiAxMC4xM0wxMS43MSAxMC44NEMxMi4wNyAxMC41NiAxMi40NiAxMC4zMiAxMi44OSAxMC4xNUwxMy4xNSA4LjI4OTk4QzEzLjE4IDguMTI5OTggMTMuMzIgNy45OTk5OCAxMy41IDcuOTk5OThIMTYuM0MxNi40NyA3Ljk5OTk4IDE2LjYyIDguMTI5OTggMTYuNjQgOC4yODk5OEwxNi45MSAxMC4xNUMxNy4zMyAxMC4zMiAxNy43MyAxMC41NiAxOC4wOSAxMC44NEwxOS44MyAxMC4xM0MyMCAxMC4wNyAyMC4xNyAxMC4xMyAyMC4yNiAxMC4yOUwyMS42NiAxMi43MUMyMS43NSAxMi44NiAyMS43MSAxMy4wNSAyMS41OCAxMy4xNkwyMC4xIDE0LjMxTDIwLjE1IDE1TDIwLjEgMTUuNjhaIi8+CiAgICA8cGF0aCBkPSJNNy4zMjk2NiA3LjQ0NDU0QzguMDgzMSA3LjAwOTU0IDguMzM5MzIgNi4wNTMzMiA3LjkwNDMyIDUuMjk5ODhDNy40NjkzMiA0LjU0NjQzIDYuNTA4MSA0LjI4MTU2IDUuNzU0NjYgNC43MTY1NkM1LjM5MTc2IDQuOTI2MDggNS4xMjY5NSA1LjI3MTE4IDUuMDE4NDkgNS42NzU5NEM0LjkxMDA0IDYuMDgwNzEgNC45NjY4MiA2LjUxMTk4IDUuMTc2MzQgNi44NzQ4OEM1LjYxMTM0IDcuNjI4MzIgNi41NzYyMiA3Ljg3OTU0IDcuMzI5NjYgNy40NDQ1NFpNOS42NTcxOCA0Ljc5NTkzTDEwLjg2NzIgNC45NTE3OUMxMC45NjI4IDQuOTc3NDEgMTEuMDQwMiA1LjA3MTMzIDExLjAzODIgNS4xODc5M0wxMS4wMzg4IDYuOTg4OTNDMTEuMDQ1NSA3LjEwMDU0IDEwLjk2MTYgNy4xOTUxOCAxMC44NTUgNy4yMTA1NEw5LjY2MDAxIDcuMzgwODNMOS4yMzkxNSA4LjEzMTg4TDkuNjY5NjEgOS4yNTc0NUM5LjcwNzI5IDkuMzYyNzEgOS42NjkzNCA5LjQ3Njk5IDkuNTc0MDggOS41MzE5OUw4LjAxNTIzIDEwLjQzMkM3LjkxMTMxIDEwLjQ5MiA3Ljc5MzM3IDEwLjQ2NzcgNy43MjEwNSAxMC4zODI0TDYuOTg3NDggOS40MzE4OEw2LjEwOTMxIDkuNDMwODNMNS4zNDcwNCAxMC4zOTA1QzUuMjg5MDkgMTAuNDcwMiA1LjE3MzgzIDEwLjQ5MDUgNS4wNzE4NyAxMC40MzM5TDMuNTEyNDUgOS41MzI5M0MzLjQxMDQ5IDkuNDc2MzMgMy4zNzY0NyA5LjM1NzQxIDMuNDEwNzUgOS4yNTY3OUwzLjg2MzQ3IDguMTQwOTNMMy42MTc0OSA3Ljc3NDg4TDMuNDIzNDcgNy4zNzg4M0wyLjIzMDc1IDcuMjEyOTdDMi4xMjY0NyA3LjE5MjM1IDIuMDQwNDkgNy4xMDM0MiAyLjA0MjQ1IDYuOTg2ODJMMi4wNDE4NyA1LjE4NTgyQzIuMDQzODMgNS4wNjkyMiAyLjExOTA5IDQuOTc5NTggMi4yMTcwNCA0Ljk2OTIyTDMuNDIwNjUgNC43OTM5M0wzLjg2NzQ5IDQuMDI3ODhMMy40MTEwNSAyLjkxNzMxQzMuMzczMzcgMi44MTIwNCAzLjQxMTMxIDIuNjk3NzYgMy41MTUyMyAyLjYzNzc2TDUuMDc0MDggMS43Mzc3NkM1LjE2OTM0IDEuNjgyNzYgNS4yODcyOSAxLjcwNzA0IDUuMzU5NjEgMS43OTIzMUw2LjExOTE1IDIuNzI3ODhMNi45ODAwMSAyLjczODkzTDcuNzI0OTYgMS43ODkyMkM3Ljc5MTU2IDEuNzA0NTggNy45MTU0OCAxLjY3OTIyIDguMDA4NzkgMS43NDA4Mkw5LjU2ODIxIDIuNjQxODJDOS42NzAxNyAyLjY5ODQyIDkuNzEyODUgMi44MTIzNCA5LjY4NzIzIDIuOTA3OTdMOS4yMTcxOCA0LjAzMzgzTDkuNDYzMTYgNC4zOTk4OEw5LjY1NzE4IDQuNzk1OTNaIi8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-caret-down-empty-thin: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIwIDIwIj4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSIgc2hhcGUtcmVuZGVyaW5nPSJnZW9tZXRyaWNQcmVjaXNpb24iPgoJCTxwb2x5Z29uIGNsYXNzPSJzdDEiIHBvaW50cz0iOS45LDEzLjYgMy42LDcuNCA0LjQsNi42IDkuOSwxMi4yIDE1LjQsNi43IDE2LjEsNy40ICIvPgoJPC9nPgo8L3N2Zz4K);
  --jp-icon-caret-down-empty: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiIHNoYXBlLXJlbmRlcmluZz0iZ2VvbWV0cmljUHJlY2lzaW9uIj4KICAgIDxwYXRoIGQ9Ik01LjIsNS45TDksOS43bDMuOC0zLjhsMS4yLDEuMmwtNC45LDVsLTQuOS01TDUuMiw1Ljl6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-caret-down: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiIHNoYXBlLXJlbmRlcmluZz0iZ2VvbWV0cmljUHJlY2lzaW9uIj4KICAgIDxwYXRoIGQ9Ik01LjIsNy41TDksMTEuMmwzLjgtMy44SDUuMnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-caret-left: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSIgc2hhcGUtcmVuZGVyaW5nPSJnZW9tZXRyaWNQcmVjaXNpb24iPgoJCTxwYXRoIGQ9Ik0xMC44LDEyLjhMNy4xLDlsMy44LTMuOGwwLDcuNkgxMC44eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-caret-right: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiIHNoYXBlLXJlbmRlcmluZz0iZ2VvbWV0cmljUHJlY2lzaW9uIj4KICAgIDxwYXRoIGQ9Ik03LjIsNS4yTDEwLjksOWwtMy44LDMuOFY1LjJINy4yeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-caret-up-empty-thin: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIwIDIwIj4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSIgc2hhcGUtcmVuZGVyaW5nPSJnZW9tZXRyaWNQcmVjaXNpb24iPgoJCTxwb2x5Z29uIGNsYXNzPSJzdDEiIHBvaW50cz0iMTUuNCwxMy4zIDkuOSw3LjcgNC40LDEzLjIgMy42LDEyLjUgOS45LDYuMyAxNi4xLDEyLjYgIi8+Cgk8L2c+Cjwvc3ZnPgo=);
  --jp-icon-caret-up: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSIgc2hhcGUtcmVuZGVyaW5nPSJnZW9tZXRyaWNQcmVjaXNpb24iPgoJCTxwYXRoIGQ9Ik01LjIsMTAuNUw5LDYuOGwzLjgsMy44SDUuMnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-case-sensitive: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8ZyBjbGFzcz0ianAtaWNvbjIiIGZpbGw9IiM0MTQxNDEiPgogICAgPHJlY3QgeD0iMiIgeT0iMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2Ii8+CiAgPC9nPgogIDxnIGNsYXNzPSJqcC1pY29uLWFjY2VudDIiIGZpbGw9IiNGRkYiPgogICAgPHBhdGggZD0iTTcuNiw4aDAuOWwzLjUsOGgtMS4xTDEwLDE0SDZsLTAuOSwySDRMNy42LDh6IE04LDkuMUw2LjQsMTNoMy4yTDgsOS4xeiIvPgogICAgPHBhdGggZD0iTTE2LjYsOS44Yy0wLjIsMC4xLTAuNCwwLjEtMC43LDAuMWMtMC4yLDAtMC40LTAuMS0wLjYtMC4yYy0wLjEtMC4xLTAuMi0wLjQtMC4yLTAuNyBjLTAuMywwLjMtMC42LDAuNS0wLjksMC43Yy0wLjMsMC4xLTAuNywwLjItMS4xLDAuMmMtMC4zLDAtMC41LDAtMC43LTAuMWMtMC4yLTAuMS0wLjQtMC4yLTAuNi0wLjNjLTAuMi0wLjEtMC4zLTAuMy0wLjQtMC41IGMtMC4xLTAuMi0wLjEtMC40LTAuMS0wLjdjMC0wLjMsMC4xLTAuNiwwLjItMC44YzAuMS0wLjIsMC4zLTAuNCwwLjQtMC41QzEyLDcsMTIuMiw2LjksMTIuNSw2LjhjMC4yLTAuMSwwLjUtMC4xLDAuNy0wLjIgYzAuMy0wLjEsMC41LTAuMSwwLjctMC4xYzAuMiwwLDAuNC0wLjEsMC42LTAuMWMwLjIsMCwwLjMtMC4xLDAuNC0wLjJjMC4xLTAuMSwwLjItMC4yLDAuMi0wLjRjMC0xLTEuMS0xLTEuMy0xIGMtMC40LDAtMS40LDAtMS40LDEuMmgtMC45YzAtMC40LDAuMS0wLjcsMC4yLTFjMC4xLTAuMiwwLjMtMC40LDAuNS0wLjZjMC4yLTAuMiwwLjUtMC4zLDAuOC0wLjNDMTMuMyw0LDEzLjYsNCwxMy45LDQgYzAuMywwLDAuNSwwLDAuOCwwLjFjMC4zLDAsMC41LDAuMSwwLjcsMC4yYzAuMiwwLjEsMC40LDAuMywwLjUsMC41QzE2LDUsMTYsNS4yLDE2LDUuNnYyLjljMCwwLjIsMCwwLjQsMCwwLjUgYzAsMC4xLDAuMSwwLjIsMC4zLDAuMmMwLjEsMCwwLjIsMCwwLjMsMFY5Ljh6IE0xNS4yLDYuOWMtMS4yLDAuNi0zLjEsMC4yLTMuMSwxLjRjMCwxLjQsMy4xLDEsMy4xLTAuNVY2Ljl6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-check: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTkgMTYuMTdMNC44MyAxMmwtMS40MiAxLjQxTDkgMTkgMjEgN2wtMS40MS0xLjQxeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-circle-empty: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEyIDJDNi40NyAyIDIgNi40NyAyIDEyczQuNDcgMTAgMTAgMTAgMTAtNC40NyAxMC0xMFMxNy41MyAyIDEyIDJ6bTAgMThjLTQuNDEgMC04LTMuNTktOC04czMuNTktOCA4LTggOCAzLjU5IDggOC0zLjU5IDgtOCA4eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-circle: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMTggMTgiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPGNpcmNsZSBjeD0iOSIgY3k9IjkiIHI9IjgiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-clear: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8bWFzayBpZD0iZG9udXRIb2xlIj4KICAgIDxyZWN0IHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgZmlsbD0id2hpdGUiIC8+CiAgICA8Y2lyY2xlIGN4PSIxMiIgY3k9IjEyIiByPSI4IiBmaWxsPSJibGFjayIvPgogIDwvbWFzaz4KCiAgPGcgY2xhc3M9ImpwLWljb24zIiBmaWxsPSIjNjE2MTYxIj4KICAgIDxyZWN0IGhlaWdodD0iMTgiIHdpZHRoPSIyIiB4PSIxMSIgeT0iMyIgdHJhbnNmb3JtPSJyb3RhdGUoMzE1LCAxMiwgMTIpIi8+CiAgICA8Y2lyY2xlIGN4PSIxMiIgY3k9IjEyIiByPSIxMCIgbWFzaz0idXJsKCNkb251dEhvbGUpIi8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-close: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbi1ub25lIGpwLWljb24tc2VsZWN0YWJsZS1pbnZlcnNlIGpwLWljb24zLWhvdmVyIiBmaWxsPSJub25lIj4KICAgIDxjaXJjbGUgY3g9IjEyIiBjeT0iMTIiIHI9IjExIi8+CiAgPC9nPgoKICA8ZyBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIGpwLWljb24tYWNjZW50Mi1ob3ZlciIgZmlsbD0iIzYxNjE2MSI+CiAgICA8cGF0aCBkPSJNMTkgNi40MUwxNy41OSA1IDEyIDEwLjU5IDYuNDEgNSA1IDYuNDEgMTAuNTkgMTIgNSAxNy41OSA2LjQxIDE5IDEyIDEzLjQxIDE3LjU5IDE5IDE5IDE3LjU5IDEzLjQxIDEyeiIvPgogIDwvZz4KCiAgPGcgY2xhc3M9ImpwLWljb24tbm9uZSBqcC1pY29uLWJ1c3kiIGZpbGw9Im5vbmUiPgogICAgPGNpcmNsZSBjeD0iMTIiIGN5PSIxMiIgcj0iNyIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-code: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjIiIGhlaWdodD0iMjIiIHZpZXdCb3g9IjAgMCAyOCAyOCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CgkJPHBhdGggZD0iTTExLjQgMTguNkw2LjggMTRMMTEuNCA5LjRMMTAgOEw0IDE0TDEwIDIwTDExLjQgMTguNlpNMTYuNiAxOC42TDIxLjIgMTRMMTYuNiA5LjRMMTggOEwyNCAxNEwxOCAyMEwxNi42IDE4LjZWMTguNloiLz4KCTwvZz4KPC9zdmc+Cg==);
  --jp-icon-console: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIwMCAyMDAiPgogIDxnIGNsYXNzPSJqcC1pY29uLWJyYW5kMSBqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiMwMjg4RDEiPgogICAgPHBhdGggZD0iTTIwIDE5LjhoMTYwdjE1OS45SDIweiIvPgogIDwvZz4KICA8ZyBjbGFzcz0ianAtaWNvbi1zZWxlY3RhYmxlLWludmVyc2UiIGZpbGw9IiNmZmYiPgogICAgPHBhdGggZD0iTTEwNSAxMjcuM2g0MHYxMi44aC00MHpNNTEuMSA3N0w3NCA5OS45bC0yMy4zIDIzLjMgMTAuNSAxMC41IDIzLjMtMjMuM0w5NSA5OS45IDg0LjUgODkuNCA2MS42IDY2LjV6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-copy: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMTggMTgiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTExLjksMUgzLjJDMi40LDEsMS43LDEuNywxLjcsMi41djEwLjJoMS41VjIuNWg4LjdWMXogTTE0LjEsMy45aC04Yy0wLjgsMC0xLjUsMC43LTEuNSwxLjV2MTAuMmMwLDAuOCwwLjcsMS41LDEuNSwxLjVoOCBjMC44LDAsMS41LTAuNywxLjUtMS41VjUuNEMxNS41LDQuNiwxNC45LDMuOSwxNC4xLDMuOXogTTE0LjEsMTUuNWgtOFY1LjRoOFYxNS41eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-cut: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTkuNjQgNy42NGMuMjMtLjUuMzYtMS4wNS4zNi0xLjY0IDAtMi4yMS0xLjc5LTQtNC00UzIgMy43OSAyIDZzMS43OSA0IDQgNGMuNTkgMCAxLjE0LS4xMyAxLjY0LS4zNkwxMCAxMmwtMi4zNiAyLjM2QzcuMTQgMTQuMTMgNi41OSAxNCA2IDE0Yy0yLjIxIDAtNCAxLjc5LTQgNHMxLjc5IDQgNCA0IDQtMS43OSA0LTRjMC0uNTktLjEzLTEuMTQtLjM2LTEuNjRMMTIgMTRsNyA3aDN2LTFMOS42NCA3LjY0ek02IDhjLTEuMSAwLTItLjg5LTItMnMuOS0yIDItMiAyIC44OSAyIDItLjkgMi0yIDJ6bTAgMTJjLTEuMSAwLTItLjg5LTItMnMuOS0yIDItMiAyIC44OSAyIDItLjkgMi0yIDJ6bTYtNy41Yy0uMjggMC0uNS0uMjItLjUtLjVzLjIyLS41LjUtLjUuNS4yMi41LjUtLjIyLjUtLjUuNXpNMTkgM2wtNiA2IDIgMiA3LTdWM3oiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-download: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTE5IDloLTRWM0g5djZINWw3IDcgNy03ek01IDE4djJoMTR2LTJINXoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-edit: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTMgMTcuMjVWMjFoMy43NUwxNy44MSA5Ljk0bC0zLjc1LTMuNzVMMyAxNy4yNXpNMjAuNzEgNy4wNGMuMzktLjM5LjM5LTEuMDIgMC0xLjQxbC0yLjM0LTIuMzRjLS4zOS0uMzktMS4wMi0uMzktMS40MSAwbC0xLjgzIDEuODMgMy43NSAzLjc1IDEuODMtMS44M3oiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-ellipses: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPGNpcmNsZSBjeD0iNSIgY3k9IjEyIiByPSIyIi8+CiAgICA8Y2lyY2xlIGN4PSIxMiIgY3k9IjEyIiByPSIyIi8+CiAgICA8Y2lyY2xlIGN4PSIxOSIgY3k9IjEyIiByPSIyIi8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-extension: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTIwLjUgMTFIMTlWN2MwLTEuMS0uOS0yLTItMmgtNFYzLjVDMTMgMi4xMiAxMS44OCAxIDEwLjUgMVM4IDIuMTIgOCAzLjVWNUg0Yy0xLjEgMC0xLjk5LjktMS45OSAydjMuOEgzLjVjMS40OSAwIDIuNyAxLjIxIDIuNyAyLjdzLTEuMjEgMi43LTIuNyAyLjdIMlYyMGMwIDEuMS45IDIgMiAyaDMuOHYtMS41YzAtMS40OSAxLjIxLTIuNyAyLjctMi43IDEuNDkgMCAyLjcgMS4yMSAyLjcgMi43VjIySDE3YzEuMSAwIDItLjkgMi0ydi00aDEuNWMxLjM4IDAgMi41LTEuMTIgMi41LTIuNVMyMS44OCAxMSAyMC41IDExeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-fast-forward: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTQgMThsOC41LTZMNCA2djEyem05LTEydjEybDguNS02TDEzIDZ6Ii8+CiAgICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-file-upload: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTkgMTZoNnYtNmg0bC03LTctNyA3aDR6bS00IDJoMTR2Mkg1eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-file: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMTkuMyA4LjJsLTUuNS01LjVjLS4zLS4zLS43LS41LTEuMi0uNUgzLjljLS44LjEtMS42LjktMS42IDEuOHYxNC4xYzAgLjkuNyAxLjYgMS42IDEuNmgxNC4yYy45IDAgMS42LS43IDEuNi0xLjZWOS40Yy4xLS41LS4xLS45LS40LTEuMnptLTUuOC0zLjNsMy40IDMuNmgtMy40VjQuOXptMy45IDEyLjdINC43Yy0uMSAwLS4yIDAtLjItLjJWNC43YzAtLjIuMS0uMy4yLS4zaDcuMnY0LjRzMCAuOC4zIDEuMWMuMy4zIDEuMS4zIDEuMS4zaDQuM3Y3LjJzLS4xLjItLjIuMnoiLz4KPC9zdmc+Cg==);
  --jp-icon-filter-list: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEwIDE4aDR2LTJoLTR2MnpNMyA2djJoMThWNkgzem0zIDdoMTJ2LTJINnYyeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-folder: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMTAgNEg0Yy0xLjEgMC0xLjk5LjktMS45OSAyTDIgMThjMCAxLjEuOSAyIDIgMmgxNmMxLjEgMCAyLS45IDItMlY4YzAtMS4xLS45LTItMi0yaC04bC0yLTJ6Ii8+Cjwvc3ZnPgo=);
  --jp-icon-html5: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDUxMiA1MTIiPgogIDxwYXRoIGNsYXNzPSJqcC1pY29uMCBqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiMwMDAiIGQ9Ik0xMDguNCAwaDIzdjIyLjhoMjEuMlYwaDIzdjY5aC0yM1Y0NmgtMjF2MjNoLTIzLjJNMjA2IDIzaC0yMC4zVjBoNjMuN3YyM0gyMjl2NDZoLTIzbTUzLjUtNjloMjQuMWwxNC44IDI0LjNMMzEzLjIgMGgyNC4xdjY5aC0yM1YzNC44bC0xNi4xIDI0LjgtMTYuMS0yNC44VjY5aC0yMi42bTg5LjItNjloMjN2NDYuMmgzMi42VjY5aC01NS42Ii8+CiAgPHBhdGggY2xhc3M9ImpwLWljb24tc2VsZWN0YWJsZSIgZmlsbD0iI2U0NGQyNiIgZD0iTTEwNy42IDQ3MWwtMzMtMzcwLjRoMzYyLjhsLTMzIDM3MC4yTDI1NS43IDUxMiIvPgogIDxwYXRoIGNsYXNzPSJqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiNmMTY1MjkiIGQ9Ik0yNTYgNDgwLjVWMTMxaDE0OC4zTDM3NiA0NDciLz4KICA8cGF0aCBjbGFzcz0ianAtaWNvbi1zZWxlY3RhYmxlLWludmVyc2UiIGZpbGw9IiNlYmViZWIiIGQ9Ik0xNDIgMTc2LjNoMTE0djQ1LjRoLTY0LjJsNC4yIDQ2LjVoNjB2NDUuM0gxNTQuNG0yIDIyLjhIMjAybDMuMiAzNi4zIDUwLjggMTMuNnY0Ny40bC05My4yLTI2Ii8+CiAgPHBhdGggY2xhc3M9ImpwLWljb24tc2VsZWN0YWJsZS1pbnZlcnNlIiBmaWxsPSIjZmZmIiBkPSJNMzY5LjYgMTc2LjNIMjU1Ljh2NDUuNGgxMDkuNm0tNC4xIDQ2LjVIMjU1Ljh2NDUuNGg1NmwtNS4zIDU5LTUwLjcgMTMuNnY0Ny4ybDkzLTI1LjgiLz4KPC9zdmc+Cg==);
  --jp-icon-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8cGF0aCBjbGFzcz0ianAtaWNvbi1icmFuZDQganAtaWNvbi1zZWxlY3RhYmxlLWludmVyc2UiIGZpbGw9IiNGRkYiIGQ9Ik0yLjIgMi4yaDE3LjV2MTcuNUgyLjJ6Ii8+CiAgPHBhdGggY2xhc3M9ImpwLWljb24tYnJhbmQwIGpwLWljb24tc2VsZWN0YWJsZSIgZmlsbD0iIzNGNTFCNSIgZD0iTTIuMiAyLjJ2MTcuNWgxNy41bC4xLTE3LjVIMi4yem0xMi4xIDIuMmMxLjIgMCAyLjIgMSAyLjIgMi4ycy0xIDIuMi0yLjIgMi4yLTIuMi0xLTIuMi0yLjIgMS0yLjIgMi4yLTIuMnpNNC40IDE3LjZsMy4zLTguOCAzLjMgNi42IDIuMi0zLjIgNC40IDUuNEg0LjR6Ii8+Cjwvc3ZnPgo=);
  --jp-icon-inspector: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMjAgNEg0Yy0xLjEgMC0xLjk5LjktMS45OSAyTDIgMThjMCAxLjEuOSAyIDIgMmgxNmMxLjEgMCAyLS45IDItMlY2YzAtMS4xLS45LTItMi0yem0tNSAxNEg0di00aDExdjR6bTAtNUg0VjloMTF2NHptNSA1aC00VjloNHY5eiIvPgo8L3N2Zz4K);
  --jp-icon-json: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8ZyBjbGFzcz0ianAtaWNvbi13YXJuMSBqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiNGOUE4MjUiPgogICAgPHBhdGggZD0iTTIwLjIgMTEuOGMtMS42IDAtMS43LjUtMS43IDEgMCAuNC4xLjkuMSAxLjMuMS41LjEuOS4xIDEuMyAwIDEuNy0xLjQgMi4zLTMuNSAyLjNoLS45di0xLjloLjVjMS4xIDAgMS40IDAgMS40LS44IDAtLjMgMC0uNi0uMS0xIDAtLjQtLjEtLjgtLjEtMS4yIDAtMS4zIDAtMS44IDEuMy0yLTEuMy0uMi0xLjMtLjctMS4zLTIgMC0uNC4xLS44LjEtMS4yLjEtLjQuMS0uNy4xLTEgMC0uOC0uNC0uNy0xLjQtLjhoLS41VjQuMWguOWMyLjIgMCAzLjUuNyAzLjUgMi4zIDAgLjQtLjEuOS0uMSAxLjMtLjEuNS0uMS45LS4xIDEuMyAwIC41LjIgMSAxLjcgMXYxLjh6TTEuOCAxMC4xYzEuNiAwIDEuNy0uNSAxLjctMSAwLS40LS4xLS45LS4xLTEuMy0uMS0uNS0uMS0uOS0uMS0xLjMgMC0xLjYgMS40LTIuMyAzLjUtMi4zaC45djEuOWgtLjVjLTEgMC0xLjQgMC0xLjQuOCAwIC4zIDAgLjYuMSAxIDAgLjIuMS42LjEgMSAwIDEuMyAwIDEuOC0xLjMgMkM2IDExLjIgNiAxMS43IDYgMTNjMCAuNC0uMS44LS4xIDEuMi0uMS4zLS4xLjctLjEgMSAwIC44LjMuOCAxLjQuOGguNXYxLjloLS45Yy0yLjEgMC0zLjUtLjYtMy41LTIuMyAwLS40LjEtLjkuMS0xLjMuMS0uNS4xLS45LjEtMS4zIDAtLjUtLjItMS0xLjctMXYtMS45eiIvPgogICAgPGNpcmNsZSBjeD0iMTEiIGN5PSIxMy44IiByPSIyLjEiLz4KICAgIDxjaXJjbGUgY3g9IjExIiBjeT0iOC4yIiByPSIyLjEiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-jupyter-favicon: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTUyIiBoZWlnaHQ9IjE2NSIgdmlld0JveD0iMCAwIDE1MiAxNjUiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbi13YXJuMCIgZmlsbD0iI0YzNzcyNiI+CiAgICA8cGF0aCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwLjA3ODk0NywgMTEwLjU4MjkyNykiIGQ9Ik03NS45NDIyODQyLDI5LjU4MDQ1NjEgQzQzLjMwMjM5NDcsMjkuNTgwNDU2MSAxNC43OTY3ODMyLDE3LjY1MzQ2MzQgMCwwIEM1LjUxMDgzMjExLDE1Ljg0MDY4MjkgMTUuNzgxNTM4OSwyOS41NjY3NzMyIDI5LjM5MDQ5NDcsMzkuMjc4NDE3MSBDNDIuOTk5Nyw0OC45ODk4NTM3IDU5LjI3MzcsNTQuMjA2NzgwNSA3NS45NjA1Nzg5LDU0LjIwNjc4MDUgQzkyLjY0NzQ1NzksNTQuMjA2NzgwNSAxMDguOTIxNDU4LDQ4Ljk4OTg1MzcgMTIyLjUzMDY2MywzOS4yNzg0MTcxIEMxMzYuMTM5NDUzLDI5LjU2Njc3MzIgMTQ2LjQxMDI4NCwxNS44NDA2ODI5IDE1MS45MjExNTgsMCBDMTM3LjA4Nzg2OCwxNy42NTM0NjM0IDEwOC41ODI1ODksMjkuNTgwNDU2MSA3NS45NDIyODQyLDI5LjU4MDQ1NjEgTDc1Ljk0MjI4NDIsMjkuNTgwNDU2MSBaIiAvPgogICAgPHBhdGggdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wMzczNjgsIDAuNzA0ODc4KSIgZD0iTTc1Ljk3ODQ1NzksMjQuNjI2NDA3MyBDMTA4LjYxODc2MywyNC42MjY0MDczIDEzNy4xMjQ0NTgsMzYuNTUzNDQxNSAxNTEuOTIxMTU4LDU0LjIwNjc4MDUgQzE0Ni40MTAyODQsMzguMzY2MjIyIDEzNi4xMzk0NTMsMjQuNjQwMTMxNyAxMjIuNTMwNjYzLDE0LjkyODQ4NzggQzEwOC45MjE0NTgsNS4yMTY4NDM5IDkyLjY0NzQ1NzksMCA3NS45NjA1Nzg5LDAgQzU5LjI3MzcsMCA0Mi45OTk3LDUuMjE2ODQzOSAyOS4zOTA0OTQ3LDE0LjkyODQ4NzggQzE1Ljc4MTUzODksMjQuNjQwMTMxNyA1LjUxMDgzMjExLDM4LjM2NjIyMiAwLDU0LjIwNjc4MDUgQzE0LjgzMzA4MTYsMzYuNTg5OTI5MyA0My4zMzg1Njg0LDI0LjYyNjQwNzMgNzUuOTc4NDU3OSwyNC42MjY0MDczIEw3NS45Nzg0NTc5LDI0LjYyNjQwNzMgWiIgLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-jupyter: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzkiIGhlaWdodD0iNTEiIHZpZXdCb3g9IjAgMCAzOSA1MSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMTYzOCAtMjI4MSkiPgogICAgPGcgY2xhc3M9ImpwLWljb24td2FybjAiIGZpbGw9IiNGMzc3MjYiPgogICAgICA8cGF0aCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxNjM5Ljc0IDIzMTEuOTgpIiBkPSJNIDE4LjI2NDYgNy4xMzQxMUMgMTAuNDE0NSA3LjEzNDExIDMuNTU4NzIgNC4yNTc2IDAgMEMgMS4zMjUzOSAzLjgyMDQgMy43OTU1NiA3LjEzMDgxIDcuMDY4NiA5LjQ3MzAzQyAxMC4zNDE3IDExLjgxNTIgMTQuMjU1NyAxMy4wNzM0IDE4LjI2OSAxMy4wNzM0QyAyMi4yODIzIDEzLjA3MzQgMjYuMTk2MyAxMS44MTUyIDI5LjQ2OTQgOS40NzMwM0MgMzIuNzQyNCA3LjEzMDgxIDM1LjIxMjYgMy44MjA0IDM2LjUzOCAwQyAzMi45NzA1IDQuMjU3NiAyNi4xMTQ4IDcuMTM0MTEgMTguMjY0NiA3LjEzNDExWiIvPgogICAgICA8cGF0aCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxNjM5LjczIDIyODUuNDgpIiBkPSJNIDE4LjI3MzMgNS45MzkzMUMgMjYuMTIzNSA1LjkzOTMxIDMyLjk3OTMgOC44MTU4MyAzNi41MzggMTMuMDczNEMgMzUuMjEyNiA5LjI1MzAzIDMyLjc0MjQgNS45NDI2MiAyOS40Njk0IDMuNjAwNEMgMjYuMTk2MyAxLjI1ODE4IDIyLjI4MjMgMCAxOC4yNjkgMEMgMTQuMjU1NyAwIDEwLjM0MTcgMS4yNTgxOCA3LjA2ODYgMy42MDA0QyAzLjc5NTU2IDUuOTQyNjIgMS4zMjUzOSA5LjI1MzAzIDAgMTMuMDczNEMgMy41Njc0NSA4LjgyNDYzIDEwLjQyMzIgNS45MzkzMSAxOC4yNzMzIDUuOTM5MzFaIi8+CiAgICA8L2c+CiAgICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgICA8cGF0aCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxNjY5LjMgMjI4MS4zMSkiIGQ9Ik0gNS44OTM1MyAyLjg0NEMgNS45MTg4OSAzLjQzMTY1IDUuNzcwODUgNC4wMTM2NyA1LjQ2ODE1IDQuNTE2NDVDIDUuMTY1NDUgNS4wMTkyMiA0LjcyMTY4IDUuNDIwMTUgNC4xOTI5OSA1LjY2ODUxQyAzLjY2NDMgNS45MTY4OCAzLjA3NDQ0IDYuMDAxNTEgMi40OTgwNSA1LjkxMTcxQyAxLjkyMTY2IDUuODIxOSAxLjM4NDYzIDUuNTYxNyAwLjk1NDg5OCA1LjE2NDAxQyAwLjUyNTE3IDQuNzY2MzMgMC4yMjIwNTYgNC4yNDkwMyAwLjA4MzkwMzcgMy42Nzc1N0MgLTAuMDU0MjQ4MyAzLjEwNjExIC0wLjAyMTIzIDIuNTA2MTcgMC4xNzg3ODEgMS45NTM2NEMgMC4zNzg3OTMgMS40MDExIDAuNzM2ODA5IDAuOTIwODE3IDEuMjA3NTQgMC41NzM1MzhDIDEuNjc4MjYgMC4yMjYyNTkgMi4yNDA1NSAwLjAyNzU5MTkgMi44MjMyNiAwLjAwMjY3MjI5QyAzLjYwMzg5IC0wLjAzMDcxMTUgNC4zNjU3MyAwLjI0OTc4OSA0Ljk0MTQyIDAuNzgyNTUxQyA1LjUxNzExIDEuMzE1MzEgNS44NTk1NiAyLjA1Njc2IDUuODkzNTMgMi44NDRaIi8+CiAgICAgIDxwYXRoIHRyYW5zZm9ybT0idHJhbnNsYXRlKDE2MzkuOCAyMzIzLjgxKSIgZD0iTSA3LjQyNzg5IDMuNTgzMzhDIDcuNDYwMDggNC4zMjQzIDcuMjczNTUgNS4wNTgxOSA2Ljg5MTkzIDUuNjkyMTNDIDYuNTEwMzEgNi4zMjYwNyA1Ljk1MDc1IDYuODMxNTYgNS4yODQxMSA3LjE0NDZDIDQuNjE3NDcgNy40NTc2MyAzLjg3MzcxIDcuNTY0MTQgMy4xNDcwMiA3LjQ1MDYzQyAyLjQyMDMyIDcuMzM3MTIgMS43NDMzNiA3LjAwODcgMS4yMDE4NCA2LjUwNjk1QyAwLjY2MDMyOCA2LjAwNTIgMC4yNzg2MSA1LjM1MjY4IDAuMTA1MDE3IDQuNjMyMDJDIC0wLjA2ODU3NTcgMy45MTEzNSAtMC4wMjYyMzYxIDMuMTU0OTQgMC4yMjY2NzUgMi40NTg1NkMgMC40Nzk1ODcgMS43NjIxNyAwLjkzMTY5NyAxLjE1NzEzIDEuNTI1NzYgMC43MjAwMzNDIDIuMTE5ODMgMC4yODI5MzUgMi44MjkxNCAwLjAzMzQzOTUgMy41NjM4OSAwLjAwMzEzMzQ0QyA0LjU0NjY3IC0wLjAzNzQwMzMgNS41MDUyOSAwLjMxNjcwNiA2LjIyOTYxIDAuOTg3ODM1QyA2Ljk1MzkzIDEuNjU4OTYgNy4zODQ4NCAyLjU5MjM1IDcuNDI3ODkgMy41ODMzOEwgNy40Mjc4OSAzLjU4MzM4WiIvPgogICAgICA8cGF0aCB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxNjM4LjM2IDIyODYuMDYpIiBkPSJNIDIuMjc0NzEgNC4zOTYyOUMgMS44NDM2MyA0LjQxNTA4IDEuNDE2NzEgNC4zMDQ0NSAxLjA0Nzk5IDQuMDc4NDNDIDAuNjc5MjY4IDMuODUyNCAwLjM4NTMyOCAzLjUyMTE0IDAuMjAzMzcxIDMuMTI2NTZDIDAuMDIxNDEzNiAyLjczMTk4IC0wLjA0MDM3OTggMi4yOTE4MyAwLjAyNTgxMTYgMS44NjE4MUMgMC4wOTIwMDMxIDEuNDMxOCAwLjI4MzIwNCAxLjAzMTI2IDAuNTc1MjEzIDAuNzEwODgzQyAwLjg2NzIyMiAwLjM5MDUxIDEuMjQ2OTEgMC4xNjQ3MDggMS42NjYyMiAwLjA2MjA1OTJDIDIuMDg1NTMgLTAuMDQwNTg5NyAyLjUyNTYxIC0wLjAxNTQ3MTQgMi45MzA3NiAwLjEzNDIzNUMgMy4zMzU5MSAwLjI4Mzk0MSAzLjY4NzkyIDAuNTUxNTA1IDMuOTQyMjIgMC45MDMwNkMgNC4xOTY1MiAxLjI1NDYyIDQuMzQxNjkgMS42NzQzNiA0LjM1OTM1IDIuMTA5MTZDIDQuMzgyOTkgMi42OTEwNyA0LjE3Njc4IDMuMjU4NjkgMy43ODU5NyAzLjY4NzQ2QyAzLjM5NTE2IDQuMTE2MjQgMi44NTE2NiA0LjM3MTE2IDIuMjc0NzEgNC4zOTYyOUwgMi4yNzQ3MSA0LjM5NjI5WiIvPgogICAgPC9nPgogIDwvZz4+Cjwvc3ZnPgo=);
  --jp-icon-jupyterlab-wordmark: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMDAiIHZpZXdCb3g9IjAgMCAxODYwLjggNDc1Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjIiIGZpbGw9IiM0RTRFNEUiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDQ4MC4xMzY0MDEsIDY0LjI3MTQ5MykiPgogICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC4wMDAwMDAsIDU4Ljg3NTU2NikiPgogICAgICA8ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgwLjA4NzYwMywgMC4xNDAyOTQpIj4KICAgICAgICA8cGF0aCBkPSJNLTQyNi45LDE2OS44YzAsNDguNy0zLjcsNjQuNy0xMy42LDc2LjRjLTEwLjgsMTAtMjUsMTUuNS0zOS43LDE1LjVsMy43LDI5IGMyMi44LDAuMyw0NC44LTcuOSw2MS45LTIzLjFjMTcuOC0xOC41LDI0LTQ0LjEsMjQtODMuM1YwSC00Mjd2MTcwLjFMLTQyNi45LDE2OS44TC00MjYuOSwxNjkuOHoiLz4KICAgICAgPC9nPgogICAgPC9nPgogICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMTU1LjA0NTI5NiwgNTYuODM3MTA0KSI+CiAgICAgIDxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEuNTYyNDUzLCAxLjc5OTg0MikiPgogICAgICAgIDxwYXRoIGQ9Ik0tMzEyLDE0OGMwLDIxLDAsMzkuNSwxLjcsNTUuNGgtMzEuOGwtMi4xLTMzLjNoLTAuOGMtNi43LDExLjYtMTYuNCwyMS4zLTI4LDI3LjkgYy0xMS42LDYuNi0yNC44LDEwLTM4LjIsOS44Yy0zMS40LDAtNjktMTcuNy02OS04OVYwaDM2LjR2MTEyLjdjMCwzOC43LDExLjYsNjQuNyw0NC42LDY0LjdjMTAuMy0wLjIsMjAuNC0zLjUsMjguOS05LjQgYzguNS01LjksMTUuMS0xNC4zLDE4LjktMjMuOWMyLjItNi4xLDMuMy0xMi41LDMuMy0xOC45VjAuMmgzNi40VjE0OEgtMzEyTC0zMTIsMTQ4eiIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgICA8ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgzOTAuMDEzMzIyLCA1My40Nzk2MzgpIj4KICAgICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMS43MDY0NTgsIDAuMjMxNDI1KSI+CiAgICAgICAgPHBhdGggZD0iTS00NzguNiw3MS40YzAtMjYtMC44LTQ3LTEuNy02Ni43aDMyLjdsMS43LDM0LjhoMC44YzcuMS0xMi41LDE3LjUtMjIuOCwzMC4xLTI5LjcgYzEyLjUtNywyNi43LTEwLjMsNDEtOS44YzQ4LjMsMCw4NC43LDQxLjcsODQuNywxMDMuM2MwLDczLjEtNDMuNywxMDkuMi05MSwxMDkuMmMtMTIuMSwwLjUtMjQuMi0yLjItMzUtNy44IGMtMTAuOC01LjYtMTkuOS0xMy45LTI2LjYtMjQuMmgtMC44VjI5MWgtMzZ2LTIyMEwtNDc4LjYsNzEuNEwtNDc4LjYsNzEuNHogTS00NDIuNiwxMjUuNmMwLjEsNS4xLDAuNiwxMC4xLDEuNywxNS4xIGMzLDEyLjMsOS45LDIzLjMsMTkuOCwzMS4xYzkuOSw3LjgsMjIuMSwxMi4xLDM0LjcsMTIuMWMzOC41LDAsNjAuNy0zMS45LDYwLjctNzguNWMwLTQwLjctMjEuMS03NS42LTU5LjUtNzUuNiBjLTEyLjksMC40LTI1LjMsNS4xLTM1LjMsMTMuNGMtOS45LDguMy0xNi45LDE5LjctMTkuNiwzMi40Yy0xLjUsNC45LTIuMywxMC0yLjUsMTUuMVYxMjUuNkwtNDQyLjYsMTI1LjZMLTQ0Mi42LDEyNS42eiIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgICA8ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSg2MDYuNzQwNzI2LCA1Ni44MzcxMDQpIj4KICAgICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMC43NTEyMjYsIDEuOTg5Mjk5KSI+CiAgICAgICAgPHBhdGggZD0iTS00NDAuOCwwbDQzLjcsMTIwLjFjNC41LDEzLjQsOS41LDI5LjQsMTIuOCw0MS43aDAuOGMzLjctMTIuMiw3LjktMjcuNywxMi44LTQyLjQgbDM5LjctMTE5LjJoMzguNUwtMzQ2LjksMTQ1Yy0yNiw2OS43LTQzLjcsMTA1LjQtNjguNiwxMjcuMmMtMTIuNSwxMS43LTI3LjksMjAtNDQuNiwyMy45bC05LjEtMzEuMSBjMTEuNy0zLjksMjIuNS0xMC4xLDMxLjgtMTguMWMxMy4yLTExLjEsMjMuNy0yNS4yLDMwLjYtNDEuMmMxLjUtMi44LDIuNS01LjcsMi45LTguOGMtMC4zLTMuMy0xLjItNi42LTIuNS05LjdMLTQ4MC4yLDAuMSBoMzkuN0wtNDQwLjgsMEwtNDQwLjgsMHoiLz4KICAgICAgPC9nPgogICAgPC9nPgogICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoODIyLjc0ODEwNCwgMC4wMDAwMDApIj4KICAgICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoMS40NjQwNTAsIDAuMzc4OTE0KSI+CiAgICAgICAgPHBhdGggZD0iTS00MTMuNywwdjU4LjNoNTJ2MjguMmgtNTJWMTk2YzAsMjUsNywzOS41LDI3LjMsMzkuNWM3LjEsMC4xLDE0LjItMC43LDIxLjEtMi41IGwxLjcsMjcuN2MtMTAuMywzLjctMjEuMyw1LjQtMzIuMiw1Yy03LjMsMC40LTE0LjYtMC43LTIxLjMtMy40Yy02LjgtMi43LTEyLjktNi44LTE3LjktMTIuMWMtMTAuMy0xMC45LTE0LjEtMjktMTQuMS01Mi45IFY4Ni41aC0zMVY1OC4zaDMxVjkuNkwtNDEzLjcsMEwtNDEzLjcsMHoiLz4KICAgICAgPC9nPgogICAgPC9nPgogICAgPGcgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoOTc0LjQzMzI4NiwgNTMuNDc5NjM4KSI+CiAgICAgIDxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKDAuOTkwMDM0LCAwLjYxMDMzOSkiPgogICAgICAgIDxwYXRoIGQ9Ik0tNDQ1LjgsMTEzYzAuOCw1MCwzMi4yLDcwLjYsNjguNiw3MC42YzE5LDAuNiwzNy45LTMsNTUuMy0xMC41bDYuMiwyNi40IGMtMjAuOSw4LjktNDMuNSwxMy4xLTY2LjIsMTIuNmMtNjEuNSwwLTk4LjMtNDEuMi05OC4zLTEwMi41Qy00ODAuMiw0OC4yLTQ0NC43LDAtMzg2LjUsMGM2NS4yLDAsODIuNyw1OC4zLDgyLjcsOTUuNyBjLTAuMSw1LjgtMC41LDExLjUtMS4yLDE3LjJoLTE0MC42SC00NDUuOEwtNDQ1LjgsMTEzeiBNLTMzOS4yLDg2LjZjMC40LTIzLjUtOS41LTYwLjEtNTAuNC02MC4xIGMtMzYuOCwwLTUyLjgsMzQuNC01NS43LDYwLjFILTMzOS4yTC0zMzkuMiw4Ni42TC0zMzkuMiw4Ni42eiIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgICA8ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxMjAxLjk2MTA1OCwgNTMuNDc5NjM4KSI+CiAgICAgIDxnIHRyYW5zZm9ybT0idHJhbnNsYXRlKDEuMTc5NjQwLCAwLjcwNTA2OCkiPgogICAgICAgIDxwYXRoIGQ9Ik0tNDc4LjYsNjhjMC0yMy45LTAuNC00NC41LTEuNy02My40aDMxLjhsMS4yLDM5LjloMS43YzkuMS0yNy4zLDMxLTQ0LjUsNTUuMy00NC41IGMzLjUtMC4xLDcsMC40LDEwLjMsMS4ydjM0LjhjLTQuMS0wLjktOC4yLTEuMy0xMi40LTEuMmMtMjUuNiwwLTQzLjcsMTkuNy00OC43LDQ3LjRjLTEsNS43LTEuNiwxMS41LTEuNywxNy4ydjEwOC4zaC0zNlY2OCBMLTQ3OC42LDY4eiIvPgogICAgICA8L2c+CiAgICA8L2c+CiAgPC9nPgoKICA8ZyBjbGFzcz0ianAtaWNvbi13YXJuMCIgZmlsbD0iI0YzNzcyNiI+CiAgICA8cGF0aCBkPSJNMTM1Mi4zLDMyNi4yaDM3VjI4aC0zN1YzMjYuMnogTTE2MDQuOCwzMjYuMmMtMi41LTEzLjktMy40LTMxLjEtMy40LTQ4Ljd2LTc2IGMwLTQwLjctMTUuMS04My4xLTc3LjMtODMuMWMtMjUuNiwwLTUwLDcuMS02Ni44LDE4LjFsOC40LDI0LjRjMTQuMy05LjIsMzQtMTUuMSw1My0xNS4xYzQxLjYsMCw0Ni4yLDMwLjIsNDYuMiw0N3Y0LjIgYy03OC42LTAuNC0xMjIuMywyNi41LTEyMi4zLDc1LjZjMCwyOS40LDIxLDU4LjQsNjIuMiw1OC40YzI5LDAsNTAuOS0xNC4zLDYyLjItMzAuMmgxLjNsMi45LDI1LjZIMTYwNC44eiBNMTU2NS43LDI1Ny43IGMwLDMuOC0wLjgsOC0yLjEsMTEuOGMtNS45LDE3LjItMjIuNywzNC00OS4yLDM0Yy0xOC45LDAtMzQuOS0xMS4zLTM0LjktMzUuM2MwLTM5LjUsNDUuOC00Ni42LDg2LjItNDUuOFYyNTcuN3ogTTE2OTguNSwzMjYuMiBsMS43LTMzLjZoMS4zYzE1LjEsMjYuOSwzOC43LDM4LjIsNjguMSwzOC4yYzQ1LjQsMCw5MS4yLTM2LjEsOTEuMi0xMDguOGMwLjQtNjEuNy0zNS4zLTEwMy43LTg1LjctMTAzLjcgYy0zMi44LDAtNTYuMywxNC43LTY5LjMsMzcuNGgtMC44VjI4aC0zNi42djI0NS43YzAsMTguMS0wLjgsMzguNi0xLjcsNTIuNUgxNjk4LjV6IE0xNzA0LjgsMjA4LjJjMC01LjksMS4zLTEwLjksMi4xLTE1LjEgYzcuNi0yOC4xLDMxLjEtNDUuNCw1Ni4zLTQ1LjRjMzkuNSwwLDYwLjUsMzQuOSw2MC41LDc1LjZjMCw0Ni42LTIzLjEsNzguMS02MS44LDc4LjFjLTI2LjksMC00OC4zLTE3LjYtNTUuNS00My4zIGMtMC44LTQuMi0xLjctOC44LTEuNy0xMy40VjIwOC4yeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-kernel: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uMiIgZmlsbD0iIzYxNjE2MSIgZD0iTTE1IDlIOXY2aDZWOXptLTIgNGgtMnYtMmgydjJ6bTgtMlY5aC0yVjdjMC0xLjEtLjktMi0yLTJoLTJWM2gtMnYyaC0yVjNIOXYySDdjLTEuMSAwLTIgLjktMiAydjJIM3YyaDJ2MkgzdjJoMnYyYzAgMS4xLjkgMiAyIDJoMnYyaDJ2LTJoMnYyaDJ2LTJoMmMxLjEgMCAyLS45IDItMnYtMmgydi0yaC0ydi0yaDJ6bS00IDZIN1Y3aDEwdjEweiIvPgo8L3N2Zz4K);
  --jp-icon-keyboard: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMjAgNUg0Yy0xLjEgMC0xLjk5LjktMS45OSAyTDIgMTdjMCAxLjEuOSAyIDIgMmgxNmMxLjEgMCAyLS45IDItMlY3YzAtMS4xLS45LTItMi0yem0tOSAzaDJ2MmgtMlY4em0wIDNoMnYyaC0ydi0yek04IDhoMnYySDhWOHptMCAzaDJ2Mkg4di0yem0tMSAySDV2LTJoMnYyem0wLTNINVY4aDJ2MnptOSA3SDh2LTJoOHYyem0wLTRoLTJ2LTJoMnYyem0wLTNoLTJWOGgydjJ6bTMgM2gtMnYtMmgydjJ6bTAtM2gtMlY4aDJ2MnoiLz4KPC9zdmc+Cg==);
  --jp-icon-launcher: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMTkgMTlINVY1aDdWM0g1YTIgMiAwIDAwLTIgMnYxNGEyIDIgMCAwMDIgMmgxNGMxLjEgMCAyLS45IDItMnYtN2gtMnY3ek0xNCAzdjJoMy41OWwtOS44MyA5LjgzIDEuNDEgMS40MUwxOSA2LjQxVjEwaDJWM2gtN3oiLz4KPC9zdmc+Cg==);
  --jp-icon-line-form: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICAgIDxwYXRoIGZpbGw9IndoaXRlIiBkPSJNNS44OCA0LjEyTDEzLjc2IDEybC03Ljg4IDcuODhMOCAyMmwxMC0xMEw4IDJ6Ii8+Cjwvc3ZnPgo=);
  --jp-icon-link: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTMuOSAxMmMwLTEuNzEgMS4zOS0zLjEgMy4xLTMuMWg0VjdIN2MtMi43NiAwLTUgMi4yNC01IDVzMi4yNCA1IDUgNWg0di0xLjlIN2MtMS43MSAwLTMuMS0xLjM5LTMuMS0zLjF6TTggMTNoOHYtMkg4djJ6bTktNmgtNHYxLjloNGMxLjcxIDAgMy4xIDEuMzkgMy4xIDMuMXMtMS4zOSAzLjEtMy4xIDMuMWgtNFYxN2g0YzIuNzYgMCA1LTIuMjQgNS01cy0yLjI0LTUtNS01eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-list: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uMiBqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiM2MTYxNjEiIGQ9Ik0xOSA1djE0SDVWNWgxNG0xLjEtMkgzLjljLS41IDAtLjkuNC0uOS45djE2LjJjMCAuNC40LjkuOS45aDE2LjJjLjQgMCAuOS0uNS45LS45VjMuOWMwLS41LS41LS45LS45LS45ek0xMSA3aDZ2MmgtNlY3em0wIDRoNnYyaC02di0yem0wIDRoNnYyaC02ek03IDdoMnYySDd6bTAgNGgydjJIN3ptMCA0aDJ2Mkg3eiIvPgo8L3N2Zz4=);
  --jp-icon-listings-info: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pg0KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJDYXBhXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgNTAuOTc4IDUwLjk3OCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgNTAuOTc4IDUwLjk3ODsiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPGc+DQoJPGc+DQoJCTxnPg0KCQkJPHBhdGggc3R5bGU9ImZpbGw6IzAxMDAwMjsiIGQ9Ik00My41Miw3LjQ1OEMzOC43MTEsMi42NDgsMzIuMzA3LDAsMjUuNDg5LDBDMTguNjcsMCwxMi4yNjYsMi42NDgsNy40NTgsNy40NTgNCgkJCQljLTkuOTQzLDkuOTQxLTkuOTQzLDI2LjExOSwwLDM2LjA2MmM0LjgwOSw0LjgwOSwxMS4yMTIsNy40NTYsMTguMDMxLDcuNDU4YzAsMCwwLjAwMSwwLDAuMDAyLDANCgkJCQljNi44MTYsMCwxMy4yMjEtMi42NDgsMTguMDI5LTcuNDU4YzQuODA5LTQuODA5LDcuNDU3LTExLjIxMiw3LjQ1Ny0xOC4wM0M1MC45NzcsMTguNjcsNDguMzI4LDEyLjI2Niw0My41Miw3LjQ1OHoNCgkJCQkgTTQyLjEwNiw0Mi4xMDVjLTQuNDMyLDQuNDMxLTEwLjMzMiw2Ljg3Mi0xNi42MTUsNi44NzJoLTAuMDAyYy02LjI4NS0wLjAwMS0xMi4xODctMi40NDEtMTYuNjE3LTYuODcyDQoJCQkJYy05LjE2Mi05LjE2My05LjE2Mi0yNC4wNzEsMC0zMy4yMzNDMTMuMzAzLDQuNDQsMTkuMjA0LDIsMjUuNDg5LDJjNi4yODQsMCwxMi4xODYsMi40NCwxNi42MTcsNi44NzINCgkJCQljNC40MzEsNC40MzEsNi44NzEsMTAuMzMyLDYuODcxLDE2LjYxN0M0OC45NzcsMzEuNzcyLDQ2LjUzNiwzNy42NzUsNDIuMTA2LDQyLjEwNXoiLz4NCgkJPC9nPg0KCQk8Zz4NCgkJCTxwYXRoIHN0eWxlPSJmaWxsOiMwMTAwMDI7IiBkPSJNMjMuNTc4LDMyLjIxOGMtMC4wMjMtMS43MzQsMC4xNDMtMy4wNTksMC40OTYtMy45NzJjMC4zNTMtMC45MTMsMS4xMS0xLjk5NywyLjI3Mi0zLjI1Mw0KCQkJCWMwLjQ2OC0wLjUzNiwwLjkyMy0xLjA2MiwxLjM2Ny0xLjU3NWMwLjYyNi0wLjc1MywxLjEwNC0xLjQ3OCwxLjQzNi0yLjE3NWMwLjMzMS0wLjcwNywwLjQ5NS0xLjU0MSwwLjQ5NS0yLjUNCgkJCQljMC0xLjA5Ni0wLjI2LTIuMDg4LTAuNzc5LTIuOTc5Yy0wLjU2NS0wLjg3OS0xLjUwMS0xLjMzNi0yLjgwNi0xLjM2OWMtMS44MDIsMC4wNTctMi45ODUsMC42NjctMy41NSwxLjgzMg0KCQkJCWMtMC4zMDEsMC41MzUtMC41MDMsMS4xNDEtMC42MDcsMS44MTRjLTAuMTM5LDAuNzA3LTAuMjA3LDEuNDMyLTAuMjA3LDIuMTc0aC0yLjkzN2MtMC4wOTEtMi4yMDgsMC40MDctNC4xMTQsMS40OTMtNS43MTkNCgkJCQljMS4wNjItMS42NCwyLjg1NS0yLjQ4MSw1LjM3OC0yLjUyN2MyLjE2LDAuMDIzLDMuODc0LDAuNjA4LDUuMTQxLDEuNzU4YzEuMjc4LDEuMTYsMS45MjksMi43NjQsMS45NSw0LjgxMQ0KCQkJCWMwLDEuMTQyLTAuMTM3LDIuMTExLTAuNDEsMi45MTFjLTAuMzA5LDAuODQ1LTAuNzMxLDEuNTkzLTEuMjY4LDIuMjQzYy0wLjQ5MiwwLjY1LTEuMDY4LDEuMzE4LTEuNzMsMi4wMDINCgkJCQljLTAuNjUsMC42OTctMS4zMTMsMS40NzktMS45ODcsMi4zNDZjLTAuMjM5LDAuMzc3LTAuNDI5LDAuNzc3LTAuNTY1LDEuMTk5Yy0wLjE2LDAuOTU5LTAuMjE3LDEuOTUxLTAuMTcxLDIuOTc5DQoJCQkJQzI2LjU4OSwzMi4yMTgsMjMuNTc4LDMyLjIxOCwyMy41NzgsMzIuMjE4eiBNMjMuNTc4LDM4LjIydi0zLjQ4NGgzLjA3NnYzLjQ4NEgyMy41Nzh6Ii8+DQoJCTwvZz4NCgk8L2c+DQo8L2c+DQo8Zz4NCjwvZz4NCjxnPg0KPC9nPg0KPGc+DQo8L2c+DQo8Zz4NCjwvZz4NCjxnPg0KPC9nPg0KPGc+DQo8L2c+DQo8Zz4NCjwvZz4NCjxnPg0KPC9nPg0KPGc+DQo8L2c+DQo8Zz4NCjwvZz4NCjxnPg0KPC9nPg0KPGc+DQo8L2c+DQo8Zz4NCjwvZz4NCjxnPg0KPC9nPg0KPGc+DQo8L2c+DQo8L3N2Zz4NCg==);
  --jp-icon-markdown: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8cGF0aCBjbGFzcz0ianAtaWNvbi1jb250cmFzdDAganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjN0IxRkEyIiBkPSJNNSAxNC45aDEybC02LjEgNnptOS40LTYuOGMwLTEuMy0uMS0yLjktLjEtNC41LS40IDEuNC0uOSAyLjktMS4zIDQuM2wtMS4zIDQuM2gtMkw4LjUgNy45Yy0uNC0xLjMtLjctMi45LTEtNC4zLS4xIDEuNi0uMSAzLjItLjIgNC42TDcgMTIuNEg0LjhsLjctMTFoMy4zTDEwIDVjLjQgMS4yLjcgMi43IDEgMy45LjMtMS4yLjctMi42IDEtMy45bDEuMi0zLjdoMy4zbC42IDExaC0yLjRsLS4zLTQuMnoiLz4KPC9zdmc+Cg==);
  --jp-icon-new-folder: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTIwIDZoLThsLTItMkg0Yy0xLjExIDAtMS45OS44OS0xLjk5IDJMMiAxOGMwIDEuMTEuODkgMiAyIDJoMTZjMS4xMSAwIDItLjg5IDItMlY4YzAtMS4xMS0uODktMi0yLTJ6bS0xIDhoLTN2M2gtMnYtM2gtM3YtMmgzVjloMnYzaDN2MnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-not-trusted: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI1IDI1Ij4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uMiIgc3Ryb2tlPSIjMzMzMzMzIiBzdHJva2Utd2lkdGg9IjIiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDMgMykiIGQ9Ik0xLjg2MDk0IDExLjQ0MDlDMC44MjY0NDggOC43NzAyNyAwLjg2Mzc3OSA2LjA1NzY0IDEuMjQ5MDcgNC4xOTkzMkMyLjQ4MjA2IDMuOTMzNDcgNC4wODA2OCAzLjQwMzQ3IDUuNjAxMDIgMi44NDQ5QzcuMjM1NDkgMi4yNDQ0IDguODU2NjYgMS41ODE1IDkuOTg3NiAxLjA5NTM5QzExLjA1OTcgMS41ODM0MSAxMi42MDk0IDIuMjQ0NCAxNC4yMTggMi44NDMzOUMxNS43NTAzIDMuNDEzOTQgMTcuMzk5NSAzLjk1MjU4IDE4Ljc1MzkgNC4yMTM4NUMxOS4xMzY0IDYuMDcxNzcgMTkuMTcwOSA4Ljc3NzIyIDE4LjEzOSAxMS40NDA5QzE3LjAzMDMgMTQuMzAzMiAxNC42NjY4IDE3LjE4NDQgOS45OTk5OSAxOC45MzU0QzUuMzMzMTkgMTcuMTg0NCAyLjk2OTY4IDE0LjMwMzIgMS44NjA5NCAxMS40NDA5WiIvPgogICAgPHBhdGggY2xhc3M9ImpwLWljb24yIiBzdHJva2U9IiMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoOS4zMTU5MiA5LjMyMDMxKSIgZD0iTTcuMzY4NDIgMEwwIDcuMzY0NzkiLz4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uMiIgc3Ryb2tlPSIjMzMzMzMzIiBzdHJva2Utd2lkdGg9IjIiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDkuMzE1OTIgMTYuNjgzNikgc2NhbGUoMSAtMSkiIGQ9Ik03LjM2ODQyIDBMMCA3LjM2NDc5Ii8+Cjwvc3ZnPgo=);
  --jp-icon-notebook: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8ZyBjbGFzcz0ianAtaWNvbi13YXJuMCBqcC1pY29uLXNlbGVjdGFibGUiIGZpbGw9IiNFRjZDMDAiPgogICAgPHBhdGggZD0iTTE4LjcgMy4zdjE1LjRIMy4zVjMuM2gxNS40bTEuNS0xLjVIMS44djE4LjNoMTguM2wuMS0xOC4zeiIvPgogICAgPHBhdGggZD0iTTE2LjUgMTYuNWwtNS40LTQuMy01LjYgNC4zdi0xMWgxMXoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-numbering: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjIiIGhlaWdodD0iMjIiIHZpZXdCb3g9IjAgMCAyOCAyOCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CgkJPHBhdGggZD0iTTQgMTlINlYxOS41SDVWMjAuNUg2VjIxSDRWMjJIN1YxOEg0VjE5Wk01IDEwSDZWNkg0VjdINVYxMFpNNCAxM0g1LjhMNCAxNS4xVjE2SDdWMTVINS4yTDcgMTIuOVYxMkg0VjEzWk05IDdWOUgyM1Y3SDlaTTkgMjFIMjNWMTlIOVYyMVpNOSAxNUgyM1YxM0g5VjE1WiIvPgoJPC9nPgo8L3N2Zz4K);
  --jp-icon-offline-bolt: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjE2Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEyIDIuMDJjLTUuNTEgMC05Ljk4IDQuNDctOS45OCA5Ljk4czQuNDcgOS45OCA5Ljk4IDkuOTggOS45OC00LjQ3IDkuOTgtOS45OFMxNy41MSAyLjAyIDEyIDIuMDJ6TTExLjQ4IDIwdi02LjI2SDhMMTMgNHY2LjI2aDMuMzVMMTEuNDggMjB6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-palette: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTE4IDEzVjIwSDRWNkg5LjAyQzkuMDcgNS4yOSA5LjI0IDQuNjIgOS41IDRINEMyLjkgNCAyIDQuOSAyIDZWMjBDMiAyMS4xIDIuOSAyMiA0IDIySDE4QzE5LjEgMjIgMjAgMjEuMSAyMCAyMFYxNUwxOCAxM1pNMTkuMyA4Ljg5QzE5Ljc0IDguMTkgMjAgNy4zOCAyMCA2LjVDMjAgNC4wMSAxNy45OSAyIDE1LjUgMkMxMy4wMSAyIDExIDQuMDEgMTEgNi41QzExIDguOTkgMTMuMDEgMTEgMTUuNDkgMTFDMTYuMzcgMTEgMTcuMTkgMTAuNzQgMTcuODggMTAuM0wyMSAxMy40MkwyMi40MiAxMkwxOS4zIDguODlaTTE1LjUgOUMxNC4xMiA5IDEzIDcuODggMTMgNi41QzEzIDUuMTIgMTQuMTIgNCAxNS41IDRDMTYuODggNCAxOCA1LjEyIDE4IDYuNUMxOCA3Ljg4IDE2Ljg4IDkgMTUuNSA5WiIvPgogICAgPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik00IDZIOS4wMTg5NEM5LjAwNjM5IDYuMTY1MDIgOSA2LjMzMTc2IDkgNi41QzkgOC44MTU3NyAxMC4yMTEgMTAuODQ4NyAxMi4wMzQzIDEySDlWMTRIMTZWMTIuOTgxMUMxNi41NzAzIDEyLjkzNzcgMTcuMTIgMTIuODIwNyAxNy42Mzk2IDEyLjYzOTZMMTggMTNWMjBINFY2Wk04IDhINlYxMEg4VjhaTTYgMTJIOFYxNEg2VjEyWk04IDE2SDZWMThIOFYxNlpNOSAxNkgxNlYxOEg5VjE2WiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-paste: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTE5IDJoLTQuMThDMTQuNC44NCAxMy4zIDAgMTIgMGMtMS4zIDAtMi40Ljg0LTIuODIgMkg1Yy0xLjEgMC0yIC45LTIgMnYxNmMwIDEuMS45IDIgMiAyaDE0YzEuMSAwIDItLjkgMi0yVjRjMC0xLjEtLjktMi0yLTJ6bS03IDBjLjU1IDAgMSAuNDUgMSAxcy0uNDUgMS0xIDEtMS0uNDUtMS0xIC40NS0xIDEtMXptNyAxOEg1VjRoMnYzaDEwVjRoMnYxNnoiLz4KICAgIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-pdf: url(data:image/svg+xml;base64,PHN2ZwogICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyMiAyMiIgd2lkdGg9IjE2Ij4KICAgIDxwYXRoIHRyYW5zZm9ybT0icm90YXRlKDQ1KSIgY2xhc3M9ImpwLWljb24tc2VsZWN0YWJsZSIgZmlsbD0iI0ZGMkEyQSIKICAgICAgIGQ9Im0gMjIuMzQ0MzY5LC0zLjAxNjM2NDIgaCA1LjYzODYwNCB2IDEuNTc5MjQzMyBoIC0zLjU0OTIyNyB2IDEuNTA4NjkyOTkgaCAzLjMzNzU3NiBWIDEuNjUwODE1NCBoIC0zLjMzNzU3NiB2IDMuNDM1MjYxMyBoIC0yLjA4OTM3NyB6IG0gLTcuMTM2NDQ0LDEuNTc5MjQzMyB2IDQuOTQzOTU0MyBoIDAuNzQ4OTIgcSAxLjI4MDc2MSwwIDEuOTUzNzAzLC0wLjYzNDk1MzUgMC42NzgzNjksLTAuNjM0OTUzNSAwLjY3ODM2OSwtMS44NDUxNjQxIDAsLTEuMjA0NzgzNTUgLTAuNjcyOTQyLC0xLjgzNDMxMDExIC0wLjY3Mjk0MiwtMC42Mjk1MjY1OSAtMS45NTkxMywtMC42Mjk1MjY1OSB6IG0gLTIuMDg5Mzc3LC0xLjU3OTI0MzMgaCAyLjIwMzM0MyBxIDEuODQ1MTY0LDAgMi43NDYwMzksMC4yNjU5MjA3IDAuOTA2MzAxLDAuMjYwNDkzNyAxLjU1MjEwOCwwLjg5MDAyMDMgMC41Njk4MywwLjU0ODEyMjMgMC44NDY2MDUsMS4yNjQ0ODAwNiAwLjI3Njc3NCwwLjcxNjM1NzgxIDAuMjc2Nzc0LDEuNjIyNjU4OTQgMCwwLjkxNzE1NTEgLTAuMjc2Nzc0LDEuNjM4OTM5OSAtMC4yNzY3NzUsMC43MTYzNTc4IC0wLjg0NjYwNSwxLjI2NDQ4IC0wLjY1MTIzNCwwLjYyOTUyNjYgLTEuNTYyOTYyLDAuODk1NDQ3MyAtMC45MTE3MjgsMC4yNjA0OTM3IC0yLjczNTE4NSwwLjI2MDQ5MzcgaCAtMi4yMDMzNDMgeiBtIC04LjE0NTg1NjUsMCBoIDMuNDY3ODIzIHEgMS41NDY2ODE2LDAgMi4zNzE1Nzg1LDAuNjg5MjIzIDAuODMwMzI0LDAuNjgzNzk2MSAwLjgzMDMyNCwxLjk1MzcwMzE0IDAsMS4yNzUzMzM5NyAtMC44MzAzMjQsMS45NjQ1NTcwNiBRIDkuOTg3MTk2MSwyLjI3NDkxNSA4LjQ0MDUxNDUsMi4yNzQ5MTUgSCA3LjA2MjA2ODQgViA1LjA4NjA3NjcgSCA0Ljk3MjY5MTUgWiBtIDIuMDg5Mzc2OSwxLjUxNDExOTkgdiAyLjI2MzAzOTQzIGggMS4xNTU5NDEgcSAwLjYwNzgxODgsMCAwLjkzODg2MjksLTAuMjkzMDU1NDcgMC4zMzEwNDQxLC0wLjI5ODQ4MjQxIDAuMzMxMDQ0MSwtMC44NDExNzc3MiAwLC0wLjU0MjY5NTMxIC0wLjMzMTA0NDEsLTAuODM1NzUwNzQgLTAuMzMxMDQ0MSwtMC4yOTMwNTU1IC0wLjkzODg2MjksLTAuMjkzMDU1NSB6IgovPgo8L3N2Zz4K);
  --jp-icon-python: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8ZyBjbGFzcz0ianAtaWNvbi1icmFuZDAganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjMEQ0N0ExIj4KICAgIDxwYXRoIGQ9Ik0xMS4xIDYuOVY1LjhINi45YzAtLjUgMC0xLjMuMi0xLjYuNC0uNy44LTEuMSAxLjctMS40IDEuNy0uMyAyLjUtLjMgMy45LS4xIDEgLjEgMS45LjkgMS45IDEuOXY0LjJjMCAuNS0uOSAxLjYtMiAxLjZIOC44Yy0xLjUgMC0yLjQgMS40LTIuNCAyLjh2Mi4ySDQuN0MzLjUgMTUuMSAzIDE0IDMgMTMuMVY5Yy0uMS0xIC42LTIgMS44LTIgMS41LS4xIDYuMy0uMSA2LjMtLjF6Ii8+CiAgICA8cGF0aCBkPSJNMTAuOSAxNS4xdjEuMWg0LjJjMCAuNSAwIDEuMy0uMiAxLjYtLjQuNy0uOCAxLjEtMS43IDEuNC0xLjcuMy0yLjUuMy0zLjkuMS0xLS4xLTEuOS0uOS0xLjktMS45di00LjJjMC0uNS45LTEuNiAyLTEuNmgzLjhjMS41IDAgMi40LTEuNCAyLjQtMi44VjYuNmgxLjdDMTguNSA2LjkgMTkgOCAxOSA4LjlWMTNjMCAxLS43IDIuMS0xLjkgMi4xaC02LjJ6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-r-kernel: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8cGF0aCBjbGFzcz0ianAtaWNvbi1jb250cmFzdDMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjMjE5NkYzIiBkPSJNNC40IDIuNWMxLjItLjEgMi45LS4zIDQuOS0uMyAyLjUgMCA0LjEuNCA1LjIgMS4zIDEgLjcgMS41IDEuOSAxLjUgMy41IDAgMi0xLjQgMy41LTIuOSA0LjEgMS4yLjQgMS43IDEuNiAyLjIgMyAuNiAxLjkgMSAzLjkgMS4zIDQuNmgtMy44Yy0uMy0uNC0uOC0xLjctMS4yLTMuN3MtMS4yLTIuNi0yLjYtMi42aC0uOXY2LjRINC40VjIuNXptMy43IDYuOWgxLjRjMS45IDAgMi45LS45IDIuOS0yLjNzLTEtMi4zLTIuOC0yLjNjLS43IDAtMS4zIDAtMS42LjJ2NC41aC4xdi0uMXoiLz4KPC9zdmc+Cg==);
  --jp-icon-react: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMTUwIDE1MCA1NDEuOSAyOTUuMyI+CiAgPGcgY2xhc3M9ImpwLWljb24tYnJhbmQyIGpwLWljb24tc2VsZWN0YWJsZSIgZmlsbD0iIzYxREFGQiI+CiAgICA8cGF0aCBkPSJNNjY2LjMgMjk2LjVjMC0zMi41LTQwLjctNjMuMy0xMDMuMS04Mi40IDE0LjQtNjMuNiA4LTExNC4yLTIwLjItMTMwLjQtNi41LTMuOC0xNC4xLTUuNi0yMi40LTUuNnYyMi4zYzQuNiAwIDguMy45IDExLjQgMi42IDEzLjYgNy44IDE5LjUgMzcuNSAxNC45IDc1LjctMS4xIDkuNC0yLjkgMTkuMy01LjEgMjkuNC0xOS42LTQuOC00MS04LjUtNjMuNS0xMC45LTEzLjUtMTguNS0yNy41LTM1LjMtNDEuNi01MCAzMi42LTMwLjMgNjMuMi00Ni45IDg0LTQ2LjlWNzhjLTI3LjUgMC02My41IDE5LjYtOTkuOSA1My42LTM2LjQtMzMuOC03Mi40LTUzLjItOTkuOS01My4ydjIyLjNjMjAuNyAwIDUxLjQgMTYuNSA4NCA0Ni42LTE0IDE0LjctMjggMzEuNC00MS4zIDQ5LjktMjIuNiAyLjQtNDQgNi4xLTYzLjYgMTEtMi4zLTEwLTQtMTkuNy01LjItMjktNC43LTM4LjIgMS4xLTY3LjkgMTQuNi03NS44IDMtMS44IDYuOS0yLjYgMTEuNS0yLjZWNzguNWMtOC40IDAtMTYgMS44LTIyLjYgNS42LTI4LjEgMTYuMi0zNC40IDY2LjctMTkuOSAxMzAuMS02Mi4yIDE5LjItMTAyLjcgNDkuOS0xMDIuNyA4Mi4zIDAgMzIuNSA0MC43IDYzLjMgMTAzLjEgODIuNC0xNC40IDYzLjYtOCAxMTQuMiAyMC4yIDEzMC40IDYuNSAzLjggMTQuMSA1LjYgMjIuNSA1LjYgMjcuNSAwIDYzLjUtMTkuNiA5OS45LTUzLjYgMzYuNCAzMy44IDcyLjQgNTMuMiA5OS45IDUzLjIgOC40IDAgMTYtMS44IDIyLjYtNS42IDI4LjEtMTYuMiAzNC40LTY2LjcgMTkuOS0xMzAuMSA2Mi0xOS4xIDEwMi41LTQ5LjkgMTAyLjUtODIuM3ptLTEzMC4yLTY2LjdjLTMuNyAxMi45LTguMyAyNi4yLTEzLjUgMzkuNS00LjEtOC04LjQtMTYtMTMuMS0yNC00LjYtOC05LjUtMTUuOC0xNC40LTIzLjQgMTQuMiAyLjEgMjcuOSA0LjcgNDEgNy45em0tNDUuOCAxMDYuNWMtNy44IDEzLjUtMTUuOCAyNi4zLTI0LjEgMzguMi0xNC45IDEuMy0zMCAyLTQ1LjIgMi0xNS4xIDAtMzAuMi0uNy00NS0xLjktOC4zLTExLjktMTYuNC0yNC42LTI0LjItMzgtNy42LTEzLjEtMTQuNS0yNi40LTIwLjgtMzkuOCA2LjItMTMuNCAxMy4yLTI2LjggMjAuNy0zOS45IDcuOC0xMy41IDE1LjgtMjYuMyAyNC4xLTM4LjIgMTQuOS0xLjMgMzAtMiA0NS4yLTIgMTUuMSAwIDMwLjIuNyA0NSAxLjkgOC4zIDExLjkgMTYuNCAyNC42IDI0LjIgMzggNy42IDEzLjEgMTQuNSAyNi40IDIwLjggMzkuOC02LjMgMTMuNC0xMy4yIDI2LjgtMjAuNyAzOS45em0zMi4zLTEzYzUuNCAxMy40IDEwIDI2LjggMTMuOCAzOS44LTEzLjEgMy4yLTI2LjkgNS45LTQxLjIgOCA0LjktNy43IDkuOC0xNS42IDE0LjQtMjMuNyA0LjYtOCA4LjktMTYuMSAxMy0yNC4xek00MjEuMiA0MzBjLTkuMy05LjYtMTguNi0yMC4zLTI3LjgtMzIgOSAuNCAxOC4yLjcgMjcuNS43IDkuNCAwIDE4LjctLjIgMjcuOC0uNy05IDExLjctMTguMyAyMi40LTI3LjUgMzJ6bS03NC40LTU4LjljLTE0LjItMi4xLTI3LjktNC43LTQxLTcuOSAzLjctMTIuOSA4LjMtMjYuMiAxMy41LTM5LjUgNC4xIDggOC40IDE2IDEzLjEgMjQgNC43IDggOS41IDE1LjggMTQuNCAyMy40ek00MjAuNyAxNjNjOS4zIDkuNiAxOC42IDIwLjMgMjcuOCAzMi05LS40LTE4LjItLjctMjcuNS0uNy05LjQgMC0xOC43LjItMjcuOC43IDktMTEuNyAxOC4zLTIyLjQgMjcuNS0zMnptLTc0IDU4LjljLTQuOSA3LjctOS44IDE1LjYtMTQuNCAyMy43LTQuNiA4LTguOSAxNi0xMyAyNC01LjQtMTMuNC0xMC0yNi44LTEzLjgtMzkuOCAxMy4xLTMuMSAyNi45LTUuOCA0MS4yLTcuOXptLTkwLjUgMTI1LjJjLTM1LjQtMTUuMS01OC4zLTM0LjktNTguMy01MC42IDAtMTUuNyAyMi45LTM1LjYgNTguMy01MC42IDguNi0zLjcgMTgtNyAyNy43LTEwLjEgNS43IDE5LjYgMTMuMiA0MCAyMi41IDYwLjktOS4yIDIwLjgtMTYuNiA0MS4xLTIyLjIgNjAuNi05LjktMy4xLTE5LjMtNi41LTI4LTEwLjJ6TTMxMCA0OTBjLTEzLjYtNy44LTE5LjUtMzcuNS0xNC45LTc1LjcgMS4xLTkuNCAyLjktMTkuMyA1LjEtMjkuNCAxOS42IDQuOCA0MSA4LjUgNjMuNSAxMC45IDEzLjUgMTguNSAyNy41IDM1LjMgNDEuNiA1MC0zMi42IDMwLjMtNjMuMiA0Ni45LTg0IDQ2LjktNC41LS4xLTguMy0xLTExLjMtMi43em0yMzcuMi03Ni4yYzQuNyAzOC4yLTEuMSA2Ny45LTE0LjYgNzUuOC0zIDEuOC02LjkgMi42LTExLjUgMi42LTIwLjcgMC01MS40LTE2LjUtODQtNDYuNiAxNC0xNC43IDI4LTMxLjQgNDEuMy00OS45IDIyLjYtMi40IDQ0LTYuMSA2My42LTExIDIuMyAxMC4xIDQuMSAxOS44IDUuMiAyOS4xem0zOC41LTY2LjdjLTguNiAzLjctMTggNy0yNy43IDEwLjEtNS43LTE5LjYtMTMuMi00MC0yMi41LTYwLjkgOS4yLTIwLjggMTYuNi00MS4xIDIyLjItNjAuNiA5LjkgMy4xIDE5LjMgNi41IDI4LjEgMTAuMiAzNS40IDE1LjEgNTguMyAzNC45IDU4LjMgNTAuNi0uMSAxNS43LTIzIDM1LjYtNTguNCA1MC42ek0zMjAuOCA3OC40eiIvPgogICAgPGNpcmNsZSBjeD0iNDIwLjkiIGN5PSIyOTYuNSIgcj0iNDUuNyIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-redo: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgd2lkdGg9IjE2Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgICA8cGF0aCBkPSJNMCAwaDI0djI0SDB6IiBmaWxsPSJub25lIi8+PHBhdGggZD0iTTE4LjQgMTAuNkMxNi41NSA4Ljk5IDE0LjE1IDggMTEuNSA4Yy00LjY1IDAtOC41OCAzLjAzLTkuOTYgNy4yMkwzLjkgMTZjMS4wNS0zLjE5IDQuMDUtNS41IDcuNi01LjUgMS45NSAwIDMuNzMuNzIgNS4xMiAxLjg4TDEzIDE2aDlWN2wtMy42IDMuNnoiLz4KICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-refresh: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDE4IDE4Ij4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTkgMTMuNWMtMi40OSAwLTQuNS0yLjAxLTQuNS00LjVTNi41MSA0LjUgOSA0LjVjMS4yNCAwIDIuMzYuNTIgMy4xNyAxLjMzTDEwIDhoNVYzbC0xLjc2IDEuNzZDMTIuMTUgMy42OCAxMC42NiAzIDkgMyA1LjY5IDMgMy4wMSA1LjY5IDMuMDEgOVM1LjY5IDE1IDkgMTVjMi45NyAwIDUuNDMtMi4xNiA1LjktNWgtMS41MmMtLjQ2IDItMi4yNCAzLjUtNC4zOCAzLjV6Ii8+CiAgICA8L2c+Cjwvc3ZnPgo=);
  --jp-icon-regex: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8ZyBjbGFzcz0ianAtaWNvbjIiIGZpbGw9IiM0MTQxNDEiPgogICAgPHJlY3QgeD0iMiIgeT0iMiIgd2lkdGg9IjE2IiBoZWlnaHQ9IjE2Ii8+CiAgPC9nPgoKICA8ZyBjbGFzcz0ianAtaWNvbi1hY2NlbnQyIiBmaWxsPSIjRkZGIj4KICAgIDxjaXJjbGUgY2xhc3M9InN0MiIgY3g9IjUuNSIgY3k9IjE0LjUiIHI9IjEuNSIvPgogICAgPHJlY3QgeD0iMTIiIHk9IjQiIGNsYXNzPSJzdDIiIHdpZHRoPSIxIiBoZWlnaHQ9IjgiLz4KICAgIDxyZWN0IHg9IjguNSIgeT0iNy41IiB0cmFuc2Zvcm09Im1hdHJpeCgwLjg2NiAtMC41IDAuNSAwLjg2NiAtMi4zMjU1IDcuMzIxOSkiIGNsYXNzPSJzdDIiIHdpZHRoPSI4IiBoZWlnaHQ9IjEiLz4KICAgIDxyZWN0IHg9IjEyIiB5PSI0IiB0cmFuc2Zvcm09Im1hdHJpeCgwLjUgLTAuODY2IDAuODY2IDAuNSAtMC42Nzc5IDE0LjgyNTIpIiBjbGFzcz0ic3QyIiB3aWR0aD0iMSIgaGVpZ2h0PSI4Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-run: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTggNXYxNGwxMS03eiIvPgogICAgPC9nPgo8L3N2Zz4K);
  --jp-icon-running: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDUxMiA1MTIiPgogIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICA8cGF0aCBkPSJNMjU2IDhDMTE5IDggOCAxMTkgOCAyNTZzMTExIDI0OCAyNDggMjQ4IDI0OC0xMTEgMjQ4LTI0OFMzOTMgOCAyNTYgOHptOTYgMzI4YzAgOC44LTcuMiAxNi0xNiAxNkgxNzZjLTguOCAwLTE2LTcuMi0xNi0xNlYxNzZjMC04LjggNy4yLTE2IDE2LTE2aDE2MGM4LjggMCAxNiA3LjIgMTYgMTZ2MTYweiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-save: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTE3IDNINWMtMS4xMSAwLTIgLjktMiAydjE0YzAgMS4xLjg5IDIgMiAyaDE0YzEuMSAwIDItLjkgMi0yVjdsLTQtNHptLTUgMTZjLTEuNjYgMC0zLTEuMzQtMy0zczEuMzQtMyAzLTMgMyAxLjM0IDMgMy0xLjM0IDMtMyAzem0zLTEwSDVWNWgxMHY0eiIvPgogICAgPC9nPgo8L3N2Zz4K);
  --jp-icon-search: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMTggMTgiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEyLjEsMTAuOWgtMC43bC0wLjItMC4yYzAuOC0wLjksMS4zLTIuMiwxLjMtMy41YzAtMy0yLjQtNS40LTUuNC01LjRTMS44LDQuMiwxLjgsNy4xczIuNCw1LjQsNS40LDUuNCBjMS4zLDAsMi41LTAuNSwzLjUtMS4zbDAuMiwwLjJ2MC43bDQuMSw0LjFsMS4yLTEuMkwxMi4xLDEwLjl6IE03LjEsMTAuOWMtMi4xLDAtMy43LTEuNy0zLjctMy43czEuNy0zLjcsMy43LTMuN3MzLjcsMS43LDMuNywzLjcgUzkuMiwxMC45LDcuMSwxMC45eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-settings: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMTkuNDMgMTIuOThjLjA0LS4zMi4wNy0uNjQuMDctLjk4cy0uMDMtLjY2LS4wNy0uOThsMi4xMS0xLjY1Yy4xOS0uMTUuMjQtLjQyLjEyLS42NGwtMi0zLjQ2Yy0uMTItLjIyLS4zOS0uMy0uNjEtLjIybC0yLjQ5IDFjLS41Mi0uNC0xLjA4LS43My0xLjY5LS45OGwtLjM4LTIuNjVBLjQ4OC40ODggMCAwMDE0IDJoLTRjLS4yNSAwLS40Ni4xOC0uNDkuNDJsLS4zOCAyLjY1Yy0uNjEuMjUtMS4xNy41OS0xLjY5Ljk4bC0yLjQ5LTFjLS4yMy0uMDktLjQ5IDAtLjYxLjIybC0yIDMuNDZjLS4xMy4yMi0uMDcuNDkuMTIuNjRsMi4xMSAxLjY1Yy0uMDQuMzItLjA3LjY1LS4wNy45OHMuMDMuNjYuMDcuOThsLTIuMTEgMS42NWMtLjE5LjE1LS4yNC40Mi0uMTIuNjRsMiAzLjQ2Yy4xMi4yMi4zOS4zLjYxLjIybDIuNDktMWMuNTIuNCAxLjA4LjczIDEuNjkuOThsLjM4IDIuNjVjLjAzLjI0LjI0LjQyLjQ5LjQyaDRjLjI1IDAgLjQ2LS4xOC40OS0uNDJsLjM4LTIuNjVjLjYxLS4yNSAxLjE3LS41OSAxLjY5LS45OGwyLjQ5IDFjLjIzLjA5LjQ5IDAgLjYxLS4yMmwyLTMuNDZjLjEyLS4yMi4wNy0uNDktLjEyLS42NGwtMi4xMS0xLjY1ek0xMiAxNS41Yy0xLjkzIDAtMy41LTEuNTctMy41LTMuNXMxLjU3LTMuNSAzLjUtMy41IDMuNSAxLjU3IDMuNSAzLjUtMS41NyAzLjUtMy41IDMuNXoiLz4KPC9zdmc+Cg==);
  --jp-icon-spreadsheet: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8cGF0aCBjbGFzcz0ianAtaWNvbi1jb250cmFzdDEganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNENBRjUwIiBkPSJNMi4yIDIuMnYxNy42aDE3LjZWMi4ySDIuMnptMTUuNCA3LjdoLTUuNVY0LjRoNS41djUuNXpNOS45IDQuNHY1LjVINC40VjQuNGg1LjV6bS01LjUgNy43aDUuNXY1LjVINC40di01LjV6bTcuNyA1LjV2LTUuNWg1LjV2NS41aC01LjV6Ii8+Cjwvc3ZnPgo=);
  --jp-icon-stop: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPgogICAgICAgIDxwYXRoIGQ9Ik02IDZoMTJ2MTJINnoiLz4KICAgIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-tab: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTIxIDNIM2MtMS4xIDAtMiAuOS0yIDJ2MTRjMCAxLjEuOSAyIDIgMmgxOGMxLjEgMCAyLS45IDItMlY1YzAtMS4xLS45LTItMi0yem0wIDE2SDNWNWgxMHY0aDh2MTB6Ii8+CiAgPC9nPgo8L3N2Zz4K);
  --jp-icon-table-rows: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPgogICAgICAgIDxwYXRoIGQ9Ik0yMSw4SDNWNGgxOFY4eiBNMjEsMTBIM3Y0aDE4VjEweiBNMjEsMTZIM3Y0aDE4VjE2eiIvPgogICAgPC9nPgo8L3N2Zz4=);
  --jp-icon-tag: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjgiIGhlaWdodD0iMjgiIHZpZXdCb3g9IjAgMCA0MyAyOCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KCTxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CgkJPHBhdGggZD0iTTI4LjgzMzIgMTIuMzM0TDMyLjk5OTggMTYuNTAwN0wzNy4xNjY1IDEyLjMzNEgyOC44MzMyWiIvPgoJCTxwYXRoIGQ9Ik0xNi4yMDk1IDIxLjYxMDRDMTUuNjg3MyAyMi4xMjk5IDE0Ljg0NDMgMjIuMTI5OSAxNC4zMjQ4IDIxLjYxMDRMNi45ODI5IDE0LjcyNDVDNi41NzI0IDE0LjMzOTQgNi4wODMxMyAxMy42MDk4IDYuMDQ3ODYgMTMuMDQ4MkM1Ljk1MzQ3IDExLjUyODggNi4wMjAwMiA4LjYxOTQ0IDYuMDY2MjEgNy4wNzY5NUM2LjA4MjgxIDYuNTE0NzcgNi41NTU0OCA2LjA0MzQ3IDcuMTE4MDQgNi4wMzA1NUM5LjA4ODYzIDUuOTg0NzMgMTMuMjYzOCA1LjkzNTc5IDEzLjY1MTggNi4zMjQyNUwyMS43MzY5IDEzLjYzOUMyMi4yNTYgMTQuMTU4NSAyMS43ODUxIDE1LjQ3MjQgMjEuMjYyIDE1Ljk5NDZMMTYuMjA5NSAyMS42MTA0Wk05Ljc3NTg1IDguMjY1QzkuMzM1NTEgNy44MjU2NiA4LjYyMzUxIDcuODI1NjYgOC4xODI4IDguMjY1QzcuNzQzNDYgOC43MDU3MSA3Ljc0MzQ2IDkuNDE3MzMgOC4xODI4IDkuODU2NjdDOC42MjM4MiAxMC4yOTY0IDkuMzM1ODIgMTAuMjk2NCA5Ljc3NTg1IDkuODU2NjdDMTAuMjE1NiA5LjQxNzMzIDEwLjIxNTYgOC43MDUzMyA5Ljc3NTg1IDguMjY1WiIvPgoJPC9nPgo8L3N2Zz4K);
  --jp-icon-terminal: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0IiA+CiAgICA8cmVjdCBjbGFzcz0ianAtaWNvbjIganAtaWNvbi1zZWxlY3RhYmxlIiB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDIgMikiIGZpbGw9IiMzMzMzMzMiLz4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uLWFjY2VudDIganAtaWNvbi1zZWxlY3RhYmxlLWludmVyc2UiIGQ9Ik01LjA1NjY0IDguNzYxNzJDNS4wNTY2NCA4LjU5NzY2IDUuMDMxMjUgOC40NTMxMiA0Ljk4MDQ3IDguMzI4MTJDNC45MzM1OSA4LjE5OTIyIDQuODU1NDcgOC4wODIwMyA0Ljc0NjA5IDcuOTc2NTZDNC42NDA2MiA3Ljg3MTA5IDQuNSA3Ljc3NTM5IDQuMzI0MjIgNy42ODk0NUM0LjE1MjM0IDcuNTk5NjEgMy45NDMzNiA3LjUxMTcyIDMuNjk3MjcgNy40MjU3OEMzLjMwMjczIDcuMjg1MTYgMi45NDMzNiA3LjEzNjcyIDIuNjE5MTQgNi45ODA0N0MyLjI5NDkyIDYuODI0MjIgMi4wMTc1OCA2LjY0MjU4IDEuNzg3MTEgNi40MzU1NUMxLjU2MDU1IDYuMjI4NTIgMS4zODQ3NyA1Ljk4ODI4IDEuMjU5NzcgNS43MTQ4NEMxLjEzNDc3IDUuNDM3NSAxLjA3MjI3IDUuMTA5MzggMS4wNzIyNyA0LjczMDQ3QzEuMDcyMjcgNC4zOTg0NCAxLjEyODkxIDQuMDk1NyAxLjI0MjE5IDMuODIyMjdDMS4zNTU0NyAzLjU0NDkyIDEuNTE1NjIgMy4zMDQ2OSAxLjcyMjY2IDMuMTAxNTZDMS45Mjk2OSAyLjg5ODQ0IDIuMTc5NjkgMi43MzQzNyAyLjQ3MjY2IDIuNjA5MzhDMi43NjU2MiAyLjQ4NDM4IDMuMDkxOCAyLjQwNDMgMy40NTExNyAyLjM2OTE0VjEuMTA5MzhINC4zODg2N1YyLjM4MDg2QzQuNzQwMjMgMi40Mjc3MyA1LjA1NjY0IDIuNTIzNDQgNS4zMzc4OSAyLjY2Nzk3QzUuNjE5MTQgMi44MTI1IDUuODU3NDIgMy4wMDE5NSA2LjA1MjczIDMuMjM2MzNDNi4yNTE5NSAzLjQ2NjggNi40MDQzIDMuNzQwMjMgNi41MDk3NyA0LjA1NjY0QzYuNjE5MTQgNC4zNjkxNCA2LjY3MzgzIDQuNzIwNyA2LjY3MzgzIDUuMTExMzNINS4wNDQ5MkM1LjA0NDkyIDQuNjM4NjcgNC45Mzc1IDQuMjgxMjUgNC43MjI2NiA0LjAzOTA2QzQuNTA3ODEgMy43OTI5NyA0LjIxNjggMy42Njk5MiAzLjg0OTYxIDMuNjY5OTJDMy42NTAzOSAzLjY2OTkyIDMuNDc2NTYgMy42OTcyNyAzLjMyODEyIDMuNzUxOTVDMy4xODM1OSAzLjgwMjczIDMuMDY0NDUgMy44NzY5NSAyLjk3MDcgMy45NzQ2MUMyLjg3Njk1IDQuMDY4MzYgMi44MDY2NCA0LjE3OTY5IDIuNzU5NzcgNC4zMDg1OUMyLjcxNjggNC40Mzc1IDIuNjk1MzEgNC41NzgxMiAyLjY5NTMxIDQuNzMwNDdDMi42OTUzMSA0Ljg4MjgxIDIuNzE2OCA1LjAxOTUzIDIuNzU5NzcgNS4xNDA2MkMyLjgwNjY0IDUuMjU3ODEgMi44ODI4MSA1LjM2NzE5IDIuOTg4MjggNS40Njg3NUMzLjA5NzY2IDUuNTcwMzEgMy4yNDAyMyA1LjY2Nzk3IDMuNDE2MDIgNS43NjE3MkMzLjU5MTggNS44NTE1NiAzLjgxMDU1IDUuOTQzMzYgNC4wNzIyNyA2LjAzNzExQzQuNDY2OCA2LjE4NTU1IDQuODI0MjIgNi4zMzk4NCA1LjE0NDUzIDYuNUM1LjQ2NDg0IDYuNjU2MjUgNS43MzgyOCA2LjgzOTg0IDUuOTY0ODQgNy4wNTA3OEM2LjE5NTMxIDcuMjU3ODEgNi4zNzEwOSA3LjUgNi40OTIxOSA3Ljc3NzM0QzYuNjE3MTkgOC4wNTA3OCA2LjY3OTY5IDguMzc1IDYuNjc5NjkgOC43NUM2LjY3OTY5IDkuMDkzNzUgNi42MjMwNSA5LjQwNDMgNi41MDk3NyA5LjY4MTY0QzYuMzk2NDggOS45NTUwOCA2LjIzNDM4IDEwLjE5MTQgNi4wMjM0NCAxMC4zOTA2QzUuODEyNSAxMC41ODk4IDUuNTU4NTkgMTAuNzUgNS4yNjE3MiAxMC44NzExQzQuOTY0ODQgMTAuOTg4MyA0LjYzMjgxIDExLjA2NDUgNC4yNjU2MiAxMS4wOTk2VjEyLjI0OEgzLjMzMzk4VjExLjA5OTZDMy4wMDE5NSAxMS4wNjg0IDIuNjc5NjkgMTAuOTk2MSAyLjM2NzE5IDEwLjg4MjhDMi4wNTQ2OSAxMC43NjU2IDEuNzc3MzQgMTAuNTk3NyAxLjUzNTE2IDEwLjM3ODlDMS4yOTY4OCAxMC4xNjAyIDEuMTA1NDcgOS44ODQ3NyAwLjk2MDkzOCA5LjU1MjczQzAuODE2NDA2IDkuMjE2OCAwLjc0NDE0MSA4LjgxNDQ1IDAuNzQ0MTQxIDguMzQ1N0gyLjM3ODkxQzIuMzc4OTEgOC42MjY5NSAyLjQxOTkyIDguODYzMjggMi41MDE5NSA5LjA1NDY5QzIuNTgzOTggOS4yNDIxOSAyLjY4OTQ1IDkuMzkyNTggMi44MTgzNiA5LjUwNTg2QzIuOTUxMTcgOS42MTUyMyAzLjEwMTU2IDkuNjkzMzYgMy4yNjk1MyA5Ljc0MDIzQzMuNDM3NSA5Ljc4NzExIDMuNjA5MzggOS44MTA1NSAzLjc4NTE2IDkuODEwNTVDNC4yMDMxMiA5LjgxMDU1IDQuNTE5NTMgOS43MTI4OSA0LjczNDM4IDkuNTE3NThDNC45NDkyMiA5LjMyMjI3IDUuMDU2NjQgOS4wNzAzMSA1LjA1NjY0IDguNzYxNzJaTTEzLjQxOCAxMi4yNzE1SDguMDc0MjJWMTFIMTMuNDE4VjEyLjI3MTVaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgzLjk1MjY0IDYpIiBmaWxsPSJ3aGl0ZSIvPgo8L3N2Zz4K);
  --jp-icon-text-editor: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI0Ij4KICA8cGF0aCBjbGFzcz0ianAtaWNvbjMganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjNjE2MTYxIiBkPSJNMTUgMTVIM3YyaDEydi0yem0wLThIM3YyaDEyVjd6TTMgMTNoMTh2LTJIM3Yyem0wIDhoMTh2LTJIM3Yyek0zIDN2MmgxOFYzSDN6Ii8+Cjwvc3ZnPgo=);
  --jp-icon-toc: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB2ZXJzaW9uPSIxLjEiIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgoJPHBhdGggZD0iTTcsNUgyMVY3SDdWNU03LDEzVjExSDIxVjEzSDdNNCw0LjVBMS41LDEuNSAwIDAsMSA1LjUsNkExLjUsMS41IDAgMCwxIDQsNy41QTEuNSwxLjUgMCAwLDEgMi41LDZBMS41LDEuNSAwIDAsMSA0LDQuNU00LDEwLjVBMS41LDEuNSAwIDAsMSA1LjUsMTJBMS41LDEuNSAwIDAsMSA0LDEzLjVBMS41LDEuNSAwIDAsMSAyLjUsMTJBMS41LDEuNSAwIDAsMSA0LDEwLjVNNywxOVYxN0gyMVYxOUg3TTQsMTYuNUExLjUsMS41IDAgMCwxIDUuNSwxOEExLjUsMS41IDAgMCwxIDQsMTkuNUExLjUsMS41IDAgMCwxIDIuNSwxOEExLjUsMS41IDAgMCwxIDQsMTYuNVoiIC8+Cjwvc3ZnPgo=);
  --jp-icon-tree-view: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjI0IiB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIyNCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxnIGNsYXNzPSJqcC1pY29uMyIgZmlsbD0iIzYxNjE2MSI+CiAgICAgICAgPHBhdGggZD0iTTAgMGgyNHYyNEgweiIgZmlsbD0ibm9uZSIvPgogICAgICAgIDxwYXRoIGQ9Ik0yMiAxMVYzaC03djNIOVYzSDJ2OGg3VjhoMnYxMGg0djNoN3YtOGgtN3YzaC0yVjhoMnYzeiIvPgogICAgPC9nPgo8L3N2Zz4=);
  --jp-icon-trusted: url(data:image/svg+xml;base64,PHN2ZyBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDI0IDI1Ij4KICAgIDxwYXRoIGNsYXNzPSJqcC1pY29uMiIgc3Ryb2tlPSIjMzMzMzMzIiBzdHJva2Utd2lkdGg9IjIiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDIgMykiIGQ9Ik0xLjg2MDk0IDExLjQ0MDlDMC44MjY0NDggOC43NzAyNyAwLjg2Mzc3OSA2LjA1NzY0IDEuMjQ5MDcgNC4xOTkzMkMyLjQ4MjA2IDMuOTMzNDcgNC4wODA2OCAzLjQwMzQ3IDUuNjAxMDIgMi44NDQ5QzcuMjM1NDkgMi4yNDQ0IDguODU2NjYgMS41ODE1IDkuOTg3NiAxLjA5NTM5QzExLjA1OTcgMS41ODM0MSAxMi42MDk0IDIuMjQ0NCAxNC4yMTggMi44NDMzOUMxNS43NTAzIDMuNDEzOTQgMTcuMzk5NSAzLjk1MjU4IDE4Ljc1MzkgNC4yMTM4NUMxOS4xMzY0IDYuMDcxNzcgMTkuMTcwOSA4Ljc3NzIyIDE4LjEzOSAxMS40NDA5QzE3LjAzMDMgMTQuMzAzMiAxNC42NjY4IDE3LjE4NDQgOS45OTk5OSAxOC45MzU0QzUuMzMzMiAxNy4xODQ0IDIuOTY5NjggMTQuMzAzMiAxLjg2MDk0IDExLjQ0MDlaIi8+CiAgICA8cGF0aCBjbGFzcz0ianAtaWNvbjIiIGZpbGw9IiMzMzMzMzMiIHN0cm9rZT0iIzMzMzMzMyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoOCA5Ljg2NzE5KSIgZD0iTTIuODYwMTUgNC44NjUzNUwwLjcyNjU0OSAyLjk5OTU5TDAgMy42MzA0NUwyLjg2MDE1IDYuMTMxNTdMOCAwLjYzMDg3Mkw3LjI3ODU3IDBMMi44NjAxNSA0Ljg2NTM1WiIvPgo8L3N2Zz4K);
  --jp-icon-undo: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjQgMjQiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEyLjUgOGMtMi42NSAwLTUuMDUuOTktNi45IDIuNkwyIDd2OWg5bC0zLjYyLTMuNjJjMS4zOS0xLjE2IDMuMTYtMS44OCA1LjEyLTEuODggMy41NCAwIDYuNTUgMi4zMSA3LjYgNS41bDIuMzctLjc4QzIxLjA4IDExLjAzIDE3LjE1IDggMTIuNSA4eiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-vega: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8ZyBjbGFzcz0ianAtaWNvbjEganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjMjEyMTIxIj4KICAgIDxwYXRoIGQ9Ik0xMC42IDUuNGwyLjItMy4ySDIuMnY3LjNsNC02LjZ6Ii8+CiAgICA8cGF0aCBkPSJNMTUuOCAyLjJsLTQuNCA2LjZMNyA2LjNsLTQuOCA4djUuNWgxNy42VjIuMmgtNHptLTcgMTUuNEg1LjV2LTQuNGgzLjN2NC40em00LjQgMEg5LjhWOS44aDMuNHY3Ljh6bTQuNCAwaC0zLjRWNi41aDMuNHYxMS4xeiIvPgogIDwvZz4KPC9zdmc+Cg==);
  --jp-icon-yaml: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgdmlld0JveD0iMCAwIDIyIDIyIj4KICA8ZyBjbGFzcz0ianAtaWNvbi1jb250cmFzdDIganAtaWNvbi1zZWxlY3RhYmxlIiBmaWxsPSIjRDgxQjYwIj4KICAgIDxwYXRoIGQ9Ik03LjIgMTguNnYtNS40TDMgNS42aDMuM2wxLjQgMy4xYy4zLjkuNiAxLjYgMSAyLjUuMy0uOC42LTEuNiAxLTIuNWwxLjQtMy4xaDMuNGwtNC40IDcuNnY1LjVsLTIuOS0uMXoiLz4KICAgIDxjaXJjbGUgY2xhc3M9InN0MCIgY3g9IjE3LjYiIGN5PSIxNi41IiByPSIyLjEiLz4KICAgIDxjaXJjbGUgY2xhc3M9InN0MCIgY3g9IjE3LjYiIGN5PSIxMSIgcj0iMi4xIi8+CiAgPC9nPgo8L3N2Zz4K);
}

/* Icon CSS class declarations */

.jp-AddIcon {
  background-image: var(--jp-icon-add);
}
.jp-BugIcon {
  background-image: var(--jp-icon-bug);
}
.jp-BuildIcon {
  background-image: var(--jp-icon-build);
}
.jp-CaretDownEmptyIcon {
  background-image: var(--jp-icon-caret-down-empty);
}
.jp-CaretDownEmptyThinIcon {
  background-image: var(--jp-icon-caret-down-empty-thin);
}
.jp-CaretDownIcon {
  background-image: var(--jp-icon-caret-down);
}
.jp-CaretLeftIcon {
  background-image: var(--jp-icon-caret-left);
}
.jp-CaretRightIcon {
  background-image: var(--jp-icon-caret-right);
}
.jp-CaretUpEmptyThinIcon {
  background-image: var(--jp-icon-caret-up-empty-thin);
}
.jp-CaretUpIcon {
  background-image: var(--jp-icon-caret-up);
}
.jp-CaseSensitiveIcon {
  background-image: var(--jp-icon-case-sensitive);
}
.jp-CheckIcon {
  background-image: var(--jp-icon-check);
}
.jp-CircleEmptyIcon {
  background-image: var(--jp-icon-circle-empty);
}
.jp-CircleIcon {
  background-image: var(--jp-icon-circle);
}
.jp-ClearIcon {
  background-image: var(--jp-icon-clear);
}
.jp-CloseIcon {
  background-image: var(--jp-icon-close);
}
.jp-CodeIcon {
  background-image: var(--jp-icon-code);
}
.jp-ConsoleIcon {
  background-image: var(--jp-icon-console);
}
.jp-CopyIcon {
  background-image: var(--jp-icon-copy);
}
.jp-CutIcon {
  background-image: var(--jp-icon-cut);
}
.jp-DownloadIcon {
  background-image: var(--jp-icon-download);
}
.jp-EditIcon {
  background-image: var(--jp-icon-edit);
}
.jp-EllipsesIcon {
  background-image: var(--jp-icon-ellipses);
}
.jp-ExtensionIcon {
  background-image: var(--jp-icon-extension);
}
.jp-FastForwardIcon {
  background-image: var(--jp-icon-fast-forward);
}
.jp-FileIcon {
  background-image: var(--jp-icon-file);
}
.jp-FileUploadIcon {
  background-image: var(--jp-icon-file-upload);
}
.jp-FilterListIcon {
  background-image: var(--jp-icon-filter-list);
}
.jp-FolderIcon {
  background-image: var(--jp-icon-folder);
}
.jp-Html5Icon {
  background-image: var(--jp-icon-html5);
}
.jp-ImageIcon {
  background-image: var(--jp-icon-image);
}
.jp-InspectorIcon {
  background-image: var(--jp-icon-inspector);
}
.jp-JsonIcon {
  background-image: var(--jp-icon-json);
}
.jp-JupyterFaviconIcon {
  background-image: var(--jp-icon-jupyter-favicon);
}
.jp-JupyterIcon {
  background-image: var(--jp-icon-jupyter);
}
.jp-JupyterlabWordmarkIcon {
  background-image: var(--jp-icon-jupyterlab-wordmark);
}
.jp-KernelIcon {
  background-image: var(--jp-icon-kernel);
}
.jp-KeyboardIcon {
  background-image: var(--jp-icon-keyboard);
}
.jp-LauncherIcon {
  background-image: var(--jp-icon-launcher);
}
.jp-LineFormIcon {
  background-image: var(--jp-icon-line-form);
}
.jp-LinkIcon {
  background-image: var(--jp-icon-link);
}
.jp-ListIcon {
  background-image: var(--jp-icon-list);
}
.jp-ListingsInfoIcon {
  background-image: var(--jp-icon-listings-info);
}
.jp-MarkdownIcon {
  background-image: var(--jp-icon-markdown);
}
.jp-NewFolderIcon {
  background-image: var(--jp-icon-new-folder);
}
.jp-NotTrustedIcon {
  background-image: var(--jp-icon-not-trusted);
}
.jp-NotebookIcon {
  background-image: var(--jp-icon-notebook);
}
.jp-NumberingIcon {
  background-image: var(--jp-icon-numbering);
}
.jp-OfflineBoltIcon {
  background-image: var(--jp-icon-offline-bolt);
}
.jp-PaletteIcon {
  background-image: var(--jp-icon-palette);
}
.jp-PasteIcon {
  background-image: var(--jp-icon-paste);
}
.jp-PdfIcon {
  background-image: var(--jp-icon-pdf);
}
.jp-PythonIcon {
  background-image: var(--jp-icon-python);
}
.jp-RKernelIcon {
  background-image: var(--jp-icon-r-kernel);
}
.jp-ReactIcon {
  background-image: var(--jp-icon-react);
}
.jp-RedoIcon {
  background-image: var(--jp-icon-redo);
}
.jp-RefreshIcon {
  background-image: var(--jp-icon-refresh);
}
.jp-RegexIcon {
  background-image: var(--jp-icon-regex);
}
.jp-RunIcon {
  background-image: var(--jp-icon-run);
}
.jp-RunningIcon {
  background-image: var(--jp-icon-running);
}
.jp-SaveIcon {
  background-image: var(--jp-icon-save);
}
.jp-SearchIcon {
  background-image: var(--jp-icon-search);
}
.jp-SettingsIcon {
  background-image: var(--jp-icon-settings);
}
.jp-SpreadsheetIcon {
  background-image: var(--jp-icon-spreadsheet);
}
.jp-StopIcon {
  background-image: var(--jp-icon-stop);
}
.jp-TabIcon {
  background-image: var(--jp-icon-tab);
}
.jp-TableRowsIcon {
  background-image: var(--jp-icon-table-rows);
}
.jp-TagIcon {
  background-image: var(--jp-icon-tag);
}
.jp-TerminalIcon {
  background-image: var(--jp-icon-terminal);
}
.jp-TextEditorIcon {
  background-image: var(--jp-icon-text-editor);
}
.jp-TocIcon {
  background-image: var(--jp-icon-toc);
}
.jp-TreeViewIcon {
  background-image: var(--jp-icon-tree-view);
}
.jp-TrustedIcon {
  background-image: var(--jp-icon-trusted);
}
.jp-UndoIcon {
  background-image: var(--jp-icon-undo);
}
.jp-VegaIcon {
  background-image: var(--jp-icon-vega);
}
.jp-YamlIcon {
  background-image: var(--jp-icon-yaml);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/**
 * (DEPRECATED) Support for consuming icons as CSS background images
 */

:root {
  --jp-icon-search-white: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMTggMTgiIHdpZHRoPSIxNiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8ZyBjbGFzcz0ianAtaWNvbjMiIGZpbGw9IiM2MTYxNjEiPgogICAgPHBhdGggZD0iTTEyLjEsMTAuOWgtMC43bC0wLjItMC4yYzAuOC0wLjksMS4zLTIuMiwxLjMtMy41YzAtMy0yLjQtNS40LTUuNC01LjRTMS44LDQuMiwxLjgsNy4xczIuNCw1LjQsNS40LDUuNCBjMS4zLDAsMi41LTAuNSwzLjUtMS4zbDAuMiwwLjJ2MC43bDQuMSw0LjFsMS4yLTEuMkwxMi4xLDEwLjl6IE03LjEsMTAuOWMtMi4xLDAtMy43LTEuNy0zLjctMy43czEuNy0zLjcsMy43LTMuN3MzLjcsMS43LDMuNywzLjcgUzkuMiwxMC45LDcuMSwxMC45eiIvPgogIDwvZz4KPC9zdmc+Cg==);
}

.jp-Icon,
.jp-MaterialIcon {
  background-position: center;
  background-repeat: no-repeat;
  background-size: 16px;
  min-width: 16px;
  min-height: 16px;
}

.jp-Icon-cover {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

/**
 * (DEPRECATED) Support for specific CSS icon sizes
 */

.jp-Icon-16 {
  background-size: 16px;
  min-width: 16px;
  min-height: 16px;
}

.jp-Icon-18 {
  background-size: 18px;
  min-width: 18px;
  min-height: 18px;
}

.jp-Icon-20 {
  background-size: 20px;
  min-width: 20px;
  min-height: 20px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/**
 * Support for icons as inline SVG HTMLElements
 */

/* recolor the primary elements of an icon */
.jp-icon0[fill] {
  fill: var(--jp-inverse-layout-color0);
}
.jp-icon1[fill] {
  fill: var(--jp-inverse-layout-color1);
}
.jp-icon2[fill] {
  fill: var(--jp-inverse-layout-color2);
}
.jp-icon3[fill] {
  fill: var(--jp-inverse-layout-color3);
}
.jp-icon4[fill] {
  fill: var(--jp-inverse-layout-color4);
}

.jp-icon0[stroke] {
  stroke: var(--jp-inverse-layout-color0);
}
.jp-icon1[stroke] {
  stroke: var(--jp-inverse-layout-color1);
}
.jp-icon2[stroke] {
  stroke: var(--jp-inverse-layout-color2);
}
.jp-icon3[stroke] {
  stroke: var(--jp-inverse-layout-color3);
}
.jp-icon4[stroke] {
  stroke: var(--jp-inverse-layout-color4);
}
/* recolor the accent elements of an icon */
.jp-icon-accent0[fill] {
  fill: var(--jp-layout-color0);
}
.jp-icon-accent1[fill] {
  fill: var(--jp-layout-color1);
}
.jp-icon-accent2[fill] {
  fill: var(--jp-layout-color2);
}
.jp-icon-accent3[fill] {
  fill: var(--jp-layout-color3);
}
.jp-icon-accent4[fill] {
  fill: var(--jp-layout-color4);
}

.jp-icon-accent0[stroke] {
  stroke: var(--jp-layout-color0);
}
.jp-icon-accent1[stroke] {
  stroke: var(--jp-layout-color1);
}
.jp-icon-accent2[stroke] {
  stroke: var(--jp-layout-color2);
}
.jp-icon-accent3[stroke] {
  stroke: var(--jp-layout-color3);
}
.jp-icon-accent4[stroke] {
  stroke: var(--jp-layout-color4);
}
/* set the color of an icon to transparent */
.jp-icon-none[fill] {
  fill: none;
}

.jp-icon-none[stroke] {
  stroke: none;
}
/* brand icon colors. Same for light and dark */
.jp-icon-brand0[fill] {
  fill: var(--jp-brand-color0);
}
.jp-icon-brand1[fill] {
  fill: var(--jp-brand-color1);
}
.jp-icon-brand2[fill] {
  fill: var(--jp-brand-color2);
}
.jp-icon-brand3[fill] {
  fill: var(--jp-brand-color3);
}
.jp-icon-brand4[fill] {
  fill: var(--jp-brand-color4);
}

.jp-icon-brand0[stroke] {
  stroke: var(--jp-brand-color0);
}
.jp-icon-brand1[stroke] {
  stroke: var(--jp-brand-color1);
}
.jp-icon-brand2[stroke] {
  stroke: var(--jp-brand-color2);
}
.jp-icon-brand3[stroke] {
  stroke: var(--jp-brand-color3);
}
.jp-icon-brand4[stroke] {
  stroke: var(--jp-brand-color4);
}
/* warn icon colors. Same for light and dark */
.jp-icon-warn0[fill] {
  fill: var(--jp-warn-color0);
}
.jp-icon-warn1[fill] {
  fill: var(--jp-warn-color1);
}
.jp-icon-warn2[fill] {
  fill: var(--jp-warn-color2);
}
.jp-icon-warn3[fill] {
  fill: var(--jp-warn-color3);
}

.jp-icon-warn0[stroke] {
  stroke: var(--jp-warn-color0);
}
.jp-icon-warn1[stroke] {
  stroke: var(--jp-warn-color1);
}
.jp-icon-warn2[stroke] {
  stroke: var(--jp-warn-color2);
}
.jp-icon-warn3[stroke] {
  stroke: var(--jp-warn-color3);
}
/* icon colors that contrast well with each other and most backgrounds */
.jp-icon-contrast0[fill] {
  fill: var(--jp-icon-contrast-color0);
}
.jp-icon-contrast1[fill] {
  fill: var(--jp-icon-contrast-color1);
}
.jp-icon-contrast2[fill] {
  fill: var(--jp-icon-contrast-color2);
}
.jp-icon-contrast3[fill] {
  fill: var(--jp-icon-contrast-color3);
}

.jp-icon-contrast0[stroke] {
  stroke: var(--jp-icon-contrast-color0);
}
.jp-icon-contrast1[stroke] {
  stroke: var(--jp-icon-contrast-color1);
}
.jp-icon-contrast2[stroke] {
  stroke: var(--jp-icon-contrast-color2);
}
.jp-icon-contrast3[stroke] {
  stroke: var(--jp-icon-contrast-color3);
}

/* CSS for icons in selected items in the settings editor */
#setting-editor .jp-PluginList .jp-mod-selected .jp-icon-selectable[fill] {
  fill: #fff;
}
#setting-editor
  .jp-PluginList
  .jp-mod-selected
  .jp-icon-selectable-inverse[fill] {
  fill: var(--jp-brand-color1);
}

/* CSS for icons in selected filebrowser listing items */
.jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] {
  fill: #fff;
}
.jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] {
  fill: var(--jp-brand-color1);
}

/* CSS for icons in selected tabs in the sidebar tab manager */
#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable[fill] {
  fill: #fff;
}

#tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable-inverse[fill] {
  fill: var(--jp-brand-color1);
}
#tab-manager
  .lm-TabBar-tab.jp-mod-active
  .jp-icon-hover
  :hover
  .jp-icon-selectable[fill] {
  fill: var(--jp-brand-color1);
}

#tab-manager
  .lm-TabBar-tab.jp-mod-active
  .jp-icon-hover
  :hover
  .jp-icon-selectable-inverse[fill] {
  fill: #fff;
}

/**
 * TODO: come up with non css-hack solution for showing the busy icon on top
 *  of the close icon
 * CSS for complex behavior of close icon of tabs in the sidebar tab manager
 */
#tab-manager
  .lm-TabBar-tab.jp-mod-dirty
  > .lm-TabBar-tabCloseIcon
  > :not(:hover)
  > .jp-icon3[fill] {
  fill: none;
}
#tab-manager
  .lm-TabBar-tab.jp-mod-dirty
  > .lm-TabBar-tabCloseIcon
  > :not(:hover)
  > .jp-icon-busy[fill] {
  fill: var(--jp-inverse-layout-color3);
}

#tab-manager
  .lm-TabBar-tab.jp-mod-dirty.jp-mod-active
  > .lm-TabBar-tabCloseIcon
  > :not(:hover)
  > .jp-icon-busy[fill] {
  fill: #fff;
}

/**
* TODO: come up with non css-hack solution for showing the busy icon on top
*  of the close icon
* CSS for complex behavior of close icon of tabs in the main area tabbar
*/
.lm-DockPanel-tabBar
  .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
  > .lm-TabBar-tabCloseIcon
  > :not(:hover)
  > .jp-icon3[fill] {
  fill: none;
}
.lm-DockPanel-tabBar
  .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
  > .lm-TabBar-tabCloseIcon
  > :not(:hover)
  > .jp-icon-busy[fill] {
  fill: var(--jp-inverse-layout-color3);
}

/* CSS for icons in status bar */
#jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] {
  fill: #fff;
}

#jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] {
  fill: var(--jp-brand-color1);
}
/* special handling for splash icon CSS. While the theme CSS reloads during
   splash, the splash icon can loose theming. To prevent that, we set a
   default for its color variable */
:root {
  --jp-warn-color0: var(--md-orange-700);
}

/* not sure what to do with this one, used in filebrowser listing */
.jp-DragIcon {
  margin-right: 4px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/**
 * Support for alt colors for icons as inline SVG HTMLElements
 */

/* alt recolor the primary elements of an icon */
.jp-icon-alt .jp-icon0[fill] {
  fill: var(--jp-layout-color0);
}
.jp-icon-alt .jp-icon1[fill] {
  fill: var(--jp-layout-color1);
}
.jp-icon-alt .jp-icon2[fill] {
  fill: var(--jp-layout-color2);
}
.jp-icon-alt .jp-icon3[fill] {
  fill: var(--jp-layout-color3);
}
.jp-icon-alt .jp-icon4[fill] {
  fill: var(--jp-layout-color4);
}

.jp-icon-alt .jp-icon0[stroke] {
  stroke: var(--jp-layout-color0);
}
.jp-icon-alt .jp-icon1[stroke] {
  stroke: var(--jp-layout-color1);
}
.jp-icon-alt .jp-icon2[stroke] {
  stroke: var(--jp-layout-color2);
}
.jp-icon-alt .jp-icon3[stroke] {
  stroke: var(--jp-layout-color3);
}
.jp-icon-alt .jp-icon4[stroke] {
  stroke: var(--jp-layout-color4);
}

/* alt recolor the accent elements of an icon */
.jp-icon-alt .jp-icon-accent0[fill] {
  fill: var(--jp-inverse-layout-color0);
}
.jp-icon-alt .jp-icon-accent1[fill] {
  fill: var(--jp-inverse-layout-color1);
}
.jp-icon-alt .jp-icon-accent2[fill] {
  fill: var(--jp-inverse-layout-color2);
}
.jp-icon-alt .jp-icon-accent3[fill] {
  fill: var(--jp-inverse-layout-color3);
}
.jp-icon-alt .jp-icon-accent4[fill] {
  fill: var(--jp-inverse-layout-color4);
}

.jp-icon-alt .jp-icon-accent0[stroke] {
  stroke: var(--jp-inverse-layout-color0);
}
.jp-icon-alt .jp-icon-accent1[stroke] {
  stroke: var(--jp-inverse-layout-color1);
}
.jp-icon-alt .jp-icon-accent2[stroke] {
  stroke: var(--jp-inverse-layout-color2);
}
.jp-icon-alt .jp-icon-accent3[stroke] {
  stroke: var(--jp-inverse-layout-color3);
}
.jp-icon-alt .jp-icon-accent4[stroke] {
  stroke: var(--jp-inverse-layout-color4);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-icon-hoverShow:not(:hover) svg {
  display: none !important;
}

/**
 * Support for hover colors for icons as inline SVG HTMLElements
 */

/**
 * regular colors
 */

/* recolor the primary elements of an icon */
.jp-icon-hover :hover .jp-icon0-hover[fill] {
  fill: var(--jp-inverse-layout-color0);
}
.jp-icon-hover :hover .jp-icon1-hover[fill] {
  fill: var(--jp-inverse-layout-color1);
}
.jp-icon-hover :hover .jp-icon2-hover[fill] {
  fill: var(--jp-inverse-layout-color2);
}
.jp-icon-hover :hover .jp-icon3-hover[fill] {
  fill: var(--jp-inverse-layout-color3);
}
.jp-icon-hover :hover .jp-icon4-hover[fill] {
  fill: var(--jp-inverse-layout-color4);
}

.jp-icon-hover :hover .jp-icon0-hover[stroke] {
  stroke: var(--jp-inverse-layout-color0);
}
.jp-icon-hover :hover .jp-icon1-hover[stroke] {
  stroke: var(--jp-inverse-layout-color1);
}
.jp-icon-hover :hover .jp-icon2-hover[stroke] {
  stroke: var(--jp-inverse-layout-color2);
}
.jp-icon-hover :hover .jp-icon3-hover[stroke] {
  stroke: var(--jp-inverse-layout-color3);
}
.jp-icon-hover :hover .jp-icon4-hover[stroke] {
  stroke: var(--jp-inverse-layout-color4);
}

/* recolor the accent elements of an icon */
.jp-icon-hover :hover .jp-icon-accent0-hover[fill] {
  fill: var(--jp-layout-color0);
}
.jp-icon-hover :hover .jp-icon-accent1-hover[fill] {
  fill: var(--jp-layout-color1);
}
.jp-icon-hover :hover .jp-icon-accent2-hover[fill] {
  fill: var(--jp-layout-color2);
}
.jp-icon-hover :hover .jp-icon-accent3-hover[fill] {
  fill: var(--jp-layout-color3);
}
.jp-icon-hover :hover .jp-icon-accent4-hover[fill] {
  fill: var(--jp-layout-color4);
}

.jp-icon-hover :hover .jp-icon-accent0-hover[stroke] {
  stroke: var(--jp-layout-color0);
}
.jp-icon-hover :hover .jp-icon-accent1-hover[stroke] {
  stroke: var(--jp-layout-color1);
}
.jp-icon-hover :hover .jp-icon-accent2-hover[stroke] {
  stroke: var(--jp-layout-color2);
}
.jp-icon-hover :hover .jp-icon-accent3-hover[stroke] {
  stroke: var(--jp-layout-color3);
}
.jp-icon-hover :hover .jp-icon-accent4-hover[stroke] {
  stroke: var(--jp-layout-color4);
}

/* set the color of an icon to transparent */
.jp-icon-hover :hover .jp-icon-none-hover[fill] {
  fill: none;
}

.jp-icon-hover :hover .jp-icon-none-hover[stroke] {
  stroke: none;
}

/**
 * inverse colors
 */

/* inverse recolor the primary elements of an icon */
.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] {
  fill: var(--jp-layout-color0);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] {
  fill: var(--jp-layout-color1);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] {
  fill: var(--jp-layout-color2);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] {
  fill: var(--jp-layout-color3);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] {
  fill: var(--jp-layout-color4);
}

.jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] {
  stroke: var(--jp-layout-color0);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] {
  stroke: var(--jp-layout-color1);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] {
  stroke: var(--jp-layout-color2);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] {
  stroke: var(--jp-layout-color3);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] {
  stroke: var(--jp-layout-color4);
}

/* inverse recolor the accent elements of an icon */
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] {
  fill: var(--jp-inverse-layout-color0);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] {
  fill: var(--jp-inverse-layout-color1);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] {
  fill: var(--jp-inverse-layout-color2);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] {
  fill: var(--jp-inverse-layout-color3);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] {
  fill: var(--jp-inverse-layout-color4);
}

.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] {
  stroke: var(--jp-inverse-layout-color0);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] {
  stroke: var(--jp-inverse-layout-color1);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] {
  stroke: var(--jp-inverse-layout-color2);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] {
  stroke: var(--jp-inverse-layout-color3);
}
.jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] {
  stroke: var(--jp-inverse-layout-color4);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-switch {
  display: flex;
  align-items: center;
  padding-left: 4px;
  padding-right: 4px;
  font-size: var(--jp-ui-font-size1);
  background-color: transparent;
  color: var(--jp-ui-font-color1);
  border: none;
  height: 20px;
}

.jp-switch:hover {
  background-color: var(--jp-layout-color2);
}

.jp-switch-label {
  margin-right: 5px;
}

.jp-switch-track {
  cursor: pointer;
  background-color: var(--jp-border-color1);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  border-radius: 34px;
  height: 16px;
  width: 35px;
  position: relative;
}

.jp-switch-track::before {
  content: '';
  position: absolute;
  height: 10px;
  width: 10px;
  margin: 3px;
  left: 0px;
  background-color: var(--jp-ui-inverse-font-color1);
  -webkit-transition: 0.4s;
  transition: 0.4s;
  border-radius: 50%;
}

.jp-switch[aria-checked='true'] .jp-switch-track {
  background-color: var(--jp-warn-color0);
}

.jp-switch[aria-checked='true'] .jp-switch-track::before {
  /* track width (35) - margins (3 + 3) - thumb width (10) */
  left: 19px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/* Sibling imports */

/* Override Blueprint's _reset.scss styles */
html {
  box-sizing: unset;
}

*,
*::before,
*::after {
  box-sizing: unset;
}

body {
  color: unset;
  font-family: var(--jp-ui-font-family);
}

p {
  margin-top: unset;
  margin-bottom: unset;
}

small {
  font-size: unset;
}

strong {
  font-weight: unset;
}

/* Override Blueprint's _typography.scss styles */
a {
  text-decoration: unset;
  color: unset;
}
a:hover {
  text-decoration: unset;
  color: unset;
}

/* Override Blueprint's _accessibility.scss styles */
:focus {
  outline: unset;
  outline-offset: unset;
  -moz-outline-radius: unset;
}

/* Styles for ui-components */
.jp-Button {
  border-radius: var(--jp-border-radius);
  padding: 0px 12px;
  font-size: var(--jp-ui-font-size1);
}

/* Use our own theme for hover styles */
button.jp-Button.bp3-button.bp3-minimal:hover {
  background-color: var(--jp-layout-color2);
}
.jp-Button.minimal {
  color: unset !important;
}

.jp-Button.jp-ToolbarButtonComponent {
  text-transform: none;
}

.jp-InputGroup input {
  box-sizing: border-box;
  border-radius: 0;
  background-color: transparent;
  color: var(--jp-ui-font-color0);
  box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
}

.jp-InputGroup input:focus {
  box-shadow: inset 0 0 0 var(--jp-border-width)
      var(--jp-input-active-box-shadow-color),
    inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
}

.jp-InputGroup input::placeholder,
input::placeholder {
  color: var(--jp-ui-font-color3);
}

.jp-BPIcon {
  display: inline-block;
  vertical-align: middle;
  margin: auto;
}

/* Stop blueprint futzing with our icon fills */
.bp3-icon.jp-BPIcon > svg:not([fill]) {
  fill: var(--jp-inverse-layout-color3);
}

.jp-InputGroupAction {
  padding: 6px;
}

.jp-HTMLSelect.jp-DefaultStyle select {
  background-color: initial;
  border: none;
  border-radius: 0;
  box-shadow: none;
  color: var(--jp-ui-font-color0);
  display: block;
  font-size: var(--jp-ui-font-size1);
  height: 24px;
  line-height: 14px;
  padding: 0 25px 0 10px;
  text-align: left;
  -moz-appearance: none;
  -webkit-appearance: none;
}

/* Use our own theme for hover and option styles */
.jp-HTMLSelect.jp-DefaultStyle select:hover,
.jp-HTMLSelect.jp-DefaultStyle select > option {
  background-color: var(--jp-layout-color2);
  color: var(--jp-ui-font-color0);
}
select {
  box-sizing: border-box;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-Collapse {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  border-top: 1px solid var(--jp-border-color2);
  border-bottom: 1px solid var(--jp-border-color2);
}

.jp-Collapse-header {
  padding: 1px 12px;
  color: var(--jp-ui-font-color1);
  background-color: var(--jp-layout-color1);
  font-size: var(--jp-ui-font-size2);
}

.jp-Collapse-header:hover {
  background-color: var(--jp-layout-color2);
}

.jp-Collapse-contents {
  padding: 0px 12px 0px 12px;
  background-color: var(--jp-layout-color1);
  color: var(--jp-ui-font-color1);
  overflow: auto;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Variables
|----------------------------------------------------------------------------*/

:root {
  --jp-private-commandpalette-search-height: 28px;
}

/*-----------------------------------------------------------------------------
| Overall styles
|----------------------------------------------------------------------------*/

.lm-CommandPalette {
  padding-bottom: 0px;
  color: var(--jp-ui-font-color1);
  background: var(--jp-layout-color1);
  /* This is needed so that all font sizing of children done in ems is
   * relative to this base size */
  font-size: var(--jp-ui-font-size1);
}

/*-----------------------------------------------------------------------------
| Modal variant
|----------------------------------------------------------------------------*/

.jp-ModalCommandPalette {
  position: absolute;
  z-index: 10000;
  top: 38px;
  left: 30%;
  margin: 0;
  padding: 4px;
  width: 40%;
  box-shadow: var(--jp-elevation-z4);
  border-radius: 4px;
  background: var(--jp-layout-color0);
}

.jp-ModalCommandPalette .lm-CommandPalette {
  max-height: 40vh;
}

.jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after {
  display: none;
}

.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header {
  display: none;
}

.jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item {
  margin-left: 4px;
  margin-right: 4px;
}

.jp-ModalCommandPalette
  .lm-CommandPalette
  .lm-CommandPalette-item.lm-mod-disabled {
  display: none;
}

/*-----------------------------------------------------------------------------
| Search
|----------------------------------------------------------------------------*/

.lm-CommandPalette-search {
  padding: 4px;
  background-color: var(--jp-layout-color1);
  z-index: 2;
}

.lm-CommandPalette-wrapper {
  overflow: overlay;
  padding: 0px 9px;
  background-color: var(--jp-input-active-background);
  height: 30px;
  box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
}

.lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper {
  box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color),
    inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
}

.lm-CommandPalette-wrapper::after {
  content: ' ';
  color: white;
  background-color: var(--jp-brand-color1);
  position: absolute;
  top: 4px;
  right: 4px;
  height: 30px;
  width: 10px;
  padding: 0px 10px;
  background-image: var(--jp-icon-search-white);
  background-size: 20px;
  background-repeat: no-repeat;
  background-position: center;
}

.lm-CommandPalette-input {
  background: transparent;
  width: calc(100% - 18px);
  float: left;
  border: none;
  outline: none;
  font-size: var(--jp-ui-font-size1);
  color: var(--jp-ui-font-color0);
  line-height: var(--jp-private-commandpalette-search-height);
}

.lm-CommandPalette-input::-webkit-input-placeholder,
.lm-CommandPalette-input::-moz-placeholder,
.lm-CommandPalette-input:-ms-input-placeholder {
  color: var(--jp-ui-font-color3);
  font-size: var(--jp-ui-font-size1);
}

/*-----------------------------------------------------------------------------
| Results
|----------------------------------------------------------------------------*/

.lm-CommandPalette-header:first-child {
  margin-top: 0px;
}

.lm-CommandPalette-header {
  border-bottom: solid var(--jp-border-width) var(--jp-border-color2);
  color: var(--jp-ui-font-color1);
  cursor: pointer;
  display: flex;
  font-size: var(--jp-ui-font-size0);
  font-weight: 600;
  letter-spacing: 1px;
  margin-top: 8px;
  padding: 8px 0 8px 12px;
  text-transform: uppercase;
}

.lm-CommandPalette-header.lm-mod-active {
  background: var(--jp-layout-color2);
}

.lm-CommandPalette-header > mark {
  background-color: transparent;
  font-weight: bold;
  color: var(--jp-ui-font-color1);
}

.lm-CommandPalette-item {
  padding: 4px 12px 4px 4px;
  color: var(--jp-ui-font-color1);
  font-size: var(--jp-ui-font-size1);
  font-weight: 400;
  display: flex;
}

.lm-CommandPalette-item.lm-mod-disabled {
  color: var(--jp-ui-font-color3);
}

.lm-CommandPalette-item.lm-mod-active {
  background: var(--jp-layout-color3);
}

.lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) {
  background: var(--jp-layout-color4);
}

.lm-CommandPalette-item:hover:not(.lm-mod-active):not(.lm-mod-disabled) {
  background: var(--jp-layout-color2);
}

.lm-CommandPalette-itemContent {
  overflow: hidden;
}

.lm-CommandPalette-itemLabel > mark {
  color: var(--jp-ui-font-color0);
  background-color: transparent;
  font-weight: bold;
}

.lm-CommandPalette-item.lm-mod-disabled mark {
  color: var(--jp-ui-font-color3);
}

.lm-CommandPalette-item .lm-CommandPalette-itemIcon {
  margin: 0 4px 0 0;
  position: relative;
  width: 16px;
  top: 2px;
  flex: 0 0 auto;
}

.lm-CommandPalette-item.lm-mod-disabled .lm-CommandPalette-itemIcon {
  opacity: 0.4;
}

.lm-CommandPalette-item .lm-CommandPalette-itemShortcut {
  flex: 0 0 auto;
}

.lm-CommandPalette-itemCaption {
  display: none;
}

.lm-CommandPalette-content {
  background-color: var(--jp-layout-color1);
}

.lm-CommandPalette-content:empty:after {
  content: 'No results';
  margin: auto;
  margin-top: 20px;
  width: 100px;
  display: block;
  font-size: var(--jp-ui-font-size2);
  font-family: var(--jp-ui-font-family);
  font-weight: lighter;
}

.lm-CommandPalette-emptyMessage {
  text-align: center;
  margin-top: 24px;
  line-height: 1.32;
  padding: 0px 8px;
  color: var(--jp-content-font-color3);
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2017, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-Dialog {
  position: absolute;
  z-index: 10000;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  top: 0px;
  left: 0px;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  background: var(--jp-dialog-background);
}

.jp-Dialog-content {
  display: flex;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
  background: var(--jp-layout-color1);
  padding: 24px;
  padding-bottom: 12px;
  min-width: 300px;
  min-height: 150px;
  max-width: 1000px;
  max-height: 500px;
  box-sizing: border-box;
  box-shadow: var(--jp-elevation-z20);
  word-wrap: break-word;
  border-radius: var(--jp-border-radius);
  /* This is needed so that all font sizing of children done in ems is
   * relative to this base size */
  font-size: var(--jp-ui-font-size1);
  color: var(--jp-ui-font-color1);
  resize: both;
}

.jp-Dialog-button {
  overflow: visible;
}

button.jp-Dialog-button:focus {
  outline: 1px solid var(--jp-brand-color1);
  outline-offset: 4px;
  -moz-outline-radius: 0px;
}

button.jp-Dialog-button:focus::-moz-focus-inner {
  border: 0;
}

button.jp-Dialog-close-button {
  padding: 0;
  height: 100%;
  min-width: unset;
  min-height: unset;
}

.jp-Dialog-header {
  display: flex;
  justify-content: space-between;
  flex: 0 0 auto;
  padding-bottom: 12px;
  font-size: var(--jp-ui-font-size3);
  font-weight: 400;
  color: var(--jp-ui-font-color0);
}

.jp-Dialog-body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  font-size: var(--jp-ui-font-size1);
  background: var(--jp-layout-color1);
  overflow: auto;
}

.jp-Dialog-footer {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  flex: 0 0 auto;
  margin-left: -12px;
  margin-right: -12px;
  padding: 12px;
}

.jp-Dialog-title {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.jp-Dialog-body > .jp-select-wrapper {
  width: 100%;
}

.jp-Dialog-body > button {
  padding: 0px 16px;
}

.jp-Dialog-body > label {
  line-height: 1.4;
  color: var(--jp-ui-font-color0);
}

.jp-Dialog-button.jp-mod-styled:not(:last-child) {
  margin-right: 12px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2016, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-HoverBox {
  position: fixed;
}

.jp-HoverBox.jp-mod-outofview {
  display: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-IFrame {
  width: 100%;
  height: 100%;
}

.jp-IFrame > iframe {
  border: none;
}

/*
When drag events occur, `p-mod-override-cursor` is added to the body.
Because iframes steal all cursor events, the following two rules are necessary
to suppress pointer events while resize drags are occurring. There may be a
better solution to this problem.
*/
body.lm-mod-override-cursor .jp-IFrame {
  position: relative;
}

body.lm-mod-override-cursor .jp-IFrame:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: transparent;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2016, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-MainAreaWidget > :focus {
  outline: none;
}

/**
 * google-material-color v1.2.6
 * https://github.com/danlevan/google-material-color
 */
:root {
  --md-red-50: #ffebee;
  --md-red-100: #ffcdd2;
  --md-red-200: #ef9a9a;
  --md-red-300: #e57373;
  --md-red-400: #ef5350;
  --md-red-500: #f44336;
  --md-red-600: #e53935;
  --md-red-700: #d32f2f;
  --md-red-800: #c62828;
  --md-red-900: #b71c1c;
  --md-red-A100: #ff8a80;
  --md-red-A200: #ff5252;
  --md-red-A400: #ff1744;
  --md-red-A700: #d50000;

  --md-pink-50: #fce4ec;
  --md-pink-100: #f8bbd0;
  --md-pink-200: #f48fb1;
  --md-pink-300: #f06292;
  --md-pink-400: #ec407a;
  --md-pink-500: #e91e63;
  --md-pink-600: #d81b60;
  --md-pink-700: #c2185b;
  --md-pink-800: #ad1457;
  --md-pink-900: #880e4f;
  --md-pink-A100: #ff80ab;
  --md-pink-A200: #ff4081;
  --md-pink-A400: #f50057;
  --md-pink-A700: #c51162;

  --md-purple-50: #f3e5f5;
  --md-purple-100: #e1bee7;
  --md-purple-200: #ce93d8;
  --md-purple-300: #ba68c8;
  --md-purple-400: #ab47bc;
  --md-purple-500: #9c27b0;
  --md-purple-600: #8e24aa;
  --md-purple-700: #7b1fa2;
  --md-purple-800: #6a1b9a;
  --md-purple-900: #4a148c;
  --md-purple-A100: #ea80fc;
  --md-purple-A200: #e040fb;
  --md-purple-A400: #d500f9;
  --md-purple-A700: #aa00ff;

  --md-deep-purple-50: #ede7f6;
  --md-deep-purple-100: #d1c4e9;
  --md-deep-purple-200: #b39ddb;
  --md-deep-purple-300: #9575cd;
  --md-deep-purple-400: #7e57c2;
  --md-deep-purple-500: #673ab7;
  --md-deep-purple-600: #5e35b1;
  --md-deep-purple-700: #512da8;
  --md-deep-purple-800: #4527a0;
  --md-deep-purple-900: #311b92;
  --md-deep-purple-A100: #b388ff;
  --md-deep-purple-A200: #7c4dff;
  --md-deep-purple-A400: #651fff;
  --md-deep-purple-A700: #6200ea;

  --md-indigo-50: #e8eaf6;
  --md-indigo-100: #c5cae9;
  --md-indigo-200: #9fa8da;
  --md-indigo-300: #7986cb;
  --md-indigo-400: #5c6bc0;
  --md-indigo-500: #3f51b5;
  --md-indigo-600: #3949ab;
  --md-indigo-700: #303f9f;
  --md-indigo-800: #283593;
  --md-indigo-900: #1a237e;
  --md-indigo-A100: #8c9eff;
  --md-indigo-A200: #536dfe;
  --md-indigo-A400: #3d5afe;
  --md-indigo-A700: #304ffe;

  --md-blue-50: #e3f2fd;
  --md-blue-100: #bbdefb;
  --md-blue-200: #90caf9;
  --md-blue-300: #64b5f6;
  --md-blue-400: #42a5f5;
  --md-blue-500: #2196f3;
  --md-blue-600: #1e88e5;
  --md-blue-700: #1976d2;
  --md-blue-800: #1565c0;
  --md-blue-900: #0d47a1;
  --md-blue-A100: #82b1ff;
  --md-blue-A200: #448aff;
  --md-blue-A400: #2979ff;
  --md-blue-A700: #2962ff;

  --md-light-blue-50: #e1f5fe;
  --md-light-blue-100: #b3e5fc;
  --md-light-blue-200: #81d4fa;
  --md-light-blue-300: #4fc3f7;
  --md-light-blue-400: #29b6f6;
  --md-light-blue-500: #03a9f4;
  --md-light-blue-600: #039be5;
  --md-light-blue-700: #0288d1;
  --md-light-blue-800: #0277bd;
  --md-light-blue-900: #01579b;
  --md-light-blue-A100: #80d8ff;
  --md-light-blue-A200: #40c4ff;
  --md-light-blue-A400: #00b0ff;
  --md-light-blue-A700: #0091ea;

  --md-cyan-50: #e0f7fa;
  --md-cyan-100: #b2ebf2;
  --md-cyan-200: #80deea;
  --md-cyan-300: #4dd0e1;
  --md-cyan-400: #26c6da;
  --md-cyan-500: #00bcd4;
  --md-cyan-600: #00acc1;
  --md-cyan-700: #0097a7;
  --md-cyan-800: #00838f;
  --md-cyan-900: #006064;
  --md-cyan-A100: #84ffff;
  --md-cyan-A200: #18ffff;
  --md-cyan-A400: #00e5ff;
  --md-cyan-A700: #00b8d4;

  --md-teal-50: #e0f2f1;
  --md-teal-100: #b2dfdb;
  --md-teal-200: #80cbc4;
  --md-teal-300: #4db6ac;
  --md-teal-400: #26a69a;
  --md-teal-500: #009688;
  --md-teal-600: #00897b;
  --md-teal-700: #00796b;
  --md-teal-800: #00695c;
  --md-teal-900: #004d40;
  --md-teal-A100: #a7ffeb;
  --md-teal-A200: #64ffda;
  --md-teal-A400: #1de9b6;
  --md-teal-A700: #00bfa5;

  --md-green-50: #e8f5e9;
  --md-green-100: #c8e6c9;
  --md-green-200: #a5d6a7;
  --md-green-300: #81c784;
  --md-green-400: #66bb6a;
  --md-green-500: #4caf50;
  --md-green-600: #43a047;
  --md-green-700: #388e3c;
  --md-green-800: #2e7d32;
  --md-green-900: #1b5e20;
  --md-green-A100: #b9f6ca;
  --md-green-A200: #69f0ae;
  --md-green-A400: #00e676;
  --md-green-A700: #00c853;

  --md-light-green-50: #f1f8e9;
  --md-light-green-100: #dcedc8;
  --md-light-green-200: #c5e1a5;
  --md-light-green-300: #aed581;
  --md-light-green-400: #9ccc65;
  --md-light-green-500: #8bc34a;
  --md-light-green-600: #7cb342;
  --md-light-green-700: #689f38;
  --md-light-green-800: #558b2f;
  --md-light-green-900: #33691e;
  --md-light-green-A100: #ccff90;
  --md-light-green-A200: #b2ff59;
  --md-light-green-A400: #76ff03;
  --md-light-green-A700: #64dd17;

  --md-lime-50: #f9fbe7;
  --md-lime-100: #f0f4c3;
  --md-lime-200: #e6ee9c;
  --md-lime-300: #dce775;
  --md-lime-400: #d4e157;
  --md-lime-500: #cddc39;
  --md-lime-600: #c0ca33;
  --md-lime-700: #afb42b;
  --md-lime-800: #9e9d24;
  --md-lime-900: #827717;
  --md-lime-A100: #f4ff81;
  --md-lime-A200: #eeff41;
  --md-lime-A400: #c6ff00;
  --md-lime-A700: #aeea00;

  --md-yellow-50: #fffde7;
  --md-yellow-100: #fff9c4;
  --md-yellow-200: #fff59d;
  --md-yellow-300: #fff176;
  --md-yellow-400: #ffee58;
  --md-yellow-500: #ffeb3b;
  --md-yellow-600: #fdd835;
  --md-yellow-700: #fbc02d;
  --md-yellow-800: #f9a825;
  --md-yellow-900: #f57f17;
  --md-yellow-A100: #ffff8d;
  --md-yellow-A200: #ffff00;
  --md-yellow-A400: #ffea00;
  --md-yellow-A700: #ffd600;

  --md-amber-50: #fff8e1;
  --md-amber-100: #ffecb3;
  --md-amber-200: #ffe082;
  --md-amber-300: #ffd54f;
  --md-amber-400: #ffca28;
  --md-amber-500: #ffc107;
  --md-amber-600: #ffb300;
  --md-amber-700: #ffa000;
  --md-amber-800: #ff8f00;
  --md-amber-900: #ff6f00;
  --md-amber-A100: #ffe57f;
  --md-amber-A200: #ffd740;
  --md-amber-A400: #ffc400;
  --md-amber-A700: #ffab00;

  --md-orange-50: #fff3e0;
  --md-orange-100: #ffe0b2;
  --md-orange-200: #ffcc80;
  --md-orange-300: #ffb74d;
  --md-orange-400: #ffa726;
  --md-orange-500: #ff9800;
  --md-orange-600: #fb8c00;
  --md-orange-700: #f57c00;
  --md-orange-800: #ef6c00;
  --md-orange-900: #e65100;
  --md-orange-A100: #ffd180;
  --md-orange-A200: #ffab40;
  --md-orange-A400: #ff9100;
  --md-orange-A700: #ff6d00;

  --md-deep-orange-50: #fbe9e7;
  --md-deep-orange-100: #ffccbc;
  --md-deep-orange-200: #ffab91;
  --md-deep-orange-300: #ff8a65;
  --md-deep-orange-400: #ff7043;
  --md-deep-orange-500: #ff5722;
  --md-deep-orange-600: #f4511e;
  --md-deep-orange-700: #e64a19;
  --md-deep-orange-800: #d84315;
  --md-deep-orange-900: #bf360c;
  --md-deep-orange-A100: #ff9e80;
  --md-deep-orange-A200: #ff6e40;
  --md-deep-orange-A400: #ff3d00;
  --md-deep-orange-A700: #dd2c00;

  --md-brown-50: #efebe9;
  --md-brown-100: #d7ccc8;
  --md-brown-200: #bcaaa4;
  --md-brown-300: #a1887f;
  --md-brown-400: #8d6e63;
  --md-brown-500: #795548;
  --md-brown-600: #6d4c41;
  --md-brown-700: #5d4037;
  --md-brown-800: #4e342e;
  --md-brown-900: #3e2723;

  --md-grey-50: #fafafa;
  --md-grey-100: #f5f5f5;
  --md-grey-200: #eeeeee;
  --md-grey-300: #e0e0e0;
  --md-grey-400: #bdbdbd;
  --md-grey-500: #9e9e9e;
  --md-grey-600: #757575;
  --md-grey-700: #616161;
  --md-grey-800: #424242;
  --md-grey-900: #212121;

  --md-blue-grey-50: #eceff1;
  --md-blue-grey-100: #cfd8dc;
  --md-blue-grey-200: #b0bec5;
  --md-blue-grey-300: #90a4ae;
  --md-blue-grey-400: #78909c;
  --md-blue-grey-500: #607d8b;
  --md-blue-grey-600: #546e7a;
  --md-blue-grey-700: #455a64;
  --md-blue-grey-800: #37474f;
  --md-blue-grey-900: #263238;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2017, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-Spinner {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: var(--jp-layout-color0);
  outline: none;
}

.jp-SpinnerContent {
  font-size: 10px;
  margin: 50px auto;
  text-indent: -9999em;
  width: 3em;
  height: 3em;
  border-radius: 50%;
  background: var(--jp-brand-color3);
  background: linear-gradient(
    to right,
    #f37626 10%,
    rgba(255, 255, 255, 0) 42%
  );
  position: relative;
  animation: load3 1s infinite linear, fadeIn 1s;
}

.jp-SpinnerContent:before {
  width: 50%;
  height: 50%;
  background: #f37626;
  border-radius: 100% 0 0 0;
  position: absolute;
  top: 0;
  left: 0;
  content: '';
}

.jp-SpinnerContent:after {
  background: var(--jp-layout-color0);
  width: 75%;
  height: 75%;
  border-radius: 50%;
  content: '';
  margin: auto;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}

@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes load3 {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2017, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

button.jp-mod-styled {
  font-size: var(--jp-ui-font-size1);
  color: var(--jp-ui-font-color0);
  border: none;
  box-sizing: border-box;
  text-align: center;
  line-height: 32px;
  height: 32px;
  padding: 0px 12px;
  letter-spacing: 0.8px;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

input.jp-mod-styled {
  background: var(--jp-input-background);
  height: 28px;
  box-sizing: border-box;
  border: var(--jp-border-width) solid var(--jp-border-color1);
  padding-left: 7px;
  padding-right: 7px;
  font-size: var(--jp-ui-font-size2);
  color: var(--jp-ui-font-color0);
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

input.jp-mod-styled:focus {
  border: var(--jp-border-width) solid var(--md-blue-500);
  box-shadow: inset 0 0 4px var(--md-blue-300);
}

.jp-select-wrapper {
  display: flex;
  position: relative;
  flex-direction: column;
  padding: 1px;
  background-color: var(--jp-layout-color1);
  height: 28px;
  box-sizing: border-box;
  margin-bottom: 12px;
}

.jp-select-wrapper.jp-mod-focused select.jp-mod-styled {
  border: var(--jp-border-width) solid var(--jp-input-active-border-color);
  box-shadow: var(--jp-input-box-shadow);
  background-color: var(--jp-input-active-background);
}

select.jp-mod-styled:hover {
  background-color: var(--jp-layout-color1);
  cursor: pointer;
  color: var(--jp-ui-font-color0);
  background-color: var(--jp-input-hover-background);
  box-shadow: inset 0 0px 1px rgba(0, 0, 0, 0.5);
}

select.jp-mod-styled {
  flex: 1 1 auto;
  height: 32px;
  width: 100%;
  font-size: var(--jp-ui-font-size2);
  background: var(--jp-input-background);
  color: var(--jp-ui-font-color0);
  padding: 0 25px 0 8px;
  border: var(--jp-border-width) solid var(--jp-input-border-color);
  border-radius: 0px;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2016, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

:root {
  --jp-private-toolbar-height: calc(
    28px + var(--jp-border-width)
  ); /* leave 28px for content */
}

.jp-Toolbar {
  color: var(--jp-ui-font-color1);
  flex: 0 0 auto;
  display: flex;
  flex-direction: row;
  border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
  box-shadow: var(--jp-toolbar-box-shadow);
  background: var(--jp-toolbar-background);
  min-height: var(--jp-toolbar-micro-height);
  padding: 2px;
  z-index: 1;
  overflow-x: hidden;
}

.jp-Toolbar:hover {
  overflow-x: auto;
}

/* Toolbar items */

.jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer {
  flex-grow: 1;
  flex-shrink: 1;
}

.jp-Toolbar-item.jp-Toolbar-kernelStatus {
  display: inline-block;
  width: 32px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px;
}

.jp-Toolbar > .jp-Toolbar-item {
  flex: 0 0 auto;
  display: flex;
  padding-left: 1px;
  padding-right: 1px;
  font-size: var(--jp-ui-font-size1);
  line-height: var(--jp-private-toolbar-height);
  height: 100%;
}

/* Toolbar buttons */

/* This is the div we use to wrap the react component into a Widget */
div.jp-ToolbarButton {
  color: transparent;
  border: none;
  box-sizing: border-box;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 0px;
  margin: 0px;
}

button.jp-ToolbarButtonComponent {
  background: var(--jp-layout-color1);
  border: none;
  box-sizing: border-box;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding: 0px 6px;
  margin: 0px;
  height: 24px;
  border-radius: var(--jp-border-radius);
  display: flex;
  align-items: center;
  text-align: center;
  font-size: 14px;
  min-width: unset;
  min-height: unset;
}

button.jp-ToolbarButtonComponent:disabled {
  opacity: 0.4;
}

button.jp-ToolbarButtonComponent span {
  padding: 0px;
  flex: 0 0 auto;
}

button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label {
  font-size: var(--jp-ui-font-size1);
  line-height: 100%;
  padding-left: 2px;
  color: var(--jp-ui-font-color1);
}

#jp-main-dock-panel[data-mode='single-document']
  .jp-MainAreaWidget
  > .jp-Toolbar.jp-Toolbar-micro {
  padding: 0;
  min-height: 0;
}

#jp-main-dock-panel[data-mode='single-document']
  .jp-MainAreaWidget
  > .jp-Toolbar {
  border: none;
  box-shadow: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2017, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Copyright (c) 2014-2017, PhosphorJS Contributors
|
| Distributed under the terms of the BSD 3-Clause License.
|
| The full license is in the file LICENSE, distributed with this software.
|----------------------------------------------------------------------------*/


/* <DEPRECATED> */ body.p-mod-override-cursor *, /* </DEPRECATED> */
body.lm-mod-override-cursor * {
  cursor: inherit !important;
}

/*-----------------------------------------------------------------------------
| Copyright (c) 2014-2016, Jupyter Development Team.
|
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-JSONEditor {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.jp-JSONEditor-host {
  flex: 1 1 auto;
  border: var(--jp-border-width) solid var(--jp-input-border-color);
  border-radius: 0px;
  background: var(--jp-layout-color0);
  min-height: 50px;
  padding: 1px;
}

.jp-JSONEditor.jp-mod-error .jp-JSONEditor-host {
  border-color: red;
  outline-color: red;
}

.jp-JSONEditor-header {
  display: flex;
  flex: 1 0 auto;
  padding: 0 0 0 12px;
}

.jp-JSONEditor-header label {
  flex: 0 0 auto;
}

.jp-JSONEditor-commitButton {
  height: 16px;
  width: 16px;
  background-size: 18px;
  background-repeat: no-repeat;
  background-position: center;
}

.jp-JSONEditor-host.jp-mod-focused {
  background-color: var(--jp-input-active-background);
  border: 1px solid var(--jp-input-active-border-color);
  box-shadow: var(--jp-input-box-shadow);
}

.jp-Editor.jp-mod-dropTarget {
  border: var(--jp-border-width) solid var(--jp-input-active-border-color);
  box-shadow: var(--jp-input-box-shadow);
}

/* BASICS */

.CodeMirror {
  /* Set height, width, borders, and global font properties here */
  font-family: monospace;
  height: 300px;
  color: black;
  direction: ltr;
}

/* PADDING */

.CodeMirror-lines {
  padding: 4px 0; /* Vertical padding around content */
}
.CodeMirror pre.CodeMirror-line,
.CodeMirror pre.CodeMirror-line-like {
  padding: 0 4px; /* Horizontal padding of content */
}

.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
  background-color: white; /* The little square between H and V scrollbars */
}

/* GUTTER */

.CodeMirror-gutters {
  border-right: 1px solid #ddd;
  background-color: #f7f7f7;
  white-space: nowrap;
}
.CodeMirror-linenumbers {}
.CodeMirror-linenumber {
  padding: 0 3px 0 5px;
  min-width: 20px;
  text-align: right;
  color: #999;
  white-space: nowrap;
}

.CodeMirror-guttermarker { color: black; }
.CodeMirror-guttermarker-subtle { color: #999; }

/* CURSOR */

.CodeMirror-cursor {
  border-left: 1px solid black;
  border-right: none;
  width: 0;
}
/* Shown when moving in bi-directional text */
.CodeMirror div.CodeMirror-secondarycursor {
  border-left: 1px solid silver;
}
.cm-fat-cursor .CodeMirror-cursor {
  width: auto;
  border: 0 !important;
  background: #7e7;
}
.cm-fat-cursor div.CodeMirror-cursors {
  z-index: 1;
}
.cm-fat-cursor-mark {
  background-color: rgba(20, 255, 20, 0.5);
  -webkit-animation: blink 1.06s steps(1) infinite;
  -moz-animation: blink 1.06s steps(1) infinite;
  animation: blink 1.06s steps(1) infinite;
}
.cm-animate-fat-cursor {
  width: auto;
  border: 0;
  -webkit-animation: blink 1.06s steps(1) infinite;
  -moz-animation: blink 1.06s steps(1) infinite;
  animation: blink 1.06s steps(1) infinite;
  background-color: #7e7;
}
@-moz-keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}
@-webkit-keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}
@keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}

/* Can style cursor different in overwrite (non-insert) mode */
.CodeMirror-overwrite .CodeMirror-cursor {}

.cm-tab { display: inline-block; text-decoration: inherit; }

.CodeMirror-rulers {
  position: absolute;
  left: 0; right: 0; top: -50px; bottom: 0;
  overflow: hidden;
}
.CodeMirror-ruler {
  border-left: 1px solid #ccc;
  top: 0; bottom: 0;
  position: absolute;
}

/* DEFAULT THEME */

.cm-s-default .cm-header {color: blue;}
.cm-s-default .cm-quote {color: #090;}
.cm-negative {color: #d44;}
.cm-positive {color: #292;}
.cm-header, .cm-strong {font-weight: bold;}
.cm-em {font-style: italic;}
.cm-link {text-decoration: underline;}
.cm-strikethrough {text-decoration: line-through;}

.cm-s-default .cm-keyword {color: #708;}
.cm-s-default .cm-atom {color: #219;}
.cm-s-default .cm-number {color: #164;}
.cm-s-default .cm-def {color: #00f;}
.cm-s-default .cm-variable,
.cm-s-default .cm-punctuation,
.cm-s-default .cm-property,
.cm-s-default .cm-operator {}
.cm-s-default .cm-variable-2 {color: #05a;}
.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}
.cm-s-default .cm-comment {color: #a50;}
.cm-s-default .cm-string {color: #a11;}
.cm-s-default .cm-string-2 {color: #f50;}
.cm-s-default .cm-meta {color: #555;}
.cm-s-default .cm-qualifier {color: #555;}
.cm-s-default .cm-builtin {color: #30a;}
.cm-s-default .cm-bracket {color: #997;}
.cm-s-default .cm-tag {color: #170;}
.cm-s-default .cm-attribute {color: #00c;}
.cm-s-default .cm-hr {color: #999;}
.cm-s-default .cm-link {color: #00c;}

.cm-s-default .cm-error {color: #f00;}
.cm-invalidchar {color: #f00;}

.CodeMirror-composing { border-bottom: 2px solid; }

/* Default styles for common addons */

div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}
div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}
.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
.CodeMirror-activeline-background {background: #e8f2ff;}

/* STOP */

/* The rest of this file contains styles related to the mechanics of
   the editor. You probably shouldn't touch them. */

.CodeMirror {
  position: relative;
  overflow: hidden;
  background: white;
}

.CodeMirror-scroll {
  overflow: scroll !important; /* Things will break if this is overridden */
  /* 50px is the magic margin used to hide the element's real scrollbars */
  /* See overflow: hidden in .CodeMirror */
  margin-bottom: -50px; margin-right: -50px;
  padding-bottom: 50px;
  height: 100%;
  outline: none; /* Prevent dragging from highlighting the element */
  position: relative;
}
.CodeMirror-sizer {
  position: relative;
  border-right: 50px solid transparent;
}

/* The fake, visible scrollbars. Used to force redraw during scrolling
   before actual scrolling happens, thus preventing shaking and
   flickering artifacts. */
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
  position: absolute;
  z-index: 6;
  display: none;
}
.CodeMirror-vscrollbar {
  right: 0; top: 0;
  overflow-x: hidden;
  overflow-y: scroll;
}
.CodeMirror-hscrollbar {
  bottom: 0; left: 0;
  overflow-y: hidden;
  overflow-x: scroll;
}
.CodeMirror-scrollbar-filler {
  right: 0; bottom: 0;
}
.CodeMirror-gutter-filler {
  left: 0; bottom: 0;
}

.CodeMirror-gutters {
  position: absolute; left: 0; top: 0;
  min-height: 100%;
  z-index: 3;
}
.CodeMirror-gutter {
  white-space: normal;
  height: 100%;
  display: inline-block;
  vertical-align: top;
  margin-bottom: -50px;
}
.CodeMirror-gutter-wrapper {
  position: absolute;
  z-index: 4;
  background: none !important;
  border: none !important;
}
.CodeMirror-gutter-background {
  position: absolute;
  top: 0; bottom: 0;
  z-index: 4;
}
.CodeMirror-gutter-elt {
  position: absolute;
  cursor: default;
  z-index: 4;
}
.CodeMirror-gutter-wrapper ::selection { background-color: transparent }
.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }

.CodeMirror-lines {
  cursor: text;
  min-height: 1px; /* prevents collapsing before first draw */
}
.CodeMirror pre.CodeMirror-line,
.CodeMirror pre.CodeMirror-line-like {
  /* Reset some styles that the rest of the page might have set */
  -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
  border-width: 0;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  margin: 0;
  white-space: pre;
  word-wrap: normal;
  line-height: inherit;
  color: inherit;
  z-index: 2;
  position: relative;
  overflow: visible;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-variant-ligatures: contextual;
  font-variant-ligatures: contextual;
}
.CodeMirror-wrap pre.CodeMirror-line,
.CodeMirror-wrap pre.CodeMirror-line-like {
  word-wrap: break-word;
  white-space: pre-wrap;
  word-break: normal;
}

.CodeMirror-linebackground {
  position: absolute;
  left: 0; right: 0; top: 0; bottom: 0;
  z-index: 0;
}

.CodeMirror-linewidget {
  position: relative;
  z-index: 2;
  padding: 0.1px; /* Force widget margins to stay inside of the container */
}

.CodeMirror-widget {}

.CodeMirror-rtl pre { direction: rtl; }

.CodeMirror-code {
  outline: none;
}

/* Force content-box sizing for the elements where we expect it */
.CodeMirror-scroll,
.CodeMirror-sizer,
.CodeMirror-gutter,
.CodeMirror-gutters,
.CodeMirror-linenumber {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
}

.CodeMirror-measure {
  position: absolute;
  width: 100%;
  height: 0;
  overflow: hidden;
  visibility: hidden;
}

.CodeMirror-cursor {
  position: absolute;
  pointer-events: none;
}
.CodeMirror-measure pre { position: static; }

div.CodeMirror-cursors {
  visibility: hidden;
  position: relative;
  z-index: 3;
}
div.CodeMirror-dragcursors {
  visibility: visible;
}

.CodeMirror-focused div.CodeMirror-cursors {
  visibility: visible;
}

.CodeMirror-selected { background: #d9d9d9; }
.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
.CodeMirror-crosshair { cursor: crosshair; }
.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }

.cm-searching {
  background-color: #ffa;
  background-color: rgba(255, 255, 0, .4);
}

/* Used to force a border model for a node */
.cm-force-border { padding-right: .1px; }

@media print {
  /* Hide the cursor when printing */
  .CodeMirror div.CodeMirror-cursors {
    visibility: hidden;
  }
}

/* See issue #2901 */
.cm-tab-wrap-hack:after { content: ''; }

/* Help users use markselection to safely style text background */
span.CodeMirror-selectedtext { background: none; }

.CodeMirror-dialog {
  position: absolute;
  left: 0; right: 0;
  background: inherit;
  z-index: 15;
  padding: .1em .8em;
  overflow: hidden;
  color: inherit;
}

.CodeMirror-dialog-top {
  border-bottom: 1px solid #eee;
  top: 0;
}

.CodeMirror-dialog-bottom {
  border-top: 1px solid #eee;
  bottom: 0;
}

.CodeMirror-dialog input {
  border: none;
  outline: none;
  background: transparent;
  width: 20em;
  color: inherit;
  font-family: monospace;
}

.CodeMirror-dialog button {
  font-size: 70%;
}

.CodeMirror-foldmarker {
  color: blue;
  text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px;
  font-family: arial;
  line-height: .3;
  cursor: pointer;
}
.CodeMirror-foldgutter {
  width: .7em;
}
.CodeMirror-foldgutter-open,
.CodeMirror-foldgutter-folded {
  cursor: pointer;
}
.CodeMirror-foldgutter-open:after {
  content: "\25BE";
}
.CodeMirror-foldgutter-folded:after {
  content: "\25B8";
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.CodeMirror {
  line-height: var(--jp-code-line-height);
  font-size: var(--jp-code-font-size);
  font-family: var(--jp-code-font-family);
  border: 0;
  border-radius: 0;
  height: auto;
  /* Changed to auto to autogrow */
}

.CodeMirror pre {
  padding: 0 var(--jp-code-padding);
}

.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-dialog {
  background-color: var(--jp-layout-color0);
  color: var(--jp-content-font-color1);
}

/* This causes https://github.com/jupyter/jupyterlab/issues/522 */
/* May not cause it not because we changed it! */
.CodeMirror-lines {
  padding: var(--jp-code-padding) 0;
}

.CodeMirror-linenumber {
  padding: 0 8px;
}

.jp-CodeMirrorEditor {
  cursor: text;
}

.jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
  border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color);
}

/* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */
@media screen and (min-width: 2138px) and (max-width: 4319px) {
  .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
    border-left: var(--jp-code-cursor-width1) solid
      var(--jp-editor-cursor-color);
  }
}

/* When zoomed out less than 33% */
@media screen and (min-width: 4320px) {
  .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
    border-left: var(--jp-code-cursor-width2) solid
      var(--jp-editor-cursor-color);
  }
}

.CodeMirror.jp-mod-readOnly .CodeMirror-cursor {
  display: none;
}

.CodeMirror-gutters {
  border-right: 1px solid var(--jp-border-color2);
  background-color: var(--jp-layout-color0);
}

.jp-CollaboratorCursor {
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: none;
  border-bottom: 3px solid;
  background-clip: content-box;
  margin-left: -5px;
  margin-right: -5px;
}

.CodeMirror-selectedtext.cm-searching {
  background-color: var(--jp-search-selected-match-background-color) !important;
  color: var(--jp-search-selected-match-color) !important;
}

.cm-searching {
  background-color: var(
    --jp-search-unselected-match-background-color
  ) !important;
  color: var(--jp-search-unselected-match-color) !important;
}

.CodeMirror-focused .CodeMirror-selected {
  background-color: var(--jp-editor-selected-focused-background);
}

.CodeMirror-selected {
  background-color: var(--jp-editor-selected-background);
}

.jp-CollaboratorCursor-hover {
  position: absolute;
  z-index: 1;
  transform: translateX(-50%);
  color: white;
  border-radius: 3px;
  padding-left: 4px;
  padding-right: 4px;
  padding-top: 1px;
  padding-bottom: 1px;
  text-align: center;
  font-size: var(--jp-ui-font-size1);
  white-space: nowrap;
}

.jp-CodeMirror-ruler {
  border-left: 1px dashed var(--jp-border-color2);
}

/**
 * Here is our jupyter theme for CodeMirror syntax highlighting
 * This is used in our marked.js syntax highlighting and CodeMirror itself
 * The string "jupyter" is set in ../codemirror/widget.DEFAULT_CODEMIRROR_THEME
 * This came from the classic notebook, which came form highlight.js/GitHub
 */

/**
 * CodeMirror themes are handling the background/color in this way. This works
 * fine for CodeMirror editors outside the notebook, but the notebook styles
 * these things differently.
 */
.CodeMirror.cm-s-jupyter {
  background: var(--jp-layout-color0);
  color: var(--jp-content-font-color1);
}

/* In the notebook, we want this styling to be handled by its container */
.jp-CodeConsole .CodeMirror.cm-s-jupyter,
.jp-Notebook .CodeMirror.cm-s-jupyter {
  background: transparent;
}

.cm-s-jupyter .CodeMirror-cursor {
  border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color);
}
.cm-s-jupyter span.cm-keyword {
  color: var(--jp-mirror-editor-keyword-color);
  font-weight: bold;
}
.cm-s-jupyter span.cm-atom {
  color: var(--jp-mirror-editor-atom-color);
}
.cm-s-jupyter span.cm-number {
  color: var(--jp-mirror-editor-number-color);
}
.cm-s-jupyter span.cm-def {
  color: var(--jp-mirror-editor-def-color);
}
.cm-s-jupyter span.cm-variable {
  color: var(--jp-mirror-editor-variable-color);
}
.cm-s-jupyter span.cm-variable-2 {
  color: var(--jp-mirror-editor-variable-2-color);
}
.cm-s-jupyter span.cm-variable-3 {
  color: var(--jp-mirror-editor-variable-3-color);
}
.cm-s-jupyter span.cm-punctuation {
  color: var(--jp-mirror-editor-punctuation-color);
}
.cm-s-jupyter span.cm-property {
  color: var(--jp-mirror-editor-property-color);
}
.cm-s-jupyter span.cm-operator {
  color: var(--jp-mirror-editor-operator-color);
  font-weight: bold;
}
.cm-s-jupyter span.cm-comment {
  color: var(--jp-mirror-editor-comment-color);
  font-style: italic;
}
.cm-s-jupyter span.cm-string {
  color: var(--jp-mirror-editor-string-color);
}
.cm-s-jupyter span.cm-string-2 {
  color: var(--jp-mirror-editor-string-2-color);
}
.cm-s-jupyter span.cm-meta {
  color: var(--jp-mirror-editor-meta-color);
}
.cm-s-jupyter span.cm-qualifier {
  color: var(--jp-mirror-editor-qualifier-color);
}
.cm-s-jupyter span.cm-builtin {
  color: var(--jp-mirror-editor-builtin-color);
}
.cm-s-jupyter span.cm-bracket {
  color: var(--jp-mirror-editor-bracket-color);
}
.cm-s-jupyter span.cm-tag {
  color: var(--jp-mirror-editor-tag-color);
}
.cm-s-jupyter span.cm-attribute {
  color: var(--jp-mirror-editor-attribute-color);
}
.cm-s-jupyter span.cm-header {
  color: var(--jp-mirror-editor-header-color);
}
.cm-s-jupyter span.cm-quote {
  color: var(--jp-mirror-editor-quote-color);
}
.cm-s-jupyter span.cm-link {
  color: var(--jp-mirror-editor-link-color);
}
.cm-s-jupyter span.cm-error {
  color: var(--jp-mirror-editor-error-color);
}
.cm-s-jupyter span.cm-hr {
  color: #999;
}

.cm-s-jupyter span.cm-tab {
  background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAMCAYAAAAkuj5RAAAAAXNSR0IArs4c6QAAAGFJREFUSMft1LsRQFAQheHPowAKoACx3IgEKtaEHujDjORSgWTH/ZOdnZOcM/sgk/kFFWY0qV8foQwS4MKBCS3qR6ixBJvElOobYAtivseIE120FaowJPN75GMu8j/LfMwNjh4HUpwg4LUAAAAASUVORK5CYII=);
  background-position: right;
  background-repeat: no-repeat;
}

.cm-s-jupyter .CodeMirror-activeline-background,
.cm-s-jupyter .CodeMirror-gutter {
  background-color: var(--jp-layout-color2);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| RenderedText
|----------------------------------------------------------------------------*/

:root {
  /* This is the padding value to fill the gaps between lines containing spans with background color. */
  --jp-private-code-span-padding: calc(
    (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2
  );
}

.jp-RenderedText {
  text-align: left;
  padding-left: var(--jp-code-padding);
  line-height: var(--jp-code-line-height);
  font-family: var(--jp-code-font-family);
}

.jp-RenderedText pre,
.jp-RenderedJavaScript pre,
.jp-RenderedHTMLCommon pre {
  color: var(--jp-content-font-color1);
  font-size: var(--jp-code-font-size);
  border: none;
  margin: 0px;
  padding: 0px;
}

.jp-RenderedText pre a:link {
  text-decoration: none;
  color: var(--jp-content-link-color);
}
.jp-RenderedText pre a:hover {
  text-decoration: underline;
  color: var(--jp-content-link-color);
}
.jp-RenderedText pre a:visited {
  text-decoration: none;
  color: var(--jp-content-link-color);
}

/* console foregrounds and backgrounds */
.jp-RenderedText pre .ansi-black-fg {
  color: #3e424d;
}
.jp-RenderedText pre .ansi-red-fg {
  color: #e75c58;
}
.jp-RenderedText pre .ansi-green-fg {
  color: #00a250;
}
.jp-RenderedText pre .ansi-yellow-fg {
  color: #ddb62b;
}
.jp-RenderedText pre .ansi-blue-fg {
  color: #208ffb;
}
.jp-RenderedText pre .ansi-magenta-fg {
  color: #d160c4;
}
.jp-RenderedText pre .ansi-cyan-fg {
  color: #60c6c8;
}
.jp-RenderedText pre .ansi-white-fg {
  color: #c5c1b4;
}

.jp-RenderedText pre .ansi-black-bg {
  background-color: #3e424d;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-red-bg {
  background-color: #e75c58;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-green-bg {
  background-color: #00a250;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-yellow-bg {
  background-color: #ddb62b;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-blue-bg {
  background-color: #208ffb;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-magenta-bg {
  background-color: #d160c4;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-cyan-bg {
  background-color: #60c6c8;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-white-bg {
  background-color: #c5c1b4;
  padding: var(--jp-private-code-span-padding) 0;
}

.jp-RenderedText pre .ansi-black-intense-fg {
  color: #282c36;
}
.jp-RenderedText pre .ansi-red-intense-fg {
  color: #b22b31;
}
.jp-RenderedText pre .ansi-green-intense-fg {
  color: #007427;
}
.jp-RenderedText pre .ansi-yellow-intense-fg {
  color: #b27d12;
}
.jp-RenderedText pre .ansi-blue-intense-fg {
  color: #0065ca;
}
.jp-RenderedText pre .ansi-magenta-intense-fg {
  color: #a03196;
}
.jp-RenderedText pre .ansi-cyan-intense-fg {
  color: #258f8f;
}
.jp-RenderedText pre .ansi-white-intense-fg {
  color: #a1a6b2;
}

.jp-RenderedText pre .ansi-black-intense-bg {
  background-color: #282c36;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-red-intense-bg {
  background-color: #b22b31;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-green-intense-bg {
  background-color: #007427;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-yellow-intense-bg {
  background-color: #b27d12;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-blue-intense-bg {
  background-color: #0065ca;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-magenta-intense-bg {
  background-color: #a03196;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-cyan-intense-bg {
  background-color: #258f8f;
  padding: var(--jp-private-code-span-padding) 0;
}
.jp-RenderedText pre .ansi-white-intense-bg {
  background-color: #a1a6b2;
  padding: var(--jp-private-code-span-padding) 0;
}

.jp-RenderedText pre .ansi-default-inverse-fg {
  color: var(--jp-ui-inverse-font-color0);
}
.jp-RenderedText pre .ansi-default-inverse-bg {
  background-color: var(--jp-inverse-layout-color0);
  padding: var(--jp-private-code-span-padding) 0;
}

.jp-RenderedText pre .ansi-bold {
  font-weight: bold;
}
.jp-RenderedText pre .ansi-underline {
  text-decoration: underline;
}

.jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] {
  background: var(--jp-rendermime-error-background);
  padding-top: var(--jp-code-padding);
}

/*-----------------------------------------------------------------------------
| RenderedLatex
|----------------------------------------------------------------------------*/

.jp-RenderedLatex {
  color: var(--jp-content-font-color1);
  font-size: var(--jp-content-font-size1);
  line-height: var(--jp-content-line-height);
}

/* Left-justify outputs.*/
.jp-OutputArea-output.jp-RenderedLatex {
  padding: var(--jp-code-padding);
  text-align: left;
}

/*-----------------------------------------------------------------------------
| RenderedHTML
|----------------------------------------------------------------------------*/

.jp-RenderedHTMLCommon {
  color: var(--jp-content-font-color1);
  font-family: var(--jp-content-font-family);
  font-size: var(--jp-content-font-size1);
  line-height: var(--jp-content-line-height);
  /* Give a bit more R padding on Markdown text to keep line lengths reasonable */
  padding-right: 20px;
}

.jp-RenderedHTMLCommon em {
  font-style: italic;
}

.jp-RenderedHTMLCommon strong {
  font-weight: bold;
}

.jp-RenderedHTMLCommon u {
  text-decoration: underline;
}

.jp-RenderedHTMLCommon a:link {
  text-decoration: none;
  color: var(--jp-content-link-color);
}

.jp-RenderedHTMLCommon a:hover {
  text-decoration: underline;
  color: var(--jp-content-link-color);
}

.jp-RenderedHTMLCommon a:visited {
  text-decoration: none;
  color: var(--jp-content-link-color);
}

/* Headings */

.jp-RenderedHTMLCommon h1,
.jp-RenderedHTMLCommon h2,
.jp-RenderedHTMLCommon h3,
.jp-RenderedHTMLCommon h4,
.jp-RenderedHTMLCommon h5,
.jp-RenderedHTMLCommon h6 {
  line-height: var(--jp-content-heading-line-height);
  font-weight: var(--jp-content-heading-font-weight);
  font-style: normal;
  margin: var(--jp-content-heading-margin-top) 0
    var(--jp-content-heading-margin-bottom) 0;
}

.jp-RenderedHTMLCommon h1:first-child,
.jp-RenderedHTMLCommon h2:first-child,
.jp-RenderedHTMLCommon h3:first-child,
.jp-RenderedHTMLCommon h4:first-child,
.jp-RenderedHTMLCommon h5:first-child,
.jp-RenderedHTMLCommon h6:first-child {
  margin-top: calc(0.5 * var(--jp-content-heading-margin-top));
}

.jp-RenderedHTMLCommon h1:last-child,
.jp-RenderedHTMLCommon h2:last-child,
.jp-RenderedHTMLCommon h3:last-child,
.jp-RenderedHTMLCommon h4:last-child,
.jp-RenderedHTMLCommon h5:last-child,
.jp-RenderedHTMLCommon h6:last-child {
  margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom));
}

.jp-RenderedHTMLCommon h1 {
  font-size: var(--jp-content-font-size5);
}

.jp-RenderedHTMLCommon h2 {
  font-size: var(--jp-content-font-size4);
}

.jp-RenderedHTMLCommon h3 {
  font-size: var(--jp-content-font-size3);
}

.jp-RenderedHTMLCommon h4 {
  font-size: var(--jp-content-font-size2);
}

.jp-RenderedHTMLCommon h5 {
  font-size: var(--jp-content-font-size1);
}

.jp-RenderedHTMLCommon h6 {
  font-size: var(--jp-content-font-size0);
}

/* Lists */

.jp-RenderedHTMLCommon ul:not(.list-inline),
.jp-RenderedHTMLCommon ol:not(.list-inline) {
  padding-left: 2em;
}

.jp-RenderedHTMLCommon ul {
  list-style: disc;
}

.jp-RenderedHTMLCommon ul ul {
  list-style: square;
}

.jp-RenderedHTMLCommon ul ul ul {
  list-style: circle;
}

.jp-RenderedHTMLCommon ol {
  list-style: decimal;
}

.jp-RenderedHTMLCommon ol ol {
  list-style: upper-alpha;
}

.jp-RenderedHTMLCommon ol ol ol {
  list-style: lower-alpha;
}

.jp-RenderedHTMLCommon ol ol ol ol {
  list-style: lower-roman;
}

.jp-RenderedHTMLCommon ol ol ol ol ol {
  list-style: decimal;
}

.jp-RenderedHTMLCommon ol,
.jp-RenderedHTMLCommon ul {
  margin-bottom: 1em;
}

.jp-RenderedHTMLCommon ul ul,
.jp-RenderedHTMLCommon ul ol,
.jp-RenderedHTMLCommon ol ul,
.jp-RenderedHTMLCommon ol ol {
  margin-bottom: 0em;
}

.jp-RenderedHTMLCommon hr {
  color: var(--jp-border-color2);
  background-color: var(--jp-border-color1);
  margin-top: 1em;
  margin-bottom: 1em;
}

.jp-RenderedHTMLCommon > pre {
  margin: 1.5em 2em;
}

.jp-RenderedHTMLCommon pre,
.jp-RenderedHTMLCommon code {
  border: 0;
  background-color: var(--jp-layout-color0);
  color: var(--jp-content-font-color1);
  font-family: var(--jp-code-font-family);
  font-size: inherit;
  line-height: var(--jp-code-line-height);
  padding: 0;
  white-space: pre-wrap;
}

.jp-RenderedHTMLCommon :not(pre) > code {
  background-color: var(--jp-layout-color2);
  padding: 1px 5px;
}

/* Tables */

.jp-RenderedHTMLCommon table {
  border-collapse: collapse;
  border-spacing: 0;
  border: none;
  color: var(--jp-ui-font-color1);
  font-size: 12px;
  table-layout: fixed;
  margin-left: auto;
  margin-right: auto;
}

.jp-RenderedHTMLCommon thead {
  border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
  vertical-align: bottom;
}

.jp-RenderedHTMLCommon td,
.jp-RenderedHTMLCommon th,
.jp-RenderedHTMLCommon tr {
  vertical-align: middle;
  padding: 0.5em 0.5em;
  line-height: normal;
  white-space: normal;
  max-width: none;
  border: none;
}

.jp-RenderedMarkdown.jp-RenderedHTMLCommon td,
.jp-RenderedMarkdown.jp-RenderedHTMLCommon th {
  max-width: none;
}

:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td,
:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th,
:not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr {
  text-align: right;
}

.jp-RenderedHTMLCommon th {
  font-weight: bold;
}

.jp-RenderedHTMLCommon tbody tr:nth-child(odd) {
  background: var(--jp-layout-color0);
}

.jp-RenderedHTMLCommon tbody tr:nth-child(even) {
  background: var(--jp-rendermime-table-row-background);
}

.jp-RenderedHTMLCommon tbody tr:hover {
  background: var(--jp-rendermime-table-row-hover-background);
}

.jp-RenderedHTMLCommon table {
  margin-bottom: 1em;
}

.jp-RenderedHTMLCommon p {
  text-align: left;
  margin: 0px;
}

.jp-RenderedHTMLCommon p {
  margin-bottom: 1em;
}

.jp-RenderedHTMLCommon img {
  -moz-force-broken-image-icon: 1;
}

/* Restrict to direct children as other images could be nested in other content. */
.jp-RenderedHTMLCommon > img {
  display: block;
  margin-left: 0;
  margin-right: 0;
  margin-bottom: 1em;
}

/* Change color behind transparent images if they need it... */
[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background {
  background-color: var(--jp-inverse-layout-color1);
}
[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background {
  background-color: var(--jp-inverse-layout-color1);
}
/* ...or leave it untouched if they don't */
[data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-dark-background {
}
[data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-light-background {
}

.jp-RenderedHTMLCommon img,
.jp-RenderedImage img,
.jp-RenderedHTMLCommon svg,
.jp-RenderedSVG svg {
  max-width: 100%;
  height: auto;
}

.jp-RenderedHTMLCommon img.jp-mod-unconfined,
.jp-RenderedImage img.jp-mod-unconfined,
.jp-RenderedHTMLCommon svg.jp-mod-unconfined,
.jp-RenderedSVG svg.jp-mod-unconfined {
  max-width: none;
}

.jp-RenderedHTMLCommon .alert {
  padding: var(--jp-notebook-padding);
  border: var(--jp-border-width) solid transparent;
  border-radius: var(--jp-border-radius);
  margin-bottom: 1em;
}

.jp-RenderedHTMLCommon .alert-info {
  color: var(--jp-info-color0);
  background-color: var(--jp-info-color3);
  border-color: var(--jp-info-color2);
}
.jp-RenderedHTMLCommon .alert-info hr {
  border-color: var(--jp-info-color3);
}
.jp-RenderedHTMLCommon .alert-info > p:last-child,
.jp-RenderedHTMLCommon .alert-info > ul:last-child {
  margin-bottom: 0;
}

.jp-RenderedHTMLCommon .alert-warning {
  color: var(--jp-warn-color0);
  background-color: var(--jp-warn-color3);
  border-color: var(--jp-warn-color2);
}
.jp-RenderedHTMLCommon .alert-warning hr {
  border-color: var(--jp-warn-color3);
}
.jp-RenderedHTMLCommon .alert-warning > p:last-child,
.jp-RenderedHTMLCommon .alert-warning > ul:last-child {
  margin-bottom: 0;
}

.jp-RenderedHTMLCommon .alert-success {
  color: var(--jp-success-color0);
  background-color: var(--jp-success-color3);
  border-color: var(--jp-success-color2);
}
.jp-RenderedHTMLCommon .alert-success hr {
  border-color: var(--jp-success-color3);
}
.jp-RenderedHTMLCommon .alert-success > p:last-child,
.jp-RenderedHTMLCommon .alert-success > ul:last-child {
  margin-bottom: 0;
}

.jp-RenderedHTMLCommon .alert-danger {
  color: var(--jp-error-color0);
  background-color: var(--jp-error-color3);
  border-color: var(--jp-error-color2);
}
.jp-RenderedHTMLCommon .alert-danger hr {
  border-color: var(--jp-error-color3);
}
.jp-RenderedHTMLCommon .alert-danger > p:last-child,
.jp-RenderedHTMLCommon .alert-danger > ul:last-child {
  margin-bottom: 0;
}

.jp-RenderedHTMLCommon blockquote {
  margin: 1em 2em;
  padding: 0 1em;
  border-left: 5px solid var(--jp-border-color2);
}

a.jp-InternalAnchorLink {
  visibility: hidden;
  margin-left: 8px;
  color: var(--md-blue-800);
}

h1:hover .jp-InternalAnchorLink,
h2:hover .jp-InternalAnchorLink,
h3:hover .jp-InternalAnchorLink,
h4:hover .jp-InternalAnchorLink,
h5:hover .jp-InternalAnchorLink,
h6:hover .jp-InternalAnchorLink {
  visibility: visible;
}

.jp-RenderedHTMLCommon kbd {
  background-color: var(--jp-rendermime-table-row-background);
  border: 1px solid var(--jp-border-color0);
  border-bottom-color: var(--jp-border-color2);
  border-radius: 3px;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);
  display: inline-block;
  font-size: 0.8em;
  line-height: 1em;
  padding: 0.2em 0.5em;
}

/* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0.
 * At the bottom of cells this is a bit too much as there is also spacing
 * between cells. Going all the way to 0 gets too tight between markdown and
 * code cells.
 */
.jp-RenderedHTMLCommon > *:last-child {
  margin-bottom: 0.5em;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-MimeDocument {
  outline: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Variables
|----------------------------------------------------------------------------*/

:root {
  --jp-private-filebrowser-button-height: 28px;
  --jp-private-filebrowser-button-width: 48px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-FileBrowser {
  display: flex;
  flex-direction: column;
  color: var(--jp-ui-font-color1);
  background: var(--jp-layout-color1);
  /* This is needed so that all font sizing of children done in ems is
   * relative to this base size */
  font-size: var(--jp-ui-font-size1);
}

.jp-FileBrowser-toolbar.jp-Toolbar {
  border-bottom: none;
  height: auto;
  margin: var(--jp-toolbar-header-margin);
  box-shadow: none;
}

.jp-BreadCrumbs {
  flex: 0 0 auto;
  margin: 8px 12px 8px 12px;
}

.jp-BreadCrumbs-item {
  margin: 0px 2px;
  padding: 0px 2px;
  border-radius: var(--jp-border-radius);
  cursor: pointer;
}

.jp-BreadCrumbs-item:hover {
  background-color: var(--jp-layout-color2);
}

.jp-BreadCrumbs-item:first-child {
  margin-left: 0px;
}

.jp-BreadCrumbs-item.jp-mod-dropTarget {
  background-color: var(--jp-brand-color2);
  opacity: 0.7;
}

/*-----------------------------------------------------------------------------
| Buttons
|----------------------------------------------------------------------------*/

.jp-FileBrowser-toolbar.jp-Toolbar {
  padding: 0px;
  margin: 8px 12px 0px 12px;
}

.jp-FileBrowser-toolbar.jp-Toolbar {
  justify-content: flex-start;
}

.jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item {
  flex: 0 0 auto;
  padding-left: 0px;
  padding-right: 2px;
}

.jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent {
  width: 40px;
}

.jp-FileBrowser-toolbar.jp-Toolbar
  .jp-Toolbar-item:first-child
  .jp-ToolbarButtonComponent {
  width: 72px;
  background: var(--jp-brand-color1);
}

.jp-FileBrowser-toolbar.jp-Toolbar
  .jp-Toolbar-item:first-child
  .jp-ToolbarButtonComponent
  .jp-icon3 {
  fill: white;
}

/*-----------------------------------------------------------------------------
| Other styles
|----------------------------------------------------------------------------*/

.jp-FileDialog.jp-mod-conflict input {
  color: red;
}

.jp-FileDialog .jp-new-name-title {
  margin-top: 12px;
}

.jp-LastModified-hidden {
  display: none;
}

.jp-FileBrowser-filterBox {
  padding: 0px;
  flex: 0 0 auto;
  margin: 8px 12px 0px 12px;
}

/*-----------------------------------------------------------------------------
| DirListing
|----------------------------------------------------------------------------*/

.jp-DirListing {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  outline: 0;
}

.jp-DirListing-header {
  flex: 0 0 auto;
  display: flex;
  flex-direction: row;
  overflow: hidden;
  border-top: var(--jp-border-width) solid var(--jp-border-color2);
  border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
  box-shadow: var(--jp-toolbar-box-shadow);
  z-index: 2;
}

.jp-DirListing-headerItem {
  padding: 4px 12px 2px 12px;
  font-weight: 500;
}

.jp-DirListing-headerItem:hover {
  background: var(--jp-layout-color2);
}

.jp-DirListing-headerItem.jp-id-name {
  flex: 1 0 84px;
}

.jp-DirListing-headerItem.jp-id-modified {
  flex: 0 0 112px;
  border-left: var(--jp-border-width) solid var(--jp-border-color2);
  text-align: right;
}

.jp-id-narrow {
  display: none;
  flex: 0 0 5px;
  padding: 4px 4px;
  border-left: var(--jp-border-width) solid var(--jp-border-color2);
  text-align: right;
  color: var(--jp-border-color2);
}

.jp-DirListing-narrow .jp-id-narrow {
  display: block;
}

.jp-DirListing-narrow .jp-id-modified,
.jp-DirListing-narrow .jp-DirListing-itemModified {
  display: none;
}

.jp-DirListing-headerItem.jp-mod-selected {
  font-weight: 600;
}

/* increase specificity to override bundled default */
.jp-DirListing-content {
  flex: 1 1 auto;
  margin: 0;
  padding: 0;
  list-style-type: none;
  overflow: auto;
  background-color: var(--jp-layout-color1);
}

.jp-DirListing-content mark {
  color: var(--jp-ui-font-color0);
  background-color: transparent;
  font-weight: bold;
}

/* Style the directory listing content when a user drops a file to upload */
.jp-DirListing.jp-mod-native-drop .jp-DirListing-content {
  outline: 5px dashed rgba(128, 128, 128, 0.5);
  outline-offset: -10px;
  cursor: copy;
}

.jp-DirListing-item {
  display: flex;
  flex-direction: row;
  padding: 4px 12px;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.jp-DirListing-item[data-is-dot] {
  opacity: 75%;
}

.jp-DirListing-item.jp-mod-selected {
  color: white;
  background: var(--jp-brand-color1);
}

.jp-DirListing-item.jp-mod-dropTarget {
  background: var(--jp-brand-color3);
}

.jp-DirListing-item:hover:not(.jp-mod-selected) {
  background: var(--jp-layout-color2);
}

.jp-DirListing-itemIcon {
  flex: 0 0 20px;
  margin-right: 4px;
}

.jp-DirListing-itemText {
  flex: 1 0 64px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  user-select: none;
}

.jp-DirListing-itemModified {
  flex: 0 0 125px;
  text-align: right;
}

.jp-DirListing-editor {
  flex: 1 0 64px;
  outline: none;
  border: none;
}

.jp-DirListing-item.jp-mod-running .jp-DirListing-itemIcon:before {
  color: limegreen;
  content: '\25CF';
  font-size: 8px;
  position: absolute;
  left: -8px;
}

.jp-DirListing-item.lm-mod-drag-image,
.jp-DirListing-item.jp-mod-selected.lm-mod-drag-image {
  font-size: var(--jp-ui-font-size1);
  padding-left: 4px;
  margin-left: 4px;
  width: 160px;
  background-color: var(--jp-ui-inverse-font-color2);
  box-shadow: var(--jp-elevation-z2);
  border-radius: 0px;
  color: var(--jp-ui-font-color1);
  transform: translateX(-40%) translateY(-58%);
}

.jp-DirListing-deadSpace {
  flex: 1 1 auto;
  margin: 0;
  padding: 0;
  list-style-type: none;
  overflow: auto;
  background-color: var(--jp-layout-color1);
}

.jp-Document {
  min-width: 120px;
  min-height: 120px;
  outline: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Private CSS variables
|----------------------------------------------------------------------------*/

:root {
}

/*-----------------------------------------------------------------------------
| Main OutputArea
| OutputArea has a list of Outputs
|----------------------------------------------------------------------------*/

.jp-OutputArea {
  overflow-y: auto;
}

.jp-OutputArea-child {
  display: flex;
  flex-direction: row;
}

.jp-OutputPrompt {
  flex: 0 0 var(--jp-cell-prompt-width);
  color: var(--jp-cell-outprompt-font-color);
  font-family: var(--jp-cell-prompt-font-family);
  padding: var(--jp-code-padding);
  letter-spacing: var(--jp-cell-prompt-letter-spacing);
  line-height: var(--jp-code-line-height);
  font-size: var(--jp-code-font-size);
  border: var(--jp-border-width) solid transparent;
  opacity: var(--jp-cell-prompt-opacity);
  /* Right align prompt text, don't wrap to handle large prompt numbers */
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  /* Disable text selection */
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.jp-OutputArea-output {
  height: auto;
  overflow: auto;
  user-select: text;
  -moz-user-select: text;
  -webkit-user-select: text;
  -ms-user-select: text;
}

.jp-OutputArea-child .jp-OutputArea-output {
  flex-grow: 1;
  flex-shrink: 1;
}

/**
 * Isolated output.
 */
.jp-OutputArea-output.jp-mod-isolated {
  width: 100%;
  display: block;
}

/*
When drag events occur, `p-mod-override-cursor` is added to the body.
Because iframes steal all cursor events, the following two rules are necessary
to suppress pointer events while resize drags are occurring. There may be a
better solution to this problem.
*/
body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated {
  position: relative;
}

body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: transparent;
}

/* pre */

.jp-OutputArea-output pre {
  border: none;
  margin: 0px;
  padding: 0px;
  overflow-x: auto;
  overflow-y: auto;
  word-break: break-all;
  word-wrap: break-word;
  white-space: pre-wrap;
}

/* tables */

.jp-OutputArea-output.jp-RenderedHTMLCommon table {
  margin-left: 0;
  margin-right: 0;
}

/* description lists */

.jp-OutputArea-output dl,
.jp-OutputArea-output dt,
.jp-OutputArea-output dd {
  display: block;
}

.jp-OutputArea-output dl {
  width: 100%;
  overflow: hidden;
  padding: 0;
  margin: 0;
}

.jp-OutputArea-output dt {
  font-weight: bold;
  float: left;
  width: 20%;
  padding: 0;
  margin: 0;
}

.jp-OutputArea-output dd {
  float: left;
  width: 80%;
  padding: 0;
  margin: 0;
}

/* Hide the gutter in case of
 *  - nested output areas (e.g. in the case of output widgets)
 *  - mirrored output areas
 */
.jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt {
  display: none;
}

/*-----------------------------------------------------------------------------
| executeResult is added to any Output-result for the display of the object
| returned by a cell
|----------------------------------------------------------------------------*/

.jp-OutputArea-output.jp-OutputArea-executeResult {
  margin-left: 0px;
  flex: 1 1 auto;
}

/* Text output with the Out[] prompt needs a top padding to match the
 * alignment of the Out[] prompt itself.
 */
.jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output {
  padding-top: var(--jp-code-padding);
  border-top: var(--jp-border-width) solid transparent;
}

/*-----------------------------------------------------------------------------
| The Stdin output
|----------------------------------------------------------------------------*/

.jp-OutputArea-stdin {
  line-height: var(--jp-code-line-height);
  padding-top: var(--jp-code-padding);
  display: flex;
}

.jp-Stdin-prompt {
  color: var(--jp-content-font-color0);
  padding-right: var(--jp-code-padding);
  vertical-align: baseline;
  flex: 0 0 auto;
}

.jp-Stdin-input {
  font-family: var(--jp-code-font-family);
  font-size: inherit;
  color: inherit;
  background-color: inherit;
  width: 42%;
  min-width: 200px;
  /* make sure input baseline aligns with prompt */
  vertical-align: baseline;
  /* padding + margin = 0.5em between prompt and cursor */
  padding: 0em 0.25em;
  margin: 0em 0.25em;
  flex: 0 0 70%;
}

.jp-Stdin-input:focus {
  box-shadow: none;
}

/*-----------------------------------------------------------------------------
| Output Area View
|----------------------------------------------------------------------------*/

.jp-LinkedOutputView .jp-OutputArea {
  height: 100%;
  display: block;
}

.jp-LinkedOutputView .jp-OutputArea-output:only-child {
  height: 100%;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

.jp-Collapser {
  flex: 0 0 var(--jp-cell-collapser-width);
  padding: 0px;
  margin: 0px;
  border: none;
  outline: none;
  background: transparent;
  border-radius: var(--jp-border-radius);
  opacity: 1;
}

.jp-Collapser-child {
  display: block;
  width: 100%;
  box-sizing: border-box;
  /* height: 100% doesn't work because the height of its parent is computed from content */
  position: absolute;
  top: 0px;
  bottom: 0px;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Header/Footer
|----------------------------------------------------------------------------*/

/* Hidden by zero height by default */
.jp-CellHeader,
.jp-CellFooter {
  height: 0px;
  width: 100%;
  padding: 0px;
  margin: 0px;
  border: none;
  outline: none;
  background: transparent;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Input
|----------------------------------------------------------------------------*/

/* All input areas */
.jp-InputArea {
  display: flex;
  flex-direction: row;
  overflow: hidden;
}

.jp-InputArea-editor {
  flex: 1 1 auto;
  overflow: hidden;
}

.jp-InputArea-editor {
  /* This is the non-active, default styling */
  border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
  border-radius: 0px;
  background: var(--jp-cell-editor-background);
}

.jp-InputPrompt {
  flex: 0 0 var(--jp-cell-prompt-width);
  color: var(--jp-cell-inprompt-font-color);
  font-family: var(--jp-cell-prompt-font-family);
  padding: var(--jp-code-padding);
  letter-spacing: var(--jp-cell-prompt-letter-spacing);
  opacity: var(--jp-cell-prompt-opacity);
  line-height: var(--jp-code-line-height);
  font-size: var(--jp-code-font-size);
  border: var(--jp-border-width) solid transparent;
  opacity: var(--jp-cell-prompt-opacity);
  /* Right align prompt text, don't wrap to handle large prompt numbers */
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  /* Disable text selection */
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Placeholder
|----------------------------------------------------------------------------*/

.jp-Placeholder {
  display: flex;
  flex-direction: row;
  flex: 1 1 auto;
}

.jp-Placeholder-prompt {
  box-sizing: border-box;
}

.jp-Placeholder-content {
  flex: 1 1 auto;
  border: none;
  background: transparent;
  height: 20px;
  box-sizing: border-box;
}

.jp-Placeholder-content .jp-MoreHorizIcon {
  width: 32px;
  height: 16px;
  border: 1px solid transparent;
  border-radius: var(--jp-border-radius);
}

.jp-Placeholder-content .jp-MoreHorizIcon:hover {
  border: 1px solid var(--jp-border-color1);
  box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.25);
  background-color: var(--jp-layout-color0);
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Private CSS variables
|----------------------------------------------------------------------------*/

:root {
  --jp-private-cell-scrolling-output-offset: 5px;
}

/*-----------------------------------------------------------------------------
| Cell
|----------------------------------------------------------------------------*/

.jp-Cell {
  padding: var(--jp-cell-padding);
  margin: 0px;
  border: none;
  outline: none;
  background: transparent;
}

/*-----------------------------------------------------------------------------
| Common input/output
|----------------------------------------------------------------------------*/

.jp-Cell-inputWrapper,
.jp-Cell-outputWrapper {
  display: flex;
  flex-direction: row;
  padding: 0px;
  margin: 0px;
  /* Added to reveal the box-shadow on the input and output collapsers. */
  overflow: visible;
}

/* Only input/output areas inside cells */
.jp-Cell-inputArea,
.jp-Cell-outputArea {
  flex: 1 1 auto;
}

/*-----------------------------------------------------------------------------
| Collapser
|----------------------------------------------------------------------------*/

/* Make the output collapser disappear when there is not output, but do so
 * in a manner that leaves it in the layout and preserves its width.
 */
.jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser {
  border: none !important;
  background: transparent !important;
}

.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser {
  min-height: var(--jp-cell-collapser-min-height);
}

/*-----------------------------------------------------------------------------
| Output
|----------------------------------------------------------------------------*/

/* Put a space between input and output when there IS output */
.jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper {
  margin-top: 5px;
}

.jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea {
  overflow-y: auto;
  max-height: 200px;
  box-shadow: inset 0 0 6px 2px rgba(0, 0, 0, 0.3);
  margin-left: var(--jp-private-cell-scrolling-output-offset);
}

.jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt {
  flex: 0 0
    calc(
      var(--jp-cell-prompt-width) -
        var(--jp-private-cell-scrolling-output-offset)
    );
}

/*-----------------------------------------------------------------------------
| CodeCell
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| MarkdownCell
|----------------------------------------------------------------------------*/

.jp-MarkdownOutput {
  flex: 1 1 auto;
  margin-top: 0;
  margin-bottom: 0;
  padding-left: var(--jp-code-padding);
}

.jp-MarkdownOutput.jp-RenderedHTMLCommon {
  overflow: auto;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Variables
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------

/*-----------------------------------------------------------------------------
| Styles
|----------------------------------------------------------------------------*/

.jp-NotebookPanel-toolbar {
  padding: 2px;
}

.jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused {
  border: none;
  box-shadow: none;
}

.jp-Notebook-toolbarCellTypeDropdown select {
  height: 24px;
  font-size: var(--jp-ui-font-size1);
  line-height: 14px;
  border-radius: 0;
  display: block;
}

.jp-Notebook-toolbarCellTypeDropdown span {
  top: 5px !important;
}

/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Private CSS variables
|----------------------------------------------------------------------------*/

:root {
  --jp-private-notebook-dragImage-width: 304px;
  --jp-private-notebook-dragImage-height: 36px;
  --jp-private-notebook-selected-color: var(--md-blue-400);
  --jp-private-notebook-active-color: var(--md-green-400);
}

/*-----------------------------------------------------------------------------
| Imports
|----------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------
| Notebook
|----------------------------------------------------------------------------*/

.jp-NotebookPanel {
  display: block;
  height: 100%;
}

.jp-NotebookPanel.jp-Document {
  min-width: 240px;
  min-height: 120px;
}

.jp-Notebook {
  padding: var(--jp-notebook-padding);
  outline: none;
  overflow: auto;
  background: var(--jp-layout-color0);
}

.jp-Notebook.jp-mod-scrollPastEnd::after {
  display: block;
  content: '';
  min-height: var(--jp-notebook-scroll-padding);
}

.jp-Notebook .jp-Cell {
  overflow: visible;
}

.jp-Notebook .jp-Cell .jp-InputPrompt {
  cursor: move;
}

/*-----------------------------------------------------------------------------
| Notebook state related styling
|
| The notebook and cells each have states, here are the possibilities:
|
| - Notebook
|   - Command
|   - Edit
| - Cell
|   - None
|   - Active (only one can be active)
|   - Selected (the cells actions are applied to)
|   - Multiselected (when multiple selected, the cursor)
|   - No outputs
|----------------------------------------------------------------------------*/

/* Command or edit modes */

.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-InputPrompt {
  opacity: var(--jp-cell-prompt-not-active-opacity);
  color: var(--jp-cell-prompt-not-active-font-color);
}

.jp-Notebook .jp-Cell:not(.jp-mod-active) .jp-OutputPrompt {
  opacity: var(--jp-cell-prompt-not-active-opacity);
  color: var(--jp-cell-prompt-not-active-font-color);
}

/* cell is active */
.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser {
  background: var(--jp-brand-color1);
}

/* collapser is hovered */
.jp-Notebook .jp-Cell .jp-Collapser:hover {
  box-shadow: var(--jp-elevation-z2);
  background: var(--jp-brand-color1);
  opacity: var(--jp-cell-collapser-not-active-hover-opacity);
}

/* cell is active and collapser is hovered */
.jp-Notebook .jp-Cell.jp-mod-active .jp-Collapser:hover {
  background: var(--jp-brand-color0);
  opacity: 1;
}

/* Command mode */

.jp-Notebook.jp-mod-commandMode .jp-Cell.jp-mod-selected {
  background: var(--jp-notebook-multiselected-color);
}

.jp-Notebook.jp-mod-commandMode
  .jp-Cell.jp-mod-active.jp-mod-selected:not(.jp-mod-multiSelected) {
  background: transparent;
}

/* Edit mode */

.jp-Notebook.jp-mod-editMode .jp-Cell.jp-mod-active .jp-InputArea-editor {
  border: var(--jp-border-width) solid var(--jp-cell-editor-active-border-color);
  box-shadow: var(--jp-input-box-shadow);
  background-color: var(--jp-cell-editor-active-background);
}

/*-----------------------------------------------------------------------------
| Notebook drag and drop
|----------------------------------------------------------------------------*/

.jp-Notebook-cell.jp-mod-dropSource {
  opacity: 0.5;
}

.jp-Notebook-cell.jp-mod-dropTarget,
.jp-Notebook.jp-mod-commandMode
  .jp-Notebook-cell.jp-mod-active.jp-mod-selected.jp-mod-dropTarget {
  border-top-color: var(--jp-private-notebook-selected-color);
  border-top-style: solid;
  border-top-width: 2px;
}

.jp-dragImage {
  display: flex;
  flex-direction: row;
  width: var(--jp-private-notebook-dragImage-width);
  height: var(--jp-private-notebook-dragImage-height);
  border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
  background: var(--jp-cell-editor-background);
  overflow: visible;
}

.jp-dragImage-singlePrompt {
  box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12);
}

.jp-dragImage .jp-dragImage-content {
  flex: 1 1 auto;
  z-index: 2;
  font-size: var(--jp-code-font-size);
  font-family: var(--jp-code-font-family);
  line-height: var(--jp-code-line-height);
  padding: var(--jp-code-padding);
  border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
  background: var(--jp-cell-editor-background-color);
  color: var(--jp-content-font-color3);
  text-align: left;
  margin: 4px 4px 4px 0px;
}

.jp-dragImage .jp-dragImage-prompt {
  flex: 0 0 auto;
  min-width: 36px;
  color: var(--jp-cell-inprompt-font-color);
  padding: var(--jp-code-padding);
  padding-left: 12px;
  font-family: var(--jp-cell-prompt-font-family);
  letter-spacing: var(--jp-cell-prompt-letter-spacing);
  line-height: 1.9;
  font-size: var(--jp-code-font-size);
  border: var(--jp-border-width) solid transparent;
}

.jp-dragImage-multipleBack {
  z-index: -1;
  position: absolute;
  height: 32px;
  width: 300px;
  top: 8px;
  left: 8px;
  background: var(--jp-layout-color2);
  border: var(--jp-border-width) solid var(--jp-input-border-color);
  box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12);
}

/*-----------------------------------------------------------------------------
| Cell toolbar
|----------------------------------------------------------------------------*/

.jp-NotebookTools {
  display: block;
  min-width: var(--jp-sidebar-min-width);
  color: var(--jp-ui-font-color1);
  background: var(--jp-layout-color1);
  /* This is needed so that all font sizing of children done in ems is
    * relative to this base size */
  font-size: var(--jp-ui-font-size1);
  overflow: auto;
}

.jp-NotebookTools-tool {
  padding: 0px 12px 0 12px;
}

.jp-ActiveCellTool {
  padding: 12px;
  background-color: var(--jp-layout-color1);
  border-top: none !important;
}

.jp-ActiveCellTool .jp-InputArea-prompt {
  flex: 0 0 auto;
  padding-left: 0px;
}

.jp-ActiveCellTool .jp-InputArea-editor {
  flex: 1 1 auto;
  background: var(--jp-cell-editor-background);
  border-color: var(--jp-cell-editor-border-color);
}

.jp-ActiveCellTool .jp-InputArea-editor .CodeMirror {
  background: transparent;
}

.jp-MetadataEditorTool {
  flex-direction: column;
  padding: 12px 0px 12px 0px;
}

.jp-RankedPanel > :not(:first-child) {
  margin-top: 12px;
}

.jp-KeySelector select.jp-mod-styled {
  font-size: var(--jp-ui-font-size1);
  color: var(--jp-ui-font-color0);
  border: var(--jp-border-width) solid var(--jp-border-color1);
}

.jp-KeySelector label,
.jp-MetadataEditorTool label {
  line-height: 1.4;
}

.jp-NotebookTools .jp-select-wrapper {
  margin-top: 4px;
  margin-bottom: 0px;
}

.jp-NotebookTools .jp-Collapse {
  margin-top: 16px;
}

/*-----------------------------------------------------------------------------
| Presentation Mode (.jp-mod-presentationMode)
|----------------------------------------------------------------------------*/

.jp-mod-presentationMode .jp-Notebook {
  --jp-content-font-size1: var(--jp-content-presentation-font-size1);
  --jp-code-font-size: var(--jp-code-presentation-font-size);
}

.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt,
.jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt {
  flex: 0 0 110px;
}

</style>

    <style type="text/css">
/*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

/*
The following CSS variables define the main, public API for styling JupyterLab.
These variables should be used by all plugins wherever possible. In other
words, plugins should not define custom colors, sizes, etc unless absolutely
necessary. This enables users to change the visual theme of JupyterLab
by changing these variables.

Many variables appear in an ordered sequence (0,1,2,3). These sequences
are designed to work well together, so for example, `--jp-border-color1` should
be used with `--jp-layout-color1`. The numbers have the following meanings:

* 0: super-primary, reserved for special emphasis
* 1: primary, most important under normal situations
* 2: secondary, next most important under normal situations
* 3: tertiary, next most important under normal situations

Throughout JupyterLab, we are mostly following principles from Google's
Material Design when selecting colors. We are not, however, following
all of MD as it is not optimized for dense, information rich UIs.
*/

:root {
  /* Elevation
   *
   * We style box-shadows using Material Design's idea of elevation. These particular numbers are taken from here:
   *
   * https://github.com/material-components/material-components-web
   * https://material-components-web.appspot.com/elevation.html
   */

  --jp-shadow-base-lightness: 0;
  --jp-shadow-umbra-color: rgba(
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    0.2
  );
  --jp-shadow-penumbra-color: rgba(
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    0.14
  );
  --jp-shadow-ambient-color: rgba(
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    var(--jp-shadow-base-lightness),
    0.12
  );
  --jp-elevation-z0: none;
  --jp-elevation-z1: 0px 2px 1px -1px var(--jp-shadow-umbra-color),
    0px 1px 1px 0px var(--jp-shadow-penumbra-color),
    0px 1px 3px 0px var(--jp-shadow-ambient-color);
  --jp-elevation-z2: 0px 3px 1px -2px var(--jp-shadow-umbra-color),
    0px 2px 2px 0px var(--jp-shadow-penumbra-color),
    0px 1px 5px 0px var(--jp-shadow-ambient-color);
  --jp-elevation-z4: 0px 2px 4px -1px var(--jp-shadow-umbra-color),
    0px 4px 5px 0px var(--jp-shadow-penumbra-color),
    0px 1px 10px 0px var(--jp-shadow-ambient-color);
  --jp-elevation-z6: 0px 3px 5px -1px var(--jp-shadow-umbra-color),
    0px 6px 10px 0px var(--jp-shadow-penumbra-color),
    0px 1px 18px 0px var(--jp-shadow-ambient-color);
  --jp-elevation-z8: 0px 5px 5px -3px var(--jp-shadow-umbra-color),
    0px 8px 10px 1px var(--jp-shadow-penumbra-color),
    0px 3px 14px 2px var(--jp-shadow-ambient-color);
  --jp-elevation-z12: 0px 7px 8px -4px var(--jp-shadow-umbra-color),
    0px 12px 17px 2px var(--jp-shadow-penumbra-color),
    0px 5px 22px 4px var(--jp-shadow-ambient-color);
  --jp-elevation-z16: 0px 8px 10px -5px var(--jp-shadow-umbra-color),
    0px 16px 24px 2px var(--jp-shadow-penumbra-color),
    0px 6px 30px 5px var(--jp-shadow-ambient-color);
  --jp-elevation-z20: 0px 10px 13px -6px var(--jp-shadow-umbra-color),
    0px 20px 31px 3px var(--jp-shadow-penumbra-color),
    0px 8px 38px 7px var(--jp-shadow-ambient-color);
  --jp-elevation-z24: 0px 11px 15px -7px var(--jp-shadow-umbra-color),
    0px 24px 38px 3px var(--jp-shadow-penumbra-color),
    0px 9px 46px 8px var(--jp-shadow-ambient-color);

  /* Borders
   *
   * The following variables, specify the visual styling of borders in JupyterLab.
   */

  --jp-border-width: 1px;
  --jp-border-color0: var(--md-grey-400);
  --jp-border-color1: var(--md-grey-400);
  --jp-border-color2: var(--md-grey-300);
  --jp-border-color3: var(--md-grey-200);
  --jp-border-radius: 2px;

  /* UI Fonts
   *
   * The UI font CSS variables are used for the typography all of the JupyterLab
   * user interface elements that are not directly user generated content.
   *
   * The font sizing here is done assuming that the body font size of --jp-ui-font-size1
   * is applied to a parent element. When children elements, such as headings, are sized
   * in em all things will be computed relative to that body size.
   */

  --jp-ui-font-scale-factor: 1.2;
  --jp-ui-font-size0: 0.83333em;
  --jp-ui-font-size1: 13px; /* Base font size */
  --jp-ui-font-size2: 1.2em;
  --jp-ui-font-size3: 1.44em;

  --jp-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica,
    Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';

  /*
   * Use these font colors against the corresponding main layout colors.
   * In a light theme, these go from dark to light.
   */

  /* Defaults use Material Design specification */
  --jp-ui-font-color0: rgba(0, 0, 0, 1);
  --jp-ui-font-color1: rgba(0, 0, 0, 0.87);
  --jp-ui-font-color2: rgba(0, 0, 0, 0.54);
  --jp-ui-font-color3: rgba(0, 0, 0, 0.38);

  /*
   * Use these against the brand/accent/warn/error colors.
   * These will typically go from light to darker, in both a dark and light theme.
   */

  --jp-ui-inverse-font-color0: rgba(255, 255, 255, 1);
  --jp-ui-inverse-font-color1: rgba(255, 255, 255, 1);
  --jp-ui-inverse-font-color2: rgba(255, 255, 255, 0.7);
  --jp-ui-inverse-font-color3: rgba(255, 255, 255, 0.5);

  /* Content Fonts
   *
   * Content font variables are used for typography of user generated content.
   *
   * The font sizing here is done assuming that the body font size of --jp-content-font-size1
   * is applied to a parent element. When children elements, such as headings, are sized
   * in em all things will be computed relative to that body size.
   */

  --jp-content-line-height: 1.6;
  --jp-content-font-scale-factor: 1.2;
  --jp-content-font-size0: 0.83333em;
  --jp-content-font-size1: 14px; /* Base font size */
  --jp-content-font-size2: 1.2em;
  --jp-content-font-size3: 1.44em;
  --jp-content-font-size4: 1.728em;
  --jp-content-font-size5: 2.0736em;

  /* This gives a magnification of about 125% in presentation mode over normal. */
  --jp-content-presentation-font-size1: 17px;

  --jp-content-heading-line-height: 1;
  --jp-content-heading-margin-top: 1.2em;
  --jp-content-heading-margin-bottom: 0.8em;
  --jp-content-heading-font-weight: 500;

  /* Defaults use Material Design specification */
  --jp-content-font-color0: rgba(0, 0, 0, 1);
  --jp-content-font-color1: rgba(0, 0, 0, 0.87);
  --jp-content-font-color2: rgba(0, 0, 0, 0.54);
  --jp-content-font-color3: rgba(0, 0, 0, 0.38);

  --jp-content-link-color: var(--md-blue-700);

  --jp-content-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI',
    Helvetica, Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji',
    'Segoe UI Symbol';

  /*
   * Code Fonts
   *
   * Code font variables are used for typography of code and other monospaces content.
   */

  --jp-code-font-size: 13px;
  --jp-code-line-height: 1.3077; /* 17px for 13px base */
  --jp-code-padding: 5px; /* 5px for 13px base, codemirror highlighting needs integer px value */
  --jp-code-font-family-default: Menlo, Consolas, 'DejaVu Sans Mono', monospace;
  --jp-code-font-family: var(--jp-code-font-family-default);

  /* This gives a magnification of about 125% in presentation mode over normal. */
  --jp-code-presentation-font-size: 16px;

  /* may need to tweak cursor width if you change font size */
  --jp-code-cursor-width0: 1.4px;
  --jp-code-cursor-width1: 2px;
  --jp-code-cursor-width2: 4px;

  /* Layout
   *
   * The following are the main layout colors use in JupyterLab. In a light
   * theme these would go from light to dark.
   */

  --jp-layout-color0: white;
  --jp-layout-color1: white;
  --jp-layout-color2: var(--md-grey-200);
  --jp-layout-color3: var(--md-grey-400);
  --jp-layout-color4: var(--md-grey-600);

  /* Inverse Layout
   *
   * The following are the inverse layout colors use in JupyterLab. In a light
   * theme these would go from dark to light.
   */

  --jp-inverse-layout-color0: #111111;
  --jp-inverse-layout-color1: var(--md-grey-900);
  --jp-inverse-layout-color2: var(--md-grey-800);
  --jp-inverse-layout-color3: var(--md-grey-700);
  --jp-inverse-layout-color4: var(--md-grey-600);

  /* Brand/accent */

  --jp-brand-color0: var(--md-blue-700);
  --jp-brand-color1: var(--md-blue-500);
  --jp-brand-color2: var(--md-blue-300);
  --jp-brand-color3: var(--md-blue-100);
  --jp-brand-color4: var(--md-blue-50);

  --jp-accent-color0: var(--md-green-700);
  --jp-accent-color1: var(--md-green-500);
  --jp-accent-color2: var(--md-green-300);
  --jp-accent-color3: var(--md-green-100);

  /* State colors (warn, error, success, info) */

  --jp-warn-color0: var(--md-orange-700);
  --jp-warn-color1: var(--md-orange-500);
  --jp-warn-color2: var(--md-orange-300);
  --jp-warn-color3: var(--md-orange-100);

  --jp-error-color0: var(--md-red-700);
  --jp-error-color1: var(--md-red-500);
  --jp-error-color2: var(--md-red-300);
  --jp-error-color3: var(--md-red-100);

  --jp-success-color0: var(--md-green-700);
  --jp-success-color1: var(--md-green-500);
  --jp-success-color2: var(--md-green-300);
  --jp-success-color3: var(--md-green-100);

  --jp-info-color0: var(--md-cyan-700);
  --jp-info-color1: var(--md-cyan-500);
  --jp-info-color2: var(--md-cyan-300);
  --jp-info-color3: var(--md-cyan-100);

  /* Cell specific styles */

  --jp-cell-padding: 5px;

  --jp-cell-collapser-width: 8px;
  --jp-cell-collapser-min-height: 20px;
  --jp-cell-collapser-not-active-hover-opacity: 0.6;

  --jp-cell-editor-background: var(--md-grey-100);
  --jp-cell-editor-border-color: var(--md-grey-300);
  --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300);
  --jp-cell-editor-active-background: var(--jp-layout-color0);
  --jp-cell-editor-active-border-color: var(--jp-brand-color1);

  --jp-cell-prompt-width: 64px;
  --jp-cell-prompt-font-family: var(--jp-code-font-family-default);
  --jp-cell-prompt-letter-spacing: 0px;
  --jp-cell-prompt-opacity: 1;
  --jp-cell-prompt-not-active-opacity: 0.5;
  --jp-cell-prompt-not-active-font-color: var(--md-grey-700);
  /* A custom blend of MD grey and blue 600
   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
  --jp-cell-inprompt-font-color: #307fc1;
  /* A custom blend of MD grey and orange 600
   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */
  --jp-cell-outprompt-font-color: #bf5b3d;

  /* Notebook specific styles */

  --jp-notebook-padding: 10px;
  --jp-notebook-select-background: var(--jp-layout-color1);
  --jp-notebook-multiselected-color: var(--md-blue-50);

  /* The scroll padding is calculated to fill enough space at the bottom of the
  notebook to show one single-line cell (with appropriate padding) at the top
  when the notebook is scrolled all the way to the bottom. We also subtract one
  pixel so that no scrollbar appears if we have just one single-line cell in the
  notebook. This padding is to enable a 'scroll past end' feature in a notebook.
  */
  --jp-notebook-scroll-padding: calc(
    100% - var(--jp-code-font-size) * var(--jp-code-line-height) -
      var(--jp-code-padding) - var(--jp-cell-padding) - 1px
  );

  /* Rendermime styles */

  --jp-rendermime-error-background: #fdd;
  --jp-rendermime-table-row-background: var(--md-grey-100);
  --jp-rendermime-table-row-hover-background: var(--md-light-blue-50);

  /* Dialog specific styles */

  --jp-dialog-background: rgba(0, 0, 0, 0.25);

  /* Console specific styles */

  --jp-console-padding: 10px;

  /* Toolbar specific styles */

  --jp-toolbar-border-color: var(--jp-border-color1);
  --jp-toolbar-micro-height: 8px;
  --jp-toolbar-background: var(--jp-layout-color1);
  --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.24);
  --jp-toolbar-header-margin: 4px 4px 0px 4px;
  --jp-toolbar-active-background: var(--md-grey-300);

  /* Input field styles */

  --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300);
  --jp-input-active-background: var(--jp-layout-color1);
  --jp-input-hover-background: var(--jp-layout-color1);
  --jp-input-background: var(--md-grey-100);
  --jp-input-border-color: var(--jp-border-color1);
  --jp-input-active-border-color: var(--jp-brand-color1);
  --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3);

  /* General editor styles */

  --jp-editor-selected-background: #d9d9d9;
  --jp-editor-selected-focused-background: #d7d4f0;
  --jp-editor-cursor-color: var(--jp-ui-font-color0);

  /* Code mirror specific styles */

  --jp-mirror-editor-keyword-color: #008000;
  --jp-mirror-editor-atom-color: #88f;
  --jp-mirror-editor-number-color: #080;
  --jp-mirror-editor-def-color: #00f;
  --jp-mirror-editor-variable-color: var(--md-grey-900);
  --jp-mirror-editor-variable-2-color: #05a;
  --jp-mirror-editor-variable-3-color: #085;
  --jp-mirror-editor-punctuation-color: #05a;
  --jp-mirror-editor-property-color: #05a;
  --jp-mirror-editor-operator-color: #aa22ff;
  --jp-mirror-editor-comment-color: #408080;
  --jp-mirror-editor-string-color: #ba2121;
  --jp-mirror-editor-string-2-color: #708;
  --jp-mirror-editor-meta-color: #aa22ff;
  --jp-mirror-editor-qualifier-color: #555;
  --jp-mirror-editor-builtin-color: #008000;
  --jp-mirror-editor-bracket-color: #997;
  --jp-mirror-editor-tag-color: #170;
  --jp-mirror-editor-attribute-color: #00c;
  --jp-mirror-editor-header-color: blue;
  --jp-mirror-editor-quote-color: #090;
  --jp-mirror-editor-link-color: #00c;
  --jp-mirror-editor-error-color: #f00;
  --jp-mirror-editor-hr-color: #999;

  /* Vega extension styles */

  --jp-vega-background: white;

  /* Sidebar-related styles */

  --jp-sidebar-min-width: 250px;

  /* Search-related styles */

  --jp-search-toggle-off-opacity: 0.5;
  --jp-search-toggle-hover-opacity: 0.8;
  --jp-search-toggle-on-opacity: 1;
  --jp-search-selected-match-background-color: rgb(245, 200, 0);
  --jp-search-selected-match-color: black;
  --jp-search-unselected-match-background-color: var(
    --jp-inverse-layout-color0
  );
  --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0);

  /* Icon colors that work well with light or dark backgrounds */
  --jp-icon-contrast-color0: var(--md-purple-600);
  --jp-icon-contrast-color1: var(--md-green-600);
  --jp-icon-contrast-color2: var(--md-pink-600);
  --jp-icon-contrast-color3: var(--md-blue-600);
}
</style>

<style type="text/css">
a.anchor-link {
   display: none;
}
.highlight  {
    margin: 0.4em;
}

/* Input area styling */
.jp-InputArea {
    overflow: hidden;
}

.jp-InputArea-editor {
    overflow: hidden;
}

@media print {
  body {
    margin: 0;
  }
}
</style>

<!-- Load mathjax -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-MML-AM_CHTML-full,Safe"> </script>
    <!-- MathJax configuration -->
    <script type="text/x-mathjax-config">
    init_mathjax = function() {
        if (window.MathJax) {
        // MathJax loaded
            MathJax.Hub.Config({
                TeX: {
                    equationNumbers: {
                    autoNumber: "AMS",
                    useLabelIds: true
                    }
                },
                tex2jax: {
                    inlineMath: [ ['$','$'], ["\\(","\\)"] ],
                    displayMath: [ ['$$','$$'], ["\\[","\\]"] ],
                    processEscapes: true,
                    processEnvironments: true
                },
                displayAlign: 'center',
                CommonHTML: {
                    linebreaks: { 
                    automatic: true 
                    }
                },
                "HTML-CSS": {
                    linebreaks: { 
                    automatic: true 
                    }
                }
            });
        
            MathJax.Hub.Queue(["Typeset", MathJax.Hub]);
        }
    }
    init_mathjax();
    </script>
    <!-- End of mathjax configuration --></head>
<body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light">

<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h1 id="Fully-Steerable-3D-Spherical-Neurons">Fully Steerable 3D Spherical Neurons<a class="anchor-link" href="#Fully-Steerable-3D-Spherical-Neurons">&#182;</a></h1>
</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[1]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="o">%</span><span class="k">load_ext</span> autoreload
<span class="o">%</span><span class="k">autoreload</span> 2
<span class="o">%</span><span class="k">matplotlib</span> inline
</pre></div>

     </div>
</div>
</div>
</div>

</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[2]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">SEED</span> <span class="o">=</span> <span class="mi">239</span>

<span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>
<span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>
<span class="n">np</span><span class="o">.</span><span class="n">set_printoptions</span><span class="p">(</span><span class="n">precision</span><span class="o">=</span><span class="mi">4</span><span class="p">)</span>

<span class="kn">import</span> <span class="nn">torch</span>
<span class="n">torch</span><span class="o">.</span><span class="n">manual_seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>
<span class="k">if</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">():</span>
    <span class="n">torch</span><span class="o">.</span><span class="n">backends</span><span class="o">.</span><span class="n">cudnn</span><span class="o">.</span><span class="n">deterministic</span> <span class="o">=</span> <span class="kc">True</span>
    <span class="n">torch</span><span class="o">.</span><span class="n">backends</span><span class="o">.</span><span class="n">cudnn</span><span class="o">.</span><span class="n">benchmark</span> <span class="o">=</span> <span class="kc">False</span>
<span class="kn">import</span> <span class="nn">torch.nn</span> <span class="k">as</span> <span class="nn">nn</span>
<span class="kn">import</span> <span class="nn">torch.nn.functional</span> <span class="k">as</span> <span class="nn">F</span> 
<span class="kn">import</span> <span class="nn">torch.optim</span> <span class="k">as</span> <span class="nn">optim</span>

<span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
<span class="kn">import</span> <span class="nn">matplotlib.collections</span> <span class="k">as</span> <span class="nn">mcol</span>
<span class="kn">import</span> <span class="nn">matplotlib.transforms</span> <span class="k">as</span> <span class="nn">mtransforms</span>

<span class="kn">from</span> <span class="nn">matplotlib</span> <span class="kn">import</span> <span class="n">cm</span>
<span class="kn">from</span> <span class="nn">mpl_toolkits.mplot3d</span> <span class="kn">import</span> <span class="n">Axes3D</span>

<span class="kn">from</span> <span class="nn">scipy.spatial.transform</span> <span class="kn">import</span> <span class="n">Rotation</span> <span class="k">as</span> <span class="n">R</span>
<span class="kn">from</span> <span class="nn">scipy.special</span> <span class="kn">import</span> <span class="n">softmax</span>

<span class="kn">from</span> <span class="nn">tqdm</span> <span class="kn">import</span> <span class="n">tqdm</span>

<span class="kn">from</span> <span class="nn">models</span> <span class="kn">import</span> <span class="n">PointCMLP</span><span class="p">,</span> <span class="n">SteerableModel</span>

<span class="kn">from</span> <span class="nn">utils</span> <span class="kn">import</span> <span class="p">(</span><span class="n">get_tetris_data</span><span class="p">,</span> <span class="n">plot_shapes</span><span class="p">,</span> <span class="n">score</span><span class="p">,</span> <span class="n">build_mlgp</span><span class="p">,</span> 
                   <span class="n">construct_filter_banks</span><span class="p">,</span> <span class="n">unembed_points</span><span class="p">,</span> 
                   <span class="n">transform_parameters</span><span class="p">,</span> <span class="n">build_steerable_model</span><span class="p">,</span>
                   <span class="n">random_axis_angle</span><span class="p">,</span> <span class="n">torch_rotation_matrix</span><span class="p">,</span> <span class="n">entropy</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[3]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">device</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">device</span><span class="p">(</span><span class="s2">&quot;cuda&quot;</span> <span class="k">if</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">()</span> <span class="k">else</span> <span class="s2">&quot;cpu&quot;</span><span class="p">)</span>
<span class="n">torch</span><span class="o">.</span><span class="n">__version__</span><span class="p">,</span> <span class="n">device</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[3]:</div>




<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
<pre>(&#39;1.8.1+cu102&#39;, device(type=&#39;cuda&#39;))</pre>
</div>

</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h2 id="Creating-a-steerable-spherical-classifer">Creating a steerable spherical classifer<a class="anchor-link" href="#Creating-a-steerable-spherical-classifer">&#182;</a></h2><p>in the following steps:</p>
<p><strong>Step 1</strong>. Train the ancestor MLGP.</p>
<p><strong>Step 2</strong>. Transform the hidden unit parameters into filter banks.</p>
<p><strong>Step 3</strong>. Fix the learned parameters and add the interpolation coefficients $v^k$ as learnable parameters to fulfill the steerability constraint $\rightarrow$ Steerable spherical classifier.</p>

</div>
</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h3 id="Step-1">Step 1<a class="anchor-link" href="#Step-1">&#182;</a></h3>
</div>
</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h4 id="Create-the-3D-Tetris-dataset">Create the 3D Tetris dataset<a class="anchor-link" href="#Create-the-3D-Tetris-dataset">&#182;</a></h4>
</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[4]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">Xtrain</span><span class="p">,</span> <span class="n">Ytrain</span><span class="p">,</span> <span class="n">shape_names</span> <span class="o">=</span> <span class="n">get_tetris_data</span><span class="p">()</span>

<span class="k">for</span> <span class="n">shape</span><span class="p">,</span> <span class="n">name</span> <span class="ow">in</span> <span class="nb">zip</span><span class="p">(</span><span class="n">Xtrain</span><span class="p">,</span> <span class="n">shape_names</span><span class="p">):</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">name</span><span class="p">,</span> <span class="s1">&#39;</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">shape</span><span class="p">,</span> <span class="s1">&#39;</span><span class="se">\n\n</span><span class="s1">&#39;</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>chiral_shape_1 
 tensor([[0., 0., 0.],
        [0., 0., 1.],
        [1., 0., 0.],
        [1., 1., 0.]]) 


chiral_shape_2 
 tensor([[ 0.,  0.,  0.],
        [ 0.,  0.,  1.],
        [ 1.,  0.,  0.],
        [ 1., -1.,  0.]]) 


square 
 tensor([[0., 0., 0.],
        [1., 0., 0.],
        [0., 1., 0.],
        [1., 1., 0.]]) 


line 
 tensor([[0., 0., 0.],
        [0., 0., 1.],
        [0., 0., 2.],
        [0., 0., 3.]]) 


corner 
 tensor([[0., 0., 0.],
        [0., 0., 1.],
        [0., 1., 0.],
        [1., 0., 0.]]) 


L 
 tensor([[0., 0., 0.],
        [0., 0., 1.],
        [0., 0., 2.],
        [0., 1., 0.]]) 


T 
 tensor([[0., 0., 0.],
        [0., 0., 1.],
        [0., 0., 2.],
        [0., 1., 1.]]) 


zigzag 
 tensor([[0., 0., 0.],
        [1., 0., 0.],
        [1., 1., 0.],
        [2., 1., 0.]]) 


</pre>
</div>
</div>

</div>

</div>

</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[5]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">plot_shapes</span><span class="p">(</span><span class="n">Xtrain</span><span class="p">,</span> <span class="n">shape_names</span><span class="p">,</span> <span class="n">offset</span><span class="o">=</span><span class="mf">1.5</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>




<div class="jp-RenderedImage jp-OutputArea-output ">
<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZQAAAGKCAYAAAArGbdLAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9eXwb9Z3//xrdl2VL8hHbiY8E577jOAFCONImlLslXKWQPKAs7GNL2R9ldyn9ftvA0m4L3e2Wb7ttt8sRCi1XKbRsoSmkIZA7zmE78R0f8Rlbl3WP5vj9IWaQZN2akSVnno8HD8CWZz6SZj6ved8Ey7KQkJCQkJDIFtlML0BCQkJCYnYgCYqEhISEhCBIgiIhISEhIQiSoEhISEhICIIkKBISEhISgqBI8nspBUxCQkJCIhoi1g8lC0VCQkJCQhAkQZGQkJCQEARJUCQkJCQkBEESFAkJCQkJQUgWlJ9GMBjE0NAQ/H6/GOuREAmNRoO5c+dCqVTO9FIkJCRmKUSSXl7TftnX14eioiJYLBYQRMxAv0SewbIsrFYrXC4X6uvrZ3o5EhIShY8wWV5+v18SkwKDIAhYLBbJqpSQkBCVjGIokpgUHtJ3JiEhITZSUF5CQkJCQhDSDsqnA8Ow+Lh7Ar89MojxKT8qjBp8dUMNrmwog0wmPTFLSEhIzCZEs1Am3QFc+9P9+MarJ/DXs+NoGXLir2fH8Y1XT+Dan+6H1R0Q9Hw7d+7EW2+9Ne3nIyMj2L59e9rHMxgMOfkbIbjvvvtQXl6O5cuXz8j5JSQkJACRBIVhWHz114dxbsIDD0lH/M5D0jg34cFXf30EDCN+q7CqqqqYQkNRlOjnzhU7d+7EBx98MNPLkJCQuMgRRVA+7p7AsN0HKo5gUAyLIbsX+7snMj7Hyy+/jJUrV2LVqlW45557AAD79+/HZZddhvnz5/Mi0t/fzz+5v/TSS7jttttw4403YuvWrXC73diyZQvWrl2LFStW4N13303p3KOjo9i8eTNWr16N5cuX45NPPuF/953vfAerVq3Cxo0bMT4+DgD405/+hA0bNmDNmjX4whe+wP98165duOeee3DNNdegoaEBv/71r/njPPvss1i/fj1WrlyJ733vewnXs3nzZpjN5hQ/OQkJCQlxEEVQfnt4cJplEo2HpPHqkcGMjn/mzBl8//vfx969e3H69Gn89Kc/BRDa6D/99FO89957ePzxx2P+7aFDh7B7927s3bsXGo0Gf/jDH3DixAn87W9/w7e+9S0kqcsBAPz2t7/Ftm3bcOrUKZw+fRqrV68OvSePBxs3bsTp06exefNmXiA2bdqEw4cP4+TJk7jzzjvxzDPP8MdqaWnB//7v/+LQoUN46qmnMDIygj179qC7uxtHjx7FqVOn0NzcjP3792f0WUlISEjkClGC8uOu1Oodxqcyq4vYu3cvtm/fjtLSUgDgn85vueUWyGQyLF26lLcCovniF7/Iv55lWTzxxBPYv38/ZDIZhoeHMT4+jjlz5iQ8//r163HfffchGAzilltu4QVFpVLhhhtuAACsW7cOf/3rXwEAQ0NDuOOOOzA6OgqSJCOKC2+++WZotVpotVpcffXVOHr0KD799FPs2bMHa9asAQC43W50d3dj8+bNGX1eEhISErlAFAulwqgR9HXRsCwbs65CrVZHvCYWer2e/+9XX30VExMTaG5uxqlTp1BRUZFS8d/mzZuxf/9+VFdX45577sHLL78MAFAqlfy65HI5H6d5+OGH8Y1vfAOtra341a9+FXGO6PdBEARYlsW3v/1tnDp1CqdOnUJPTw/uv//+pOuSkJCQmElEEZSvbqiBXiVP+Bq9So67N9RkdPwtW7bgjTfegNVqBQDYbLaMjuN0OlFeXg6lUom//e1vGBgYSOnvBgYGUF5ejgceeAD3338/Tpw4kfQ81dXVAIDdu3dH/O7dd9+F3++H1WrFvn37sH79emzbtg0vvPAC3G43AGB4eBgXLlzI4B1KSEhI5A5RXF5XNpSh2qTFuQlPzMC8QkZgrkmHzQ1lGR1/2bJl+M53voMrr7wScrmcdw2ly913340bb7wRjY2NWL16NRYvXpzS3+3btw/PPvsslEolDAYDb6HEY9euXbjttttQXV2NjRs3oq+vj/9dU1MTrr/+egwODuL//t//i6qqKlRVVaG9vR2XXnopgFA68iuvvILy8vKYx7/rrruwb98+TE5OYu7cuXjyyScli0ZCQiLnpN0csr29HUuWLEl6YKs7gK/++giG7N6IAL1eJcdckw6/fWADLAZ1giPMfnbt2gWDwYDHHnssJ+dL9buTkJCQSELMynTRKuUtBjXef+QK7O+ewKthlfJ3b6jBZqlSXkJCQmLWIZqFMhtobW3la1w41Go1jhw5kvO1WK1WbNmyZdrPP/roI1gslpSOcTF9dxISEqKSWwtlNrBixQqcOnVqppcBALBYLHmzFgkJCYlYSN2GJSQkJCQEQRIUibyGYRhQFJVSBwMJCYmZRXJ5SeQlLMuCpmkEAgGQJAmZTAa5XA6lUgm5XA65XC4NDZOQyDPEFRSGAXo/Ao6/ALhGgaJKoPE+YMEWQCYZRxKxYVkWJEmCYRgAgEwmA0EQoGk6oku0QqHg/5EERkJi5hFvV3dPAL+4DHhzJ9D5Z2DkZOjfb+4M/dwzKejpLtZ5KOfPn8fVV1+NJUuWYNmyZXyjzEKFpmmMjo6ir68PBEHwIkEQBG+lyOVyyGQy0DQNn88Ht9sNp9MJl8sFv98vucgkJGYIcQSFYYDdNwLWHoB0R/6OdId+vvuG0OtEZrbPQ1EoFPj3f/93tLe34/Dhw/j5z3+Os2fPzvSy0oZlWQSDQZAkCZqmEQwGE1ocnMBw1olMJgPDMDhw4IAkMBISM4Q4gtL7EeA8DzDB2L9ngoDjPNC7N+NTSPNQQlRWVmLt2rUAgKKiIixZsgTDw8Opfox5AcMwIEkSFEXxQpGuAHB/RxBEhMD4/X5JYCQkcoQ4gnL8hemWSTSkGzj+fEaHl+ahxKa/vx8nT57Ehg0bkr42H2BZFhRFIRAIgGVZXhCEiIXEcpHFE5hgMMjHayQkJDJHnKC8azTF141ldHhpHsp03G43br31Vvznf/4njEZj0s9wpgkPvMcSEaEtiOhzsCzLCwyHTCaDUqmMcKNJSEikjjh3TFFliq9LvHHHQ5qHEkkwGMStt96Ku+++G1/5yleSrn8m4awSv98fV0y4z0BMYlkwLMsiEAjA4/FgamoKU1NT8Hq9kgUjIZEi4ghK432AKknGk8oANGbWYl2ah/I5LMvi/vvvx5IlS/Doo4+mtP6ZghMTLuDOubiiyYWgxDpnLIEhSTKuwEhxGAmJSMRxeS3YAhTPC2VzxQrMy5RAyTxgwTUZHV6ah/I5Bw4cwG9+8xusWLGCd7394Ac/wHXXXZfqx5ATuMA7Z10my+CK9d+5JJaLDABIkoTb7cbY2Bjq6uqgUCj4Ykuh4j8SEoWKeN2GPZOh1GDH+cgAvcoQEpMd7wH60vRXPIu4GOahcFYJl8GVyobrdDoxNDSEZcuW8UKUajzj2LFjWL9+fbbLTojf70dXVxdWrFgRYanEisFIAiMxS8lxt2F9KfDQwVBq8PHnQwH4ojkhN9eCa6RK+YuAZIH3ZH+b73Apyhzc+w0EAvz7DbdgJIGRmO2I23pFJgMavhD6pwARex7Krl27Un6tEPNQcgXXhysYDLk70xWTbGMo8ZI2xCaWwASDwYjPIbxdjCQwErMNqTlkAqR5KOnDbaI0TWccU8hGUPJpg5YERuJiQxIUCcFgGAZTU1Po6urCypUrM94cs91UZ8pCSUYsgeGy3jjCXWRSw0uJQkMSFImsiQ68c//O9piZUEgbcKxMsvCOyizLwufzwWw2Sx2VJQoCUQWFYRkcGD6AN7vexAXvBZTrynHbwttwefXlkBFSUH42wDAMX5eRaR+uaISIoRQi0QJDkiS6u7sjrD1uJowkMBL5iGiCYvVZcf+e+zHqHoWX8gIAzljP4MjoEVQaKvHCthdg1pjFOr2EyMQLvAtRlDhbYijZEp4pBnzeLsbn80kCI5GXiGImMCyD+/fcjwHnAC8mHF7KiwHnAO7/y/1g2PxvZ0HT9EwvIe8IDy5HV7wTBJF1m5KL1UJJRryW/VJHZYl8QRRBOTB8AKPuUVBs7JkjFEthxD2CgyMHMzq+x+PB9ddfj1WrVmH58uV4/fXX8cEHH2Dx4sXYtGkTvvnNb/JNGnft2oUf//jH/N8uX74c/f39AELNJNetW4dly5bhv//7v/nXGAwGfPe738WGDRtw6NAhvPLKK2hqasLq1avx4IMPXtQiwzAMAoFA3CwuMSyUi/WpO1lygdRRWSLfEEVQ3ux6c5plEo2X8uKNzjcyOv4HH3yAqqoqnD59Gm1tbbj22mvxwAMP4E9/+hM++eQTjI2l1sX4hRdeQHNzM44fP47nnnuO7w3m8XiwfPlyHDlyBBaLBa+//joOHDiAU6dOQS6X49VXX81o3YUMZ5UEAgEAELUPVzYCMhN9wPKFRAIT3o/M5/NJAiMhCqLEUC54YzcyzPR10axYsQKPPfYY/uVf/gU33HADioqKUF9fj4aGBgDA1772tQiLIx7PPfcc/vCHPwAIjdLt7u6GxWKBXC7HrbfeCiBUONjc3My38/D5fDF7as1mogPvyZ6ahdjQL1ZRCCfb9OdYWWRcR+XwB4Poan4JiUwRRVDKdeU4Yz2T0usyYeHChWhubsaf//xnfPvb38bWrVvj3ngKhSLiSYxrHb9v3z58+OGHOHToEHQ6Ha666ir+dxqNhq8XYFkWO3bswL/9279ltNZCJpOKd6GGY2UTlJfEKDbxBIYkSbS3t2Pu3LnQarVSw0uJjBHlceS2hbdBp9AlfI1OocPti27P6PgjIyPQ6XT42te+hsceewwHDx5EX18fent7AQC/+93v+NfW1dXx7eVPnDjBd/p1Op0wmUzQ6XTo6OjA4cOHY55ry5YteOutt/j28TabLeU294UMt9EkazUvBtGikI5AzKbNT+wCzXAXmd/v588Vq2U/15NNEmuJRIhioVxefTkqDZUYcA7EDMwrCAWqDFW4rOqyjI7f2tqKf/qnf+K7u/7iF7/A5OQkrr/+epSWlmLTpk1oa2sDANx66614+eWXsXr1aqxfvx4LFy4EAFx77bX45S9/iZUrV2LRokXYuHFjzHMtXboUTz/9NLZu3QqGYaBUKvHzn/8ctbW1Ga29EOCsklRazYtBtkF5adNLn/ARzOHWOQC+4SUgdVSWSIwogiIjZHhh2wu4/y/3Y8Q9EhGg1yl0qDJU4fltz2dc3Lht2zZs27Zt2s87OjoAhNxZnKBotVrs2bMn5nHef//9mD/nBltx3HHHHbjjjjsyWmshEV3xPlP+9GzmocymzS2XLWRinSu81iX8dbE6Kkv9yCQAEQsbzRozfn/T73Fw5CDe6HyDr5S/fdHtuKzqMqlSPs9gGAYXLlyAz+dDZWXljG4K4RbK5OQkRkdHUVJSApPJFDHmOR6ShZI+qYqX1PBSIhGitl6RETJsqt6ETdWbxDzNNK666ipcddVVOT1noRIeeA8EAvB6vXmxATAMg87OTrhcLsydOxdTU1Nob28HSZIwGo0wmUwoKSlJSWAKlVwKY6bWULKGl5LAXFxIzSEvYqIHYMnl8rx4uvf5fPB4PKisrMTatWsRDAZhNofa9DAMA5fLBbvdjpGREVAUBaPRyFswsy3LK5cuLyGIlUkW3VGZa3gpdVSefUiCcpHCxUrCA+9CtE3JlpGREfT390Oj0aC+vn7aRieTyVBcXIzi4mLU1dXxLfM5gXG5XDh37hzKyspQUlIClUo1Q++k8BBjY48lMGfPnsW6dev4n4VbMJLAFDaSoFxkJAq8z6SgUBSF9vZ2MAyDpqYmHD16NKW/k8lkKCkpQUlJCYBQBqDFYoHH48HQ0BBomkZxcTH/mkISmJkOyotBdKA/3OUqNbwsfEQVFJZh4Pn0U9hffx3U+AUoKsphuuMO6DdtAiFV5OYcrko6XjqwEK3nM2FqagptbW2ora1FVVVV1tXhRqMRc+bMQX19PWia5i2YcIHhYjBKpVLAd1K45EpQos/DXYfcg43UUbmwEU1QKKsVAzt2IjgyAtb7WdpwG+A5dBjKqirUvrwbCnNm7esNBgPcbjdGRkbwzW9+E2+99ZaAK599cBXRHPHSgXMdf2BZFgMDAxgbG8OqVaug1+uzPmb0e5DL5TCZTDCZTABCNTZOpxMOhwPnz58HTdO89ZJvApPryZO5OBcXr0u0hlgCw3WxAD4XGLlcDoVCIQlMHiGKoLAMg4EdO0H29wNUZGEj6/WC7O/HwI6dmP/uO1lZKlVVVZKYJCFaTBLdfFwzwVxAkiRaW1uh0+nQ1NSUs5oXuVwOs9nMB/k5gbHb7RgcHATLshEWDDeLREIYuALKVIkVg+EEhhNcTljCiy0lZgZR7hbPp58iODIyTUx4KArB4WF4DhyA4YorMj5Pf38/brjhBrS1teGll17CH//4R3i9XvT29uLLX/4ynnnmGQDAnj178L3vfQ+BQAALFizAiy++CIPBkPF5CwFORNJtWyKUhZLo6dpqtaKjowMLFy5EWVmZIOfjSPc9RAsMRVG8BTMwMACWZSMsGElgskOMhpfcSIVE1fwSuUGUu8P+2uufu7niwHq9sL/2WlaCEs2pU6dw8uRJqNVqLFq0CA8//DC0Wi2efvppfPjhh9Dr9fjRj36E//iP/8B3v/tdwc6bb0RbJakilIXCberRGwfDMOjp6YHT6cS6deug0WiyPpfQKBQKWCwWWCwWAJ8LjN1u5wXGYDCAJElQFCWqwOTa5ZULGIYRdINP1lF5cHAQdXV1UkflHCHK3UBdSK0tPTWeWfv6eGzZsgXFxcUAQj24BgYG4HA4cPbsWVx++eUAQq6WSy+9VNDz5hOZigkgnIUS6zherxetra0oKytDY2OjaBul0MeNJTATExOw2+04deoUCILgXWTFxcWSBZOEXDS8DD/+xMQEamtrQZIkSJIEML1lv9RRWThEufoVFeVAW4qvE5Dwqmm5XM7XWXzxi1+M6EA8G8lGSDiEtlA4xsbG0Nvbi2XLlvHpvWIiZmKBQqGAyWTCxMQEVq5cCYqi4HA4YLPZ0NfXB4Ig+CLL4uLiiCrydJmtFkquEw3CLZLwhpecwBAEITW8FAhRBMV0xx3wHDqc0O1F6HQw3XmnGKePYOPGjfiHf/gH9PT04JJLLoHX68XQ0BDfdXg2wOXyZ2vKC2WhcOnHNE2jvb0dFEWhqakpJxlUuaylAEICU1paitLSUgBAMBiEw+GA1WrFuXPnBBWY2UC6QflszxVNrDoYQOqoLBSiCIp+0yYoq6piZnmFzqqAsroa+s/cUGJSVlaGl156CXfddRd/wTz99NOzQlDCA+9erzfrRAMhLRSXy4WOjg7U1NSguro6pzfkTLZeUSqVKCsr45MNOIGZnJxEb28v5HI5H+BPJjCz0ULJt2LNRB2Vwy0YqR9ZaogiKIRMhtqXd4fqUIaHIywVQqeDsroatbtfyjhlmGsvX1dXx7ep37lzJ3bu3Mm/5r333uP/+5prrsGxY8cyOle+IoSLKxohLBSWZeH3+9He3o5Vq1blPJsu3270WAJjt9unCYzJZILRaJz1FkwuXV6ZnkvqqJw5okUQFWYz5r/7DjwHDsD+2mufV8rfeSf0l18uVcpngRhiAmRvoZAkiba2NtA0jcbGRkEKFTMhn5tDKpVKlJeXo7w8FD8kSRIOhwMXLlxAT08PX4jJxZpm20aVa5eXEOdKpaNyeDX/xSwwoqakEDIZDFdcIWhq8MWMWELCkY2FYrPZ0N7ejoaGBgwPD8/YDVVoN7JKpYorMDabjZ8SylkwhZ7ymmsLRYzPK1aqMk3T6Ovrg8FggMlkumgbXko5jgWC2GICZLYZMwyD3t5eOBwOvrZkZGRkRq2EfLZQkhEuMHa7HWNjY9DpdBgbG0NXVxcvLiaTCUVFRQUnMLm0UMQSlGg4gQkGg3wQ/2JteCkJSp6TScV7rvD5fGhtbYXZbI6oLZnJmSSz7UZVKBSoqKhARUUFACAQCMBut2N0dBSdnZ1QqVR8DKYQBCaXQflcCQoHTdMRdS0XY8NLSVDymFxYJZkyPj6Onp4eLF26lG+8yDHTQ67y9TMTArVajTlz5mDOnDkAAL/fD4fDwc+CUalUvAVjMBjyTmBmg8sr3fNdTAIjcvt6FoNnbWj7ZBheRwC6EjWWX1GNmqVmELLC/MByRbpiEq/didDQNI2Ojg6QJBm3tmSm2uADs8tCSeX71Gg00wTGbrdjeHgYLpcLarU6woKJdbxcd5iebS6vdM+Xakfl1157DQ888IBo6xUD0QTFO0Xi3Z+chMvmRzBAh3444MJwhx1FZg1ueXQNtEWFM+woV+SzVeJyudDW1obq6mrMmzcv7mYnlIWS6TFy8fnl63ek0WhQWVmJyspKACG3pMPhwNDQENxuN9RqdYQFk6sHEY7ZbKFwLq90iRfk//nPfy4JChCyTN79yUnYL3jB0pE3XjBAw37Bi3d+chJ3/p+mnFoq2Tbz4zZ7sS7SbPtwiQXLsjh//jyGh4exfPlyFBUVJV1LtgWS4RtdOu/tYrNQkqHVaqHVaiMExm634/z583C73dBoNCguLgbDMDkRllxbKLm8HoQSMC7AH95KqlAQRVAGz9rgsvmniQkHS7NwWf0YbLehdpklo3O8/PLL+PGPfwyCILBy5Uo8/fTTuO+++zAxMYGysjK8+OKLqKmpwc6dO2E2m3Hy5EmsXbsWVqsVRqMRx48fx9jYGJ555hls374dAPDss8/ijTfeQCAQwJe//GU8+eST6O/vx5e+9CVcffXVOHToEN555x3U1tZm/NnEQqjAuxgbQjAYRFtbG1QqFZqamlJ6AhPCQsnmyTlfrYd8gBOYqqoqvgh1cnISgUAAx44dg0aj4S0YvV4v+PWU60r5XFsoQp3P6/VCq9UKcqxcIoqgtO0f/tzNFYdggEbb/uGMBOXMmTP4/ve/jwMHDqC0tBQ2mw07duzAvffeix07duCFF17AN7/5TbzzzjsAgK6uLnz44YeQy+XYuXMnRkdH8emnn6KjowM33XQTtm/fjj179qC7uxtHjx4Fy7K46aabsH//ftTU1KCzsxMvvvgi/uu//iujzyMR+ezistvtOHv2LBYsWMD76FNBSEG5mMlFmjhnvUxMTGDNmjW8BTMwMAC32w2dTsfHYIQQmNns8hJSwDwez4wVBmeDKILidQZSe50jtddFs3fvXmzfvp1vyGc2m3Ho0CG8/fbbAIB77rkH//zP/8y//rbbbot4sr7lllsgk8mwdOlSjI+PAwgN4dqzZw/WrFkDINTepbu7GzU1NaitrcXGjRszWmsiuJYOQrQ8F/ImZVkWvb29sFqtWLt2bdpPSjOdNjybhCgXm2+4a1Gn00Gn06G6uhosy/IC09/fD4/HA51Ox1fyZyIwLMvmrL1MrgUFEO778vl80Ol0ghwrl4giKLoSNTDgSu11GZBO0zcA05Q+3DcZ7m769re/jQcffDDitf39/YI/KYRbJX6/X7B+V0JspAzD4NixYzCZTFi/fn1GN6RkoRQW8e6nWALj9XojBEav1/MWjE6nS3pfzuY6FCEpVAtFlE97+RXVUKoTP4Uo1XIs31yd0fG3bNmCN954A1arFUCo7cdll12G1157DQDw6quvYtOmTWkdc9u2bXjhhRf4xpPDw8O4kOKgsHTIZxfXhQsX4PV6MX/+fDQ0NGR8MwotKJmkT88GcrX5pnoegiCg1+sxd+5cLF++HE1NTaivrwcAnDt3DkePHkVbWxuGh4fh8Xhifg+53ORnwuUlFJw1WGiIYqHULDWjyKyJmeUFAIScQJFFg5ol5oyOv2zZMnznO9/BlVdeCblcjjVr1uC5557Dfffdh2effZYPyqfD1q1b0d7ezk9zNBgMeOWVVwQzz8WueM9mI6VpGp2dnfD7/SgqKsp6CJYQbfBnkzDkO5kKFycwnMiwLAuPxwOHw4Fz587xIxU4C0ar1ebcQinUCZqSyysMQkbglkfX4J2fnITL6o8I0CvVchRZNLjl/1uTVcrwjh07sGPHjoif7d27d9rrXnrppYT/z1kkAPDII4/gkUcemXYMrkV+puSzVeJ2u9Ha2oqqqiosWbIEx44dywt3FXcMkiTR29sLvV4Ps9mcNJVyNglRvlkoySAIAgaDAQaDIUJg7HY7enp64PP5AIQyB/V6PbRarajvL5cWitDfldfrLUiXl2jyrS1S4c7/04TBdhva9odVym+uRs2Si6dSPldikklwdHh4GIODg1ixYgVfW5Iv1gVBEHA4HOjt7UV1dTUCgQDa29tBkiQ/w72kpAQqlVQcmy1iCVe4wMybNw8sy6K9vR0Mw6Cnp4ePH4ZbMEKSy4wyMQRFslCiIGQEapdZMq41KWRmwipJ9XzBYBBnzpyBQqFAU1NThFsgHwLqXPC3r68P69at41u51NXVgWEYTE1NwW63Y2hoCAzDRAjMbLJQckWuLCGCCM1uLy0thclkAsuycLvdsNvt6OrqQiAQ4Nu/l5SUZC0whdzmpVCD8oXpYMxz8tnF5XA4cObMGcyfP5+vng5npi0UkiTR0tIChmGwZs0aaDQafhQrtz5uhG59fT1omobD4eAzj0iShMFggFKpLPgZ7oXm8kqF8I2XIAgUFRWhqKgINTU1YFkWLpcLDoeDFxgupmcymaDRaDI+l9hk2nYlHj6fL+tY5kwgCYqAZCIkQvVSSuXvKYpCZ2cn1qxZE9ecnkkLhRvStXDhQgwPD6f0N3K5HBaLBRZLyAru6+sDRVH8iF2FQlGw80Ny9VCS6+r1RD3gjEYjjEYjampqwDAMb8FwDUmLior47zNZPK2QM8qkGMpFTj5YJfHOz7XKZlk2aW2JEBZKusdgWRbnzp2D1WrNekiXXC6HVqvlK/tJkoyYHxKrOWI+kysLJV2oES+CXU6ApCEv00K5tAREklIBIL24hkwm4wWmtrYWDMPA5XLBbrfz8TSj0chbMNECk8AigRsAACAASURBVO4mz7ngvF4vAPAZbKmsV8i2K0DIQpEEJQqWYdB/+gROf/gB3DYrDGYLVn3hWtStWjtrZspnmw4s9oZBURT8fj80Gg2USmXSi14oCyVVQQkEAmhtbYXRaERjY2OEOyTTc4evX6VSRQyo4iq/BwcH+dYinMCkUpg3W0l1M2SmSHje6ANjCwDBz75jJQHfniForq6Cuqks4d9nE9eQyWQoLi5GcXFxaC1hAnP27FkEg0EYjUY+BpOOoHg8HvT39yMYDPJ/Q9M0tFotamtrk8ZzGIYR1OUlBeWj8DodeOOpJzA1OYGgP5QuOH6uG4Ntp2EsLcPt3/s36IzFGR3bYDBEpPvOFEJZJUK5vKLX4vf7wTBMWi0ychlDCXdxlZVN34jEsPiimyNyld/hdRNmszkjn73Q5DKGktLr/BTcL3WD9QSB8Esk+FnXh30jAAGo18cXFSHfU7jARCdscAPHAPBJAPEyAr1eL3p6eqBSqaZ10g4EAujp6cHChQsTutgkl1cIkdrXM3jjqSdgHx0GQ0c2iQz6fbCPDuPNp57Avc/8v4K1VIQSE6F7cAGfu7iUSmXam2IuYiixXFxCrSOdv4tVmMf57Ds7OxEIBPgn3kQbUqGT6iYfOGEF66MixSScIAv/30ahWm0BoYx9XwuVyuv3+zE2Nga/3w+1Wo3KykpoNBo+YQMATp06hbKyMng8HgwPD4Om6QgLhvs+x8bGoFAoYn6/arUaHo8Hk5OTqK6O39mDJEkEg0GQJCnIdSJZKGH0nz6BqcmJaWLCwdA0nBPj6G85ifrV68RYgmiwLMvPjhDqiUTIJ/FgMIhAIACtVpvxsB8xLZR4Lq50jiEW0VlHnEvFZrNhZGQEFEWhuLgYBoMh688oFfIty4s8NgFQSb4TAgh2OaFaZor562zvG4Zh0Nraiq6uLn7d3L8bGhqwcuXKiEmIJpMJ5eXlfEZgeMo5TdPQ6/WwWq0xLWQOrVaLyclJzJkzZ9o95fV60dHRgfb2dgSDQbS0tKC8vBzLli1Lq0N3NJy1XGiIIiinP3yfd3PFI+j34/Rf3y8oQeGsEpIkIZPJ8i5jKBgMQi6XZ9VmXIjxvfHEwGq1oqOjI66LK5VjZHruTIj22dM0DafTicnJSbhcLhw/fpy3Xgo5RTlVQWE9VPKDBRkwDjLur7O1UE6ePImenp5pGXsMw6CzsxMURaGxsTHmueRyOf99AaHvc3x8HCMjIxgcHATDMNDpdDAYDNDr9Xx9VnhMJfw7drlc+PDDD+H3+/lZ8DqdDlarFXv37sXatWuxePHijN6n1HolDLfNltrr7FYxTi840YF3IZ8ahdgAaZpGIBCATCbLuhhMjBgKy4ba4dtstrgurljHyDfkcjnMZjP0ej18Ph+WLVsGh8MBq9WK3t7eiA3LaDRm/cCRd2nDCoKPl8RFRoBQxX/f2VgoTqcT586di5n+LZPJUFRUhL6+PjQ0NKC4uDjuuWia5vt8mUwmlJaWoqioCAzDwOPxwO12Y2JiAizLQq/X8xt79JjeAwcO8HVPXFsZbsYMTdM4efIkysvLYTan37PQ4/FIFgqHwWzB+Lnu5K8z5X8FfbxYyUynCHMEAgFQFAW1Wg06josxHYSOoQQCAbS0tKCkpCShiysWmVoouXBHAYBCoUBpaSk/l4ckSTgcDoyPj6OrqwsqlSqiBibTBoxik6qgKBcWI3jWAST5WpQL4yfbZOPG6+/vBxA/I437eX9/P1atWjXtXP39/Th8+DBGRkYAhOIjq1atgtFoRDAYhFKp5F2eAHiBsdvtIEkSp0+f5rsy0DQNu93OB86jz8VZMl1dXRnNUgoEAtIIYI5VX7gWg22nE7q9lBoNVn3xS2KcXjDiiYmQbpVMj8WyoeFHMpkMer0eNE2DolJwSYi0nnA4txnn4lq0aBG/6eZyHblGpVKhvLwc5eXlAEKBY85fz81vN5lMMJvNeZWinOomr760AsFOZ/w4ipyAor4IsuL4QelsXF5TU1NQKpUJX6NUKuF0Ovn/58518OBBHDt2LOIe8fv9OH78ONRqNdasWQOLxRIhVjKZDDqdDizLoqGhARqNBk6nEw6HA52dnXwWmVKpjGkNabXalAt0oyEIIu9c6qkgiqDUrVoLY2lZzCwvAJDJ5Sguq0DdyjUZHd/r9WLu3Ln8/z/66KN49NFHM15vNKlkcM3kZhdeWyJ0e24hXF5AKCXY6XSm7OKKJlxQ0s3cyhc0Gg0qKytRWVnJPwDY7Xb09fXxLg3OgonlqsxVL6pUBUVeoYX2hnnwvXceYNjIbC8lAZlZA90ttWC8FJhJP5ipUCxFVqKC3KIBoQ1dq5l+R0qlMum1yTDMNNEZHBycJiYcNE3D5/Ohq6uLD+hzlkEgEADDMKipqeHdT1xXhkAgALvdDqVSiWAwCL/fD4IgQFEUlEolv4ZMHxYLFZHa18tw+/f+DW8+9QScE+MI+v3875QaDYrLKnDbd3+QccqwmC6NVMRE6BhKOsSrLRFqTdm6jAKBADo7OwEgbRdX9DoyvbHy8YaMNf2Qc6d0d3fzs2hSbSsiJOl8XqplZsjn6EAemUCw0wGWYiErUUG9sRzKpSWgL/hAD/sAOfjKeXrCD3rMB3ltaFPO9FqdN28ezp8/n/A1NE1j3rx5ET87cuRIQuudZVnY7XaUl5fz/cQAoKysLO7IhJKSEl58uN8rFAoQBIFgMAiPxwOKomCxWGC1WlFcXJz2w18+PRylimiFjTpjMe595v+hv+UkTv/1fbjtVhhMFqz64pdQt3JN3tWfpFvxLuSmlcqxuNoShUIRN/tDiDVlk+XFubiqq6vh8XiyerrOJsurEIhu7R5d9U1RFGQyGQwGA+/fF4t0LSG5RQPtdfOgvS5y46ZtftBDXhBFyojxFIRCBpZhQQ+4ofBHHy115syZA71eH7dGg/s51/SUezgcGhpKemyWZTE2Noa1a9emvBaucalKpeI/Q5VKBbVazQvTokWLYLPZ0NfXB4Ig+DYxybIC8/GhKBVEbl8vQ/3qdXmfGpxukWKuN61sa0vSIZONnMvistvtWLduHQKBwIx2MijEmzFW1Xd3dzef1MCybMRmJKSrU6huD/SIF4ROEXPWESEjALUc6vHM7x25XI5Nmzbh448/xtTUFDQaDeRyOWiaht/vh1arxRVXXDHtHknF4mZZNq2kFplMhksvvRT79u0DwzARsSGKouDz+VBfX4/FixfzPw8GgxFZgTKZjC+yDBeYYDBYsJMmC3PVApJpxbuQQfl4FzzLsvB/5i5MVlsiVBBbJpMhGAym/ProLC6CIECSpOjV9rMdLgXcaDSisrISFEXB6XTyMRiCICJqYLKNtWT9kBSgwfppyIwJqsRVMij8AEvSIFSZPRgZjUZs3boVg4OD6O3thc/ng1arxZIlS1BTUxPhniIIgu9gPDU1lfC4crk87cSROXPmYMuWLTh+/Dimpqb4a18ul2PFihVYtmxZxOeqVCpRVlbG12BxAsN1xpbL5WhtbY1IVU6V++67D++99x7Ky8v5CbM2mw133HEH+vv7UVdXhzfeeIOvwRGLi1ZQsmmdkovNjgsWqtVqUd0d0aTz3uJlcc1kC/zZJkTchqRQKCLa9HOb0YULF9DT08PXVJjNZhgMhrTTs7MVFJYGkOSUBEGEMo6zDIGq1Wo0NDSgoaEh/nrCroF169bhk08+SRhHUSgUqK2tTXstZWVluPbaa3H06FGUlZVBr9fDYrGkZGFECwxJkhgcHMQf/vAHnD17FldffTWuvPJKbNmyBVdccUXCY+3cuRPf+MY3cO+99/I/++EPf4gtW7bg8ccfxw9/+EP88Ic/xI9+9KO032M6XJSCIlQfLiGItQFyfYF0Ol3OUwdTyfJiWRY9PT1wOBwxs7gkQRGf6M2IyzoaHh6Gy+XiU5RNJlNS6zYTQWF8VKjjMEFAblaBUBIAm3i2D8uwAFhAKb7LOLxZ44oVK9Da2gq73R7TraVQKHDttddmlUCi0WhQXV2dVTKFSqXCLbfcguXLl+Ppp5/GL37xC+zfvx+ffPJJUkHZvHkzX6fD8e6772Lfvn0AgB07duCqq64qbEFhGRb+bjs8R0ZBT5GQG1XQb6iEpsE0IzPl0w28x0OsTSu6tmQm1pTsOLFcXNEI1b4lX8mHYVTRqNVqzJkzh+8fxaUoDwwMwO12Q6/XR6QoR1d9p9y+3kshcOQC6D4X2M+OQbCAfEERFGUaMH6aTw+e9n58FEgDAUIu/kNSuKAolUrceeed+OCDD9DX18dfnwRBQKVSYdu2baivr8/qfELOQ+GSC8rLy7F9+/aMjzM+Ps4nKFRWVuLChQuCrC8RogkK7SYx8etW0HY/WDL0xBsEEOhxQG7SoOyBFZAb0u/KabVasWXLFgChLqFyuZx/Sjt69GjcTp/5ZJWEEx7IE6u2JB0SWSici2vx4sW86yUWYjeYTPZ3ErHb9NtsNvT09MDv90fUwKQqXIyPgu9Pg2DcQRBaBWSfPRSyDAuqZwr0qBeK+QawcmJajIT10wBBgDTm5h6MbievVqtx8803w+12o7+/HzRNw2QyYd68eYJcM0LOQynUTsOAaO3rWUz8uhXUhHeav5QlGVATXkz8uhUVj6xN21KxWCw4deoUAGDXrl0wGAx47LHHEq/ns4aOAASJRwhtoVAUBZqmZ8TFFU2s9xbu4mpsbExq1gv1+cymOpRMECK2AUS26Z83bx6f0sqN1vV4PNDpdJDL5RFt3aMhmyfBuIKQGSLvIUJGgNArwbiDgI8GdEowLhLg1s6wIHQKKOuKwJzJ+u2kRLz5JAaDAcuXLxf8fEJ9V0Coj5cQs1AqKiowOjqKyspKjI6O8h0cxEQUQfF320Hb/fGDbwxA2/0IdNuhWZR+47RUCbdK8nGT4WpLAOTNMJ1oC8Xv96O1tTWhiyuamY6hSCSGy3ziRuv29/fzfau4tu5cinJJSQkUCgXYAA2qewqELv6WQWgVoPrc0F1aAQQYMF4KIACZTgFCrxB0001GLufJA8IKilAWyk033YTdu3fj8ccfx+7du3HzzTcLsLrEiCIonsOjvJsrHizJwH1kVDRBiXZx5bJpYCpwtSVqtTqtNF2xCd/IJycn0dnZmdTFlegYQqwjXfLx4SETcrkBGwyGiLkhTqcTNpsN/f39IAgCFqIIJRQFhTa+W4eQE2BJgHVTkJvVkBVFWjJCDddKhVyeS2gymdZ41113Yd++fZicnMTcuXPx5JNP4vHHH8ftt9+O559/HjU1NXjzzTdFWvHniCIotCv+PISI102l9rp0SNTQMR/gaktYNtQam2XZvBIUmUwGmqbR3d2dsosrGqEEJdZ/SwhPrE65ZrOZb7seDAbh6J9AMDgBj9MPGUFAoVRCpVRCrlCAQFiAHywQ5+vK5Safqz5oYpDJLJTf/e53MX/+0UcfCbGklBFFUORGFVLZIuWJiqAyIFngfaafXLnaEpVKFeGnnul1hRMMBjE5OYl58+al7OKKRogsLyDz9vX59HlmQ67eRzJLSKlUorR+Djx6D7RyAqw8dJ34AwFQn7XYUSqVUBJyyBXyuMWNudzkc+3yElIoPR5P0gF0+Yoon7h+Q2XCITsAQKhkMGyoFOycycRkpp9ySZKE3++HTqfL29nkk5OTaG9vh16vxyWXXJLxZzaTWV6zjVzNQ0m6DoUMyqUlYP00CBBQq9Qw6A0oKS6BXq+HDAA55ceQ3oG2s20YGhqCx+OJOPZsjaEIfZ0W6rRGQCQLRdNggtykiZnlBQCQAXKTBuoGcdsARDMTG1R4bUmsGRj5sHEyDIPe3l44HA4sX74cAwMDWR1PKJcX1zCxtbUVDMOgpKQEZrOZDxSLde5UmOnvTGhS2ehVqy2gx32gx7yAWgFCGdqwZTQBJSWH9hIjLF+sgi8QmgNz7tw5fja6yWTKaRZjrgVFaAslX5J00kWk9vUEyh5YMa0OBQhZJlwdSrbFjbt27Up9TQJvNNzxEl1Iua4tyeSi9vv9aGlpgdlsRmNjI3w+X14UJRIEAYfDgeHhYSxduhQqlQpTU1Ow2+18oJhrNSLEuN18JFdP9Kmeh1DKoL12LoJn7SBb7WC8Ice2TCOHamM5lEtKQMhl0CtCKcpz584Fy7Jwu928wLjdbnR0dPA1MGJZ67kUFCGLGoHQPSkJShRygwoVj6xFoNsOd1ilvGFDJdQzVCmfS7jRvLmuLUlnE4qVxSXUgK1sYBgGw8PDCAaD2LBhA4CQOEcHiu12Oz9uV61Ww2QyQaFQzPj6C410rhlCIYNqpQXK5Waw3lBvrHgdhoHQgwE3VtdsNqO/vx+VlZWw2WwYGRkBRVH8WN2SkhLB+tblUlCELGoEwNcFFSIit68noFlkFrXWhD9XEgskVxZK+NySfH3KYBgGPT09cDqd07K4ZlpQvF4vWlpaoNPpUFpaCoVCEbOpn1KpjBi3y7UaGRsbg8fjQTAY5C2YTCZG5gOJNnqGYcAEg5CrVNk3dszAEiJkBAhDeps/y7KQy+V8m34AfIqy3W7H4OBgRJv+kpKSjDfqQrZQMkkbzhcumuaQuXAd5HJuSSxSccNFu7jyKaYzMTGBrq4uLF26FH6/ny/6TAWu1YhOp8P4+Diqqqr4SnCSJFFcXMzHX3LZvVloxnq6cOK9tzF8thUAoFCpsWTzFqzcdj10xSUZHXMmXWvRKcoURcHhcPBDqbiZISaTKS3XZq5rXoS8330+nyQohYAYFgp33PDakpnOKIsHTdNobm5OWKg4E4LCtXZxOp1Yv349VCoVxsbGshovwLlZampqwDDMtKfg8PjLTIh/KkS///aPP8Kh118GRX5evxX0+9D20QfoOvgxbnniX2Esr8joPLm4ZlOxGhQKBUpLS/lxCCRJwuFw8K5NlUrFC0xRUVH8zsafWUO5QGhrSLJQLkK4C5mbFqdUKvM2HRgIWSY0TSctVMy1y4skSZw+fRolJSVYt24d/7kK2b4+/CkX+HyWyMTEBHp6eqBUKiNmieTTAwG3FtvweRx87WXQwenFwAxNwe9x4/2f/gi3P/3vaa8/E0Fhg0xoUJaMiNtdWIjzqFSqCNem3x/KIBsaGoLb7Y7bpl9yec0MogoKl456/PhxuFwuFBUVobGxEQsWLJgVWTnBYBA0TUOr1ebF+4m1mYbHdLh51+keQyy4+ekLFy6cVsgl5jqiZ4lwm9Tg4GBEq3ez2QytVivKGtKl5S/vgaHjD4gCy8LjsGG8pxNzGhandex0NnrGR4EecIMa8QIsC7CArEgJeX0RFOWJPysh3FAajQaVlZWorKzkU/K5zD+Px8OnKAcCgZwFtoV2eXHjjAsR0QTF7XZj9+7dcDqdfKdfAOjr60NxcTF27twpqApfd911eOWVV1BSkpkfOR1YlgVFUXFrS9IlldhHJmSStpwrX/rAwADGxsawdu3amDdPNkWV6RK9SXk8HtjtdnR1dSEQCMBoNPLxl1xaoeHXxEDLSbBJLEcqEMDA6ZOiCQrjCYJsngRLMSD0Sj6ziw3QCJ62gb2kCMp6Y8LzCPngRRAEdDoddDodqqurI747q9WKyclJTE5O8hZMNsOvEiG0NZRLd53QiCIoDMNg9+7dsFqt09wnJEnCarVi9+7deOihhwT7Iv785z/nxFXDbdJyuRwKhSIv3SNA6CmHYZi8i+lQFIW2tjaoVCo0NTUl/P45CyUTF06mEAQBg8EAg8GAefPmgWEYvv5laGgIDMOgqKiIt05zdeOzMSYNxiKWSyzpsVP8vIJnHGBZQFYUKaqEWg4oZaB6XZCbNZAVx2+9Iua1GP7d+f1+fhSvzWbD2bNnQVEUjEYjLzBCJWcIeR0UesGsKILS29sLp9MZd4NnGAYOhwO9vb0J50LH45e//CV++ctfAgCcTifq6urQ19eHo0ePorS0FE8//TR++9vfYu7cuSgtLcW6detw11134brrruM3sNbWVvT09KClpQU/+MEPQJIkLBYLfvOb36CiogITExO4++67YbPZ0NjYiL/85S/49NNPUVJSAp1Ol3A+dboIeZMxDAO/3w+FQpF3uexc1XtdXR2qqqoSvlbIGEo2yGQylJSUoKSkBPX19aAoin/yPXHiRMQs90RB4kwI34CLKyox0d+b8PUKtRqWeenPRQeSX4PMFAlmiowrFoSMACsnQA15oIrzmpnIvOLa9NfV1UUkZ5w/fz4iRbm4uDjj4mMxLJR8eghMB1Ec/8ePH49wc8WCJEkcP348o+M/9NBDOHXqFI4dO4a5c+fi0UcfjTj322+/jebmZvz+979Hc3MzAKCqqgoHDhxAc3Mzvv71r+MrX/kKamtrsWnTJhw8eBDNzc24/fbb8eyzzwIAnnrqKVxzzTU4fvw4br75ZgwODgIIzS3hLh4hNy4hjsWJiVqtFs28z5SRkRG0trZi5cqVScUEyI+WNLFQKBQwm83Q6/VYv349li5dCo1Gg6GhIRw9ehStra0YGhqC1+sVdP2rrr0BimTfKQssWH9p2sdOZQNjXMnbvRJaOZhJf8LzzGTrFS45Y/78+Vi3bh1Wr14Nk8kEu92OU6dOobm5GefOnYs7ez6dc12siGKhuFwuQV8Xj0ceeQTXXHMNbrzxRjz88MMgCAIHDhzATTfdxPvlb7jhBv71BEHg008/xfPPP4+PP/4YADA0NIQ777wTY2NjIEkSdXV1AIADBw7g97//PYLBIK644oppPlghNzwhnka4LK6ZHiEcDU3T6OjoQDAYRFNTU1qxnHywUJIRPsudG7Vrt9v5UbtFRUW8BZNu/CV8o69bsx6lH/0FE/3nYrq15CoVLrtrR3LRSXKe7EgiSnk2D0WhUMBisfAp9NHZf5z1yaUoxxMNmqYFu+eEzhjLNaLsPEVFRYK+LhYvvfQSBgYG8LOf/Szi54k2k7GxMTz44IN45513YDAYAIRE6R//8R9x0003Yd++fXjqqaf44wQCAQSDwbjJA/lgoURnceUTXNV7ZWUlampq0tpMCtHkDx+1O3fuXL65pd1uR1tbGz8J0Ww2p+1ikcnluO7Rb+PT3zyP3mOHQMjkYBkGMrkMMrkCl915LxouvSKjdaciKDKDEkhyibJ+CnJL/K4EubRQMjlXdPZfIBCA3W7HyMgIXC5XwhRloWIohdxpGBBJUBobG9HX15fQ7aVSqdDY2JjR8Zubm/HjH/8Yn3zyybSL5vLLL8ff//3f4/HHHwdFUfjzn/+Mr3/96wgGg7j33nvx/e9/HwsXLuRf73Q6UV1dDQB4+eWXAYQukKamJrz99tt44oknsGfPHtjt9ojz5MOGF53FFQgEZnpJPBRF4eTJk1i2bFnGmXeFYKEkQiaT8W1G6urqQNM0HA4H7HZ7RBU4F3+JvpajN3qFUoWr7vt7bLztbgy2nkIw4EdRaTnmLl0BWRYbWiqCQhiVkBUpwPgoyGLUnbAMCwQZKObFz9ycaZdXuoRbn8Dn7X0GBgYi0ss5S1QICrmPFyCSoCxYsADFxcUxs7yAzwOdCxYsyOj4P/vZz2Cz2XD11VcDQIQwrV+/HjfeeCPWrFmDmpoarFu3DkajEQcPHsSJEyfw1FNP4V//9V8BAO+99x6++93v4o477kB1dTU2bNjAt9zetWsX7r33Xrz99tvYvHkzKisrp100Qrq80j1WrCyufNhMWZZFd3c3SJLEpk2bMu6jlQ/vRWjkcnmEi4UkyZhPwGazOeGmoikyYuFlmwVbV0qCQhBQLjMj0DwJxh0Eof88w5ElabBeGor6IshK4rvchK7XSIQYcQ2uvU9VVVWEe9Nut8PhcODChQu8BZPpdS/UPPmZQhRBkclk2LlzJ3bv3g2HwxFhqahUKpSUlGDHjh0Zf+EvvvhizJ9zQ7a+9a1v4Xvf+x68Xi+uuuoqPProo1i7di1sNhsUCkWEq+Hmm2/GzTffzBdJEQQBjUYDpVKJ999/HwqFAocOHcK+ffumxVBmgnAXV75deIFAAC0tLSgpKYHBYMjKr5xNDKVQUKlUqKioQEVFRUSRHvdQwzAMNBpNSgWp2ZBqDEVWpIR6fSmocy7Q4z6wn/0JoZFDuawE8srE12OhWSiJCHdvut1uVFZWgiCIaf3juCaXqbqjJUGJg16vx0MPPTQjlfIPPvgg2tvb4ff7ce+992Lt2rUA4m9S3GhetVrN56YPDg7izjvvBMMwUKlU+NWvfjXt73JtoSQrVBTyqT7dQG101bvdbs+6HiTTvy9EyyZWkV5LSwuCwSBfQxHe4FLIxIt0vmuZXgnVCjPYhTTYAA3IiAhrJRG5DsrnsvWKXC6HwWCA0WhEbW3ttPolLn7GCUy876+QG0MCIrdekclkaGhoyKjWJBteffXVlF8bb25JQ0MDn3Ici1w/CadaqCjEZsrNhE/lPXJV7+Pj4xFV79mK28VgoSSCIAgolUpUVVXBYDBEtHkXesBYRu3r1fJQQWOa5ynUKYqJiOXKi65fivX9hdfAcH9/UcZQCrXwJnyTEmJuSS7ShoVycaWzVoIgUnrCoygKra2tUKvVWL9+fcTrZzIGUogWSizC7zOuzTvh9+JCcweGzrQgSAagMpag+JLFKF2wCJbSUr5GJp37M98mQwpFPllD0W36uRTlyclJ9Pb2Qi6X48MPP4RSqcxqfs9PfvIT/M///A8IgsCKFSvw4osv5nQeUNqCotFoYLVaYbFYCk5UuE1OiNG8Qr/3WJsgt85U56skauVts9lS9sOn0nE4WdW7kBZKoV1nYtF9+FM0//H3AMtCqdFAo9WB8rgxeeIwmIlRlF73lWlNEvNpwFguXV65JJPWK9EpyiRJoqWlBe+++y7Onj2L1tZWXHPNNbj++uuxZMmSlI45PDyM5557DmfPnoVWq8Xtt9+O1157DTt37kz3LWVM2rvp3LlzMTQ0hImJCTHWkxXJNjCapkFRFO9OyObiZlkWt2TqZAAAIABJREFUJEkKEiylaRosy0aIWzAYBMuyaa2TpmkwDBOzRxGXApkKycRgeHgYAwMDWLlyJV/PE022bfALpbBRTMLfx+RAH5r/+BYUKjXkYdeJUqOBgmVhOz+A4WMHsPG2u8Gyn89xT3XAWK4slEIu2ouHEPEalUqFnTt3QiaT4frrr8ett96KvXv3orW1NWVBAUIPoT6fD0qlEl6vN6WuFEKStqAolUrU19eLsZas4Tb5WLjdbpw8eRIajSbmpMJMznX48GFcemn6rS6iGR0dhc/nw/z58+Hz+dDS0oKysjLU19entU6bzYbx8fGM07E5uBhKNOlUvUsxFGHg3k/7xx8BLBEhJuGvUWl1GDh1HKu/dDM0BkNaA8ZyRaG6ypMhpOXl9XphNBpRU1OTtmVRXV2Nxx57DDU1NdBqtdi6dSu2bt0qyLpSZfY9LkTBsiyGhobQ0tKCuro6wQYoCfkkzD3NX7hwASdOnMDChQsxf/789AOlAq2Ji6GE4/V6cezYMRgMBqxatSqpq1AIQcmU2WKhcLAMg6H2Vqi08V1XoYcAYLy3K+bvontYGY1GTExM4MSJE/B6vRgYGIDL5RL1s5vNPa+EFJR4Vn8y7HY73n33XfT19WFkZAQejwevvPKKIOtKlfxp+iQCFEXhzJkzkMlkaGpqgsfjgdPpnOllTYMgCExMTESMwM0EoaYtRgvKhQsX0N3dnVbVu2ShZA/3RM/QNMACRNLNmE2pfb1CoYjw3x85cgQqlUr0AWOz1UIREp/Pl/Fn/uGHH6K+vp7/Xr/yla/g4MGD+NrXvibkEhMyawXF4XDgzJkzqK+v5/2Icrk8rS6iucDn86GrqwtKpRJr167N6oYTSlA4lxdX9T41NZW20AlhLV1MdSiJkCkUUOsNoINByBPM8CAIAnqTOf3jy2Q5GTCWq6B8rr9/Id8Tl1CRCTU1NTh8+DC8Xi+0Wi0++uijjNtbZcqsEhRuE+vr68PExATWrFkTkWqbb4LCPfnX1tbC5XJlfWEKKSiBQAAdHR0wmUwRs95TRbJQsod7oicIAos2XYmWv/xvXEGhyADU+iKU11+S1TnDh1TFGzAW3uAyneymXAXlC9m1ls08+Q0bNmD79u1Yu3YtFAoF1qxZg7/7u78TeIWJmVWCwjAMmpubUVRUNK0uAsgfQWEYBl1dXfB4PFi/fj38fr8grjihBIUkSZw9exZLliyZNus9nbVIlfLC0bBhE3qPHoLXYYcqauw0RZKgKQqX3nJ7qMPxhTFMTVwAyzDQGotRXDEHal1mm1SsAWMOhwNWqxW9vb1pDRjLlcsrl+nJQl9r2XYbfvLJJ/Hkk08KuKL0mFWCIpPJsGTJkrgKL4agpHuTcFlc5eXlWLRoEQiCAEmSgqwr202cq3p3Op1ZiQkgXFCeZVn09vbCarXyhWFCT0bMV8KvLZVOhy/+/T/iwG9fwuRgX+jBgWUhVyihUKmx8Y57YJk7Dz1HPgVNBqHUaACCgNdpx0RfL8rmL0BZbfqJHtEoFAqUlpaitLQUwOct3oeGhuByuaDT6SLiL+Hny5XlwLK5m8kutHhlE5TPB2aVoACAwWCIu5EJ9QTPIZfL0+qgyrm4li5dCpPJJPi6YmVnpUp41fucOXOynredzVq4v6dpGidOnIDBYMCSJUvgdDr5jUuv1/MCE164l6s6lJmwgrTGYnzhoUfgGBvFeG8XaCoIY1kFqhYuAUUFce7YISiUamhMn3fFVmm0oQzC3h4olCqYq+cJuqZ0BozNRgtF6A7KUnPIAkLoi0wmk6VUJRvt4ooObAoZ+8jkOFzVe319PSorK9HZ2Zn1hpntxu52u+FyubBy5UqUlZWBJMmIjcvj8cBms/GFe5xfPxdPdzPdPqRkTiVK5lRG/Mwx2B8qhI1RFS+TyaArLsFEXy9K5lRlNTsl2VoTDRhzuVw4d+4cSktLs5rhnoxcxlCEPpdkoeQZuayU5iyURMRycUUzk4ISq+pdiPVk8z2Mjo6ir68POp0OFRUV0544wwPHNTU1fOM9m82Gvr4+eL1e9Pf3F7x7LNXPj2VZ2IbPQ6OPP+RJrlDARwXhm3JmlAmWCdEDxo4dOwaLxZLygLFMmYlOw0IhTWy8iOEslHiMj4+jp6dnmosrmlSEKRXS2cRpmkZ7eztomp5W9S6EKGdyDIZh0NnZCb/fj8bGxoTdnsMJb7zHuck0Gs0095jJZBK0riJfYFkWDEUltzxYhGpaZhCLxcLHX5INGMv0QaCQLRSGYUSz3HJB4a48D4gnBNzG6PV6U6rfSCZMqZLqDcjNeq+qqsK8efOm/d1MWCiBQACnT59GaWkpFi9eDCDzEcAEQUzz69tsNr6ugnOPCT1XRGhSHnwlk0GuUoGmgpArEse+YrVuySXh7yfZgLHw+Es6PfNybaEUaoqyGOTv3SQiQgUHYwkBt1lXVFRg8eLFKZ0nly6ZVKrec22hcEWoixYt4p9ehRwNwPn1uboKzj3W398f4XYxGo157R5jWRa2oUEMnGrGxMA5gGVhqpqLujXrYa6eh4n+c9CXxLaEqSAJpVoNrbE4x6tOjVgDxtxuN2w2W9oDxnJtoQjl8poN6e6zTlCSbQhc6rAQT6bRaciciyudFiW5gmEY9PT0pFT1LoSFkkoKM9dnbXh4OGI4FzD9e0z1ISCZkHECwrkgw90uHR0d0Ol0vPtspt1j4e+ZZVl0HdqPc8cOQ6FUQlsUEr+piXE0//EtVDQshq64BAGvZ1rNCUNT8E1NYd7yVdPat+TrJkYQBN/gsra2Nq0BY4Xs8ir09jSzTlCSIaSgcBsv5+Ly+XxZ9eISC27We6pV77mwUGiaxtmzZwEA69evT/qUJ9ZNFu12iXaPcU/FJpNpRt1j4z1d6D1yEAazJSJWojEUQa3TY7y7AwuaLoNMIYfbboVcoQRByEBTJAACVUuWobhi+viCQtnAYg2ostvtGB8fR1dXF9RqNS8wuUwbFtLlVSjfRSIuWkER6lherxe9vb2YM2dOyi6uXMLNeg93JyVDiJhOojoUn8+H06dPx43hxDpWOufNlETusYGBAd66MRqNOa11YVkWPUcPQq3Xxwy8EzIZtMZinG87jat2Pgi/xw3X5AQYhoamyAhjaTkUcR5yCnUTUyqVKC8vR3l5OQDw8Zf+/n44nU4olUqo1WrRB4wJ6fLKpjFkvjDrBCVVl5cQcLUQq1evzjsXF8uy6O/vx4ULF6a5k5IhpoVitVrR0dGRl27BaOK5x8bGxvjaHbHdYwRBIOBxw22dSJjuq1CpQkJis6JkTmXKqcGFKijRaLVaaLVaVFVVYWRkBF6vFxRFobOzk7c0ue8y26LdcIR0eXFNHQuZWScoyRBCUDgXl8vlQl1dXd5tjMFgEG1tbdBoNDF7miUj2xYuwHRB4QRuYmICjY2Ngky6zDWce8xsNiMQCGD+/Pk5cY8xFAWCkCW35ECAoam0jj1bBCUclmWh1WpRXV09bcDY+fPnAYDP9DMajVlZGELWoXg8nowbQ+YLkqCkCZfFNWfOHNTW1oKi0ruBEyHEzc0wDI4dO8ZXvWdCtm1Too9BURTa2tqgVqvR2Ng4K9Isk7nHCIKI6D2WyXvmrgeVXg9CLgNNUXHTflmGAQs27Syu2Sgo0bUc0ZYmRVGw2+2YmJhAT08PlEolH39JdwAfwzCCxUwLvagRkAQlLaKzuEZHR+OOHE4XLsCfzdPO8PAwfD4fNmzYkNVoVyHrUNxuN1pbW1FbW5vz+da5JHrTCgaDsNlsfNGeVqvN2D2mUKowb/kqDJxqhsFsifkan2sKpbX10Bal/73PRkFJJODRA8YCgQBsNhvOnz/PF8KmOmBMyKB8offxAmahoIgRQwnP4mpqauJ9sEIH+DMVlPCqd6PRmLUfVqgYytTUFEZGRrBixQoUFcVvCzIbUSqVWWePhVsP9WubMNbdCY/TCV1YvQzLsgi43SBkMiy6/Mq015krCyWX6cnpxjXUanXMAWPd3d3w+/0JB4wJGZSXXF4FSLoiEO7iis7iErJ7MZdZlW7AMLrqvbm5OSc1JIlgWRbj4+Nwu93YuHGjoEHQYP8AqKHzIDQaqFesAFEAsZhE7rHBwUEAgMlkgsViiese0xiKsGH7V9H61/dhHwnFAULfEQFjaRlWbL0ORZb0xw3kaqPPdQfgTK2GWAPGXC4XbDZbzAFjQgflJQulwEhHUMbGxtDb24vly5ejuHi6b1pICyUTceKq3sPXJ5S7KtNjkCSJlpYWKBQKVFZWCiYmgZZWOJ95BtTAAMA90bMs9LffhuIHHwSRxy1UoonlHgvvaaXVamEymUDTdMQmrCsuwYbtd8FlnYBzfAxgWRgsZSiumJPxZp1LCyVXsTMh31N4g8tYA8YCgQD/3rJtRFronYaBi1RQksU9GIZBR0cHAoFAhIsrGqEtlFSPxTAMuru74Xa7pxVSzmSn4KmpKbS1teGSS0JjaIWYQgkAvmPHYX34YbB+f+gHgQD/O89rryPY3YPS//j3aVXghUJ4TQXX08pmsyEQCODo0aO8y4VLeS2ylGVkjcQil4JSCBZKMqIHjLW0tOD/Z++9oyPL7nLR75zKSSqpVJK6lVrqoJbUyq3umQHDgGcYM4YxeFi+5o7hOoztO9d3reF6YZxteG9hm2AuXvgBvvAwCxs/1jVwsRkHcMCEsT3T7WmplEMr54qqcCqcsN8fmn36VKlynapS+pb9h92qU7uqztnf/qXvMxqN2NraSjoMpDMYy4XzOZRjiFJrKMoUV09PT9brVSNCoVPv9fX1GBkZSSvsWGoaoxhS2t7extraGgYHB2GxWOB2u1VJpxBRxP773/+ATFL/PRZD4pVXEP3ud2F+7LGS3y/rWgjB3nIIc9/fg2dHwMHkEq7eduLi1RowrDqbpVLTamdnB6OjowgGg3LRGEBGyZFiUEnTq5Mqh5INDMOgsbERJpMp6TBw//59RKPRJIHLXN1g5zWUE4hsJJArxZUKNSOUfCTsfT4fZmdns069q9HyWwgp0WgukUhgbGxMLjCr5UsT/cEPMpIJBYlGEfqrL5SVUBJRAd/+swUE9qIQEoff77rbj+35A1jq9PiZ/3odJqt6tSLgQZqIeroDD9Jju7u7WFhYgNFoTOoeK5QcziOU0qCcQ1EeBqjBGBW4nJ6ehiAIsNvtqKurSytwGY1GS7LdPg44c4SSjgTyTXGlQs0IhVrepoNy6n10dDSrlEQlayixWAwulwtOp/NINKcWocSnZ0Ci0Zx/x9+/X/J7ZQIhBN/+8wX4tjlIYvJnEhISgu4Y/ulP5vDUe2+A1ZR308yUHqOWu6npsVw4J5TyvRfLsqipqUFNTQ0uXboEURQRCARkiRhlLc1sNp8X5Y8jct20Wq02aRiRprguXLiQM8WVinK0Daei0Kn3StVQqEbY9evX4XAcnY1QzTlTwwIMA+S6Vhk3q/2VMAK70SNkQkEkgAsksDkbQPuNzEZqhSIfjbPUE3Gh6bHzlFdpKGQORaPRwOFwyM8LlfKZn5/Hu9/9blgsFvj9fvT19RWlCxgIBPDss89iamoKDMPgL/7iL/Dwww8X/JlKwakjlFxQbriFpriyXUvNdVHQIndXVxeam48qxZZrTdmuQQjB+vo6dnZ2smqEqUUoppFRBAyGnFGKob+/5PfKhIUf7stprkwQEhLmf7CvKqEU+v0Vkx47j1BKQynda0ql63v37uE973kPLBYLPvaxj2F+fh6f/vSn8fjjj+d9veeffx6ve93r8Ld/+7dIJBLgOK6odZWCU0ko2TYzjUYDQRAwMzNTcIorFWoUwJXXUm7im5ub2NjYSPJ6L+Y6xSDT9yeKIqanp8GyLG7dupX1QVKLbA3DQ9A0NEDY3MwYpTBGI2xv/S8lv1cmRA7yU0OIBvmyraEY5JMeMxgMFZlFOSlzKNUCfeZ++Zd/GaOjoxBFsSBZp2AwiH/7t3/DX/7lXwI4JKtq2GicrG9dBcTjcfj9flgsFgwNDak6dFcK6AYsiiKmpqbg8/kwNjZWcF96ubq8OI7Dyy+/jLq6Oty4cSPnA6taygtA0//8n2DMZiDNezJGI8xP/TyMt2+r8l7pYLbld48Yreqez9TcgGl6rLW1FQMDA7h58yaam5sRjUbh8Xhw9+5dLC8vIxAIqBZ1K1HJOZRKkpea76OsoWg0moIEVJeXl+F0OvG2t70Nw8PDePbZZxGJRFRbW744U4Sys7ODqakpmEwmdHR0HCsNI5ZlEYvFcOfOHdTU1KC/v78oxVq1hB2VZODxeHDv3j309PSgra2tqGuUsg79lcto/OIXYHrtawG9HozZDMZggKa1Ffb3vx/2X//1kt4nF67eboRWn/1R0RpYdD/cWNZ1qAmaHmtubkZTUxMGBwdhtVqxt7eHu3fvwuVyYXNzExzHqdP+XcGUVyXJS02UMtgoCAJeeeUVPPfcc7h37x4sFgs+9alPqbzC3DgTKS9RFGVfhFu3buHOnTtVXF16RCIR7O7uYmRkpKh6DoWaNRRCCJaXl+Hz+QqWnFczQgEAbUsLHJ/4bUiRCMT9fTAmEzRNTRXZpJqv2GBzGBDYj4Kk6cFgWMBo0aGtz444J+BgP4ZYiAdYwOYwwOYwQqs7vhscwzBHDKs4joPf70+ap3A4HEX7iVQ6DVVJ8lILpagNt7a2orW1FbdfjdR/6Zd+6ZxQyoFIJCJrXRXaxVUJ0Kl3v9+P1tbWksgEULdteHx8HCaTCaOjowVvBmpGKLSlWqvVgrVYwHZ2lnTdYtbx+Lu78c9/Oo+wPw4h/uD71RpYGC06PPFcN7xbHLybEWg0LLQGFkQ47BDzrIVxsbsWFvvx0x3LFDnQ7rGWlpYkPauNjQ0QQuTusdra2rzujdMok6/2ZyolQmlubkZbWxvm5+fR3d2N73znO+jt7VVtbfniVBPKzs4OVlZW0NfXV/JGnQ3F3ljKqfeuri6Ew+GS16KGfW8kEkE4HC7ZU0UNQpEkCUtLS9jb24NGo5E3MrvdXtETr9Giw8/9jz5szx9g7sU9+PaCqGusQfdDjWjtteNgPwrvegRmuz5pal5n0EBIiNicO8ClgXoYzMfrkcvn3k3Vs+J5HoFAQNaSo1a79fX1MJvNaa9XybpGpaB21MXzfEk13T/6oz/CM888g0Qiga6uLnz+859XbW354njd3SpBFEXMzMyA53mMjY2VtfBerI9J6tS72+1WpRjKsix4vvhuo93dXSwvL8NkMhVNJnQdpRIKIQTj4+Ow2+24desWCCHw+/3weDxYWlqSNzKHw1HUlHihYFkGrT12NF2xYGpqCsPD3QAASSLwbkZgrNGllWDR6jUQ4hIO9qJo7Mxfxr9SvvWFfm86nS7JT4R2jy0vL8vpMUow9Nk7qXWNbFCbUBiGKekeHhoawt27d1VbTzE4lYSysLAAm82Gtra2jD+QWuEqHW7Ml1AyTb2r1WZbbGRAU2+RSARjY2Ml15lKjVDC4TBCoRB6e3tx8eJFJBKJw0JyLAarx4t2jQZiYyMCr0YwsVhM9hippPcGAMTCPESewGDJvLnoLVoE9qJwdlhV0/1SA2o8B9RuNzU9trm5KafHGIY5dYSipv1vpe/ZcuFUEkpPT0/WzVkNd8TUa+WDbFPv+Wh5qb0eikQigYmJCdTX12N4eFgVoi2l22xvbw/379+HzWaTT8H82jpCn/sc+KUlQKM5nEkhBJZHHsaFZ58FzGbZY4TjOLzyyity9FKorWuhkEQCMNk3BJY9JFhCCBjkt5aTOHCYTu7d7/fLHWMHBwc502MnBeVoNDjJ3wdwSgklX8VhNQglX/mVXFPvatQ+6HUK2cgPDg4wNTWFa9euqSpMV0yEQgjB/fv3EQgEMDY2BpfLBUII+LU1+D/yERA+AaZW4VYoioi9+CKEtXXUf+K3ZV0kn8+HGzduyAZW4XAYVqsVDocjL9XXQqHRsUCOjyoKEjRatqDo5LimvAoBtdvleR6SJMHhcMjpMY7jkrTH1PhdKnnSV9P+lx42TjpOJaHkQqVl5/OZelcr5VXIdei6hoeHVRelK5RQBEHA5OQkzGYzRkdHkyxuA3/8JyB8AmxNsl86o9EAtbUQ1tfBfeMbsL7xjfK/6fV6NDc3o7m5Wfa293q9mJqagiRJBXcpAYCQELG9GMTKPQ88ewKCU0voGKjHxWs10Bm1EBIitPr0h5R4RICjzXLsTqCV1PJiGCZjemxra6vo30WJSku8qJXySiQSBbXlH1ecSkIph698MdeiXu+SJCVJu6dDJQlFkiTMzs5CEATcunVLtYdCiUIIheM4TExMoKOjAxcvXky6Br+5icTiApgMnvQMwwAWMyL/+AIsv/ALaU22GIaBzWaDzWbDpUuX5DQM7VIyGo1y9JJJmywa5PGDv1sBd8BDo2UAAkRDPKb+ZQeLL7sx8NoL8O9EwbAMNNrkNcQ5AVodi9rGzCrRGT9bmVFJLa/U+yxTeqyQ7rFUnFQRykgkcuKVhoFTSii5UIkIhW6SLS0tWZsDcl2nmPVk28hjsRgmJibQ1NRUVrWAfAnF4/Fgfn4+rUAnwzCHGl6sJus6GYMB0kEQJBQCk0d7OE3DOJ1OWePK6/ViYWEB8Xhc9gyvq6t7tbZF8NI/rCEaEmCy6Q47lngGOoMGOoMGcU7A5Hd3cPP1bXCvRxCXeLAaFoQAkijBaNbhYncNdBmil2riOIlDKn8XILl7jKbHcplVHVel4Vw4DdL1wBkmFDWNsVLJaW9vD0tLSwWpGKu1pmzFcNqq3NPTg/r6+pLfK9c6shEK7XZzu90Zp/AZhjnU7yLksEaRYT8ihBxqyCtOwPlulEoJ+La2NkiShEAgAJ/Ph5WVFWi1Wmh5G4KeKCy16VMSBrMW0RAPLsija9SBSCCOWEQEywLmWj1MVh0kkSDojoHRMLCmzKqcBRSz0SvTY4QQhEKhI2lLalZFr13pCEWt6J7juBPv1gicUkLJJxooRMkzG5REkM3rPRfKWZQnhGBtbQ17e3s5DbrUQrbfgApg6nQ63Lx5M+sGoL16FcBhAZ7Rpn94CcdB23EJjAoPJMuycpoFOBw+ffmFFcQTcfCB6CHB6LRHyJLVMNiYCeBidy1qGkyoedVQMxbhcfeFDSy/4j1cKyHQG7XoeU0Tuh9uLLshVy5Uaj6k1EiIYRjZrIqmxwKBQNJMEjWqqlQNRe0I5ZxQTijUjFAoEcTjcUxMTMDhcKT1es/nOuWooQiCgOnpaeh0urwMupQoRzokGo0mpQKzgWEYMDYbzD/xEwh/97tg7bVH1kMkCUjwsPziL8r/pqbPh8FggFFnhsUqwWA6NGeLJ+IQRREHBwfQ6XTQ6/VgNQz4ePKBIBrm8c3/Z/ZQ14uBHJXEOB4T/7yF3ftB/ORbrlSVVI5TyqsQaLVaNDQ0yFbY0WhUbk8OBoOYmZmRDwblknFXu4aSqX53knBmCUXNonwoFMLKykpG98J8oNbDpiQUWsdpa2tDa2trUddRs2BPU269vb2oq8ttREWJwf7OZxFfXga/sgLWcqg0TAgB4TggwcP0+OMwPlI+ZzprvR57y4cRiVarlT11amw14HkesVgMsbAA1hbD9vY2HA4HDAYDXvq7NcRCPJgUwqAzKXv3Q1i648a1h9KrFJ+GtmGKcqeiTCYTTCYTrFYrNjc30draCp/PJ6fHaF2strZWtXtakqSiFMHT4TxCOcFQi1AIIfB6vQiFQrh161ZFUkm5QInA7XZjYWGhaDdKNdWCCSHY2NjAzs5OQSk3ugbWbEbd//1/IfpP/wTuH1+AFDgACIG2sxOWX/gFGB95uCx+9hStvXW4f9d7ZPNlGAZ6vR46nQ4aIqD34SYIAofZ2VlwQR5bC69GWWmKPwzDQBIJZv99D1dvO6vWTnxSI5Rs76PVapO83FPTY3q9Xo5eLJbiW7lFUVQt+ilFafg44VQSSj5tw6XoXQEPpt4lSUJLS8uxIBPg8LNzHIfV1dWC6zhKqJWCkyQJMzMzIITg5s2bBZ0OlakrjckEyxveAMtTTx1GJhoN2AqlCGz1BrT12bE+FYDJqk1qDiCEIBbi0dRVg5bLDjBMA9rb27Hq8mJdswpJIhCFw8MLwzJgGVZ+PcMCXJBHnBNgtBzVmztNG32liuXpRChT02OxWAw+nw+rq6uIRCJJ2mOFPC9qRvCRSOQ8Qjmp0Gg0iMViRb9eOfXOMAxCoZCKqysePM9jYmICkiTh5s2bJRdBSz3lS5KEO3fuoLm5Ge3t7epIurAsmBwS32pHKADQ/9MXodEyWHP5IUkEQhSI4tDzpKXHjoHXXjwSvTAsC5ZKshBAIoeOnASHmzjLsGAYZJyyP00pr+NEXEajERcvXsTFixfl7jGaHhNFMWm4MhthqEmS523DJxilpLzodPng4CAsFgs8Ho9q9ZhSEAqFMDk5ia6uLiwvL5f88JYaoQQCAXAch9HR0ZLqSsdFjoLVMLjxUxdx+aYTW/N+LC+s43J3Ey5cqYG59uiptv6iGUQiMnmAwWF08ur+QwiBJEhgdcD0vEserLTZbBVNf51FQlFC2T2Wmh67f/8+dDpdxvSY2l1eLS0tqlyrmjiVhFKOSXkqiU8ISZouVys1VAqo7wuVdlleXi75mqVs5ltbW1hfX4fZbC6aTEpZQzk3LpNNh0tD9Qiym7g80pDx72wOI+pbLPCsh8FkeMpYjQb9P3UB1/odsjpvKBSC1WqtmGrycd3oq/U++abH6urqVE15nddQTjAKJRTaLUVtNpUPoJodY0BhD7gkSVhYWEA0GsWtW7dU6zgBiiNKSZJkq+WxsTG8/PLLJa0hlVCIKEJYXYXwqiy6trUVuq6uQ02vFByHyObhpzvwzT+ZAx8TwWgeEN3hICYDe5MR13+sCVodm1Z3LBaL4e7duyXrW2XDWY9QciFTemx6elo2xGtqaiq5e+y8y+uYI9s069IjAAAgAElEQVTpthASoFLqmVwf1Z5pyffUQ90eHQ4Huru7VX9YC40OqAS+w+HA9evXVZPAp2sQNrcQ+v++BMkfABjm8L9EAltrh+2X3wytYqbluAgw2hqMeN1/u447X13H/koY7KtzKERi0DlSj+EnW494zVPdMavVCrfbjaGhoSO6Y0pTsVJRKeKtlGNjOSOh1PTYxMQEamtr5fSYVquVU5eFdo9Fo9FzQjmpyIdQUqfeM7k+qjXhTteVD6EEAgFMT0/Lbo/lQCERSjAYxOTkZFkk8AFA2NtD8M//HNDpoE1xkZRCIQT//P9FzXP/FVqFLcBxiFCAw9TXT7/tGriDBA72Y2BYwNFigc6Y32k2Vd+K4zj4fL6MumPFoFIRSqVSXuUQO00HQggaGhpkQdPU9BhNXdbX1+dUEj4vyp9g5CKUWCwmn/5zTb2XY+o+m2XxxsYGtra2yiI5r0S+EQqt3wwNDZXlhEUIQeRb3wYIOSJfDwCszQYxkUD0O9+B7Zln5LUfN5hr9WmL95mQKUVEdcdaW1vT6o7R6CXfE/JpS3lV0mo4tSifmh6jqcuZmRkIgiCTv91uP0J6523DJxjZCIVOc+c79a5mhJItKkiVwi/3KSxXhEIIkSO4bPWbUjYShmEghcOITU2BzfJbsHV1SMzOQgoGZdI5LhFKOZFOdyy1gExTMJkOKSe1tlHt98n1XqmWCaIoyuS/vLwsk39NTQ1qa2vPU17HHdlO2JkEFFdWVuB2uwua5q6EFD7Vv7p48WJeUvhqINv3x/M8XC4XampqsloGl6qpRQmFZQ7nTzJRBMOyh38bCoGtqTmWEUolYDAYcOHCBVy4cCFJnXdzcxMAUFdXB4fDAZvNJm+Epy1CqSShFBINaTQaOBwO+ZBKyf9b3/oWPvGJT8BgMOCFF17A008/jQspad18IIoibt68iZaWFrzwwgsFv14tnFpCyYbUG5vnedktsFABRTVnJdIRitfrxdzcXN76VxSlPsCZyC0cDsPlcmW0Mlai1O+GYRhAqwORDv3jkeHzEEJAJAJGkac+6RGK2uq8PM/D7/dje3sboVAIJpMJDocDgiCcE0qRKOXzUPJ/05vehKeffhqPPfYYAoEAfuVXfgUHBwf4yle+kmQ2lwuf+cxn0NPTg2AwWPSa1MCZJBQlcnm954KaD4myHpOPX0i2NamxIaVuyvv7+1haWkJ/fz9sGRwUc12j0DXAXgttczOEg4OMro0kEoHG6ZTTYmc1QskGnU6HxsZGNDY2ghACjuPg9XoRCAQQDofl1Fi6/L4aOI2EotahhYqNfvCDH8RHPvIRcBxXkJTT5uYmvva1r+HDH/4w/uAP/kCVNRWLU0so+dy8qVPv1QatxwiCgKmpKRgMhpx+IZmuU+qDpYxQCCFYXl6G3+/HzZs389Y7Umvo0/L4Y/D/xefBmkxgUmo1RBAgHRzA+vonk37zsx6hZAPDMLBYLLBYLAiFQmhvb0cikZDz+zqdTiYYNf1FThuhqA267kKbbX7t134Nv/u7v3ssJKBOLaFkgyiKsr1ouTzViwHLsuA4DgsLC0f81Qu9TqkbOY0uBEHA5OQkTCYTRkZGKpoOpK839PXB8vonEfn6NyDpdNC8GqmIoRAgCDA/8TPQ9/cX/T5nGdTrXZnfj8Vi8Hq9WF5eRjQaRU1NjVz8V3N4thw4iYRSyuHhhRdeQGNjI0ZHR/G9731P3YUVgeN9d5QBkUgELpcLGo0GfX19x4ZMgMPi+87ODoaHh1GTpkU2X6hBKCzLIhaL4c6dO0WTm1qEkkgksGi3Q//6J1Gztg7D1iYYloVhZBjGsTFoUzSQjpMGWLGo1PrTbWZGo1G23pUkCcFgED6fD+vr62BZNqm4f9zSi5UiFLUjyGKv9+KLL+KrX/0qvv71ryMWiyEYDOItb3kLvvjFL6q2tkJwpghFOfU+Nzen6kNbyg1GCMHS0hIODg7Q1dVVEpkA6hAKx3HY39/H8PBwUX4qgDqEwnEcVlZWcPnyZaClBb7mZmz6r8pTyQ67HZoK5ecrjeNQLGdZFna7HXa7HV1dXXJqLFV3LJ/hvUrgNNZqsuGTn/wkPvnJTwIAvve97+H3f//3q0YmwCkmFOVNRTWvOI6Tp95pu68aITzLskXfyIlEApOTk6ipqUFbW5sqN2kphEKbATweD9rb24smE6B0QgkGg0l1G0mSkmYuUtMyDocDdXV1pyJCqSQKuW/1ev0R3TGfz4eZmRmIogi73Q6Hw1EW3bF8UKmNXk2lYZ7nsw4znyScWkKhoFPvDQ0NSZpXas+PFHODUcmSK1euoKmpCRsbG6qsqdgNVRRFTE9PQ6PR4NKlSyVvysWugxCC+/fvIxgM4tKlS7BYLEcM0QwGgzyVLEkSDg4O4PV6sbq6ing8DoPBgObm5pIc+aqJkzAfohze6+jokKXfU3XHKqWcDFR2gFKtdDnHcarosj366KN49NFHS19QCTjVhEJnONJNvavtK59LMiUV29vbWF1dTZIsYVm2ZCdJep1CIxQ6PNnS0oK2tjZsb28jkUiUvI5CNxJRFDE5OQmj0Zh3xEbz+nROZ3JyEhqNBisrK+A4DrW1tXL0ctyLypWGmht9qvQ71R1bWloCx3GYn5+Hw+GA3W4v2+9wEiOU0yK7ApxiQqEKoJmm3isx4Z4OSon3VMkStdpsC70OlZtRDk8yDKNap1i+oKTW1taGlpYWbGxsJL1eCochbm5C2NgAESVoGhzQdXWBra8/YingdDrR2dkpRy8+nw9ra2tyR1OpfuLlxkmIUHJBqTv28ssvo7GxUY4iNRqNHL1YrVbV1nASJV5OixcKcIoJxeFwZJ3hKEeEkgvxeBwTExNwOp1pJd6rQSjr6+vY3t4+Qrxq1CEKISWqoJyJ1PitLUR/+EMwAFhbDRi9FsLOLviVVeivXYV+YADMq7+1cu2p0QutvaysrBypvZzF6KUSxEXfI/V3oJ1j4XC4aF/3dKhUUf7cT/4oTu0TxLJs1hNEpSMUv9+PmZmZrKKTlSQUSZIwMzOTUWxSzVmWXKAOjyMjI0dyyYQQiH4/Yt//AVh7LVj9g04ijd0OIklILCyAsVigv3o153ul1l6CwSC8Xq8cvRSq1lsunIYIJdt7ZNIdm5qakpsvqHjiceimSoWaKa/zCOUUoFIRCiEEGxsb2N7eTrthpl5HDULJtZHH43GMj4+jqakJHR0daTcUtSKUbNcghCR136VGCHRdiaX7YPQ6MGlOrgzLQuNoAD87C11nJxitNu+1K1tigbMZvVSLUJRI1R0TBAE+nw+7u7tYWFiAyWSSib4QSZJyQu0I5ZxQjjlyPSTl6PJKBfWhZxgmL8n5SkQoBwcHmJqayinPX+4IRRAETExMoKamBkNDQxlJTRIEJNZWwdbWZlYb1ukgJXhIgQA0JRiO5Ru9VGLe4rRHKNmg1WqP6I75fD7Mzc2B5/msviKVgpo1lNNi/wucYkLJBbUjlNTNl+M4uFwuuWsqH6jlrZKJDGhqKR9zrnJGKBzHYWJiApcuXcoq1c0wDCCKYCQCwrAgkgiGzbyBEEFUbe2ZohfqNcLzPNxu96mIXspNKKVsvkrdsba2tiO+IjqdTib6Sp7y1Ux5nRa3RuCME0qpbbHKaymJwOPxYH5+Hn19ffKGlA/KFaEoO8vSpZbKtZZ0Gztt5b5x40bOoUmGYUA0GkCvh5SIQ1IMkB7+98EDTUDAGMsXOSijF57nce/ePQSDQaytrYFlWVkLS63ay2kazFQzCkqnO0bJJRqNIh6PY39/H3V1dWUdFlR7DuU8QjnhKEdRnpp0eTyegiXnlddRaz3A4ST+xMQE6uvr03aWZYJap3zlNWgtKV8DM4ZhIBECzZXL4CcnoWtshCRJkCQCQiQAr35XsRjY2lqwrxJUuSflGYaBVqs9lIPB0ehFrbmX49rSXCjK2cqrtN0VRRF37txBOBzGxsYGAMjRi9q6Y5IkqRaZchwHp9OpyrWqjVNLKJWsodBoZ3x8HCaTqSjJeUBdQuF5HqFQCC6XC1evXkVjY2PF10I3dkmS5Pz3zZs38zrZ0VOt2+2GobERVpMZ0sEBNPY6aDQAIRIkQiBxHMRgEPrXvAaCIBQ1TFkqstVeyhG9nDRUqh5Eib6rqwvAoaSJUnfMYrHIM0il1sFEUVStlnYeoZwQZDupqtVRBRxGAWtra7h+/XpR9p1qr4lhGASDQWxvb2NwcBBWq7Woa6hRQ0kkEvjRj34Eh8OBnp6evDYWSkJ2ux09PT3wer1YqrNDOzsL69YWbDYbjGYLGFGAxmSC8dFHoW1qgiRJEAQBkUgEkiSB53loNJqKtp2mq70ofd5p51guKfhKbcKVQLUEG3U6HZqamtDU1ARCCCKRCLxeL2ZmZiAIAurq6uTifqH3iNpF+fMaygkHdUkrFXt7e9jY2EBjY2NJZAKoU5QnhGBvbw/hcBgPPfRQ0XlkNSIUnuexubmJnp6evCMkQghEUZT9upNsbG/fhmd5GZ7lZUTCYZgbm1B/9QoanE454pyenkZjYyPsdjskSYIoivJ3yr7qPV9JglHOWyijFyoFfxail+Mwvc4wDKxWK6xWKzo6OiCKIvx+PzweD5aWlmAwGGSiN5lMOX8LtedQziOUE45SN0w6QxEOh3Ht2jVV3NJKXRPP87LXS1NTU0lFyVIjFLfbjZ2dHbS3txdFJrTwroROp8OF7m5c6O4GIQTBYBAejwf37t0DIQSxWAydnZ1oa2uTX0trW4e1F0kmGUosxzV6OS/KF/c++f6eGo0mSXcsGo0eRsJLS4jFYqitrUV9fX3GOth5UT49ziyhlFJDSSQScLlcsNvtGBkZgd/vRyAQKHlNpTx04XAYLpcLXV1d0Gq18Hq9Ja2l2FoEIQRra2vY399HW1tb3oNooijKZJrPpsAwDGpra1FbWwu73Y75+Xm0t7fj4OAAW1tbqK2tRUNDg5xaog8/JZTjHr0QQmR5+JMevVQyQin2ezKZTGhtbUVra+sR/TeWZeXiPtUdO095pcepJpRcNZRiCIUOBioL3WrWY4oBlQsfGBiAzWaDz+dTpaBe6DWonAsA3Lx584i4Yzooo4d0UUkubGxsYHd3N8nrnhCCg4MDeDweWYjQ4XCgoaEBFotFjtyU0Qu9F45L9OLz+bCyslJw7eU44qSZXqXqv1FTMaXuGMdxqjX1cBxXVJ3zOOJk3ZkqohhCoYOBSsl5QL2BxEJBCMHy8jJ8Ph/GxsbkDVWNTqdC029U+LKxsVGWc8lFSqWQCU05JhIJjIyMJKUfGIY5klqi6tMcx8Fut8vRi0ajgUajgU6nk4mFpt6qGb3odDqYzWb09PRAkiSEQiF4PJ4TWXs5aYSSilRTsVAohJmZGSwtLQGAbIlcrO7YuZbXKUAhmy5te00kEmkHA9VsQc4XgiBgcnISJpMJo6OjSTdypaXnaXtyd3e3nJMGshNtrnpJNtDPXltbi2vXruV8rcFgSPJIDwQCstujTqeTc+lms1n+Hmn0okzF0eil0tEoy7Jyeg8ovnOsWjgORXm1QHXHDAYD+vr6wLIs/H7/Ed0xWtzPB5FI5DxCOQlQ41QUi8UwMTGBpqamjG2vas2P5AsqXdLe3o6WlpayrCdfwt3b28P9+/fTtidnIqVSyCQajcLlcqGjowPNzc15v46C5sOplXAsFoPH48HCwgJisRjq6urQ0NAg60Sl1l5oXQM4TIVoNJqyRC/ZTvWptReq1Eujl9R8f7Vx0iOUbO+l1WrhdDrhdDqTdMdo9EyHXLPpjsVisWMjelkqTjWhlApqPNXT0yNvQOlQyQglH+mSSkjP03Sb3+/H2NhY2o6ydNdQ1isKffgDgYBsBFaK170SRqMxqRhLW0kXFxdhMBjk6MVkMoFlWTl11tvbm1Q7q2bthUYvXV1dSCQS8lDlcYleTiuhpBJEOt0xak29vLwMrVab0dytWiKXauOcUNKAdirt7e3lJROidoSS7gFUdk/lknUpd8QkiiKmpqag1+sxMjKStfefEkqpxfednR1sbGxgaGhIFf/tdFDWJoDDSNDj8WB2dhaJRAI6nQ7xeBwjIyNJ90S62gshpKTopdhNWK/XJ/mMpM69VCN6OU0pLyXyUeNIjYaVqUpa5C+W6Dc2NvCrv/qr2N3dBcuyeNe73oXnn3++qGuphTNPKKkPLt0stVotxsbG8vY0V2sDp6de5YmFDuxpNJq8ZF3KSSixWAzj4+NZVZSjQhQJMYGYGJPbX0spvi8vLyMUCmFkZKSip2yz2Yz29na0tbVhYWEBwWAQdXV1uHfvHsxmMxoaGmSPjmy1FyoJU+noRdlanSl64XkegiCU9Xs9TVL8yvcqFErdMUII9Ho9vvSlL2FtbQ2vec1r8Pjjj+OJJ57A7du38/ocWq0Wn/70pzEyMoJQKITR0VE8/vjj6O3tLeYjqYJTTSi5fhS68dLNm9Ym2tra0Nraqtr7FILUNeWzgae7RjkG42jLdKYUoD/mx7R3GnvcHsAAwWAQRtEIS6MFDqOjYDKhRGo0GjE4OFiVegBdA9Voo1EXjV6mp6chCALq6+vR0NCA2tratLWXYuZe1P68qdELTceMj4+XNXqpVOSg5vR6ucEwDIaHhzE0NIQf/vCH+OpXv4pvf/vb+PKXv4zbt2/ndQ36WwKAzWZDT08Ptra2zgmlWqC1D41GA7fbjYWFhbxk1csJ2hml0+lk22Clz3o+KEcn0s7ODlZXVzN6qexGdvEf2/8Bo9aIBlMDGIaBLq7DlmcL31n/Dn6s5cfQZsuPEIHDTiaXy4ULFy4URO5qgio1p65BmSvv6OiQHQZ3dnYwNzcHi8Ui1170en1R0Uu5J+Vpt5LRaMTNmzfl6IWmYZRulaXKwBcywX4S3kdNUBKsr6/Hm970JrzpTW8q6jqrq6u4d+9e3mRULpx5QhEEARsbG0dmOaoFGqFsbGxga2srb6n3dNdQA4QQLC0tIRQKZfRS4UUeL+2+hBp9DYxao/w6s9mMWmMt/Nt+/N3O3+HJjifR0tSSU2YiFAphenoa165dy9oMUU5EIhFMTk7i6tWrWZ0tgaMOg+FwGB6PBy6XC5IkyUOVdE4hn+ilEl2DyhRROWsvp7EorxbUkF0Jh8N4+umn8Yd/+IeoqalRaWXF4VQTSq6bmGEYTE1Noba29sgsR7XAMAwWFhbAsmxetsGZrqHGCZcQgvHxcZjNZgwPD2f8Pne5XSSkBOq0dUk1E41GI+eMtw624Bbc4Ba5pPbcuro6SJCwHl5HhI+AC3Lgd3kMDwxXTd/I5/Nhfn4eN27cgM1mK+i1DMPAZrPBZrMdCloqJNSDwSBsNptMMDqdLmP0Eo/H5f9drqHKTBt9ptpLsdFLJYvylaixqUmQHMeV1GTC8zyefvppPPPMM3jjG9+oyppKwakmlGwIhULw+Xzo7OyU/RNKRak3Wjweh9/vx4ULF9Dd3V30tdS42aPRKDiOQ2dnJy5evJj1b/ej+zBqjElkklovsZvtYPQMhq4NyUqv+/v7+IbrG7iXuAdJK4FIBAk+gcb6RuAAeMT8CFimsiRPu8mGh4dVmQ1IlVCnE+/j4+MAIJOLzWaToxePx4PNzU309vYekYZRc2o/3/u11OjltEUoatv/FntwIoTgHe94B3p6evDe975XlfWUijNJKDs7O1hZWZEH2NQAjQqKfXBowbu2thbNzc1VHUijtRtqHJUPspFJKqjS633hPiZ9k6g31yPij0AQBZg1ZohREX+/8PcIJUJ4XcfrKtYhRLvJRkdHyzIXQOsWNTU1R7qu6MmfZVm5o42mX5VKyTSSoaRSCrkUc7+mi15Sda5o5KnUTDtNbcNqKw0XG6G8+OKL+MIXvoD+/n4MDQ0BAD7xiU/gySefVGVtxeBMEYokSVhYWADHcRgbG8Py8rKqro3Fnly2t7extraG4eFhrK+vV0UXjGJzcxObm5sYHR3FK6+8knbTkYgEBg9Iw2l0Ysm/BKvWmpFMOIHDVftV+X+H+TBeWH0BTqMTfq8fFosFthobiEQQjUUBDviHyX+AxW/BtQvX4HA4yuYRTkUttVptRbvJlCd/SZIwOzsLn88HrVYLl8slF/YtFoucyskkxw88GI7L9x5UI3JI1blKF73E4/GS3iNfnLUI5cd//MePnc3BqSYU5cOi9Fan9QCtVqta8bOYQioluFgsJhe8Ky3jQkEIwfz8vLwWOpRHNx1BEvDi9ov4yspXsB5cB8Mw6Hf046mup3DVdhU6RoeElJCL8kokxAQAoMXyQCZm0jOJBJ+AN+CF3W6XO8cYzYMOKnDAnmEPLZEWeYNSbrJqbPzUQ8bpdKK9vb3k6xUDSiYajQaPPPIIGIaRfeqXl5dln/pMcvypxEI3vFzRi9qpqEzRy+7urpzipJPi5TgcnMTU2mnyQgFOOaFQ0HTStWvX4HQ65f9fTZXgQuVXlASnrJdUg1DoplpbW5t0QqeEkhAT+NTdT8HldcHAGlBnOCykT3un4fK48POXfh6PtT2GF3dfREJKwKazya8N82FEhAgeaX4kiWwW3YuIBCPobOrM2Fln0Vnglby4fPkyLl++fEQ1WFnYLyYFEY1GMTExga6urrxNwNQGFbqsq6uTVZqBoz71VI5/ZWUFWq02SdAyV/SSSRKm3BswjV6CwSCcTidYloXX68Xm5iYAyKoEas29qJmKqtT7RCKRU6M0DJwBQtnc3JSLrKk/nJoaXIUQQSgUwuTkJK5cuXJkI6u0t0okEpE31VSxRTog+aWFL8HldaFOX3dIFCBgCQub3gaJSPjH1X/Etbpr+OnWn8asbxY73A4YHP5dk6kJt5tvw2F80Hq7tbUFv8cPe509a5u2RCRomQe3aDrVYLfbLVu4KnW3cuHg4AAzMzPo6+urWqsllfxva2vLah+d6s9BBS2XlpYQjUZlOX5KrKnRC21JTi3sV9pJUamYnK72Umr0UorBVqHvcx6hpMepJpREIoFgMIhbt26lPVFoNBrwPK/Ke+VLTru7u1heXsbAwEBayepKyqNTocn+/v60myrDMIgkIvjn9X9Gja5GJpPD/xAwYKBhNNCxOvz9/b/Hpx75FB658AhiQgxxKQ49q4dJa4IgCdjldgECBDYDSMQTeHzwcXxx4YtZ1xfmw3ht62vT/luqarBSd4vn+aTJ9dSHf29vD6urq2XVBcsFOudSzKxNqqBlIBBI8kZPFbSkqd3UjjGe5+X/r5y1h3TXT+cxQrvbgOKil0rWUNSKUE6TFwpwygnFYDBklSHQaDSIxWKqvFeuyIIOCAaDwYzqvPQ6akRNlJgyPWDr6+vY2dnJKjTJsiwW/AuHkQKrPUImFBatBSvBFYQSIdj0Nhi1RhhhREyI4XNTn8OXl74MXuIhSiKMGiOe6X4G/6nmP6HOUIdAPAC74WinXYSPwKAx4IbjRl6fl+putbe3H5lct1qtcv1hZ2cHPp8PIyMjZSvy5wJVTe7v7y/ZByOVWKPRKDweD+bm5hCPx4+kBamZWCwWw9LSElpbW8tuJpYrElJ2vwHFRy8nsZssEomo1ml6HHCqCSUX1E55ZbqWIAhwuVywWq0YGRnJ+nCxLKtK1JRJz4sWgEVRzCl+yTAMEmJCTl/R6ynJhP4dy7DgpQfr5gQOz373WWyENpCQEvL/zws8Pj/3eby4+yI+PvZx/NXcX2E3sot6Yz30Gj0ESYAv5gPDMHhrz1th0RWeDkidXA+FQrK0DgC0tbUhFotBq9VWvD2bRkdqzbmkwmQyoa2tTZZP9/v9cLvdWFxchNFoRENDA6xWK+bm5mQVgGxmYmoIWhaaWksXvShrL3TuxWazJV33JHZ5RaPRtJ5GJxWnnlCyTY2rSSiZIpRwOAyXy5W2RpEOahXlaYSiDM1pI0BDQwMuXbqUl3im0+iEQITDhzXDkCEv8dBr9KjRP0ib/dHEHx0hE4q4GMdCYAFfW/sa/vvgf8fLuy/jB7s/gC/mg5bV4lbTLTzU/BCcJueR1xYKhmFgNpsRDAbR3t6Oixcvwuv1YmVlJal7yuFwlL2gu76+DrfbXbHoiM77NDQ0yIKWW1tbWFhYgNFohM/nk2sbmczE1JDjL2WjV0YvnZ2dcvSysbFxJHo5qXMo5zWUU4JyRyj0ZNjf35+3hIdahJJ6HUpsV69eTep0ywaGYdBkaEKnrRProXXY9Ok/Q5gP46nOp6BlD28nTuDw9bWvpyUTirgYx5eXvoxne5/F4+2P47G2x8BLPLSsVtXp+FgsBpfLhfb2dpnQ03VPLS8vQ6/XJ3VPqQVCCBYXFxGPxzE8PFwViR+GYeTN+Pbt2zAYDLJ1rVLQ0uFwwGAw5GWFnG/0ombxP1v0Eg6HsbGxISsPlCv6PC/KZ8Y5oZShbZhOXft8Pty8ebMgwclyEMr+/j6WlpYyNgKkAyEEWq0WKysreOOFN+Iz4c8gzIdh0T6Y/yCEIMgHUW+sx891/pz82nnfPBiS+2GWiIS10Bou114GwzDQa9QV5gyFQrLcfro8tbJ76urVq3L9YX5+HvF4XC7s2+32ojcQSZIwNTUFk8mEGzduVE0BYX9/X0610ZqZ0ro2EonA4/FgcnISkiQdaWrIFL0IggAAWaOXcqkAp0YvL730EkwmU9roRc2IkKqBqwGO486L8icJlUp50Q1cEARMTU3BYDAUJTip1ppoxLSysgKPx1MQsdHN4sqVK/IJ/heNv4ivhb4Gb8ILVsMeRhEM0FvXi/cMvAe1+sN2UEmScH/lfl7vw4CBSMqjCuB2u2Wv+3wf2NT6g8/nw97eHubn52E2m+F0OuUTfD6g8z2NjY15e9mUA5ubm9jb28Pw8HBGq2ar1Qqr1YpLly7JgpZbW1uYnZ2VmxocDkdOOf500Uul2nlZlk3SHMu39lIozlNemXHqCSUb1I5QwuEw7ty5g/b29qILbWqZY1HV4kKJjT1mce4AACAASURBVBAinzqpB7bD4UB3dzeeCD+Bu+t3seBeAAjQ39iP3pZe1BgedOe4XC5cd16HuJn7exWIgFar+l4nGxsb2NvbS9LDKhQajebICd7tdssneKUkfbrNKRqNwuVyobOzs2pDkzRSDofDGBoaynsTTBW0pHL8ExMTANILWgLp5fhpW3KlJUJSoxee52VyCYVCJUUvahflzwnllEBNQolEItja2sLIyEhJBl1qTO9T2Y6WlhZ0d3fn9Zp8bHqtVise7X0Uj+JR+QHd2NhAKBSSC9/d3d1obGzEQzsP4T+2/wMS0qfvtIwWP9P2MzBry1OryOZ1XyiUJ3jl5kQ/e01NjXyC12q1OVNtlQAhBHNzcwCAgYGBkpSrU+X4qVaX8rPTjTk1egkEAnLXYiKRqIoVMnBIksV0jqWD2pPy54RySqBGvYIQgrW1Nezt7aGpqalkt8eMayIEjO8+mK07QCwI1FyA1P4IYG5I+rNgMIjJyUnU1taiqakp789QqOe78gF1u92Yn59HfX09VlZWsLm5if/c9J8x4Z5ASAhBIsmfR8NoYDfY8Z6B9+S1vnwgiiKmpqZgsVjKXqtI3ZxoWnB1dfVQqiaRQG9vb9WcP+l3QUlAze8i9bMHg0F4PB6sra2BZVk5erFarQgEAlhcXMTIyAgMBkPRVshqI5/ohRJMuuhFzaL8eYRywpBroKoUUL9xlmXR3d0Nj8dT0vWADIQSC0Lz4qfB7s+CMABYLRiRBzv+RUjXfx7S4DMAw8pT+ENDQ1hfX8+LLIshEyXW19exv7+PW7duyeklWtx+34X34Qt7X8ByYhk6VgeGYcBLPG433cYHb34QdYb8bY2zgdoFX7x4seI9/QzDwG63ywKXGxsb6OjowObmJhYXF1FXVwen04m6urqKbJq0btPU1FR262SlGOTly5eRSCRkvbGDgwNIkoQrV67IkUsuK+Ri25JLRaboxeVyATgavaitNnxelD8HYrGY7Dfe3t6OQCCgSnfWkXkWMQHtv/42EFgFsV0AaIcVAEgi2Jl/AAGDRetDODg4kKfw84m+6ENN2zoLIROqlCwIwpH0krK4/VPCT2F+ex6vbL2CaDSKvvo+XLlwBTUadfSzwuEwpqam8rLqLRcIIVhdXUUgEMDNmzeh0WjQ0dEBSZLkwcKFhQWYTCa5LbkcQ41UG+zSpUtVqdvo9XrZPycej6OzsxOBQAA/+tGPjghaZqq9lMtMLF+ki16o42YoFILVakU0GlVNHqlSLpOVwun5JBUENaDq7e2VBfvU7M5S3qzM9iuAbxmwXZTJ5MEfa0CszeDufAnk9jWMjIzlrVqsLL4X+sDyPC8r5OZyltRqtehr70Nfe9+RFIly8K6YsN/n82FhYQE3btwoWcKkWEiShPn5eRBCMDg4mPRd0hSQw+GQBws9Hg+mp6chCIKcHqqtrS05WqbaYN3d3fI9WQ2sra3J0jb0971y5QpisRi8Xi+WlpZkpWhaFNdoNEnRi/K/QP5y/OVAOsfNmZkZ2aa71M6xahrplQOnnlDU/sE2Njbk4rtSWFDN+RElMbEL3wR05qNkgsMHzevzo1anQbfJD0nxN5m6xUpNcXEch8nJSVy6dCnvGg1FaoqEquYuLi7KPvNOpzOvuY/t7W1sbW0lzVVUGqIoyvWqXMoDDPPA56WjowOCIMDr9cqtudTpsBgjsYODA8zOzqKvry/vAVq1QQiRbQVSiRU4FLRMVYqmA6U6ne5I9AIgiVBymYlVojWZRi8GgwF9fX1gGOZI9EIPEPn8hsfNHEsNnHpCyQf5FNkkScLc3BwEQZANqJQoW4QS2QN0RxVxE4kE/P5DCXhDQoIUdif9ezrV4lLJxO/3Y25uTjXJd6VqLtWdonMfFotFnvtQtv7SjSsSicin4GqAyti0tLTkbZOshFarTTr50sitUCMxr9eLxcVFDA4OVk05mZqzEULQ39+fl6RPOkFLOlCqFLRMrb0oiUVphVypWRe6DipVkxq9ZKu9ZMJpilLOPKHQmkU2QqG5aafTmfEkqqYGlxJEbwPDeQCFORXHcQiHw3A0OKDVaIGYCBiSUz6p6ymVTLa3t7G5uVk2UcNU3anU2Qd6el9dXYXBYCipFbZUcBwny9ioUbdJjdxo2zc98VO/E5oeotjZ2cHm5mZJ8zalQpIkTE9Pw2Qy4fLly0X9JqkDpTR6UQpaOhwOWY6fvq/ynuY47rDpg+eTUmjlQLr9Ip/aC03x0d+qGs6s5cY5obwaWWQqjFG3x+7ubjQ0NKT9G+V11Aa5/BiYu38GGGpAQBA8CEIQBDQ4Gw6n1QkBGEBqHUt6nZJQSim+KyOC0dHRikQEqbMPiUQCu7u7eOWVV8CyLBobG+H1elFfX1/xnDo15rpx40bZ0kupbo3USOz+/fuy30k8HkcoFKpqlCaKIlwuF+rr69HR0aHKNTUajZw2Ag5rQ16vN8nnxuFwwG63y1FCJBLB/Pw8rl+/LndhVVOOH8g8HDo5OQngsNZktVpLOpx985vfxPPPPw9RFPHss8/iAx/4QNHXUgunnlBy/fDZiGB7extra2tp3R5TUS7rXqn9EbBT/xsS54U/SqDT6VHvqD+UkCcETGgbUustoCa5XZbWYkopvtN5BrPZXNWIQBAEbG9vo6+vDw6HA36/XzaUUnZOlbuWsr+/j5WVlYoac6WmhyKRCObm5hAOh2EwGLC8vJzRSKyc4HkeExMTMvGVC7Tu1N7enlYOx2q1Ynd3F4ODg3JjRjozMTXl+AtFuuHQzc1N/Nmf/Rnm5+fxlre8BT/7sz+LJ554IuuhVQlRFPGe97wH3/rWt9Da2oqxsTE89dRTWf2fKoFTTyi5kI5QaEtsNBrF2NhYXm19ZdtsDVaEH3ofYl/7IGxaEQZ9PZCIAgIHCHFITTcgPnR0QJCe1ARBKCrFRVV6W1tby7ph5AI1o1LWbVI7p1IlUZxOp+pqsxsbG9jf36+qMZckSVhZWYHNZsPIyIi8wVIjsUx1J7VRrfbkVDmcvb09WYp/ZmYmraClTqdLKwkDVKctGTiMXt7whjdgcHAQH/rQh/De974X3/jGN/A7v/M7+L3f+728rvHyyy/jypUr6OrqAgC8+c1vxle+8pVzQqk2UgmF6lHl0xJbCfh8Pswue3DjF/4Y2uAsyPJ3wMQjIA1XIV19AqTpBpAi904IgU6nw8rKChiGgdPpLOhEHQwGMT09jevXr1e1BXV3dxfr6+sZ6zbKzikqauj1erG2toZwOIza2lo4nc4jtYdCQJ02o9Fo1aTngQfppbq6Oly6dAnAUSOxcDgMt9udpLnldDoLstHNhWg0iomJiaKsi9WE3+/H6uoqxsbGYDKZZJfO7e3tvAQtj0P0wnGcbLo3MjJS0Gu3traSBEdbW1vx0ksvqb3EgnHqCaWQlFcoFMLk5CSuXLlSNUE/JWiL8ujoKIxGI0hDM8Sun8r6Gvqw1NXVYWhoKMlnnW4wmQQNgQdpnUJUetUGHRT0+/0YGRnJe/BLOfGs9DpR1h6o13o+kCQJMzMz0Ov1eXUvlQu0o6y1tRUXLlxI+zfKtEpXVxcSiURaI7H6+vqiB+nC4TAmJyerKisDQP5NlS3j6cjV4/HA5XKBECJHLzU1NWmjF7XMxApBNBotOnWaruW42odf4AwQSi5QQqGyJYV4hpQLhBDMzMyA5/m0LcrZXqcsviu7Z+jcg1LQkKZHNBqNrElWbb912p4NAENDQ0U/0KleJ3SoUEmu2YYKqYSJ0+lEe3t7SZ+pFFDV4suXL+edXwcOp9aplLuSXFdWVo7MfeQD2ozQ399f1edjb29PrmtmSutlErSk937qzE8hcvxqtieXIgzZ2tqKjY0N+X9vbm5WNTVNceYJhWVZbG1tQZIkWbakmuB5HtFoFE1NTejp6cn75s1VfE+dezg4OIDb7ZadCgVBgNlsLmkTLxV0Ap92Dal54jKbzWhvb0d7e3vaoUJKrlqtVpbVKWZ4U02oFREoyRVIP/eRbaCUzrpUshkhHba3t7G9vV1Q1ApkFrSkGzIlV6vVmtNMTBAEmVhKfU5KIZSxsTEsLi5iZWUFLS0t+Ju/+Rt86UtfKmk9auBME4ogCNjZ2YHRaMTo6GjJGxgdJiz2RqM2vSaTCe3t7enXI8QBngMYDWCwgeDBwFe+xXeloGFHRwfGx8eh1+sRj8dx9+7dshW2s4GexCuxiacbKnS73VhbW5PX0t3dXVUy8fv9mJ+fx8DAgOpqtLmMxJRdc+mcHquBjY0NuN1uDA8Pl9QmnU7Q0uv1YnV1Va67KVODqUOV6+vrsFqtcnqslNpLKUrDWq0Wn/3sZ/HEE09AFEW8/e1vR19fX1HXUhOnnlAybYiRSAQTExOoq6tTrWhZysmFnhgHBgawsLBwtAU5Hgaz5wLjXTqcPSESiLEWUmM/pNoOMK92rBQCqv90+fJl2Wc+tbBtt9tltdxyzTvQJoBq+IcoNxifz4e5uTm0trZiZ2cHq6urqK+vh9PprGhbrrI9uRxDpEqkMxKj8xKxWAyEEPT29lZtcBKALLxZjuhZmRpMtSKgMzE0Nbi8vAxRFNHT05OUXi629lKq0vCTTz6JJ598sujXlwOnnlDSwe12Y3FxETdu3EAkEkE0GlXlurmGJNOB1i729/cxNjYmd6QkEUo8BGbhG2CExKH/CXtY8yCJCNjlfwEuDIJcHC1orTSNkar/lFrYpkN1ypkPp9Op2gazv7+P5eXlqjYBAIdT5xsbGxgdHZVP4vT0vru7i7m5OblzqKGhoWyp0c3NTezu7laljqU0EmMYBh6PBxcuXMDOzg4WFhaOGImVG9RxkuM4DAwMlJ3QlZE7cNgeTRsA/H4/9Ho9rly5Ikuv5JLjz2Umdtqk64EzQijUV54QgpWVFXi9XtljPRaLqWoDXMhwI+0iAoCbN2/KN94RPa+1F8FIImA9jCJkW1WtEUzNRbB7k5BqWkFszXm97+bmJnZ2dnKmMZRDdcqZD9o5Q8kll95UJqyvr8PtdmN0dLRqtStK6Ok6ylJP77Qt9969ewXpbeW7jpWVFYRCoZLTOqWu4/79+0lt0hcvXkw6vVOlaJoaNZvNqqdGCSFYWFiAKIplN0zLBKpYEAwG0dzcLCs0ZGpsyGaFDByde+E47lh0k6qJM0EowOGJYWpq6ojHupqSKYXY9yYSCYyPj6OxsfFIATqJmKJ+MKEdwHbYLkoIgSi9eoMyLMAA0JnBeGYzEwrnBRMLgLA6zO+GkeDFgiU7Umc+qJnS8vIyIpFIQUZSVExQEISqznbQdYiimFYhV4nUttxUva1SjLToOiRJqqoiAbUNZhjmyCaeenpXKkVHo1FVjcQIIZidnYVGoymoMUVt0HXodDpcuXIFDMPIszf08y8sLMhK2Q0NDbIkTD7RC8dxVW1yKAfOBKFwHIfx8XG0t7cfcfQrNKrIhnzJKRQKweVy4dq1a3LtQokkYooFAIYBAUAkCRKRwCCl+G6sBRPcOnIdJrgJzczfg92fgUSAg4AfHeY6mEbfDMKW9pBSMyWqN6U0kqIT2+lSQ1Ty3WazVXVwlMrKWK3WotaRqrel/Pxms1n+/LlSg5IkydbFXV1dVfs+Cl2HUimafv5UQcdijMRo1G40GosWm1QDhBBMT09nXEe2z59u5ik1ehEEAS+88ELZXTUrjTNBKIuLixkLvhqNRm63LRX56Hnt7e3h/v37SdpDOa9DXk1zpSOTDGD8q9C++PsAw4I3OeF2e1DT0AmLngHj+iLE8A7E/jen9VkpFKlGUnSobHx8HAzDyKkxrVYrD+hVs2eeDgqqZRmc+vlpYdvlckGSJPnzpzZ/CIKAiYkJNDY2Jk09Vxp0Ct/hcBQ1c6P8/ADkz1+okZgkSUn+MtUCVVCm5JoLqZ9fOfOUSCTkoUrali1JEp5//nk89dRTeO6558r9cSoKJofJy6lwgOF5PuNGz3EcFhYWMDQ0VPL7zM/Pyw9PKmiB0efzYWhoKGvNYGFhQU4hEM4Hdvr/QLQ2gWEydHJF/SDWRkidr07REwm6734cSHCIM0Z4fT44HI4H9RJJBBPaAv9jvw7S0F3y584GWtjc2dnBwcEBnE4nWltb8zLRKgeo9PyVK1cKGhQsFjzPw+PxwOPxyF1ztO4yNTWFjo6OqrYn8zyP8fHxon1dcoHO/Hg8HgSDwYxGYqIoyhYR1SRXGqnRochSQX1+PB4P/vqv/xp37949dDHt68NnPvOZYzHdXiTSLvxMRCjZUEjdI59rpSMuml7R6XRJ9Ztc1yGEQNTXQLI2gY0FwJjTeG8QCeA5kIYe+f9ivItgwvsIa+sQPPChsbExuSuH1YBoTWCX/wVimQnFYDDAaDTKxmTxeBy7u7uYn5+H1WqVBworUZSn095qGYTlA51Od2RifWdnBy6XCzabDTzPIxaLlb09OB3i8TjGx8fR2dlZtuJwLiMxh8OBuro6LC0tlV25OBckSZL10tSU46fpr49+9KN497vfLd+Ht2/fxhve8AZ8+MMfVuW9jgPOPKFotVpVu7xSrxWLxeQTYL4nL3odmopjOn4czOI3gfA+YHYA7KvFdJ4Doj5IzYMg1genXCa4jXA4hLBWh6bm5vQEZrRD452H+g4uyaAdZUoTKNo1FQqF4Ha7sb6+LndUFSIHUgion0g1p73pFPbBwQFu3boFjUZzJDWUS2tNLVRD5DGdkdje3h7Gx8fl70Wn05Uk5lksSk375YIgCHjuuefQ3d2N3/qt3wLDMAiFQpiamlL9vaqJM0Eo2R7OckYo1Jzr+vXrBTn70RkAm812uLkabBCvPQl2bxKMd+Hwbwg5HGy89ChIXadcCxFFEWurq2gmBI2NjVk+OwFB+VJOVKWX47i0HWVKhzulv/z8/Lycd6YDhaVursrZjmoO6KWTMEmVg1FqrZVr5oNKulQyUsuEnZ0d2eeGOjUWK+ZZLGi6rbGxsSxFckEQ8K53vQvd3d34zd/8Tfl+ttlsePjhh1V/v2riTNRQBEHIShrf//738cgjj5T8PhsbGyCEoL29XZ60LmRgj86XJBIJ7O3twe12H1UJFhOAED2UXtFbk4rq8XgcLpcL7VYBbQufB6lpzVh0Z8J7EC+OQhx5W8mfOxWiKMq2sLTdstDXe71euN1uBINBWciyUKVcWrcKh8O4ceNG1WY7gEMp/o2NDQwODuYkNeXMh9frlWceCrUhSAfqL1MOSZdCQCP3TBESLWx7PB4kEomkwr6atTdRFDE+Po7m5mZVGjRSIQgC3vnOd6Knpwcf//jHT3LNJBVpP8g5oUA9Qtne3kY8HocgCAgGgxgcHMx7A8zk+U5Prm63G6FQCLW1tWhsbERdXR20nhlo7/wvaPZcEBkN1i3DMP34c7BfvAzdv/42EHEDljSFZ0kAE9oB/xMfPIxuVATtoLpw4YIqpz2l1hbdXOmwYba6gyRJ8ixDtX1t1tfX4fF4MDAwUFS0EYvF4Ha74fF4EI/Hi95caYQ0ODhY1fkH2hhx/fr1vKR26AHD4/Hg4OAAFotFjl5KiTgFQZDT0ZlsAUoBz/N45zvfib6+PnzsYx87TWQCnGVCUdYj0iEfQtkPxfE3dzbx9ak9xAUJVxoteNvD7Xi4q16+Uba2trC8vIzGxkZcu3atIKXgfDzfZSmU/T00vvQJNLv/HSzhwZBXveM1BoBhkXjqTyE19UP74u+D4TkQSyPAag81wOIHYGIHEHrfCOmaujpAVBusnB1U0WhU3lx5npc3FmXdQRCEpHx4NWcZlpaWEIvF0NfXp8rJmsrBuN1uHBwc5N3YQGXfh4aGqpr2KzXdpmxL93g8ACATbCFiprS7ra2tDc3N+SlMFAKe5/Hss8+iv78fH/3oR08bmQDnhFI8ofzrggfP/28XRAIkhAc1EpNOg5sddvzxLw9C5A+Vei0WS0Hua8V4vmv//Xehu/OnYIT0GmREa0Lsma+C2JqhWfwnaNa/D0ACCIFU2w7x2utBmgdUmUGh8Pv9mJubw40bN5K0wcqJdNGb3W7HxsYGOjo6yrJR5AsaIWm12oIOF4VA2djg9XplOZhUOZStrS3Zd70SGlyZQEVA1fRUoWrBtC07HyMxSibt7e1ladmmZDIwMICPfOQjp5FMgHNCyU4oDz/8cNof/r47gjd+7iXE+PRzLEYti8e76/CLLRxaW1sRjUZx/fr1vNdViOw8AIDnYPpsPxiey/gnEhgEL74G3M997rCoLcSAeAjQ6ACjXVUiAR4IKw4MDFSl/RU43MB3d3exsLAAnU4np0WcTmfFZdfT2fVWAnTmx+PxyHIooigiHo9jYGCgqjWkQCCAubk5DAwMlE0QUWkk5vP50uptUcmjS5culaVVmud5vOMd78Dw8DA+9KEPnVYyAc7nUDKDdmele+A+9+8r4MXMvBoTJHxz1ov3vvYWzBoJ4XA45/tlqpfkA83Kv4CATf9rvgoWBLW738fSxhpmZzmFt3oNNCre4FTQ8ODgoGDTI7VxcHCAtbU13Lx5E1arNUmGPdu0utqgNaRyDQpmg8FgQEtLC1paWuTGiFAoBJZlMTU1lbccjNrw+Xzy8HA5Dxy5jMRqamrg9/vLZvHN8zze/va3Y3R0FB/84AdPM5lkxJkglHx95dMRyjen9yFK2QM1rYbFi6shPHHVllN6pRQyAYDEwR40Ip9Hwy+D3qsdIIZaWYL+/v37MBqNclG7lI1FWfTOJaxYbihtYemGRYUsOzo65Gl16q9Ohfzq6+tVXTd1eizUrldtULFJvV4vp3IjkQjcbjcmJiYAJLsUlnPjc7vdWFlZqUrLttJIjOM4vPLKK7BarVheXsbu7m6SkVipSCQSePvb346xsTF84AMfOJNkApwRQsmFTKKOkkQQF3ILR/IiQTAm5BSHzLf4ngk+nw/evTD6NTpAimf/Y4YB9IebhfLUlrqxUHIppIWU+q03NDRUtegNAGtra/B6vVkjpNRpdUqwi4uLBQk5ZgMtNlfDJEyJTCKP1Oeks7NTrjtQgi2XiRptlR4eHq6qtXYsFoPL5UJvb69sxZAawdLCfjFDpZRMbt26hfe///1nlkyAc0IBkJlQWJaBzahFKJZdPNKgZdFUY8gqDllM8V2Jra0tbG9vY+Cn3wbm/mez/i1hNBCuP3XY2ZWCVAl6urHGYjF53iXbMCG16i2nXEc+oH4ZPM8X5OSX6vGS7uReqMeLsj5QzdkOOqBHiT4TlC6FlGA9Hg+WlpZKUgpWgjYCDA8PVzUVSudduru75UOV0kjs0qVLsktp6lBpfX19TiJMJBJ429vehoceegi/8Ru/cabJBDgjRXlCCBKJRMZ/n5qaQltbG2pra4/82+/+0yL+6qX1rHUUk47FD37jJ6HB4QM9NjaW9O9FFd8Va19aWkI0GkVfXx80Gg20d/8XdP/+KTB8hi4vnRmx//LPIPWX834f2o66v7+fNEzocDjkUyvVIOrt7U37XVUKtD5gNptVlTinHi9utzvJ4yObkKXb7ZYdJ6vVkAA86FxqbW0taaaCntw9Hg9EUSzq5L6+vg6v11v1RgAqL5PvvAuQPPfk8/myGoklEgm89a1vxSOPPIL3ve99Z41Mzm6XVy5CmZ2dRVNTU9qJ3f1QHK//7A8QiglpvwyTjsV/+8lOvOs1nRAEAT/60Y9w+/Zt+X1LqZdQ7xCr1Zq8cRIC7Yu/B91LfwyAHE7PAyA6C8CyiD/9RUittwp6LyXopDZtR6UCj9TXu5pDcTzPY2JiAs3NzWX1kpAkSZ73CAQCaT1etra2sLOzg8HBwaqmdKjIY1dXV1p/nWLB87z8HdCTey7FgpWVFQSDQfT391e1rkaHJ3t6eko6/MRiMbktmeM4/P/tnXtcVHXexz8DDDe5iTJioCipGHJRSUNFK1h0RRgqATXzsuZjtV1s29q19Wmzem3aZUurZ19teXnMrNyC0SJzNV1atezRXUGQQFGQOzMDA8MwzAwz5zx/uL/TOA4yw5wzZ5Tf+z/dnPOb2ZnzOb/f9/v9fEJCQlBdXY309HQ89thjSEtLw7PPPjvUxASggtK/oFRXV3PeUbYwDIPDp85h03cdMDES9JiuHo35+ngBLPDwnLFYn347FzP8ww8/YPbs2S6LCTn3HTNmTL9PnBJtE3xKP4JXSylYH19Y4nJgicsBpPzd8MkOqa2tDb6+vtfkm/ARfesM5LiN7xvnQFjH/6rVai4nnGEYUeN6gZ9vnNZHOkJg/ZBBWnKJwAYEBHDRwQaDAfHx8aKKSU9PD86dO8e7VxnDMKivr8crr7yC48ePIzQ0FE899RQWLVrEy8PNmjVrUFxcDJlMxplGPvfcc/jqq6/g6+uL22+/Hbt27RK1RmcFFZT+uHTpEoYNG3bdIBxpAR05ciTGjI3Bdxfb8ffzbdD3WXBHZDDyU6IgC762Q4TMtDhbfGdYFmYLC28vCXTdWlRWVnpEgZdE095xxx3w8vK67ljI2sRRyJsIGYoT+7iNZVlUVlZCr9fDx8cHRqOR+wzCwsLcKrDErVYMk0fSkkv85oCrtRmxO/5Ic4RQA7ZGoxErV67EPffcg+zsbBw8eBAHDx7Epk2bMGfOHJde+5///CeCgoKwcuVKTlAOHz6M9PR0+Pj44Pe//z0A4LXXXnP5ffDA0BUU4OoXoT9qa2u5SFeCTqfjgpicKT5///33XA3FkR+WzmhGjUqHi0o9GIaFrlsLX6MGC1ITIQtzz8S5PcxmM8rLyxEWFoZx48bZvVHa2oAEBwdzdRc+C7HEg0rIoThHIB1U1rUbd30GtpBGgMTERFEbAViWRUVFBSwWC6RS6Q1DtISGCCyfk/jWGI1GrFixAunp6fjNb34jyMNDXV0dsrOz7draKxQKfPHFF9i7dy/v1x0EdLCxP2xjgEk2eFJSklNPORaLBT4+Pjh37hxkMtmAragdPSb844IaDMMiLFCKdpUKVPu7ygAAIABJREFUZn03gmRjUHJJi/Q4P4wMcr/vkiPHbQC4DBOSb0KKmXV1dfD19eWORFwpVjc3N6OpqUl06/n+4npv9Bnw6RJsTXt7O2pqagQfFBwIey3K9nJuSNeYkMJHdrBCddoRMcnIyMDTTz8tSs1k586dWLJkiduv6wxDZodiMpnQ33ttampCX18fYmJiUFdXB7Va7ZDNOMG2XqLX66FUKqFWqyGRSLgbjvXTtZlhUFyuhLcEGObrhfqGBnh7eyPqttsgkXhBb7LAaGGQnTgKvt7uO0IgT3mTJ0926Uxer9dzNQeLxeL0pDqZwicFXjHrFEajEWVlZU7H9doeC/ERoOUpJo+kYYTsYPuD5Nyo1WoYDAaHOuechXQfOhMV4QwGgwErVqzA/Pnz8dRTTwkqJv3tUP70pz/hzJkzKCoq8pQGgKF95HUjQWltbUV3dzd6e3vh7e3N1QtsMfRZUNHcjdauXvhJvTF5VBCiwvy5gUUvr+sz341GI1QqFZRKJeeOGxERAa3FB8cvaTAywBt1dXVc1rg1bVoDZsWGI2aEe455yCwC38coZFJdpVKhp6fnmpqDvc+ZYRhUVVVBIpFg8uTJov6ASNHb1WRD22x1e23ZA9HY2Ii2tjbRTR4Hm/9una+u0Wh4saEnR39CWfIbDAY89NBD+OUvf4knn3xS8O+iPUHZvXs33n//fRw9elTUI18bqKD0916bm5tx4cIFjB8/vt/J71OXO/Dp6UYYzQy8JADDXv1wJkYEYnVqNMICfQf8spGbilKpxJn6LuhYX3iZDYiKikJoyPWFZq2hDyODfDHndsfTHgcLSTVMSkoS9MnXth03KCgIMpmMqzkQY8Ub1W7cBTlG4bvAa68te6DjQeKZJvZujbRtu5r/bs+G3tnuQY1Gg+rqasGO/gwGA5YvX46srCw88cQTbvku2grKoUOH8Mwzz+C7775za2ejAwxtQenr67M7xa7ValFaWoqgoKB+bef/r06D7SfqMDLIF/7Sqz9mlgUYxgKVzoSIID88N38CAqSO/9C/+fdllF9qQETIMBiMBgQEBCA0JBTBIcHw/k9mvM5oRligFHMnCCcoLMtyk/JkcNJdWJ+3q9VqeHt7w2AwcLG4YuLORgCSTqhSqbhhwoiICE7ELl68CJPJJHo7LnHqdfboz9HXJuJi7bfWnx2M0IaTvb29WL58ObKzs/H444+7RUyWLVuGkpISqNVqjBo1Ci+99BI2b97MhaoBQGpqKt5//33B1+IAVFBsBaW1tRWXL19GbGws1Go1EhISrv93FgbPKyoh9ZYgwJeICcvtdiQSCZo6DXjwzijMnejYjb+hoQH/qmlGT2AkbgsbBhYs9Ho9tF1adHdr4eMjRUhoCExeAZg+Lhx3RArT7WWxWLiiKp8T54Ohp6cHZWVlGD58OPR6PXdjlclkghsY2tLa2or6+npR6hTEBkSlUkGn04FhGAwbNgwJCQmiHnOR4Ul3GF9a+61pNBrO0JQYOVo3JQgRTUDEJCcnB7/+9a89pWbhaVBBIYJChrA6OzuRnJwMo9GIS5cuITk5+bp/d75Zi/dKLmN0qD+uflTXigkA9BjN8PXxwkvZ1+egaPQmHK1So01rRIi/N2KkWoT7AbET4/BVuRLDA6WQ2hTdjSYjOjo60aDqxOwoKcaMljlt4DgQZMbmtttuEyRL2xlIzrn10ZJt3YUUc4cPHy7oU7qrcb18wTAMzp07B6lUCh8fH7s3VndBLExcrSMNFuK3RiKQLRYLpkyZgvDwcN5v9r29vXjwwQeRm5uLxx57jIpJ/9C2YeDn7hR/f3+kpKRAIpHcMHNeo+/7z44EAFgwDAuJ5FpL/ABfb7RpjdwgIwBYGBbvfVeLz//VDBZAn5kBy1rg7eWFeyZF4MU4L8wYF4YfLmswPFB6zXEZK/EBGxCK++eNxbgwP66N2Wg0cufMrnQK6XQ6VFRUYOLEidxWWiyUSiVqa2uvsZ4HrncI1mg03OcwbNgwru7C15wDecjo7e11ymxSCEiEsW3Rm9xYy8vLwbKsWyzoydS5mAOlxNA0MDAQtbW1iImJQUtLCy5cuMAlNDrT3NAfvb29WLZsGe6//348+uijVEwGwZDZoZjNZvT09HAGetZWCeRp3dbUEQBO12mw4/sriAz++ejD9otmMjPoMVnw58VTuL9780gNFGWt8Pa6KuV9fWb4eHtD4iVBn4XF1OhQvLc0EU2dvShr1EJntECCqze2QD8fJEeHICb82rN728jbsLAwyGQyp57aydlzQkKCIMNfztDQ0AClUomkpCSHhYEUc5VKJdrb26+ZAxlsl4874nodhXwXBzJ5tFdz4HsHJ/TUuTO0tbVxx5DkuzKQHYwzEDF54IEH8Mgjj1AxGZihfeRFnuzi4+Ovm6+wWCw4ffo0UlNTr/t3XXoTNijOY2SQL3z6mQdp1Rpxz8QRyJt+teulqdOAgu1n4O0FgAXM5j74+Ejh5XX1/wOWZcGwwBsPTEHq+OFgWRYafR9MFgZSby8MD5TCa4AvNDlnViqV0Gg0CAoK4n5M/R3VNDc3o7GxEcnJyW6PxbWG+IORRgBXboAGgwEqlYqb9SA7uODgYIduCmTHGhoaKnpXGQnoctarzHoHx1c7LpntENuSH/g5V8VaTOzR29vLHY2RuZ+RI0feMI4BuNoUsWzZMuTl5WHdunVUTBxjaAtKQ0MDgoKC7HbsWJs6WkNs5z/7VzOO13TgtlC/675sepMFOqMZG385CaNCrt6k/3q8DrtPNcBbgv9YUvhc9+8MfRbMig3H23nXNwI4i223lFQqhUwm4/LUWZbF5cuX0d3dLXrbKcMwOH/+PPz9/TFhwgRef7xms5mru+h0Oi44qr9kRr5aYPmAL5NH23ZcWzNPRyDtuELNdjhDS0sLmpqaMHXqVKdqWmazmWtPJ3Yw9ixx9Ho9li5dioKCAvzXf/0XFRPHGdqCcqM6CXDVg4sIiu3ke5+FxY7vr+BckxYBUm8E+fnAzLDo6u2Dj5cX1qWNxZTbfjbn26CoxLFqFaReLKQ+UrsfvdnCYFSIPwrXXX/M5iq9vb1QKpVQqVTc+wgKCsKUKVNE/cGQpEdb+xIhsO4U6ujouM5+frC7ASEg7gRCHC0ZjUZOZB2ZVCft0mLbugA/h3RNnTrVpYcgYomjVqvR3t4OADhy5AgWLFiAl156CUuXLsXatWupmDjH0BYUi8VyjV+XLURQiJjYTr5bGBbVbTocq1ajudMAX5+rRfVZ44cjfNjPxwoWiwXPfvIjjjeaEOTf//bcZGZwe8Qw7Fltf/aFD0jokr+/PywWi8OpjEJAbuBiJD3a2s+zLAuj0Yi4uDje5ymcxZ0mj8TIUq1Wc0Ol5KldKpVCqVSirq5OdFsX4OqgrVKpRHJyMu876q6uLrz//vv429/+Br1ej7y8POTk5GDOnDkuN3nYs6Dv6OjAkiVLUFdXh3HjxuFvf/uboFEDboIKykCCMhjbeWuI55NKMhxb/tkGL8n1BXyC2cLiiXvGY+mdwrTskiOU22+/nXsCt1gsXFFfq9UiNDQUMpms3yMhviBP4GLb8QNXb+CVlZUYNWoUurq6ePPYGgxqtZprV3f3bsD6mLS9vR1msxkMwyApKcntVvi2CJ342NPTgyVLlmD58uV48MEH8Y9//APFxcXIzs5GVlaWS69tz4L+d7/7HcLDw7FhwwZs2bIFGo3GUyzoXYEKykCCMnPmzEGLCblpxsXFIWz4cCzZ/i80dvbCz+f6G7XJzCDA1xuKR2Yg5Aa7mMFC5jpulJPBMAy6urqgVCrtHgnxBekqE9tmHbAf12vbORcaGsrVXYSsNZFCszMmpELR1NSE5uZmyGQydHR0cJPZYuxkr1y5Ao1Gg6SkJEEecoiYPPTQQ1izZg3vrw9cb58SFxeHkpISjB49Gi0tLbjnnntQXV0tyLXdyNAWFIZhuCAgWywWC3766Sd0d3cjIiICMpnMqZufUqnE5cuXr7HpaO4y4JG9ZVfnWMDCWyIB85/uLn+pN94pSEDCbfw/Cba1taGurs6pp17bIyFvb2+uqO/Kk3NLSwt30xSzqwxwLK7XWmQ1Gg0CAgI4keXzpk/apcU2eQTs7wZsd7IhISHcrIeQ662trUV3dzcSEhIEEROdToelS5dixYoV+NWvfsX76xNsBSUsLAydnZ3c/z58+HBoNBrBru8mqKDYCsp1xff/TGcrlUoYDIYBhwhZlsWVK1fQ0dGBxMTE625UPUYzisvb8Ld/N6Ojpw9Bft7ISRqF+6eORkQQvzdY67W4OuVN2i+Jt9TIkSM5kXXUer6urg6dnZ1ITEwU9aZJ1uKssSLLstdMaJNuKZlMNmhvL7IWrVaLhIQEUbvtAMdu4NYZL+3t7dysh6sPG7ZcvnwZPT09LreR94dOp8OSJUuwatUqrF69mvfXt4YKSv/csoLSX/GdYLFYOHHR6XQYPnw4ZDIZ1x1DhuGIxbqYk9XE7h0A72uxFlnryN/+4m5ZlkVVVRVYlhX9c2FZFtXV1bBYLP1GEjgKiSFQqVSDOhJiWRYXLlyA2Wx2eS2uQuaAjEaj04aT9mY9XKk/WWfRC9WFqNPpUFBQgF/96ldYtWoV769vCz3y6p9bUlBIfomj9RIyOKZUKrnuGJ1Oh9GjRyMmJkbUdkNi0xEeHi74WmzjbkNCQriivre3NzckGBISgvHjx4v6udiL6+ULe0dC1p+DvbX89NNPkEqlmDhxoqifCxFZ4OqNzpW1uFp/IsLW19eHO+64Q5DPpbu7G0uWLMGaNWuwcuVK3l/fHraC8txzz2HEiBFcUb6jowOvv/66W9YiIENbUFiW5TJRXOnk0ul0KCsrQ1BQEHp7exEQEMDF/bozPxv4uRV33Lhxbm9/JbYXpKjv5+cHvV6PMWPGiG49T0R25MiRgq/F9nMgBo4RERHw9fXlHJ1DQkJEn8RnWRaVlZXw9fXlfaiU1J/I3A/JeCHDtfbWcuHCBTAMI1iIWnd3NwoKCrB27VqsWLGC99e3hz0L+vvuuw8FBQWor6/H2LFj8fnnn4tisskzVFB6e3u5eslgvsBk6GvKlCkIDg7mztnJEKHthLqQkPAnT2jFJR5poaGh0Ov1vPhrDRaS2TF27FhERka69drAzwaOKpWKe4iJjIzEhAkT3L4Wa8iOLSgoyC27x56eHm6gkmGYayKgAaCqqgpeXl6CeadptVoUFBRg3bp1eOihh3h/fcoQFxSFQoGSkhLI5XLMnDnT6YJoY2MjWlpakJSU1K9YWE+osyzLdYzxHdCkUqlw6dIlt4Q/DQTxfLJuUbbnr+WOXBO+4nr5wGQy4ezZswgODobJZILBYBiw/iQUJAWTHIu6G9soApZluYwXIRoTtFot8vPz8eijj2L58uW8vz4FwFAXFL1ej7///e8oKirC2bNnMWvWLOTm5iItLe2GLaFka04S8xz9AZhMJk5cTCYTbzfV+vp6ruXU3UdstpC5jqSkpH53IiQwSqlUOpQnP1jIju1GszfughxFWodR2as/OZspPxjMZjPKysowatSoaxy2xYBlWZw/fx4sy0IqlaKzs5P31mwiJo899hgefPBBHlZN6YehLSjW9PX1oaSkBIWFhThx4gSSk5Mhl8uRkZFxzRO/2WzmisyxsbGDFgJiWmh9UyUdY46+JhG2vr4+0aNggZ8z6J0RNts8+eDgYC7XxJWbKhme9IQdW09PD8rLyzF58uR+jyL7y5Tn+6iUWO8MZIXvDogpaGBgIPdbsm3NBpzPlbemq6sL+fn5ePzxx7Fs2TIh3gblZ6ig2MNiseDUqVMoKirCt99+i9jYWGRnZyMuLg4bN27Ehx9+yOuTHcMwXGdMV1eXQ/YnpHsqODjYJWHjA9LmqdfrXcqgJ/MNJNfEtpjtKG1tbbhy5YpHDE8O1uRRr9dfU3dx5aZKILWkcePGud07zRZSvwkODsb48eP7/e9IxotKpYJer3dqN0vE5IknnsDSpUv5fguU66GCMhAMw6C8vBzvvPMOioqKkJqaiqysLGRnZ0Mmk/F+I2dZlss0IfYnpGOMDAMSf7Do6GjRLdYZhkFlZSWkUinvxVTrYrZEIuHE5UY7joaGBqhUKtHjeoGfLd9d3SVZ31R7e3sHdAe2BzlymzBhguiJnOQ3RfJmnPl3xMiSZLz0Zw1ExOTJJ5/EkiVLeH4HlH6gguII+/btw1tvvYV9+/ahr68PCoUCX375JSQSCRYtWgS5XC7IvAcx6yNP7L6+vggJCUFbWxsmT54sepGZtOKOGDFC8MKu9RChyWTCiBEjIJPJuNAs612SUDYdzmDPI4wPLBYLN//U1dXVb6aHNST/3dVcFT5gGAZlZWUYMWKES+3bttZAXl5e8PLyglQqxZgxY5Cfn4/169ejoKCAx9VTBoAKiiMUFhZi/vz51xxZsCyLlpYWKBQKKBQKaLVaLFy4EDk5OYINZDU1NeHSpUvw9fWFj48P1zEmRuCRwWDAuXPnEBMT4/Z5FzI8RxwLwsLCuPkfoeYXnKGlpQWNjY0Dpgm6iiMWKJ6Q/06wWCwoKytDREQE79k3RqMRx48fx+uvv46LFy8iNTUVzz77LGbNmiXITvXtt9/G9u3bIZFIkJiYiF27domeFeMBUEHhi/b2dnz11VdQKBSor69HRkYG5HI5pk+fzsvTMnF/JS3KRqOR6xgzm81Oe2u5gk6n41yUxX7i7evrw9mzZwFcvWEFBQVxRX0xjrzEPHLT6/Xc0ZjFYkFwcDDa29uRnJwsev47EZNRo0YhKkqYeAaNRsMV4ENDQ/HVV1/hhx9+wLfffstrzaipqQlpaWmorKxEQEAACgoKkJWVJbgf2E0AFRQh0Ol0+Oabb6BQKFBeXo60tDTk5uZi9uzZTt9kyFFOT09Pvz36tt5aQtqMk7pAQkICN5AmFiSud/To0YiKirJ7RChEp5Q9WJbljBUTExNFP3Jrb29HZWUlhg0bBqPReJ3vnDshbcqjR48WrOan0WiQl5eH3/72t8jLy+P+nmEY3t9vU1MTUlNTUVZWhpCQENx333146qmnMH/+fF6vcxNCBUVojEYjjh07BoVCge+//x4pKSnIyclBenr6gFtki8WCyspK+Pn5Oez3RDyllEoluru7ERYWBplMhuHDh7v8w2ptbUV9fb1HdE85Etdr2ylFxIXvDBZrk8f4+HjRj9xs899tW7NJKqN1o4dQmM1mlJaWIioqSrA2ZSImzz77LBYvXizINWzZtm0bNm7ciICAAMyfPx979+51y3U9HCoo7sRsNuPkyZNQKBQ4duwYJk2ahJycHCxYsOC6wTuTyYRz585h1KhRgz5vJhnqJMuDFHBHjhzpVGsvy7LXZGSI3T3lyFyHLSaTiRMXEnssk8lcTmQkXW5+fn68e2ENBpL4OHXq1H79skgqo1qtFsx6Hvh55mXs2LGC1dk6OjqQn5+P3/3ud7j//vsFuYYtGo0Gixcvxr59+xAWFob8/Hzk5eVROxcqKOLBMAzOnj2LoqIiHDp0CDKZDHK5HFlZWWhtbcXevXvx7LPPclPVrmJvxoN4jN2ocOxJFuvAz8mTiYmJgz5ys7eLI464zrw/MgsUGhp6w1kKdzGY/HfbnBtyXEq65wYLqW0JOfPS0dGBvLw8/P73v3ebmADA559/jkOHDmHHjh0AgI8++ginTp3CX/7yF7etwUOhguIJEPvwoqIifPLJJ1Cr1Vi1ahUefvhhREVFCfLUa21g2V8aI3HFDQoKEn14EhCmFZfs4ogjrr25H3t4kn0JcLWzrKmpySX7HWKJo1KpuLyfiIgIp49LyQDl+PHj+z2OdJX29nbk5eXh+eefx3333SfINfrjxx9/xJo1a3D69GkEBARg9erVuPPOO/Hkk0+6dR0eCBUUT+Kzzz7D1q1bsW3bNpw6dQr79+9Hb28vsrKykJOTI5gLq8Fg4MTFYrFwN5GamhpERkZ6xA2zubkZTU1NgrbiktkGsosjrdm2QktumGK0TNujsbGR83LjywOM5P2oVKoBhwitMRqNKC0tFXSAkojJH/7wB+Tm5gpyjYF48cUXsW/fPvj4+GDatGnYvn276HVFD4AKiqdgMpnw29/+Fq+++uo1LZ4qlQoHDhyAQqFAS0sLMjMzIZfLkZycLMjxk8lkQnNzM2prayGVShEZGelS+p6rkBhjjUZzTca5O7A+DiJ266Ghobhw4QImTpwo+sQ5AO6zcSbK2Flshba/KAKDwYDS0lJBnZ3b29uxePFi/Pd//zfkcrkg16AMGiooNxNarRZff/01FAoFqqqqMG/ePMjlcqSmpvJWKCcOvfHx8QgKCrph5LHQeFL9xmQyoampCbW1tfDz8+OOCIVozXYElmW5zHV3OwPYRhGMGDECoaGhqKmpweTJkwWbTVKr1cjLy8MLL7yAnJwcQa5BcQkqKDcrBoMBR44cQVFREU6fPo2ZM2dCLpfj7rvvHvTWW61Wo6amxq73lG3ksdBW68SJ1t/f3yO6p4jQJiQkIDAwEB0dHVAqldBqtU7H3LoKy7K4ePEi5zItdtx0S0sLampqIJVKuaK+sw0OA0HE5I9//COys7N5e10Kr1BBuRUwm804fvw4CgsL8d133yE+Ph5yuRyZmZkOd0KRSfzk5OQBO4RsI275jjx2Z1yvI9zICp+YeZKivtDxzyzLoqqqChKJxOX8dz4gAWZ33HEHgoODr/ksAgMDuaMxVz4LlUqFvLw8bNq0CYsWLeJx9RSeoYJyq8EwDM6cOYPCwkIcPnwY0dHRyMnJQVZWlt1zbXJ0otPpBpWWx3fksdhxvbaQzrL+5jqssf4s1Go1V2uQyWS8dKWRmRd/f3/cfvvtoosJ8QmzF2Bm+1l4eXk55BZti0qlwuLFi/HSSy9RMfF8qKDcypA0vKKiIhw8eBCBgYGQy+XIyclBZGQkTCYTvvzySyQmJvL2tOtK5DFxxfWUgrerJo+k1qBUKmGxWK7JUHf2syaW7yEhIR4x86LT6VBeXu5wzovBYOB8xoxGI/dZ3KjZQ6lUIi8vDy+//DKysrL4fgsU/qGCMlQgXlPEet9oNKK3txfz5s3D5s2bBesYczTymARReUJcL3A1VlmtVvPWimuboe5MQifJf3fV8p0viJgMdriUuEWrVCp0d3fbrUERMXnllVewcOFCvt8CRRiooNhy6NAhrF+/HhaLBWvXrsWGDRvEXhLvtLS0cK3HjY2NaG9vR2ZmJnJzczFlyhRBxOVGkccajcZj4nrd0T1lm2lyowYHMkAZGRkpmEuvMxDhT0pK4sUTjWEYLvpYqVTizTffxOzZs7F//35s2bIFv/zlL3lYtX06Ozuxdu1aVFRUQCKRYOfOnZg1a5Zg1xsCUEGxxmKxYNKkSThy5Aiio6MxY8YMfPrpp4iPjxd7abzBMAzS09Px4osv4t577wVw9YdVXFwMhUKBmpoa3HvvvZDL5ZgxY4ZgHVzkCbW9vR0WiwVxcXEYNWqUqK3BxLGAYRjBMm3sXdM6Sz4gIIAbIJRIJCgtLcWYMWM8op5EOt2Sk5MFEX6GYVBSUoJXXnkFPT09GDlyJLKzs5Gfny9IgNuqVaswd+5crF27FiaTCXq93mFvOIpdqKBY88MPP2DTpk34+9//DgDYvHkzAOD5558Xc1m8YzQa+y0w6/V6HD58GIWFhTh79ixmzZqF3NxcpKWlOZXr7ggNDQ1oa2vDuHHj0N7e7pT1Cd94iskjKWSTnVxkZCTGjx8vSoiaNV1dXfjpp584B2MhaG1tRX5+PjZv3oz58+ejra0NxcXFuO2223g/9tJqtUhOTsbly5dFb264haCCYs0XX3yBQ4cOYfv27QCAPXv24Mcff8R7770n8srEoa+vDyUlJSgsLMSJEyeQnJwMuVyOjIwMl55Q+ztWspdnQjrG+BYza0iNYvjw4U5lnAsFmTiPiYmBxWKBUqlEX1/fDWtQQtLZ2YmqqirBxSQvLw9btmxxS65IaWkp1q1bh/j4eJSVlSElJQXbtm3jPdpgiGH3SymuN7mI2BPSofz0IpVKkZmZiczMTFgsFpw6dQpFRUV49dVXERsbi+zsbCxcuNCpYwKGYVBVVQUvLy8kJiZe8/lKJBKEhIQgJCQEEyZMgF6vh1KpRFlZGSQSiSCRx319fTh37pzH1CjIXIe1NX90dDRXg6qrq4NOp0N4eDgiIiIEdy0gMzhTp04VLOKW7Exee+01ZGZmCnINW8xmM/7973/j3XffxV133YX169djy5YteOWVV9xy/aHEkBWU6OhoNDQ0cH9ubGwULGHuZsPb2xtz5szBnDlzuBbWwsJC5ObmIjw8HNnZ2cjOzoZMJutXhIl7cXBwMMaPHz+gWAcGBmLcuHEYN24cF3n8008/8RZ57Gkmj6R7yl6nm4+PDyIjIxEZGcm5FrS1taG6uhrBwcFc7DGfNa/29nbU1NRg2rRpghkfWovJL37xC0GuYY/o6GhER0fjrrvuAgBud0ThnyF75GU2mzFp0iQcPXoUUVFRmDFjBj755BNMmTJF7KV5LCzLoqamhmtHlkgkWLRoEeRyOWJiYribvdFoRHl5OS/uxXxEHnvazAvpnnK2FZfk3JDALGufMVeOCUlQ17Rp0wQ7bmxpaUFBQQFef/11ZGRkCHKNGzF37lxs374dcXFx2LRpE3p6evDGG2+4fR23ELSGYsvBgwfx9NNPw2KxYM2aNdi4caPYS7ppYFkWLS0tUCgUUCgU0Gq1WLhwIe68805s3LgRH3/8MSZMmMDrNQcTeUwmvOPj4xEaGsrregYDqVHw0Tbd09PDGTdKJBJuJ+fsdHptba1TQV3O0tLSgvz8fLz55ptIT08X5BoDUVpaynV4xcbGYteuXYIZWw4RqKBQhKO9vR0ffPAB3njjDcTHxyM1NRU5OTlISUkR5Nzfkcjjrq4uVFZWupT4yCdC1iioqG7OAAAQZ0lEQVSMRiMnLiaTiYs9vlEao1KpxJUrVwTNnWlubkZBQQH+/Oc/c63rlFsCKijupqGhAStXrkRrayu8vLywbt06rF+/XuxlCcKPP/6IRx55BB9//DHGjRuHb775BgqFAuXl5UhLS4NcLsfs2bMFM1G0jTweNmwY1Go1pk6dKnobLuCcT5ir2E6n20tjbG1tRUNDg+Bikp+fj7feeouKya0HFRR309LSgpaWFkyfPh3d3d1ISUnB/v37b6nhScLJkycxZsyY6+xCjEYjjh07BoVCge+//x7Tp0+HXC5Henq6YJ1E9fX1qKurg5+fH5fEyJdp42Boa2tDfX29oDfv/rDdyQUFBUEqlaK7uxvTpk0TbP6nqakJBQUFePvtt3HPPfcIcg2KqFBBEZvc3Fw88cQTbmuX9DTMZjNOnjwJhUKBY8eOYeLEiZDL5ViwYAFvnl7Nzc2cNb9UKrUbeUw6xtwBWc/UqVPdOrxpDzIT1NzcDKlUCj8/P84VmM9dExGTrVu34u677+btdSkeBRUUMamrq8O8efNQUVHhEYaIYsMwDM6ePYuioiIcOnQIMpkMcrkcWVlZnBWJs1y5cgUdHR39xgebTCauY8xgMDjkgusKDQ0NUKlUvOa/u4JtHr1er+fqLsQtOiIiwiWxbWxsxJIlS7Bt2zbMmzePx9VTPAwqKGKh0+lw9913Y+PGjXjggQfEXo7HQXy1ioqKUFxcDD8/P64dOSoqasCbPcuyuHTpEvR6vcMmjxaLRdDI47q6OnR1dSExMVFUzzJCQ0MD1Gq1w2JLivrOiG1DQwOWLl2Kd955B3PnzuX7LVA8CyooYtDX14fs7GwsWLAAzzzzjNjL8XhYlkVjYyOKiopw4MAB6PV6ZGVlIScnB5MmTbru5kbEiGVZTJ48eVA7DT4jj4m49fb2Cubm7CxXrlyBRqNBUlKSw2JLivok9lgmk90w6rehoQFLlizBu+++S8VkaEAFxd2wLItVq1YhPDwcW7duFXs5NyUqlQoHDhzA/v370dzcjMzMTM6Ov6+vDzt37kRmZiZvqYbWkcft7e0IDAx0OOaXZVlcuHABFovFbQ7GA+HqTokU9UnULzH0HDFiBPd51NfXY+nSpXjvvfeQlpbG91ugeCZUUNzNiRMnMHfu3Gt+zK+++ipNpBskWq0WX3/9NRQKBSorKwEAs2bNwp///GdBCt4sy0Kn03HRtlKplCvq2xaxWZbFTz/9BG9vb7s7KTGwjnvmY6dk/Xk0Nzfj5ZdfxuzZs3Hw4EF88MEHmDNnDg+r7h+LxYI777wTUVFRKC4uFvRalAGhgnKrM1R+cJ2dncjNzcXUqVOh1Wpx+vRpzJw5E3K5HHfffbdgcx79RR77+/vj/PnzCAwMRGxsrOhiQo7dDAYD4uPjBTt2++c//4k//vGPYFkWvr6+WLRoEZYuXYrY2FhBrvfWW2/hzJkz0Gq1t/T3+yaBug3f6mzbtg133HEHtFqt2EsRlF//+tf4zW9+g/vuuw/A1Xbk48ePo7CwEC+88ALi4+Mhl8uRmZnJ64R8QEAAYmJiEBMTw0UeV1VVcUmMnmCHT/zWTCYTpkyZIpi4XblyBRs2bMD777+P1NRUdHR04Ouvv8alS5cEEZTGxkZ8/fXX2LhxI9566y3eX5/CD3SHcovQ2NiIVatWcT+4W/kJzmw293vExTAMzpw5g8LCQhw+fBjR0dHIyclBVlYWwsPDeV2HxWJBWVkZwsPD4e/vbzfy2J27FVLDYRhm0A0KjlBXV4dly5bhr3/9K1JTUwW5hi15eXl4/vnn0d3djTfffPOW/n7fJNAdyq3M008/jddffx3d3d1iL0VwblQv8fLywsyZMzFz5kxs2bIF58+fR1FREfLy8hAYGIicnBzI5XJERka6dMM1m80oLS3FbbfdxsUeELv59vZ2NDc3o6qqyqEOKT4g3W4A3CImH3zwAWcHLzTFxcWQyWRISUlBSUmJW65JGRxUUG4B6A/OPhKJBAkJCUhISMALL7yA2tpaKBQKrFmzBmazmWtHdrZD7EbZKl5eXtyAIMuynO3JxYsXBYs8Jg0BPj4+mDhxomBiUltbiwcffBAffvghZs6cKcg17HHy5El8+eWXOHjwIAwGA7RaLR566CF8/PHHblsDxTHokdctwPPPP489e/bAx8eH+8E98MAD9AfXDyzLQqlUYv/+/VAoFFCr1Zg/fz5yc3MHnB0xGo0oLS1FbGwsIiIinLqmEJHHLMuisrISvr6+mDBhgmBicvnyZSxfvtztYmJLSUkJPfLyDGiX11CA/uCcp7OzE8XFxVAoFKipqcG9994LuVyOGTNmXDPYSIK6Jk2a5HI9hkQekyyTwUQeMwyDyspKBAQECNpdRsRk+/btmDFjhiDXcBT6/fYYqKAMBegPzjX0ej0OHz6MwsJCnD17FrNnz4ZcLkd4eDhefvll7Nixg/dgJhJ5rFKpHI48ZhgGFRUVCAoKEqxNFwBqamqwYsUK7NixA3feeadg16HcdFBBoVCcoa+vDyUlJfjwww/x7bffIjMzEw888AAyMjJcTlu80TWtI49Jx5h15DHDMCgvL0doaKigrcpETHbu3ImUlBTBrkO5KaGCQuGHzs5OrF27FhUVFZBIJNi5cydmzZol9rIE4V//+hcefvhh7N27F52dnVAoFDhy5AhiY2ORnZ2NhQsXIiwsTJBr24s8HjlyJBobGzFixIjrsmf45OLFi1ixYgV27dpFxYRiDyooFH5YtWoV5s6dy2V06/V6wW6qYrN161bI5fJrjpXIDqGoqAgHDx5EeHg4srOzkZ2dDZlMJkgtg7QjV1VVgWVZhIeHXxd5zBcXLlzAypUr8b//+7+YPn06r69NuWWggkJxHa1Wi+TkZFy+fFl0ixFPgNicFBUV4csvv4REIuGs92NiYnj7jMgQpUwmQ1RU1HWRx6RjzNVESComFAehgkJxndLSUqxbtw7x8fEoKytDSkoKtm3b5rYERE+GZVm0tLRAoVBg//796OrqwsKFC5GTk+OS+7DZbEZZWRlGjx7NDVFa09PTwxX1vb29Bx15XF1djVWrVmH37t2YNm3aoNZKGTJQQaG4zpkzZ5CamoqTJ0/irrvuwvr16xESEoJXXnlF7KV5HO3t7fjqq6+gUChQX1+PjIwM5OTkICUlxeGpeTKRHxUVhdGjRw/43w828piIyUcffYSpU6c6tDbKkIYKCsV1WltbkZqairq6OgDA8ePHsWXLFnz99dfiLszD0el0+Oabb6BQKFBeXo60tDTI5XLMnj2732Oqvr4+lJaWYuzYsddN5DuCoymMVVVVWL16Nfbs2YPk5ORBv0fKkIIKCoUf5s6di+3btyMuLg6bNm1CT08P3njjDbGXddNgNBpx7NgxKBQKfP/995g+fTrkcjnS09O5YyqNRoMLFy5g/PjxkMlkLl/TNvK4tbUVUqkUY8eOxbp16wQXk4aGBqxcuRKtra3w8vLCunXrsH79esGuRxEcKigUfigtLeU6vGJjY7Fr1y7eh/2GCmazGSdPnoRCocCxY8cwceJEpKen47333sO7776L2bNn835NhmFw4sQJ/M///A9OnjyJuXPn4uGHH0ZmZqZTk/rO0NLSgpaWFkyfPh3d3d1ISUnB/v37ER8fL8j1KIJDBYVyc/H2229j+/btkEgkSExMxK5du5wuNN9MMAyDo0ePYvXq1Rg7dizCwsIgl8uRlZWFkSNH8tpVV1lZiTVr1mDPnj3Q6/VQKBT49ttvceTIEYwYMYK36/RHbm4unnjiCWRmZgp+LYogUEGh3Dw0NTUhLS2N86oqKChAVlYWVq9eLfbSBKO1tRU5OTnYsmUL0tPTUV1djaKiIhQXF8PX1xfZ2dmQy+WIiopySVyImOzduxeJiYk8vgPHqKurw7x581BRUYGQkBC3X5/CC3a/gMIFNFAoLmI2m9Hb2wuz2Qy9Xm+3ZfZWQiqV4p133kFGRgYkEgkmT56MP/zhDzh58iT27NkDqVSKRx99FBkZGXjjjTdQXV2NAR4Ir4OIySeffCKKmOh0OixevBhbt26lYnILQncoFI9l27Zt2LhxIwICAjB//nzs3btX7CV5BCqVCgcOHMD+/fvR3NyMX/ziF8jNzUVycvIN25HPnz+Phx9+GJ9++immTJnixhVfpa+vD9nZ2ViwYAGeeeYZt1+fwiv0yIty86DRaLB48WLs27cPYWFhyM/PR15eHh566CGxl+ZRaLVaHDx4EEVFRaiqqsK8efMgl8uRmpp6TYhXRUUF1q5dK5qYsCyLVatWITw8HFu3bnX79Sm8QwWFcvPw+eef49ChQ9ixYwcA4KOPPsKpU6fwl7/8ReSVeS4GgwHffvstCgsLcfr0acycORNyuRwRERF47LHH8Nlnn4nWVXXixAnMnTsXiYmJ3C7q1VdfRVZWlijrobgMzZSn3DyMHTsWp06dgl6vR0BAAI4ePUrzOAbA39+fM6k0m804fvw4vvjiC+zbtw/fffedqC26aWlpTtd7KDcfdIdC8VhefPFF7Nu3Dz4+Ppg2bRq2b98OPz8/sZd108GyLDXypPANPfKiUCgUCi/QtmEKxZo1a9ZAJpMhISGB+7uOjg5kZmZi4sSJyMzMhEajEXGFFMrNBRUUypBl9erVOHTo0DV/t2XLFmRkZODixYvIyMjAli1bRFodhXLzQY+8KEOauro6ZGdno6KiAgAQFxeHkpISjB49Gi0tLbjnnntQXV0t8iopFI+DHnlRKAPR1tbG5Y6MHj0aSqVS5BVRKDcPVFAoFAqFwgtUUCgUK0aNGoWWlhYAVy3X+cgiuRU4dOgQ4uLiMGHCBFpXovQLFRQKxQq5XI7du3cDAHbv3o3c3FyRVyQ+FosFjz/+OL755htUVlbi008/RWVlpdjLonggVFAoQ5Zly5Zh1qxZqK6uRnR0NHbs2IENGzbgyJEjmDhxIo4cOYINGzaIvUzR+b//+z9MmDABsbGx8PX1xdKlS3HgwAGxl0XxQKj1CmXI8umnn9r9+6NHj7p5JZ5NU1MTxowZw/05OjoaP/74o4grongqdIdCobgBe0OUzz33HCZPnoykpCTcf//96OzsFHGF/WNvtIBauVDsQQWFQnED9oYoMzMzUVFRgXPnzmHSpEnYvHmzSKu7MdHR0WhoaOD+3NjYeMuHnVEGBxUUCsUNzJs3D+Hh4df83fz587nMktTUVDQ2NoqxtAGZMWMGLl68iNraWphMJnz22WeQy+ViL4vigdAaCoXiAezcuRNLliwRexl28fHxwXvvvYcFCxbAYrFgzZo1ooR0UTwfKigUisj86U9/go+PD5YvXy72UvolKyuLhmFRBoQKCoUiIrt370ZxcTGOHj1KC92Umx4qKBSKSBw6dAivvfYavvvuOwQGBoq9HArFZajbMIXiBpYtW4aSkhKo1WqMGjUKL730EjZv3gyj0YgRI0YAuFqYf//990VeKYXiEDSxkUKhUCi8QO3rKRQKhSIcVFAoFAqFwgtUUCgUCoXCCwN1edE+RgqFQqE4BN2hUCgUCoUXqKBQKBQKhReooFAoFAqFF6igUCgUCoUXqKBQKBQKhReooFAoFAqFF/4fs2IfCxeX+bAAAAAASUVORK5CYII=
"
>
</div>

</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h4 id="Train-the-MLGP-on-the-shapes-in-the-canonical-orientation">Train the MLGP on the shapes in the canonical orientation<a class="anchor-link" href="#Train-the-MLGP-on-the-shapes-in-the-canonical-orientation">&#182;</a></h4>
</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[6]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">N_GEOMETRIC_NEURONS</span> <span class="o">=</span> <span class="mi">5</span>
<span class="n">OUTPUT_DIM</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="nb">set</span><span class="p">(</span><span class="n">Ytrain</span><span class="o">.</span><span class="n">numpy</span><span class="p">()))</span>
</pre></div>

     </div>
</div>
</div>
</div>

</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[7]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># set the seed here:</span>
<span class="n">torch</span><span class="o">.</span><span class="n">manual_seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>

<span class="c1"># instantiate the model:</span>
<span class="n">model</span> <span class="o">=</span> <span class="n">build_mlgp</span><span class="p">(</span><span class="n">input_shape</span><span class="o">=</span><span class="n">Xtrain</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">1</span><span class="p">:],</span> <span class="n">output_dim</span><span class="o">=</span><span class="n">OUTPUT_DIM</span><span class="p">,</span> <span class="n">hidden_layer_sizes</span><span class="o">=</span><span class="p">[</span><span class="n">N_GEOMETRIC_NEURONS</span><span class="p">],</span> <span class="n">bias</span><span class="o">=</span><span class="kc">False</span><span class="p">)</span>

<span class="nb">print</span><span class="p">(</span><span class="n">model</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;total number of trainable parameters:&#39;</span><span class="p">,</span> <span class="nb">sum</span><span class="p">([</span><span class="n">np</span><span class="o">.</span><span class="n">prod</span><span class="p">(</span><span class="n">p</span><span class="o">.</span><span class="n">size</span><span class="p">())</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="nb">filter</span><span class="p">(</span><span class="k">lambda</span> <span class="n">p</span><span class="p">:</span> <span class="n">p</span><span class="o">.</span><span class="n">requires_grad</span><span class="p">,</span> <span class="n">model</span><span class="o">.</span><span class="n">parameters</span><span class="p">())]))</span>
<span class="nb">print</span><span class="p">()</span>

<span class="n">model</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
<span class="n">Xtrain</span><span class="p">,</span> <span class="n">Ytrain</span> <span class="o">=</span> <span class="n">Xtrain</span><span class="o">.</span><span class="n">float</span><span class="p">()</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">),</span> <span class="n">Ytrain</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>

<span class="c1"># define the loss and optimizer:</span>
<span class="n">criterion</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">CrossEntropyLoss</span><span class="p">()</span>
<span class="n">optimizer</span> <span class="o">=</span> <span class="n">optim</span><span class="o">.</span><span class="n">Adam</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">parameters</span><span class="p">(),</span> <span class="n">lr</span><span class="o">=</span><span class="mf">1e-3</span><span class="p">)</span>

<span class="n">epochs</span> <span class="o">=</span> <span class="mi">2000</span>

<span class="c1"># train the model:</span>
<span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">epochs</span><span class="p">):</span> 
        <span class="n">y_pred</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">Xtrain</span><span class="p">)</span>
        <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">y_pred</span><span class="p">,</span> <span class="n">Ytrain</span><span class="p">)</span>
        <span class="n">optimizer</span><span class="o">.</span><span class="n">zero_grad</span><span class="p">()</span>
        <span class="n">loss</span><span class="o">.</span><span class="n">backward</span><span class="p">()</span>
        <span class="n">optimizer</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
        <span class="n">acc</span> <span class="o">=</span> <span class="n">score</span><span class="p">(</span><span class="n">y_pred</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">Ytrain</span><span class="p">)</span>

        <span class="k">if</span> <span class="n">i</span> <span class="o">%</span> <span class="mi">500</span> <span class="o">==</span> <span class="mi">0</span><span class="p">:</span>
            <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;epoch: </span><span class="si">%d</span><span class="s1">, loss: </span><span class="si">%.3f</span><span class="s1">,  acc:  </span><span class="si">%.3f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">i</span><span class="p">,</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">(),</span> <span class="n">acc</span><span class="p">))</span>

<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;epoch: </span><span class="si">%d</span><span class="s1">, loss: </span><span class="si">%.3f</span><span class="s1">,  acc:  </span><span class="si">%.3f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">i</span><span class="p">,</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">(),</span> <span class="n">acc</span><span class="p">))</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
model: MLGP
PointCMLP(
  (hidden_layers): ModuleList(
    (0): Linear(in_features=20, out_features=5, bias=False)
  )
  (out_layer): Linear(in_features=7, out_features=8, bias=False)
)
total number of trainable parameters: 156

epoch: 0, loss: 2.064,  acc:  0.375
epoch: 500, loss: 0.318,  acc:  1.000
epoch: 1000, loss: 0.054,  acc:  1.000
epoch: 1500, loss: 0.019,  acc:  1.000
epoch: 1999, loss: 0.009,  acc:  1.000
</pre>
</div>
</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h3 id="Step-2">Step 2<a class="anchor-link" href="#Step-2">&#182;</a></h3>
</div>
</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<p>The main function in this step is <code>construct_filter_banks</code>:</p>
<ul>
<li>takes in <em>non-normalized</em> (raw) spheres $\tilde{S}_k \in \mathbb{R}^5$, i.e., parameters, extracted from the trained ancestor MLGP model;</li>
<li>computes the initial rotations $R_O^k$, i.e., from the original sphere centers $c_k$ to (1,1,1);</li>
<li>computes the tetrahedron rotations $R_{Ti}$, i.e., rotations transforming (1, 1, 1) into the other three vertices;</li>
<li>constructs the filter banks for each sphere as discussed in Section 4.1.2 in the paper</li>
</ul>
\begin{equation*}
    B(\tilde{S}_k) = 
    \begin{bmatrix}
        R_O^{k\top} R_{T0} R_O^{k} \tilde{S}_k \\
        R_O^{k\top} R_{T1} R_O^{k} \tilde{S}_k \\
        R_O^{k\top} R_{T2} R_O^{k} \tilde{S}_k \\ 
        R_O^{k\top} R_{T3} R_O^{k} \tilde{S}_k \\
    \end{bmatrix} ~;
\end{equation*}<ul>
<li>returns an array of $R_O^k$ (optionally) and an array of the constructed $B(\tilde{S}_k)$.</li>
</ul>
<p>To demonstrate how it works, we first extract the ancestor model hidden layer (i.e., geometric neurons) spheres, and then take one of them to form a filter bank:</p>

</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[8]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># extract the spheres from the ancestor model:</span>
<span class="n">original_state_dict</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">()</span>

<span class="c1"># get the geometric neuron spheres:</span>
<span class="n">hidden_name</span> <span class="o">=</span> <span class="s1">&#39;hidden_layers.0.weight&#39;</span> 
<span class="n">hidden_spheres</span> <span class="o">=</span> <span class="n">original_state_dict</span><span class="p">[</span><span class="n">hidden_name</span><span class="p">]</span>            <span class="c1"># (n_geometric_neurons x N_points*5)</span>

<span class="c1"># each sphere is a parameter vector of length 5;</span>
<span class="c1"># each geometric neuron contains a number of spheres corresponding to the number of input points</span>
<span class="c1"># in the point set</span>

<span class="c1"># reshape to (n_geometric_neurons x N_points x 5):</span>
<span class="n">hidden_spheres_numpy</span> <span class="o">=</span> <span class="n">hidden_spheres</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span><span class="o">.</span><span class="n">reshape</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">hidden_spheres</span><span class="p">),</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;hidden_spheres_numpy.shape:&#39;</span><span class="p">,</span> <span class="n">hidden_spheres_numpy</span><span class="o">.</span><span class="n">shape</span><span class="p">)</span> 


<span class="c1"># e.g., select the third sphere from the second geometric neuron:</span>
<span class="n">one_sphere</span> <span class="o">=</span> <span class="n">hidden_spheres_numpy</span><span class="p">[</span><span class="mi">1</span><span class="p">,</span><span class="mi">2</span><span class="p">,:]</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">S_tilde_k = &#39;</span><span class="p">,</span> <span class="n">one_sphere</span><span class="p">)</span>

<span class="c1"># construct a filter bank for this sphere:</span>
<span class="n">init_rotation</span><span class="p">,</span> <span class="n">filter_bank</span> <span class="o">=</span> <span class="n">construct_filter_banks</span><span class="p">(</span><span class="n">one_sphere</span><span class="p">,</span> <span class="n">return_init_rotations</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">R_O^k =</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">init_rotation</span><span class="p">,</span> <span class="s1">&#39;</span><span class="se">\n\n</span><span class="s1">B(S_tilde_k) =</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">filter_bank</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>hidden_spheres_numpy.shape: (5, 4, 5)

S_tilde_k =  [-0.6873  0.6743 -0.2568 -0.4767 -0.417 ]

R_O^k =
 [[[ 0.408  -0.6725 -0.6174]
  [ 0.9052  0.2101  0.3693]
  [-0.1187 -0.7096  0.6945]]] 

B(S_tilde_k) =
 [[-0.6873  0.6743 -0.2568 -0.4767 -0.417 ]
 [ 0.2178  0.0995  0.9673 -0.4767 -0.417 ]
 [-0.3543 -0.9161 -0.1682 -0.4767 -0.417 ]
 [ 0.8238  0.1422 -0.5423 -0.4767 -0.417 ]]
</pre>
</div>
</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h4 id="Visualize">Visualize<a class="anchor-link" href="#Visualize">&#182;</a></h4><p>We normalize, i.e., <em>unembed</em>, the resulting spheres to get their Euclidean $\mathbb{R}^3$ representation.</p>
<p>By unembedding the 5-vectors, we will get the first three elements that represent the Euclidean coordinates of the sphere center:</p>

</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[9]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># the centers of the filter bank spheres:</span>
<span class="n">centers</span> <span class="o">=</span> <span class="n">unembed_points</span><span class="p">(</span><span class="n">filter_bank</span><span class="p">)</span>

<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">the four sphere centers:</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">centers</span><span class="p">)</span>
<span class="n">fig</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">figure</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="n">figsize</span><span class="o">=</span><span class="p">(</span><span class="mi">7</span><span class="p">,</span><span class="mi">7</span><span class="p">))</span>
<span class="n">ax</span> <span class="o">=</span> <span class="n">fig</span><span class="o">.</span><span class="n">add_subplot</span><span class="p">(</span><span class="mi">111</span><span class="p">,</span> <span class="n">projection</span><span class="o">=</span><span class="s1">&#39;3d&#39;</span><span class="p">)</span>         
<span class="n">ax</span><span class="o">.</span><span class="n">scatter</span><span class="p">(</span><span class="n">centers</span><span class="p">[:,</span> <span class="mi">0</span><span class="p">],</span> <span class="n">centers</span><span class="p">[:,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">centers</span><span class="p">[:,</span> <span class="mi">2</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">100</span><span class="p">)</span>
<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;A regular tetrahedron formed by the centers of the $B(S_k)$ spheres&#39;</span><span class="p">)</span>
<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
the four sphere centers:
 [[ 1.6482 -1.6171  0.6159]
 [-0.5223 -0.2387 -2.3197]
 [ 0.8498  2.1969  0.4033]
 [-1.9756 -0.3411  1.3006]]
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>




<div class="jp-RenderedImage jp-OutputArea-output ">
<img src="data:image/png;base64,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
"
>
</div>

</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<p><strong>Step 2</strong> is wrapped into the function <code>transform_parameters</code>:</p>
<ul>
<li><p>takes in the trained ancestor MLGP model;</p>
</li>
<li><p>transforms its parameters --- uses the hidden layer spheres to create the filter banks and keeps the output (classification) layer the same;</p>
</li>
<li><p>returns the initial rotations $R_O^k$, the filter banks $B(\tilde{S}_k)$, and the ancestor model output layer parameters.</p>
</li>
</ul>

</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[10]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">transformed_parameters</span> <span class="o">=</span> <span class="n">transform_parameters</span><span class="p">(</span><span class="n">model</span><span class="p">)</span> <span class="c1"># used in the experiments further down</span>
</pre></div>

     </div>
</div>
</div>
</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h3 id="Step-3">Step 3<a class="anchor-link" href="#Step-3">&#182;</a></h3>
</div>
</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<p><strong>Step 3</strong> is wrapped into the <code>build_steerable_model</code> function:</p>
<ul>
<li><p>creates a steerable model with learnable interpolation coefficients $v^k$ according to the constraint (13) in the paper;</p>
<ul>
<li>since $v^k$ depends on the (possibly unknown) rotation $R_B$ applied to the input (see (12) in the paper), we will learn the parameters of this rotation instead, i.e., three axis-angle parameters, if they are unknown (as discussed in the paper in Section 5.2);</li>
</ul>
</li>
<li><p>the rest of the model parameters are set to be the ones obtained in Step 2 (the filter banks and the unchanged output layer) and are fixed (<strong>not</strong> updated).</p>
</li>
</ul>

</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[11]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># choose initial model parameters:</span>
<span class="n">init_axis_angle</span> <span class="o">=</span> <span class="n">random_axis_angle</span><span class="p">()</span>

<span class="c1"># use the initial parameters and the transformed ancestor model parameters obtained in Step 2</span>
<span class="c1"># to build a steerable spherical classifier:</span>
<span class="n">steerable_model</span> <span class="o">=</span> <span class="n">build_steerable_model</span><span class="p">(</span><span class="n">input_shape</span><span class="o">=</span><span class="n">Xtrain</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">1</span><span class="p">:],</span> 
                                        <span class="n">output_dim</span><span class="o">=</span><span class="n">OUTPUT_DIM</span><span class="p">,</span>
                                        <span class="n">hidden_layer_sizes</span><span class="o">=</span><span class="p">[</span><span class="n">N_GEOMETRIC_NEURONS</span><span class="p">],</span>
                                        <span class="n">init_axis_angle</span><span class="o">=</span><span class="n">init_axis_angle</span><span class="p">,</span>
                                        <span class="n">transformed_parameters</span><span class="o">=</span><span class="n">transformed_parameters</span><span class="p">,</span>
                                        <span class="n">print_hidden_layer_output</span><span class="o">=</span><span class="kc">False</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="n">steerable_model</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;total number of trainable parameters:&#39;</span><span class="p">,</span> \
      <span class="nb">sum</span><span class="p">([</span><span class="n">np</span><span class="o">.</span><span class="n">prod</span><span class="p">(</span><span class="n">p</span><span class="o">.</span><span class="n">size</span><span class="p">())</span> <span class="k">for</span> <span class="n">p</span> <span class="ow">in</span> <span class="nb">filter</span><span class="p">(</span><span class="k">lambda</span> <span class="n">p</span><span class="p">:</span> <span class="n">p</span><span class="o">.</span><span class="n">requires_grad</span><span class="p">,</span> <span class="n">steerable_model</span><span class="o">.</span><span class="n">parameters</span><span class="p">())]))</span>

<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">init_axis_angle:</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">init_axis_angle</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">steerable_model.axis_angle:</span><span class="se">\n</span><span class="s1">&#39;</span><span class="p">,</span> <span class="n">steerable_model</span><span class="o">.</span><span class="n">axis_angle</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>SteerableModel(
  (hidden_layers): ModuleList(
    (0): Linear(in_features=80, out_features=5, bias=False)
  )
  (out_layer): Linear(in_features=7, out_features=8, bias=False)
)
total number of trainable parameters: 3

init_axis_angle:
 [-0.9549 -0.4905  1.5045]

steerable_model.axis_angle:
 Parameter containing:
tensor([-0.9549, -0.4905,  1.5045], device=&#39;cuda:0&#39;, dtype=torch.float64,
       requires_grad=True)
</pre>
</div>
</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h2 id="Paper-experiments">Paper experiments<a class="anchor-link" href="#Paper-experiments">&#182;</a></h2>
</div>
</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h4 id="Get-the-ancestor-MLGP-activations">Get the ancestor MLGP activations<a class="anchor-link" href="#Get-the-ancestor-MLGP-activations">&#182;</a></h4><p>(used in the experiments further down)</p>

</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[12]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">activation</span> <span class="o">=</span> <span class="p">{}</span>
<span class="k">def</span> <span class="nf">get_activation</span><span class="p">(</span><span class="n">name</span><span class="p">):</span>
    <span class="k">def</span> <span class="nf">hook</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="nb">input</span><span class="p">,</span> <span class="n">output</span><span class="p">):</span>
        <span class="n">activation</span><span class="p">[</span><span class="n">name</span><span class="p">]</span> <span class="o">=</span> <span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span>
    <span class="k">return</span> <span class="n">hook</span>

<span class="n">model</span><span class="o">.</span><span class="n">hidden_layers</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">register_forward_hook</span><span class="p">(</span><span class="n">get_activation</span><span class="p">(</span><span class="s1">&#39;hidden_layer&#39;</span><span class="p">))</span>
<span class="n">output</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">Xtrain</span><span class="p">)</span>

<span class="c1"># the ground truth hidden activations -- the ancestor MLGP hidden layer output:</span>
<span class="n">gt_hidden_activations</span> <span class="o">=</span> <span class="n">activation</span><span class="p">[</span><span class="s1">&#39;hidden_layer&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>

<span class="c1"># the ground truth output activations -- the ancestor MLGP model output: </span>
<span class="n">gt_outs</span> <span class="o">=</span> <span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>

<span class="c1"># gt_hidden_activations, gt_outs</span>
</pre></div>

     </div>
</div>
</div>
</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h3 id="The-known-rotation-experiment-(Section-5.3)">The known rotation experiment (Section 5.3)<a class="anchor-link" href="#The-known-rotation-experiment-(Section-5.3)">&#182;</a></h3>
</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[13]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>
<span class="n">torch</span><span class="o">.</span><span class="n">manual_seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>

<span class="n">n_trials</span> <span class="o">=</span> <span class="mi">1000</span>

<span class="c1"># the parameter of additive uniform noise to apply to the rotated shapes:</span>
<span class="n">distortions</span> <span class="o">=</span> <span class="p">[</span><span class="mf">0.0</span><span class="p">,</span> <span class="mf">0.05</span><span class="p">,</span> <span class="mf">0.1</span><span class="p">,</span> <span class="mf">0.2</span><span class="p">,</span> <span class="mf">0.3</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">]</span>


<span class="n">init_axis_angles</span> <span class="o">=</span> <span class="p">[]</span>
<span class="n">accs</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>          <span class="c1"># classification accuracies for the perturbed rotated shapes</span>
<span class="n">dists</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>         <span class="c1"># L1 distances to the ground truth hidden activations</span>

<span class="c1"># the same for the ancestor:</span>
<span class="n">ancestor_accs</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span> 
<span class="n">ancestor_dists</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>


<span class="k">for</span> <span class="n">distortion</span> <span class="ow">in</span> <span class="n">distortions</span><span class="p">:</span>
    <span class="n">accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span> <span class="o">=</span> <span class="p">[]</span>  
    <span class="n">dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span> <span class="o">=</span> <span class="p">[]</span> 
    <span class="n">ancestor_accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span> <span class="o">=</span> <span class="p">[]</span> 
    <span class="n">ancestor_dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span> <span class="o">=</span> <span class="p">[]</span> 
    
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">distortion:&#39;</span><span class="p">,</span> <span class="n">distortion</span><span class="p">)</span>
    
    <span class="k">for</span> <span class="n">n</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_trials</span><span class="p">):</span>       
        <span class="c1"># construct a random ground truth rotation:</span>
        <span class="n">init_axis_angle</span> <span class="o">=</span> <span class="n">random_axis_angle</span><span class="p">()</span>
        <span class="n">init_axis_angles</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_axis_angle</span><span class="p">)</span>
        <span class="n">gt_rotation</span> <span class="o">=</span> <span class="n">torch_rotation_matrix</span><span class="p">(</span><span class="n">init_axis_angle</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span><span class="o">.</span><span class="n">float</span><span class="p">()</span>

        <span class="c1"># rotate the shapes with the ground truth:</span>
        <span class="n">test_data</span> <span class="o">=</span> <span class="n">Xtrain</span><span class="o">.</span><span class="n">reshape</span><span class="p">(</span><span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">3</span><span class="p">)</span> <span class="o">@</span> <span class="n">gt_rotation</span><span class="o">.</span><span class="n">T</span>
        <span class="n">test_data</span> <span class="o">=</span> <span class="n">test_data</span><span class="o">.</span><span class="n">reshape</span><span class="p">(</span><span class="n">Xtrain</span><span class="o">.</span><span class="n">shape</span><span class="p">)</span>
        <span class="n">test_label</span> <span class="o">=</span> <span class="n">Ytrain</span>

        <span class="c1"># add uniform noise to the transformed shapes:</span>
        <span class="n">noise</span> <span class="o">=</span> <span class="n">distortion</span> <span class="o">*</span> <span class="p">(</span><span class="mi">2</span> <span class="o">*</span> <span class="n">torch</span><span class="o">.</span><span class="n">rand</span><span class="p">(</span><span class="n">test_data</span><span class="o">.</span><span class="n">shape</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span> <span class="o">-</span> <span class="mi">1</span><span class="p">)</span>
        <span class="n">test_data</span> <span class="o">+=</span> <span class="n">noise</span>

        <span class="c1"># construct the steerable model with the initial axis-angle parameters:</span>
        <span class="n">steerable_model</span> <span class="o">=</span> <span class="n">build_steerable_model</span><span class="p">(</span><span class="n">input_shape</span><span class="o">=</span><span class="n">test_data</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">1</span><span class="p">:],</span> 
                                                <span class="n">output_dim</span><span class="o">=</span><span class="n">OUTPUT_DIM</span><span class="p">,</span>
                                                <span class="n">hidden_layer_sizes</span><span class="o">=</span><span class="p">[</span><span class="n">N_GEOMETRIC_NEURONS</span><span class="p">],</span>
                                                <span class="n">init_axis_angle</span><span class="o">=</span><span class="n">init_axis_angle</span><span class="p">,</span>
                                                <span class="n">transformed_parameters</span><span class="o">=</span><span class="n">transformed_parameters</span><span class="p">,</span>
                                                <span class="n">print_hidden_layer_output</span><span class="o">=</span><span class="kc">False</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>

        <span class="c1"># get the model output:</span>
        <span class="n">output</span> <span class="o">=</span> <span class="n">steerable_model</span><span class="p">(</span><span class="n">test_data</span><span class="p">)</span>
        <span class="n">ancestor_output</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">test_data</span><span class="p">)</span>
        
        <span class="c1"># compute the model accuracy for the perturbed rotated shapes:</span>
        <span class="n">acc</span> <span class="o">=</span> <span class="n">score</span><span class="p">(</span><span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">test_label</span><span class="p">)</span>
        <span class="n">accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">acc</span><span class="p">)</span>
        
        <span class="n">ancestor_acc</span> <span class="o">=</span> <span class="n">score</span><span class="p">(</span><span class="n">ancestor_output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">test_label</span><span class="p">)</span>
        <span class="n">ancestor_accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">ancestor_acc</span><span class="p">)</span>
        
        <span class="c1"># compute the L1 distance between the hidden activations:</span>
        <span class="n">hidden_activations</span> <span class="o">=</span> <span class="n">steerable_model</span><span class="o">.</span><span class="n">hidden_layer_activations</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>
        <span class="n">dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">linalg</span><span class="o">.</span><span class="n">norm</span><span class="p">(</span><span class="n">hidden_activations</span> <span class="o">-</span> <span class="n">gt_hidden_activations</span><span class="p">,</span> <span class="nb">ord</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">axis</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">dist</span><span class="p">)</span>
        <span class="n">dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">dist</span><span class="p">)</span>
        
        <span class="n">ancestor_hidden_activations</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">hidden_layer_activations</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>
        <span class="n">ancestor_dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">linalg</span><span class="o">.</span><span class="n">norm</span><span class="p">(</span><span class="n">ancestor_hidden_activations</span> <span class="o">-</span> <span class="n">gt_hidden_activations</span><span class="p">,</span> <span class="nb">ord</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">axis</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">ancestor_dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">ancestor_dist</span><span class="p">)</span>
        <span class="n">ancestor_dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">ancestor_dist</span><span class="p">)</span>

        <span class="c1"># if n % 10 == 0:</span>
            <span class="c1"># print(&#39;\nexperiment #%d/%d&#39; % (n+1, n_trials))</span>
            <span class="c1"># print(&#39;\nadditive_uniform_noise:\n&#39;, noise)</span>
            <span class="c1"># print(&#39;\ngt_rotation:\n&#39;, gt_rotation)</span>
            <span class="c1"># print(&#39;\nacc:  %.3f&#39; % acc)</span>
            
    <span class="nb">print</span><span class="p">()</span>
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;ancestor_acc:     </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">ancestor_accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">ancestor_accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">])))</span>
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;acc:              </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">accs</span><span class="p">[</span><span class="n">distortion</span><span class="p">])))</span>
    <span class="nb">print</span><span class="p">()</span>
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;ancestor L1 dist: </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">ancestor_dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">ancestor_dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">])))</span>
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;L1 dist:          </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">dists</span><span class="p">[</span><span class="n">distortion</span><span class="p">])))</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">end</span><span class="o">=</span><span class="s1">&#39;</span><span class="se">\n\n</span><span class="s1">&#39;</span><span class="p">)</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
distortion: 0.0

ancestor_acc:     0.4728 +/- 0.3403
acc:              1.0000 +/- 0.0000

ancestor L1 dist: 8.1021 +/- 4.1254
L1 dist:          0.0000 +/- 0.0000



distortion: 0.05

ancestor_acc:     0.4761 +/- 0.3424
acc:              1.0000 +/- 0.0000

ancestor L1 dist: 8.0639 +/- 4.0796
L1 dist:          0.3319 +/- 0.0472



distortion: 0.1

ancestor_acc:     0.4928 +/- 0.3501
acc:              1.0000 +/- 0.0000

ancestor L1 dist: 7.9400 +/- 3.9921
L1 dist:          0.6625 +/- 0.0953



distortion: 0.2

ancestor_acc:     0.4595 +/- 0.3439
acc:              0.9999 +/- 0.0040

ancestor L1 dist: 8.3054 +/- 3.8510
L1 dist:          1.3219 +/- 0.1936



distortion: 0.3

ancestor_acc:     0.4756 +/- 0.3439
acc:              0.9971 +/- 0.0187

ancestor L1 dist: 8.2549 +/- 3.7809
L1 dist:          2.0030 +/- 0.3098



distortion: 0.5

ancestor_acc:     0.4445 +/- 0.3193
acc:              0.9491 +/- 0.0772

ancestor L1 dist: 8.6461 +/- 3.4424
L1 dist:          3.3332 +/- 0.4837


</pre>
</div>
</div>

</div>

</div>

</div>
<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
<h3 id="The-adaptive-rotation-experiment-(Section-5.4)">The adaptive rotation experiment (Section 5.4)<a class="anchor-link" href="#The-adaptive-rotation-experiment-(Section-5.4)">&#182;</a></h3>
</div>
</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
<div class="jp-Cell-inputWrapper">
<div class="jp-InputArea jp-Cell-inputArea">
<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[14]:</div>
<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
     <div class="CodeMirror cm-s-jupyter">
<div class=" highlight hl-ipython3"><pre><span></span><span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>
<span class="n">torch</span><span class="o">.</span><span class="n">manual_seed</span><span class="p">(</span><span class="n">SEED</span><span class="p">)</span>


<span class="n">n_trials</span> <span class="o">=</span> <span class="mi">1000</span>
<span class="n">epochs</span> <span class="o">=</span> <span class="mi">300</span>

<span class="c1"># print_period = 50 # for online optimization</span>


<span class="c1"># distortion rotation angle parameters (in degrees): </span>
<span class="n">distortion_std</span> <span class="o">=</span> <span class="mi">10</span>
<span class="n">distortion_means</span> <span class="o">=</span> <span class="p">[</span><span class="mi">0</span><span class="p">,</span> <span class="mi">5</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">15</span><span class="p">,</span> <span class="mi">30</span><span class="p">]</span>


<span class="n">all_results</span> <span class="o">=</span> <span class="nb">dict</span><span class="p">()</span>

<span class="k">for</span> <span class="n">distortion_mean</span> <span class="ow">in</span> <span class="n">distortion_means</span><span class="p">:</span>
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n\n\n</span><span class="s1">distortion = </span><span class="si">%d</span><span class="s1"> +/- </span><span class="si">%d</span><span class="s1"> degrees&#39;</span> <span class="o">%</span> <span class="p">(</span><span class="n">distortion_mean</span><span class="p">,</span> <span class="n">distortion_std</span><span class="p">))</span>
    
    <span class="n">gt_axis_angles</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">init_axis_angles</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">gt_labels</span> <span class="o">=</span> <span class="p">[]</span>
    
    <span class="n">init_outputs</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">init_predictions</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">init_losses</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">init_accs</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">init_dists</span> <span class="o">=</span> <span class="p">[]</span>

    <span class="n">final_outputs</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">final_predictions</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">final_losses</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">final_accs</span> <span class="o">=</span> <span class="p">[]</span>
    <span class="n">final_dists</span> <span class="o">=</span> <span class="p">[]</span>
    
    <span class="n">optimized_axis_angles</span> <span class="o">=</span> <span class="p">[]</span>
    
    
    <span class="k">for</span> <span class="n">n</span> <span class="ow">in</span> <span class="n">tqdm</span><span class="p">(</span><span class="nb">range</span><span class="p">(</span><span class="n">n_trials</span><span class="p">)):</span>
        
        <span class="c1"># 1) Randomly transform the train data:</span>
        <span class="n">gt_axis_angle</span> <span class="o">=</span> <span class="n">random_axis_angle</span><span class="p">()</span>
        <span class="n">gt_axis_angles</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">gt_axis_angle</span><span class="p">)</span>
        <span class="n">gt_rotation</span> <span class="o">=</span> <span class="n">torch_rotation_matrix</span><span class="p">(</span><span class="n">gt_axis_angle</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span><span class="o">.</span><span class="n">float</span><span class="p">()</span>
        <span class="c1"># print(&#39;\ngt_rotation:\n&#39;, gt_rotation)</span>

        <span class="c1"># select a sample:</span>
        <span class="n">shape_label</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">choice</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">Xtrain</span><span class="p">))</span>
        <span class="c1"># print(&#39;\nshape_label:&#39;, shape_label)</span>
        <span class="n">gt_labels</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">shape_label</span><span class="p">)</span>
        <span class="n">test_data</span> <span class="o">=</span> <span class="n">Xtrain</span><span class="o">.</span><span class="n">reshape</span><span class="p">(</span><span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">3</span><span class="p">)</span> <span class="o">@</span> <span class="n">gt_rotation</span><span class="o">.</span><span class="n">T</span> 
        <span class="n">test_data</span> <span class="o">=</span> <span class="n">test_data</span><span class="o">.</span><span class="n">reshape</span><span class="p">(</span><span class="n">Xtrain</span><span class="o">.</span><span class="n">shape</span><span class="p">)[</span><span class="n">shape_label</span><span class="p">:</span><span class="n">shape_label</span><span class="o">+</span><span class="mi">1</span><span class="p">]</span>
        <span class="n">test_label</span> <span class="o">=</span> <span class="n">Ytrain</span><span class="p">[</span><span class="n">shape_label</span><span class="p">:</span><span class="n">shape_label</span><span class="o">+</span><span class="mi">1</span><span class="p">]</span>   
        

        <span class="c1"># 2) Initialize steerable model parameters with distorted ground truth axis-angle </span>
        <span class="c1"># create a &quot;distortion&quot; axis-angle:</span>
        <span class="n">distortion_angle</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">radians</span><span class="p">(</span><span class="n">distortion_std</span><span class="p">)</span><span class="o">*</span><span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">randn</span><span class="p">()</span> <span class="o">+</span> <span class="n">np</span><span class="o">.</span><span class="n">radians</span><span class="p">(</span><span class="n">distortion_mean</span><span class="p">)</span>
        <span class="c1"># print(&#39;\ndistortion_angle:&#39;, np.degrees(distortion_angle))</span>
        <span class="n">distortion_axis_angle</span> <span class="o">=</span> <span class="n">random_axis_angle</span><span class="p">(</span><span class="n">angle</span><span class="o">=</span><span class="n">distortion_angle</span><span class="p">)</span>
        <span class="n">distortion_matrix</span> <span class="o">=</span> <span class="n">torch_rotation_matrix</span><span class="p">(</span><span class="n">distortion_axis_angle</span><span class="p">)</span>

        <span class="c1"># by multiplying distortion_matrix with the gt_rotation matrix, </span>
        <span class="c1"># we can control the rotation angle randomness:</span>
        <span class="n">distorted_rotation</span> <span class="o">=</span>  <span class="n">distortion_matrix</span> <span class="o">@</span> <span class="n">gt_rotation</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span>   
        <span class="n">init_r</span> <span class="o">=</span> <span class="n">R</span><span class="o">.</span><span class="n">from_matrix</span><span class="p">(</span><span class="n">distorted_rotation</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">())</span>
        <span class="n">init_axis_angle</span> <span class="o">=</span> <span class="n">init_r</span><span class="o">.</span><span class="n">as_rotvec</span><span class="p">()</span>

        <span class="n">init_axis_angles</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_axis_angle</span><span class="p">)</span>

        <span class="c1"># construct the steerable model with init_axis_angle:</span>
        <span class="n">steerable_model</span> <span class="o">=</span> <span class="n">build_steerable_model</span><span class="p">(</span><span class="n">input_shape</span><span class="o">=</span><span class="n">test_data</span><span class="o">.</span><span class="n">shape</span><span class="p">[</span><span class="mi">1</span><span class="p">:],</span> 
                                                <span class="n">output_dim</span><span class="o">=</span><span class="n">OUTPUT_DIM</span><span class="p">,</span>
                                                <span class="n">hidden_layer_sizes</span><span class="o">=</span><span class="p">[</span><span class="n">N_GEOMETRIC_NEURONS</span><span class="p">],</span>
                                                <span class="n">init_axis_angle</span><span class="o">=</span><span class="n">init_axis_angle</span><span class="p">,</span>
                                                <span class="n">transformed_parameters</span><span class="o">=</span><span class="n">transformed_parameters</span><span class="p">,</span>
                                                <span class="n">print_hidden_layer_output</span><span class="o">=</span><span class="kc">False</span><span class="p">)</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
        
        
        <span class="c1"># get initial model output, hidden_activations, acc and loss:</span>
        <span class="n">output</span> <span class="o">=</span> <span class="n">steerable_model</span><span class="p">(</span><span class="n">test_data</span><span class="p">)</span>
        <span class="n">init_output</span> <span class="o">=</span> <span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>
        <span class="n">init_outputs</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_output</span><span class="p">)</span>
    
        <span class="n">init_dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">linalg</span><span class="o">.</span><span class="n">norm</span><span class="p">(</span><span class="n">softmax</span><span class="p">(</span><span class="n">init_output</span><span class="p">)</span> <span class="o">-</span> <span class="n">softmax</span><span class="p">(</span><span class="n">gt_outs</span><span class="p">[</span><span class="n">shape_label</span><span class="p">]),</span> <span class="nb">ord</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">init_dists</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_dist</span><span class="p">)</span>

        <span class="n">init_acc</span> <span class="o">=</span> <span class="n">score</span><span class="p">(</span><span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">test_label</span><span class="p">)</span>
        <span class="n">init_accs</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_acc</span><span class="p">)</span>
        
        <span class="n">init_loss</span> <span class="o">=</span> <span class="n">entropy</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">is_logits</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span><span class="o">.</span><span class="n">item</span><span class="p">()</span>
        <span class="n">init_losses</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_loss</span><span class="p">)</span>

        <span class="c1"># print(&#39;\ninit_acc:  %.3f&#39; % init_acc)</span>

        <span class="c1"># collect the initial predictions:</span>
        <span class="n">init_prediction</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">argmax</span><span class="p">(</span><span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">axis</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">init_predictions</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">init_prediction</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">())</span>
        <span class="c1"># print(&#39;initial prediction:&#39;, init_prediction.cpu().numpy())</span>
        <span class="c1"># print()</span>


        <span class="c1"># 3) Otimize the entropy loss wrt the axis-angle parameters of the steerable model:</span>
        <span class="n">optimizer</span> <span class="o">=</span> <span class="n">optim</span><span class="o">.</span><span class="n">Adam</span><span class="p">(</span><span class="n">steerable_model</span><span class="o">.</span><span class="n">parameters</span><span class="p">(),</span> <span class="n">lr</span><span class="o">=</span><span class="mf">1e-2</span><span class="p">)</span>

        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">epochs</span><span class="p">):</span>          
            <span class="c1"># compute the entropy loss:</span>
            <span class="n">output</span> <span class="o">=</span> <span class="n">steerable_model</span><span class="p">(</span><span class="n">test_data</span><span class="p">)</span>
            <span class="n">loss</span> <span class="o">=</span> <span class="n">entropy</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">is_logits</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>

            <span class="c1"># backpropagate:</span>
            <span class="n">optimizer</span><span class="o">.</span><span class="n">zero_grad</span><span class="p">()</span>
            <span class="n">loss</span><span class="o">.</span><span class="n">backward</span><span class="p">()</span>
            <span class="n">optimizer</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>        

            <span class="c1"># if i % print_period == 0:</span>
            <span class="c1">#    print(&#39;epoch: %d,  loss: %.3f&#39; % (i, loss.item())) </span>

                
        <span class="c1"># store the final data:                </span>
        <span class="n">final_losses</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">())</span>
        <span class="n">final_output</span> <span class="o">=</span> <span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>
        <span class="n">final_outputs</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">final_output</span><span class="p">)</span>
        
        <span class="n">final_dist</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">linalg</span><span class="o">.</span><span class="n">norm</span><span class="p">(</span><span class="n">softmax</span><span class="p">(</span><span class="n">final_output</span><span class="p">)</span> <span class="o">-</span> <span class="n">softmax</span><span class="p">(</span><span class="n">gt_outs</span><span class="p">[</span><span class="n">shape_label</span><span class="p">]),</span> <span class="nb">ord</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">final_dists</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">final_dist</span><span class="p">)</span>

        <span class="n">final_acc</span> <span class="o">=</span> <span class="n">score</span><span class="p">(</span><span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">test_label</span><span class="p">)</span>
        <span class="n">final_accs</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">final_acc</span><span class="p">)</span>

        <span class="n">final_prediction</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">argmax</span><span class="p">(</span><span class="n">output</span><span class="o">.</span><span class="n">detach</span><span class="p">(),</span> <span class="n">axis</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
        <span class="n">final_predictions</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">final_prediction</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">())</span>
        
        <span class="n">optimized_axis_angle</span> <span class="o">=</span> <span class="n">steerable_model</span><span class="o">.</span><span class="n">axis_angle</span><span class="o">.</span><span class="n">detach</span><span class="p">()</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span>
        <span class="n">optimized_axis_angles</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">optimized_axis_angle</span><span class="p">)</span>

        <span class="c1"># print(&#39;epoch: %d,  loss: %.3f&#39; % (i, loss.item()))  </span>
        <span class="c1"># print(&#39;\nfinal_acc: %.3f&#39; % final_acc)</span>
        <span class="c1"># print(&#39;final prediction:&#39;, final_prediction.cpu().numpy()) </span>
        <span class="c1"># print(&#39;\ngt_axis_angle:\n&#39;, gt_axis_angle)</span>
        <span class="c1"># print(&#39;\ninit_axis_angle:\n&#39;, init_axis_angle)</span>
        <span class="c1"># print(&#39;optimized_axis_angle:\n&#39;, optimized_axis_angle) </span>
        
        
        
    <span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span>        
        <span class="s1">&#39;gt_axis_angles&#39;</span><span class="p">:</span> <span class="n">gt_axis_angles</span><span class="p">,</span>
        <span class="s1">&#39;gt_labels&#39;</span><span class="p">:</span> <span class="n">gt_labels</span><span class="p">,</span>

        <span class="s1">&#39;init_axis_angles&#39;</span><span class="p">:</span> <span class="n">init_axis_angles</span><span class="p">,</span>
        <span class="s1">&#39;init_outputs&#39;</span><span class="p">:</span> <span class="n">init_outputs</span><span class="p">,</span>
        <span class="s1">&#39;init_predictions&#39;</span><span class="p">:</span> <span class="n">init_predictions</span><span class="p">,</span>
        <span class="s1">&#39;init_losses&#39;</span><span class="p">:</span> <span class="n">init_losses</span><span class="p">,</span>
        <span class="s1">&#39;init_accs&#39;</span><span class="p">:</span> <span class="n">init_accs</span><span class="p">,</span>
        <span class="s1">&#39;init_dists&#39;</span><span class="p">:</span> <span class="n">init_dists</span><span class="p">,</span>
        
        <span class="s1">&#39;final_outputs&#39;</span><span class="p">:</span> <span class="n">final_outputs</span><span class="p">,</span>
        <span class="s1">&#39;final_predictions&#39;</span><span class="p">:</span> <span class="n">final_predictions</span><span class="p">,</span>
        <span class="s1">&#39;final_losses&#39;</span><span class="p">:</span> <span class="n">final_losses</span><span class="p">,</span>
        <span class="s1">&#39;final_accs&#39;</span><span class="p">:</span> <span class="n">final_accs</span><span class="p">,</span>
        <span class="s1">&#39;final_dists&#39;</span><span class="p">:</span> <span class="n">final_dists</span><span class="p">,</span>
        
        <span class="s1">&#39;optimized_axis_angles&#39;</span><span class="p">:</span> <span class="n">optimized_axis_angles</span><span class="p">,</span>
    <span class="p">}</span>
    
    
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">mean_init_acc: </span><span class="si">%.4f</span><span class="s1">, mean_final_acc: </span><span class="si">%.4f</span><span class="s1">&#39;</span> 
          <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;init_accs&#39;</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;final_accs&#39;</span><span class="p">])))</span>
    
    <span class="nb">print</span><span class="p">(</span><span class="s1">&#39;</span><span class="se">\n</span><span class="s1">mean_init_dist: </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">, mean_final_dist: </span><span class="si">%.4f</span><span class="s1"> +/- </span><span class="si">%.4f</span><span class="s1">&#39;</span>  
          <span class="o">%</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;init_dists&#39;</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;init_dists&#39;</span><span class="p">]),</span> 
             <span class="n">np</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;final_dists&#39;</span><span class="p">]),</span> <span class="n">np</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">all_results</span><span class="p">[</span><span class="n">distortion_mean</span><span class="p">][</span><span class="s1">&#39;final_dists&#39;</span><span class="p">])))</span>
</pre></div>

     </div>
</div>
</div>
</div>

<div class="jp-Cell-outputWrapper">


<div class="jp-OutputArea jp-Cell-outputArea">

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>


distortion = 0 +/- 10 degrees
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [51:10&lt;00:00,  3.07s/it]
  0%|                                                                                                                                             | 0/1000 [00:00&lt;?, ?it/s]</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
mean_init_acc: 0.9990, mean_final_acc: 0.9990

mean_init_dist: 0.0072 +/- 0.0328, mean_final_dist: 0.0065 +/- 0.0313



distortion = 5 +/- 10 degrees
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>100%|████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [1:04:02&lt;00:00,  3.84s/it]
  0%|                                                                                                                                             | 0/1000 [00:00&lt;?, ?it/s]</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
mean_init_acc: 0.9980, mean_final_acc: 0.9990

mean_init_dist: 0.0092 +/- 0.0376, mean_final_dist: 0.0066 +/- 0.0315



distortion = 10 +/- 10 degrees
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [53:55&lt;00:00,  3.24s/it]
  0%|                                                                                                                                             | 0/1000 [00:00&lt;?, ?it/s]</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
mean_init_acc: 0.9980, mean_final_acc: 0.9980

mean_init_dist: 0.0133 +/- 0.0459, mean_final_dist: 0.0074 +/- 0.0441



distortion = 15 +/- 10 degrees
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [59:23&lt;00:00,  3.56s/it]
  0%|                                                                                                                                             | 0/1000 [00:00&lt;?, ?it/s]</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
mean_init_acc: 0.9920, mean_final_acc: 0.9930

mean_init_dist: 0.0250 +/- 0.0808, mean_final_dist: 0.0123 +/- 0.0822



distortion = 30 +/- 10 degrees
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 1000/1000 [54:45&lt;00:00,  3.29s/it]</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
<pre>
mean_init_acc: 0.9360, mean_final_acc: 0.9410

mean_init_dist: 0.1059 +/- 0.2049, mean_final_dist: 0.0635 +/- 0.2323
</pre>
</div>
</div>

<div class="jp-OutputArea-child">

    
    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>


<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
<pre>
</pre>
</div>
</div>

</div>

</div>

</div>
</body>







</html>
