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

<title>ToyCircle</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="Topological-regularization-of-circle-embedding">Topological regularization of circle embedding<a class="anchor-link" href="#Topological-regularization-of-circle-embedding">&#182;</a></h1><p>In this notebook, we show how a topological loss can be combined with a linear embedding procedure, as to regularize the embedding and better reflect the topological---in this case circular---prior.</p>
<p>We start by setting the working directory and importing the necessary libraries.</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;[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="c1"># Set working directory</span>
<span class="kn">import</span> <span class="nn">os</span>
<span class="n">os</span><span class="o">.</span><span class="n">chdir</span><span class="p">(</span><span class="s2">&quot;..&quot;</span><span class="p">)</span>

<span class="c1"># Handling arrays and data.frames</span>
<span class="kn">import</span> <span class="nn">pandas</span> <span class="k">as</span> <span class="nn">pd</span> 
<span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>

<span class="c1"># Pytorch compatible topology layer and losses</span>
<span class="kn">import</span> <span class="nn">torch</span>
<span class="kn">from</span> <span class="nn">topologylayer.nn</span> <span class="kn">import</span> <span class="n">AlphaLayer</span>
<span class="kn">from</span> <span class="nn">Code.losses</span> <span class="kn">import</span> <span class="n">DiagramLoss</span><span class="p">,</span> <span class="n">pca_loss</span><span class="p">,</span> <span class="n">ortho_loss</span>

<span class="c1"># Ordinary and topologically regularized PCA embedding</span>
<span class="kn">from</span> <span class="nn">Code.topembed</span> <span class="kn">import</span> <span class="n">PCA</span>

<span class="c1"># Plotting</span>
<span class="kn">import</span> <span class="nn">seaborn</span> <span class="k">as</span> <span class="nn">sns</span>
<span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>

<span class="c1"># Quantitative evaluation</span>
<span class="kn">from</span> <span class="nn">sklearn.svm</span> <span class="kn">import</span> <span class="n">SVR</span>
<span class="kn">from</span> <span class="nn">sklearn.multioutput</span> <span class="kn">import</span> <span class="n">MultiOutputRegressor</span>
<span class="kn">from</span> <span class="nn">Code.evaluation</span> <span class="kn">import</span> <span class="n">evaluate_embeddings</span>

<span class="c1"># Representative cycle analysis with alpha-filtrations</span>
<span class="kn">import</span> <span class="nn">networkx</span> <span class="k">as</span> <span class="nn">nx</span>
<span class="kn">import</span> <span class="nn">diode</span>
<span class="kn">import</span> <span class="nn">dionysus</span>

<span class="o">%</span><span class="k">matplotlib</span> inline
</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">
<h2 id="Construct-data-and-view-restriction-to-first-two-coordinates">Construct data and view restriction to first two coordinates<a class="anchor-link" href="#Construct-data-and-view-restriction-to-first-two-coordinates">&#182;</a></h2><p>We now construct a high-dimensional data set sampled from a circular model. The model occurs only in the first two dimensions, and the high-dimensionality of the data is directly caused by random noise.</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;[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="c1"># Seed for reproducibility</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="mi">420</span><span class="p">)</span>

<span class="c1"># Sample parameters</span>
<span class="n">npoints</span> <span class="o">=</span> <span class="mi">50</span> <span class="c1"># number of points</span>
<span class="n">ndim</span> <span class="o">=</span> <span class="mi">500</span> <span class="c1"># data dimensionality (with noise)</span>
<span class="n">sigma</span> <span class="o">=</span> <span class="mf">0.45</span> <span class="c1"># magnitude of noise per dimension</span>

<span class="c1"># Sample data</span>
<span class="n">t</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">uniform</span><span class="p">(</span><span class="n">low</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">high</span><span class="o">=</span><span class="mi">2</span> <span class="o">*</span> <span class="n">np</span><span class="o">.</span><span class="n">pi</span><span class="p">,</span> <span class="n">size</span><span class="o">=</span><span class="n">npoints</span><span class="p">)</span>
<span class="n">X</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">concatenate</span><span class="p">([</span><span class="n">np</span><span class="o">.</span><span class="n">transpose</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="n">np</span><span class="o">.</span><span class="n">cos</span><span class="p">(</span><span class="n">t</span><span class="p">),</span> <span class="n">np</span><span class="o">.</span><span class="n">sin</span><span class="p">(</span><span class="n">t</span><span class="p">)])),</span> <span class="n">np</span><span class="o">.</span><span class="n">zeros</span><span class="p">([</span><span class="n">npoints</span><span class="p">,</span> <span class="n">ndim</span> <span class="o">-</span> <span class="mi">2</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">N</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">uniform</span><span class="p">(</span><span class="n">low</span><span class="o">=-</span><span class="n">sigma</span><span class="p">,</span> <span class="n">high</span><span class="o">=</span><span class="n">sigma</span><span class="p">,</span> <span class="n">size</span><span class="o">=</span><span class="p">[</span><span class="n">npoints</span><span class="p">,</span> <span class="n">ndim</span><span class="p">])</span>
<span class="n">data</span> <span class="o">=</span> <span class="n">X</span> <span class="o">+</span> <span class="n">N</span>

<span class="c1"># Plot the first two dimensions of the data two illustrate the circular model</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">()</span>
<span class="n">sns</span><span class="o">.</span><span class="n">scatterplot</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">data</span><span class="p">[:,</span><span class="mi">0</span><span class="p">],</span> <span class="n">y</span><span class="o">=</span><span class="n">data</span><span class="p">[:,</span><span class="mi">1</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">50</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="n">t</span><span class="p">,</span> <span class="n">palette</span><span class="o">=</span><span class="s2">&quot;husl&quot;</span><span class="p">,</span> <span class="n">ax</span><span class="o">=</span><span class="n">ax</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">remove</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-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">
<h2 id="Conduct-ordinary-PCA-embedding">Conduct ordinary PCA embedding<a class="anchor-link" href="#Conduct-ordinary-PCA-embedding">&#182;</a></h2><p>We now explore how well the ordinary PCA embedding is able to recover the model from our data.</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;[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="c1"># Conduct PCA embedding</span>
<span class="n">Y_pca</span><span class="p">,</span> <span class="n">W_pca</span> <span class="o">=</span> <span class="n">PCA</span><span class="p">(</span><span class="n">data</span><span class="p">,</span> <span class="n">random_state</span><span class="o">=</span><span class="mi">42</span><span class="p">)</span>

<span class="c1"># View PCA embedding (flip for consistency)</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">()</span>
<span class="n">sns</span><span class="o">.</span><span class="n">scatterplot</span><span class="p">(</span><span class="n">x</span><span class="o">=-</span><span class="n">Y_pca</span><span class="p">[:,</span><span class="mi">0</span><span class="p">],</span> <span class="n">y</span><span class="o">=</span><span class="n">Y_pca</span><span class="p">[:,</span><span class="mi">1</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">50</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="n">t</span><span class="p">,</span> <span class="n">palette</span><span class="o">=</span><span class="s2">&quot;husl&quot;</span><span class="p">,</span> <span class="n">ax</span><span class="o">=</span><span class="n">ax</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">remove</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>Time for embedding: 00:00:00
</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>We see that due to the noise in high dimensions, while the overall ordering points is good, PCA is no longer able to effectively recover the circular hole.</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">
<h2 id="Apply-topological-regularization-to-the-embedding">Apply topological regularization to the embedding<a class="anchor-link" href="#Apply-topological-regularization-to-the-embedding">&#182;</a></h2><p>We now show how we can bias a linear embedding using a loss function that captures our topological prior.</p>
<p>The model we will use for this learns a linear transformation $W$, which is optimized for the following three losses:</p>
<ul>
<li>the reconstruction loss between our data and its $X$ low-rank approximation $XWW^T$;</li>
<li>a loss function encouraging orthonormality of $W$, i.e., such that  $WW^T$ is a projection matrix;</li>
<li>a loss function that captures our topological prior.</li>
</ul>
<p>As a topological loss, we will use the persistence of the most prominent cycle in our embedding. It is important to multiply this by a factor $\lambda_{\mathrm{top}} &lt;0$, since we want this persistence to be high. To obtain this loss, we require an additional layer that constructs the alpha complex from the embedding, from which subsequently persistent homology is computed.</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;[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="c1"># Define topological loss</span>
<span class="k">def</span> <span class="nf">g</span><span class="p">(</span><span class="n">p</span><span class="p">):</span> <span class="k">return</span> <span class="n">p</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span> <span class="o">-</span> <span class="n">p</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="c1"># function that returns the persistence d - b of a point (b, d)</span>
<span class="n">TopLayer</span> <span class="o">=</span> <span class="n">AlphaLayer</span><span class="p">(</span><span class="n">maxdim</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span> <span class="c1"># alpha complex layer</span>
<span class="n">CircularPersistence</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">j</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># compute persistence of most prominent cycle</span>
<span class="n">lambda_top</span> <span class="o">=</span> <span class="o">-</span><span class="mf">1e1</span> <span class="c1"># scalar factor that trades off embedding and topological loss</span>

<span class="c1"># Construct topological loss function</span>
<span class="k">def</span> <span class="nf">top_loss</span><span class="p">(</span><span class="n">output</span><span class="p">):</span>
    <span class="n">dgminfo</span> <span class="o">=</span> <span class="n">TopLayer</span><span class="p">(</span><span class="n">output</span><span class="p">)</span>
    <span class="n">loss</span> <span class="o">=</span> <span class="n">lambda_top</span> <span class="o">*</span> <span class="n">CircularPersistence</span><span class="p">(</span><span class="n">dgminfo</span><span class="p">)</span>
    
    <span class="k">return</span> <span class="n">loss</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">
<p>We can now conduct the topologically regularized linear embedding as follows.</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;[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="c1"># Learning hyperparameters</span>
<span class="n">num_epochs</span> <span class="o">=</span> <span class="mi">500</span>
<span class="n">learning_rate</span> <span class="o">=</span> <span class="mf">1e-1</span>

<span class="c1"># Conduct topological regularization</span>
<span class="n">Y_top</span><span class="p">,</span> <span class="n">W_top</span><span class="p">,</span> <span class="n">losses_top</span> <span class="o">=</span> <span class="n">PCA</span><span class="p">(</span><span class="n">data</span><span class="p">,</span> <span class="n">top_loss</span><span class="o">=</span><span class="n">top_loss</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="n">num_epochs</span><span class="p">,</span> 
                               <span class="n">learning_rate</span><span class="o">=</span><span class="n">learning_rate</span><span class="p">,</span> <span class="n">random_state</span><span class="o">=</span><span class="mi">42</span><span class="p">)</span>

<span class="c1"># View topologically regularized embedding (flip for consistency)</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">()</span>
<span class="n">sns</span><span class="o">.</span><span class="n">scatterplot</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">Y_top</span><span class="p">[:,</span><span class="mi">0</span><span class="p">],</span> <span class="n">y</span><span class="o">=-</span><span class="n">Y_top</span><span class="p">[:,</span><span class="mi">1</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">50</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="n">t</span><span class="p">,</span> <span class="n">palette</span><span class="o">=</span><span class="s2">&quot;husl&quot;</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">remove</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>[epoch 1] [emb. loss: 0.063185, ortho. loss: 0.001478, top. loss: -1.539055, total loss: -1.474392]
[epoch 50] [emb. loss: 0.067497, ortho. loss: 3410.821045, top. loss: -0.782473, total loss: 3410.105957]
[epoch 100] [emb. loss: 0.066744, ortho. loss: 1016.062500, top. loss: -3.505133, total loss: 1012.624146]
[epoch 150] [emb. loss: 0.066747, ortho. loss: 1201.616699, top. loss: -5.466840, total loss: 1196.216675]
[epoch 200] [emb. loss: 0.066591, ortho. loss: 555.281982, top. loss: -8.052293, total loss: 547.296265]
[epoch 250] [emb. loss: 0.067223, ortho. loss: 6603.874023, top. loss: -2.147141, total loss: 6601.794434]
[epoch 300] [emb. loss: 0.066911, ortho. loss: 1616.312256, top. loss: -5.034025, total loss: 1611.345093]
[epoch 350] [emb. loss: 0.066875, ortho. loss: 1885.948242, top. loss: -3.005395, total loss: 1883.009766]
[epoch 400] [emb. loss: 0.066544, ortho. loss: 377.594055, top. loss: -7.798023, total loss: 369.862579]
[epoch 450] [emb. loss: 0.066521, ortho. loss: 311.904297, top. loss: -6.428357, total loss: 305.542480]
[epoch 500] [emb. loss: 0.066493, ortho. loss: 310.406158, top. loss: -8.081623, total loss: 302.391022]
Time for embedding: 00:00:05
</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,iVBORw0KGgoAAAANSUhEUgAAAXwAAAD4CAYAAADvsV2wAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAuiUlEQVR4nO3deXhkV33n//f33lpVpdK+S70v7raNjbu923ilvTDQBDBeWBKGTP9IbOaX4ZeAZ4gzSSbJkPCEB3AMpkMMmEBYDAZDDMYLuI033O320m276d1SS619r1It957fH5LVrVapN5Vq/b6ex09L55brfkul+ujUuafOEWMMSimlip+V6wKUUkplhwa+UkqVCA18pZQqERr4SilVIjTwlVKqRHhyXcDx1NbWmiVLluS6DKWUKhjbtm3rM8bUpTuW14G/ZMkStm7dmusylFKqYIjIwbmO6ZCOUkqVCA18pZQqERr4SilVIjTwlVKqRGjgq5wzxpBKTVAq6zo5yRgTI10kxvtyXYoqMXk9S0cVv+Gh/ezf9zA9h7dS13Aey5a/i4rKZbkua8FE+/fQ/tw9DB54Gl+ojraL/pTKJZfhDVTkujRVAiSfe1Xr1683Oi2zeA0PH+DRX/xX4vGh6TafL8KGG+4rytCfGO5gxwN/RCo2OKN9xYa/p3bV9TmqShUbEdlmjFmf7pgO6aicaT/4+IywB0gkRji4/1e5KWiBRfv3zAp7gPbnvkoyOpCDilSp0cBXOeG6Dj3dL6Y91tOzHcdJZrmihZdME/aT7f24TiLL1ahSpIGvcsKybBqbL0p7rKn5Imzbm+WKFl6odlXa9uplV+EJVmW5GlWKNPBVzrS2XUGwrH5GWyBYS9uiq3NU0cLyVy6iZf0fz2jzheppWf9xbI8/R1WpUqIXbVVOjYy8Seehp+nueoH6xvW0tF5GJLIo12UtmFR8lInhdmKDB/AGKghWLcMfacp1WaqIHO+irQa+Uirj3IFOnEM7MT17sVrOxGpajVVRf+L/Uc3b8QJf5+ErpTLK7W9n4pu3YwYOTbdZi87Bf/M/YFU25rAypYFfolw3xehYJ2NjXdi2l/LyVkJl2gNT82OMIfXKIzPCHsB982Wc9h0a+DmmgV+CXDfFoc5neWLLZ3CcCQDC4WY2XPVlKovwA08qixJRnNd+nfaQ88YWvGdfm+WC1NF0lk4JGh07xBNbPj0d9gBjY50898LnSSTGc1iZKngeH1KfvtNgNaWflqqyRwO/BI2NdeE48VntnYefJxbrzUFFqliI7cV7yW1gHTN44A/jWXVpbopS0zTwS5B17IvxqHYRO8vVqGJjNa4gsOnfsFZdhlQ0YJ97A4FNX8eqX5rr0kqejuGXoPLyVsqCdUSP6c2vWvE+QqGGHFWlCoWbnCA5ehjjJPGEavGUzfyUsNhe7LazCNzyOUxiHAmUI179YFk+yEgPX0TuE5EeEdkxx3ERkS+LyB4ReUVEzsvEedXpCYca2XDNPdTVng2AiIfVK9/P2876I2zbl+PqVD5LjnZz+NefZ983P8j++2/h4Pc3Eet+Pe1txR/EKq/VsM8jGfnglYi8AxgD7jfGnJXm+I3AJ4EbgQuBLxljLjzR/eoHrxZWPD5CNNaHZXkIhxqwbX1hqrkZJ0X3U19mcNt3ZrRbgQhLP/RtfJWtOapMHW3BP3hljNkiIkuOc5ONTP4xMMBzIlIpIk3GmK5MnF+dHr8/gt8fyXUZqkAkx3oYevmBWe3uxAiJoQ4N/AKQrYu2LUD7Ud93TLUppQqFcTFzLFtt3FSWi1GnI1sXbSVNW9qxJBHZBGwCWLSoeBfRypSh6GH2927j1Td/RUPFcs5ZdAP1FcuwSnC2jeMkGRltZ3B4LyIWVRXLiJS3zTkrSZ0aO1RD+cqrGf39YzMPWB7t3ReIbL0SOoC2o75vBTrT3dAYsxnYDJNj+AtfWuEajvbwvWc/Q/vAqwDsOvwUz+z+Lpuuuo+W6rU5ri67jDF0Hn6eX/3mUxgz2du0LC/XXfVlWppOeLlInQTbG6TusttJDB4k3rsbAPEGaXnX/8VXoW/YC0G2Av8h4A4R+R6TF22Hdfx+/rpH9kyH/VtSboLHdt7LLRd/Dr+nLEeVZd/oeCe/fvqz02EP4LpJfvP0X7Lxhm8TDhXWGi4mPoEZ6MWMDSNlYaS6Hgnm/vn0Vy1i0fvvITF8CJOK44k04os0I1bpvaMsRBkJfBH5D+BKoFZEOoD/DXgBjDH3Ag8zOUNnDxAFPpaJ85a67uG9advbB15lIjFWUoEfjfaSSIzOao9N9BON9S1Y4JupcW0rgxuYmPFRUk/9AufXP4OpWXTW+nfguf4mrEjud8byhGrwhGpyXYY6DZmapXPrCY4b4PZMnEsdUR9J/8nF5srV+L2hLFeTW15PcI4jgmfOY6fPuA4TfXsZfPXHxPt2U77iaiLLr8jIWLbbeRDniYdmtm3dgrvyTKy36/IE6vTp0goFrLFiJU0Vq2e0WeLhnWfdTqDEAj8cbqat5fJZ7cuXXEc4lPkdpSZ6d7P/P/6QwZd/SPTQS3Q/+QUO/viTJIbTXpo6Jc72Z9K3P/s4JjF7DSSlTpZOXyhgFWUN3HbpP7P78NO88uYj1EWWcsGy99NQsTzXpWWd31fOJeffyWuRJby++wFELNauvpk1Kz+Az5vZoS0nOUHv8/+GcRIz2hNDbxLrfh1fRfO87l8C6d+RiD8Ion00dfo08AtcdaiZC5ffxLolG7EsD1YJB0J5uInz3/5JzjxjcoSxLFiHdZIXE2Oxfhwngd9fgfcEfyBMYpyJnvTLCUz0vkHFqmtOrfBj2OdegvPbR2a3X34d4vXO675VadPALxIeXQMHYGqZiJO/QBuPj3L48PNse/Fuxse7aG66hLefdzvVVSvnPoc/TLDpbSRHZk80CzaceVp1H00aW/F+5L+TfPCbMDYCgTI8N96C1VZ679xUZmngq5LW3bON3zz56envOw5toaf3Jd514/1EIuk/+Gd5/NRd8EeM7duCm4xNt/vrVxOoP2PeNYnPj332BVhtyzDRKAQCSGUtYpXuuzeVGRr4qmTF40Ns3/6VWe2JxAj9/a/NGfgA/tqVLL31W4z8/jFiPbuIrLiSUNt6fJHMTf+UylqkMmN3p5QGvipdjpMgFutLeyw6R/tbRIRA7XICtTrMogqHvkdUJcvvr2LxoqvTHqurnbXKt1IFTwNflSzb9rL2zI8QOmae/pozbqWiQrfjU8VHh3RUSauILOb6677O8PB+YrF+KiqXEilfpPsEqKKkga9KXjjcRDic+U/jKpVvdEhHKaVKhAa+UkqVCA18pZQqERr4SilVIjTwlVKqRGjgK6VUidBpmUqpk2JcFzPQhxkaAK8Xqa7FKq/IdVnqFGjgnwLHTZFMxfB6gtiW/uhU5hhjcIa7SI10I7YXT2Uzdqg612VNM04K9/c7Sf77vTC165Y0teL9yO1YdQ05rk6dLE2tk9Q7vJcX9zxAe9+LtNScw7oVN1FXsQIRyXVpqsAZY4i3b6f/R3+OGxsGwFu/kpo/+Ee8NYtzXN0k099L8lv3gJM60tbVQeqXP8J788cRX+Y2cVcLR8fwT0Lf8D7uf/xjbNvzfXqGdrN97wPc//jH6BvZl+vSVBFwhg7R94M/mw57gGTPbgYf/Wfc+HgOKzvCDPTOCPu3uK9uw4wMp/k/VD7SwD8Jb3Q8Tjw5NqMtkYry6oGfY4zJUVWqWKSGOjGJ2cEe3/c0zlhvDipKY66tIm0PWPou93hMPIGJJ058wyzQIZ0TMMbQ0fdy2mOd/Ttw3KRuL6jmZ67AFAvIjzCVmnoIhiA28w+TfdGVSKQqR1XlN3dkHLOnndSWF8ESPO9YhyxvxSo//p7JC0l7+CcgIqxsfkfaYyuaL89K2DtOisHRgxzqe5n+kf2knPzoLajM8FS0YqW5QBtcswE7kh8XRK2aOnyb/j+koXmqwcI6/3I8V1yHeLTfeCyTSOI88TuS3/5PzMEuzP5Okt/6Gc5vt2NSTs7q0mfqJCxruoTKUBtD4+3TbZGyRla1XLng555IjLHzwM/Z8vKXSDlxLMvDRWs+zttXfpCygPasioGnsom6m++m/6efJdV/AIDAyndQeeXtWN5Abos7itW6BO8nPg0jw+DxIlXViFff3aZjBoZxtmyf1e48/gL2ujVIfW5mYGngn4SqcCu3XnkP7b3bae/dTmvt21hUt46q8rYFP3fv0C6eePGfpr933RTP7PwaDdVnsKLligU/v8oOX+MZ1H/4X3FGexHbgx1pxPKHcl3WLFY4AmHdK+BETHQC0l3fcxyIxbNf0BQN/JNUFW6lKtzK25a+O6vn3bH/Z2nbX9z9fZY0XoTH1ulwxcIOVefV3Ht1+iRcBl4PJI+Z2eT3QSiYm6LQMXyllMo4qa7A857Z78A977sKqc7dp5O1h5/nzlr6bnbsf2hW+3krb9bevVJ5Sjw29ro1WC11OC/9HmwL+5xVSGMNksNprBr4ea6ucjVXn/fpWRdtm2veluvSlFLHIUE/srQFa2lLrkuZpoGf5wK+MOeu+ABLmy4mFh8i4KugItSsc/+VUqdMA78A2JaH6vLFUJ4f66oopQqTXrRVSqkSkZHAF5HrRWSXiOwRkTvTHL9SRIZF5KWp//4qE+dVSil18uY9pCMiNnAP8E6gA3hBRB4yxrx2zE2fMsb8l/meTyml1OnJRA//AmCPMWafMSYBfA/YmIH7VUoplUGZCPwWoP2o7zum2o51sYi8LCK/EJEz57ozEdkkIltFZGtvb54sDauUUkUgE4Gf7lMExy4i8SKw2BhzDnA38JO57swYs9kYs94Ys76uri4D5SmllILMBH4HcPQqYq1A59E3MMaMGGPGpr5+GPCKSG0Gzq2UUuokZSLwXwBWishSEfEBtwAz1gIQkUaZ2vxVRC6YOm9/Bs6tlFLqJM17lo4xJiUidwCPADZwnzFmp4h8Yur4vcAHgD8RkRQQA24xujegUiXJTcZBwPLoWlDZJvmcu+vXrzdbt27NdRlKqQxwxgeJd7zE2NbvgdiEz78Vf8vZ2GWVuS6tqIjINmPM+nTHdGkFpdSCc5MTjP7uO4w++43ptviB54lccTuRCz+CeLw5rK506NIKSqkF5wx3Mvrc/bPaR377r6SGD+WgotKkga+UWnBubARMms27nQTuxGj2CypRGvhKqQVnlVWBPXvYRrxBrGBl9gsqURr4SqkF56lopuLKO2a1V17zP/BUNuWgotKkF22VUgtOPF7C57wHX+Maxnf8HLE8lJ15I96GlYilMZQt+pNWSmWFFYgQWLyOwOJ1uS6lZOmQjlJKlQjt4atTlnQS9Iy3c3jsILblpSm8mIbwolyXpdQs7sAwpncQUimkphKprUQ8pRt7pfvI1WlJuUle7n6Ke164E3dqml3AE+LTl3yV5dVn5bg6tdBMIobpP4wZ6AJfEKu2Bamqz3VZabmdPSTu/QGMRScbLMHz4Xdjn7WiZENfh3TUKemLdvG1bXdNhz3ARGqcf33xrxieGMhhZWqhmUQMZ9tjJL/0J6Tu/xtSX7+TxL2fwu15M9elzWKiEyR/+MiRsAdwDanv/BzTP5y7wnJMA1+dkoHYYRLOxKz2rrEDjMR1AdRiZvq7cH7yL3D0+ltDvTiPfBMTn/07kUtmdBxzsGv2AcfFDGrgK3VS/HYwbbstHry2L8vVqGwyvR1p292dz2LGh7JbzInYFnjnGLbxlu66PRr46pTUhZpZUrlmVvtVS95HTVA/QFPU/GXp24NhxM6vMXGpjGBfdt7s9tpKrJrK7BeUJzTw1SmJ+Gu4ff3nuGzRe7DFQ8BTxntXb+Jdqz6mPfwiJ3WtEK6c1W5f+yGkIr82sBOPjecd67DfeTH4vJPr75+5Au8fvx+pLM91eTmj6+Gr05Jw4oxM9CNiURWswxI71yWpLHAPHyD1n5sxv98GwTD2NbdhnXs1VnlVrktLyzguZngUXBcpDyH+4u+U6Hr4KuN8tp/aUHOuy1BZZjUuwfuhv8SMDyO2DRV1TO1empfEtpDqilyXkTc08JVSp0QCZUhgjvF8ldd0DF8ppUqEBr5SSpUIDXyllCoRGvhKKVUiNPCVUqpEaOArpVSJ0MBXSqkSoYGvlFIlQgNfKaVKhAa+UkqVCA18pZQqERr4SilVInTxNKVU0TKOCyNJjIBV6c91OTmngX8aOsa76Ih24RiX1rJGWsqa8Fi6HrxS+cTtmyD15CGcZ7rBa+G5rg37vFqsitINfg38U7RjcBe3P38XY6lxAHyWly+s/ysurDsXS3SETKl84I4mSHzrDcyekem21A/2YoYTeP/LYsST2deqmUhiBsZwB8eRoA+pLceKpN//OZcy8qhF5HoR2SUie0TkzjTHRUS+PHX8FRGZvdlkAeibGOSz2z8/HfYACTfJnS9+jq5oTw4rU0odzfRNzAj7tziPd2AGJjJ7rmic1FNvEP/Hn5H82hMkvvhLEv/6a9z+0YyeJxPmHfgiYgP3ADcAa4FbRWTtMTe7AVg59d8m4KvzPW8u9MUH6Ih2zWofS43TPdGXg4pOTzQVZTgx+8WgVNGIO+nbUwYS7mnfrTuYwNk7hrNvHHc4OdnWM0LqZ9vhqN1izcE+nGf3YNzTP9dCyMSQzgXAHmPMPgAR+R6wEXjtqNtsBO43kxvoPicilSLSZIyZnZ55zGd5EQTD7H2A/QWwgfdYcpxXBl/jG3u+y2BimPe0Xce1TVfQXNaY69KUyiip9INHJgP+6Pa6AJSf3mvVOThO4iv7MIOTQS+Nfvy3L8fdm/7dfep3e7EvX41U5M/uYJkY0mkB2o/6vmOq7VRvA4CIbBKRrSKytbe3NwPlZU5TsI4NTZfPaj+zYiXNwYas1RFNjLK7bzsP7PgyP3tjMwcHXyfpxE/4//225znu+N2dbBt4hX1jB/ni65u5a/v/pT8+kIWqlcoeqQ3gvW3VzEavhfejq7EqTj3w3cEEiXuOhD2AORwn/p03kWD6+5OAFzJ8rWC+MtHDT7eD8bFd4JO5zWSjMZuBzQDr169Pe5tc6Yr1c2PrtfhsP7/s/DWO6/LO5sv4k9UfocqfnY2SE06cLQcf5IEdX5xue+j1zdx+0T9zbtMVc/5/PbE+vvDa12a1bx/cQft4JzX+6oUoV6mcEI+Fva4Wqy2E++YY+CyslhDScHq9bdOfwAwlZ7e/MYa8fwl4bUjOHEbyXPc2rFDgtM63UDIR+B1A21HftwKdp3GbvLZ/9BAff/qvGUmOc37NWj55xn/DK14uqjubtlBz1uroGz/Ej3fePaPN4PLt7X/PoorVVM8xPBNzJuiL96c9puP5qhiJz0Zaw1it4fnf2XE66sYXwHfHO0l+/zlM5xCU+fC861ysM5rmf94My0TgvwCsFJGlwCHgFuC2Y27zEHDH1Pj+hcDwQozfx1JJDo0Pc2h8hKDHS1u4gqaySEbu+7Gu5xlJTs7OeaH/NV7on7xE8d9WvY9PrL4pI+c4GcMTfbhm9gWp4XgfY4nhOQM/4g2zonwpe0b3zzpWH6zLeJ1KFROp9iF1PkxvYka7tTKEFfFhNdUjd2yA8Th4baQqhEi6gY3cmnfgG2NSInIH8AhgA/cZY3aKyCemjt8LPAzcCOwBosDH5nveY8VSSR5+8w3+6eUnp8eK6gIh/uXSjSyNzG+4wjEuLw28kfbYSwO7SLlO1j54FfKl/wPmt4MEPHO/Xa3yV/I/z/5/+cRzf0HSPfLW9Lal76e1LP96IkrlE6vSh/9PlxP/+n7MoclpndbyEL6PLsYKTcaoFQ5AOL+GcI6VkQ9eGWMeZjLUj26796ivDXB7Js41l47x4RlhD9A7Mc7dO5/h787fQJnn9GfR2GJxSd05PNf76qxjl9Sfm9VP2daWtXB+63W80PHIjPZ3n7GJmhME99mVa/n3y77Cs70v0Bcf5PL6C1lRvpRybwbe8ipV5KyWIP5PrZy8cCuTvf63wr5QFFa1x3FofDjtVeCnDx9gMB6bV+ADXN5wHt/d/wsOx46Mg9cHqrmyYf287vdUlfnK+eBZf8bq2nX8Zt8P8dkBrlv1UVbVrMO20j+d3dFxXunv4dedB1lSXsGG1utZVB7BysO3nErlM6vcC+XeXJdx2oom8IOe9E9C2OvHk4ElDxaFm7j34rt4vvdVtvW/xnnVa7io/mzaQtmfw14VbODKpR/g/JYNWGIT9IbmvG3fRJS/2foUW/sOT7d9+/c72HzFDaypqs1GuUqpPFE0gb8oXEltIETfxPiM9v+6ej31wcwMWbSFGmgLNfCBJddm5P7ma67x/KPtGxmaEfYAcdfh3p0v8g8XXknIm/8fGFNKZUZ+fSpgHprKItxz6UYua1yCABGvnz8761Kub1udl1fLs2X/yFDa9lcH+xhLzp5XrJQqXkXTwwdYGqnm787fwGA8hkcs6oPhkg57gLZw+ncBKyKVlHmL6ulXSp1A0b3iyzy+eV+gLSbLI1WsjFSxe2Rwus0W4fYz11HuLd11wZUqRUUX+GqmhrIQn7/4ap7qaudXHftpC0W4ecUaVkSqcl2aUirLNPBLQHOonJtXrGXjklV4LQvbKppLN0qpU6CBX0ICHn26lcp37rgDjkHCNmJl9hqkJoBSqiC4AwlMTwIz4WLVepE6H+Ivnr2k3bEU7q4YyZ/3Q8zFvjSC5+IIVm3mrklq4BeBpJOiI9pNV6yPgO2jtayB+qAud6yKh3s4TvxL+zF9U1OJBby3NuG5uAoJFH7oG2NwXhgl+Z0jm6mkftqPu2Mc3+0tWJHMRLUGfoFLOEl+c3grd22/h9TUKprNwTruvuhOloSzt2yzUgvFJBySD3UfCXsAA8nvdmGvCCFt+bdZ+KkyAymSP5m9Taq7dwLTk4QMBb5evStwHdFu/nL7v0yHPUBnrJcv7fwOsVRmN2tWKhfMqIPz4nDaY27XiXd6KwgJF8bT739ronPsz3saNPAL3KFoD46Z/YvyVM92+uLpXyRKFRRLoCx9D1cCRRJhIRtpTjNWL2BVZ24gpkh+WqXLZ6VfNC5g+7AzsGicUrlmVXnxvjvNJj1hG2kqjg8PWhEPvo80TG68fhTPe2qQ2sytzqlj+AWuLdRIta+CgcTM3vyHlr2LhmBNjqpSKrPsdZWQguTPuyHqYp0RwndzE1ZdcQQ+gLU8SOCuxTi7o5gxB3tNCKvJl9GL0jK5N0l+Wr9+vdm6dWuuy8h7u0cO8rlXvsFLg7vwW15uXXYDtyy9jrqAztRRxcMYM7n5SMog5R4kWPizcxaCiGwzxqTdqEN7+EVgZWQxX7zwL+iPD+MRm8ZgDZ45NkNRqlCJCFKt62TNh6ZCkSj3hij3hugcH+HxQ/t4Y6iXM6saOLO6gaay8lyXp5TKAxr4RaRjbJhPPv0Qh6Ij023Lyqv5wsU30hyqyGFlSql8oNM4isiTXftmhD3AvtEBXujtyFFFSql8ooFfJOJOii1d+9Mee7LzQHaLUUrlJQ38IuG1bFZVpJmrDKytqs9yNUqpfKSBXyQsETYuWYvfmjlVLeTxcnXL8hxVpZTKJ3rRtogsi1Tzb1e8n2/vfonXBrs5p6aJ21acw7KIzsdXSmngFxVLhFWVddx13lWMp5KEPD58tn44RSk1SQO/CPlsDz5bn1ql1Ew6hq+UUiVCu4EFLuW6dEVH6Y6NEbQ9NJdFqAoU/oYQSqnM08AvYEnH4Znudu7a+jgTTgqAtZX1/N3519AajuS4OqVUvtEhnQLWPj7Cnb97dDrsAV4b6uG+XdtIHNWmVD5JRl3GDjkM708x0e9inPxdsbfYaA+/gLWPDaXd7eoX7Xv44zPW0RzSXr7KLxODLvseijOyd/L31vLC8vf6qTzDxvbKCf5vNV/awy9gHiv9lEufZWGJvnhUfjGOoft3yemwB3CTsPuBOBP92svPhnn18EWkGvg+sAQ4AHzQGDOY5nYHgFHAAVJzLc6vTk1buIKQx8t4Kjmj/eblZ1MXDOWoKpXvJnpcxvY6xPtdylfaBJstvOUL3/dLjBl6tqUZajQQPewQatT+50Kb70/4TuBxY8xK4PGp7+dylTHmXA37zGkLRbj70nexKDy59LEtwnuXrOEDy9bqfrYqrViXw+57Yhz6aYK+36bY/404HT9JkBydPTSYcQIyx+cA52pXmTXfMfyNwJVTX38L+A3wmXnepzpJIsJZ1Q187fL3MBCP4rM8NJaF8euHrlQaTsJw+NEkbnxm+8hOh/ilBu8C75PjKxeaLvHS/ujMd6TigTLt3WfFfJOhwRjTBWCM6RKRuZZlNMCvRMQAXzPGbJ7rDkVkE7AJYNGiRfMsL3/EUikOj08w4TjUBP3UBwMZu++aQBk1gbKM3Z8qTk7MMLbPSXss1uUSXraw3WwRoe4cD4kRQ88LKYwLvgph+ft8BGs08LPhhIEvIo8BjWkOffYUznOpMaZz6g/CoyLyhjFmS7obTv0x2AyTm5ifwjnyVnc0xr079vDLg10YoD7o568vOJtz66r04qrKGssL/lqLWMfs4RtfdXZ+D30Ri0UbfDRe6MVNGDxhwR/RsM+WE/6kjTHXGmPOSvPfT4FuEWkCmPq3Z4776Jz6twd4ELggcw8hvznG8OO9HfxiKuwBemJx/sdTL9I+Gs1pbao4JFOG4VGXsejxx+E9ZRZNN3jhmGz31QjBLA6p2F4hWGsRarY17LNsvkM6DwF/CHxu6t+fHnsDEQkBljFmdOrrDcDfzvO8BaMvNsEP97w5qz3uuhwcHWdxRGfTqNPXN+jy5NYEuw44hMqEq873smKRTVkgfZCWLbJZ/v8E6HkiQWLQUHGWh+p1HnxVGrylYL6B/zngByLyceBN4CYAEWkGvm6MuRFoAB6UyaELD/BdY8wv53negmEAx00/MuWYohixUjkyNOry7Z9PMDo++Xs0PGr4yRMJNl7l45zV6QPc9grhJTbBDwcwSYMdFMTSYcVSMa/AN8b0A9ekae8Ebpz6eh9wznzOU8hqA37es6yFH+5pn9Fui7BEe/dqHvoG3emwP9oTv0uyrNWmPDR3r932Cfg06EuNvo9bYB7L4rZVizm//siuUyGPh3+85BxawzqzRp2+WDz9O8SxqMHJwrR6VXh0wnYWNIXK+PuLz6FzPEYs5dAQ9NMYCuoMHTUvNZXp+2urFtuUBfR3S82mgZ8lEZ+XiM+b6zJUEamOWFyx3suTW498kCkUhKsv8OLThchUGhr4RcQ1hp7YBI5rqPb7CHr16S1mAb9w4dleVi626el3KQsKdVUWVTrVUc1BE6FI9MXiPHzgEN964wDRVIrLm+v407NXsiQSznVpeacnmuTweBLHQEOZh+awL9clnbaAX2ius2mu08Vo1Ilp4BcBxxge2t/B5p17p9u2dPby+6FRvnbV+TSU6ZaHb9k7FOcvnjxEd3Ry1caIz+Kf3tHC2XVHfkaDEw7to0kOjSapK/OwOOKlrkxfKqrw6W9xEeiJTvDvuw7Maj8cnaBjLKaBP2UonuL/PNs1HfYAIwmXO5/q5N82LKIx7KU/luKLWwd4on18+jYrq7z8w+UNNIf1GowqbDrYVwRSrks0lX5RrIk52ktRXzTF7qHErPahuMPh6OSFz10DiRlhD7B7MMmTx7QpVYg08ItAVcDHurqqWe22CE0h7d2/xTrOJ0o9U8ee6ki/vtEjB8YZS+gfz2LhJAxj3S4D+1KMdjmkJkrjgws6pFMEwl4vn3r7GXzyyW0MxCd7sAL8r3VradHAn9YQ9HBJU4hnumb21tvKvTSFJodrmsPpXxINZR68dnanOjopQ3TUYIBgWPDqVMuMSEZd2p9N0f7bI9NZG95ms/RaH/4s7PyVSxr4RWJ5RTlfv+ZCOsaixFIpWsNltIaC+D06e+MtIZ/Nn62vQ7bB052ToX9WTYD/eWEDNcHJl8IlLWXct2OIhDPzU6y3ranAb2cvDMaGXXY8l2Dfaw4YaF1h8/bLfZTrImfzNtrlzgh7gO5XHKqWOzS8rbh/vhr4RaQ5FKRZe/TH1RL28deXNNEdTeIaqCvzEPEd+aO4tMLLPdc08i/bB9jRF2dxxMsd51Wzujp7UzeTCcO23yTo2HNkCKl9t8P4SJyr3ucnUFbcobTQel5Ns68u0Lk1Re0aD3YRv5PSwFclp8xrsbTCn/aYJcLa2gD/dEUDY0mXgG1RGcjuu6TxEXdG2L9loNtlfMSgm5vNj2eOZSc8fpm1V0Cx0a6CUmmEfTaNIW/Wwx7APc61YSd951Sdgvqz0/dzWy7yYHuKO/E18JXKM8GwEK6cHTy+AJSVF3cgZUOo3mLtB/14Q5M/S08AVr3bR6Sl+K936ZCOUnkmGLK47F1+nvjRBImJyTbbA5e/208oooE/X7ZXqFvjobzZIjVhsH1CoFKQHK9eGx9ySQyYyc3dKwV/deY3p9HAVyoP1TTa3PChIKPDLsZAuMKiPA9CaSG5MYPpcXH7DVImWA2CtYCzkgIVFlQs2N2fkthhhz3fjJMcmZwdZnlh2Yf9lC+3Mxr6GvhK5alwpUV4jjXvi4077pL4ZYrEQ0emS1ptQvC/B7Dri/tnkIy6HPhRYjrsAdwk7PtOnDWfDOKvyVzgF/dPUhWVgZjD0Ak+ETmRcjgwPMFr/eMcHo9nqTI1X26nmRH2AG67IflkCjPHntDFIjViiB2a/XvtJiA+lNnHrj18lfd6ow5PHIzzo10xbBFuWRvkslYfNcGZF9n6ognuf6ObB/f04hio8nv4Xxcs5oKGcrxZ/NCUOnXOrvRTk5LPpPC904OkuYhdLMSemg6aJtutDCe0vgpUXhtLuHzlxXHu3jZO55hL+6jD558f47s7o7M+DfvrjiEe2D0Z9gCD8RR3/nYvB0e1p5/vZI6L0RKWou+WeiuFqnNmzxDyVwu+qsz+odPAV3nt8JjDowdmB/YDuyboGjvSKxyIJfne73tm3c4xsKNvbEFrVPNnr7AhzWfh/Bu9WOHijinbKzS/00fNOns6kcPLLJZ/NIAvw7uXFfnfTlXoxlPpxzAdA9HkkWMGcOYY63VMcY8BFwOrSSi7M8DEvydw97pIheC/yYt9RnGH/Vv8VRat7/HTcIUB1+Apt/AEMz+MpYGv8lp1wCZgw8QxQ7yVfqEqYB11Ow/vX1nHV1/pnHE7Ac6u1W0e852I4FlmU/YpP2YcxAtWdWmE/Vtsr2DXLuy1itL6iaqC0xS2+IsLy2e0WQJ3XlxOY/jIuKeIsGFxNVe3VU63BT0Wf33REhaXp183R+UfK2xhN1glF/bZIiaP3+6uX7/ebN26NddlqBybSLm8OeLwUncS24Jz6n0sitj40qxPP5ZI0TWeYDzpUBv00hjyT29uolQpEJFtxpj16Y7pkI7KewGPxapqi1XVJ95TNuzzsNKnv9ZKpaPvm5RSqkRoV0gdV18syXjSIey1qQmeuIetlMpfGvgqrVjKYWv3GF/YdojuaJKmkI8/X9fCefVh/B59Y6hUIdJXrkprz9AEn3nqAN3RyfVNusYT/PmW/ewdnshxZUqp06WBr2ZxXMOPd/fNajfAz/cNZL8gpVRG6JCOmsUYQ99E+r30+mMJjDFFvS67yj+pqIsTBfGAr0SWjF4I8/rJichNIrJTRFwRSTvvc+p214vILhHZIyJ3zuecauF5bIt3L6tOe+zGZdUa9iqrYh0OB78RZ/fnY+z9Uoz+Z5Okxo+/TLZKb75/KncA7wO2zHUDEbGBe4AbgLXArSKydp7nVQvs7XUhrmyNzGjbsLiSM2tCOapIlaJ4r8v+zRPE3pwMeCcKXT9JMDrHcsrq+OY1pGOMeR04UY/vAmCPMWbf1G2/B2wEXpvPudXCqivz8Znz2/jQmjhDEymqAl5awj4q/DoKqLIn1ungplnduvexJOWrbDxFvpJmpmXj1dsCtB/1fQdw4Vw3FpFNwCaARYsWLWxl6rgq/B4NeJVTzvgc7TGD0U7+KTvhq1lEHgMa0xz6rDHmpydxjnTd/zkX8DHGbAY2w+RaOidx/0qpIhVsS9+DrzjXgx3Sa0mn6oSBb4y5dp7n6ADajvq+Feic47ZKFT1jDMNRg2sgEhQ8aRaBU5P8tRYN13vp/uWR/W799ULNpV4sj/7cTlU23q+/AKwUkaXAIeAW4LYsnFepvDM07rJtb4rHX0mSSMH5K22uOdtHbYZ3NioWdlCovthL+Ayb5KDB9gu+WsFboT+v0zHfaZl/ICIdwMXAf4rII1PtzSLyMIAxJgXcATwCvA78wBizc35lK1V4Uo7hyZ0pfvq7JGMTkEjB0687fPOJOKMxnWY4FzsgBJtsIms9hJbbGvbzMN9ZOg8CD6Zp7wRuPOr7h4GH53MupQrd4JjhyZ3JWe1v9rn0jRrKgzkoSpUU/VOpVJYkHUNqjpkl8YTOT1ALTwNfqSwpDwj1FbMvNHosqArrBUi18DTwlcqS8jKLD1/h5+gNuQS49R0+asr1pagWnn6qRqksWlxn8en3BukackmmDE1VNnUVOjVTZYcGvlJZJCLUVwr1uuKjygENfKWOI+UausaT9ERTBGyL5rCHqoC+bFRh0t9cpeaQdAzPdI7zt892M+FMzqJZU+3nby5poKXcl+PqlDp1+r5SqTl0jCW56+nD02EP8PpAnG/uHCTh6AelVOHRwFdqDu2jCZw00+MfOTBKf0yXalSFRwNfqTl45tjnwWcLlk6qUQVIA1+pObRFvJSlWZHxg6srqQ3q5S9VeDTwlZpDa9jLF69qpq3cC4At8AcrIrx3RQRbu/iqAGk3Rak5iAhn1gb5yrUt9MccfLbQGPLgt7WfpAqTBr5SJ1Ad8FCtc+9VEdCuilJKlQgNfKWUKhEa+EopVSI08JVSqkRo4CulVIkQY/J3azUR6QUO5rqOeagF+nJdRJaV2mMutccLpfeYC+3xLjbG1KU7kNeBX+hEZKsxZn2u68imUnvMpfZ4ofQeczE9Xh3SUUqpEqGBr5RSJUIDf2FtznUBOVBqj7nUHi+U3mMumserY/hKKVUitIevlFIlQgNfKaVKhAZ+BonITSKyU0RcEZlzGpeIXC8iu0Rkj4jcmc0aM01EqkXkURHZPfVv1Ry3OyAir4rISyKyNdt1zteJnjOZ9OWp46+IyHm5qDOTTuIxXykiw1PP6Usi8le5qDNTROQ+EekRkR1zHC/451gDP7N2AO8Dtsx1AxGxgXuAG4C1wK0isjY75S2IO4HHjTErgcenvp/LVcaYcwttTvNJPmc3ACun/tsEfDWrRWbYKfyePjX1nJ5rjPnbrBaZed8Erj/O8YJ/jjXwM8gY87oxZtcJbnYBsMcYs88YkwC+B2xc+OoWzEbgW1Nffwt4b+5KWTAn85xtBO43k54DKkWkKduFZlCx/Z6ekDFmCzBwnJsU/HOsgZ99LUD7Ud93TLUVqgZjTBfA1L/1c9zOAL8SkW0isilr1WXGyTxnxfa8nuzjuVhEXhaRX4jImdkpLWcK/jnWbXxOkYg8BjSmOfRZY8xPT+Yu0rTl9dzY4z3mU7ibS40xnSJSDzwqIm9M9agKwck8ZwX3vJ7AyTyeF5lct2VMRG4EfsLkcEexKvjnWAP/FBljrp3nXXQAbUd93wp0zvM+F9TxHrOIdItIkzGma+rtbc8c99E59W+PiDzI5JBBoQT+yTxnBfe8nsAJH48xZuSorx8Wka+ISK0xppAWGjsVBf8c65BO9r0ArBSRpSLiA24BHspxTfPxEPCHU1//ITDrXY6IhESk/K2vgQ1MXuAuFCfznD0EfHRqJsdFwPBbQ10F6oSPWUQaRUSmvr6AyTzpz3ql2VPwz7H28DNIRP4AuBuoA/5TRF4yxlwnIs3A140xNxpjUiJyB/AIYAP3GWN25rDs+foc8AMR+TjwJnATwNGPGWgAHpzKBg/wXWPML3NU7ymb6zkTkU9MHb8XeBi4EdgDRIGP5areTDjJx/wB4E9EJAXEgFtMAX90X0T+A7gSqBWRDuB/A14onudYl1ZQSqkSoUM6SilVIjTwlVKqRGjgK6VUidDAV0qpEqGBr5RSJUIDXymlSoQGvlJKlYj/H8Y2AhCzQCmZAAAAAElFTkSuQmCC
"
>
</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="Compare-with-ordinary-topological-optimization">Compare with ordinary topological optimization<a class="anchor-link" href="#Compare-with-ordinary-topological-optimization">&#182;</a></h2><p>For comparison, we also conduct the same topological optimization procedure directly on the initialized embedding.
We observe that the results were much worse than when we accounted for the embedding loss.</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;[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="c1"># Learning hyperparameters</span>
<span class="n">num_epochs</span> <span class="o">=</span> <span class="mi">500</span>
<span class="n">learning_rate</span> <span class="o">=</span> <span class="mf">1e-1</span>

<span class="c1"># Conduct topological optimization</span>
<span class="n">Y_opt</span><span class="p">,</span> <span class="n">W_opt</span><span class="p">,</span> <span class="n">losses_opt</span> <span class="o">=</span> <span class="n">PCA</span><span class="p">(</span><span class="n">data</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="n">emb_loss</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span> <span class="n">top_loss</span><span class="o">=</span><span class="n">top_loss</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="n">num_epochs</span><span class="p">,</span> 
                               <span class="n">learning_rate</span><span class="o">=</span><span class="n">learning_rate</span><span class="p">,</span> <span class="n">random_state</span><span class="o">=</span><span class="mi">42</span><span class="p">)</span>

<span class="c1"># View topologically optimized embedding (flip for consistency)</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">()</span>
<span class="n">sns</span><span class="o">.</span><span class="n">scatterplot</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">Y_opt</span><span class="p">[:,</span><span class="mi">0</span><span class="p">],</span> <span class="n">y</span><span class="o">=-</span><span class="n">Y_opt</span><span class="p">[:,</span><span class="mi">1</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">50</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="n">t</span><span class="p">,</span> <span class="n">palette</span><span class="o">=</span><span class="s2">&quot;husl&quot;</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">remove</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>[epoch 1] [emb. loss: 0.000000, ortho. loss: 0.001478, top. loss: -1.539055, total loss: -1.537577]
[epoch 50] [emb. loss: 0.000000, ortho. loss: 3397.123535, top. loss: -0.791807, total loss: 3396.331787]
[epoch 100] [emb. loss: 0.000000, ortho. loss: 543.927490, top. loss: -6.307951, total loss: 537.619568]
[epoch 150] [emb. loss: 0.000000, ortho. loss: 1442.463501, top. loss: -3.729107, total loss: 1438.734375]
[epoch 200] [emb. loss: 0.000000, ortho. loss: 1797.159668, top. loss: -5.906724, total loss: 1791.252930]
[epoch 250] [emb. loss: 0.000000, ortho. loss: 1037.598145, top. loss: -6.311464, total loss: 1031.286621]
[epoch 300] [emb. loss: 0.000000, ortho. loss: 1997.365601, top. loss: -3.227956, total loss: 1994.137695]
[epoch 350] [emb. loss: 0.000000, ortho. loss: 3691.520752, top. loss: -3.611770, total loss: 3687.908936]
[epoch 400] [emb. loss: 0.000000, ortho. loss: 1454.978638, top. loss: -7.833032, total loss: 1447.145630]
[epoch 450] [emb. loss: 0.000000, ortho. loss: 6961.562500, top. loss: -2.408313, total loss: 6959.154297]
[epoch 500] [emb. loss: 0.000000, ortho. loss: 1272.623657, top. loss: -2.707522, total loss: 1269.916138]
Time for embedding: 00:00:05
</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>We observe that the results are highly similar.</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">
<h2 id="Quantitative-evaluation">Quantitative evaluation<a class="anchor-link" href="#Quantitative-evaluation">&#182;</a></h2><p>First, we evaluate the different losses (embedding and topological) for all final embeddings.</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;[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="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="se">\033</span><span class="s2">[1mLosses for pca embedding: </span><span class="se">\033</span><span class="s2">[0m&quot;</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Reconstruction: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">losses_top</span><span class="p">[</span><span class="s2">&quot;embedding&quot;</span><span class="p">][</span><span class="mi">0</span><span class="p">]))</span> <span class="c1"># PCA initialization gives first embedding loss</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Orthonormality: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">ortho_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">W_pca</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()))</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Topological: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">top_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">Y_pca</span><span class="p">)</span><span class="o">.</span><span class="n">type</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">float</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">/</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">lambda_top</span><span class="p">))</span> <span class="o">+</span> <span class="s2">&quot;</span><span class="se">\n</span><span class="s2">&quot;</span><span class="p">)</span>

<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="se">\033</span><span class="s2">[1mLosses for topologically optimized pca embedding: </span><span class="se">\033</span><span class="s2">[0m&quot;</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Reconstruction: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">pca_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">data</span> <span class="o">-</span> <span class="n">data</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">axis</span><span class="o">=</span><span class="mi">0</span><span class="p">)),</span> 
                                        <span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">W_opt</span><span class="p">),</span> <span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">Y_opt</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()))</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Orthonormality: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">ortho_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">W_opt</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()))</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Topological: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">top_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">Y_opt</span><span class="p">)</span><span class="o">.</span><span class="n">type</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">float</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">/</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">lambda_top</span><span class="p">))</span> <span class="o">+</span> <span class="s2">&quot;</span><span class="se">\n</span><span class="s2">&quot;</span><span class="p">)</span>

<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="se">\033</span><span class="s2">[1mLosses for topologically regularized pca embedding: </span><span class="se">\033</span><span class="s2">[0m&quot;</span><span class="p">)</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Reconstruction: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">pca_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">data</span> <span class="o">-</span> <span class="n">data</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">axis</span><span class="o">=</span><span class="mi">0</span><span class="p">)),</span> 
                                        <span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">W_top</span><span class="p">),</span> <span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">Y_top</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()))</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Orthonormality: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">ortho_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">W_top</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()))</span>
<span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Topological: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">top_loss</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">tensor</span><span class="p">(</span><span class="n">Y_top</span><span class="p">)</span><span class="o">.</span><span class="n">type</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">float</span><span class="p">))</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">/</span> <span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">lambda_top</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><span class="ansi-bold">Losses for pca embedding: </span>
Reconstruction: 0.06318476796150208
Orthonormality: 1.7184031883525453e-15
Topological: -0.15390551090240479

<span class="ansi-bold">Losses for topologically optimized pca embedding: </span>
Reconstruction: 0.06680672810017917
Orthonormality: 0.21647799015045166
Topological: -0.34679036140441893

<span class="ansi-bold">Losses for topologically regularized pca embedding: </span>
Reconstruction: 0.06649286039989714
Orthonormality: 0.028079602867364883
Topological: -0.7508018016815186
</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">
<p>We also compare the magnitudes of the new projection weights with those from the ordinary PCA embedding.</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"># Compute the magnitudes of the weights by dimension</span>
<span class="n">magnitudes</span> <span class="o">=</span> <span class="n">pd</span><span class="o">.</span><span class="n">DataFrame</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">abs</span><span class="p">(</span><span class="n">W</span><span class="p">[</span><span class="mi">2</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="k">for</span> <span class="n">W</span> <span class="ow">in</span> <span class="p">[</span><span class="n">W_pca</span><span class="p">,</span> <span class="n">W_opt</span><span class="p">,</span> <span class="n">W_top</span><span class="p">]])</span><span class="o">.</span><span class="n">ravel</span><span class="p">(),</span>
                         <span class="n">columns</span><span class="o">=</span><span class="p">[</span><span class="s2">&quot;magnitude&quot;</span><span class="p">])</span>
<span class="n">magnitudes</span><span class="p">[</span><span class="s2">&quot;type&quot;</span><span class="p">]</span> <span class="o">=</span> <span class="p">(</span><span class="n">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="o">-</span> <span class="mi">2</span><span class="p">)</span> <span class="o">*</span> <span class="p">[</span><span class="s2">&quot;pca&quot;</span><span class="p">]</span> <span class="o">+</span> <span class="p">(</span><span class="n">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="o">-</span> <span class="mi">2</span><span class="p">)</span> <span class="o">*</span> <span class="p">[</span><span class="s2">&quot;top. opt.&quot;</span><span class="p">]</span> <span class="o">+</span> \
                        <span class="p">(</span><span class="n">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="o">-</span> <span class="mi">2</span><span class="p">)</span> <span class="o">*</span> <span class="p">[</span><span class="s2">&quot;top. reg.&quot;</span><span class="p">]</span>
    
<span class="c1"># Compare the magnitudes</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">(</span><span class="n">figsize</span><span class="o">=</span><span class="p">(</span><span class="mi">15</span><span class="p">,</span> <span class="mi">3</span><span class="p">))</span>
<span class="n">sns</span><span class="o">.</span><span class="n">kdeplot</span><span class="p">(</span><span class="n">data</span><span class="o">=</span><span class="n">magnitudes</span><span class="p">,</span> <span class="n">x</span><span class="o">=</span><span class="s2">&quot;magnitude&quot;</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="s2">&quot;type&quot;</span><span class="p">,</span> <span class="n">ax</span><span class="o">=</span><span class="n">ax</span><span class="p">,</span> <span class="n">linewidth</span><span class="o">=</span><span class="mi">4</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">set_xlim</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">0.2</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">set_ylabel</span><span class="p">(</span><span class="s2">&quot;density&quot;</span><span class="p">,</span> <span class="n">fontsize</span><span class="o">=</span><span class="mi">20</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">set_xlabel</span><span class="p">(</span><span class="s2">&quot;feature importance (irrelevant features only)&quot;</span><span class="p">,</span> <span class="n">fontsize</span><span class="o">=</span><span class="mi">20</span><span class="p">)</span>
<span class="n">ax</span><span class="o">.</span><span class="n">tick_params</span><span class="p">(</span><span class="n">axis</span><span class="o">=</span><span class="s2">&quot;both&quot;</span><span class="p">,</span> <span class="n">which</span><span class="o">=</span><span class="s2">&quot;major&quot;</span><span class="p">,</span> <span class="n">labelsize</span><span class="o">=</span><span class="mi">15</span><span class="p">)</span>
<span class="n">plt</span><span class="o">.</span><span class="n">setp</span><span class="p">(</span><span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">get_texts</span><span class="p">(),</span> <span class="n">fontsize</span><span class="o">=</span><span class="s2">&quot;20&quot;</span><span class="p">)</span>
<span class="n">plt</span><span class="o">.</span><span class="n">setp</span><span class="p">(</span><span class="n">ax</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">get_title</span><span class="p">(),</span> <span class="n">fontsize</span><span class="o">=</span><span class="s2">&quot;25&quot;</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-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>We see that by adding a loss for topological regularization, the linear embedding model puts less emphasis on the majority of features that are irrelevant for capturing the topological prior.</p>
<p>Finally, we compare if the topologically regularized embedding improves on the ordinary PCA embedding for predicting data point labels.</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"># Machine learning model to be used for label prediction</span>
<span class="n">Ys</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;pca&quot;</span><span class="p">:</span> <span class="n">Y_pca</span><span class="p">,</span> <span class="s2">&quot;top. opt.&quot;</span><span class="p">:</span> <span class="n">Y_opt</span><span class="p">,</span> <span class="s2">&quot;top. reg.&quot;</span><span class="p">:</span> <span class="n">Y_top</span><span class="p">}</span>
<span class="n">model</span> <span class="o">=</span> <span class="n">MultiOutputRegressor</span><span class="p">(</span><span class="n">SVR</span><span class="p">())</span>
<span class="n">scoring</span> <span class="o">=</span> <span class="s2">&quot;r2&quot;</span>

<span class="c1"># Hyperparameters for quantitative evaluation</span>
<span class="n">ntimes</span> <span class="o">=</span> <span class="mi">100</span>
<span class="n">test_frac</span> <span class="o">=</span> <span class="mf">0.1</span>
<span class="n">params</span> <span class="o">=</span> <span class="p">{</span><span class="s2">&quot;estimator__C&quot;</span><span class="p">:[</span><span class="mf">0.01</span><span class="p">,</span> <span class="mf">0.1</span><span class="p">,</span> <span class="mi">1</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">100</span><span class="p">]}</span>

<span class="c1"># Obtain performances over multiple train-test splits</span>
<span class="n">performances</span> <span class="o">=</span> <span class="n">evaluate_embeddings</span><span class="p">(</span><span class="n">Ys</span><span class="p">,</span> <span class="n">X</span><span class="p">[:,:</span><span class="mi">2</span><span class="p">],</span> <span class="n">model</span><span class="p">,</span> <span class="n">scoring</span><span class="p">,</span> <span class="n">params</span><span class="o">=</span><span class="n">params</span><span class="p">,</span> <span class="n">ntimes</span><span class="o">=</span><span class="n">ntimes</span><span class="p">,</span> 
                                   <span class="n">test_frac</span><span class="o">=</span><span class="n">test_frac</span><span class="p">,</span> <span class="n">random_state</span><span class="o">=</span><span class="mi">42</span><span class="p">)</span>

<span class="c1"># View resulting performances</span>
<span class="n">pd</span><span class="o">.</span><span class="n">concat</span><span class="p">([</span><span class="n">pd</span><span class="o">.</span><span class="n">DataFrame</span><span class="p">({</span><span class="s2">&quot;mean&quot;</span><span class="p">:</span><span class="n">performances</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">axis</span><span class="o">=</span><span class="mi">0</span><span class="p">)}),</span>
           <span class="n">pd</span><span class="o">.</span><span class="n">DataFrame</span><span class="p">({</span><span class="s2">&quot;std&quot;</span><span class="p">:</span><span class="n">performances</span><span class="o">.</span><span class="n">std</span><span class="p">(</span><span class="n">axis</span><span class="o">=</span><span class="mi">0</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="o">.</span><span class="n">style</span><span class="o">.</span><span class="n">highlight_max</span><span class="p">(</span><span class="n">subset</span><span class="o">=</span><span class="s2">&quot;mean&quot;</span><span class="p">,</span> <span class="n">color</span><span class="o">=</span><span class="s2">&quot;lightgreen&quot;</span><span class="p">,</span> <span class="n">axis</span><span class="o">=</span><span class="mi">0</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">Out[9]:</div>



<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html">
<style type="text/css">
#T_2b9a9_row2_col0 {
  background-color: lightgreen;
}
</style>
<table id="T_2b9a9_">
  <thead>
    <tr>
      <th class="blank level0" >&nbsp;</th>
      <th class="col_heading level0 col0" >mean</th>
      <th class="col_heading level0 col1" >std</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <th id="T_2b9a9_level0_row0" class="row_heading level0 row0" >pca</th>
      <td id="T_2b9a9_row0_col0" class="data row0 col0" >0.562144</td>
      <td id="T_2b9a9_row0_col1" class="data row0 col1" >0.472218</td>
    </tr>
    <tr>
      <th id="T_2b9a9_level0_row1" class="row_heading level0 row1" >top. opt.</th>
      <td id="T_2b9a9_row1_col0" class="data row1 col0" >0.774822</td>
      <td id="T_2b9a9_row1_col1" class="data row1 col1" >0.244247</td>
    </tr>
    <tr>
      <th id="T_2b9a9_level0_row2" class="row_heading level0 row2" >top. reg.</th>
      <td id="T_2b9a9_row2_col0" class="data row2 col0" >0.849050</td>
      <td id="T_2b9a9_row2_col1" class="data row2 col1" >0.137003</td>
    </tr>
  </tbody>
</table>

</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="Topological-regularization-for-different-shape-prior">Topological regularization for different shape prior<a class="anchor-link" href="#Topological-regularization-for-different-shape-prior">&#182;</a></h2><p>Finally, we study how the tologically regularized embedding varies over different forms of (potentially wrong) prior topological information. In particular, we study the topologically regularized embedding when the topological loss function is designed to ensure that:</p>
<p>1) The sum of persistence of the two most prominent cycles is high.<br>
2) The persistence of the second most prominent cycle is high.<br>
3) The topology resembles a connected component with at least three flares away from the center.</p>
<p>All other hyperparameters will be kept equal.</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;[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="c1"># Define different topological loss</span>
<span class="k">def</span> <span class="nf">g</span><span class="p">(</span><span class="n">p</span><span class="p">):</span> <span class="k">return</span> <span class="n">p</span><span class="p">[</span><span class="mi">1</span><span class="p">]</span> <span class="o">-</span> <span class="n">p</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="c1"># function that returns the persistence d - b of a point (b, d)</span>
<span class="n">TopLayer</span> <span class="o">=</span> <span class="n">AlphaLayer</span><span class="p">(</span><span class="n">maxdim</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span> <span class="c1"># alpha complex layer</span>
<span class="n">CircularPersistence</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">j</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># compute persistence of most prominent cycle</span>
<span class="n">CircularPersistence2</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">i</span><span class="o">=</span><span class="mi">2</span><span class="p">,</span> <span class="n">j</span><span class="o">=</span><span class="mi">2</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># sum of persistence of two most prominent cycles</span>
<span class="n">CircularPersistence2Total</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">i</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">j</span><span class="o">=</span><span class="mi">2</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># sum of persistence of two most prominent cycles</span>
<span class="n">ComponentPersistence</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">i</span><span class="o">=</span><span class="mi">2</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># compute total (finite) persistence</span>
<span class="n">Component3Persistence</span> <span class="o">=</span> <span class="n">DiagramLoss</span><span class="p">(</span><span class="n">dim</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">i</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span> <span class="n">j</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span> <span class="n">g</span><span class="o">=</span><span class="n">g</span><span class="p">)</span> <span class="c1"># compute persistence of third most prominent gap</span>
<span class="n">lambda_top</span> <span class="o">=</span> <span class="o">-</span><span class="mf">1e1</span> <span class="c1"># scalar factor that trades off embedding and topological loss</span>
<span class="n">tau_flare</span> <span class="o">=</span> <span class="mf">0.25</span> <span class="c1"># sample fraction for which the flare topological loss is computed</span>

<span class="c1"># Construct the topological loss functions</span>
<span class="k">def</span> <span class="nf">top_loss_other1</span><span class="p">(</span><span class="n">output</span><span class="p">):</span>
    <span class="n">dgminfo</span> <span class="o">=</span> <span class="n">TopLayer</span><span class="p">(</span><span class="n">output</span><span class="p">)</span>
    <span class="n">loss</span> <span class="o">=</span> <span class="n">lambda_top</span> <span class="o">*</span> <span class="n">CircularPersistence2Total</span><span class="p">(</span><span class="n">dgminfo</span><span class="p">)</span>
    
    <span class="k">return</span> <span class="n">loss</span>

<span class="k">def</span> <span class="nf">top_loss_other2</span><span class="p">(</span><span class="n">output</span><span class="p">):</span>
    <span class="n">dgminfo</span> <span class="o">=</span> <span class="n">TopLayer</span><span class="p">(</span><span class="n">output</span><span class="p">)</span>
    <span class="n">loss</span> <span class="o">=</span> <span class="n">lambda_top</span> <span class="o">*</span> <span class="n">CircularPersistence2</span><span class="p">(</span><span class="n">dgminfo</span><span class="p">)</span>
    
    <span class="k">return</span> <span class="n">loss</span>

<span class="k">def</span> <span class="nf">top_loss_other3</span><span class="p">(</span><span class="n">output</span><span class="p">):</span>    
    <span class="c1"># Loss for connectedness</span>
    <span class="n">dgminfo_connected</span> <span class="o">=</span> <span class="n">TopLayer</span><span class="p">(</span><span class="n">output</span><span class="p">)</span>         
    <span class="n">loss_connected</span> <span class="o">=</span> <span class="n">ComponentPersistence</span><span class="p">(</span><span class="n">dgminfo_connected</span><span class="p">)</span>

    <span class="c1"># Loss for flare</span>
    <span class="n">f</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">norm</span><span class="p">(</span><span class="n">output</span> <span class="o">-</span> <span class="n">torch</span><span class="o">.</span><span class="n">mean</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">dim</span><span class="o">=</span><span class="mi">0</span><span class="p">),</span> <span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
    <span class="n">f</span> <span class="o">/=</span> <span class="n">torch</span><span class="o">.</span><span class="n">max</span><span class="p">(</span><span class="n">f</span><span class="p">)</span>
    <span class="n">dgminfo_flare</span> <span class="o">=</span> <span class="n">TopLayer</span><span class="p">(</span><span class="n">output</span><span class="p">[</span><span class="n">f</span> <span class="o">&gt;</span> <span class="n">tau_flare</span><span class="p">,:])</span>
    <span class="n">loss_flare</span> <span class="o">=</span> <span class="o">-</span><span class="n">Component3Persistence</span><span class="p">(</span><span class="n">dgminfo_flare</span><span class="p">)</span>    
        
    <span class="c1"># Total loss</span>
    <span class="n">loss</span> <span class="o">=</span> <span class="o">-</span><span class="n">lambda_top</span> <span class="o">*</span> <span class="p">(</span><span class="n">loss_connected</span> <span class="o">+</span> <span class="n">loss_flare</span><span class="p">)</span>
    
    <span class="k">return</span> <span class="n">loss</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">
<p>We now obtain the topologically regularized embeddings for the different loss functions.</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;[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"># Learning hyperparameters</span>
<span class="n">num_epochs</span> <span class="o">=</span> <span class="mi">500</span>
<span class="n">learning_rate</span> <span class="o">=</span> <span class="mf">1e-1</span>

<span class="c1"># Conduct topological regularization for different topological loss functions</span>
<span class="n">top_losses</span> <span class="o">=</span> <span class="p">[</span><span class="n">top_loss_other1</span><span class="p">,</span> <span class="n">top_loss_other2</span><span class="p">,</span> <span class="n">top_loss_other3</span><span class="p">]</span>
<span class="n">Y_tops</span> <span class="o">=</span> <span class="p">[]</span>

<span class="k">for</span> <span class="n">idx</span><span class="p">,</span> <span class="n">this_top_loss</span> <span class="ow">in</span> <span class="nb">enumerate</span><span class="p">(</span><span class="n">top_losses</span><span class="p">):</span>
    <span class="c1"># Conduct topological regularization</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="se">\033</span><span class="s2">[1mConducting topologically regularized embedding for topological loss &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">idx</span> <span class="o">+</span> <span class="mi">1</span><span class="p">)</span> <span class="o">+</span> <span class="s2">&quot;</span><span class="se">\033</span><span class="s2">[0m&quot;</span><span class="p">)</span>
    <span class="n">this_Y_top</span><span class="p">,</span> <span class="n">W_top</span><span class="p">,</span> <span class="n">losses_top</span> <span class="o">=</span> <span class="n">PCA</span><span class="p">(</span><span class="n">data</span><span class="p">,</span> <span class="n">top_loss</span><span class="o">=</span><span class="n">this_top_loss</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="n">num_epochs</span><span class="p">,</span>
                                        <span class="n">learning_rate</span><span class="o">=</span><span class="n">learning_rate</span><span class="p">,</span> <span class="n">random_state</span><span class="o">=</span><span class="mi">42</span><span class="p">)</span>
    <span class="n">Y_tops</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">this_Y_top</span><span class="p">)</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="se">\n</span><span class="s2">&quot;</span><span class="p">)</span>
    
<span class="c1"># View topologically regularized embeddings</span>
<span class="n">fig</span><span class="p">,</span> <span class="n">ax</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">subplots</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="nb">len</span><span class="p">(</span><span class="n">top_losses</span><span class="p">),</span> <span class="n">figsize</span><span class="o">=</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">top_losses</span><span class="p">)</span> <span class="o">*</span> <span class="mi">5</span><span class="p">,</span> <span class="mf">3.5</span><span class="p">))</span>
<span class="k">for</span> <span class="n">idx</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="nb">len</span><span class="p">(</span><span class="n">top_losses</span><span class="p">)):</span>
    <span class="n">sns</span><span class="o">.</span><span class="n">scatterplot</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">Y_tops</span><span class="p">[</span><span class="n">idx</span><span class="p">][:,</span><span class="mi">0</span><span class="p">],</span> <span class="n">y</span><span class="o">=</span><span class="n">Y_tops</span><span class="p">[</span><span class="n">idx</span><span class="p">][:,</span><span class="mi">1</span><span class="p">],</span> <span class="n">s</span><span class="o">=</span><span class="mi">50</span><span class="p">,</span> <span class="n">hue</span><span class="o">=</span><span class="n">t</span><span class="p">,</span> <span class="n">palette</span><span class="o">=</span><span class="s2">&quot;husl&quot;</span><span class="p">,</span> <span class="n">ax</span><span class="o">=</span><span class="n">ax</span><span class="p">[</span><span class="n">idx</span><span class="p">])</span>
    <span class="n">ax</span><span class="p">[</span><span class="n">idx</span><span class="p">]</span><span class="o">.</span><span class="n">get_legend</span><span class="p">()</span><span class="o">.</span><span class="n">remove</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><span class="ansi-bold">Conducting topologically regularized embedding for topological loss 1</span>
[epoch 1] [emb. loss: 0.063185, ortho. loss: 0.001478, top. loss: -3.069539, total loss: -3.004876]
[epoch 50] [emb. loss: 0.067590, ortho. loss: 4030.990967, top. loss: -1.291014, total loss: 4029.767578]
[epoch 100] [emb. loss: 0.066726, ortho. loss: 678.191345, top. loss: -8.951507, total loss: 669.306580]
[epoch 150] [emb. loss: 0.066657, ortho. loss: 784.648376, top. loss: -10.140961, total loss: 774.574097]
[epoch 200] [emb. loss: 0.066653, ortho. loss: 1258.971802, top. loss: -7.716102, total loss: 1251.322388]
[epoch 250] [emb. loss: 0.066619, ortho. loss: 548.612061, top. loss: -5.368172, total loss: 543.310486]
[epoch 300] [emb. loss: 0.066566, ortho. loss: 355.967926, top. loss: -7.132659, total loss: 348.901825]
[epoch 350] [emb. loss: 0.067129, ortho. loss: 3932.833740, top. loss: -3.193539, total loss: 3929.707275]
[epoch 400] [emb. loss: 0.067130, ortho. loss: 4167.404297, top. loss: -4.837134, total loss: 4162.634277]
[epoch 450] [emb. loss: 0.067381, ortho. loss: 5485.577148, top. loss: -2.801000, total loss: 5482.843750]
[epoch 500] [emb. loss: 0.066741, ortho. loss: 480.503693, top. loss: -7.617016, total loss: 472.953430]
Time for embedding: 00:00:05


<span class="ansi-bold">Conducting topologically regularized embedding for topological loss 2</span>
[epoch 1] [emb. loss: 0.063185, ortho. loss: 0.001478, top. loss: -1.530484, total loss: -1.465821]
[epoch 50] [emb. loss: 0.067736, ortho. loss: 1249.523560, top. loss: -0.778874, total loss: 1248.812378]
[epoch 100] [emb. loss: 0.066756, ortho. loss: 685.630188, top. loss: -1.517200, total loss: 684.179749]
[epoch 150] [emb. loss: 0.066748, ortho. loss: 386.324554, top. loss: -1.305436, total loss: 385.085846]
[epoch 200] [emb. loss: 0.066631, ortho. loss: 408.183807, top. loss: -2.597678, total loss: 405.652740]
[epoch 250] [emb. loss: 0.066589, ortho. loss: 471.743835, top. loss: -2.147955, total loss: 469.662476]
[epoch 300] [emb. loss: 0.067160, ortho. loss: 2124.012451, top. loss: -1.638885, total loss: 2122.440674]
[epoch 350] [emb. loss: 0.066761, ortho. loss: 959.783936, top. loss: -2.546629, total loss: 957.304077]
[epoch 400] [emb. loss: 0.067828, ortho. loss: 9674.896484, top. loss: -0.521681, total loss: 9674.442383]
[epoch 450] [emb. loss: 0.067338, ortho. loss: 2702.017822, top. loss: -2.920576, total loss: 2699.164551]
[epoch 500] [emb. loss: 0.066865, ortho. loss: 753.225403, top. loss: -1.828310, total loss: 751.463989]
Time for embedding: 00:00:05


<span class="ansi-bold">Conducting topologically regularized embedding for topological loss 3</span>
[epoch 1] [emb. loss: 0.063185, ortho. loss: 0.001478, top. loss: 197.619308, total loss: 197.683975]
[epoch 50] [emb. loss: 0.068041, ortho. loss: 5166.160645, top. loss: 55.678978, total loss: 5221.907715]
[epoch 100] [emb. loss: 0.067140, ortho. loss: 1323.296387, top. loss: 85.885590, total loss: 1409.249146]
[epoch 150] [emb. loss: 0.067050, ortho. loss: 577.588562, top. loss: 73.926880, total loss: 651.582520]
[epoch 200] [emb. loss: 0.066967, ortho. loss: 454.377075, top. loss: 79.713654, total loss: 534.157715]
[epoch 250] [emb. loss: 0.067389, ortho. loss: 2904.738525, top. loss: 100.876320, total loss: 3005.682129]
[epoch 300] [emb. loss: 0.067422, ortho. loss: 1593.473511, top. loss: 71.410591, total loss: 1664.951538]
[epoch 350] [emb. loss: 0.067249, ortho. loss: 524.616699, top. loss: 68.545914, total loss: 593.229858]
[epoch 400] [emb. loss: 0.067267, ortho. loss: 200.631836, top. loss: 63.663490, total loss: 264.362579]
[epoch 450] [emb. loss: 0.067247, ortho. loss: 443.747040, top. loss: 74.482666, total loss: 518.296997]
[epoch 500] [emb. loss: 0.067320, ortho. loss: 407.586548, top. loss: 59.356419, total loss: 467.010284]
Time for embedding: 00:00:11


</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 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;[&nbsp;]:</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> 
</pre></div>

     </div>
</div>
</div>
</div>

</div>
</body>







</html>
