From f0d7b69eecd4384291bb681bb7aec450eda31436 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Mar=C3=ADa=20Ramos?= <ramosm@jupyterMiLAB>
Date: Sun, 28 Feb 2021 10:27:27 -0500
Subject: [PATCH] code

---
 codigo/dataAnalysisHyy.html  | 15574 +++++++++++++++++++++++++++++++++
 codigo/dataAnalysisHyy.ipynb |  1145 +++
 2 files changed, 16719 insertions(+)
 create mode 100644 codigo/dataAnalysisHyy.html
 create mode 100644 codigo/dataAnalysisHyy.ipynb

diff --git a/codigo/dataAnalysisHyy.html b/codigo/dataAnalysisHyy.html
new file mode 100644
index 0000000..c6b83a6
--- /dev/null
+++ b/codigo/dataAnalysisHyy.html
@@ -0,0 +1,15574 @@
+<!DOCTYPE html>
+<html>
+<head><meta charset="utf-8" />
+<meta name="viewport" content="width=device-width, initial-scale=1.0">
+
+<title>dataAnalysisHyy</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%; margin: 0; }
+td.linenos pre { color: #000000; background-color: #f0f0f0; padding-left: 5px; padding-right: 5px; }
+span.linenos { color: #000000; background-color: #f0f0f0; padding-left: 5px; padding-right: 5px; }
+td.linenos pre.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;
+}
+
+/*
+ * 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;
+}
+
+/*
+ * 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;
+}
+
+/*-----------------------------------------------------------------------------
+| 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;
+}
+
+
+/* <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";
+/*!
+
+Copyright 2015-present Palantir Technologies, Inc. All rights reserved.
+Licensed under the Apache License, Version 2.0.
+
+*/
+html{
+  -webkit-box-sizing:border-box;
+          box-sizing:border-box; }
+
+*,
+*::before,
+*::after{
+  -webkit-box-sizing:inherit;
+          box-sizing:inherit; }
+
+body{
+  text-transform:none;
+  line-height:1.28581;
+  letter-spacing:0;
+  font-size:14px;
+  font-weight:400;
+  color:#182026;
+  font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; }
+
+p{
+  margin-top:0;
+  margin-bottom:10px; }
+
+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{
+  line-height:40px;
+  font-size:36px; }
+
+h2.bp3-heading, .bp3-running-text h2{
+  line-height:32px;
+  font-size:28px; }
+
+h3.bp3-heading, .bp3-running-text h3{
+  line-height:25px;
+  font-size:22px; }
+
+h4.bp3-heading, .bp3-running-text h4{
+  line-height:21px;
+  font-size:18px; }
+
+h5.bp3-heading, .bp3-running-text h5{
+  line-height:19px;
+  font-size:16px; }
+
+h6.bp3-heading, .bp3-running-text h6{
+  line-height:16px;
+  font-size:14px; }
+.bp3-ui-text{
+  text-transform:none;
+  line-height:1.28581;
+  letter-spacing:0;
+  font-size:14px;
+  font-weight:400; }
+
+.bp3-monospace-text{
+  text-transform:none;
+  font-family:monospace; }
+
+.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{
+  line-height:1.5;
+  font-size:14px; }
+  .bp3-running-text h1{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h1{
+      color:#f5f8fa; }
+  .bp3-running-text h2{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h2{
+      color:#f5f8fa; }
+  .bp3-running-text h3{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h3{
+      color:#f5f8fa; }
+  .bp3-running-text h4{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h4{
+      color:#f5f8fa; }
+  .bp3-running-text h5{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h5{
+      color:#f5f8fa; }
+  .bp3-running-text h6{
+    color:#182026;
+    font-weight:600;
+    margin-top:40px;
+    margin-bottom:20px; }
+    .bp3-dark .bp3-running-text h6{
+      color:#f5f8fa; }
+  .bp3-running-text hr{
+    margin:20px 0;
+    border:none;
+    border-bottom:1px solid rgba(16, 22, 26, 0.15); }
+    .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{
+  text-decoration:none;
+  color:#106ba3; }
+  a:hover{
+    cursor:pointer;
+    text-decoration:underline;
+    color:#106ba3; }
+  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{
+  text-transform:none;
+  font-family:monospace;
+  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);
+  background:rgba(255, 255, 255, 0.7);
+  padding:2px 5px;
+  color:#5c7080;
+  font-size:smaller; }
+  .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{
+    -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);
+    background:rgba(16, 22, 26, 0.3);
+    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{
+  text-transform:none;
+  font-family:monospace;
+  display:block;
+  margin:10px 0;
+  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);
+  background:rgba(255, 255, 255, 0.7);
+  padding:13px 15px 12px;
+  line-height:1.4;
+  color:#182026;
+  font-size:13px;
+  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{
+    -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);
+    background:rgba(16, 22, 26, 0.3);
+    color:#f5f8fa; }
+  .bp3-running-text pre > code, .bp3-code-block > code{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:none;
+    padding:0;
+    color:inherit;
+    font-size:inherit; }
+
+.bp3-running-text kbd, .bp3-key{
+  display:-webkit-inline-box;
+  display:-ms-inline-flexbox;
+  display:inline-flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  -webkit-box-pack:center;
+      -ms-flex-pack:center;
+          justify-content:center;
+  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);
+  background:#ffffff;
+  min-width:24px;
+  height:24px;
+  padding:3px 6px;
+  vertical-align:middle;
+  line-height:24px;
+  color:#5c7080;
+  font-family:inherit;
+  font-size:12px; }
+  .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{
+    -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);
+    background:#394b59;
+    color:#a7b6c2; }
+.bp3-running-text blockquote, .bp3-blockquote{
+  margin:0 0 10px;
+  border-left:solid 4px rgba(167, 182, 194, 0.5);
+  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{
+  margin:0;
+  padding:0;
+  list-style:none; }
+  .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{
+    margin-top:0;
+    margin-right:20px;
+    font-size:40px; }
+
+.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{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -ms-flex-wrap:wrap;
+      flex-wrap:wrap;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  margin:0;
+  cursor:default;
+  height:30px;
+  padding:0;
+  list-style:none; }
+  .bp3-breadcrumbs > li{
+    display:-webkit-box;
+    display:-ms-flexbox;
+    display:flex;
+    -webkit-box-align:center;
+        -ms-flex-align:center;
+            align-items:center; }
+    .bp3-breadcrumbs > li::after{
+      display:block;
+      margin:0 5px;
+      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 0 0-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 0 0 1.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e");
+      width:16px;
+      height:16px;
+      content:""; }
+    .bp3-breadcrumbs > li:last-of-type::after{
+      display:none; }
+
+.bp3-breadcrumb,
+.bp3-breadcrumb-current,
+.bp3-breadcrumbs-collapsed{
+  display:-webkit-inline-box;
+  display:-ms-inline-flexbox;
+  display:inline-flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  font-size:16px; }
+
+.bp3-breadcrumb,
+.bp3-breadcrumbs-collapsed{
+  color:#5c7080; }
+
+.bp3-breadcrumb:hover{
+  text-decoration:none; }
+
+.bp3-breadcrumb.bp3-disabled{
+  cursor:not-allowed;
+  color:rgba(92, 112, 128, 0.6); }
+
+.bp3-breadcrumb .bp3-icon{
+  margin-right:5px; }
+
+.bp3-breadcrumb-current{
+  color:inherit;
+  font-weight:600; }
+  .bp3-breadcrumb-current .bp3-input{
+    vertical-align:baseline;
+    font-size:inherit;
+    font-weight:inherit; }
+
+.bp3-breadcrumbs-collapsed{
+  margin-right:2px;
+  border:none;
+  border-radius:3px;
+  background:#ced9e0;
+  cursor:pointer;
+  padding:1px 5px;
+  vertical-align:text-bottom; }
+  .bp3-breadcrumbs-collapsed::before{
+    display:block;
+    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;
+    width:16px;
+    height:16px;
+    content:""; }
+  .bp3-breadcrumbs-collapsed:hover{
+    background:#bfccd6;
+    text-decoration:none;
+    color:#182026; }
+
+.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;
+  -webkit-box-pack:center;
+      -ms-flex-pack:center;
+          justify-content:center;
+  border:none;
+  border-radius:3px;
+  cursor:pointer;
+  padding:5px 10px;
+  vertical-align:middle;
+  text-align:left;
+  font-size:14px;
+  min-width:30px;
+  min-height: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-"]){
+    -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);
+    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));
+    color:#182026; }
+    .bp3-button:not([class*="bp3-intent-"]):hover{
+      -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);
+      background-clip:padding-box;
+      background-color:#ebf1f5; }
+    .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{
+      -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);
+      background-color:#d8e1e8;
+      background-image:none; }
+    .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
+      outline:none;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(206, 217, 224, 0.5);
+      background-image:none;
+      cursor:not-allowed;
+      color:rgba(92, 112, 128, 0.6); }
+      .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{
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#106ba3; }
+    .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{
+      -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);
+      background-color:#0e5a8a;
+      background-image:none; }
+    .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{
+      border-color:transparent;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(19, 124, 189, 0.5);
+      background-image:none;
+      color:rgba(255, 255, 255, 0.6); }
+  .bp3-button.bp3-intent-success{
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#0d8050; }
+    .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{
+      -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);
+      background-color:#0a6640;
+      background-image:none; }
+    .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{
+      border-color:transparent;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(15, 153, 96, 0.5);
+      background-image:none;
+      color:rgba(255, 255, 255, 0.6); }
+  .bp3-button.bp3-intent-warning{
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#bf7326; }
+    .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{
+      -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);
+      background-color:#a66321;
+      background-image:none; }
+    .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{
+      border-color:transparent;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(217, 130, 43, 0.5);
+      background-image:none;
+      color:rgba(255, 255, 255, 0.6); }
+  .bp3-button.bp3-intent-danger{
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#c23030; }
+    .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{
+      -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);
+      background-color:#a82a2a;
+      background-image:none; }
+    .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{
+      border-color:transparent;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(219, 55, 55, 0.5);
+      background-image: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-width:40px;
+    min-height:40px;
+    padding:5px 15px;
+    font-size:16px; }
+    .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-width:24px;
+    min-height: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{
+      position:absolute;
+      margin:0; }
+    .bp3-button.bp3-loading > :not(.bp3-button-spinner){
+      visibility:hidden; }
+  .bp3-button[class*="bp3-icon-"]::before{
+    line-height:1;
+    font-family:"Icons16", sans-serif;
+    font-size:16px;
+    font-weight:400;
+    font-style:normal;
+    -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-"]){
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#30404d; }
+    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{
+      -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);
+      background-color:#202b33;
+      background-image:none; }
+    .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(57, 75, 89, 0.5);
+      background-image: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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-image: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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:none; }
+    .bp3-button.bp3-minimal:hover{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(167, 182, 194, 0.3);
+      text-decoration:none;
+      color:#182026; }
+    .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(115, 134, 148, 0.3);
+      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;
+      cursor:not-allowed;
+      color:rgba(92, 112, 128, 0.6); }
+      .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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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;
+        cursor:not-allowed;
+        color:rgba(167, 182, 194, 0.6); }
+        .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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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); }
+
+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-top-left-radius:0;
+    border-bottom-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){
+    margin-right:-1px;
+    border-top-right-radius:0;
+    border-bottom-right-radius:0; }
+  .bp3-button-group.bp3-minimal .bp3-button{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:none; }
+    .bp3-button-group.bp3-minimal .bp3-button:hover{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(167, 182, 194, 0.3);
+      text-decoration:none;
+      color:#182026; }
+    .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(115, 134, 148, 0.3);
+      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;
+      cursor:not-allowed;
+      color:rgba(92, 112, 128, 0.6); }
+      .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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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;
+        cursor:not-allowed;
+        color:rgba(167, 182, 194, 0.6); }
+        .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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background: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-orient:vertical;
+    -webkit-box-direction:normal;
+        -ms-flex-direction:column;
+            flex-direction:column;
+    -webkit-box-align:stretch;
+        -ms-flex-align:stretch;
+            align-items:stretch;
+    vertical-align:top; }
+    .bp3-button-group.bp3-vertical.bp3-fill{
+      width:unset;
+      height:100%; }
+    .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{
+  line-height:1.5;
+  font-size:14px;
+  position:relative;
+  border-radius:3px;
+  background-color:rgba(138, 155, 168, 0.15);
+  width:100%;
+  padding:10px 12px 9px; }
+  .bp3-callout[class*="bp3-icon-"]{
+    padding-left:40px; }
+    .bp3-callout[class*="bp3-icon-"]::before{
+      line-height:1;
+      font-family:"Icons20", sans-serif;
+      font-size:20px;
+      font-weight:400;
+      font-style:normal;
+      -moz-osx-font-smoothing:grayscale;
+      -webkit-font-smoothing:antialiased;
+      position:absolute;
+      top:10px;
+      left:10px;
+      color:#5c7080; }
+  .bp3-callout.bp3-callout-icon{
+    padding-left:40px; }
+    .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{
+      position:absolute;
+      top:10px;
+      left:10px;
+      color:#5c7080; }
+  .bp3-callout .bp3-heading{
+    margin-top:0;
+    margin-bottom:5px;
+    line-height:20px; }
+    .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{
+  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);
+  background-color:#ffffff;
+  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{
+    -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);
+    background-color:#30404d; }
+
+.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{
+  opacity:0.9;
+  -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);
+  -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{
+  margin:5px;
+  border-right:1px solid rgba(16, 22, 26, 0.15);
+  border-bottom:1px solid rgba(16, 22, 26, 0.15); }
+  .bp3-dark .bp3-divider{
+    border-color:rgba(16, 22, 26, 0.4); }
+.bp3-dialog-container{
+  opacity:1;
+  -webkit-transform:scale(1);
+          transform:scale(1);
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  -webkit-box-pack:center;
+      -ms-flex-pack:center;
+          justify-content:center;
+  width:100%;
+  min-height:100%;
+  pointer-events:none;
+  -webkit-user-select:none;
+     -moz-user-select:none;
+      -ms-user-select:none;
+          user-select:none; }
+  .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-property:opacity, -webkit-transform;
+    transition-property:opacity, -webkit-transform;
+    transition-property:opacity, transform;
+    transition-property:opacity, transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:opacity, -webkit-transform;
+    transition-property:opacity, -webkit-transform;
+    transition-property:opacity, transform;
+    transition-property:opacity, transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+
+.bp3-dialog{
+  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;
+  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);
+  background:#ebf1f5;
+  width:500px;
+  padding-bottom:20px;
+  pointer-events:all;
+  -webkit-user-select:text;
+     -moz-user-select:text;
+      -ms-user-select:text;
+          user-select:text; }
+  .bp3-dialog:focus{
+    outline:0; }
+  .bp3-dialog.bp3-dark,
+  .bp3-dark .bp3-dialog{
+    -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);
+    background:#293742;
+    color:#f5f8fa; }
+
+.bp3-dialog-header{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-flex:0;
+      -ms-flex:0 0 auto;
+          flex:0 0 auto;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  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);
+  background:#ffffff;
+  min-height:40px;
+  padding-right:5px;
+  padding-left:20px; }
+  .bp3-dialog-header .bp3-icon-large,
+  .bp3-dialog-header .bp3-icon{
+    -webkit-box-flex:0;
+        -ms-flex:0 0 auto;
+            flex:0 0 auto;
+    margin-right:10px;
+    color:#5c7080; }
+  .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;
+    margin:0;
+    line-height:inherit; }
+    .bp3-dialog-header .bp3-heading:last-child{
+      margin-right:20px; }
+  .bp3-dark .bp3-dialog-header{
+    -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
+            box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
+    background:#30404d; }
+    .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;
+  margin:20px;
+  line-height:18px; }
+
+.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{
+  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;
+  -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);
+  background:#ffffff;
+  padding:0; }
+  .bp3-drawer:focus{
+    outline:0; }
+  .bp3-drawer.bp3-position-top{
+    top:0;
+    right:0;
+    left:0;
+    height:50%; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer.bp3-position-bottom{
+    right:0;
+    bottom:0;
+    left:0;
+    height:50%; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer.bp3-position-left{
+    top:0;
+    bottom:0;
+    left: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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer.bp3-position-right{
+    top:0;
+    right:0;
+    bottom: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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
+  .bp3-position-right):not(.bp3-vertical){
+    top:0;
+    right:0;
+    bottom: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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay: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{
+      -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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
+  .bp3-position-right).bp3-vertical{
+    right:0;
+    bottom:0;
+    left:0;
+    height:50%; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+    .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-property:-webkit-transform;
+      transition-property:-webkit-transform;
+      transition-property:transform;
+      transition-property:transform, -webkit-transform;
+      -webkit-transition-duration:100ms;
+              transition-duration:100ms;
+      -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);
+      -webkit-transition-delay:0;
+              transition-delay:0; }
+  .bp3-drawer.bp3-dark,
+  .bp3-dark .bp3-drawer{
+    -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);
+    background:#30404d;
+    color:#f5f8fa; }
+
+.bp3-drawer-header{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-flex:0;
+      -ms-flex:0 0 auto;
+          flex:0 0 auto;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  position:relative;
+  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);
+  min-height:40px;
+  padding:5px;
+  padding-left:20px; }
+  .bp3-drawer-header .bp3-icon-large,
+  .bp3-drawer-header .bp3-icon{
+    -webkit-box-flex:0;
+        -ms-flex:0 0 auto;
+            flex:0 0 auto;
+    margin-right:10px;
+    color:#5c7080; }
+  .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;
+    margin:0;
+    line-height:inherit; }
+    .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;
+  overflow:auto;
+  line-height:18px; }
+
+.bp3-drawer-footer{
+  -webkit-box-flex:0;
+      -ms-flex:0 0 auto;
+          flex:0 0 auto;
+  position:relative;
+  -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);
+  padding:10px 20px; }
+  .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{
+  display:inline-block;
+  position:relative;
+  cursor:text;
+  max-width:100%;
+  vertical-align:top;
+  white-space:nowrap; }
+  .bp3-editable-text::before{
+    position:absolute;
+    top:-3px;
+    right:-3px;
+    bottom:-3px;
+    left:-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{
+    -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);
+    background-color:#ffffff; }
+  .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{
+    -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);
+    background-color:rgba(16, 22, 26, 0.3); }
+  .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{
+  display:inherit;
+  position:relative;
+  min-width:inherit;
+  max-width:inherit;
+  vertical-align:top;
+  text-transform:inherit;
+  letter-spacing:inherit;
+  color:inherit;
+  font:inherit;
+  resize:none; }
+
+.bp3-editable-text-input{
+  border:none;
+  -webkit-box-shadow:none;
+          box-shadow:none;
+  background:none;
+  width:100%;
+  padding:0;
+  white-space:pre-wrap; }
+  .bp3-editable-text-input::-webkit-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-editable-text-input::-moz-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-editable-text-input:-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-editable-text-input::-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-editable-text-input::placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .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{
+    position:absolute;
+    left:0;
+    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-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{
+    z-index:2;
+    border-radius:inherit; }
+    .bp3-control-group .bp3-input:focus{
+      z-index:14;
+      border-radius:3px; }
+    .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);
+    z-index:4;
+    border-radius:inherit; }
+    .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:not(.bp3-vertical) > *{
+    margin-right:-1px; }
+  .bp3-dark .bp3-control-group:not(.bp3-vertical) > *{
+    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{
+    margin-right:0;
+    border-radius:0 3px 3px 0; }
+  .bp3-control-group > :only-child{
+    margin-right:0;
+    border-radius:3px; }
+  .bp3-control-group .bp3-input-group .bp3-button{
+    border-radius:3px; }
+  .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{
+      margin-top:0;
+      border-radius:3px 3px 0 0; }
+    .bp3-control-group.bp3-vertical > :last-child{
+      border-radius:0 0 3px 3px; }
+.bp3-control{
+  display:block;
+  position:relative;
+  margin-bottom:10px;
+  cursor:pointer;
+  text-transform:none; }
+  .bp3-control input:checked ~ .bp3-control-indicator{
+    -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);
+    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));
+    color:#ffffff; }
+  .bp3-control:hover input:checked ~ .bp3-control-indicator{
+    -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);
+    background-color:#106ba3; }
+  .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
+    -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);
+    background:#0e5a8a; }
+  .bp3-control input:disabled:checked ~ .bp3-control-indicator{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(19, 124, 189, 0.5); }
+  .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{
+    -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);
+    background-color:#106ba3; }
+  .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
+    -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);
+    background-color:#0e5a8a; }
+  .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(14, 90, 138, 0.5); }
+  .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{
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-control.bp3-inline{
+    display:inline-block;
+    margin-right:20px; }
+  .bp3-control input{
+    position:absolute;
+    top:0;
+    left:0;
+    opacity:0;
+    z-index:-1; }
+  .bp3-control .bp3-control-indicator{
+    display:inline-block;
+    position:relative;
+    margin-top:-3px;
+    margin-right:10px;
+    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);
+    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));
+    cursor:pointer;
+    width:1em;
+    height:1em;
+    vertical-align:middle;
+    font-size:16px;
+    -webkit-user-select:none;
+       -moz-user-select:none;
+        -ms-user-select:none;
+            user-select:none; }
+    .bp3-control .bp3-control-indicator::before{
+      display:block;
+      width:1em;
+      height:1em;
+      content:""; }
+  .bp3-control:hover .bp3-control-indicator{
+    background-color:#ebf1f5; }
+  .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
+    -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);
+    background:#d8e1e8; }
+  .bp3-control input:disabled ~ .bp3-control-indicator{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(206, 217, 224, 0.5);
+    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-top:1px;
+    margin-left:10px; }
+  .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{
+    -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);
+    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));
+    color:#ffffff; }
+  .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{
+    -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);
+    background-color:#106ba3; }
+  .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
+    -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);
+    background:#0e5a8a; }
+  .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(19, 124, 189, 0.5); }
+  .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{
+    -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);
+    background-color:#106ba3; }
+  .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
+    -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);
+    background-color:#0e5a8a; }
+  .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(14, 90, 138, 0.5); }
+  .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 0 0-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0 0 12 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;
+    width:auto;
+    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); }
+    .bp3-control.bp3-switch .bp3-control-indicator::before{
+      position:absolute;
+      left:0;
+      margin:2px;
+      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);
+      background:#ffffff;
+      width:calc(1em - 4px);
+      height:calc(1em - 4px);
+      -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); }
+  .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{
+    -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);
+    background:#394b59; }
+  .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{
+    text-align:center;
+    font-size:0.7em; }
+  .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{
+    visibility:hidden;
+    margin-right:1.2em;
+    margin-left:0.5em;
+    line-height:0; }
+  .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{
+    visibility:visible;
+    margin-right:0.5em;
+    margin-left:1.2em;
+    line-height:1em; }
+  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{
+    visibility:visible;
+    line-height:1em; }
+  .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{
+    visibility:hidden;
+    line-height:0; }
+  .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{
+      -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);
+      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)); }
+    .bp3-dark .bp3-control:hover .bp3-control-indicator{
+      background-color:#30404d; }
+    .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
+      -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);
+      background:#202b33; }
+    .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(57, 75, 89, 0.5);
+      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{
+  display:inline-block;
+  position:relative;
+  cursor:pointer;
+  height:30px; }
+  .bp3-file-input input{
+    opacity:0;
+    margin:0;
+    min-width:200px; }
+    .bp3-file-input input:disabled + .bp3-file-upload-input,
+    .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(206, 217, 224, 0.5);
+      cursor:not-allowed;
+      color:rgba(92, 112, 128, 0.6);
+      resize:none; }
+      .bp3-file-input input:disabled + .bp3-file-upload-input::after,
+      .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{
+        outline:none;
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background-color:rgba(206, 217, 224, 0.5);
+        background-image:none;
+        cursor:not-allowed;
+        color:rgba(92, 112, 128, 0.6); }
+        .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{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background:rgba(57, 75, 89, 0.5);
+        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{
+          -webkit-box-shadow:none;
+                  box-shadow:none;
+          background-color:rgba(57, 75, 89, 0.5);
+          background-image: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{
+  outline:none;
+  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);
+  background:#ffffff;
+  height:30px;
+  padding:0 10px;
+  vertical-align:middle;
+  line-height:30px;
+  color:#182026;
+  font-size:14px;
+  font-weight:400;
+  -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);
+  -webkit-appearance:none;
+     -moz-appearance:none;
+          appearance:none;
+  overflow:hidden;
+  text-overflow:ellipsis;
+  white-space:nowrap;
+  word-wrap:normal;
+  position:absolute;
+  top:0;
+  right:0;
+  left:0;
+  padding-right:80px;
+  color:rgba(92, 112, 128, 0.6);
+  -webkit-user-select:none;
+     -moz-user-select:none;
+      -ms-user-select:none;
+          user-select:none; }
+  .bp3-file-upload-input::-webkit-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-file-upload-input::-moz-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-file-upload-input:-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-file-upload-input::-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-file-upload-input::placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(206, 217, 224, 0.5);
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6);
+    resize:none; }
+  .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);
+    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));
+    color:#182026;
+    min-width:24px;
+    min-height:24px;
+    overflow:hidden;
+    text-overflow:ellipsis;
+    white-space:nowrap;
+    word-wrap:normal;
+    position:absolute;
+    top:0;
+    right:0;
+    margin:3px;
+    border-radius:3px;
+    width:70px;
+    text-align:center;
+    line-height:24px;
+    content:"Browse"; }
+    .bp3-file-upload-input::after:hover{
+      -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);
+      background-clip:padding-box;
+      background-color:#ebf1f5; }
+    .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{
+      -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);
+      background-color:#d8e1e8;
+      background-image:none; }
+    .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{
+      outline:none;
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(206, 217, 224, 0.5);
+      background-image:none;
+      cursor:not-allowed;
+      color:rgba(92, 112, 128, 0.6); }
+      .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{
+    -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);
+    background-clip:padding-box;
+    background-color:#ebf1f5; }
+  .bp3-file-upload-input:active::after{
+    -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);
+    background-color:#d8e1e8;
+    background-image:none; }
+  .bp3-large .bp3-file-upload-input{
+    height:40px;
+    line-height:40px;
+    font-size:16px;
+    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-width:30px;
+      min-height:30px;
+      margin:5px;
+      width:85px;
+      line-height:30px; }
+  .bp3-dark .bp3-file-upload-input{
+    -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);
+    background:rgba(16, 22, 26, 0.3);
+    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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(57, 75, 89, 0.5);
+      color:rgba(167, 182, 194, 0.6); }
+    .bp3-dark .bp3-file-upload-input::after{
+      -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);
+      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));
+      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{
+        -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);
+        background-color:#30404d; }
+      .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{
+        -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);
+        background-color:#202b33;
+        background-image:none; }
+      .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background-color:rgba(57, 75, 89, 0.5);
+        background-image: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{
+      -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);
+      background-color:#30404d; }
+    .bp3-dark .bp3-file-upload-input:active::after{
+      -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);
+      background-color:#202b33;
+      background-image:none; }
+
+.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{
+    margin-top:5px;
+    color:#5c7080;
+    font-size:12px; }
+  .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-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; }
+    .bp3-form-group.bp3-inline.bp3-large label.bp3-label{
+      margin:0 10px 0 0;
+      line-height:40px; }
+    .bp3-form-group.bp3-inline label.bp3-label{
+      margin:0 10px 0 0;
+      line-height:30px; }
+  .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-button,
+  .bp3-input-group > .bp3-icon{
+    position:absolute;
+    top:0; }
+    .bp3-input-group .bp3-input-action: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-button:last-child,
+    .bp3-input-group > .bp3-icon:last-child{
+      right:0; }
+  .bp3-input-group .bp3-button{
+    min-width:24px;
+    min-height:24px;
+    margin:3px;
+    padding:0 7px; }
+    .bp3-input-group .bp3-button:empty{
+      padding:0; }
+  .bp3-input-group > .bp3-icon{
+    z-index:1;
+    color:#5c7080; }
+    .bp3-input-group > .bp3-icon:empty{
+      line-height:1;
+      font-family:"Icons16", sans-serif;
+      font-size:16px;
+      font-weight:400;
+      font-style:normal;
+      -moz-osx-font-smoothing:grayscale;
+      -webkit-font-smoothing:antialiased; }
+  .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-width:30px;
+    min-height:30px;
+    margin:5px; }
+  .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{
+    height:40px;
+    line-height:40px;
+    font-size:16px; }
+    .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-width:20px;
+    min-height:20px;
+    margin:2px; }
+  .bp3-input-group.bp3-small .bp3-tag{
+    min-width:20px;
+    min-height:20px;
+    margin:2px; }
+  .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{
+    height:24px;
+    padding-right:8px;
+    padding-left:8px;
+    line-height:24px;
+    font-size:12px; }
+    .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{
+  outline:none;
+  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);
+  background:#ffffff;
+  height:30px;
+  padding:0 10px;
+  vertical-align:middle;
+  line-height:30px;
+  color:#182026;
+  font-size:14px;
+  font-weight:400;
+  -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);
+  -webkit-appearance:none;
+     -moz-appearance:none;
+          appearance:none; }
+  .bp3-input::-webkit-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input::-moz-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input:-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input::-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input::placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(206, 217, 224, 0.5);
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6);
+    resize:none; }
+  .bp3-input.bp3-large{
+    height:40px;
+    line-height:40px;
+    font-size:16px; }
+    .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{
+      padding:0 15px; }
+  .bp3-input.bp3-small{
+    height:24px;
+    padding-right:8px;
+    padding-left:8px;
+    line-height:24px;
+    font-size:12px; }
+    .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{
+    -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);
+    background:rgba(16, 22, 26, 0.3);
+    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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(57, 75, 89, 0.5);
+      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{
+    -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);
+    background:rgba(16, 22, 26, 0.3);
+    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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background:rgba(57, 75, 89, 0.5);
+      color:rgba(167, 182, 194, 0.6); }
+label.bp3-label{
+  display:block;
+  margin-top:0;
+  margin-bottom:15px; }
+  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{
+    width:100%;
+    vertical-align:top;
+    font-weight:400; }
+  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;
+  width:30px;
+  min-height:0;
+  padding:0; }
+  .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;
+  -webkit-box-pack:center;
+      -ms-flex-pack:center;
+          justify-content:center;
+  border:none;
+  border-radius:3px;
+  cursor:pointer;
+  padding:5px 10px;
+  vertical-align:middle;
+  text-align:left;
+  font-size:14px;
+  -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);
+  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));
+  color:#182026;
+  border-radius:3px;
+  width:100%;
+  height:30px;
+  padding:0 25px 0 10px;
+  -moz-appearance:none;
+  -webkit-appearance:none; }
+  .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{
+    -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);
+    background-clip:padding-box;
+    background-color:#ebf1f5; }
+  .bp3-html-select select:active,
+  .bp3-select select:active, .bp3-html-select select.bp3-active,
+  .bp3-select select.bp3-active{
+    -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);
+    background-color:#d8e1e8;
+    background-image:none; }
+  .bp3-html-select select:disabled,
+  .bp3-select select:disabled, .bp3-html-select select.bp3-disabled,
+  .bp3-select select.bp3-disabled{
+    outline:none;
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background-color:rgba(206, 217, 224, 0.5);
+    background-image:none;
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+    .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{
+  -webkit-box-shadow:none;
+          box-shadow:none;
+  background:none; }
+  .bp3-html-select.bp3-minimal select:hover,
+  .bp3-select.bp3-minimal select:hover{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(167, 182, 194, 0.3);
+    text-decoration:none;
+    color:#182026; }
+  .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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:rgba(115, 134, 148, 0.3);
+    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;
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+    .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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background: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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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;
+      cursor:not-allowed;
+      color:rgba(167, 182, 194, 0.6); }
+      .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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background: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{
+  height:40px;
+  padding-right:35px;
+  font-size:16px; }
+
+.bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{
+  -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);
+  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));
+  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{
+    -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);
+    background-color:#30404d; }
+  .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{
+    -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);
+    background-color:#202b33;
+    background-image:none; }
+  .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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background-color:rgba(57, 75, 89, 0.5);
+    background-image: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{
+  -webkit-box-shadow:none;
+          box-shadow:none;
+  background-color:rgba(206, 217, 224, 0.5);
+  cursor:not-allowed;
+  color:rgba(92, 112, 128, 0.6); }
+
+.bp3-html-select .bp3-icon,
+.bp3-select .bp3-icon, .bp3-select::after{
+  position:absolute;
+  top:7px;
+  right:7px;
+  color:#5c7080;
+  pointer-events:none; }
+  .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;
+  position:relative;
+  vertical-align:middle;
+  letter-spacing:normal; }
+  .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{
+    top:12px;
+    right: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::after, .bp3-dark
+  .bp3-select::after{
+    color:#a7b6c2; }
+
+.bp3-select::after{
+  line-height:1;
+  font-family:"Icons16", sans-serif;
+  font-size:16px;
+  font-weight:400;
+  font-style:normal;
+  -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;
+    vertical-align:top;
+    text-align:left; }
+  .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-top:6px;
+  padding-bottom: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-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{
+  top:40px;
+  padding-bottom:0; }
+  .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{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  -webkit-box-pack:justify;
+      -ms-flex-pack:justify;
+          justify-content:space-between;
+  margin-right:0;
+  margin-left: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{
+  line-height:1;
+  font-family:"Icons16", sans-serif;
+  font-size:16px;
+  font-weight:400;
+  font-style:normal;
+  -moz-osx-font-smoothing:grayscale;
+  -webkit-font-smoothing:antialiased;
+  display:inline-block; }
+
+span.bp3-icon-large{
+  line-height:1;
+  font-family:"Icons20", sans-serif;
+  font-size:20px;
+  font-weight:400;
+  font-style:normal;
+  -moz-osx-font-smoothing:grayscale;
+  -webkit-font-smoothing:antialiased;
+  display:inline-block; }
+
+span.bp3-icon:empty{
+  line-height:1;
+  font-family:"Icons20";
+  font-size:inherit;
+  font-weight:400;
+  font-style:normal; }
+  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-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-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{
+  -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{
+  margin:0;
+  border-radius:3px;
+  background:#ffffff;
+  min-width:180px;
+  padding:5px;
+  list-style:none;
+  text-align:left;
+  color:#182026; }
+
+.bp3-menu-divider{
+  display:block;
+  margin:5px;
+  border-top:1px solid rgba(16, 22, 26, 0.15); }
+  .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;
+  padding:5px 7px;
+  text-decoration:none;
+  line-height:20px;
+  color:inherit;
+  -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;
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+  .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{
+    line-height:1;
+    font-family:"Icons16", sans-serif;
+    font-size:16px;
+    font-weight:400;
+    font-style:normal;
+    -moz-osx-font-smoothing:grayscale;
+    -webkit-font-smoothing:antialiased;
+    margin-right:7px; }
+  .bp3-menu-item::before,
+  .bp3-menu-item > .bp3-icon{
+    margin-top:2px;
+    color:#5c7080; }
+  .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{
+    outline:none !important;
+    background-color:inherit !important;
+    cursor:not-allowed !important;
+    color:rgba(92, 112, 128, 0.6) !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{
+    padding:9px 7px;
+    line-height:22px;
+    font-size:16px; }
+    .bp3-large .bp3-menu-item .bp3-icon{
+      margin-top:3px; }
+    .bp3-large .bp3-menu-item::before{
+      line-height:1;
+      font-family:"Icons20", sans-serif;
+      font-size:20px;
+      font-weight:400;
+      font-style:normal;
+      -moz-osx-font-smoothing:grayscale;
+      -webkit-font-smoothing:antialiased;
+      margin-top:1px;
+      margin-right:10px; }
+
+button.bp3-menu-item{
+  border:none;
+  background:none;
+  width:100%;
+  text-align:left; }
+.bp3-menu-header{
+  display:block;
+  margin:5px;
+  border-top:1px solid rgba(16, 22, 26, 0.15);
+  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;
+    margin:0;
+    padding:10px 7px 0 1px;
+    line-height:17px; }
+    .bp3-dark .bp3-menu-header > h6{
+      color:#f5f8fa; }
+  .bp3-menu-header:first-of-type > h6{
+    padding-top:0; }
+  .bp3-large .bp3-menu-header > h6{
+    padding-top:15px;
+    padding-bottom:5px;
+    font-size:18px; }
+  .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-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{
+  position:relative;
+  z-index:10;
+  -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);
+  background-color:#ffffff;
+  width:100%;
+  height:50px;
+  padding:0 15px; }
+  .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{
+    position:fixed;
+    top:0;
+    right:0;
+    left:0; }
+
+.bp3-navbar-heading{
+  margin-right:15px;
+  font-size:16px; }
+
+.bp3-navbar-group{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  height:50px; }
+  .bp3-navbar-group.bp3-align-left{
+    float:left; }
+  .bp3-navbar-group.bp3-align-right{
+    float:right; }
+
+.bp3-navbar-divider{
+  margin:0 10px;
+  border-left:1px solid rgba(16, 22, 26, 0.15);
+  height:20px; }
+  .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;
+  -webkit-box-pack:center;
+      -ms-flex-pack:center;
+          justify-content:center;
+  width:100%;
+  height:100%;
+  text-align:center; }
+  .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{
+  position:static;
+  top:0;
+  right:0;
+  bottom:0;
+  left:0;
+  z-index:20; }
+  .bp3-overlay:not(.bp3-overlay-open){
+    pointer-events:none; }
+  .bp3-overlay.bp3-overlay-container{
+    position:fixed;
+    overflow:hidden; }
+    .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{
+      position:absolute; }
+  .bp3-overlay.bp3-overlay-scroll-container{
+    position:fixed;
+    overflow:auto; }
+    .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{
+  position:fixed;
+  top:0;
+  right:0;
+  bottom:0;
+  left:0;
+  opacity:1;
+  z-index:20;
+  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; }
+  .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-property:opacity;
+    transition-property:opacity;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .bp3-overlay-backdrop.bp3-overlay-exit{
+    opacity:1; }
+  .bp3-overlay-backdrop.bp3-overlay-exit-active{
+    opacity:0;
+    -webkit-transition-property:opacity;
+    transition-property:opacity;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .bp3-overlay-backdrop:focus{
+    outline:none; }
+  .bp3-overlay-inline .bp3-overlay-backdrop{
+    position:absolute; }
+.bp3-panel-stack{
+  position:relative;
+  overflow:hidden; }
+
+.bp3-panel-stack-header{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -ms-flex-negative:0;
+      flex-shrink:0;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  z-index:1;
+  -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15);
+          box-shadow:0 1px rgba(16, 22, 26, 0.15);
+  height:30px; }
+  .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{
+    display:-webkit-box;
+    display:-ms-flexbox;
+    display:flex;
+    -webkit-box-flex:1;
+        -ms-flex:1;
+            flex:1;
+    -webkit-box-align:stretch;
+        -ms-flex-align:stretch;
+            align-items:stretch; }
+  .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{
+  position:absolute;
+  top:0;
+  right:0;
+  bottom:0;
+  left:0;
+  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;
+  border-right:1px solid rgba(16, 22, 26, 0.15);
+  background-color:#ffffff;
+  overflow-y:auto; }
+  .bp3-dark .bp3-panel-stack-view{
+    background-color:#30404d; }
+
+.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-property:opacity, -webkit-transform;
+  transition-property:opacity, -webkit-transform;
+  transition-property:transform, opacity;
+  transition-property:transform, opacity, -webkit-transform;
+  -webkit-transition-duration:400ms;
+          transition-duration:400ms;
+  -webkit-transition-timing-function:ease;
+          transition-timing-function:ease;
+  -webkit-transition-delay:0;
+          transition-delay:0; }
+
+.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-property:opacity, -webkit-transform;
+  transition-property:opacity, -webkit-transform;
+  transition-property:transform, opacity;
+  transition-property:transform, opacity, -webkit-transform;
+  -webkit-transition-duration:400ms;
+          transition-duration:400ms;
+  -webkit-transition-timing-function:ease;
+          transition-timing-function:ease;
+  -webkit-transition-delay:0;
+          transition-delay:0; }
+
+.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-property:opacity, -webkit-transform;
+  transition-property:opacity, -webkit-transform;
+  transition-property:transform, opacity;
+  transition-property:transform, opacity, -webkit-transform;
+  -webkit-transition-duration:400ms;
+          transition-duration:400ms;
+  -webkit-transition-timing-function:ease;
+          transition-timing-function:ease;
+  -webkit-transition-delay:0;
+          transition-delay:0; }
+
+.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-property:opacity, -webkit-transform;
+  transition-property:opacity, -webkit-transform;
+  transition-property:transform, opacity;
+  transition-property:transform, opacity, -webkit-transform;
+  -webkit-transition-duration:400ms;
+          transition-duration:400ms;
+  -webkit-transition-timing-function:ease;
+          transition-timing-function:ease;
+  -webkit-transition-delay:0;
+          transition-delay:0; }
+.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);
+  display:inline-block;
+  z-index:20;
+  border-radius:3px; }
+  .bp3-popover .bp3-popover-arrow{
+    position:absolute;
+    width:30px;
+    height:30px; }
+    .bp3-popover .bp3-popover-arrow::before{
+      margin:5px;
+      width:20px;
+      height:20px; }
+  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{
+    margin-top:-17px;
+    margin-bottom: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-right:17px;
+    margin-left:-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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .bp3-popover .bp3-popover-content{
+    position:relative;
+    border-radius:3px; }
+  .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-property:-webkit-transform;
+        transition-property:-webkit-transform;
+        transition-property:transform;
+        transition-property:transform, -webkit-transform;
+        -webkit-transition-duration:100ms;
+                transition-duration:100ms;
+        -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);
+        -webkit-transition-delay:0;
+                transition-delay:0; }
+      .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-property:-webkit-transform;
+        transition-property:-webkit-transform;
+        transition-property:transform;
+        transition-property:transform, -webkit-transform;
+        -webkit-transition-duration:100ms;
+                transition-duration:100ms;
+        -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);
+        -webkit-transition-delay:0;
+                transition-delay:0; }
+  .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{
+  display:block;
+  position:absolute;
+  -webkit-transform:rotate(45deg);
+          transform:rotate(45deg);
+  border-radius:2px;
+  content:""; }
+
+.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-property:opacity;
+    transition-property:opacity;
+    -webkit-transition-duration:100ms;
+            transition-duration:100ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .bp3-transition-container.bp3-popover-exit{
+    opacity:1; }
+  .bp3-transition-container.bp3-popover-exit-active{
+    opacity:0;
+    -webkit-transition-property:opacity;
+    transition-property:opacity;
+    -webkit-transition-duration:100ms;
+            transition-duration:100ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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{
+  position:absolute;
+  top:0;
+  right:0;
+  left: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{
+  display:block;
+  position:relative;
+  border-radius:40px;
+  background:rgba(92, 112, 128, 0.2);
+  width:100%;
+  height:8px;
+  overflow:hidden; }
+  .bp3-progress-bar .bp3-progress-meter{
+    position:absolute;
+    border-radius:40px;
+    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;
+    width:100%;
+    height:100%;
+    -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); }
+  .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{
+    border-color:rgba(206, 217, 224, 0.2);
+    background:rgba(206, 217, 224, 0.2); }
+  to{
+    border-color:rgba(92, 112, 128, 0.2);
+    background:rgba(92, 112, 128, 0.2); } }
+@keyframes skeleton-glow{
+  from{
+    border-color:rgba(206, 217, 224, 0.2);
+    background:rgba(206, 217, 224, 0.2); }
+  to{
+    border-color:rgba(92, 112, 128, 0.2);
+    background:rgba(92, 112, 128, 0.2); } }
+.bp3-skeleton{
+  border-color:rgba(206, 217, 224, 0.2) !important;
+  border-radius:2px;
+  -webkit-box-shadow:none !important;
+          box-shadow:none !important;
+  background:rgba(206, 217, 224, 0.2);
+  background-clip:padding-box !important;
+  cursor:default;
+  color:transparent !important;
+  -webkit-animation:1000ms linear infinite alternate skeleton-glow;
+          animation:1000ms linear infinite alternate skeleton-glow;
+  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{
+  width:100%;
+  min-width:150px;
+  height:40px;
+  position:relative;
+  outline:none;
+  cursor:default;
+  -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{
+    opacity:0.5;
+    cursor:not-allowed; }
+  .bp3-slider.bp3-slider-unlabeled{
+    height:16px; }
+
+.bp3-slider-track,
+.bp3-slider-progress{
+  top:5px;
+  right:0;
+  left:0;
+  height:6px;
+  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{
+  -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);
+  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));
+  color:#182026;
+  position:absolute;
+  top:0;
+  left:0;
+  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;
+  width:16px;
+  height:16px; }
+  .bp3-slider-handle:hover{
+    -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);
+    background-clip:padding-box;
+    background-color:#ebf1f5; }
+  .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{
+    -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);
+    background-color:#d8e1e8;
+    background-image:none; }
+  .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{
+    outline:none;
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background-color:rgba(206, 217, 224, 0.5);
+    background-image:none;
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+    .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{
+    -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);
+    background-clip:padding-box;
+    background-color:#ebf1f5;
+    z-index:2;
+    -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; }
+  .bp3-slider-handle.bp3-active{
+    -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);
+    background-color:#d8e1e8;
+    background-image:none;
+    -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{
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:#bfccd6;
+    pointer-events:none; }
+  .bp3-dark .bp3-slider-handle{
+    -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);
+    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));
+    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{
+      -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);
+      background-color:#30404d; }
+    .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{
+      -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);
+      background-color:#202b33;
+      background-image:none; }
+    .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{
+      -webkit-box-shadow:none;
+              box-shadow:none;
+      background-color:rgba(57, 75, 89, 0.5);
+      background-image: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{
+    border-color:#5c7080;
+    -webkit-box-shadow:none;
+            box-shadow:none;
+    background:#5c7080; }
+  .bp3-slider-handle .bp3-slider-label{
+    margin-left:8px;
+    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);
+    background:#394b59;
+    color:#f5f8fa; }
+    .bp3-dark .bp3-slider-handle .bp3-slider-label{
+      -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);
+      background:#e1e8ed;
+      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-top-right-radius:0;
+    border-bottom-right-radius:0; }
+  .bp3-slider-handle.bp3-end{
+    margin-left:8px;
+    border-top-left-radius:0;
+    border-bottom-left-radius:0; }
+    .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;
+  position:absolute;
+  padding:2px 5px;
+  vertical-align:top;
+  line-height:1;
+  font-size:12px; }
+
+.bp3-slider.bp3-vertical{
+  width:40px;
+  min-width:40px;
+  height:150px; }
+  .bp3-slider.bp3-vertical .bp3-slider-track,
+  .bp3-slider.bp3-vertical .bp3-slider-progress{
+    top:0;
+    bottom:0;
+    left:5px;
+    width:6px;
+    height:auto; }
+  .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-top:-8px;
+      margin-left:0; }
+    .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
+      margin-left:0;
+      width:16px;
+      height:8px; }
+    .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
+      border-top-left-radius:0;
+      border-bottom-right-radius:3px; }
+      .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{
+      margin-bottom:8px;
+      border-top-left-radius:3px;
+      border-bottom-left-radius:0;
+      border-bottom-right-radius:0; }
+
+@-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{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  -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{
+    -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);
+    stroke:rgba(92, 112, 128, 0.8);
+    stroke-linecap:round; }
+  .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-orient:vertical;
+    -webkit-box-direction:normal;
+        -ms-flex-direction:column;
+            flex-direction:column;
+    -webkit-box-align:start;
+        -ms-flex-align:start;
+            align-items:flex-start; }
+    .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{
+      border-radius:3px;
+      width:100%;
+      padding:0 10px; }
+      .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{
+        -webkit-box-shadow:none;
+                box-shadow:none;
+        background-color:rgba(19, 124, 189, 0.2); }
+    .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{
+      top:0;
+      right:0;
+      bottom:0;
+      left:0;
+      border-radius:3px;
+      background-color:rgba(19, 124, 189, 0.2);
+      height:auto; }
+  .bp3-tabs.bp3-vertical > .bp3-tab-panel{
+    margin-top:0;
+    padding-left:20px; }
+
+.bp3-tab-list{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-flex:0;
+      -ms-flex:0 0 auto;
+          flex:0 0 auto;
+  -webkit-box-align:end;
+      -ms-flex-align:end;
+          align-items:flex-end;
+  position:relative;
+  margin:0;
+  border:none;
+  padding:0;
+  list-style:none; }
+  .bp3-tab-list > *:not(:last-child){
+    margin-right:20px; }
+
+.bp3-tab{
+  overflow:hidden;
+  text-overflow:ellipsis;
+  white-space:nowrap;
+  word-wrap:normal;
+  -webkit-box-flex:0;
+      -ms-flex:0 0 auto;
+          flex:0 0 auto;
+  position:relative;
+  cursor:pointer;
+  max-width:100%;
+  vertical-align:top;
+  line-height:30px;
+  color:#182026;
+  font-size:14px; }
+  .bp3-tab a{
+    display:block;
+    text-decoration:none;
+    color:inherit; }
+  .bp3-tab-indicator-wrapper ~ .bp3-tab{
+    -webkit-box-shadow:none !important;
+            box-shadow:none !important;
+    background-color:transparent !important; }
+  .bp3-tab[aria-disabled="true"]{
+    cursor:not-allowed;
+    color:rgba(92, 112, 128, 0.6); }
+  .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{
+    line-height:40px;
+    font-size:16px; }
+
+.bp3-tab-panel{
+  margin-top:20px; }
+  .bp3-tab-panel[aria-hidden="true"]{
+    display:none; }
+
+.bp3-tab-indicator-wrapper{
+  position:absolute;
+  top:0;
+  left: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);
+  pointer-events:none; }
+  .bp3-tab-indicator-wrapper .bp3-tab-indicator{
+    position:absolute;
+    right:0;
+    bottom:0;
+    left:0;
+    background-color:#106ba3;
+    height:3px; }
+  .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;
+  position:relative;
+  border:none;
+  border-radius:3px;
+  -webkit-box-shadow:none;
+          box-shadow:none;
+  background-color:#5c7080;
+  min-width:20px;
+  max-width:100%;
+  min-height:20px;
+  padding:2px 6px;
+  line-height:16px;
+  color:#f5f8fa;
+  font-size:12px; }
+  .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-right:8px;
+    padding-left: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{
+    min-width:30px;
+    min-height:30px;
+    padding:0 10px;
+    line-height:20px;
+    font-size:14px; }
+    .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-right:12px;
+      padding-left: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{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  opacity:0.5;
+  margin-top:-2px;
+  margin-right:-6px !important;
+  margin-bottom:-2px;
+  border:none;
+  background:none;
+  cursor:pointer;
+  padding:2px;
+  padding-left:0;
+  color:inherit; }
+  .bp3-tag-remove:hover{
+    opacity:0.8;
+    background:none;
+    text-decoration:none; }
+  .bp3-tag-remove:active{
+    opacity:1; }
+  .bp3-tag-remove:empty::before{
+    line-height:1;
+    font-family:"Icons16", sans-serif;
+    font-size:16px;
+    font-weight:400;
+    font-style:normal;
+    -moz-osx-font-smoothing:grayscale;
+    -webkit-font-smoothing:antialiased;
+    content:"î›—"; }
+  .bp3-large .bp3-tag-remove{
+    margin-right:-10px !important;
+    padding:5px;
+    padding-left:0; }
+    .bp3-large .bp3-tag-remove:empty::before{
+      line-height:1;
+      font-family:"Icons20", sans-serif;
+      font-size:20px;
+      font-weight:400;
+      font-style:normal; }
+.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;
+  min-height:30px;
+  padding-right:0;
+  padding-left:5px;
+  line-height:inherit; }
+  .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{
+    margin-top:7px;
+    margin-right:7px;
+    margin-left:2px;
+    color:#5c7080; }
+  .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;
+    -ms-flex-wrap:wrap;
+        flex-wrap:wrap;
+    -webkit-box-align:center;
+        -ms-flex-align:center;
+            align-items:center;
+    -ms-flex-item-align:stretch;
+        align-self:stretch;
+    margin-top:5px;
+    margin-right:7px;
+    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;
+    width:80px;
+    line-height:20px; }
+    .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-width:24px;
+    min-height: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-top:10px;
+      margin-left:5px; }
+    .bp3-tag-input.bp3-large .bp3-input-ghost{
+      line-height:30px; }
+    .bp3-tag-input.bp3-large .bp3-button{
+      min-width:30px;
+      min-height: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{
+    -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);
+    background-color:#ffffff; }
+    .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{
+    -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);
+    background-color:rgba(16, 22, 26, 0.3); }
+    .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{
+  border:none;
+  -webkit-box-shadow:none;
+          box-shadow:none;
+  background:none;
+  padding:0; }
+  .bp3-input-ghost::-webkit-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input-ghost::-moz-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input-ghost:-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input-ghost::-ms-input-placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input-ghost::placeholder{
+    opacity:1;
+    color:rgba(92, 112, 128, 0.6); }
+  .bp3-input-ghost:focus{
+    outline:none !important; }
+.bp3-toast{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:start;
+      -ms-flex-align:start;
+          align-items:flex-start;
+  position:relative !important;
+  margin:20px 0 0;
+  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);
+  background-color:#ffffff;
+  min-width:300px;
+  max-width:500px;
+  pointer-events:all; }
+  .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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:opacity, -webkit-filter;
+    transition-property:opacity, -webkit-filter;
+    transition-property:opacity, filter;
+    transition-property:opacity, filter, -webkit-filter;
+    -webkit-transition-duration:300ms;
+            transition-duration:300ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:100ms;
+            transition-duration:100ms;
+    -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);
+    -webkit-transition-delay:50ms;
+            transition-delay:50ms; }
+  .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{
+    margin:12px;
+    margin-right:0;
+    color:#5c7080; }
+  .bp3-toast.bp3-dark,
+  .bp3-dark .bp3-toast{
+    -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);
+    background-color:#394b59; }
+    .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{
+  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;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  position:fixed;
+  right:0;
+  left:0;
+  z-index:40;
+  overflow:hidden;
+  padding:0 20px 20px;
+  pointer-events:none; }
+  .bp3-toast-container.bp3-toast-container-top{
+    top:0;
+    bottom:auto; }
+  .bp3-toast-container.bp3-toast-container-bottom{
+    -webkit-box-orient:vertical;
+    -webkit-box-direction:reverse;
+        -ms-flex-direction:column-reverse;
+            flex-direction:column-reverse;
+    top:auto;
+    bottom:0; }
+  .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-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{
+    position:absolute;
+    width:22px;
+    height:22px; }
+    .bp3-tooltip .bp3-popover-arrow::before{
+      margin:4px;
+      width:14px;
+      height:14px; }
+  .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{
+    margin-top:-11px;
+    margin-bottom: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-right:11px;
+    margin-left:-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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:100ms;
+            transition-duration:100ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:-webkit-transform;
+    transition-property:-webkit-transform;
+    transition-property:transform;
+    transition-property:transform, -webkit-transform;
+    -webkit-transition-duration:100ms;
+            transition-duration:100ms;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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{
+  margin:0;
+  padding-left:0;
+  list-style:none; }
+
+.bp3-tree-root{
+  position:relative;
+  background-color:transparent;
+  cursor:default;
+  padding-left:0; }
+
+.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{
+  display:-webkit-box;
+  display:-ms-flexbox;
+  display:flex;
+  -webkit-box-align:center;
+      -ms-flex-align:center;
+          align-items:center;
+  width:100%;
+  height:30px;
+  padding-right:5px; }
+  .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;
+  -webkit-transform:rotate(0deg);
+          transform:rotate(0deg);
+  cursor:pointer;
+  padding:7px;
+  -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{
+  position:relative;
+  margin-right:7px; }
+
+.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{
+    display:-webkit-box;
+    display:-ms-flexbox;
+    display:flex;
+    -webkit-box-align:center;
+        -ms-flex-align:center;
+            align-items:center; }
+
+.bp3-tree-node.bp3-disabled .bp3-tree-node-content{
+  background-color:inherit;
+  cursor:not-allowed;
+  color:rgba(92, 112, 128, 0.6); }
+
+.bp3-tree-node.bp3-disabled .bp3-tree-node-caret,
+.bp3-tree-node.bp3-disabled .bp3-tree-node-icon{
+  cursor:not-allowed;
+  color:rgba(92, 112, 128, 0.6); }
+
+.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; }
+/*!
+
+Copyright 2017-present Palantir Technologies, Inc. All rights reserved.
+Licensed under the Apache License, Version 2.0.
+
+*/
+.bp3-omnibar{
+  -webkit-filter:blur(0);
+          filter:blur(0);
+  opacity:1;
+  top:20vh;
+  left:calc(50% - 250px);
+  z-index:21;
+  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);
+  background-color:#ffffff;
+  width:500px; }
+  .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-property:opacity, -webkit-filter;
+    transition-property:opacity, -webkit-filter;
+    transition-property:filter, opacity;
+    transition-property:filter, opacity, -webkit-filter;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .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-property:opacity, -webkit-filter;
+    transition-property:opacity, -webkit-filter;
+    transition-property:filter, opacity;
+    transition-property:filter, opacity, -webkit-filter;
+    -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);
+    -webkit-transition-delay:0;
+            transition-delay:0; }
+  .bp3-omnibar .bp3-input{
+    border-radius:0;
+    background-color:transparent; }
+    .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{
+      -webkit-box-shadow:none;
+              box-shadow:none; }
+  .bp3-omnibar .bp3-menu{
+    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);
+    background-color:transparent;
+    max-height:calc(60vh - 40px);
+    overflow:auto; }
+    .bp3-omnibar .bp3-menu:empty{
+      display:none; }
+  .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{
+    -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);
+    background-color:#30404d; }
+
+.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-width:400px;
+  max-height:300px;
+  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-width:400px;
+  max-height:300px;
+  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-width:400px;
+  max-height:300px;
+  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();
+  --jp-icon-bug: url();
+  --jp-icon-build: url();
+  --jp-icon-caret-down-empty-thin: url();
+  --jp-icon-caret-down-empty: url();
+  --jp-icon-caret-down: url();
+  --jp-icon-caret-left: url();
+  --jp-icon-caret-right: url();
+  --jp-icon-caret-up-empty-thin: url();
+  --jp-icon-caret-up: url();
+  --jp-icon-case-sensitive: url();
+  --jp-icon-check: url();
+  --jp-icon-circle-empty: url();
+  --jp-icon-circle: url();
+  --jp-icon-clear: url();
+  --jp-icon-close: url();
+  --jp-icon-console: url();
+  --jp-icon-copy: url();
+  --jp-icon-cut: url();
+  --jp-icon-download: url();
+  --jp-icon-edit: url();
+  --jp-icon-ellipses: url();
+  --jp-icon-extension: url();
+  --jp-icon-fast-forward: url();
+  --jp-icon-file-upload: url();
+  --jp-icon-file: url();
+  --jp-icon-filter-list: url();
+  --jp-icon-folder: url();
+  --jp-icon-html5: url();
+  --jp-icon-image: url();
+  --jp-icon-inspector: url();
+  --jp-icon-json: url();
+  --jp-icon-jupyter-favicon: url();
+  --jp-icon-jupyter: url();
+  --jp-icon-jupyterlab-wordmark: url();
+  --jp-icon-kernel: url();
+  --jp-icon-keyboard: url();
+  --jp-icon-launcher: url();
+  --jp-icon-line-form: url();
+  --jp-icon-link: url();
+  --jp-icon-list: url();
+  --jp-icon-listings-info: url();
+  --jp-icon-markdown: url();
+  --jp-icon-new-folder: url();
+  --jp-icon-not-trusted: url();
+  --jp-icon-notebook: url();
+  --jp-icon-palette: url();
+  --jp-icon-paste: url();
+  --jp-icon-python: url();
+  --jp-icon-r-kernel: url();
+  --jp-icon-react: url();
+  --jp-icon-refresh: url();
+  --jp-icon-regex: url();
+  --jp-icon-run: url();
+  --jp-icon-running: url();
+  --jp-icon-save: url();
+  --jp-icon-search: url();
+  --jp-icon-settings: url();
+  --jp-icon-spreadsheet: url();
+  --jp-icon-stop: url();
+  --jp-icon-tab: url();
+  --jp-icon-terminal: url();
+  --jp-icon-text-editor: url();
+  --jp-icon-trusted: url();
+  --jp-icon-undo: url();
+  --jp-icon-vega: url();
+  --jp-icon-yaml: url();
+}
+
+/* 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-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-PaletteIcon {
+  background-image: var(--jp-icon-palette);
+}
+.jp-PasteIcon {
+  background-image: var(--jp-icon-paste);
+}
+.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-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-TerminalIcon {
+  background-image: var(--jp-icon-terminal);
+}
+.jp-TextEditorIcon {
+  background-image: var(--jp-icon-text-editor);
+}
+.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();
+}
+
+.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.
+|----------------------------------------------------------------------------*/
+
+/* 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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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);
+}
+
+/*-----------------------------------------------------------------------------
+| 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);
+}
+
+.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;
+}
+
+.jp-Dialog-header {
+  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;
+}
+
+/* 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);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) 2014-2017, 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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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);
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* 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 */
+  /* 30px is the magic margin used to hide the element's real scrollbars */
+  /* See overflow: hidden in .CodeMirror */
+  margin-bottom: -30px; margin-right: -30px;
+  padding-bottom: 30px;
+  height: 100%;
+  outline: none; /* Prevent dragging from highlighting the element */
+  position: relative;
+}
+.CodeMirror-sizer {
+  position: relative;
+  border-right: 30px 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: -30px;
+}
+.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";
+}
+
+/*
+  Name:       material
+  Author:     Mattia Astorino (http://github.com/equinusocio)
+  Website:    https://material-theme.site/
+*/
+
+.cm-s-material.CodeMirror {
+  background-color: #263238;
+  color: #EEFFFF;
+}
+
+.cm-s-material .CodeMirror-gutters {
+  background: #263238;
+  color: #546E7A;
+  border: none;
+}
+
+.cm-s-material .CodeMirror-guttermarker,
+.cm-s-material .CodeMirror-guttermarker-subtle,
+.cm-s-material .CodeMirror-linenumber {
+  color: #546E7A;
+}
+
+.cm-s-material .CodeMirror-cursor {
+  border-left: 1px solid #FFCC00;
+}
+
+.cm-s-material div.CodeMirror-selected {
+  background: rgba(128, 203, 196, 0.2);
+}
+
+.cm-s-material.CodeMirror-focused div.CodeMirror-selected {
+  background: rgba(128, 203, 196, 0.2);
+}
+
+.cm-s-material .CodeMirror-line::selection,
+.cm-s-material .CodeMirror-line>span::selection,
+.cm-s-material .CodeMirror-line>span>span::selection {
+  background: rgba(128, 203, 196, 0.2);
+}
+
+.cm-s-material .CodeMirror-line::-moz-selection,
+.cm-s-material .CodeMirror-line>span::-moz-selection,
+.cm-s-material .CodeMirror-line>span>span::-moz-selection {
+  background: rgba(128, 203, 196, 0.2);
+}
+
+.cm-s-material .CodeMirror-activeline-background {
+  background: rgba(0, 0, 0, 0.5);
+}
+
+.cm-s-material .cm-keyword {
+  color: #C792EA;
+}
+
+.cm-s-material .cm-operator {
+  color: #89DDFF;
+}
+
+.cm-s-material .cm-variable-2 {
+  color: #EEFFFF;
+}
+
+.cm-s-material .cm-variable-3,
+.cm-s-material .cm-type {
+  color: #f07178;
+}
+
+.cm-s-material .cm-builtin {
+  color: #FFCB6B;
+}
+
+.cm-s-material .cm-atom {
+  color: #F78C6C;
+}
+
+.cm-s-material .cm-number {
+  color: #FF5370;
+}
+
+.cm-s-material .cm-def {
+  color: #82AAFF;
+}
+
+.cm-s-material .cm-string {
+  color: #C3E88D;
+}
+
+.cm-s-material .cm-string-2 {
+  color: #f07178;
+}
+
+.cm-s-material .cm-comment {
+  color: #546E7A;
+}
+
+.cm-s-material .cm-variable {
+  color: #f07178;
+}
+
+.cm-s-material .cm-tag {
+  color: #FF5370;
+}
+
+.cm-s-material .cm-meta {
+  color: #FFCB6B;
+}
+
+.cm-s-material .cm-attribute {
+  color: #C792EA;
+}
+
+.cm-s-material .cm-property {
+  color: #C792EA;
+}
+
+.cm-s-material .cm-qualifier {
+  color: #DECB6B;
+}
+
+.cm-s-material .cm-variable-3,
+.cm-s-material .cm-type {
+  color: #DECB6B;
+}
+
+
+.cm-s-material .cm-error {
+  color: rgba(255, 255, 255, 1.0);
+  background-color: #FF5370;
+}
+
+.cm-s-material .CodeMirror-matchingbracket {
+  text-decoration: underline;
+  color: white !important;
+}
+/**
+ * "
+ *  Using Zenburn color palette from the Emacs Zenburn Theme
+ *  https://github.com/bbatsov/zenburn-emacs/blob/master/zenburn-theme.el
+ *
+ *  Also using parts of https://github.com/xavi/coderay-lighttable-theme
+ * "
+ * From: https://github.com/wisenomad/zenburn-lighttable-theme/blob/master/zenburn.css
+ */
+
+.cm-s-zenburn .CodeMirror-gutters { background: #3f3f3f !important; }
+.cm-s-zenburn .CodeMirror-foldgutter-open, .CodeMirror-foldgutter-folded { color: #999; }
+.cm-s-zenburn .CodeMirror-cursor { border-left: 1px solid white; }
+.cm-s-zenburn { background-color: #3f3f3f; color: #dcdccc; }
+.cm-s-zenburn span.cm-builtin { color: #dcdccc; font-weight: bold; }
+.cm-s-zenburn span.cm-comment { color: #7f9f7f; }
+.cm-s-zenburn span.cm-keyword { color: #f0dfaf; font-weight: bold; }
+.cm-s-zenburn span.cm-atom { color: #bfebbf; }
+.cm-s-zenburn span.cm-def { color: #dcdccc; }
+.cm-s-zenburn span.cm-variable { color: #dfaf8f; }
+.cm-s-zenburn span.cm-variable-2 { color: #dcdccc; }
+.cm-s-zenburn span.cm-string { color: #cc9393; }
+.cm-s-zenburn span.cm-string-2 { color: #cc9393; }
+.cm-s-zenburn span.cm-number { color: #dcdccc; }
+.cm-s-zenburn span.cm-tag { color: #93e0e3; }
+.cm-s-zenburn span.cm-property { color: #dfaf8f; }
+.cm-s-zenburn span.cm-attribute { color: #dfaf8f; }
+.cm-s-zenburn span.cm-qualifier { color: #7cb8bb; }
+.cm-s-zenburn span.cm-meta { color: #f0dfaf; }
+.cm-s-zenburn span.cm-header { color: #f0efd0; }
+.cm-s-zenburn span.cm-operator { color: #f0efd0; }
+.cm-s-zenburn span.CodeMirror-matchingbracket { box-sizing: border-box; background: transparent; border-bottom: 1px solid; }
+.cm-s-zenburn span.CodeMirror-nonmatchingbracket { border-bottom: 1px solid; background: none; }
+.cm-s-zenburn .CodeMirror-activeline { background: #000000; }
+.cm-s-zenburn .CodeMirror-activeline-background { background: #000000; }
+.cm-s-zenburn div.CodeMirror-selected { background: #545454; }
+.cm-s-zenburn .CodeMirror-focused div.CodeMirror-selected { background: #4f4f4f; }
+
+.cm-s-abcdef.CodeMirror { background: #0f0f0f; color: #defdef; }
+.cm-s-abcdef div.CodeMirror-selected { background: #515151; }
+.cm-s-abcdef .CodeMirror-line::selection, .cm-s-abcdef .CodeMirror-line > span::selection, .cm-s-abcdef .CodeMirror-line > span > span::selection { background: rgba(56, 56, 56, 0.99); }
+.cm-s-abcdef .CodeMirror-line::-moz-selection, .cm-s-abcdef .CodeMirror-line > span::-moz-selection, .cm-s-abcdef .CodeMirror-line > span > span::-moz-selection { background: rgba(56, 56, 56, 0.99); }
+.cm-s-abcdef .CodeMirror-gutters { background: #555; border-right: 2px solid #314151; }
+.cm-s-abcdef .CodeMirror-guttermarker { color: #222; }
+.cm-s-abcdef .CodeMirror-guttermarker-subtle { color: azure; }
+.cm-s-abcdef .CodeMirror-linenumber { color: #FFFFFF; }
+.cm-s-abcdef .CodeMirror-cursor { border-left: 1px solid #00FF00; }
+
+.cm-s-abcdef span.cm-keyword { color: darkgoldenrod; font-weight: bold; }
+.cm-s-abcdef span.cm-atom { color: #77F; }
+.cm-s-abcdef span.cm-number { color: violet; }
+.cm-s-abcdef span.cm-def { color: #fffabc; }
+.cm-s-abcdef span.cm-variable { color: #abcdef; }
+.cm-s-abcdef span.cm-variable-2 { color: #cacbcc; }
+.cm-s-abcdef span.cm-variable-3, .cm-s-abcdef span.cm-type { color: #def; }
+.cm-s-abcdef span.cm-property { color: #fedcba; }
+.cm-s-abcdef span.cm-operator { color: #ff0; }
+.cm-s-abcdef span.cm-comment { color: #7a7b7c; font-style: italic;}
+.cm-s-abcdef span.cm-string { color: #2b4; }
+.cm-s-abcdef span.cm-meta { color: #C9F; }
+.cm-s-abcdef span.cm-qualifier { color: #FFF700; }
+.cm-s-abcdef span.cm-builtin { color: #30aabc; }
+.cm-s-abcdef span.cm-bracket { color: #8a8a8a; }
+.cm-s-abcdef span.cm-tag { color: #FFDD44; }
+.cm-s-abcdef span.cm-attribute { color: #DDFF00; }
+.cm-s-abcdef span.cm-error { color: #FF0000; }
+.cm-s-abcdef span.cm-header { color: aquamarine; font-weight: bold; }
+.cm-s-abcdef span.cm-link { color: blueviolet; }
+
+.cm-s-abcdef .CodeMirror-activeline-background { background: #314151; }
+
+/*
+
+    Name:       Base16 Default Light
+    Author:     Chris Kempson (http://chriskempson.com)
+
+    CodeMirror template by Jan T. Sott (https://github.com/idleberg/base16-codemirror)
+    Original Base16 color scheme by Chris Kempson (https://github.com/chriskempson/base16)
+
+*/
+
+.cm-s-base16-light.CodeMirror { background: #f5f5f5; color: #202020; }
+.cm-s-base16-light div.CodeMirror-selected { background: #e0e0e0; }
+.cm-s-base16-light .CodeMirror-line::selection, .cm-s-base16-light .CodeMirror-line > span::selection, .cm-s-base16-light .CodeMirror-line > span > span::selection { background: #e0e0e0; }
+.cm-s-base16-light .CodeMirror-line::-moz-selection, .cm-s-base16-light .CodeMirror-line > span::-moz-selection, .cm-s-base16-light .CodeMirror-line > span > span::-moz-selection { background: #e0e0e0; }
+.cm-s-base16-light .CodeMirror-gutters { background: #f5f5f5; border-right: 0px; }
+.cm-s-base16-light .CodeMirror-guttermarker { color: #ac4142; }
+.cm-s-base16-light .CodeMirror-guttermarker-subtle { color: #b0b0b0; }
+.cm-s-base16-light .CodeMirror-linenumber { color: #b0b0b0; }
+.cm-s-base16-light .CodeMirror-cursor { border-left: 1px solid #505050; }
+
+.cm-s-base16-light span.cm-comment { color: #8f5536; }
+.cm-s-base16-light span.cm-atom { color: #aa759f; }
+.cm-s-base16-light span.cm-number { color: #aa759f; }
+
+.cm-s-base16-light span.cm-property, .cm-s-base16-light span.cm-attribute { color: #90a959; }
+.cm-s-base16-light span.cm-keyword { color: #ac4142; }
+.cm-s-base16-light span.cm-string { color: #f4bf75; }
+
+.cm-s-base16-light span.cm-variable { color: #90a959; }
+.cm-s-base16-light span.cm-variable-2 { color: #6a9fb5; }
+.cm-s-base16-light span.cm-def { color: #d28445; }
+.cm-s-base16-light span.cm-bracket { color: #202020; }
+.cm-s-base16-light span.cm-tag { color: #ac4142; }
+.cm-s-base16-light span.cm-link { color: #aa759f; }
+.cm-s-base16-light span.cm-error { background: #ac4142; color: #505050; }
+
+.cm-s-base16-light .CodeMirror-activeline-background { background: #DDDCDC; }
+.cm-s-base16-light .CodeMirror-matchingbracket { color: #f5f5f5 !important; background-color: #6A9FB5 !important}
+
+/*
+
+    Name:       Base16 Default Dark
+    Author:     Chris Kempson (http://chriskempson.com)
+
+    CodeMirror template by Jan T. Sott (https://github.com/idleberg/base16-codemirror)
+    Original Base16 color scheme by Chris Kempson (https://github.com/chriskempson/base16)
+
+*/
+
+.cm-s-base16-dark.CodeMirror { background: #151515; color: #e0e0e0; }
+.cm-s-base16-dark div.CodeMirror-selected { background: #303030; }
+.cm-s-base16-dark .CodeMirror-line::selection, .cm-s-base16-dark .CodeMirror-line > span::selection, .cm-s-base16-dark .CodeMirror-line > span > span::selection { background: rgba(48, 48, 48, .99); }
+.cm-s-base16-dark .CodeMirror-line::-moz-selection, .cm-s-base16-dark .CodeMirror-line > span::-moz-selection, .cm-s-base16-dark .CodeMirror-line > span > span::-moz-selection { background: rgba(48, 48, 48, .99); }
+.cm-s-base16-dark .CodeMirror-gutters { background: #151515; border-right: 0px; }
+.cm-s-base16-dark .CodeMirror-guttermarker { color: #ac4142; }
+.cm-s-base16-dark .CodeMirror-guttermarker-subtle { color: #505050; }
+.cm-s-base16-dark .CodeMirror-linenumber { color: #505050; }
+.cm-s-base16-dark .CodeMirror-cursor { border-left: 1px solid #b0b0b0; }
+
+.cm-s-base16-dark span.cm-comment { color: #8f5536; }
+.cm-s-base16-dark span.cm-atom { color: #aa759f; }
+.cm-s-base16-dark span.cm-number { color: #aa759f; }
+
+.cm-s-base16-dark span.cm-property, .cm-s-base16-dark span.cm-attribute { color: #90a959; }
+.cm-s-base16-dark span.cm-keyword { color: #ac4142; }
+.cm-s-base16-dark span.cm-string { color: #f4bf75; }
+
+.cm-s-base16-dark span.cm-variable { color: #90a959; }
+.cm-s-base16-dark span.cm-variable-2 { color: #6a9fb5; }
+.cm-s-base16-dark span.cm-def { color: #d28445; }
+.cm-s-base16-dark span.cm-bracket { color: #e0e0e0; }
+.cm-s-base16-dark span.cm-tag { color: #ac4142; }
+.cm-s-base16-dark span.cm-link { color: #aa759f; }
+.cm-s-base16-dark span.cm-error { background: #ac4142; color: #b0b0b0; }
+
+.cm-s-base16-dark .CodeMirror-activeline-background { background: #202020; }
+.cm-s-base16-dark .CodeMirror-matchingbracket { text-decoration: underline; color: white !important; }
+
+/*
+
+    Name:       dracula
+    Author:     Michael Kaminsky (http://github.com/mkaminsky11)
+
+    Original dracula color scheme by Zeno Rocha (https://github.com/zenorocha/dracula-theme)
+
+*/
+
+
+.cm-s-dracula.CodeMirror, .cm-s-dracula .CodeMirror-gutters {
+  background-color: #282a36 !important;
+  color: #f8f8f2 !important;
+  border: none;
+}
+.cm-s-dracula .CodeMirror-gutters { color: #282a36; }
+.cm-s-dracula .CodeMirror-cursor { border-left: solid thin #f8f8f0; }
+.cm-s-dracula .CodeMirror-linenumber { color: #6D8A88; }
+.cm-s-dracula .CodeMirror-selected { background: rgba(255, 255, 255, 0.10); }
+.cm-s-dracula .CodeMirror-line::selection, .cm-s-dracula .CodeMirror-line > span::selection, .cm-s-dracula .CodeMirror-line > span > span::selection { background: rgba(255, 255, 255, 0.10); }
+.cm-s-dracula .CodeMirror-line::-moz-selection, .cm-s-dracula .CodeMirror-line > span::-moz-selection, .cm-s-dracula .CodeMirror-line > span > span::-moz-selection { background: rgba(255, 255, 255, 0.10); }
+.cm-s-dracula span.cm-comment { color: #6272a4; }
+.cm-s-dracula span.cm-string, .cm-s-dracula span.cm-string-2 { color: #f1fa8c; }
+.cm-s-dracula span.cm-number { color: #bd93f9; }
+.cm-s-dracula span.cm-variable { color: #50fa7b; }
+.cm-s-dracula span.cm-variable-2 { color: white; }
+.cm-s-dracula span.cm-def { color: #50fa7b; }
+.cm-s-dracula span.cm-operator { color: #ff79c6; }
+.cm-s-dracula span.cm-keyword { color: #ff79c6; }
+.cm-s-dracula span.cm-atom { color: #bd93f9; }
+.cm-s-dracula span.cm-meta { color: #f8f8f2; }
+.cm-s-dracula span.cm-tag { color: #ff79c6; }
+.cm-s-dracula span.cm-attribute { color: #50fa7b; }
+.cm-s-dracula span.cm-qualifier { color: #50fa7b; }
+.cm-s-dracula span.cm-property { color: #66d9ef; }
+.cm-s-dracula span.cm-builtin { color: #50fa7b; }
+.cm-s-dracula span.cm-variable-3, .cm-s-dracula span.cm-type { color: #ffb86c; }
+
+.cm-s-dracula .CodeMirror-activeline-background { background: rgba(255,255,255,0.1); }
+.cm-s-dracula .CodeMirror-matchingbracket { text-decoration: underline; color: white !important; }
+
+/*
+
+    Name:       Hopscotch
+    Author:     Jan T. Sott
+
+    CodeMirror template by Jan T. Sott (https://github.com/idleberg/base16-codemirror)
+    Original Base16 color scheme by Chris Kempson (https://github.com/chriskempson/base16)
+
+*/
+
+.cm-s-hopscotch.CodeMirror {background: #322931; color: #d5d3d5;}
+.cm-s-hopscotch div.CodeMirror-selected {background: #433b42 !important;}
+.cm-s-hopscotch .CodeMirror-gutters {background: #322931; border-right: 0px;}
+.cm-s-hopscotch .CodeMirror-linenumber {color: #797379;}
+.cm-s-hopscotch .CodeMirror-cursor {border-left: 1px solid #989498 !important;}
+
+.cm-s-hopscotch span.cm-comment {color: #b33508;}
+.cm-s-hopscotch span.cm-atom {color: #c85e7c;}
+.cm-s-hopscotch span.cm-number {color: #c85e7c;}
+
+.cm-s-hopscotch span.cm-property, .cm-s-hopscotch span.cm-attribute {color: #8fc13e;}
+.cm-s-hopscotch span.cm-keyword {color: #dd464c;}
+.cm-s-hopscotch span.cm-string {color: #fdcc59;}
+
+.cm-s-hopscotch span.cm-variable {color: #8fc13e;}
+.cm-s-hopscotch span.cm-variable-2 {color: #1290bf;}
+.cm-s-hopscotch span.cm-def {color: #fd8b19;}
+.cm-s-hopscotch span.cm-error {background: #dd464c; color: #989498;}
+.cm-s-hopscotch span.cm-bracket {color: #d5d3d5;}
+.cm-s-hopscotch span.cm-tag {color: #dd464c;}
+.cm-s-hopscotch span.cm-link {color: #c85e7c;}
+
+.cm-s-hopscotch .CodeMirror-matchingbracket { text-decoration: underline; color: white !important;}
+.cm-s-hopscotch .CodeMirror-activeline-background { background: #302020; }
+
+/****************************************************************/
+/*   Based on mbonaci's Brackets mbo theme                      */
+/*   https://github.com/mbonaci/global/blob/master/Mbo.tmTheme  */
+/*   Create your own: http://tmtheme-editor.herokuapp.com       */
+/****************************************************************/
+
+.cm-s-mbo.CodeMirror { background: #2c2c2c; color: #ffffec; }
+.cm-s-mbo div.CodeMirror-selected { background: #716C62; }
+.cm-s-mbo .CodeMirror-line::selection, .cm-s-mbo .CodeMirror-line > span::selection, .cm-s-mbo .CodeMirror-line > span > span::selection { background: rgba(113, 108, 98, .99); }
+.cm-s-mbo .CodeMirror-line::-moz-selection, .cm-s-mbo .CodeMirror-line > span::-moz-selection, .cm-s-mbo .CodeMirror-line > span > span::-moz-selection { background: rgba(113, 108, 98, .99); }
+.cm-s-mbo .CodeMirror-gutters { background: #4e4e4e; border-right: 0px; }
+.cm-s-mbo .CodeMirror-guttermarker { color: white; }
+.cm-s-mbo .CodeMirror-guttermarker-subtle { color: grey; }
+.cm-s-mbo .CodeMirror-linenumber { color: #dadada; }
+.cm-s-mbo .CodeMirror-cursor { border-left: 1px solid #ffffec; }
+
+.cm-s-mbo span.cm-comment { color: #95958a; }
+.cm-s-mbo span.cm-atom { color: #00a8c6; }
+.cm-s-mbo span.cm-number { color: #00a8c6; }
+
+.cm-s-mbo span.cm-property, .cm-s-mbo span.cm-attribute { color: #9ddfe9; }
+.cm-s-mbo span.cm-keyword { color: #ffb928; }
+.cm-s-mbo span.cm-string { color: #ffcf6c; }
+.cm-s-mbo span.cm-string.cm-property { color: #ffffec; }
+
+.cm-s-mbo span.cm-variable { color: #ffffec; }
+.cm-s-mbo span.cm-variable-2 { color: #00a8c6; }
+.cm-s-mbo span.cm-def { color: #ffffec; }
+.cm-s-mbo span.cm-bracket { color: #fffffc; font-weight: bold; }
+.cm-s-mbo span.cm-tag { color: #9ddfe9; }
+.cm-s-mbo span.cm-link { color: #f54b07; }
+.cm-s-mbo span.cm-error { border-bottom: #636363; color: #ffffec; }
+.cm-s-mbo span.cm-qualifier { color: #ffffec; }
+
+.cm-s-mbo .CodeMirror-activeline-background { background: #494b41; }
+.cm-s-mbo .CodeMirror-matchingbracket { color: #ffb928 !important; }
+.cm-s-mbo .CodeMirror-matchingtag { background: rgba(255, 255, 255, .37); }
+
+/*
+  MDN-LIKE Theme - Mozilla
+  Ported to CodeMirror by Peter Kroon <plakroon@gmail.com>
+  Report bugs/issues here: https://github.com/codemirror/CodeMirror/issues
+  GitHub: @peterkroon
+
+  The mdn-like theme is inspired on the displayed code examples at: https://developer.mozilla.org/en-US/docs/Web/CSS/animation
+
+*/
+.cm-s-mdn-like.CodeMirror { color: #999; background-color: #fff; }
+.cm-s-mdn-like div.CodeMirror-selected { background: #cfc; }
+.cm-s-mdn-like .CodeMirror-line::selection, .cm-s-mdn-like .CodeMirror-line > span::selection, .cm-s-mdn-like .CodeMirror-line > span > span::selection { background: #cfc; }
+.cm-s-mdn-like .CodeMirror-line::-moz-selection, .cm-s-mdn-like .CodeMirror-line > span::-moz-selection, .cm-s-mdn-like .CodeMirror-line > span > span::-moz-selection { background: #cfc; }
+
+.cm-s-mdn-like .CodeMirror-gutters { background: #f8f8f8; border-left: 6px solid rgba(0,83,159,0.65); color: #333; }
+.cm-s-mdn-like .CodeMirror-linenumber { color: #aaa; padding-left: 8px; }
+.cm-s-mdn-like .CodeMirror-cursor { border-left: 2px solid #222; }
+
+.cm-s-mdn-like .cm-keyword { color: #6262FF; }
+.cm-s-mdn-like .cm-atom { color: #F90; }
+.cm-s-mdn-like .cm-number { color:  #ca7841; }
+.cm-s-mdn-like .cm-def { color: #8DA6CE; }
+.cm-s-mdn-like span.cm-variable-2, .cm-s-mdn-like span.cm-tag { color: #690; }
+.cm-s-mdn-like span.cm-variable-3, .cm-s-mdn-like span.cm-def, .cm-s-mdn-like span.cm-type { color: #07a; }
+
+.cm-s-mdn-like .cm-variable { color: #07a; }
+.cm-s-mdn-like .cm-property { color: #905; }
+.cm-s-mdn-like .cm-qualifier { color: #690; }
+
+.cm-s-mdn-like .cm-operator { color: #cda869; }
+.cm-s-mdn-like .cm-comment { color:#777; font-weight:normal; }
+.cm-s-mdn-like .cm-string { color:#07a; font-style:italic; }
+.cm-s-mdn-like .cm-string-2 { color:#bd6b18; } /*?*/
+.cm-s-mdn-like .cm-meta { color: #000; } /*?*/
+.cm-s-mdn-like .cm-builtin { color: #9B7536; } /*?*/
+.cm-s-mdn-like .cm-tag { color: #997643; }
+.cm-s-mdn-like .cm-attribute { color: #d6bb6d; } /*?*/
+.cm-s-mdn-like .cm-header { color: #FF6400; }
+.cm-s-mdn-like .cm-hr { color: #AEAEAE; }
+.cm-s-mdn-like .cm-link { color:#ad9361; font-style:italic; text-decoration:none; }
+.cm-s-mdn-like .cm-error { border-bottom: 1px solid red; }
+
+div.cm-s-mdn-like .CodeMirror-activeline-background { background: #efefff; }
+div.cm-s-mdn-like span.CodeMirror-matchingbracket { outline:1px solid grey; color: inherit; }
+
+.cm-s-mdn-like.CodeMirror { background-image: url(); }
+
+/*
+
+    Name:       seti
+    Author:     Michael Kaminsky (http://github.com/mkaminsky11)
+
+    Original seti color scheme by Jesse Weed (https://github.com/jesseweed/seti-syntax)
+
+*/
+
+
+.cm-s-seti.CodeMirror {
+  background-color: #151718 !important;
+  color: #CFD2D1 !important;
+  border: none;
+}
+.cm-s-seti .CodeMirror-gutters {
+  color: #404b53;
+  background-color: #0E1112;
+  border: none;
+}
+.cm-s-seti .CodeMirror-cursor { border-left: solid thin #f8f8f0; }
+.cm-s-seti .CodeMirror-linenumber { color: #6D8A88; }
+.cm-s-seti.CodeMirror-focused div.CodeMirror-selected { background: rgba(255, 255, 255, 0.10); }
+.cm-s-seti .CodeMirror-line::selection, .cm-s-seti .CodeMirror-line > span::selection, .cm-s-seti .CodeMirror-line > span > span::selection { background: rgba(255, 255, 255, 0.10); }
+.cm-s-seti .CodeMirror-line::-moz-selection, .cm-s-seti .CodeMirror-line > span::-moz-selection, .cm-s-seti .CodeMirror-line > span > span::-moz-selection { background: rgba(255, 255, 255, 0.10); }
+.cm-s-seti span.cm-comment { color: #41535b; }
+.cm-s-seti span.cm-string, .cm-s-seti span.cm-string-2 { color: #55b5db; }
+.cm-s-seti span.cm-number { color: #cd3f45; }
+.cm-s-seti span.cm-variable { color: #55b5db; }
+.cm-s-seti span.cm-variable-2 { color: #a074c4; }
+.cm-s-seti span.cm-def { color: #55b5db; }
+.cm-s-seti span.cm-keyword { color: #ff79c6; }
+.cm-s-seti span.cm-operator { color: #9fca56; }
+.cm-s-seti span.cm-keyword { color: #e6cd69; }
+.cm-s-seti span.cm-atom { color: #cd3f45; }
+.cm-s-seti span.cm-meta { color: #55b5db; }
+.cm-s-seti span.cm-tag { color: #55b5db; }
+.cm-s-seti span.cm-attribute { color: #9fca56; }
+.cm-s-seti span.cm-qualifier { color: #9fca56; }
+.cm-s-seti span.cm-property { color: #a074c4; }
+.cm-s-seti span.cm-variable-3, .cm-s-seti span.cm-type { color: #9fca56; }
+.cm-s-seti span.cm-builtin { color: #9fca56; }
+.cm-s-seti .CodeMirror-activeline-background { background: #101213; }
+.cm-s-seti .CodeMirror-matchingbracket { text-decoration: underline; color: white !important; }
+
+/*
+Solarized theme for code-mirror
+http://ethanschoonover.com/solarized
+*/
+
+/*
+Solarized color palette
+http://ethanschoonover.com/solarized/img/solarized-palette.png
+*/
+
+.solarized.base03 { color: #002b36; }
+.solarized.base02 { color: #073642; }
+.solarized.base01 { color: #586e75; }
+.solarized.base00 { color: #657b83; }
+.solarized.base0 { color: #839496; }
+.solarized.base1 { color: #93a1a1; }
+.solarized.base2 { color: #eee8d5; }
+.solarized.base3  { color: #fdf6e3; }
+.solarized.solar-yellow  { color: #b58900; }
+.solarized.solar-orange  { color: #cb4b16; }
+.solarized.solar-red { color: #dc322f; }
+.solarized.solar-magenta { color: #d33682; }
+.solarized.solar-violet  { color: #6c71c4; }
+.solarized.solar-blue { color: #268bd2; }
+.solarized.solar-cyan { color: #2aa198; }
+.solarized.solar-green { color: #859900; }
+
+/* Color scheme for code-mirror */
+
+.cm-s-solarized {
+  line-height: 1.45em;
+  color-profile: sRGB;
+  rendering-intent: auto;
+}
+.cm-s-solarized.cm-s-dark {
+  color: #839496;
+  background-color: #002b36;
+  text-shadow: #002b36 0 1px;
+}
+.cm-s-solarized.cm-s-light {
+  background-color: #fdf6e3;
+  color: #657b83;
+  text-shadow: #eee8d5 0 1px;
+}
+
+.cm-s-solarized .CodeMirror-widget {
+  text-shadow: none;
+}
+
+.cm-s-solarized .cm-header { color: #586e75; }
+.cm-s-solarized .cm-quote { color: #93a1a1; }
+
+.cm-s-solarized .cm-keyword { color: #cb4b16; }
+.cm-s-solarized .cm-atom { color: #d33682; }
+.cm-s-solarized .cm-number { color: #d33682; }
+.cm-s-solarized .cm-def { color: #2aa198; }
+
+.cm-s-solarized .cm-variable { color: #839496; }
+.cm-s-solarized .cm-variable-2 { color: #b58900; }
+.cm-s-solarized .cm-variable-3, .cm-s-solarized .cm-type { color: #6c71c4; }
+
+.cm-s-solarized .cm-property { color: #2aa198; }
+.cm-s-solarized .cm-operator { color: #6c71c4; }
+
+.cm-s-solarized .cm-comment { color: #586e75; font-style:italic; }
+
+.cm-s-solarized .cm-string { color: #859900; }
+.cm-s-solarized .cm-string-2 { color: #b58900; }
+
+.cm-s-solarized .cm-meta { color: #859900; }
+.cm-s-solarized .cm-qualifier { color: #b58900; }
+.cm-s-solarized .cm-builtin { color: #d33682; }
+.cm-s-solarized .cm-bracket { color: #cb4b16; }
+.cm-s-solarized .CodeMirror-matchingbracket { color: #859900; }
+.cm-s-solarized .CodeMirror-nonmatchingbracket { color: #dc322f; }
+.cm-s-solarized .cm-tag { color: #93a1a1; }
+.cm-s-solarized .cm-attribute { color: #2aa198; }
+.cm-s-solarized .cm-hr {
+  color: transparent;
+  border-top: 1px solid #586e75;
+  display: block;
+}
+.cm-s-solarized .cm-link { color: #93a1a1; cursor: pointer; }
+.cm-s-solarized .cm-special { color: #6c71c4; }
+.cm-s-solarized .cm-em {
+  color: #999;
+  text-decoration: underline;
+  text-decoration-style: dotted;
+}
+.cm-s-solarized .cm-error,
+.cm-s-solarized .cm-invalidchar {
+  color: #586e75;
+  border-bottom: 1px dotted #dc322f;
+}
+
+.cm-s-solarized.cm-s-dark div.CodeMirror-selected { background: #073642; }
+.cm-s-solarized.cm-s-dark.CodeMirror ::selection { background: rgba(7, 54, 66, 0.99); }
+.cm-s-solarized.cm-s-dark .CodeMirror-line::-moz-selection, .cm-s-dark .CodeMirror-line > span::-moz-selection, .cm-s-dark .CodeMirror-line > span > span::-moz-selection { background: rgba(7, 54, 66, 0.99); }
+
+.cm-s-solarized.cm-s-light div.CodeMirror-selected { background: #eee8d5; }
+.cm-s-solarized.cm-s-light .CodeMirror-line::selection, .cm-s-light .CodeMirror-line > span::selection, .cm-s-light .CodeMirror-line > span > span::selection { background: #eee8d5; }
+.cm-s-solarized.cm-s-light .CodeMirror-line::-moz-selection, .cm-s-ligh .CodeMirror-line > span::-moz-selection, .cm-s-ligh .CodeMirror-line > span > span::-moz-selection { background: #eee8d5; }
+
+/* Editor styling */
+
+
+
+/* Little shadow on the view-port of the buffer view */
+.cm-s-solarized.CodeMirror {
+  -moz-box-shadow: inset 7px 0 12px -6px #000;
+  -webkit-box-shadow: inset 7px 0 12px -6px #000;
+  box-shadow: inset 7px 0 12px -6px #000;
+}
+
+/* Remove gutter border */
+.cm-s-solarized .CodeMirror-gutters {
+  border-right: 0;
+}
+
+/* Gutter colors and line number styling based of color scheme (dark / light) */
+
+/* Dark */
+.cm-s-solarized.cm-s-dark .CodeMirror-gutters {
+  background-color: #073642;
+}
+
+.cm-s-solarized.cm-s-dark .CodeMirror-linenumber {
+  color: #586e75;
+  text-shadow: #021014 0 -1px;
+}
+
+/* Light */
+.cm-s-solarized.cm-s-light .CodeMirror-gutters {
+  background-color: #eee8d5;
+}
+
+.cm-s-solarized.cm-s-light .CodeMirror-linenumber {
+  color: #839496;
+}
+
+/* Common */
+.cm-s-solarized .CodeMirror-linenumber {
+  padding: 0 5px;
+}
+.cm-s-solarized .CodeMirror-guttermarker-subtle { color: #586e75; }
+.cm-s-solarized.cm-s-dark .CodeMirror-guttermarker { color: #ddd; }
+.cm-s-solarized.cm-s-light .CodeMirror-guttermarker { color: #cb4b16; }
+
+.cm-s-solarized .CodeMirror-gutter .CodeMirror-gutter-text {
+  color: #586e75;
+}
+
+/* Cursor */
+.cm-s-solarized .CodeMirror-cursor { border-left: 1px solid #819090; }
+
+/* Fat cursor */
+.cm-s-solarized.cm-s-light.cm-fat-cursor .CodeMirror-cursor { background: #77ee77; }
+.cm-s-solarized.cm-s-light .cm-animate-fat-cursor { background-color: #77ee77; }
+.cm-s-solarized.cm-s-dark.cm-fat-cursor .CodeMirror-cursor { background: #586e75; }
+.cm-s-solarized.cm-s-dark .cm-animate-fat-cursor { background-color: #586e75; }
+
+/* Active line */
+.cm-s-solarized.cm-s-dark .CodeMirror-activeline-background {
+  background: rgba(255, 255, 255, 0.06);
+}
+.cm-s-solarized.cm-s-light .CodeMirror-activeline-background {
+  background: rgba(0, 0, 0, 0.06);
+}
+
+.cm-s-the-matrix.CodeMirror { background: #000000; color: #00FF00; }
+.cm-s-the-matrix div.CodeMirror-selected { background: #2D2D2D; }
+.cm-s-the-matrix .CodeMirror-line::selection, .cm-s-the-matrix .CodeMirror-line > span::selection, .cm-s-the-matrix .CodeMirror-line > span > span::selection { background: rgba(45, 45, 45, 0.99); }
+.cm-s-the-matrix .CodeMirror-line::-moz-selection, .cm-s-the-matrix .CodeMirror-line > span::-moz-selection, .cm-s-the-matrix .CodeMirror-line > span > span::-moz-selection { background: rgba(45, 45, 45, 0.99); }
+.cm-s-the-matrix .CodeMirror-gutters { background: #060; border-right: 2px solid #00FF00; }
+.cm-s-the-matrix .CodeMirror-guttermarker { color: #0f0; }
+.cm-s-the-matrix .CodeMirror-guttermarker-subtle { color: white; }
+.cm-s-the-matrix .CodeMirror-linenumber { color: #FFFFFF; }
+.cm-s-the-matrix .CodeMirror-cursor { border-left: 1px solid #00FF00; }
+
+.cm-s-the-matrix span.cm-keyword { color: #008803; font-weight: bold; }
+.cm-s-the-matrix span.cm-atom { color: #3FF; }
+.cm-s-the-matrix span.cm-number { color: #FFB94F; }
+.cm-s-the-matrix span.cm-def { color: #99C; }
+.cm-s-the-matrix span.cm-variable { color: #F6C; }
+.cm-s-the-matrix span.cm-variable-2 { color: #C6F; }
+.cm-s-the-matrix span.cm-variable-3, .cm-s-the-matrix span.cm-type { color: #96F; }
+.cm-s-the-matrix span.cm-property { color: #62FFA0; }
+.cm-s-the-matrix span.cm-operator { color: #999; }
+.cm-s-the-matrix span.cm-comment { color: #CCCCCC; }
+.cm-s-the-matrix span.cm-string { color: #39C; }
+.cm-s-the-matrix span.cm-meta { color: #C9F; }
+.cm-s-the-matrix span.cm-qualifier { color: #FFF700; }
+.cm-s-the-matrix span.cm-builtin { color: #30a; }
+.cm-s-the-matrix span.cm-bracket { color: #cc7; }
+.cm-s-the-matrix span.cm-tag { color: #FFBD40; }
+.cm-s-the-matrix span.cm-attribute { color: #FFF700; }
+.cm-s-the-matrix span.cm-error { color: #FF0000; }
+
+.cm-s-the-matrix .CodeMirror-activeline-background { background: #040; }
+
+/*
+Copyright (C) 2011 by MarkLogic Corporation
+Author: Mike Brevoort <mike@brevoort.com>
+
+Permission is hereby granted, free of charge, to any person obtaining a copy
+of this software and associated documentation files (the "Software"), to deal
+in the Software without restriction, including without limitation the rights
+to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+copies of the Software, and to permit persons to whom the Software is
+furnished to do so, subject to the following conditions:
+
+The above copyright notice and this permission notice shall be included in
+all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+THE SOFTWARE.
+*/
+.cm-s-xq-light span.cm-keyword { line-height: 1em; font-weight: bold; color: #5A5CAD; }
+.cm-s-xq-light span.cm-atom { color: #6C8CD5; }
+.cm-s-xq-light span.cm-number { color: #164; }
+.cm-s-xq-light span.cm-def { text-decoration:underline; }
+.cm-s-xq-light span.cm-variable { color: black; }
+.cm-s-xq-light span.cm-variable-2 { color:black; }
+.cm-s-xq-light span.cm-variable-3, .cm-s-xq-light span.cm-type { color: black; }
+.cm-s-xq-light span.cm-property {}
+.cm-s-xq-light span.cm-operator {}
+.cm-s-xq-light span.cm-comment { color: #0080FF; font-style: italic; }
+.cm-s-xq-light span.cm-string { color: red; }
+.cm-s-xq-light span.cm-meta { color: yellow; }
+.cm-s-xq-light span.cm-qualifier { color: grey; }
+.cm-s-xq-light span.cm-builtin { color: #7EA656; }
+.cm-s-xq-light span.cm-bracket { color: #cc7; }
+.cm-s-xq-light span.cm-tag { color: #3F7F7F; }
+.cm-s-xq-light span.cm-attribute { color: #7F007F; }
+.cm-s-xq-light span.cm-error { color: #f00; }
+
+.cm-s-xq-light .CodeMirror-activeline-background { background: #e8f2ff; }
+.cm-s-xq-light .CodeMirror-matchingbracket { outline:1px solid grey;color:black !important;background:yellow; }
+
+/*-----------------------------------------------------------------------------
+| 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-static {
+  margin: var(--jp-code-padding);
+}
+
+.jp-CodeMirrorEditor,
+.jp-CodeMirrorEditor-static {
+  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();
+  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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/*-----------------------------------------------------------------------------
+| RenderedText
+|----------------------------------------------------------------------------*/
+
+.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;
+  line-height: normal;
+}
+
+.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;
+}
+.jp-RenderedText pre .ansi-red-bg {
+  background-color: #e75c58;
+}
+.jp-RenderedText pre .ansi-green-bg {
+  background-color: #00a250;
+}
+.jp-RenderedText pre .ansi-yellow-bg {
+  background-color: #ddb62b;
+}
+.jp-RenderedText pre .ansi-blue-bg {
+  background-color: #208ffb;
+}
+.jp-RenderedText pre .ansi-magenta-bg {
+  background-color: #d160c4;
+}
+.jp-RenderedText pre .ansi-cyan-bg {
+  background-color: #60c6c8;
+}
+.jp-RenderedText pre .ansi-white-bg {
+  background-color: #c5c1b4;
+}
+
+.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;
+}
+.jp-RenderedText pre .ansi-red-intense-bg {
+  background-color: #b22b31;
+}
+.jp-RenderedText pre .ansi-green-intense-bg {
+  background-color: #007427;
+}
+.jp-RenderedText pre .ansi-yellow-intense-bg {
+  background-color: #b27d12;
+}
+.jp-RenderedText pre .ansi-blue-intense-bg {
+  background-color: #0065ca;
+}
+.jp-RenderedText pre .ansi-magenta-intense-bg {
+  background-color: #a03196;
+}
+.jp-RenderedText pre .ansi-cyan-intense-bg {
+  background-color: #258f8f;
+}
+.jp-RenderedText pre .ansi-white-intense-bg {
+  background-color: #a1a6b2;
+}
+
+.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);
+}
+
+.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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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.
+|----------------------------------------------------------------------------*/
+
+.jp-MimeDocument {
+  outline: none;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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
+|----------------------------------------------------------------------------*/
+
+: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: 4px 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;
+}
+
+.jp-FileBrowser-toolbar.jp-Toolbar {
+  justify-content: space-evenly;
+}
+
+.jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item {
+  flex: 1;
+}
+
+.jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent {
+  width: 100%;
+}
+
+/*-----------------------------------------------------------------------------
+| 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-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);
+}
+
+/* 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.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;
+}
+
+.jp-FileDialog.jp-mod-conflict input {
+  color: red;
+}
+
+.jp-FileDialog .jp-new-name-title {
+  margin-top: 12px;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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;
+}
+
+.jp-OutputArea-executeResult.jp-RenderedText {
+  padding-top: var(--jp-code-padding);
+}
+
+/*-----------------------------------------------------------------------------
+| 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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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;
+}
+
+.jp-InputArea-editor {
+  flex: 1 1 auto;
+}
+
+.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;
+}
+
+/* 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);
+}
+
+.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.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| 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;
+}
+
+/*-----------------------------------------------------------------------------
+| 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;
+}
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+/* This file was auto-generated by ensurePackage() in @jupyterlab/buildutils */
+
+/*-----------------------------------------------------------------------------
+| Copyright (c) Jupyter Development Team.
+| Distributed under the terms of the Modified BSD License.
+|----------------------------------------------------------------------------*/
+
+</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: 'Source Code Pro', monospace;
+  --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: 180px;
+
+  /* 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">
+<h3 id="Student:-Mar&#237;a-Jos&#233;-Ramos">Student: Mar&#237;a Jos&#233; Ramos<a class="anchor-link" href="#Student:-Mar&#237;a-Jos&#233;-Ramos">&#182;</a></h3><h1 id="Data-Science">Data Science<a class="anchor-link" href="#Data-Science">&#182;</a></h1><h2 id="Module-1:-Research-Software-Engineering">Module 1: Research Software Engineering<a class="anchor-link" href="#Module-1:-Research-Software-Engineering">&#182;</a></h2><h3 id="Final-homework:-Data-Analysis-Project">Final homework: Data Analysis Project<a class="anchor-link" href="#Final-homework:-Data-Analysis-Project">&#182;</a></h3>
+</div>
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<p>Inspired by Higgs boson discovery and the notebooks collection from ATLAS Open Data, this notebook explores <a href="http://opendata.atlas.cern">open data</a> from the ATLAS experiment concerning photon events, in order to look for Higgs boson signals in the graph of invariant mass for diphotonic systems. 
+This work is heavily based on: <a href="https://github.com/atlas-outreach-data-tools/notebooks-collection-opendata/blob/master/13-TeV-examples/uproot_python/HyyAnalysis.ipynb">HyyAnalysis notebook</a>, although it offers a new approach to generate the dataframe, and a quick revision of the variables that are used to filter photons.<br>
+The photons conditions considered in this analysis come from criteria mentioned in Higgs boson search papers by ATLAS Collaboration, mainly: <a href="https://arxiv.org/pdf/1207.7214.pdf">Observation of a New Particle in the Search for the Standard Model Higgs Bosonwith the ATLAS Detector at the LHC</a><br>
+  For more information on uproot, consult this <a href="https://hsf-training.github.io/hsf-training-uproot-webpage/index.html">tutorial</a>, that provided useful information to this notebook.<br>
+  Also note most of this work was done in ATLAS Virtual Machine: <a href="https://doi.org/10.5281/zenodo.3629875"><img src="https://zenodo.org/badge/DOI/10.5281/zenodo.3629875.svg" alt="DOI"></a></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">
+<p>Tools:</p>
+<ul>
+<li>time: to measure time to generate the final dataframe</li>
+<li>uproot3: to read the .root file into data formats used in python</li>
+<li>pandas: to store data as dataframe.</li>
+<li>numpy: for numerical calculations involving arrays.</li>
+<li>matplotlib: for making plots.</li>
+<li>lmfit: for statistical fitting in the final plot.</li>
+<li>Colormaps: for coloring histograms </li>
+</ul>
+
+</div>
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[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="kn">import</span> <span class="nn">time</span>
+<span class="kn">import</span> <span class="nn">uproot3</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="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
+<span class="kn">from</span> <span class="nn">matplotlib</span> <span class="kn">import</span> <span class="n">cm</span>
+<span class="kn">from</span> <span class="nn">matplotlib.ticker</span> <span class="kn">import</span> <span class="n">MaxNLocator</span><span class="p">,</span> <span class="n">AutoMinorLocator</span>
+<span class="kn">from</span> <span class="nn">lmfit.models</span> <span class="kn">import</span> <span class="n">PolynomialModel</span><span class="p">,</span> <span class="n">GaussianModel</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell jp-mod-noOutputs  ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[2]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">colors</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">get_cmap</span><span class="p">(</span><span class="s1">&#39;gist_rainbow&#39;</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<h3 id="Exploring-the-data"><em>Exploring the data</em><a class="anchor-link" href="#Exploring-the-data">&#182;</a></h3>
+</div>
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<p>To open a root file in python, one can use uproot, both to open a local file or by an url. After assign it to a variable <em>data</em>, one can explore its <em>key</em> and store it in a <em>tree</em>, which has tables of information organized by <em>branches</em>, that covers a range of events. To get the name of these <em>branches</em>, one can access to the <em>tree</em> keys.</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;[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"># Open data from file</span>
+<span class="n">data</span> <span class="o">=</span> <span class="n">uproot3</span><span class="o">.</span><span class="n">open</span><span class="p">(</span><span class="s1">&#39;/home/ramosm/ejercicios-clase-08-datos/data-used/data_A.GamGam.root&#39;</span><span class="p">)</span>
+<span class="c1"># URL: data = uproot3.open(&#39;https://atlas-opendata.web.cern.ch/atlas-opendata/samples/2020/GamGam/Data/&#39;)</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[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"># Know the data keys:</span>
+<span class="n">data</span><span class="o">.</span><span class="n">keys</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[4]:</div>
+
+
+
+
+<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
+<pre>[b&#39;mini;1&#39;]</pre>
+</div>
+
+</div>
+
+</div>
+
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[5]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># Generate tree</span>
+<span class="n">tree</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s1">&#39;mini&#39;</span><span class="p">]</span>
+<span class="c1"># Exploring the data</span>
+<span class="n">tree</span><span class="o">.</span><span class="n">keys</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[5]:</div>
+
+
+
+
+<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
+<pre>[b&#39;runNumber&#39;,
+ b&#39;eventNumber&#39;,
+ b&#39;channelNumber&#39;,
+ b&#39;mcWeight&#39;,
+ b&#39;scaleFactor_PILEUP&#39;,
+ b&#39;scaleFactor_ELE&#39;,
+ b&#39;scaleFactor_MUON&#39;,
+ b&#39;scaleFactor_PHOTON&#39;,
+ b&#39;scaleFactor_TAU&#39;,
+ b&#39;scaleFactor_BTAG&#39;,
+ b&#39;scaleFactor_LepTRIGGER&#39;,
+ b&#39;scaleFactor_PhotonTRIGGER&#39;,
+ b&#39;trigE&#39;,
+ b&#39;trigM&#39;,
+ b&#39;trigP&#39;,
+ b&#39;lep_n&#39;,
+ b&#39;lep_truthMatched&#39;,
+ b&#39;lep_trigMatched&#39;,
+ b&#39;lep_pt&#39;,
+ b&#39;lep_eta&#39;,
+ b&#39;lep_phi&#39;,
+ b&#39;lep_E&#39;,
+ b&#39;lep_z0&#39;,
+ b&#39;lep_charge&#39;,
+ b&#39;lep_type&#39;,
+ b&#39;lep_isTightID&#39;,
+ b&#39;lep_ptcone30&#39;,
+ b&#39;lep_etcone20&#39;,
+ b&#39;lep_trackd0pvunbiased&#39;,
+ b&#39;lep_tracksigd0pvunbiased&#39;,
+ b&#39;met_et&#39;,
+ b&#39;met_phi&#39;,
+ b&#39;jet_n&#39;,
+ b&#39;jet_pt&#39;,
+ b&#39;jet_eta&#39;,
+ b&#39;jet_phi&#39;,
+ b&#39;jet_E&#39;,
+ b&#39;jet_jvt&#39;,
+ b&#39;jet_trueflav&#39;,
+ b&#39;jet_truthMatched&#39;,
+ b&#39;jet_MV2c10&#39;,
+ b&#39;photon_n&#39;,
+ b&#39;photon_truthMatched&#39;,
+ b&#39;photon_trigMatched&#39;,
+ b&#39;photon_pt&#39;,
+ b&#39;photon_eta&#39;,
+ b&#39;photon_phi&#39;,
+ b&#39;photon_E&#39;,
+ b&#39;photon_isTightID&#39;,
+ b&#39;photon_ptcone30&#39;,
+ b&#39;photon_etcone20&#39;,
+ b&#39;photon_convType&#39;,
+ b&#39;tau_n&#39;,
+ b&#39;tau_pt&#39;,
+ b&#39;tau_eta&#39;,
+ b&#39;tau_phi&#39;,
+ b&#39;tau_E&#39;,
+ b&#39;tau_isTightID&#39;,
+ b&#39;tau_truthMatched&#39;,
+ b&#39;tau_trigMatched&#39;,
+ b&#39;tau_nTracks&#39;,
+ b&#39;tau_BDTid&#39;,
+ b&#39;ditau_m&#39;,
+ b&#39;lep_pt_syst&#39;,
+ b&#39;met_et_syst&#39;,
+ b&#39;jet_pt_syst&#39;,
+ b&#39;photon_pt_syst&#39;,
+ b&#39;tau_pt_syst&#39;,
+ b&#39;XSection&#39;,
+ b&#39;SumWeights&#39;,
+ b&#39;largeRjet_n&#39;,
+ b&#39;largeRjet_pt&#39;,
+ b&#39;largeRjet_eta&#39;,
+ b&#39;largeRjet_phi&#39;,
+ b&#39;largeRjet_E&#39;,
+ b&#39;largeRjet_m&#39;,
+ b&#39;largeRjet_truthMatched&#39;,
+ b&#39;largeRjet_D2&#39;,
+ b&#39;largeRjet_tau32&#39;,
+ b&#39;largeRjet_pt_syst&#39;,
+ b&#39;tau_charge&#39;]</pre>
+</div>
+
+</div>
+
+</div>
+
+</div>
+
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<p>For this analysis, these are the variables needed:</p>
+<ul>
+<li>photon_n: number of photons in the event.</li>
+<li>photon_isTightID: boolean indicating whether the photon tight identification reconstruction criteria.</li>
+<li>photon_pt: transverse momentum of the photon.</li>
+<li>photon_eta: pseudorapidity of the photon.</li>
+<li>photon_phi: azimuthal angle of the photon.</li>
+<li>photon_E: energy of the photon.</li>
+<li>photon<em>etcone20: scalar sum of track $E</em>{t}$ in a cone of R=0.2 around photon. </li>
+</ul>
+<p>These <em>branches</em> have their information ordered in <em>arrays</em>.</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"># Assign the branches </span>
+<span class="n">branches</span> <span class="o">=</span> <span class="n">tree</span><span class="o">.</span><span class="n">arrays</span><span class="p">(</span><span class="n">namedecode</span><span class="o">=</span><span class="s1">&#39;utf-8&#39;</span><span class="p">)</span>
+<span class="c1"># Explore one branch as an example:</span>
+<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;As you can see, this branch contains arrays:&#39;</span><span class="p">)</span>
+<span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
+<pre>As you can see, this branch contains arrays:
+</pre>
+</div>
+</div>
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[6]:</div>
+
+
+
+
+<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
+<pre>&lt;JaggedArray [[46690.223 29442.607] [60888.74 37795.01] [39186.21 25327.361] ... [39450.035 31067.45] [65747.49 33625.59] [40766.176 35701.254]] at 0x7fa4aa3796a0&gt;</pre>
+</div>
+
+</div>
+
+</div>
+
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[7]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># To know the number of events or the number of photon systems</span>
+<span class="n">events</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">tree</span><span class="p">)</span>
+<span class="c1"># To know the number of actual photons</span>
+<span class="n">photons</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">())</span>
+
+<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">&#39;Number of events in the data / Number of photon systems: </span><span class="si">{</span><span class="n">events</span><span class="si">}</span><span class="s1">&#39;</span><span class="p">)</span>
+<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">&#39;Total number of photons: </span><span class="si">{</span><span class="n">photons</span><span class="si">}</span><span class="s1">&#39;</span><span class="p">)</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
+<pre>Number of events in the data / Number of photon systems: 430344
+Total number of photons: 862157
+</pre>
+</div>
+</div>
+
+</div>
+
+</div>
+
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<h3 id="Studying-the-photon-events-and-finding-candidates"><em>Studying the photon events and finding candidates</em><a class="anchor-link" href="#Studying-the-photon-events-and-finding-candidates">&#182;</a></h3><p>To search for a higgs boson decay in diphoton systems, the first filter will be of course to only consider events of two photons (<em>photon_n</em> == 2) and the second one, that both of these photons pass the photon tight identification reconstruction criteria. This last condition means a photon has been identified and reconstructed as a photon (<em>photon_isTightID</em> == True). Note that in the referenced notebook this first filter is not applied.</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"># To know the number of photons per system</span>
+<span class="n">nmin</span> <span class="o">=</span> <span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_n&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">min</span><span class="p">()</span>
+<span class="n">nmax</span> <span class="o">=</span> <span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_n&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">max</span><span class="p">()</span>
+<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">&#39;Minimum number of photons per system: </span><span class="si">{</span><span class="n">nmin</span><span class="si">}</span><span class="s1">&#39;</span><span class="p">)</span>
+<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">&#39;Maximum number of photons per system: </span><span class="si">{</span><span class="n">nmax</span><span class="si">}</span><span class="s1">&#39;</span><span class="p">)</span>
+<span class="c1"># To plot this number as a function of events in the branch</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">hist</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_n&#39;</span><span class="p">],</span> <span class="n">bins</span><span class="o">=</span><span class="mi">5</span><span class="p">,</span> <span class="nb">range</span><span class="o">=</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">5</span><span class="p">),</span> <span class="n">color</span><span class="o">=</span><span class="n">colors</span><span class="p">(</span><span class="mi">0</span><span class="p">))</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">&#39;Number n of pre-selected photons&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">&#39;Number of events&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;Number of photons per system&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
+<pre>Minimum number of photons per system: 2
+Maximum number of photons per system: 4
+</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="
+"
+>
+</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;[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"># Filter 1: 2 photons per system</span>
+<span class="n">photon2</span> <span class="o">=</span> <span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_n&#39;</span><span class="p">]</span> <span class="o">==</span> <span class="mi">2</span><span class="p">)</span>
+<span class="c1"># Filter 2: Photons identified and reconstructed as photons</span>
+<span class="n">photonTrue</span> <span class="o">=</span> <span class="p">((</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_isTightID&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">==</span> <span class="kc">True</span><span class="p">)</span> <span class="o">&amp;</span> 
+              <span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_isTightID&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">]</span> <span class="o">==</span> <span class="kc">True</span><span class="p">))</span>
+<span class="c1"># Note the bitwise symbols used instead &#39;or&#39;, &#39;and&#39;</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>The next variable to plot in a histogram will be the $E_{t}$. The values &gt;4000MeV (for both photons) must be not considered in Higgs boson searches according to the papers consulted. The histogram will show less events than expected because it has been filtered by the two conditions.</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;[10]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">plt</span><span class="o">.</span><span class="n">hist</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_etcone20&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">(),</span> 
+         <span class="n">bins</span><span class="o">=</span><span class="mi">100</span><span class="p">,</span> <span class="nb">range</span><span class="o">=</span><span class="p">(</span><span class="o">-</span><span class="mi">2500</span><span class="p">,</span> <span class="mi">5000</span><span class="p">),</span> <span class="n">color</span><span class="o">=</span><span class="n">colors</span><span class="p">(</span><span class="mi">1</span><span class="p">))</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">&#39;Scalar sum of track $E_{\mathrm</span><span class="si">{t}</span><span class="s1">}$ [MeV] &#39;</span> 
+           <span class="s1">&#39;in a cone of R=0.2 around photon&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">&#39;Events&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;Isolation transverse energy of photons filtered by </span><span class="se">\n</span><span class="s1">&#39;</span>
+          <span class="s1">&#39;diphoton systems and reconstruction quality&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+
+
+<div class="jp-RenderedImage jp-OutputArea-output ">
+<img src="
+"
+>
+</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;[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"># Filter 3: [&#39;photon_etcone20&#39;]&lt;4000 MeV</span>
+<span class="n">photonEt</span> <span class="o">=</span> <span class="p">((</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_etcone20&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">&lt;</span> <span class="mi">4000</span><span class="p">)</span> <span class="o">&amp;</span> 
+            <span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_etcone20&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">]</span> <span class="o">&lt;</span> <span class="mi">4000</span><span class="p">))</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>Another histogram shows the photon pseudorapidity values after applying the filters given before. Values in the range $|{\eta}|&gt;2.37$ (not considered in the original code) and $1.37&lt;|{\eta}|&lt;1.52$ (for the calorimeter barrel/end-cap transition region) must be excluded by a filter.</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;[12]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">plt</span><span class="o">.</span><span class="n">hist</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span> <span class="o">&amp;</span> <span class="n">photonEt</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">(),</span> 
+         <span class="n">bins</span><span class="o">=</span><span class="mi">100</span><span class="p">,</span> <span class="nb">range</span><span class="o">=</span><span class="p">(</span><span class="o">-</span><span class="mi">3</span><span class="p">,</span> <span class="mi">3</span><span class="p">),</span> <span class="n">color</span><span class="o">=</span><span class="n">colors</span><span class="p">(</span><span class="mi">6</span><span class="p">))</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">&#39;Pseudo rapidity $\eta$ of photon&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">&#39;Events&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;Pseudo rapidity of photons filtered by </span><span class="se">\n</span><span class="s1"> diphoton systems, &#39;</span>
+          <span class="s1">&#39;reconstruction quality and $E_{\mathrm</span><span class="si">{t}</span><span class="s1">}$&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+
+
+<div class="jp-RenderedImage jp-OutputArea-output ">
+<img src="
+"
+>
+</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;[13]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># Filter 4: </span>
+<span class="n">photonEta</span> <span class="o">=</span> <span class="p">(((</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">])</span><span class="o">&lt;</span><span class="mf">2.37</span><span class="p">)</span> <span class="o">&amp;</span> 
+              <span class="p">(</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">])</span><span class="o">&lt;</span><span class="mf">2.37</span><span class="p">))</span> <span class="o">&amp;</span>
+             <span class="p">((</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">])</span><span class="o">&gt;</span><span class="mf">1.52</span><span class="p">)</span> <span class="o">|</span> 
+              <span class="p">(</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">])</span><span class="o">&lt;</span><span class="mf">1.37</span><span class="p">))</span> <span class="o">&amp;</span>
+             <span class="p">((</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">])</span><span class="o">&gt;</span><span class="mf">1.52</span><span class="p">)</span> <span class="o">|</span> 
+              <span class="p">(</span><span class="nb">abs</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">])</span><span class="o">&lt;</span><span class="mf">1.37</span><span class="p">)))</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>The final histograms are of the photon transverse momentum variable. For Higgs detection, one needs that the first photon of the system has a momentum of $p_{t0}&gt;40GeV$ and that the second photon has $p_{t1}&gt;30GeV$. The last histogram is normalized to show a comparative of photon momentum considering the filter4 for $\eta$ and considering and opposite filter, to demonstrate that the momentum of a photon $p_{t}$ depends on its pseudorapidity $\eta$.</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;[14]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">plt</span><span class="o">.</span><span class="n">hist</span><span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span> <span class="o">&amp;</span> <span class="n">photonEt</span> <span class="o">&amp;</span> <span class="n">photonEta</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">(),</span> 
+         <span class="n">bins</span><span class="o">=</span> <span class="mi">100</span><span class="p">,</span> <span class="nb">range</span><span class="o">=</span><span class="p">(</span><span class="mi">20000</span><span class="p">,</span> <span class="mi">250000</span><span class="p">),</span> <span class="n">color</span><span class="o">=</span><span class="n">colors</span><span class="p">(</span><span class="mi">8</span><span class="p">))</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">&#39;Transverse momentum of photon $p_{\mathrm</span><span class="si">{T}</span><span class="s1">}$ [MeV]&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">&#39;Events&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;Transverse momentum of photons filtered by </span><span class="se">\n</span><span class="s1"> diphoton systems, &#39;</span>
+          <span class="s1">&#39;reconstruction quality, $E_{\mathrm</span><span class="si">{t}</span><span class="s1">}$ and $\eta$&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+
+
+<div class="jp-RenderedImage jp-OutputArea-output ">
+<img src="
+"
+>
+</div>
+
+</div>
+
+</div>
+
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[15]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">plt</span><span class="o">.</span><span class="n">hist</span><span class="p">([</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span> <span class="o">&amp;</span> <span class="n">photonEt</span> <span class="o">&amp;</span> <span class="n">photonEta</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">(),</span> 
+         <span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span> <span class="o">&amp;</span> <span class="n">photonEt</span> <span class="o">&amp;</span> <span class="o">~</span><span class="n">photonEta</span><span class="p">]</span><span class="o">.</span><span class="n">flatten</span><span class="p">()],</span>
+         <span class="n">label</span><span class="o">=</span><span class="p">[</span><span class="s1">&#39;$|\eta| &gt; 1.52$ and $|\eta| &lt; 1.37$&#39;</span><span class="p">,</span> <span class="s1">&#39;$1.37&lt;|\eta|&lt;1.52$&#39;</span><span class="p">],</span>
+         <span class="n">bins</span><span class="o">=</span> <span class="mi">20</span><span class="p">,</span> <span class="nb">range</span><span class="o">=</span><span class="p">(</span><span class="mi">20000</span><span class="p">,</span> <span class="mi">100000</span><span class="p">),</span> <span class="n">color</span><span class="o">=</span><span class="p">[</span><span class="n">colors</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="n">colors</span><span class="p">(</span><span class="mi">7</span><span class="p">)],</span> <span class="n">density</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">xlabel</span><span class="p">(</span><span class="s1">&#39;Transverse momentum of photon $p_{\mathrm</span><span class="si">{T}</span><span class="s1">}$ [MeV]&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">ylabel</span><span class="p">(</span><span class="s1">&#39;Events&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">legend</span><span class="p">()</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="s1">&#39;Normalized graph for difference of </span><span class="se">\n</span><span class="s1">&#39;</span>
+          <span class="s1">&#39;photon momentum considering $\eta$ regions&#39;</span><span class="p">)</span>
+<span class="n">plt</span><span class="o">.</span><span class="n">show</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[15]:</div>
+
+
+
+
+<div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
+<pre>&lt;function matplotlib.pyplot.show(close=None, block=None)&gt;</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="
+"
+>
+</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;[16]:</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"># Filter 5: </span>
+<span class="n">photonPt</span> <span class="o">=</span> <span class="p">((</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">][:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">&gt;</span> <span class="mi">40000</span><span class="p">)</span> <span class="o">&amp;</span> 
+            <span class="p">(</span><span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">][:,</span><span class="mi">1</span><span class="p">]</span> <span class="o">&gt;</span> <span class="mi">30000</span><span class="p">))</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>Finally, by applying all filters to a branch, one can know the number of photon events that satisfy this criteria.</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;[17]:</div>
+<div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
+     <div class="CodeMirror cm-s-jupyter">
+<div class=" highlight hl-ipython3"><pre><span></span><span class="n">photonFilter</span> <span class="o">=</span> <span class="n">branches</span><span class="p">[</span><span class="s1">&#39;photon_E&#39;</span><span class="p">][</span><span class="n">photon2</span> <span class="o">&amp;</span> <span class="n">photonTrue</span> <span class="o">&amp;</span> <span class="n">photonEt</span> <span class="o">&amp;</span> <span class="n">photonEta</span> <span class="o">&amp;</span> <span class="n">photonPt</span><span class="p">]</span>
+<span class="nb">print</span><span class="p">(</span><span class="s1">&#39;Number of events with photons that satisfy the &#39;</span>
+      <span class="sa">f</span><span class="s1">&#39;criteria: </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">photonFilter</span><span class="p">)</span><span class="si">}</span><span class="s1">&#39;</span><span class="p">)</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+<div class="jp-Cell-outputWrapper">
+
+
+<div class="jp-OutputArea jp-Cell-outputArea">
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
+
+
+<div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
+<pre>Number of events with photons that satisfy the criteria: 22253
+</pre>
+</div>
+</div>
+
+</div>
+
+</div>
+
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<h3 id="Creating-the-data-frame"><em>Creating the data frame</em><a class="anchor-link" href="#Creating-the-data-frame">&#182;</a></h3><p>One can generate, from a root file, a pandas dataframe that contains only the wanted <em>keys</em> of a <em>tree</em> using uproot. After this process has been done, one can use pandas to keep the dataframe rows that contain photons that satisfy the given conditions. At the end of this filtering, one needs to calculate the invariant mass to search for the Higgs boson. This can be done using numpy, that operates quickly over <em>series</em> and <em>arrays</em> of data. To complete the data frame, one can add a column for invariant mass. 
+The next code allows us to do all of this without running the cells above, to obtain an independent process.</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;[18]:</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"># Function to calculate the invariant mass &#39;myy&#39; of the events</span>
+<span class="c1"># It returns arrays.</span>
+
+<span class="k">def</span> <span class="nf">calculateMyy</span><span class="p">(</span><span class="n">photonData</span><span class="p">):</span>
+    <span class="n">px</span> <span class="o">=</span> <span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:]</span><span class="o">*</span><span class="n">np</span><span class="o">.</span><span class="n">cos</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_phi&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:])</span>
+    <span class="n">py</span> <span class="o">=</span> <span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:]</span><span class="o">*</span><span class="n">np</span><span class="o">.</span><span class="n">sin</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_phi&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:])</span>
+    <span class="n">pz</span> <span class="o">=</span> <span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:]</span><span class="o">*</span><span class="n">np</span><span class="o">.</span><span class="n">sinh</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:])</span>
+    <span class="n">sumpx</span> <span class="o">=</span> <span class="n">px</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">+</span> <span class="n">px</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">1</span><span class="p">]</span>
+    <span class="n">sumpy</span> <span class="o">=</span> <span class="n">py</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">+</span> <span class="n">py</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">1</span><span class="p">]</span>
+    <span class="n">sumpz</span> <span class="o">=</span> <span class="n">px</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">+</span> <span class="n">pz</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">1</span><span class="p">]</span>
+    <span class="n">sump</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">sqrt</span><span class="p">(</span><span class="n">sumpx</span><span class="o">**</span><span class="mi">2</span> <span class="o">+</span> <span class="n">sumpy</span><span class="o">**</span><span class="mi">2</span> <span class="o">+</span> <span class="n">sumpz</span><span class="o">**</span><span class="mi">2</span><span class="p">)</span>
+    <span class="n">sumE</span> <span class="o">=</span> <span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_E&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">0</span><span class="p">]</span> <span class="o">+</span> <span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_E&#39;</span><span class="p">]</span><span class="o">.</span><span class="n">loc</span><span class="p">[:,</span><span class="mi">1</span><span class="p">])</span>
+    <span class="n">myy</span> <span class="o">=</span> <span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">sqrt</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">absolute</span><span class="p">(</span><span class="n">sumE</span><span class="o">**</span><span class="mi">2</span> <span class="o">-</span> <span class="n">sump</span><span class="o">**</span><span class="mi">2</span><span class="p">))</span><span class="o">/</span><span class="mi">1000</span><span class="p">)</span>
+    <span class="k">return</span> <span class="n">myy</span>
+
+<span class="c1"># Function to generate a dataframe from a tree and</span>
+<span class="c1"># filter it considering the given conditions </span>
+
+<span class="k">def</span> <span class="nf">getPhotonData</span><span class="p">(</span><span class="n">tree</span><span class="p">):</span>
+    <span class="c1"># Convert the photon keys from tree to a dataframe</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">tree</span><span class="o">.</span><span class="n">pandas</span><span class="o">.</span><span class="n">df</span><span class="p">([</span><span class="s1">&#39;photon_n&#39;</span><span class="p">,</span> <span class="s1">&#39;photon_isTightID&#39;</span><span class="p">,</span> 
+                                 <span class="s1">&#39;photon_etcone20&#39;</span><span class="p">,</span> <span class="s1">&#39;photon_pt&#39;</span><span class="p">,</span>
+                                 <span class="s1">&#39;photon_phi&#39;</span><span class="p">,</span> <span class="s1">&#39;photon_eta&#39;</span><span class="p">,</span> <span class="s1">&#39;photon_E&#39;</span><span class="p">])</span>
+    <span class="c1"># Only keep diphoton events in dataframe</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="p">[</span><span class="n">photonData</span><span class="o">.</span><span class="n">photon_n</span> <span class="o">==</span> <span class="mi">2</span><span class="p">]</span>
+    <span class="c1"># Only keep events where both photons satisfy the reconstruction </span>
+    <span class="c1"># quality conditions</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">loc</span><span class="p">[(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_isTightID&#39;</span><span class="p">]</span><span class="o">==</span><span class="kc">True</span><span class="p">)</span><span class="o">.</span>
+                                <span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="s1">&#39;entry&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">transform</span><span class="p">(</span><span class="s1">&#39;all&#39;</span><span class="p">)]</span>
+    <span class="c1"># Only keep events where both photons satisfy the isolation</span>
+    <span class="c1"># transverse energy condition</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">loc</span><span class="p">[(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_etcone20&#39;</span><span class="p">]</span><span class="o">&lt;</span><span class="mi">4000</span><span class="p">)</span><span class="o">.</span>
+                                <span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="s1">&#39;entry&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">transform</span><span class="p">(</span><span class="s1">&#39;all&#39;</span><span class="p">)]</span>
+    <span class="c1"># Only keep events where both photons satisfy the eta conditions</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">loc</span><span class="p">[(((</span><span class="nb">abs</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">]))</span><span class="o">&lt;</span><span class="mf">2.37</span><span class="p">))</span><span class="o">.</span>
+                                <span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="s1">&#39;entry&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">transform</span><span class="p">(</span><span class="s1">&#39;all&#39;</span><span class="p">)]</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">loc</span><span class="p">[(((</span><span class="nb">abs</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">]))</span><span class="o">&gt;</span><span class="mf">1.52</span><span class="p">)</span> <span class="o">|</span> 
+                                 <span class="p">((</span><span class="nb">abs</span><span class="p">(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_eta&#39;</span><span class="p">]))</span><span class="o">&lt;</span><span class="mf">1.37</span><span class="p">))</span><span class="o">.</span>
+                                <span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="s1">&#39;entry&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">transform</span><span class="p">(</span><span class="s1">&#39;all&#39;</span><span class="p">)]</span>
+    <span class="c1"># Only keep events where both photons have </span>
+    <span class="c1"># photon momentum &gt;30000 MeV</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">loc</span><span class="p">[(</span><span class="n">photonData</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">&gt;</span><span class="mi">30000</span><span class="p">)</span><span class="o">.</span>
+                                <span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="s1">&#39;entry&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">transform</span><span class="p">(</span><span class="s1">&#39;all&#39;</span><span class="p">)]</span>
+    <span class="c1"># To look for events where the first photons has a photon </span>
+    <span class="c1"># momentum &lt; 40000 MeV and remove that photon from the dataframe. </span>
+    <span class="c1"># This leaves some entries (events) with only one photon.</span>
+    <span class="n">pt</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">groupby</span><span class="p">([</span><span class="s1">&#39;entry&#39;</span><span class="p">])</span><span class="o">.</span><span class="n">head</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span> 
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">drop</span><span class="p">(</span><span class="n">pt</span><span class="o">.</span><span class="n">index</span><span class="p">[</span><span class="n">pt</span><span class="p">[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">&lt;</span><span class="mi">40000</span><span class="p">])</span>
+    <span class="c1"># To only keep entries which have two photons. </span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="p">[</span><span class="n">photonData</span><span class="o">.</span><span class="n">groupby</span><span class="p">(</span><span class="n">level</span><span class="o">=</span><span class="mi">0</span><span class="p">)[</span><span class="s1">&#39;photon_pt&#39;</span><span class="p">]</span><span class="o">.</span>
+                            <span class="n">transform</span><span class="p">(</span><span class="s1">&#39;size&#39;</span><span class="p">)</span><span class="o">.</span><span class="n">ne</span><span class="p">(</span><span class="mi">1</span><span class="p">)]</span>
+    <span class="c1"># Generate a series and then a dataFrame from the array </span>
+    <span class="c1"># returned by the &#39;calculateMyy&#39; function</span>
+    <span class="n">myyS</span> <span class="o">=</span> <span class="n">pd</span><span class="o">.</span><span class="n">Series</span><span class="p">(</span><span class="n">calculateMyy</span><span class="p">(</span><span class="n">photonData</span><span class="p">))</span>
+    <span class="n">myyData</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="s1">&#39;InvariantMass&#39;</span><span class="p">:</span><span class="n">myyS</span><span class="p">})</span>
+    <span class="c1"># Join the InvariantMass dataframe as a column for the</span>
+    <span class="c1"># original data frame</span>
+    <span class="n">photonData</span> <span class="o">=</span> <span class="n">photonData</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">myyData</span><span class="p">)</span>
+    <span class="k">return</span> <span class="n">photonData</span>
+
+<span class="c1"># To measure the time taken to generate this dataframe</span>
+<span class="n">start</span> <span class="o">=</span> <span class="n">time</span><span class="o">.</span><span class="n">time</span><span class="p">()</span>
+<span class="c1"># To open the file, generate the tree and call the function</span>
+<span class="c1"># that generates the dataframe</span>
+<span class="n">data</span> <span class="o">=</span> <span class="n">uproot3</span><span class="o">.</span><span class="n">open</span><span class="p">(</span><span class="s1">&#39;/home/ramosm/ejercicios-clase-08-datos/data-used/data_A.GamGam.root&#39;</span><span class="p">)</span>
+<span class="n">tree</span> <span class="o">=</span> <span class="n">data</span><span class="p">[</span><span class="s1">&#39;mini&#39;</span><span class="p">]</span>
+<span class="n">photonDataFrame</span> <span class="o">=</span> <span class="n">getPhotonData</span><span class="p">(</span><span class="n">tree</span><span class="p">)</span>
+<span class="n">end</span> <span class="o">=</span> <span class="n">time</span><span class="o">.</span><span class="n">time</span><span class="p">()</span>
+<span class="c1"># Done! Let&#39;s see the dataframe and the time</span>
+<span class="n">timetaken</span><span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">round</span><span class="p">((</span><span class="n">end</span><span class="o">-</span><span class="n">start</span><span class="p">),</span> <span class="mi">2</span><span class="p">)</span>
+<span class="nb">print</span><span class="p">(</span><span class="sa">f</span><span class="s1">&#39;It took </span><span class="si">{</span><span class="n">timetaken</span><span class="si">}</span><span class="s1"> seconds to create this dataframe from </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">tree</span><span class="p">)</span><span class="si">}</span><span class="s1"> &#39;</span>
+      <span class="sa">f</span><span class="s1">&#39;events to </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">photonDataFrame</span><span class="p">)</span><span class="o">//</span><span class="mi">2</span><span class="si">}</span><span class="s1"> events</span><span class="se">\n</span><span class="s1">that fit the criteria. &#39;</span>
+      <span class="sa">f</span><span class="s1">&#39;This corresponds to a total of </span><span class="si">{</span><span class="nb">len</span><span class="p">(</span><span class="n">photonDataFrame</span><span class="p">)</span><span class="si">}</span><span class="s1"> photons.&#39;</span><span class="p">)</span>
+<span class="n">photonDataFrame</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>It took 1.6 seconds to create this dataframe from 430344 events to 22253 events
+that fit the criteria. This corresponds to a total of 44506 photons.
+</pre>
+</div>
+</div>
+
+<div class="jp-OutputArea-child">
+
+    
+    <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[18]:</div>
+
+
+
+<div class="jp-RenderedHTMLCommon jp-RenderedHTML jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/html">
+<div>
+<style scoped>
+    .dataframe tbody tr th:only-of-type {
+        vertical-align: middle;
+    }
+
+    .dataframe tbody tr th {
+        vertical-align: top;
+    }
+
+    .dataframe thead th {
+        text-align: right;
+    }
+</style>
+<table border="1" class="dataframe">
+  <thead>
+    <tr style="text-align: right;">
+      <th></th>
+      <th></th>
+      <th>photon_n</th>
+      <th>photon_isTightID</th>
+      <th>photon_etcone20</th>
+      <th>photon_pt</th>
+      <th>photon_phi</th>
+      <th>photon_eta</th>
+      <th>photon_E</th>
+      <th>InvariantMass</th>
+    </tr>
+    <tr>
+      <th>entry</th>
+      <th>subentry</th>
+      <th></th>
+      <th></th>
+      <th></th>
+      <th></th>
+      <th></th>
+      <th></th>
+      <th></th>
+      <th></th>
+    </tr>
+  </thead>
+  <tbody>
+    <tr>
+      <th rowspan="2" valign="top">10</th>
+      <th>0</th>
+      <td>2</td>
+      <td>True</td>
+      <td>272.148438</td>
+      <td>176121.156250</td>
+      <td>-0.294239</td>
+      <td>-0.833492</td>
+      <td>240922.312500</td>
+      <td>86.241936</td>
+    </tr>
+    <tr>
+      <th>1</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-26.389771</td>
+      <td>39629.144531</td>
+      <td>0.567294</td>
+      <td>0.094703</td>
+      <td>39806.988281</td>
+      <td>86.241936</td>
+    </tr>
+    <tr>
+      <th rowspan="2" valign="top">11</th>
+      <th>0</th>
+      <td>2</td>
+      <td>True</td>
+      <td>8.248505</td>
+      <td>100427.679688</td>
+      <td>0.655955</td>
+      <td>1.734354</td>
+      <td>293338.343750</td>
+      <td>383.845337</td>
+    </tr>
+    <tr>
+      <th>1</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-584.198364</td>
+      <td>95522.570312</td>
+      <td>-2.457152</td>
+      <td>0.688044</td>
+      <td>119039.132812</td>
+      <td>383.845337</td>
+    </tr>
+    <tr>
+      <th>76</th>
+      <th>0</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-432.027344</td>
+      <td>45906.085938</td>
+      <td>-2.951355</td>
+      <td>0.560444</td>
+      <td>53306.277344</td>
+      <td>70.931763</td>
+    </tr>
+    <tr>
+      <th>...</th>
+      <th>...</th>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+      <td>...</td>
+    </tr>
+    <tr>
+      <th>430299</th>
+      <th>1</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-72.140320</td>
+      <td>40531.183594</td>
+      <td>-0.491031</td>
+      <td>-0.640433</td>
+      <td>49131.210938</td>
+      <td>69.801758</td>
+    </tr>
+    <tr>
+      <th rowspan="2" valign="top">430307</th>
+      <th>0</th>
+      <td>2</td>
+      <td>True</td>
+      <td>739.843750</td>
+      <td>57563.054688</td>
+      <td>2.412255</td>
+      <td>-0.635498</td>
+      <td>69583.203125</td>
+      <td>75.343292</td>
+    </tr>
+    <tr>
+      <th>1</th>
+      <td>2</td>
+      <td>True</td>
+      <td>1081.072266</td>
+      <td>33026.769531</td>
+      <td>-1.628855</td>
+      <td>-0.654452</td>
+      <td>40355.648438</td>
+      <td>75.343292</td>
+    </tr>
+    <tr>
+      <th rowspan="2" valign="top">430337</th>
+      <th>0</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-585.297729</td>
+      <td>42460.062500</td>
+      <td>2.333366</td>
+      <td>-1.032692</td>
+      <td>67185.890625</td>
+      <td>122.064262</td>
+    </tr>
+    <tr>
+      <th>1</th>
+      <td>2</td>
+      <td>True</td>
+      <td>-355.998718</td>
+      <td>41162.777344</td>
+      <td>-0.719427</td>
+      <td>-1.739026</td>
+      <td>120761.015625</td>
+      <td>122.064262</td>
+    </tr>
+  </tbody>
+</table>
+<p>44506 rows × 8 columns</p>
+</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>This number of events is the same as the one obtained by applying filters to the branches, a measure of both codes accuracy.</p>
+
+</div>
+</div>
+<div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
+</div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
+<h3 id="Plotting-the-invariant-mass"><em>Plotting the invariant mass</em><a class="anchor-link" href="#Plotting-the-invariant-mass">&#182;</a></h3><p>Note: The next code to plot the invariant mass is taken from the original notebook. Some minor changes have been done, for locating legends and adding titles.</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;[19]:</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="k">def</span> <span class="nf">plot_data</span><span class="p">(</span><span class="n">data</span><span class="p">):</span>   
+
+    <span class="n">xmin</span> <span class="o">=</span> <span class="mi">100</span> <span class="c1"># GeV</span>
+    <span class="n">xmax</span> <span class="o">=</span> <span class="mi">160</span> <span class="c1"># GeV</span>
+    <span class="n">step_size</span> <span class="o">=</span> <span class="mi">2</span> <span class="c1"># GeV</span>
+    
+    <span class="n">bin_edges</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="n">start</span><span class="o">=</span><span class="n">xmin</span><span class="p">,</span> <span class="n">stop</span><span class="o">=</span><span class="n">xmax</span><span class="o">+</span><span class="n">step_size</span><span class="p">,</span> <span class="n">step</span><span class="o">=</span><span class="n">step_size</span><span class="p">)</span> 
+    <span class="n">bin_centres</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">arange</span><span class="p">(</span><span class="n">start</span><span class="o">=</span><span class="n">xmin</span><span class="o">+</span><span class="n">step_size</span><span class="o">/</span><span class="mi">2</span><span class="p">,</span> <span class="n">stop</span><span class="o">=</span><span class="n">xmax</span><span class="o">+</span><span class="n">step_size</span><span class="o">/</span><span class="mi">2</span><span class="p">,</span>
+                            <span class="n">step</span><span class="o">=</span><span class="n">step_size</span><span class="p">)</span>
+
+    <span class="n">data_x</span><span class="p">,</span><span class="n">_</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">histogram</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="s1">&#39;InvariantMass&#39;</span><span class="p">],</span> <span class="n">bins</span><span class="o">=</span><span class="n">bin_edges</span><span class="p">)</span>
+    <span class="n">data_x_errors</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">sqrt</span><span class="p">(</span><span class="n">data_x</span><span class="p">)</span>
+
+    <span class="c1"># data fit</span>
+    <span class="n">polynomial_mod</span> <span class="o">=</span> <span class="n">PolynomialModel</span><span class="p">(</span><span class="mi">4</span><span class="p">)</span>
+    <span class="n">gaussian_mod</span> <span class="o">=</span> <span class="n">GaussianModel</span><span class="p">()</span>
+    
+    <span class="c1"># set initial guesses for the parameters of the polynomial model</span>
+    <span class="c1"># c0 + c1*x + c2*x^2 + c3*x^3 + c4*x^4</span>
+    <span class="n">pars</span> <span class="o">=</span> <span class="n">polynomial_mod</span><span class="o">.</span><span class="n">guess</span><span class="p">(</span><span class="n">data_x</span><span class="p">,</span> <span class="n">x</span><span class="o">=</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">c0</span><span class="o">=</span><span class="n">data_x</span><span class="o">.</span><span class="n">max</span><span class="p">(),</span> 
+                                <span class="n">c1</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">c2</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">c3</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">c4</span><span class="o">=</span><span class="mi">0</span><span class="p">)</span>
+    
+    <span class="c1"># set initial guesses for the parameters of the Gaussian model</span>
+    <span class="n">pars</span> <span class="o">+=</span> <span class="n">gaussian_mod</span><span class="o">.</span><span class="n">guess</span><span class="p">(</span><span class="n">data_x</span><span class="p">,</span> <span class="n">x</span><span class="o">=</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">amplitude</span><span class="o">=</span><span class="mi">100</span><span class="p">,</span> 
+                               <span class="n">center</span><span class="o">=</span><span class="mi">125</span><span class="p">,</span> <span class="n">sigma</span><span class="o">=</span><span class="mi">2</span><span class="p">)</span>
+    
+    <span class="c1"># combined model</span>
+    <span class="n">model</span> <span class="o">=</span> <span class="n">polynomial_mod</span> <span class="o">+</span> <span class="n">gaussian_mod</span>
+    
+    <span class="c1"># fit the model to the data</span>
+    <span class="n">out</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">fit</span><span class="p">(</span><span class="n">data_x</span><span class="p">,</span> <span class="n">pars</span><span class="p">,</span> <span class="n">x</span><span class="o">=</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">weights</span><span class="o">=</span><span class="mi">1</span><span class="o">/</span><span class="n">data_x_errors</span><span class="p">)</span> 
+
+    <span class="c1"># background part of fit</span>
+    <span class="n">params_dict</span> <span class="o">=</span> <span class="n">out</span><span class="o">.</span><span class="n">params</span><span class="o">.</span><span class="n">valuesdict</span><span class="p">()</span>
+    <span class="n">c0</span> <span class="o">=</span> <span class="n">params_dict</span><span class="p">[</span><span class="s1">&#39;c0&#39;</span><span class="p">]</span>
+    <span class="n">c1</span> <span class="o">=</span> <span class="n">params_dict</span><span class="p">[</span><span class="s1">&#39;c1&#39;</span><span class="p">]</span>
+    <span class="n">c2</span> <span class="o">=</span> <span class="n">params_dict</span><span class="p">[</span><span class="s1">&#39;c2&#39;</span><span class="p">]</span>
+    <span class="n">c3</span> <span class="o">=</span> <span class="n">params_dict</span><span class="p">[</span><span class="s1">&#39;c3&#39;</span><span class="p">]</span>
+    <span class="n">c4</span> <span class="o">=</span> <span class="n">params_dict</span><span class="p">[</span><span class="s1">&#39;c4&#39;</span><span class="p">]</span>
+    
+    <span class="c1"># get the background only part of the fit to data</span>
+    <span class="n">background</span> <span class="o">=</span> <span class="p">(</span><span class="n">c0</span> <span class="o">+</span> <span class="n">c1</span><span class="o">*</span><span class="n">bin_centres</span> <span class="o">+</span> <span class="n">c2</span><span class="o">*</span><span class="n">bin_centres</span><span class="o">**</span><span class="mi">2</span> 
+                  <span class="o">+</span> <span class="n">c3</span><span class="o">*</span><span class="n">bin_centres</span><span class="o">**</span><span class="mi">3</span> <span class="o">+</span> <span class="n">c4</span><span class="o">*</span><span class="n">bin_centres</span><span class="o">**</span><span class="mi">4</span><span class="p">)</span>
+
+    <span class="c1"># data fit - background fit = signal fit</span>
+    <span class="n">signal_x</span> <span class="o">=</span> <span class="n">data_x</span> <span class="o">-</span> <span class="n">background</span> 
+
+
+    <span class="c1"># *************</span>
+    <span class="c1"># Main plot </span>
+    <span class="c1"># *************</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">axes</span><span class="p">([</span><span class="mf">0.1</span><span class="p">,</span><span class="mf">0.3</span><span class="p">,</span><span class="mf">0.85</span><span class="p">,</span><span class="mf">0.65</span><span class="p">])</span>
+    <span class="n">main_axes</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">gca</span><span class="p">()</span>
+    
+    <span class="c1"># plot the data points</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">errorbar</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">y</span><span class="o">=</span><span class="n">data_x</span><span class="p">,</span> <span class="n">yerr</span><span class="o">=</span><span class="n">data_x_errors</span><span class="p">,</span> 
+                       <span class="n">fmt</span><span class="o">=</span><span class="s1">&#39;ko&#39;</span><span class="p">,</span> <span class="n">label</span><span class="o">=</span><span class="s1">&#39;Data&#39;</span><span class="p">)</span> 
+    
+    <span class="c1"># plot the signal + background fit</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">out</span><span class="o">.</span><span class="n">best_fit</span><span class="p">,</span> <span class="s1">&#39;-r&#39;</span><span class="p">,</span> 
+                   <span class="n">label</span><span class="o">=</span><span class="s1">&#39;Sig+Bkg Fit ($m_H=120$ GeV)&#39;</span><span class="p">)</span>
+    
+    <span class="c1"># plot the background only fit</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">background</span><span class="p">,</span> <span class="s1">&#39;--r&#39;</span><span class="p">,</span> 
+                   <span class="n">label</span><span class="o">=</span><span class="s1">&#39;Bkg (4th order polynomial)&#39;</span><span class="p">)</span>
+
+    <span class="c1"># set the x-limit of the main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">set_xlim</span><span class="p">(</span><span class="n">left</span><span class="o">=</span><span class="n">xmin</span><span class="p">,</span> <span class="n">right</span><span class="o">=</span><span class="n">xmax</span><span class="p">)</span> 
+    
+    <span class="c1"># separation of x-axis minor ticks</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">xaxis</span><span class="o">.</span><span class="n">set_minor_locator</span><span class="p">(</span><span class="n">AutoMinorLocator</span><span class="p">())</span> 
+    
+    <span class="c1"># set the axis tick parameters for the main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">tick_params</span><span class="p">(</span><span class="n">which</span><span class="o">=</span><span class="s1">&#39;both&#39;</span><span class="p">,</span> <span class="n">direction</span><span class="o">=</span><span class="s1">&#39;in&#39;</span><span class="p">,</span> <span class="n">top</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> 
+                          <span class="n">labelbottom</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span> <span class="n">right</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
+    
+    <span class="c1"># write y-axis label for main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">set_ylabel</span><span class="p">(</span><span class="s1">&#39;Events / &#39;</span><span class="o">+</span><span class="nb">str</span><span class="p">(</span><span class="n">step_size</span><span class="p">)</span><span class="o">+</span><span class="s1">&#39; GeV&#39;</span><span class="p">,</span> 
+                         <span class="n">horizontalalignment</span><span class="o">=</span><span class="s1">&#39;right&#39;</span><span class="p">)</span> 
+    
+    <span class="c1"># set the y-axis limit for the main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">set_ylim</span><span class="p">(</span><span class="n">bottom</span><span class="o">=</span><span class="mi">0</span><span class="p">,</span> <span class="n">top</span><span class="o">=</span><span class="n">np</span><span class="o">.</span><span class="n">amax</span><span class="p">(</span><span class="n">data_x</span><span class="p">)</span><span class="o">*</span><span class="mf">1.1</span><span class="p">)</span> 
+    
+    <span class="c1"># set minor ticks on the y-axis of the main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">set_minor_locator</span><span class="p">(</span><span class="n">AutoMinorLocator</span><span class="p">())</span> 
+
+    <span class="c1"># avoid displaying y=0 on the main axes</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">get_major_ticks</span><span class="p">()[</span><span class="mi">0</span><span class="p">]</span><span class="o">.</span><span class="n">set_visible</span><span class="p">(</span><span class="kc">False</span><span class="p">)</span> 
+
+    <span class="c1"># Add text &#39;ATLAS Open Data&#39; on plot</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="mf">0.67</span><span class="p">,</span> <span class="mf">0.92</span><span class="p">,</span> <span class="s1">&#39;ATLAS Open Data&#39;</span><span class="p">,</span> <span class="n">transform</span><span class="o">=</span><span class="n">main_axes</span><span class="o">.</span><span class="n">transAxes</span><span class="p">,</span> 
+             <span class="n">fontsize</span><span class="o">=</span><span class="mi">13</span> <span class="p">)</span> 
+    
+    <span class="c1"># Add text &#39;for education&#39; on plot</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="mf">0.83</span><span class="p">,</span> <span class="mf">0.86</span><span class="p">,</span> <span class="s1">&#39;for education&#39;</span><span class="p">,</span> <span class="n">transform</span><span class="o">=</span><span class="n">main_axes</span><span class="o">.</span><span class="n">transAxes</span><span class="p">,</span> 
+             <span class="n">style</span><span class="o">=</span><span class="s1">&#39;italic&#39;</span><span class="p">,</span> <span class="n">fontsize</span><span class="o">=</span><span class="mi">8</span><span class="p">)</span> 
+    
+    <span class="c1"># Add energy and luminosity on plot</span>
+    <span class="n">lumi_used</span> <span class="o">=</span> <span class="nb">str</span><span class="p">(</span><span class="n">lumi</span><span class="o">*</span><span class="n">fraction</span><span class="p">)</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="mf">0.60</span><span class="p">,</span> <span class="mf">0.8</span><span class="p">,</span> <span class="s1">&#39;$\sqrt</span><span class="si">{s}</span><span class="s1">$=13 TeV,$\int$L dt =&#39;</span><span class="o">+</span><span class="n">lumi_used</span><span class="o">+</span><span class="s1">&#39;fb$^{-1}$&#39;</span><span class="p">,</span>
+             <span class="n">transform</span><span class="o">=</span><span class="n">main_axes</span><span class="o">.</span><span class="n">transAxes</span><span class="p">)</span> 
+    
+    <span class="c1"># Add a label for the analysis carried out</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">text</span><span class="p">(</span><span class="mf">0.89</span><span class="p">,</span> <span class="mf">0.74</span><span class="p">,</span> <span class="sa">r</span><span class="s1">&#39;$H \rightarrow \gamma\gamma$&#39;</span><span class="p">,</span>
+             <span class="n">transform</span><span class="o">=</span><span class="n">main_axes</span><span class="o">.</span><span class="n">transAxes</span><span class="p">)</span>
+
+    <span class="c1"># draw the legend</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">legend</span><span class="p">(</span><span class="n">frameon</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span> <span class="n">loc</span><span class="o">=</span><span class="s1">&#39;lower left&#39;</span><span class="p">)</span>
+    
+    <span class="c1"># Add title over plot</span>
+    
+    <span class="n">plt</span><span class="o">.</span><span class="n">title</span><span class="p">(</span><span class="sa">r</span><span class="s1">&#39;$H \rightarrow \gamma\gamma$ search from ATLAS Open Data&#39;</span><span class="p">)</span>
+
+
+    <span class="c1"># *************</span>
+    <span class="c1"># Data-Bkg plot </span>
+    <span class="c1"># *************</span>
+    <span class="n">plt</span><span class="o">.</span><span class="n">axes</span><span class="p">([</span><span class="mf">0.1</span><span class="p">,</span><span class="mf">0.1</span><span class="p">,</span><span class="mf">0.85</span><span class="p">,</span><span class="mf">0.2</span><span class="p">])</span>
+    <span class="n">sub_axes</span> <span class="o">=</span> <span class="n">plt</span><span class="o">.</span><span class="n">gca</span><span class="p">()</span>
+    
+    <span class="c1"># set the y axis to be symmetric about Data-Background=0</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">set_major_locator</span><span class="p">(</span><span class="n">MaxNLocator</span><span class="p">(</span><span class="n">nbins</span><span class="o">=</span><span class="s1">&#39;auto&#39;</span><span class="p">,</span> 
+                                                  <span class="n">symmetric</span><span class="o">=</span><span class="kc">True</span><span class="p">))</span>
+    
+    <span class="c1"># plot Data-Background</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">errorbar</span><span class="p">(</span><span class="n">x</span><span class="o">=</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">y</span><span class="o">=</span><span class="n">signal_x</span><span class="p">,</span> <span class="n">yerr</span><span class="o">=</span><span class="n">data_x_errors</span><span class="p">,</span>
+                      <span class="n">fmt</span><span class="o">=</span><span class="s1">&#39;ko&#39;</span><span class="p">)</span>
+    
+    <span class="c1"># draw the fit to data</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">out</span><span class="o">.</span><span class="n">best_fit</span><span class="o">-</span><span class="n">background</span><span class="p">,</span><span class="s1">&#39;-r&#39;</span><span class="p">)</span>
+    
+    <span class="c1"># draw the background only fit</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="n">bin_centres</span><span class="p">,</span> <span class="n">background</span><span class="o">-</span><span class="n">background</span><span class="p">,</span> <span class="s1">&#39;--r&#39;</span><span class="p">)</span>
+    
+    <span class="c1"># set the x-axis limits on the sub axes</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">set_xlim</span><span class="p">(</span><span class="n">left</span><span class="o">=</span><span class="n">xmin</span><span class="p">,</span> <span class="n">right</span><span class="o">=</span><span class="n">xmax</span><span class="p">)</span> 
+    
+    <span class="c1"># separation of x-axis minor ticks</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">xaxis</span><span class="o">.</span><span class="n">set_minor_locator</span><span class="p">(</span><span class="n">AutoMinorLocator</span><span class="p">())</span> 
+    
+    <span class="c1"># x-axis label</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">set_xlabel</span><span class="p">(</span><span class="sa">r</span><span class="s1">&#39;di-photon invariant mass $\mathrm{m_{\gamma\gamma}}$&#39;</span>
+                        <span class="s1">&#39;[GeV]&#39;</span><span class="p">,</span><span class="n">x</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span> <span class="n">horizontalalignment</span><span class="o">=</span><span class="s1">&#39;right&#39;</span><span class="p">,</span> <span class="n">fontsize</span><span class="o">=</span><span class="mi">13</span><span class="p">)</span> 
+    
+    <span class="c1"># set the tick parameters for the sub axes</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">tick_params</span><span class="p">(</span><span class="n">which</span><span class="o">=</span><span class="s1">&#39;both&#39;</span><span class="p">,</span> <span class="n">direction</span><span class="o">=</span><span class="s1">&#39;in&#39;</span><span class="p">,</span>
+                         <span class="n">top</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">right</span><span class="o">=</span><span class="kc">True</span> <span class="p">)</span>
+    
+    <span class="c1"># separation of y-axis minor ticks</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">set_minor_locator</span><span class="p">(</span><span class="n">AutoMinorLocator</span><span class="p">())</span> 
+    
+    <span class="c1"># y-axis label on the sub axes</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">set_ylabel</span><span class="p">(</span><span class="s1">&#39;Events-Bkg&#39;</span><span class="p">)</span> 
+
+
+    <span class="c1"># Generic features for both plots</span>
+    <span class="n">main_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">set_label_coords</span><span class="p">(</span><span class="o">-</span><span class="mf">0.09</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
+    <span class="n">sub_axes</span><span class="o">.</span><span class="n">yaxis</span><span class="o">.</span><span class="n">set_label_coords</span><span class="p">(</span><span class="o">-</span><span class="mf">0.09</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">)</span>
+    
+    
+    
+    <span class="k">return</span>
+</pre></div>
+
+     </div>
+</div>
+</div>
+</div>
+
+</div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
+<div class="jp-Cell-inputWrapper">
+<div class="jp-InputArea jp-Cell-inputArea">
+<div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[20]:</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"># Luminosity corresponding to data_A.GamGam.root</span>
+<span class="n">lumi</span> <span class="o">=</span> <span class="mf">0.5</span>
+<span class="c1"># Fraction of the data used</span>
+<span class="n">fraction</span> <span class="o">=</span> <span class="mi">1</span>
+
+<span class="c1"># To plot the invariant mass</span>
+<span class="n">plot_data</span><span class="p">(</span><span class="n">photonDataFrame</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="
+"
+>
+</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>The above graph suggests, luckily, a Higgs-like particle at 120 GeV.
+At the moment, this notebook ends here. But the research continues.</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">
+
+</div>
+</div>
+</body>
+
+
+
+
+
+
+
+</html>
diff --git a/codigo/dataAnalysisHyy.ipynb b/codigo/dataAnalysisHyy.ipynb
new file mode 100644
index 0000000..f2c4d4b
--- /dev/null
+++ b/codigo/dataAnalysisHyy.ipynb
@@ -0,0 +1,1145 @@
+{
+ "cells": [
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "### Student: María José Ramos \n",
+    "\n",
+    "# Data Science\n",
+    "## Module 1: Research Software Engineering\n",
+    "\n",
+    "### Final homework: Data Analysis Project\n"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "Inspired by Higgs boson discovery and the notebooks collection from ATLAS Open Data, this notebook explores [open data](http://opendata.atlas.cern) from the ATLAS experiment concerning photon events, in order to look for Higgs boson signals in the graph of invariant mass for diphotonic systems. \n",
+    "This work is heavily based on: [HyyAnalysis notebook](https://github.com/atlas-outreach-data-tools/notebooks-collection-opendata/blob/master/13-TeV-examples/uproot_python/HyyAnalysis.ipynb), although it offers a new approach to generate the dataframe, and a quick revision of the variables that are used to filter photons.  \n",
+    "The photons conditions considered in this analysis come from criteria mentioned in Higgs boson search papers by ATLAS Collaboration, mainly: [Observation of a New Particle in the Search for the Standard Model Higgs Bosonwith the ATLAS Detector at the LHC](https://arxiv.org/pdf/1207.7214.pdf)  \n",
+    "  For more information on uproot, consult this [tutorial](https://hsf-training.github.io/hsf-training-uproot-webpage/index.html), that provided useful information to this notebook.  \n",
+    "  Also note most of this work was done in ATLAS Virtual Machine: [![DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.3629875.svg)](https://doi.org/10.5281/zenodo.3629875)  "
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "Tools:\n",
+    "* time: to measure time to generate the final dataframe\n",
+    "* uproot3: to read the .root file into data formats used in python\n",
+    "* pandas: to store data as dataframe.\n",
+    "* numpy: for numerical calculations involving arrays.\n",
+    "* matplotlib: for making plots.\n",
+    "* lmfit: for statistical fitting in the final plot.\n",
+    "* Colormaps: for coloring histograms \n"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 1,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "import time\n",
+    "import uproot3\n",
+    "import pandas as pd\n",
+    "import numpy as np\n",
+    "import matplotlib.pyplot as plt\n",
+    "from matplotlib import cm\n",
+    "from matplotlib.ticker import MaxNLocator, AutoMinorLocator\n",
+    "from lmfit.models import PolynomialModel, GaussianModel\n"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 2,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "colors = plt.get_cmap('gist_rainbow', 10)"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "### *Exploring the data*"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "To open a root file in python, one can use uproot, both to open a local file or by an url. After assign it to a variable *data*, one can explore its *key* and store it in a *tree*, which has tables of information organized by *branches*, that covers a range of events. To get the name of these *branches*, one can access to the *tree* keys."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 3,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "# Open data from file\n",
+    "data = uproot3.open('/home/ramosm/ejercicios-clase-08-datos/data-used/data_A.GamGam.root')\n",
+    "# URL: data = uproot3.open('https://atlas-opendata.web.cern.ch/atlas-opendata/samples/2020/GamGam/Data/')"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 4,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "text/plain": [
+       "[b'mini;1']"
+      ]
+     },
+     "execution_count": 4,
+     "metadata": {},
+     "output_type": "execute_result"
+    }
+   ],
+   "source": [
+    "# Know the data keys:\n",
+    "data.keys()"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 5,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "text/plain": [
+       "[b'runNumber',\n",
+       " b'eventNumber',\n",
+       " b'channelNumber',\n",
+       " b'mcWeight',\n",
+       " b'scaleFactor_PILEUP',\n",
+       " b'scaleFactor_ELE',\n",
+       " b'scaleFactor_MUON',\n",
+       " b'scaleFactor_PHOTON',\n",
+       " b'scaleFactor_TAU',\n",
+       " b'scaleFactor_BTAG',\n",
+       " b'scaleFactor_LepTRIGGER',\n",
+       " b'scaleFactor_PhotonTRIGGER',\n",
+       " b'trigE',\n",
+       " b'trigM',\n",
+       " b'trigP',\n",
+       " b'lep_n',\n",
+       " b'lep_truthMatched',\n",
+       " b'lep_trigMatched',\n",
+       " b'lep_pt',\n",
+       " b'lep_eta',\n",
+       " b'lep_phi',\n",
+       " b'lep_E',\n",
+       " b'lep_z0',\n",
+       " b'lep_charge',\n",
+       " b'lep_type',\n",
+       " b'lep_isTightID',\n",
+       " b'lep_ptcone30',\n",
+       " b'lep_etcone20',\n",
+       " b'lep_trackd0pvunbiased',\n",
+       " b'lep_tracksigd0pvunbiased',\n",
+       " b'met_et',\n",
+       " b'met_phi',\n",
+       " b'jet_n',\n",
+       " b'jet_pt',\n",
+       " b'jet_eta',\n",
+       " b'jet_phi',\n",
+       " b'jet_E',\n",
+       " b'jet_jvt',\n",
+       " b'jet_trueflav',\n",
+       " b'jet_truthMatched',\n",
+       " b'jet_MV2c10',\n",
+       " b'photon_n',\n",
+       " b'photon_truthMatched',\n",
+       " b'photon_trigMatched',\n",
+       " b'photon_pt',\n",
+       " b'photon_eta',\n",
+       " b'photon_phi',\n",
+       " b'photon_E',\n",
+       " b'photon_isTightID',\n",
+       " b'photon_ptcone30',\n",
+       " b'photon_etcone20',\n",
+       " b'photon_convType',\n",
+       " b'tau_n',\n",
+       " b'tau_pt',\n",
+       " b'tau_eta',\n",
+       " b'tau_phi',\n",
+       " b'tau_E',\n",
+       " b'tau_isTightID',\n",
+       " b'tau_truthMatched',\n",
+       " b'tau_trigMatched',\n",
+       " b'tau_nTracks',\n",
+       " b'tau_BDTid',\n",
+       " b'ditau_m',\n",
+       " b'lep_pt_syst',\n",
+       " b'met_et_syst',\n",
+       " b'jet_pt_syst',\n",
+       " b'photon_pt_syst',\n",
+       " b'tau_pt_syst',\n",
+       " b'XSection',\n",
+       " b'SumWeights',\n",
+       " b'largeRjet_n',\n",
+       " b'largeRjet_pt',\n",
+       " b'largeRjet_eta',\n",
+       " b'largeRjet_phi',\n",
+       " b'largeRjet_E',\n",
+       " b'largeRjet_m',\n",
+       " b'largeRjet_truthMatched',\n",
+       " b'largeRjet_D2',\n",
+       " b'largeRjet_tau32',\n",
+       " b'largeRjet_pt_syst',\n",
+       " b'tau_charge']"
+      ]
+     },
+     "execution_count": 5,
+     "metadata": {},
+     "output_type": "execute_result"
+    }
+   ],
+   "source": [
+    "# Generate tree\n",
+    "tree = data['mini']\n",
+    "# Exploring the data\n",
+    "tree.keys()"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "For this analysis, these are the variables needed:\n",
+    "* photon_n: number of photons in the event.\n",
+    "* photon_isTightID: boolean indicating whether the photon tight identification reconstruction criteria.\n",
+    "* photon_pt: transverse momentum of the photon.\n",
+    "* photon_eta: pseudorapidity of the photon.\n",
+    "* photon_phi: azimuthal angle of the photon.\n",
+    "* photon_E: energy of the photon.\n",
+    "* photon_etcone20: scalar sum of track $E_{t}$ in a cone of R=0.2 around photon. \n",
+    "  \n",
+    "These *branches* have their information ordered in *arrays*."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 6,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "As you can see, this branch contains arrays:\n"
+     ]
+    },
+    {
+     "data": {
+      "text/plain": [
+       "<JaggedArray [[46690.223 29442.607] [60888.74 37795.01] [39186.21 25327.361] ... [39450.035 31067.45] [65747.49 33625.59] [40766.176 35701.254]] at 0x7fa4aa3796a0>"
+      ]
+     },
+     "execution_count": 6,
+     "metadata": {},
+     "output_type": "execute_result"
+    }
+   ],
+   "source": [
+    "# Assign the branches \n",
+    "branches = tree.arrays(namedecode='utf-8')\n",
+    "# Explore one branch as an example:\n",
+    "print('As you can see, this branch contains arrays:')\n",
+    "branches['photon_pt']"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 7,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "Number of events in the data / Number of photon systems: 430344\n",
+      "Total number of photons: 862157\n"
+     ]
+    }
+   ],
+   "source": [
+    "# To know the number of events or the number of photon systems\n",
+    "events = len(tree)\n",
+    "# To know the number of actual photons\n",
+    "photons = len(branches['photon_pt'].flatten())\n",
+    "\n",
+    "print(f'Number of events in the data / Number of photon systems: {events}')\n",
+    "print(f'Total number of photons: {photons}')"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "### *Studying the photon events and finding candidates*\n",
+    "\n",
+    "To search for a higgs boson decay in diphoton systems, the first filter will be of course to only consider events of two photons (*photon_n* == 2) and the second one, that both of these photons pass the photon tight identification reconstruction criteria. This last condition means a photon has been identified and reconstructed as a photon (*photon_isTightID* == True). Note that in the referenced notebook this first filter is not applied."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 8,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "Minimum number of photons per system: 2\n",
+      "Maximum number of photons per system: 4\n"
+     ]
+    },
+    {
+     "data": {
+      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZcAAAEWCAYAAACqitpwAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAgI0lEQVR4nO3de7hVVb3/8fdHBCURUSGTi2KJp7A6pju19JRhKV4Sf6WleQ81y1KPWaGPecn6qdn9dFHLEssjkpagaUgKlhXCxruguTMMUANFuWhe0O/5Y46l0+Xea09grrXYi8/redaz5xxzjDm+cy1Y3zVvYyoiMDMzK9N6zQ7AzMxaj5OLmZmVzsnFzMxK5+RiZmalc3IxM7PSObmYmVnpnFxsrSbpcklfb1LfkvQLSU9Lmrka7adLOrYesZmt7ZxcbJVImidpkaSNcmXHSprexLDqZXfgI8DQiNi5kR2n9/nDjeyzp5G0h6QFzY7DOufkYqujF3Bys4NYVZJ6rWKTrYF5EfFsPeJpZZLWb3YM1lxOLrY6LgJOkzSgeoGk4ZIi/+WSPzwk6WhJf5b0XUnPSHpE0vtT+fy0V3RU1WoHSpoqabmk2yRtnVv329OyJZIekvSJ3LLLJf1E0o2SngU+1Em8gyVNTu07JB2XyscCPwPeJ2mFpHM7aVvZlh9KWirpQUl7VlXbOtVZLulmSQNz7Q+Q9EB6H6ZLekcq/yWwFXB96vvLteqnZfMknSbp3hTL1ZI2TMsGSrohtVsi6U+SOv2/nz67k9Ln8qSki/J1JX1a0tx0qHBK1WcRkk6U9DDwcCfr3lDSryQ9lWKZJWkLSQdLml1V91RJk9L0vpLmpPdwYdrOjYCbgMHpPVqRPsv1JI2T9PfUz0RJm6X1VP5tHpP+rT0t6QRJ703v2zOSftjZ+2KrISL88qvwC5gHfBj4DfD1VHYsMD1NDwcCWD/XZjpwbJo+GlgJHEO2B/R14J/Aj4ANgL2A5UC/VP/yNP+BtPz7wO1p2UbA/LSu9YH3AE8CI3NtlwK7kf2Q2rCT7fkj8GNgQ2AHYDEwKhfr7TXei8q2/DfQG/hk6m+z3Hb/HdgO6JvmL0jLtgOeJTvs1hv4MtAB9Mm/z7m+itSfCQwGNgPmAiekZecDF6d2vYH/AtTFNgUwLa1jK+Bvuc9uTOrzHen9PhP4S1Xbqalt307W/RngeuBN6bPfCeifPtclwDtyde8CPp6mHwf+K01vCuyYpvcAFlT1cTIwAxia1nsJcFXVv82L0+e9F/A8cB3wZmAIsAj4YLP/n7XCq+kB+NWzXryWXN6ZvkgHserJ5eHcsnel+lvkyp4CdkjTlwMTcsv6AS8Dw8i+zP9UFd8lwNm5tlfU2JZhaV0b58rOBy7Pxdpdcnks/0VN9gV/RG67z8wt+xzw+zT9VWBibtl6wEJgj/z7nFtepP7hueXfBC5O018DJgHbFvh8AxhdFfMtafomYGxVDM8BW+fajqqx7k8DfwHe3cmynwDfSNPbA08DG6T5f5Ilpv5VbfbgjcllLrBnbn5L4CWyZDg8xTik6t/aJ3Pz1wKnNPv/WSu8fFjMVktE3A/cAIxbjeb/yk3/O62vuqxfbn5+rt8VZL9yB5OdE9klHc54RtIzwGHAWzpr24nBwJKIWJ4re5TsF2xRCyN9K+XaD87NP5Gbfo7XtmtwqgtARLySYu2q7yL1u+rrIrI9jpvT4a7uPrP8e5bfnq2B7+fe6yWAqmKo9X7/EpgCTJD0mKRvSuqdlo0HPiVJwBFkifSFtOzjwL7Ao+mw6Ptq9LE18NtcjHPJfkBskatT/W+t1r89W01OLrYmzgaO4/VfLpWT32/KleW/7FfHsMqEpH5kh10eI/siuy0iBuRe/SLis7m2tYb9fgzYTNLGubKtyPYIihqSvhDz7R8r0O4xsi9CILvsmWw7K31Xx91d/S5FxPKI+GJEvBU4ADi1k3NDecNy0/ntmQ98pur97hsRf8l3VyOOlyLi3IgYCbwf2B84Mi2bAbxIdsjuU2SJqNJuVkSMITt0dR0wsUZf84F9qmLcMCJW5TO1Eji52GqLiA7gauCkXNlisi+8wyX1kvRp4G1r2NW+knaX1Ac4D5gREfPJ9py2k3SEpN7p9d78ie5u4p9Pdpjm/HSy+d3AWOBXqxDbm4GTUt8Hk52PuLFAu4nAfpL2TL/evwi8kOKB7Nf0W1ehfpck7S9p25SQlpL9kn+lRpMvSdpU0jCycxhXp/KLgdMlbZ/Wu0na5kIkfUjSu5RdtbeM7HBVPo4rgB8CL0XE7alNH0mHSdokIl5K7Spt/gVsLmmT3DouBr5RudBA0iBJY4rGaOVxcrE19TWyE+t5xwFfIjuevT0FvgC78b9ke0lLyE4CHw7ZL3Kyk7KHkP26fgK4kOxEblGHkh2Lfwz4Ldn5mj+sQvs7gBFkFxJ8AzgoIp7qrlFEPES2Hf+T2n4U+GhEvJiqnA+cmQ7vnFagfi0jgD8AK4C/Aj+OiGk16k8CZgN3A78DLksx/5bs/Z0gaRlwP7BPgf4r3gJcQ5Yg5gK3kdtDSdPv5I3J/QhgXurzBLJDn0TEg8BVwCPpfRpMdsHHZLJDgMvJTu7vsgoxWkn0+sPFZlaUpKPJLlTYvdmxlEVSACPSXmmj++5LdrXWjhHxhkuZrWfxnouZrS0+C8xyYmkNvovWzJpO0jyyK88ObG4kVhYfFjMzs9L5sJiZmZXOh8WSgQMHxvDhw5sdhplZjzJ79uwnI2JQdbmTSzJ8+HDa29ubHYaZWY8i6dHOyn1YzMzMSufkYmZmpXNyMTOz0jm5mJlZ6ZxczMysdE4uZmZWOicXMzMrnZOLmZmVzsnFzMxK5zv0zYrSyGZH0Hgxp9kRWA/lPRczMyudk4uZmZXOycXMzErn5GJmZqVzcjEzs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK13dk4ukXpLuknRDmt9G0h2SOiRdLalPKt8gzXek5cNz6zg9lT8kae9c+ehU1iFpXK680z7MzKwxGrHncjIwNzd/IfDdiNgWeBoYm8rHAk+n8u+mekgaCRwCbA+MBn6cElYv4EfAPsBI4NBUt1YfZmbWAHVNLpKGAvsBP0vzAkYB16Qq44ED0/SYNE9avmeqPwaYEBEvRMQ/gA5g5/TqiIhHIuJFYAIwpps+zMysAeq95/I94MvAK2l+c+CZiFiZ5hcAQ9L0EGA+QFq+NNV/tbyqTVfltfowM7MGqFtykbQ/sCgiZterjzUl6XhJ7ZLaFy9e3OxwzMxaRj33XHYDDpA0j+yQ1Sjg+8AASZWh/ocCC9P0QmAYQFq+CfBUvryqTVflT9Xo43Ui4tKIaIuItkGDBq3+lpqZ2evULblExOkRMTQihpOdkL81Ig4DpgEHpWpHAZPS9OQ0T1p+a0REKj8kXU22DTACmAnMAkakK8P6pD4mpzZd9WFmZg3QjPtcvgKcKqmD7PzIZan8MmDzVH4qMA4gIh4AJgJzgN8DJ0bEy+mcyueBKWRXo01MdWv1YWZmDaDsh761tbVFe3t7s8OwtZmfRGn2BpJmR0Rbdbnv0Dczs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK52Ti5mZlc7JxczMSufkYmZmpXNyMTOz0jm5mJlZ6ZxczMysdE4uZmZWOicXMzMrnZOLmZmVzsnFzMxK5+RiZmalc3IxM7PSObmYmVnpnFzMzKx0Ti5mZlY6JxczMyudk4uZmZXOycXMzErn5GJmZqVzcjEzs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK52Ti5mZlc7JxczMSufkYmZmpXNyMTOz0jm5mJlZ6ZxczMysdE4uZmZWOicXMzMrXbfJRdI3JfWX1FvSLZIWSzq8EcGZmVnPVGTPZa+IWAbsD8wDtgW+VM+gzMysZyuSXHqnv/sBv46IpXWMx8zMWkCR5HK9pAeBnYBbJA0Cnu+ukaQNJc2UdI+kBySdm8q3kXSHpA5JV0vqk8o3SPMdafnw3LpOT+UPSdo7Vz46lXVIGpcr77QPMzNrjCLJ5Wzg/UBbRLwEPAccUKDdC8CoiPhPYAdgtKRdgQuB70bEtsDTwNhUfyzwdCr/bqqHpJHAIcD2wGjgx5J6SeoF/AjYBxgJHJrqUqMPMzNrgCLJ5a8RsSQiXgaIiGeBm7prFJkVabZ3egUwCrgmlY8HDkzTY9I8afmekpTKJ0TECxHxD6AD2Dm9OiLikYh4EZgAjEltuurDzMwaYP2uFkh6CzAE6CvpPYDSov7Am4qsPO1dzCa7COBHwN+BZyJiZaqyIPVB+jsfICJWSloKbJ7KZ+RWm28zv6p8l9Smqz6q4zseOB5gq622KrJJZmZWQJfJBdgbOBoYCnwnV74cOKPIytPezg6SBgC/Bd6+WlHWSURcClwK0NbWFk0Ox8ysZXSZXCJiPDBe0scj4to16SQinpE0DXgfMEDS+mnPYiiwMFVbCAwDFkhaH9gEeCpXXpFv01n5UzX6MDOzBihyzuUGSZ+SdIaksyqv7hpJGpT2WJDUF/gIMBeYBhyUqh0FTErTk9M8afmtERGp/JB0Ndk2wAhgJjALGJGuDOtDdtJ/cmrTVR9mZtYAtQ6LVUwClpKdO3lhFda9JdmeTy+yJDYxIm6QNAeYIOnrwF3AZan+ZcAvJXUAS8iSBRHxgKSJwBxgJXBi5eICSZ8HpgC9gJ9HxANpXV/pog8zM2sAZT/0a1SQ7o+IdzYonqZpa2uL9vb2Zodha7NXr3Rfh8ScZkdgazlJsyOirbq8yGGxv0h6Vx1iMjOzFlXksNjuwNGS/kF2WExkt7G8u66RmZlZj1UkuexT9yjMzKyldHtYLCIeJbvkd1Safq5IOzMzW3cVeZ7L2WRXX52einoDv6pnUGZm1rMV2QP5f2QDVT4LEBGPARvXMygzM+vZiiSXF9ONiQEgaaP6hmRmZj1dkeQyUdIlZEOqHAf8AfhpfcMyM7OerNurxSLiW5I+AiwD/gM4KyKm1j0yMzPrsbpNLpJOBa52QjEzs6KKHBbbGLhZ0p8kfV7SFvUOyszMerYi97mcGxHbAyeSDUZ5m6Q/1D0yMzPrsVblZshFwBNkz0t5c33CMTOzVlDkJsrPSZoO3EL2COHjPK6YmZnVUmRssWHAKRFxd51jMTOzFlHknMvpQD9Jx8CrT5jcpu6RmZlZj+WxxczMrHQeW8zMzErnscXMzKx0HlvMzMxK57HFzMysdEUuRSYlEycUMzMrxI8rNjOz0jm5mJlZ6bpMLpJuSX8vbFw4ZmbWCmqdc9lS0vuBAyRNAJRfGBF31jUyMzPrsWoll7OArwJDge9ULQtgVL2CMjOznq3L5BIR1wDXSPpqRJzXwJjMzKyHK3Kfy3mSDgA+kIqmR8QN9Q3LzMx6siIDV54PnAzMSa+TJf3/egdmZmY9V5GbKPcDdoiIVwAkjQfuAs6oZ2BmZtZzFb3PZUBuepM6xGFmZi2kyJ7L+cBdkqaRXY78AWBcXaMyM7MercgJ/askTQfem4q+EhFP1DUqMzPr0YoOXPk4MLnOsZiZWYvw2GJmZlY6JxczMytdzeQiqZekBxsVjJmZtYaaySUiXgYekrRVg+IxM7MWUOSw2KbAA5JukTS58uqukaRhkqZJmiPpAUknp/LNJE2V9HD6u2kql6QfSOqQdK+kHXPrOirVf1jSUbnynSTdl9r8QJJq9WFmZo1R5Gqxr67mulcCX4yIOyVtDMyWNBU4GrglIi6QNI7snpmvAPsAI9JrF+AnwC6SNgPOBtrIRmOeLWlyRDyd6hwH3AHcCIwGbkrr7KwPMzNrgG73XCLiNmAe0DtNzwK6fZZLRDxeeeZLRCwH5gJDgDHA+FRtPHBgmh4DXBGZGcAASVsCewNTI2JJSihTgdFpWf+ImBERAVxRta7O+jAzswYoMnDlccA1wCWpaAhw3ap0Imk48B6yPYwt0n0zAE8AW+TWOz/XbEEqq1W+oJNyavRRHdfxktoltS9evHhVNsnMzGoocs7lRGA3YBlARDwMvLloB5L6AdcCp0TEsvyytMcRhaNdDbX6iIhLI6ItItoGDRpUzzDMzNYpRZLLCxHxYmVG0voUTAiSepMllisj4jep+F/pkBbp76JUvhAYlms+NJXVKh/aSXmtPszMrAGKJJfbJJ0B9JX0EeDXwPXdNUpXbl0GzI2I/GOSJwOVK76OAiblyo9MV43tCixNh7amAHtJ2jRd9bUXMCUtWyZp19TXkVXr6qwPMzNrgCJXi40DxgL3AZ8huyrrZwXa7QYcAdwn6e5UdgZwATBR0ljgUeATadmNwL5AB/AccAxARCyRdB7ZhQQAX4uIJWn6c8DlQF+yq8RuSuVd9WFmZg2g7JREN5WkPsDbyQ6HPZQ/TNYq2traor29vdlh2NpMI5sdQePFnGZHYGs5SbMjoq26vNs9F0n7ARcDfyd7nss2kj4TETfVbmlmZuuqIofFvg18KCI6ACS9Dfgdrx2CMjMze50iJ/SXVxJL8giwvE7xmJlZC+hyz0XSx9Jku6QbgYlk51wO5rWT62ZmZm9Q67DYR3PT/wI+mKYXk12dZWZm1qkuk0tEHNPIQMzMrHUUuVpsG+ALwPB8/Yg4oH5hmZlZT1bkarHryO60vx54pa7RmJlZSyiSXJ6PiB/UPRIzM2sZRZLL9yWdDdwMvFAprDyrxczMrFqR5PIusjHCRvHaYbFI82ZmZm9QJLkcDLy1FccTMzOz+ihyh/79wIA6x2FmZi2kyJ7LAOBBSbN4/TkXX4psZmadKpJczq57FGZm1lK6TS4RcVsjAjEzs9ZR5A795WRXhwH0AXoDz0ZE/3oGZmZmPVeRPZeNK9PpWfVjgF3rGZSZmfVsRa4We1VkrgP2rk84ZmbWCoocFvtYbnY9oA14vm4RmZlZj1fkarH8c11WAvPIDo2ZmZl1qsg5Fz/XxczMVkmtxxyfVaNdRMR5dYjHzMxaQK09l2c7KdsIGAtsDji5mJlZp2o95vjblWlJGwMnA8cAE4Bvd9XOzMys5jkXSZsBpwKHAeOBHSPi6UYEZmZmPVetcy4XAR8DLgXeFRErGhaVmZn1aLVuovwiMBg4E3hM0rL0Wi5pWWPCMzOznqjWOZdVunvfzMyswgnEzMxK5+RiZmalc3IxM7PSObmYmVnpnFzMzKx0Ti5mZlY6JxczMyudk4uZmZXOycXMzErn5GJmZqWrW3KR9HNJiyTdnyvbTNJUSQ+nv5umckn6gaQOSfdK2jHX5qhU/2FJR+XKd5J0X2rzA0mq1YeZmTVOPfdcLgdGV5WNA26JiBHALWkeYB9gRHodD/wEXh3y/2xgF2Bn4OxcsvgJcFyu3ehu+jAzswapW3KJiD8CS6qKx5A9F4b098Bc+RWRmQEMkLQlsDcwNSKWpOfITAVGp2X9I2JGRARwRdW6OuvDzMwapNHnXLaIiMfT9BPAFml6CDA/V29BKqtVvqCT8lp9mJlZgzTthH7a44hm9iHpeEntktoXL15cz1DMzNYpjU4u/0qHtEh/F6XyhcCwXL2hqaxW+dBOymv18QYRcWlEtEVE26BBg1Z7o8zM7PUanVwmA5Urvo4CJuXKj0xXje0KLE2HtqYAe0naNJ3I3wuYkpYtk7RrukrsyKp1ddaHmZk1SJdPolxTkq4C9gAGSlpAdtXXBcBESWOBR4FPpOo3AvsCHcBzwDEAEbFE0nnArFTvaxFRuUjgc2RXpPUFbkovavRhZmYNouy0hLW1tUV7e3uzw7C1mUY2O4LGiznNjsDWcpJmR0Rbdbnv0Dczs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK52Ti5mZlc7JxczMSufkYmZmpXNyMTOz0jm5mJlZ6ZxczMysdE4uZmZWOicXMzMrnZOLmZmVzsnFzMxK5+RiZmalc3IxM7PSObmYmVnpnFzMzKx0Ti5mZlY6JxczMyudk4uZmZXOycXMzErn5GJmZqVzcjEzs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK52Ti5mZlc7JxczMSufkYmZmpXNyMTOz0jm5mJlZ6ZxczMysdE4uZmZWOicXMzMrnZOLmZmVzsnFzMxK5+RiZmala9nkImm0pIckdUga1+x4zMzWJS2ZXCT1An4E7AOMBA6VNLK5UZmZrTvWb3YAdbIz0BERjwBImgCMAeY0NSqznmZd/E0W/pooQ6smlyHA/Nz8AmCX6kqSjgeOT7MrJD20mv0NBJ5czbY9lbd53bDubbO0rm3zmm7v1p0VtmpyKSQiLgUuXdP1SGqPiLYSQuoxvM3rBm9z66vX9rbkORdgITAsNz80lZmZWQO0anKZBYyQtI2kPsAhwOQmx2Rmts5oycNiEbFS0ueBKUAv4OcR8UAdu1zjQ2s9kLd53eBtbn112V5FRD3Wa2Zm67BWPSxmZmZN5ORiZmalc3JZQ+vaMDOSfi5pkaT7mx1LI0gaJmmapDmSHpB0crNjqjdJG0qaKemetM3nNjumRpHUS9Jdkm5odiyNIGmepPsk3S2pvdR1+5zL6kvDzPwN+AjZjZqzgEMjWvcWX0kfAFYAV0TEO5sdT71J2hLYMiLulLQxMBs4sMU/YwEbRcQKSb2B24GTI2JGk0OrO0mnAm1A/4jYv9nx1JukeUBbRJR+06j3XNbMq8PMRMSLQGWYmZYVEX8EljQ7jkaJiMcj4s40vRyYSzYCRMuKzIo02zu9Wv5XqKShwH7Az5odSytwclkznQ0z09JfPOsyScOB9wB3NDmUukuHh+4GFgFTI6Lltxn4HvBl4JUmx9FIAdwsaXYaDqs0Ti5mBUjqB1wLnBIRy5odT71FxMsRsQPZ6BY7S2rpQ6CS9gcWRcTsZsfSYLtHxI5kI8ifmA57l8LJZc14mJl1QDrvcC1wZUT8ptnxNFJEPANMA0Y3OZR62w04IJ2DmACMkvSr5oZUfxGxMP1dBPyW7FB/KZxc1oyHmWlx6eT2ZcDciPhOs+NpBEmDJA1I033JLlh5sKlB1VlEnB4RQyNiONn/41sj4vAmh1VXkjZKF6kgaSNgL6C0q0CdXNZARKwEKsPMzAUm1nmYmaaTdBXwV+A/JC2QNLbZMdXZbsARZL9k706vfZsdVJ1tCUyTdC/ZD6ipEbFOXJq7jtkCuF3SPcBM4HcR8fuyVu5Lkc3MrHTeczEzs9I5uZiZWemcXMzMrHROLmZmVjonFzMzK52Ti5VOUkj6dm7+NEnnlLTuyyUdVMa61pSkDST9IV2e/Mlmx1Mh6WhJP1zNtmfUuz9Je6zqqMOSTpH0plWNzZrHycXq4QXgY5IGNjuQPEllP9b7PQARsUNEXL0WxFOGVU4uDXIK4OTSgzi5WD2sJHsu939XL6je85C0Iv3dQ9JtkiZJekTSBZIOS88VuU/S23Kr+bCkdkl/S2NCVQZavEjSLEn3SvpMbr1/kjQZeMMw+ZJWSPpGenbJDElbdFJnM0nXpfXOkPRuSW8GfgW8N+25vK2qzXRJ30/L7pe0cyo/R9IvJf0Z+GW6G/7aFPcsSbt19oam92NOiuFbqazbtl3VkdRP0i/Se3uvpI9LugDom2K+MtU7PH0Gd0u6RNljJpB0THr/Z5LdaNpZzJVt/aukhyUdl1vcT9I1kh6UdKUkpTZ7Knueyn3Knh20gaSTgMFkN3ZOS/UOTXXul3Rhd5+npINT3Xsk/bGzeK1kEeGXX6W+yJ730h+YB2wCnAack5ZdDhyUr5v+7gE8Q3Z3+AZkY7Sdm5adDHwv1/73ZD+MRpCNRL0hcDxwZqqzAdAObJPW+yywTRexBvDRNP3Nyjqq6vwPcHaaHgXcnYv5hi7WOx34aZr+AHB/mj6H7JkwfdP8/5INHgiwFdkwM9Xr2hx4iNdueh5Qqy1wNPDDbupcWHlP0/ym+c8jTb8DuB7oneZ/DByZPqN/AoOAPsCfK/1VxX0OcA/QFxhINoL44PS+LSUbi289shEfdk+f43xgu9T+CrKBQiH7tzQwTQ/O9b8+cCvZM3a6/DyB+4Ah+ffPr/q+1sbdcmsBEbFM0hXAScC/CzabFRGPA0j6O3BzKr8P+FCu3sSIeAV4WNIjwNvJxkV6d26vaBOy5PMiMDMi/tFFny8CleP/s8nG0aq2O/DxtF23StpcUv8C23NVavNHSf2VxusCJkdE5T35MDAy/XAH6C+pX7z2PBXIvoifBy5Tdq7ihlptq2Loqs6HycbQIsX4dCfx7wnsBMxK7fuSDcG/CzA9IhYDSLoa2K6L92BS2tZ/p72Oncl+RMyMiAWp/d3AcGA58I+I+FtqOx44kWwo/Lz3VvV/JVkCv46uP88/A5dLmgisU4OPNouTi9XT94A7gV/kylaSDsdKWo/sl2/FC7npV3Lzr/D6f6vVYxYFIOALETElv0DSHmR7Ll15KdLPWeBlyv0/0VmcVMWzHrBrRDyfryhpCtnYT+0RcWw6rLYncBDZeHajarTNzxap0xUB4yPi9Kq2BxZpnHT1HuQ/6zLf904/z4g4QdIuZA8Dmy1pp4h4qqQ+rRM+52J1ExFLgIlAfnDLeWS/hgEOIHvK4ao6WNJ66TzHW8kOGU0BPqtseHwkbadspNcy/Ak4LK13D+DJKPZMl0+mNrsDSyNiaSd1bga+UJmRtANAROwd2YUCx6Y9jU0i4kay81j/WattkfUDU8n2Cirlm6bJlyrvIXALcFA6v1Q597Q12cPSPpj24HoDB9d4D8ZI2lDS5mSHw2bVqPsQMFzStmn+COC2NL0c2DhNz0z9D0zngA7N1euUpLdFxB0RcRawmNc/KsPqwMnF6u3bZMfbK35K9sVwD/A+au9VdOWfZF8wNwEnpF/lPyM7YX+npPuBSyjv1/A5wE7KRgm+ADiqYLvnJd0FXMzrE2zeSUBbOqk+BzihkzobAzek/m8HTl2Ftl3V+TqwaeUkN68ddrwUuFfSlRExBziT7EmF95IlpC3ToctzyM6V/JlsRPCu3Ev2PJgZwHkR8VhXFdPneAzwa0n3ke2xXpyL6/eSpqX+x6X13gPMjohJNWIAuKhyAQDwl9TO6sijIpvVgaTpwGkR0d7sWJpF2b1NKyLiW82OxRrPey5mZlY677mYmVnpvOdiZmalc3IxM7PSObmYmVnpnFzMzKx0Ti5mZla6/wNEPdnA/Liq/wAAAABJRU5ErkJggg==\n",
+      "text/plain": [
+       "<Figure size 432x288 with 1 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "# To know the number of photons per system\n",
+    "nmin = branches['photon_n'].min()\n",
+    "nmax = branches['photon_n'].max()\n",
+    "print(f'Minimum number of photons per system: {nmin}')\n",
+    "print(f'Maximum number of photons per system: {nmax}')\n",
+    "# To plot this number as a function of events in the branch\n",
+    "plt.hist(branches['photon_n'], bins=5, range=(0, 5), color=colors(0))\n",
+    "plt.xlabel('Number n of pre-selected photons')\n",
+    "plt.ylabel('Number of events')\n",
+    "plt.title('Number of photons per system')\n",
+    "plt.show()"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 9,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "# Filter 1: 2 photons per system\n",
+    "photon2 = (branches['photon_n'] == 2)\n",
+    "# Filter 2: Photons identified and reconstructed as photons\n",
+    "photonTrue = ((branches['photon_isTightID'][:,0] == True) & \n",
+    "              (branches['photon_isTightID'][:,1] == True))\n",
+    "# Note the bitwise symbols used instead 'or', 'and'"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "The next variable to plot in a histogram will be the $E_{t}$. The values >4000MeV (for both photons) must be not considered in Higgs boson searches according to the papers consulted. The histogram will show less events than expected because it has been filtered by the two conditions."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 10,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "image/png": "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\n",
+      "text/plain": [
+       "<Figure size 432x288 with 1 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "plt.hist(branches['photon_etcone20'][photon2 & photonTrue].flatten(), \n",
+    "         bins=100, range=(-2500, 5000), color=colors(1))\n",
+    "plt.xlabel('Scalar sum of track $E_{\\mathrm{t}}$ [MeV] ' \n",
+    "           'in a cone of R=0.2 around photon')\n",
+    "plt.ylabel('Events')\n",
+    "plt.title('Isolation transverse energy of photons filtered by \\n'\n",
+    "          'diphoton systems and reconstruction quality')\n",
+    "plt.show()"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 11,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "# Filter 3: ['photon_etcone20']<4000 MeV\n",
+    "photonEt = ((branches['photon_etcone20'][:,0] < 4000) & \n",
+    "            (branches['photon_etcone20'][:,1] < 4000))"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "Another histogram shows the photon pseudorapidity values after applying the filters given before. Values in the range $|{\\eta}|>2.37$ (not considered in the original code) and $1.37<|{\\eta}|<1.52$ (for the calorimeter barrel/end-cap transition region) must be excluded by a filter. "
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 12,
+   "metadata": {
+    "scrolled": true
+   },
+   "outputs": [
+    {
+     "data": {
+      "image/png": "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\n",
+      "text/plain": [
+       "<Figure size 432x288 with 1 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "plt.hist(branches['photon_eta'][photon2 & photonTrue & photonEt].flatten(), \n",
+    "         bins=100, range=(-3, 3), color=colors(6))\n",
+    "plt.xlabel('Pseudo rapidity $\\eta$ of photon')\n",
+    "plt.ylabel('Events')\n",
+    "plt.title('Pseudo rapidity of photons filtered by \\n diphoton systems, '\n",
+    "          'reconstruction quality and $E_{\\mathrm{t}}$')\n",
+    "plt.show()"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 13,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "# Filter 4: \n",
+    "photonEta = (((abs(branches['photon_eta'][:,0])<2.37) & \n",
+    "              (abs(branches['photon_eta'][:,1])<2.37)) &\n",
+    "             ((abs(branches['photon_eta'][:,0])>1.52) | \n",
+    "              (abs(branches['photon_eta'][:,0])<1.37)) &\n",
+    "             ((abs(branches['photon_eta'][:,1])>1.52) | \n",
+    "              (abs(branches['photon_eta'][:,1])<1.37)))\n"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "The final histograms are of the photon transverse momentum variable. For Higgs detection, one needs that the first photon of the system has a momentum of $p_{t0}>40GeV$ and that the second photon has $p_{t1}>30GeV$. The last histogram is normalized to show a comparative of photon momentum considering the filter4 for $\\eta$ and considering and opposite filter, to demonstrate that the momentum of a photon $p_{t}$ depends on its pseudorapidity $\\eta$."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 14,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "image/png": "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\n",
+      "text/plain": [
+       "<Figure size 432x288 with 1 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "plt.hist(branches['photon_pt'][photon2 & photonTrue & photonEt & photonEta].flatten(), \n",
+    "         bins= 100, range=(20000, 250000), color=colors(8))\n",
+    "plt.xlabel('Transverse momentum of photon $p_{\\mathrm{T}}$ [MeV]')\n",
+    "plt.ylabel('Events')\n",
+    "plt.title('Transverse momentum of photons filtered by \\n diphoton systems, '\n",
+    "          'reconstruction quality, $E_{\\mathrm{t}}$ and $\\eta$')\n",
+    "plt.show()"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 15,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "text/plain": [
+       "<function matplotlib.pyplot.show(close=None, block=None)>"
+      ]
+     },
+     "execution_count": 15,
+     "metadata": {},
+     "output_type": "execute_result"
+    },
+    {
+     "data": {
+      "image/png": "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adIk7rnnHvbYY4+G9lXu1VdfZerUqYwZM4aDDjqoYjlcdNFFzJo1q0/bb4Qf5JoNIgsWLODSSy+lq6uLrq6uurXzrq4uDj/8cA4//HCWLVvGSSedxA477MBvf/tb9tprr6b2feutt7Lddtvx9NNPc9BBB7HLLruw//77r5n/wgsv8N73vpfTTz+dTTfddK31zzjjDH79618D6TnAgw8+yBve8AbGjx/P1KlTAdhzzz3X3He/5ZZbOPLIIxkxYgQARxxxRENxNlNG22yzDbvvvjvnnnsuu+yyS0Pbr6Wrq4vu7m5WrFjBkUceycKFC3s9A3j55Ze57LLL+MY3vrHO+6rGNX2zQWL16tUsW7aMCRMmAHDPPfew22671V3v2Wef5eyzz+aII47gwQcf5LzzzmP33Xdvev/bbbcdAGPGjOHII4/kzjvv7BXbe9/7Xo499liOOuqotdadM2cO119/Pb/73e+YP38+e+yxx5pfn2600UZrluvq6uKVV15pOrbSOJopo0suuYTtttuOo446ilNPPZVHHmmq6fqqRo0axQEHHLDWM4CrrrqKadOmsfXWW/fLfipx0jcbJBYvXszEiRPXjHd3dzNlypSa6xx33HFMmzaNhx9+mAsuuICbb76ZD33oQwwbNqypfa9cuZLnn39+zfC11167pgYbERx//PFMnDiRz3zmMxXXf/bZZ9l8880ZMWIE999//5oHnLXsv//+/OY3v2HVqlU8//zzXH755XXXabaMDj74YC6++GJuueUWNttsM9797ndz4IEH9uktn2XLlrFixQoAVq1axXXXXbfWt4cLL7ywpbd2wLd3zPpPtPeNlAULFvSqoXd3d3PYYYfVXOf9738/559/PkOG1E4Fs2bNYs6cOTzzzDOMHTuWU045heOPP55DDz2Uc889l5deemnN2yavvPIKH/jAB5g5cyYAt912Gz/5yU/WvM4JcNppp3HooYeu2f7MmTM566yzmDhxIjvvvDN777133eOdNm0aRx99NFOmTGHMmDG8+c1vrrtOX8oIYPTo0Zx44omceOKJ3HnnnXR1da21TL0yeuaZZ/jwhz/Mq6++ymuvvcb73/9+Dj/88DXrr1y5kuuuu46zzz67bjzrJCI65rPnnnvGYLIxlT82OCxatKjdIURExNvf/vZ4+OGH15o+YcKEePHFF2suUwS1jn19K6NK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\n",
+      "text/plain": [
+       "<Figure size 432x288 with 1 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "plt.hist([branches['photon_pt'][photon2 & photonTrue & photonEt & photonEta].flatten(), \n",
+    "         branches['photon_pt'][photon2 & photonTrue & photonEt & ~photonEta].flatten()],\n",
+    "         label=['$|\\eta| > 1.52$ and $|\\eta| < 1.37$', '$1.37<|\\eta|<1.52$'],\n",
+    "         bins= 20, range=(20000, 100000), color=[colors(0), colors(7)], density=True)\n",
+    "plt.xlabel('Transverse momentum of photon $p_{\\mathrm{T}}$ [MeV]')\n",
+    "plt.ylabel('Events')\n",
+    "plt.legend()\n",
+    "plt.title('Normalized graph for difference of \\n'\n",
+    "          'photon momentum considering $\\eta$ regions')\n",
+    "plt.show"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 16,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "# Filter 5: \n",
+    "photonPt = ((branches['photon_pt'][:,0] > 40000) & \n",
+    "            (branches['photon_pt'][:,1] > 30000))"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "Finally, by applying all filters to a branch, one can know the number of photon events that satisfy this criteria."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 17,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "Number of events with photons that satisfy the criteria: 22253\n"
+     ]
+    }
+   ],
+   "source": [
+    "photonFilter = branches['photon_E'][photon2 & photonTrue & photonEt & photonEta & photonPt]\n",
+    "print('Number of events with photons that satisfy the '\n",
+    "      f'criteria: {len(photonFilter)}')"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "### *Creating the data frame*\n",
+    "\n",
+    "One can generate, from a root file, a pandas dataframe that contains only the wanted *keys* of a *tree* using uproot. After this process has been done, one can use pandas to keep the dataframe rows that contain photons that satisfy the given conditions. At the end of this filtering, one needs to calculate the invariant mass to search for the Higgs boson. This can be done using numpy, that operates quickly over *series* and *arrays* of data. To complete the data frame, one can add a column for invariant mass. \n",
+    "The next code allows us to do all of this without running the cells above, to obtain an independent process."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 18,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "It took 1.6 seconds to create this dataframe from 430344 events to 22253 events\n",
+      "that fit the criteria. This corresponds to a total of 44506 photons.\n"
+     ]
+    },
+    {
+     "data": {
+      "text/html": [
+       "<div>\n",
+       "<style scoped>\n",
+       "    .dataframe tbody tr th:only-of-type {\n",
+       "        vertical-align: middle;\n",
+       "    }\n",
+       "\n",
+       "    .dataframe tbody tr th {\n",
+       "        vertical-align: top;\n",
+       "    }\n",
+       "\n",
+       "    .dataframe thead th {\n",
+       "        text-align: right;\n",
+       "    }\n",
+       "</style>\n",
+       "<table border=\"1\" class=\"dataframe\">\n",
+       "  <thead>\n",
+       "    <tr style=\"text-align: right;\">\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th>photon_n</th>\n",
+       "      <th>photon_isTightID</th>\n",
+       "      <th>photon_etcone20</th>\n",
+       "      <th>photon_pt</th>\n",
+       "      <th>photon_phi</th>\n",
+       "      <th>photon_eta</th>\n",
+       "      <th>photon_E</th>\n",
+       "      <th>InvariantMass</th>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>entry</th>\n",
+       "      <th>subentry</th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "      <th></th>\n",
+       "    </tr>\n",
+       "  </thead>\n",
+       "  <tbody>\n",
+       "    <tr>\n",
+       "      <th rowspan=\"2\" valign=\"top\">10</th>\n",
+       "      <th>0</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>272.148438</td>\n",
+       "      <td>176121.156250</td>\n",
+       "      <td>-0.294239</td>\n",
+       "      <td>-0.833492</td>\n",
+       "      <td>240922.312500</td>\n",
+       "      <td>86.241936</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>1</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-26.389771</td>\n",
+       "      <td>39629.144531</td>\n",
+       "      <td>0.567294</td>\n",
+       "      <td>0.094703</td>\n",
+       "      <td>39806.988281</td>\n",
+       "      <td>86.241936</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th rowspan=\"2\" valign=\"top\">11</th>\n",
+       "      <th>0</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>8.248505</td>\n",
+       "      <td>100427.679688</td>\n",
+       "      <td>0.655955</td>\n",
+       "      <td>1.734354</td>\n",
+       "      <td>293338.343750</td>\n",
+       "      <td>383.845337</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>1</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-584.198364</td>\n",
+       "      <td>95522.570312</td>\n",
+       "      <td>-2.457152</td>\n",
+       "      <td>0.688044</td>\n",
+       "      <td>119039.132812</td>\n",
+       "      <td>383.845337</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>76</th>\n",
+       "      <th>0</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-432.027344</td>\n",
+       "      <td>45906.085938</td>\n",
+       "      <td>-2.951355</td>\n",
+       "      <td>0.560444</td>\n",
+       "      <td>53306.277344</td>\n",
+       "      <td>70.931763</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>...</th>\n",
+       "      <th>...</th>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "      <td>...</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>430299</th>\n",
+       "      <th>1</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-72.140320</td>\n",
+       "      <td>40531.183594</td>\n",
+       "      <td>-0.491031</td>\n",
+       "      <td>-0.640433</td>\n",
+       "      <td>49131.210938</td>\n",
+       "      <td>69.801758</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th rowspan=\"2\" valign=\"top\">430307</th>\n",
+       "      <th>0</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>739.843750</td>\n",
+       "      <td>57563.054688</td>\n",
+       "      <td>2.412255</td>\n",
+       "      <td>-0.635498</td>\n",
+       "      <td>69583.203125</td>\n",
+       "      <td>75.343292</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>1</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>1081.072266</td>\n",
+       "      <td>33026.769531</td>\n",
+       "      <td>-1.628855</td>\n",
+       "      <td>-0.654452</td>\n",
+       "      <td>40355.648438</td>\n",
+       "      <td>75.343292</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th rowspan=\"2\" valign=\"top\">430337</th>\n",
+       "      <th>0</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-585.297729</td>\n",
+       "      <td>42460.062500</td>\n",
+       "      <td>2.333366</td>\n",
+       "      <td>-1.032692</td>\n",
+       "      <td>67185.890625</td>\n",
+       "      <td>122.064262</td>\n",
+       "    </tr>\n",
+       "    <tr>\n",
+       "      <th>1</th>\n",
+       "      <td>2</td>\n",
+       "      <td>True</td>\n",
+       "      <td>-355.998718</td>\n",
+       "      <td>41162.777344</td>\n",
+       "      <td>-0.719427</td>\n",
+       "      <td>-1.739026</td>\n",
+       "      <td>120761.015625</td>\n",
+       "      <td>122.064262</td>\n",
+       "    </tr>\n",
+       "  </tbody>\n",
+       "</table>\n",
+       "<p>44506 rows × 8 columns</p>\n",
+       "</div>"
+      ],
+      "text/plain": [
+       "                 photon_n  photon_isTightID  photon_etcone20      photon_pt  \\\n",
+       "entry  subentry                                                               \n",
+       "10     0                2              True       272.148438  176121.156250   \n",
+       "       1                2              True       -26.389771   39629.144531   \n",
+       "11     0                2              True         8.248505  100427.679688   \n",
+       "       1                2              True      -584.198364   95522.570312   \n",
+       "76     0                2              True      -432.027344   45906.085938   \n",
+       "...                   ...               ...              ...            ...   \n",
+       "430299 1                2              True       -72.140320   40531.183594   \n",
+       "430307 0                2              True       739.843750   57563.054688   \n",
+       "       1                2              True      1081.072266   33026.769531   \n",
+       "430337 0                2              True      -585.297729   42460.062500   \n",
+       "       1                2              True      -355.998718   41162.777344   \n",
+       "\n",
+       "                 photon_phi  photon_eta       photon_E  InvariantMass  \n",
+       "entry  subentry                                                        \n",
+       "10     0          -0.294239   -0.833492  240922.312500      86.241936  \n",
+       "       1           0.567294    0.094703   39806.988281      86.241936  \n",
+       "11     0           0.655955    1.734354  293338.343750     383.845337  \n",
+       "       1          -2.457152    0.688044  119039.132812     383.845337  \n",
+       "76     0          -2.951355    0.560444   53306.277344      70.931763  \n",
+       "...                     ...         ...            ...            ...  \n",
+       "430299 1          -0.491031   -0.640433   49131.210938      69.801758  \n",
+       "430307 0           2.412255   -0.635498   69583.203125      75.343292  \n",
+       "       1          -1.628855   -0.654452   40355.648438      75.343292  \n",
+       "430337 0           2.333366   -1.032692   67185.890625     122.064262  \n",
+       "       1          -0.719427   -1.739026  120761.015625     122.064262  \n",
+       "\n",
+       "[44506 rows x 8 columns]"
+      ]
+     },
+     "execution_count": 18,
+     "metadata": {},
+     "output_type": "execute_result"
+    }
+   ],
+   "source": [
+    "# Function to calculate the invariant mass 'myy' of the events\n",
+    "# It returns arrays.\n",
+    "\n",
+    "def calculateMyy(photonData):\n",
+    "    px = photonData['photon_pt'].loc[:]*np.cos(photonData['photon_phi'].loc[:])\n",
+    "    py = photonData['photon_pt'].loc[:]*np.sin(photonData['photon_phi'].loc[:])\n",
+    "    pz = photonData['photon_pt'].loc[:]*np.sinh(photonData['photon_eta'].loc[:])\n",
+    "    sumpx = px.loc[:,0] + px.loc[:,1]\n",
+    "    sumpy = py.loc[:,0] + py.loc[:,1]\n",
+    "    sumpz = px.loc[:,0] + pz.loc[:,1]\n",
+    "    sump = np.sqrt(sumpx**2 + sumpy**2 + sumpz**2)\n",
+    "    sumE = (photonData['photon_E'].loc[:,0] + photonData['photon_E'].loc[:,1])\n",
+    "    myy = (np.sqrt(np.absolute(sumE**2 - sump**2))/1000)\n",
+    "    return myy\n",
+    "\n",
+    "# Function to generate a dataframe from a tree and\n",
+    "# filter it considering the given conditions \n",
+    "\n",
+    "def getPhotonData(tree):\n",
+    "    # Convert the photon keys from tree to a dataframe\n",
+    "    photonData = tree.pandas.df(['photon_n', 'photon_isTightID', \n",
+    "                                 'photon_etcone20', 'photon_pt',\n",
+    "                                 'photon_phi', 'photon_eta', 'photon_E'])\n",
+    "    # Only keep diphoton events in dataframe\n",
+    "    photonData = photonData[photonData.photon_n == 2]\n",
+    "    # Only keep events where both photons satisfy the reconstruction \n",
+    "    # quality conditions\n",
+    "    photonData = photonData.loc[(photonData['photon_isTightID']==True).\n",
+    "                                groupby(level='entry').transform('all')]\n",
+    "    # Only keep events where both photons satisfy the isolation\n",
+    "    # transverse energy condition\n",
+    "    photonData = photonData.loc[(photonData['photon_etcone20']<4000).\n",
+    "                                groupby(level='entry').transform('all')]\n",
+    "    # Only keep events where both photons satisfy the eta conditions\n",
+    "    photonData = photonData.loc[(((abs(photonData['photon_eta']))<2.37)).\n",
+    "                                groupby(level='entry').transform('all')]\n",
+    "    photonData = photonData.loc[(((abs(photonData['photon_eta']))>1.52) | \n",
+    "                                 ((abs(photonData['photon_eta']))<1.37)).\n",
+    "                                groupby(level='entry').transform('all')]\n",
+    "    # Only keep events where both photons have \n",
+    "    # photon momentum >30000 MeV\n",
+    "    photonData = photonData.loc[(photonData['photon_pt']>30000).\n",
+    "                                groupby(level='entry').transform('all')]\n",
+    "    # To look for events where the first photons has a photon \n",
+    "    # momentum < 40000 MeV and remove that photon from the dataframe. \n",
+    "    # This leaves some entries (events) with only one photon.\n",
+    "    pt = photonData.groupby(['entry']).head(1) \n",
+    "    photonData = photonData.drop(pt.index[pt['photon_pt']<40000])\n",
+    "    # To only keep entries which have two photons. \n",
+    "    photonData = photonData[photonData.groupby(level=0)['photon_pt'].\n",
+    "                            transform('size').ne(1)]\n",
+    "    # Generate a series and then a dataFrame from the array \n",
+    "    # returned by the 'calculateMyy' function\n",
+    "    myyS = pd.Series(calculateMyy(photonData))\n",
+    "    myyData = pd.DataFrame({'InvariantMass':myyS})\n",
+    "    # Join the InvariantMass dataframe as a column for the\n",
+    "    # original data frame\n",
+    "    photonData = photonData.join(myyData)\n",
+    "    return photonData\n",
+    "\n",
+    "# To measure the time taken to generate this dataframe\n",
+    "start = time.time()\n",
+    "# To open the file, generate the tree and call the function\n",
+    "# that generates the dataframe\n",
+    "data = uproot3.open('/home/ramosm/ejercicios-clase-08-datos/data-used/data_A.GamGam.root')\n",
+    "tree = data['mini']\n",
+    "photonDataFrame = getPhotonData(tree)\n",
+    "end = time.time()\n",
+    "# Done! Let's see the dataframe and the time\n",
+    "timetaken= np.round((end-start), 2)\n",
+    "print(f'It took {timetaken} seconds to create this dataframe from {len(tree)} '\n",
+    "      f'events to {len(photonDataFrame)//2} events\\nthat fit the criteria. '\n",
+    "      f'This corresponds to a total of {len(photonDataFrame)} photons.')\n",
+    "photonDataFrame"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "This number of events is the same as the one obtained by applying filters to the branches, a measure of both codes accuracy."
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "### *Plotting the invariant mass*\n",
+    "\n",
+    "Note: The next code to plot the invariant mass is taken from the original notebook. Some minor changes have been done, for locating legends and adding titles."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 19,
+   "metadata": {},
+   "outputs": [],
+   "source": [
+    "def plot_data(data):   \n",
+    "\n",
+    "    xmin = 100 # GeV\n",
+    "    xmax = 160 # GeV\n",
+    "    step_size = 2 # GeV\n",
+    "    \n",
+    "    bin_edges = np.arange(start=xmin, stop=xmax+step_size, step=step_size) \n",
+    "    bin_centres = np.arange(start=xmin+step_size/2, stop=xmax+step_size/2,\n",
+    "                            step=step_size)\n",
+    "\n",
+    "    data_x,_ = np.histogram(data['InvariantMass'], bins=bin_edges)\n",
+    "    data_x_errors = np.sqrt(data_x)\n",
+    "\n",
+    "    # data fit\n",
+    "    polynomial_mod = PolynomialModel(4)\n",
+    "    gaussian_mod = GaussianModel()\n",
+    "    \n",
+    "    # set initial guesses for the parameters of the polynomial model\n",
+    "    # c0 + c1*x + c2*x^2 + c3*x^3 + c4*x^4\n",
+    "    pars = polynomial_mod.guess(data_x, x=bin_centres, c0=data_x.max(), \n",
+    "                                c1=0, c2=0, c3=0, c4=0)\n",
+    "    \n",
+    "    # set initial guesses for the parameters of the Gaussian model\n",
+    "    pars += gaussian_mod.guess(data_x, x=bin_centres, amplitude=100, \n",
+    "                               center=125, sigma=2)\n",
+    "    \n",
+    "    # combined model\n",
+    "    model = polynomial_mod + gaussian_mod\n",
+    "    \n",
+    "    # fit the model to the data\n",
+    "    out = model.fit(data_x, pars, x=bin_centres, weights=1/data_x_errors) \n",
+    "\n",
+    "    # background part of fit\n",
+    "    params_dict = out.params.valuesdict()\n",
+    "    c0 = params_dict['c0']\n",
+    "    c1 = params_dict['c1']\n",
+    "    c2 = params_dict['c2']\n",
+    "    c3 = params_dict['c3']\n",
+    "    c4 = params_dict['c4']\n",
+    "    \n",
+    "    # get the background only part of the fit to data\n",
+    "    background = (c0 + c1*bin_centres + c2*bin_centres**2 \n",
+    "                  + c3*bin_centres**3 + c4*bin_centres**4)\n",
+    "\n",
+    "    # data fit - background fit = signal fit\n",
+    "    signal_x = data_x - background \n",
+    "\n",
+    "\n",
+    "    # *************\n",
+    "    # Main plot \n",
+    "    # *************\n",
+    "    plt.axes([0.1,0.3,0.85,0.65])\n",
+    "    main_axes = plt.gca()\n",
+    "    \n",
+    "    # plot the data points\n",
+    "    main_axes.errorbar(x=bin_centres, y=data_x, yerr=data_x_errors, \n",
+    "                       fmt='ko', label='Data') \n",
+    "    \n",
+    "    # plot the signal + background fit\n",
+    "    main_axes.plot(bin_centres, out.best_fit, '-r', \n",
+    "                   label='Sig+Bkg Fit ($m_H=120$ GeV)')\n",
+    "    \n",
+    "    # plot the background only fit\n",
+    "    main_axes.plot(bin_centres, background, '--r', \n",
+    "                   label='Bkg (4th order polynomial)')\n",
+    "\n",
+    "    # set the x-limit of the main axes\n",
+    "    main_axes.set_xlim(left=xmin, right=xmax) \n",
+    "    \n",
+    "    # separation of x-axis minor ticks\n",
+    "    main_axes.xaxis.set_minor_locator(AutoMinorLocator()) \n",
+    "    \n",
+    "    # set the axis tick parameters for the main axes\n",
+    "    main_axes.tick_params(which='both', direction='in', top=True, \n",
+    "                          labelbottom=False, right=True)\n",
+    "    \n",
+    "    # write y-axis label for main axes\n",
+    "    main_axes.set_ylabel('Events / '+str(step_size)+' GeV', \n",
+    "                         horizontalalignment='right') \n",
+    "    \n",
+    "    # set the y-axis limit for the main axes\n",
+    "    main_axes.set_ylim(bottom=0, top=np.amax(data_x)*1.1) \n",
+    "    \n",
+    "    # set minor ticks on the y-axis of the main axes\n",
+    "    main_axes.yaxis.set_minor_locator(AutoMinorLocator()) \n",
+    "\n",
+    "    # avoid displaying y=0 on the main axes\n",
+    "    main_axes.yaxis.get_major_ticks()[0].set_visible(False) \n",
+    "\n",
+    "    # Add text 'ATLAS Open Data' on plot\n",
+    "    plt.text(0.67, 0.92, 'ATLAS Open Data', transform=main_axes.transAxes, \n",
+    "             fontsize=13 ) \n",
+    "    \n",
+    "    # Add text 'for education' on plot\n",
+    "    plt.text(0.83, 0.86, 'for education', transform=main_axes.transAxes, \n",
+    "             style='italic', fontsize=8) \n",
+    "    \n",
+    "    # Add energy and luminosity on plot\n",
+    "    lumi_used = str(lumi*fraction)\n",
+    "    plt.text(0.60, 0.8, '$\\sqrt{s}$=13 TeV,$\\int$L dt ='+lumi_used+'fb$^{-1}$',\n",
+    "             transform=main_axes.transAxes) \n",
+    "    \n",
+    "    # Add a label for the analysis carried out\n",
+    "    plt.text(0.89, 0.74, r'$H \\rightarrow \\gamma\\gamma$',\n",
+    "             transform=main_axes.transAxes)\n",
+    "\n",
+    "    # draw the legend\n",
+    "    main_axes.legend(frameon=False, loc='lower left')\n",
+    "    \n",
+    "    # Add title over plot\n",
+    "    \n",
+    "    plt.title(r'$H \\rightarrow \\gamma\\gamma$ search from ATLAS Open Data')\n",
+    "\n",
+    "\n",
+    "    # *************\n",
+    "    # Data-Bkg plot \n",
+    "    # *************\n",
+    "    plt.axes([0.1,0.1,0.85,0.2])\n",
+    "    sub_axes = plt.gca()\n",
+    "    \n",
+    "    # set the y axis to be symmetric about Data-Background=0\n",
+    "    sub_axes.yaxis.set_major_locator(MaxNLocator(nbins='auto', \n",
+    "                                                  symmetric=True))\n",
+    "    \n",
+    "    # plot Data-Background\n",
+    "    sub_axes.errorbar(x=bin_centres, y=signal_x, yerr=data_x_errors,\n",
+    "                      fmt='ko')\n",
+    "    \n",
+    "    # draw the fit to data\n",
+    "    sub_axes.plot(bin_centres, out.best_fit-background,'-r')\n",
+    "    \n",
+    "    # draw the background only fit\n",
+    "    sub_axes.plot(bin_centres, background-background, '--r')\n",
+    "    \n",
+    "    # set the x-axis limits on the sub axes\n",
+    "    sub_axes.set_xlim(left=xmin, right=xmax) \n",
+    "    \n",
+    "    # separation of x-axis minor ticks\n",
+    "    sub_axes.xaxis.set_minor_locator(AutoMinorLocator()) \n",
+    "    \n",
+    "    # x-axis label\n",
+    "    sub_axes.set_xlabel(r'di-photon invariant mass $\\mathrm{m_{\\gamma\\gamma}}$'\n",
+    "                        '[GeV]',x=1, horizontalalignment='right', fontsize=13) \n",
+    "    \n",
+    "    # set the tick parameters for the sub axes\n",
+    "    sub_axes.tick_params(which='both', direction='in',\n",
+    "                         top=True, right=True )\n",
+    "    \n",
+    "    # separation of y-axis minor ticks\n",
+    "    sub_axes.yaxis.set_minor_locator(AutoMinorLocator()) \n",
+    "    \n",
+    "    # y-axis label on the sub axes\n",
+    "    sub_axes.set_ylabel('Events-Bkg') \n",
+    "\n",
+    "\n",
+    "    # Generic features for both plots\n",
+    "    main_axes.yaxis.set_label_coords(-0.09, 1)\n",
+    "    sub_axes.yaxis.set_label_coords(-0.09, 0.5)\n",
+    "    \n",
+    "    \n",
+    "    \n",
+    "    return"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 20,
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "image/png": "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Ro0aNahduzbdu3fnoYce4tChQ37Xs2DBAipVCk7pfc6cOa4ZaDCGnw2+tEAw1qVnYixOVw5WqyTcoTgafBaLpWyQk5Oj8fHxWqdOHT3vvPO85rngggv0wQcfLBAfHx+vM2bMKLT+G264QevUqaNxcXF68ODBPGkXXnihXn311bp7925VVd29e7dOmzZNf/vtN5/1jRo1Sps0aaKfffaZZmdn665du/TWW2/V6tWr68qVK4sYbfjYsmWLArp9+3ZVVT1x4oQuWbJE+/Tpo61atdK9e/f6Vc/8+fM1Ojo6JH0ClmmQz//CBFlVz2ugbbCNhTNYQWaxlF8+/vhjrVSpkn700UcK6OrVqwvkKa4g279/v8bGxmpaWprWrVtX//Wvf+VJr169us6dO9fvvi5atEgBXbBgQYG0AQMG6AUXXOC+B/S5557TTp06afXq1XXAgAG6YcMGd/rJkyc1JSVFW7durTVr1tTzzjtPly5d6k4fPXq0Xn/99Tp27FitWbOmnnnmmfrvf//bZ9/yCzIX+/bt0/r16+vf//53VVU9duyYjhgxQhs2bKg1atTQLl266Oeff66qqjt37tTY2FgFtFq1alqtWjWdOnWqqqreeOON2rRpU61evbq2a9dO09LSivy8wirI3BmML6X1GO+sYLQXZwfbcKiDFWQWS/nl8ssv12HDhqmqaseOHXXChAkF8hRXkE2ePFnr1aun2dnZ+uc//1k7dOiQJ/3iiy/Wc845R1955RX98ccf9dSpU4X29b777tOmTZt6TXvttdc0OjpaMzMzVdUIsnbt2umGDRs0MzNTb7vtNm3Xrp27jb///e967rnn6qZNm/TUqVP62muvad26dXX//v2qagRZbGysfvjhh5qTk6Pvv/++VqpUSdPT072270uQqaped9112rNnT1VVPXLkiM6YMUMPHz6sJ06c0Keeekpr1Kihe/bsUVXfM7LXXntN9+7dq6dOndK3335bK1eurGvXri308yopQbbcWcP8ySNudbANhzqESpD1799f+/fvH5K6LBZL8OzcuVMrVaqk//vf/1RV9fnnn9datWq5hYGL4gqyc845R++44w5VVV25cqUC+s0337jTjxw5oo899pj26tVLY2NjtWbNmnrHHXfo8ePHvdY3duxYt0DIz8cff6yA7tixQ1WNIHvttdfc6ceOHdOYmBhdsmSJ5ubmavXq1XXhwoV56mjfvr17PKNHj9aLL744T3q9evX0gw8+8Np+YYLs3nvv1VatWnktp6pat25d98zU36XFbt266YsvvlhonlAIMn9sLZ5U46o8z9ZaIPtwFovFUlxef/116tSpw6WXXgrA9ddfz/Hjx3nnnXeCrnvRokWsW7eOm2++GYCOHTvSvXt3XnnlFXee6tWrc9999/Htt99y6NAhpk+fzptvvsljjz3mtc769euzc+dOr2m7du0iOjqaOnXquOMSEhLc13FxcdSvX58dO3awd+9ejh49yrBhw6hVq5Y7bN68mR07drjLNG7cOE8b1apV48iRIwF/Fjt27KBu3boAHD9+nAkTJtCyZUvOOOMMatWqxYEDB8jI8K0pn5ubywMPPEDbtm2pWbMmtWrVYuXKlYWWCRX+CLK1InIdEC0irUXkX8A3Ye5XwFitRYul/JGbm8vrr7/OwYMHadq0KY0aNeKcc84hJycnj7ApLo5lCS688EIaNWpEo0aNWLduHe+++y4HDx4skD8mJobLLruMwYMHs2LFCq91DhkyhB07drBo0aICaW+99Rb9+/enatWq7rj09HT3dWZmJhkZGTRt2pR69epRrVo1vvjiCw4ePOgOx44dY+LEiUGNOz8HDhxg3rx5DBo0CIBnn32Wr7/+mi+//JJDhw5x8OBBateu7VqRIyqqoOh4++23ee2113j//fc5cOAABw8epFOnTu4y+Qml1qI/gux2jHffbOBt4DBwZ7ANh5qaNWsGZKLKYrFEPp9++inbt2/nm2++YcWKFe7w0Ucf8d1337F6tX++Wk+ePElWVpY7ZGdns3//ft577z1efPHFPHWvW7eO2NhYZsyYAcBf/vIXli5dSlZWFrm5uSxYsID58+fTt29fr23169eP6667jqSkJL744gtOnDjB77//zu23387333/P008/nSf/c889x6ZNm8jKymLixIm0bNmSnj17IiLccccd3HPPPWzYsAGAo0eP8tlnn7Fr164gPtXTnDp1iu+++44RI0ZQo0YN/vKXvwBw+PBhqlSpQt26dTlx4gSPPPJIHsHeqFEjcnJy2LJlizvu8OHDVKpUifr165Obm8sbb7zBypUrfbbtYaLKf71/XwS7NhkpIRR7ZDNnztQqVaoooPHx8Tpz5syg67RYLMXnsssu0yuuuMJrWu/evfW2225z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vEC7du1ISkoiPT3dq7LG6tWrufTSS/OEPXv2FMhX4gQrCSMleDsQHc6Zg3PGrUAQEdU1a1SvuELdh7BBtVUr1Uce0Rt69Cjzsxk7I7P4YteuXfqPf/wjJHUtXLhQly9f7nZwqaqam5urR44cUVVzgPfcc8/Vb7/91mcdDz74oP7zn/8ssq1XXnlFb7zxxjxxPXv21IULF/osc9555+kbb7xRIL5atWpFtuetf1u2bMkz1kA4deqUtmzZUjdt2qTZ2dnasWNHXbt2rde88fHxmpGRUSC+bdu2boedxe1LJM7IyjyusxXhoFDljcREePddoyhy9dUQG2sURx54gOlLlzL9hx/g7rtNuo83xEjFdah74cKFJCQk+HUOztqXrDi88847eVYapk2bRrdu3ejYsWPAziP79etHnTp18sSJiHvGc/LkSU6ePIlRavafmTNncu6559K5c2f+9Kc/kZOTw1VXXcXcuXPdM7b09HR27dpF3759fdZz9OjRgGZfLlJSUmjTpg19+vRh/frT9tcnTpzIpk2b6Ny5M3/9618DqvOHH36gVatWtGzZkpiYGK699tqA9u1uueUWNm/ezNChQ3nuuecAc64sKSmJdu3acdVVVxU4PuTJvn37uOWWW/jpp594/PHHA+p7SAhWEkZKaNWqlY4bN05nz54d8BtBcZg5c6bGxcXl3SOLi/O+73X8uOp776n+6U+q//qX6oUXqkZFmZlatWpm9vb666q7dpVI34tLQGP2wM7gyi979+7VTz/91H1/5513uq8PHz6s7dq10+zsbFVVPXDgQJ6yffr00U6dOhUI8+bNc+fxNjM4deqUdurUSatVq6b33ntvof3LPyNbt26dXnrppW5zTLfeeqtOmzZNVVUvueQS/eCDD1RV9fHHH9e777670LpbtmypH3/8cYH4wmZky5Yt0/bt2+uxY8f00KFDetZZZ/k9Iyvs8/rPf/6jY8aMceedPn2626xUfhISErRLly7atWtXfeWVV9zxnjO1LVu2KKCLFy9WVdWbbrrJr5ltIMyePVvHjRunGF+XQT3/fSfAmcFWXpLB29JiuCm28kZurmq/fubjF1GNjVX3EmTXrqr336/67beqp04Vq1/hEhzx8fFel1Pj4+ND3h8r/MoGrgfzgQMHdN26dfr666+7044dO6YJCQk6YcIEXbp0abHqL+zhfuDA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ybfffsuoUaNYs2YNYM7WDR8+nP/+97+cc845RbaVH8+6A2Hv3r3UqlXLfZ+VlcXBgwe58847ARARxowZQ+PG5kx7dHQ0MTExAAwfPtw9G7r66quZNWsW0dHRACxatCjgvnjj6NGjXHnllUyePJkzzjij2PXcdtttLF68mJiYGJYuXcqXX37J8uXL6dGjB2BeBBo0aADAyJEjmTVrlluQvf766+56XOM/cuQINWrUCG5wFksFpOIIsiJmTuEkOjqaAQMGMGDAADp06MC0adPyCLLCcM0MFixYwNSpU5k6darPvL1792bv3r1kZGQAZrm1efPmLF682C3ISoKqVauSlZXlvnfNZKKizEr2ypUrufXWWwHYsWMHZ555JiLC9u3b3cINIDc31y3EIDQzspMnT3LllVeSlJTEFVdcAUCTJk3Yvv30efsdO3bQpEmTAmUTExN5//333fcvvvgie/fudR3qRFUZPXo0jz/+eIGyw4cP56677uLHH38kMzOzwCw4Ozub2NhYv8ZgsVjyUm72yCKV9evXs2HDBvf9ihUriI+Pz5Pn/PPPZ86cOWRlZXH06FE++uijYrX1yy+/kJOTQ926dQGIiYnhf//7H9OnT+ett94KaVs1atTwKlQAateuTU5OjluYrV69mk6dOrnTV61aRceOHQEj1FzXy5cvZ926ddxyyy2MHj3avZfoYtGiRaxYsaJA8FeIqSpjxoyhXbt2/OUvf3HH9+jRgw0bNrBlyxZOnDjBrFmzuOyyywqUHzRoEFlZWbz88mlTn5mZme7rCy64gPfee489e8zxx/3797N161bAzMwHDhzIzTffzMiRI/PUu2/fPurVq0flypX9GofFYslLuZmRufyRDRs2LKIUPo4ePcrtt9/OwYMHqVSpEq1atSpgPqtHjx5cdtlldOzYkYYNG9KhQwdq1vTPRY/nPpaqMm3atDyzmGrVqvHRRx/xhz/8gerVq3PZZZcVuy1P6taty/nnn0/79u0ZOnQo//znP/OkX3jhhSxevJjBgwezevVqzj33XMAsMx4/ftytlOIp1JYvX84zzzxDjx49mDt3rntmWRxGjhzJggUL2Lt3L02bNuXhhx+mbdu2zJgxgw4dOrg/s8cee4yLL76YKVOmcNFFF5GTk8PNN99MYmJigTpFhA8++IC77rqLp556ivr161OtWjWefPJJAM455xweffRRLrzwQnJzc6lcuTIvvvii+8Vl5MiRjBgxglmzZuWpd/78+VxyySXFHqvFUhaZM2eOy39k0P7ISl1tPlShW7duQamCljZHjhxRVdVjx45pt27d3GriZbWt5cuX6/XXXx9Qmcsvv1yzs7NVVfWBBx7QVatWhbxfkciIESN0/fr1pd0Ni6VUAJZpkM//cjMjK+skJyezbt06srKyGD16dKHacWWhra5duzJw4EBycnLyzBALw1Mr8uGHHw55nyKREydOcPnll9OmTZvS7orFUmaxHqItFovFUmqUWQ/RFovFYrGEinIjyFzKHs7mocVisVgimDlz5rhcuQSt7GGXFi0Wi8VSatilRYvFYrFUeKwgs1gsFkuZxgoyi8VisZRprCALM74cXy5YsIBLL7202PWqKoMGDeLw4cPuuJycHLp06ZKn3smTJ+cxo+TpOibUJCQksHfv3rDVn5+pU6cyYcKEEmvPkwceeIAvvvii0Dw33ngj7733HgDXXnttHlNlFosldJQbQRapWosuC/IrV67k8ccf57777gtJvR9//DGdOnXKY739+eefp127dnny5RdkoSIUHo1Ly3t0KHjkkUcCch1z66238tRTT4WxRxZL2SKUWovlRpBFqmNNT3w5vly6dCldunRh06ZNZGRk8Ic//IHExETGjh1LfHy811lOfseVO3bsYO7cuYwdO9Yd98ILL7Br1y4GDhzIwIED3fGTJk2iU6dO9OrVi927dxeoe//+/Vx++eV07NiRXr16sWrVKgAeeughbrjhBs4//3xuuOEG9u3bx4UXXujuq6cGrDcHk2BmhHfffTedOnXi22+/zdPugAEDuOOOO+jcuTPt27fnhx9+KLQ/Lo4cOUKLFi04efKk+3N23Q8YMIC//e1vnHvuubRp08btCiYrK4ubbrqJDh060KVLF+bPnw+YWd7ll1/OH/7wBxISEpgyZQrPPvssXbp0oVevXuzfvx/IO9t65JFH6NGjB+3btyc5ORlvmsB9+/bliy++CMkLgMVSHgilY81SEWQi8oaI7BGRNR5xdURknohscP7WduJFRF4QkY0iskpEim9PacCAguGll0xaZqb3dJfblL17C6b5gcuo79lnn83YsWP5v//7vzzp33zzDbfccgsffvghZ511Fg8//DCDBg1i7dq1XHXVVWzbts1rvUuWLMnjCuTO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\n",
+      "text/plain": [
+       "<Figure size 432x288 with 2 Axes>"
+      ]
+     },
+     "metadata": {
+      "needs_background": "light"
+     },
+     "output_type": "display_data"
+    }
+   ],
+   "source": [
+    "# Luminosity corresponding to data_A.GamGam.root\n",
+    "lumi = 0.5\n",
+    "# Fraction of the data used\n",
+    "fraction = 1\n",
+    "\n",
+    "# To plot the invariant mass\n",
+    "plot_data(photonDataFrame)\n",
+    "plt.show()"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "metadata": {},
+   "source": [
+    "The above graph suggests, luckily, a Higgs-like particle at 120 GeV.\n",
+    "At the moment, this notebook ends here. But the research continues."
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 21,
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stdout",
+     "output_type": "stream",
+     "text": [
+      "[NbConvertApp] Converting notebook dataAnalysisHyy.ipynb to html\n",
+      "[NbConvertApp] Writing 767602 bytes to dataAnalysisHyy.html\n"
+     ]
+    }
+   ],
+   "source": [
+    "! jupyter nbconvert dataAnalysisHyy.ipynb --to html --output dataAnalysisHyy.html"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": null,
+   "metadata": {},
+   "outputs": [],
+   "source": []
+  }
+ ],
+ "metadata": {
+  "kernelspec": {
+   "display_name": "Python 3",
+   "language": "python",
+   "name": "python3"
+  },
+  "language_info": {
+   "codemirror_mode": {
+    "name": "ipython",
+    "version": 3
+   },
+   "file_extension": ".py",
+   "mimetype": "text/x-python",
+   "name": "python",
+   "nbconvert_exporter": "python",
+   "pygments_lexer": "ipython3",
+   "version": "3.7.3"
+  }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 2
+}
-- 
GitLab