Skip to content
Snippets Groups Projects
Select Git revision
2 results Searching

README.md

Blame
  • Forked from an inaccessible project.
    TD2 Deep Learning.html 1.14 MiB
    <!DOCTYPE html>
    <html>
    <head><meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    
    <title>TD2 Deep Learning</title><script src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.1.10/require.min.js"></script>
    
    
    
    
    <style type="text/css">
        pre { line-height: 125%; }
    td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
    span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; }
    td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
    span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; }
    .highlight .hll { background-color: var(--jp-cell-editor-active-background) }
    .highlight { background: var(--jp-cell-editor-background); color: var(--jp-mirror-editor-variable-color) }
    .highlight .c { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment */
    .highlight .err { color: var(--jp-mirror-editor-error-color) } /* Error */
    .highlight .k { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword */
    .highlight .o { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator */
    .highlight .p { color: var(--jp-mirror-editor-punctuation-color) } /* Punctuation */
    .highlight .ch { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Hashbang */
    .highlight .cm { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Multiline */
    .highlight .cp { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Preproc */
    .highlight .cpf { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.PreprocFile */
    .highlight .c1 { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Single */
    .highlight .cs { color: var(--jp-mirror-editor-comment-color); font-style: italic } /* Comment.Special */
    .highlight .kc { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Constant */
    .highlight .kd { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Declaration */
    .highlight .kn { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Namespace */
    .highlight .kp { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Pseudo */
    .highlight .kr { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Reserved */
    .highlight .kt { color: var(--jp-mirror-editor-keyword-color); font-weight: bold } /* Keyword.Type */
    .highlight .m { color: var(--jp-mirror-editor-number-color) } /* Literal.Number */
    .highlight .s { color: var(--jp-mirror-editor-string-color) } /* Literal.String */
    .highlight .ow { color: var(--jp-mirror-editor-operator-color); font-weight: bold } /* Operator.Word */
    .highlight .w { color: var(--jp-mirror-editor-variable-color) } /* Text.Whitespace */
    .highlight .mb { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Bin */
    .highlight .mf { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Float */
    .highlight .mh { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Hex */
    .highlight .mi { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer */
    .highlight .mo { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Oct */
    .highlight .sa { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Affix */
    .highlight .sb { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Backtick */
    .highlight .sc { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Char */
    .highlight .dl { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Delimiter */
    .highlight .sd { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Doc */
    .highlight .s2 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Double */
    .highlight .se { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Escape */
    .highlight .sh { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Heredoc */
    .highlight .si { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Interpol */
    .highlight .sx { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Other */
    .highlight .sr { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Regex */
    .highlight .s1 { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Single */
    .highlight .ss { color: var(--jp-mirror-editor-string-color) } /* Literal.String.Symbol */
    .highlight .il { color: var(--jp-mirror-editor-number-color) } /* Literal.Number.Integer.Long */
      </style>
    
    
    
    <style type="text/css">
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*
     * Mozilla scrollbar styling
     */
    
    /* use standard opaque scrollbars for most nodes */
    [data-jp-theme-scrollbars='true'] {
      scrollbar-color: rgb(var(--jp-scrollbar-thumb-color))
        var(--jp-scrollbar-background-color);
    }
    
    /* for code nodes, use a transparent style of scrollbar. These selectors
     * will match lower in the tree, and so will override the above */
    [data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar,
    [data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar {
      scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
    }
    
    /* tiny scrollbar */
    
    .jp-scrollbar-tiny {
      scrollbar-color: rgba(var(--jp-scrollbar-thumb-color), 0.5) transparent;
      scrollbar-width: thin;
    }
    
    /*
     * Webkit scrollbar styling
     */
    
    /* use standard opaque scrollbars for most nodes */
    
    [data-jp-theme-scrollbars='true'] ::-webkit-scrollbar,
    [data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-corner {
      background: var(--jp-scrollbar-background-color);
    }
    
    [data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-thumb {
      background: rgb(var(--jp-scrollbar-thumb-color));
      border: var(--jp-scrollbar-thumb-margin) solid transparent;
      background-clip: content-box;
      border-radius: var(--jp-scrollbar-thumb-radius);
    }
    
    [data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:horizontal {
      border-left: var(--jp-scrollbar-endpad) solid
        var(--jp-scrollbar-background-color);
      border-right: var(--jp-scrollbar-endpad) solid
        var(--jp-scrollbar-background-color);
    }
    
    [data-jp-theme-scrollbars='true'] ::-webkit-scrollbar-track:vertical {
      border-top: var(--jp-scrollbar-endpad) solid
        var(--jp-scrollbar-background-color);
      border-bottom: var(--jp-scrollbar-endpad) solid
        var(--jp-scrollbar-background-color);
    }
    
    /* for code nodes, use a transparent style of scrollbar */
    
    [data-jp-theme-scrollbars='true'] .CodeMirror-hscrollbar::-webkit-scrollbar,
    [data-jp-theme-scrollbars='true'] .CodeMirror-vscrollbar::-webkit-scrollbar,
    [data-jp-theme-scrollbars='true']
      .CodeMirror-hscrollbar::-webkit-scrollbar-corner,
    [data-jp-theme-scrollbars='true']
      .CodeMirror-vscrollbar::-webkit-scrollbar-corner {
      background-color: transparent;
    }
    
    [data-jp-theme-scrollbars='true']
      .CodeMirror-hscrollbar::-webkit-scrollbar-thumb,
    [data-jp-theme-scrollbars='true']
      .CodeMirror-vscrollbar::-webkit-scrollbar-thumb {
      background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
      border: var(--jp-scrollbar-thumb-margin) solid transparent;
      background-clip: content-box;
      border-radius: var(--jp-scrollbar-thumb-radius);
    }
    
    [data-jp-theme-scrollbars='true']
      .CodeMirror-hscrollbar::-webkit-scrollbar-track:horizontal {
      border-left: var(--jp-scrollbar-endpad) solid transparent;
      border-right: var(--jp-scrollbar-endpad) solid transparent;
    }
    
    [data-jp-theme-scrollbars='true']
      .CodeMirror-vscrollbar::-webkit-scrollbar-track:vertical {
      border-top: var(--jp-scrollbar-endpad) solid transparent;
      border-bottom: var(--jp-scrollbar-endpad) solid transparent;
    }
    
    /* tiny scrollbar */
    
    .jp-scrollbar-tiny::-webkit-scrollbar,
    .jp-scrollbar-tiny::-webkit-scrollbar-corner {
      background-color: transparent;
      height: 4px;
      width: 4px;
    }
    
    .jp-scrollbar-tiny::-webkit-scrollbar-thumb {
      background: rgba(var(--jp-scrollbar-thumb-color), 0.5);
    }
    
    .jp-scrollbar-tiny::-webkit-scrollbar-track:horizontal {
      border-left: 0px solid transparent;
      border-right: 0px solid transparent;
    }
    
    .jp-scrollbar-tiny::-webkit-scrollbar-track:vertical {
      border-top: 0px solid transparent;
      border-bottom: 0px solid transparent;
    }
    
    /*
     * Phosphor
     */
    
    .lm-ScrollBar[data-orientation='horizontal'] {
      min-height: 16px;
      max-height: 16px;
      min-width: 45px;
      border-top: 1px solid #a0a0a0;
    }
    
    .lm-ScrollBar[data-orientation='vertical'] {
      min-width: 16px;
      max-width: 16px;
      min-height: 45px;
      border-left: 1px solid #a0a0a0;
    }
    
    .lm-ScrollBar-button {
      background-color: #f0f0f0;
      background-position: center center;
      min-height: 15px;
      max-height: 15px;
      min-width: 15px;
      max-width: 15px;
    }
    
    .lm-ScrollBar-button:hover {
      background-color: #dadada;
    }
    
    .lm-ScrollBar-button.lm-mod-active {
      background-color: #cdcdcd;
    }
    
    .lm-ScrollBar-track {
      background: #f0f0f0;
    }
    
    .lm-ScrollBar-thumb {
      background: #cdcdcd;
    }
    
    .lm-ScrollBar-thumb:hover {
      background: #bababa;
    }
    
    .lm-ScrollBar-thumb.lm-mod-active {
      background: #a0a0a0;
    }
    
    .lm-ScrollBar[data-orientation='horizontal'] .lm-ScrollBar-thumb {
      height: 100%;
      min-width: 15px;
      border-left: 1px solid #a0a0a0;
      border-right: 1px solid #a0a0a0;
    }
    
    .lm-ScrollBar[data-orientation='vertical'] .lm-ScrollBar-thumb {
      width: 100%;
      min-height: 15px;
      border-top: 1px solid #a0a0a0;
      border-bottom: 1px solid #a0a0a0;
    }
    
    .lm-ScrollBar[data-orientation='horizontal']
      .lm-ScrollBar-button[data-action='decrement'] {
      background-image: var(--jp-icon-caret-left);
      background-size: 17px;
    }
    
    .lm-ScrollBar[data-orientation='horizontal']
      .lm-ScrollBar-button[data-action='increment'] {
      background-image: var(--jp-icon-caret-right);
      background-size: 17px;
    }
    
    .lm-ScrollBar[data-orientation='vertical']
      .lm-ScrollBar-button[data-action='decrement'] {
      background-image: var(--jp-icon-caret-up);
      background-size: 17px;
    }
    
    .lm-ScrollBar[data-orientation='vertical']
      .lm-ScrollBar-button[data-action='increment'] {
      background-image: var(--jp-icon-caret-down);
      background-size: 17px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-Widget, /* </DEPRECATED> */
    .lm-Widget {
      box-sizing: border-box;
      position: relative;
      overflow: hidden;
      cursor: default;
    }
    
    
    /* <DEPRECATED> */ .p-Widget.p-mod-hidden, /* </DEPRECATED> */
    .lm-Widget.lm-mod-hidden {
      display: none !important;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-CommandPalette, /* </DEPRECATED> */
    .lm-CommandPalette {
      display: flex;
      flex-direction: column;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-search, /* </DEPRECATED> */
    .lm-CommandPalette-search {
      flex: 0 0 auto;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-content, /* </DEPRECATED> */
    .lm-CommandPalette-content {
      flex: 1 1 auto;
      margin: 0;
      padding: 0;
      min-height: 0;
      overflow: auto;
      list-style-type: none;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-header, /* </DEPRECATED> */
    .lm-CommandPalette-header {
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-item, /* </DEPRECATED> */
    .lm-CommandPalette-item {
      display: flex;
      flex-direction: row;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-itemIcon, /* </DEPRECATED> */
    .lm-CommandPalette-itemIcon {
      flex: 0 0 auto;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-itemContent, /* </DEPRECATED> */
    .lm-CommandPalette-itemContent {
      flex: 1 1 auto;
      overflow: hidden;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-itemShortcut, /* </DEPRECATED> */
    .lm-CommandPalette-itemShortcut {
      flex: 0 0 auto;
    }
    
    
    /* <DEPRECATED> */ .p-CommandPalette-itemLabel, /* </DEPRECATED> */
    .lm-CommandPalette-itemLabel {
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
    }
    
    .lm-close-icon {
    	border:1px solid transparent;
      background-color: transparent;
      position: absolute;
    	z-index:1;
    	right:3%;
    	top: 0;
    	bottom: 0;
    	margin: auto;
    	padding: 7px 0;
    	display: none;
    	vertical-align: middle;
      outline: 0;
      cursor: pointer;
    }
    .lm-close-icon:after {
    	content: "X";
    	display: block;
    	width: 15px;
    	height: 15px;
    	text-align: center;
    	color:#000;
    	font-weight: normal;
    	font-size: 12px;
    	cursor: pointer;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-DockPanel, /* </DEPRECATED> */
    .lm-DockPanel {
      z-index: 0;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-widget, /* </DEPRECATED> */
    .lm-DockPanel-widget {
      z-index: 0;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-tabBar, /* </DEPRECATED> */
    .lm-DockPanel-tabBar {
      z-index: 1;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-handle, /* </DEPRECATED> */
    .lm-DockPanel-handle {
      z-index: 2;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-handle.p-mod-hidden, /* </DEPRECATED> */
    .lm-DockPanel-handle.lm-mod-hidden {
      display: none !important;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-handle:after, /* </DEPRECATED> */
    .lm-DockPanel-handle:after {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      content: '';
    }
    
    
    /* <DEPRECATED> */
    .p-DockPanel-handle[data-orientation='horizontal'],
    /* </DEPRECATED> */
    .lm-DockPanel-handle[data-orientation='horizontal'] {
      cursor: ew-resize;
    }
    
    
    /* <DEPRECATED> */
    .p-DockPanel-handle[data-orientation='vertical'],
    /* </DEPRECATED> */
    .lm-DockPanel-handle[data-orientation='vertical'] {
      cursor: ns-resize;
    }
    
    
    /* <DEPRECATED> */
    .p-DockPanel-handle[data-orientation='horizontal']:after,
    /* </DEPRECATED> */
    .lm-DockPanel-handle[data-orientation='horizontal']:after {
      left: 50%;
      min-width: 8px;
      transform: translateX(-50%);
    }
    
    
    /* <DEPRECATED> */
    .p-DockPanel-handle[data-orientation='vertical']:after,
    /* </DEPRECATED> */
    .lm-DockPanel-handle[data-orientation='vertical']:after {
      top: 50%;
      min-height: 8px;
      transform: translateY(-50%);
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-overlay, /* </DEPRECATED> */
    .lm-DockPanel-overlay {
      z-index: 3;
      box-sizing: border-box;
      pointer-events: none;
    }
    
    
    /* <DEPRECATED> */ .p-DockPanel-overlay.p-mod-hidden, /* </DEPRECATED> */
    .lm-DockPanel-overlay.lm-mod-hidden {
      display: none !important;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-Menu, /* </DEPRECATED> */
    .lm-Menu {
      z-index: 10000;
      position: absolute;
      white-space: nowrap;
      overflow-x: hidden;
      overflow-y: auto;
      outline: none;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    
    /* <DEPRECATED> */ .p-Menu-content, /* </DEPRECATED> */
    .lm-Menu-content {
      margin: 0;
      padding: 0;
      display: table;
      list-style-type: none;
    }
    
    
    /* <DEPRECATED> */ .p-Menu-item, /* </DEPRECATED> */
    .lm-Menu-item {
      display: table-row;
    }
    
    
    /* <DEPRECATED> */
    .p-Menu-item.p-mod-hidden,
    .p-Menu-item.p-mod-collapsed,
    /* </DEPRECATED> */
    .lm-Menu-item.lm-mod-hidden,
    .lm-Menu-item.lm-mod-collapsed {
      display: none !important;
    }
    
    
    /* <DEPRECATED> */
    .p-Menu-itemIcon,
    .p-Menu-itemSubmenuIcon,
    /* </DEPRECATED> */
    .lm-Menu-itemIcon,
    .lm-Menu-itemSubmenuIcon {
      display: table-cell;
      text-align: center;
    }
    
    
    /* <DEPRECATED> */ .p-Menu-itemLabel, /* </DEPRECATED> */
    .lm-Menu-itemLabel {
      display: table-cell;
      text-align: left;
    }
    
    
    /* <DEPRECATED> */ .p-Menu-itemShortcut, /* </DEPRECATED> */
    .lm-Menu-itemShortcut {
      display: table-cell;
      text-align: right;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-MenuBar, /* </DEPRECATED> */
    .lm-MenuBar {
      outline: none;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    
    /* <DEPRECATED> */ .p-MenuBar-content, /* </DEPRECATED> */
    .lm-MenuBar-content {
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: row;
      list-style-type: none;
    }
    
    
    /* <DEPRECATED> */ .p--MenuBar-item, /* </DEPRECATED> */
    .lm-MenuBar-item {
      box-sizing: border-box;
    }
    
    
    /* <DEPRECATED> */
    .p-MenuBar-itemIcon,
    .p-MenuBar-itemLabel,
    /* </DEPRECATED> */
    .lm-MenuBar-itemIcon,
    .lm-MenuBar-itemLabel {
      display: inline-block;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-ScrollBar, /* </DEPRECATED> */
    .lm-ScrollBar {
      display: flex;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    
    /* <DEPRECATED> */
    .p-ScrollBar[data-orientation='horizontal'],
    /* </DEPRECATED> */
    .lm-ScrollBar[data-orientation='horizontal'] {
      flex-direction: row;
    }
    
    
    /* <DEPRECATED> */
    .p-ScrollBar[data-orientation='vertical'],
    /* </DEPRECATED> */
    .lm-ScrollBar[data-orientation='vertical'] {
      flex-direction: column;
    }
    
    
    /* <DEPRECATED> */ .p-ScrollBar-button, /* </DEPRECATED> */
    .lm-ScrollBar-button {
      box-sizing: border-box;
      flex: 0 0 auto;
    }
    
    
    /* <DEPRECATED> */ .p-ScrollBar-track, /* </DEPRECATED> */
    .lm-ScrollBar-track {
      box-sizing: border-box;
      position: relative;
      overflow: hidden;
      flex: 1 1 auto;
    }
    
    
    /* <DEPRECATED> */ .p-ScrollBar-thumb, /* </DEPRECATED> */
    .lm-ScrollBar-thumb {
      box-sizing: border-box;
      position: absolute;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-SplitPanel-child, /* </DEPRECATED> */
    .lm-SplitPanel-child {
      z-index: 0;
    }
    
    
    /* <DEPRECATED> */ .p-SplitPanel-handle, /* </DEPRECATED> */
    .lm-SplitPanel-handle {
      z-index: 1;
    }
    
    
    /* <DEPRECATED> */ .p-SplitPanel-handle.p-mod-hidden, /* </DEPRECATED> */
    .lm-SplitPanel-handle.lm-mod-hidden {
      display: none !important;
    }
    
    
    /* <DEPRECATED> */ .p-SplitPanel-handle:after, /* </DEPRECATED> */
    .lm-SplitPanel-handle:after {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      content: '';
    }
    
    
    /* <DEPRECATED> */
    .p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle,
    /* </DEPRECATED> */
    .lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle {
      cursor: ew-resize;
    }
    
    
    /* <DEPRECATED> */
    .p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle,
    /* </DEPRECATED> */
    .lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle {
      cursor: ns-resize;
    }
    
    
    /* <DEPRECATED> */
    .p-SplitPanel[data-orientation='horizontal'] > .p-SplitPanel-handle:after,
    /* </DEPRECATED> */
    .lm-SplitPanel[data-orientation='horizontal'] > .lm-SplitPanel-handle:after {
      left: 50%;
      min-width: 8px;
      transform: translateX(-50%);
    }
    
    
    /* <DEPRECATED> */
    .p-SplitPanel[data-orientation='vertical'] > .p-SplitPanel-handle:after,
    /* </DEPRECATED> */
    .lm-SplitPanel[data-orientation='vertical'] > .lm-SplitPanel-handle:after {
      top: 50%;
      min-height: 8px;
      transform: translateY(-50%);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-TabBar, /* </DEPRECATED> */
    .lm-TabBar {
      display: flex;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar[data-orientation='horizontal'], /* </DEPRECATED> */
    .lm-TabBar[data-orientation='horizontal'] {
      flex-direction: row;
      align-items: flex-end;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar[data-orientation='vertical'], /* </DEPRECATED> */
    .lm-TabBar[data-orientation='vertical'] {
      flex-direction: column;
      align-items: flex-end;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar-content, /* </DEPRECATED> */
    .lm-TabBar-content {
      margin: 0;
      padding: 0;
      display: flex;
      flex: 1 1 auto;
      list-style-type: none;
    }
    
    
    /* <DEPRECATED> */
    .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content,
    /* </DEPRECATED> */
    .lm-TabBar[data-orientation='horizontal'] > .lm-TabBar-content {
      flex-direction: row;
    }
    
    
    /* <DEPRECATED> */
    .p-TabBar[data-orientation='vertical'] > .p-TabBar-content,
    /* </DEPRECATED> */
    .lm-TabBar[data-orientation='vertical'] > .lm-TabBar-content {
      flex-direction: column;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar-tab, /* </DEPRECATED> */
    .lm-TabBar-tab {
      display: flex;
      flex-direction: row;
      box-sizing: border-box;
      overflow: hidden;
    }
    
    
    /* <DEPRECATED> */
    .p-TabBar-tabIcon,
    .p-TabBar-tabCloseIcon,
    /* </DEPRECATED> */
    .lm-TabBar-tabIcon,
    .lm-TabBar-tabCloseIcon {
      flex: 0 0 auto;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar-tabLabel, /* </DEPRECATED> */
    .lm-TabBar-tabLabel {
      flex: 1 1 auto;
      overflow: hidden;
      white-space: nowrap;
    }
    
    
    .lm-TabBar-tabInput {
      user-select: all;
      width: 100%;
      box-sizing : border-box;
    }
    
    
    /* <DEPRECATED> */ .p-TabBar-tab.p-mod-hidden, /* </DEPRECATED> */
    .lm-TabBar-tab.lm-mod-hidden {
      display: none !important;
    }
    
    
    .lm-TabBar-addButton.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;
    }
    
    .lm-TabBar-tabLabel .lm-TabBar-tabInput {
      user-select: all;
      width: 100%;
      box-sizing : border-box;
      background: inherit;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ .p-TabPanel-tabBar, /* </DEPRECATED> */
    .lm-TabPanel-tabBar {
      z-index: 1;
    }
    
    
    /* <DEPRECATED> */ .p-TabPanel-stackedPanel, /* </DEPRECATED> */
    .lm-TabPanel-stackedPanel {
      z-index: 0;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    @charset "UTF-8";
    html{
      -webkit-box-sizing:border-box;
              box-sizing:border-box; }
    
    *,
    *::before,
    *::after{
      -webkit-box-sizing:inherit;
              box-sizing:inherit; }
    
    body{
      font-size:14px;
      font-weight:400;
      letter-spacing:0;
      line-height:1.28581;
      text-transform:none;
      color:#182026;
      font-family:-apple-system, "BlinkMacSystemFont", "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Open Sans", "Helvetica Neue", "Icons16", sans-serif; }
    
    p{
      margin-bottom:10px;
      margin-top:0; }
    
    small{
      font-size:12px; }
    
    strong{
      font-weight:600; }
    
    ::-moz-selection{
      background:rgba(125, 188, 255, 0.6); }
    
    ::selection{
      background:rgba(125, 188, 255, 0.6); }
    .bp3-heading{
      color:#182026;
      font-weight:600;
      margin:0 0 10px;
      padding:0; }
      .bp3-dark .bp3-heading{
        color:#f5f8fa; }
    
    h1.bp3-heading, .bp3-running-text h1{
      font-size:36px;
      line-height:40px; }
    
    h2.bp3-heading, .bp3-running-text h2{
      font-size:28px;
      line-height:32px; }
    
    h3.bp3-heading, .bp3-running-text h3{
      font-size:22px;
      line-height:25px; }
    
    h4.bp3-heading, .bp3-running-text h4{
      font-size:18px;
      line-height:21px; }
    
    h5.bp3-heading, .bp3-running-text h5{
      font-size:16px;
      line-height:19px; }
    
    h6.bp3-heading, .bp3-running-text h6{
      font-size:14px;
      line-height:16px; }
    .bp3-ui-text{
      font-size:14px;
      font-weight:400;
      letter-spacing:0;
      line-height:1.28581;
      text-transform:none; }
    
    .bp3-monospace-text{
      font-family:monospace;
      text-transform:none; }
    
    .bp3-text-muted{
      color:#5c7080; }
      .bp3-dark .bp3-text-muted{
        color:#a7b6c2; }
    
    .bp3-text-disabled{
      color:rgba(92, 112, 128, 0.6); }
      .bp3-dark .bp3-text-disabled{
        color:rgba(167, 182, 194, 0.6); }
    
    .bp3-text-overflow-ellipsis{
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
      word-wrap:normal; }
    .bp3-running-text{
      font-size:14px;
      line-height:1.5; }
      .bp3-running-text h1{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h1{
          color:#f5f8fa; }
      .bp3-running-text h2{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h2{
          color:#f5f8fa; }
      .bp3-running-text h3{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h3{
          color:#f5f8fa; }
      .bp3-running-text h4{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h4{
          color:#f5f8fa; }
      .bp3-running-text h5{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h5{
          color:#f5f8fa; }
      .bp3-running-text h6{
        color:#182026;
        font-weight:600;
        margin-bottom:20px;
        margin-top:40px; }
        .bp3-dark .bp3-running-text h6{
          color:#f5f8fa; }
      .bp3-running-text hr{
        border:none;
        border-bottom:1px solid rgba(16, 22, 26, 0.15);
        margin:20px 0; }
        .bp3-dark .bp3-running-text hr{
          border-color:rgba(255, 255, 255, 0.15); }
      .bp3-running-text p{
        margin:0 0 10px;
        padding:0; }
    
    .bp3-text-large{
      font-size:16px; }
    
    .bp3-text-small{
      font-size:12px; }
    a{
      color:#106ba3;
      text-decoration:none; }
      a:hover{
        color:#106ba3;
        cursor:pointer;
        text-decoration:underline; }
      a .bp3-icon, a .bp3-icon-standard, a .bp3-icon-large{
        color:inherit; }
      a code,
      .bp3-dark a code{
        color:inherit; }
      .bp3-dark a,
      .bp3-dark a:hover{
        color:#48aff0; }
        .bp3-dark a .bp3-icon, .bp3-dark a .bp3-icon-standard, .bp3-dark a .bp3-icon-large,
        .bp3-dark a:hover .bp3-icon,
        .bp3-dark a:hover .bp3-icon-standard,
        .bp3-dark a:hover .bp3-icon-large{
          color:inherit; }
    .bp3-running-text code, .bp3-code{
      font-family:monospace;
      text-transform:none;
      background:rgba(255, 255, 255, 0.7);
      border-radius:3px;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2);
      color:#5c7080;
      font-size:smaller;
      padding:2px 5px; }
      .bp3-dark .bp3-running-text code, .bp3-running-text .bp3-dark code, .bp3-dark .bp3-code{
        background:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
        color:#a7b6c2; }
      .bp3-running-text a > code, a > .bp3-code{
        color:#137cbd; }
        .bp3-dark .bp3-running-text a > code, .bp3-running-text .bp3-dark a > code, .bp3-dark a > .bp3-code{
          color:inherit; }
    
    .bp3-running-text pre, .bp3-code-block{
      font-family:monospace;
      text-transform:none;
      background:rgba(255, 255, 255, 0.7);
      border-radius:3px;
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
      color:#182026;
      display:block;
      font-size:13px;
      line-height:1.4;
      margin:10px 0;
      padding:13px 15px 12px;
      word-break:break-all;
      word-wrap:break-word; }
      .bp3-dark .bp3-running-text pre, .bp3-running-text .bp3-dark pre, .bp3-dark .bp3-code-block{
        background:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
      .bp3-running-text pre > code, .bp3-code-block > code{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:inherit;
        font-size:inherit;
        padding:0; }
    
    .bp3-running-text kbd, .bp3-key{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      background:#ffffff;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
      color:#5c7080;
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex;
      font-family:inherit;
      font-size:12px;
      height:24px;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      line-height:24px;
      min-width:24px;
      padding:3px 6px;
      vertical-align:middle; }
      .bp3-running-text kbd .bp3-icon, .bp3-key .bp3-icon, .bp3-running-text kbd .bp3-icon-standard, .bp3-key .bp3-icon-standard, .bp3-running-text kbd .bp3-icon-large, .bp3-key .bp3-icon-large{
        margin-right:5px; }
      .bp3-dark .bp3-running-text kbd, .bp3-running-text .bp3-dark kbd, .bp3-dark .bp3-key{
        background:#394b59;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
        color:#a7b6c2; }
    .bp3-running-text blockquote, .bp3-blockquote{
      border-left:solid 4px rgba(167, 182, 194, 0.5);
      margin:0 0 10px;
      padding:0 20px; }
      .bp3-dark .bp3-running-text blockquote, .bp3-running-text .bp3-dark blockquote, .bp3-dark .bp3-blockquote{
        border-color:rgba(115, 134, 148, 0.5); }
    .bp3-running-text ul,
    .bp3-running-text ol, .bp3-list{
      margin:10px 0;
      padding-left:30px; }
      .bp3-running-text ul li:not(:last-child), .bp3-running-text ol li:not(:last-child), .bp3-list li:not(:last-child){
        margin-bottom:5px; }
      .bp3-running-text ul ol, .bp3-running-text ol ol, .bp3-list ol,
      .bp3-running-text ul ul,
      .bp3-running-text ol ul,
      .bp3-list ul{
        margin-top:5px; }
    
    .bp3-list-unstyled{
      list-style:none;
      margin:0;
      padding:0; }
      .bp3-list-unstyled li{
        padding:0; }
    .bp3-rtl{
      text-align:right; }
    
    .bp3-dark{
      color:#f5f8fa; }
    
    :focus{
      outline:rgba(19, 124, 189, 0.6) auto 2px;
      outline-offset:2px;
      -moz-outline-radius:6px; }
    
    .bp3-focus-disabled :focus{
      outline:none !important; }
      .bp3-focus-disabled :focus ~ .bp3-control-indicator{
        outline:none !important; }
    
    .bp3-alert{
      max-width:400px;
      padding:20px; }
    
    .bp3-alert-body{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex; }
      .bp3-alert-body .bp3-icon{
        font-size:40px;
        margin-right:20px;
        margin-top:0; }
    
    .bp3-alert-contents{
      word-break:break-word; }
    
    .bp3-alert-footer{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:reverse;
          -ms-flex-direction:row-reverse;
              flex-direction:row-reverse;
      margin-top:10px; }
      .bp3-alert-footer .bp3-button{
        margin-left:10px; }
    .bp3-breadcrumbs{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      cursor:default;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -ms-flex-wrap:wrap;
          flex-wrap:wrap;
      height:30px;
      list-style:none;
      margin:0;
      padding:0; }
      .bp3-breadcrumbs > li{
        -webkit-box-align:center;
            -ms-flex-align:center;
                align-items:center;
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex; }
        .bp3-breadcrumbs > li::after{
          background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M10.71 7.29l-4-4a1.003 1.003 0 00-1.42 1.42L8.59 8 5.3 11.29c-.19.18-.3.43-.3.71a1.003 1.003 0 001.71.71l4-4c.18-.18.29-.43.29-.71 0-.28-.11-.53-.29-.71z' fill='%235C7080'/%3e%3c/svg%3e");
          content:"";
          display:block;
          height:16px;
          margin:0 5px;
          width:16px; }
        .bp3-breadcrumbs > li:last-of-type::after{
          display:none; }
    
    .bp3-breadcrumb,
    .bp3-breadcrumb-current,
    .bp3-breadcrumbs-collapsed{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex;
      font-size:16px; }
    
    .bp3-breadcrumb,
    .bp3-breadcrumbs-collapsed{
      color:#5c7080; }
    
    .bp3-breadcrumb:hover{
      text-decoration:none; }
    
    .bp3-breadcrumb.bp3-disabled{
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
    
    .bp3-breadcrumb .bp3-icon{
      margin-right:5px; }
    
    .bp3-breadcrumb-current{
      color:inherit;
      font-weight:600; }
      .bp3-breadcrumb-current .bp3-input{
        font-size:inherit;
        font-weight:inherit;
        vertical-align:baseline; }
    
    .bp3-breadcrumbs-collapsed{
      background:#ced9e0;
      border:none;
      border-radius:3px;
      cursor:pointer;
      margin-right:2px;
      padding:1px 5px;
      vertical-align:text-bottom; }
      .bp3-breadcrumbs-collapsed::before{
        background:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cg fill='%235C7080'%3e%3ccircle cx='2' cy='8.03' r='2'/%3e%3ccircle cx='14' cy='8.03' r='2'/%3e%3ccircle cx='8' cy='8.03' r='2'/%3e%3c/g%3e%3c/svg%3e") center no-repeat;
        content:"";
        display:block;
        height:16px;
        width:16px; }
      .bp3-breadcrumbs-collapsed:hover{
        background:#bfccd6;
        color:#182026;
        text-decoration:none; }
    
    .bp3-dark .bp3-breadcrumb,
    .bp3-dark .bp3-breadcrumbs-collapsed{
      color:#a7b6c2; }
    
    .bp3-dark .bp3-breadcrumbs > li::after{
      color:#a7b6c2; }
    
    .bp3-dark .bp3-breadcrumb.bp3-disabled{
      color:rgba(167, 182, 194, 0.6); }
    
    .bp3-dark .bp3-breadcrumb-current{
      color:#f5f8fa; }
    
    .bp3-dark .bp3-breadcrumbs-collapsed{
      background:rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-breadcrumbs-collapsed:hover{
        background:rgba(16, 22, 26, 0.6);
        color:#f5f8fa; }
    .bp3-button{
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      border:none;
      border-radius:3px;
      cursor:pointer;
      font-size:14px;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      padding:5px 10px;
      text-align:left;
      vertical-align:middle;
      min-height:30px;
      min-width:30px; }
      .bp3-button > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-button > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-button::before,
      .bp3-button > *{
        margin-right:7px; }
      .bp3-button:empty::before,
      .bp3-button > :last-child{
        margin-right:0; }
      .bp3-button:empty{
        padding:0 !important; }
      .bp3-button:disabled, .bp3-button.bp3-disabled{
        cursor:not-allowed; }
      .bp3-button.bp3-fill{
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        width:100%; }
      .bp3-button.bp3-align-right,
      .bp3-align-right .bp3-button{
        text-align:right; }
      .bp3-button.bp3-align-left,
      .bp3-align-left .bp3-button{
        text-align:left; }
      .bp3-button:not([class*="bp3-intent-"]){
        background-color:#f5f8fa;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
        color:#182026; }
        .bp3-button:not([class*="bp3-intent-"]):hover{
          background-clip:padding-box;
          background-color:#ebf1f5;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
        .bp3-button:not([class*="bp3-intent-"]):active, .bp3-button:not([class*="bp3-intent-"]).bp3-active{
          background-color:#d8e1e8;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
          background-color:rgba(206, 217, 224, 0.5);
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed;
          outline:none; }
          .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active:hover, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active, .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active:hover{
            background:rgba(206, 217, 224, 0.7); }
      .bp3-button.bp3-intent-primary{
        background-color:#137cbd;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
        .bp3-button.bp3-intent-primary:hover, .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{
          color:#ffffff; }
        .bp3-button.bp3-intent-primary:hover{
          background-color:#106ba3;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-primary:active, .bp3-button.bp3-intent-primary.bp3-active{
          background-color:#0e5a8a;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-primary:disabled, .bp3-button.bp3-intent-primary.bp3-disabled{
          background-color:rgba(19, 124, 189, 0.5);
          background-image:none;
          border-color:transparent;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(255, 255, 255, 0.6); }
      .bp3-button.bp3-intent-success{
        background-color:#0f9960;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
        .bp3-button.bp3-intent-success:hover, .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{
          color:#ffffff; }
        .bp3-button.bp3-intent-success:hover{
          background-color:#0d8050;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-success:active, .bp3-button.bp3-intent-success.bp3-active{
          background-color:#0a6640;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-success:disabled, .bp3-button.bp3-intent-success.bp3-disabled{
          background-color:rgba(15, 153, 96, 0.5);
          background-image:none;
          border-color:transparent;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(255, 255, 255, 0.6); }
      .bp3-button.bp3-intent-warning{
        background-color:#d9822b;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
        .bp3-button.bp3-intent-warning:hover, .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{
          color:#ffffff; }
        .bp3-button.bp3-intent-warning:hover{
          background-color:#bf7326;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-warning:active, .bp3-button.bp3-intent-warning.bp3-active{
          background-color:#a66321;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-warning:disabled, .bp3-button.bp3-intent-warning.bp3-disabled{
          background-color:rgba(217, 130, 43, 0.5);
          background-image:none;
          border-color:transparent;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(255, 255, 255, 0.6); }
      .bp3-button.bp3-intent-danger{
        background-color:#db3737;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
        .bp3-button.bp3-intent-danger:hover, .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{
          color:#ffffff; }
        .bp3-button.bp3-intent-danger:hover{
          background-color:#c23030;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-danger:active, .bp3-button.bp3-intent-danger.bp3-active{
          background-color:#a82a2a;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-button.bp3-intent-danger:disabled, .bp3-button.bp3-intent-danger.bp3-disabled{
          background-color:rgba(219, 55, 55, 0.5);
          background-image:none;
          border-color:transparent;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(255, 255, 255, 0.6); }
      .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{
        stroke:#ffffff; }
      .bp3-button.bp3-large,
      .bp3-large .bp3-button{
        min-height:40px;
        min-width:40px;
        font-size:16px;
        padding:5px 15px; }
        .bp3-button.bp3-large::before,
        .bp3-button.bp3-large > *,
        .bp3-large .bp3-button::before,
        .bp3-large .bp3-button > *{
          margin-right:10px; }
        .bp3-button.bp3-large:empty::before,
        .bp3-button.bp3-large > :last-child,
        .bp3-large .bp3-button:empty::before,
        .bp3-large .bp3-button > :last-child{
          margin-right:0; }
      .bp3-button.bp3-small,
      .bp3-small .bp3-button{
        min-height:24px;
        min-width:24px;
        padding:0 7px; }
      .bp3-button.bp3-loading{
        position:relative; }
        .bp3-button.bp3-loading[class*="bp3-icon-"]::before{
          visibility:hidden; }
        .bp3-button.bp3-loading .bp3-button-spinner{
          margin:0;
          position:absolute; }
        .bp3-button.bp3-loading > :not(.bp3-button-spinner){
          visibility:hidden; }
      .bp3-button[class*="bp3-icon-"]::before{
        font-family:"Icons16", sans-serif;
        font-size:16px;
        font-style:normal;
        font-weight:400;
        line-height:1;
        -moz-osx-font-smoothing:grayscale;
        -webkit-font-smoothing:antialiased;
        color:#5c7080; }
      .bp3-button .bp3-icon, .bp3-button .bp3-icon-standard, .bp3-button .bp3-icon-large{
        color:#5c7080; }
        .bp3-button .bp3-icon.bp3-align-right, .bp3-button .bp3-icon-standard.bp3-align-right, .bp3-button .bp3-icon-large.bp3-align-right{
          margin-left:7px; }
      .bp3-button .bp3-icon:first-child:last-child,
      .bp3-button .bp3-spinner + .bp3-icon:last-child{
        margin:0 -7px; }
      .bp3-dark .bp3-button:not([class*="bp3-intent-"]){
        background-color:#394b59;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover, .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{
          color:#f5f8fa; }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]):hover{
          background-color:#30404d;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]):active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-active{
          background-color:#202b33;
          background-image:none;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled{
          background-color:rgba(57, 75, 89, 0.5);
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
          .bp3-dark .bp3-button:not([class*="bp3-intent-"]):disabled.bp3-active, .bp3-dark .bp3-button:not([class*="bp3-intent-"]).bp3-disabled.bp3-active{
            background:rgba(57, 75, 89, 0.7); }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-button-spinner .bp3-spinner-head{
          background:rgba(16, 22, 26, 0.5);
          stroke:#8a9ba8; }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"])[class*="bp3-icon-"]::before{
          color:#a7b6c2; }
        .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-button:not([class*="bp3-intent-"]) .bp3-icon-large{
          color:#a7b6c2; }
      .bp3-dark .bp3-button[class*="bp3-intent-"]{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-button[class*="bp3-intent-"]:hover{
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-button[class*="bp3-intent-"]:active, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-active{
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-dark .bp3-button[class*="bp3-intent-"]:disabled, .bp3-dark .bp3-button[class*="bp3-intent-"].bp3-disabled{
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(255, 255, 255, 0.3); }
        .bp3-dark .bp3-button[class*="bp3-intent-"] .bp3-button-spinner .bp3-spinner-head{
          stroke:#8a9ba8; }
      .bp3-button:disabled::before,
      .bp3-button:disabled .bp3-icon, .bp3-button:disabled .bp3-icon-standard, .bp3-button:disabled .bp3-icon-large, .bp3-button.bp3-disabled::before,
      .bp3-button.bp3-disabled .bp3-icon, .bp3-button.bp3-disabled .bp3-icon-standard, .bp3-button.bp3-disabled .bp3-icon-large, .bp3-button[class*="bp3-intent-"]::before,
      .bp3-button[class*="bp3-intent-"] .bp3-icon, .bp3-button[class*="bp3-intent-"] .bp3-icon-standard, .bp3-button[class*="bp3-intent-"] .bp3-icon-large{
        color:inherit !important; }
      .bp3-button.bp3-minimal{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none; }
        .bp3-button.bp3-minimal:hover{
          background:rgba(167, 182, 194, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026;
          text-decoration:none; }
        .bp3-button.bp3-minimal:active, .bp3-button.bp3-minimal.bp3-active{
          background:rgba(115, 134, 148, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026; }
        .bp3-button.bp3-minimal:disabled, .bp3-button.bp3-minimal:disabled:hover, .bp3-button.bp3-minimal.bp3-disabled, .bp3-button.bp3-minimal.bp3-disabled:hover{
          background:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed; }
          .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{
            background:rgba(115, 134, 148, 0.3); }
        .bp3-dark .bp3-button.bp3-minimal{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:inherit; }
          .bp3-dark .bp3-button.bp3-minimal:hover, .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none; }
          .bp3-dark .bp3-button.bp3-minimal:hover{
            background:rgba(138, 155, 168, 0.15); }
          .bp3-dark .bp3-button.bp3-minimal:active, .bp3-dark .bp3-button.bp3-minimal.bp3-active{
            background:rgba(138, 155, 168, 0.3);
            color:#f5f8fa; }
          .bp3-dark .bp3-button.bp3-minimal:disabled, .bp3-dark .bp3-button.bp3-minimal:disabled:hover, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover{
            background:none;
            color:rgba(167, 182, 194, 0.6);
            cursor:not-allowed; }
            .bp3-dark .bp3-button.bp3-minimal:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-disabled:hover.bp3-active{
              background:rgba(138, 155, 168, 0.3); }
        .bp3-button.bp3-minimal.bp3-intent-primary{
          color:#106ba3; }
          .bp3-button.bp3-minimal.bp3-intent-primary:hover, .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#106ba3; }
          .bp3-button.bp3-minimal.bp3-intent-primary:hover{
            background:rgba(19, 124, 189, 0.15);
            color:#106ba3; }
          .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
            background:rgba(19, 124, 189, 0.3);
            color:#106ba3; }
          .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{
            background:none;
            color:rgba(16, 107, 163, 0.5); }
            .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{
              background:rgba(19, 124, 189, 0.3); }
          .bp3-button.bp3-minimal.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
            stroke:#106ba3; }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary{
            color:#48aff0; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:hover{
              background:rgba(19, 124, 189, 0.2);
              color:#48aff0; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-active{
              background:rgba(19, 124, 189, 0.3);
              color:#48aff0; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled{
              background:none;
              color:rgba(72, 175, 240, 0.5); }
              .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-primary.bp3-disabled.bp3-active{
                background:rgba(19, 124, 189, 0.3); }
        .bp3-button.bp3-minimal.bp3-intent-success{
          color:#0d8050; }
          .bp3-button.bp3-minimal.bp3-intent-success:hover, .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#0d8050; }
          .bp3-button.bp3-minimal.bp3-intent-success:hover{
            background:rgba(15, 153, 96, 0.15);
            color:#0d8050; }
          .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
            background:rgba(15, 153, 96, 0.3);
            color:#0d8050; }
          .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{
            background:none;
            color:rgba(13, 128, 80, 0.5); }
            .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{
              background:rgba(15, 153, 96, 0.3); }
          .bp3-button.bp3-minimal.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
            stroke:#0d8050; }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success{
            color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:hover{
              background:rgba(15, 153, 96, 0.2);
              color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-active{
              background:rgba(15, 153, 96, 0.3);
              color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled{
              background:none;
              color:rgba(61, 204, 145, 0.5); }
              .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-success.bp3-disabled.bp3-active{
                background:rgba(15, 153, 96, 0.3); }
        .bp3-button.bp3-minimal.bp3-intent-warning{
          color:#bf7326; }
          .bp3-button.bp3-minimal.bp3-intent-warning:hover, .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#bf7326; }
          .bp3-button.bp3-minimal.bp3-intent-warning:hover{
            background:rgba(217, 130, 43, 0.15);
            color:#bf7326; }
          .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
            background:rgba(217, 130, 43, 0.3);
            color:#bf7326; }
          .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{
            background:none;
            color:rgba(191, 115, 38, 0.5); }
            .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{
              background:rgba(217, 130, 43, 0.3); }
          .bp3-button.bp3-minimal.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
            stroke:#bf7326; }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning{
            color:#ffb366; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:hover{
              background:rgba(217, 130, 43, 0.2);
              color:#ffb366; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-active{
              background:rgba(217, 130, 43, 0.3);
              color:#ffb366; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled{
              background:none;
              color:rgba(255, 179, 102, 0.5); }
              .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-warning.bp3-disabled.bp3-active{
                background:rgba(217, 130, 43, 0.3); }
        .bp3-button.bp3-minimal.bp3-intent-danger{
          color:#c23030; }
          .bp3-button.bp3-minimal.bp3-intent-danger:hover, .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#c23030; }
          .bp3-button.bp3-minimal.bp3-intent-danger:hover{
            background:rgba(219, 55, 55, 0.15);
            color:#c23030; }
          .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
            background:rgba(219, 55, 55, 0.3);
            color:#c23030; }
          .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{
            background:none;
            color:rgba(194, 48, 48, 0.5); }
            .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{
              background:rgba(219, 55, 55, 0.3); }
          .bp3-button.bp3-minimal.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
            stroke:#c23030; }
          .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger{
            color:#ff7373; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:hover{
              background:rgba(219, 55, 55, 0.2);
              color:#ff7373; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-active{
              background:rgba(219, 55, 55, 0.3);
              color:#ff7373; }
            .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled{
              background:none;
              color:rgba(255, 115, 115, 0.5); }
              .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-minimal.bp3-intent-danger.bp3-disabled.bp3-active{
                background:rgba(219, 55, 55, 0.3); }
      .bp3-button.bp3-outlined{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        border:1px solid rgba(24, 32, 38, 0.2);
        -webkit-box-sizing:border-box;
                box-sizing:border-box; }
        .bp3-button.bp3-outlined:hover{
          background:rgba(167, 182, 194, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026;
          text-decoration:none; }
        .bp3-button.bp3-outlined:active, .bp3-button.bp3-outlined.bp3-active{
          background:rgba(115, 134, 148, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026; }
        .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined.bp3-disabled:hover{
          background:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed; }
          .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{
            background:rgba(115, 134, 148, 0.3); }
        .bp3-dark .bp3-button.bp3-outlined{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:inherit; }
          .bp3-dark .bp3-button.bp3-outlined:hover, .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none; }
          .bp3-dark .bp3-button.bp3-outlined:hover{
            background:rgba(138, 155, 168, 0.15); }
          .bp3-dark .bp3-button.bp3-outlined:active, .bp3-dark .bp3-button.bp3-outlined.bp3-active{
            background:rgba(138, 155, 168, 0.3);
            color:#f5f8fa; }
          .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{
            background:none;
            color:rgba(167, 182, 194, 0.6);
            cursor:not-allowed; }
            .bp3-dark .bp3-button.bp3-outlined:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined:disabled:hover.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover.bp3-active{
              background:rgba(138, 155, 168, 0.3); }
        .bp3-button.bp3-outlined.bp3-intent-primary{
          color:#106ba3; }
          .bp3-button.bp3-outlined.bp3-intent-primary:hover, .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#106ba3; }
          .bp3-button.bp3-outlined.bp3-intent-primary:hover{
            background:rgba(19, 124, 189, 0.15);
            color:#106ba3; }
          .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
            background:rgba(19, 124, 189, 0.3);
            color:#106ba3; }
          .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
            background:none;
            color:rgba(16, 107, 163, 0.5); }
            .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{
              background:rgba(19, 124, 189, 0.3); }
          .bp3-button.bp3-outlined.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
            stroke:#106ba3; }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{
            color:#48aff0; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:hover{
              background:rgba(19, 124, 189, 0.2);
              color:#48aff0; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-active{
              background:rgba(19, 124, 189, 0.3);
              color:#48aff0; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
              background:none;
              color:rgba(72, 175, 240, 0.5); }
              .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled.bp3-active{
                background:rgba(19, 124, 189, 0.3); }
        .bp3-button.bp3-outlined.bp3-intent-success{
          color:#0d8050; }
          .bp3-button.bp3-outlined.bp3-intent-success:hover, .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#0d8050; }
          .bp3-button.bp3-outlined.bp3-intent-success:hover{
            background:rgba(15, 153, 96, 0.15);
            color:#0d8050; }
          .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
            background:rgba(15, 153, 96, 0.3);
            color:#0d8050; }
          .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
            background:none;
            color:rgba(13, 128, 80, 0.5); }
            .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{
              background:rgba(15, 153, 96, 0.3); }
          .bp3-button.bp3-outlined.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
            stroke:#0d8050; }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{
            color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:hover{
              background:rgba(15, 153, 96, 0.2);
              color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-active{
              background:rgba(15, 153, 96, 0.3);
              color:#3dcc91; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
              background:none;
              color:rgba(61, 204, 145, 0.5); }
              .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled.bp3-active{
                background:rgba(15, 153, 96, 0.3); }
        .bp3-button.bp3-outlined.bp3-intent-warning{
          color:#bf7326; }
          .bp3-button.bp3-outlined.bp3-intent-warning:hover, .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#bf7326; }
          .bp3-button.bp3-outlined.bp3-intent-warning:hover{
            background:rgba(217, 130, 43, 0.15);
            color:#bf7326; }
          .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
            background:rgba(217, 130, 43, 0.3);
            color:#bf7326; }
          .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
            background:none;
            color:rgba(191, 115, 38, 0.5); }
            .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{
              background:rgba(217, 130, 43, 0.3); }
          .bp3-button.bp3-outlined.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
            stroke:#bf7326; }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{
            color:#ffb366; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:hover{
              background:rgba(217, 130, 43, 0.2);
              color:#ffb366; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-active{
              background:rgba(217, 130, 43, 0.3);
              color:#ffb366; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
              background:none;
              color:rgba(255, 179, 102, 0.5); }
              .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled.bp3-active{
                background:rgba(217, 130, 43, 0.3); }
        .bp3-button.bp3-outlined.bp3-intent-danger{
          color:#c23030; }
          .bp3-button.bp3-outlined.bp3-intent-danger:hover, .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#c23030; }
          .bp3-button.bp3-outlined.bp3-intent-danger:hover{
            background:rgba(219, 55, 55, 0.15);
            color:#c23030; }
          .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
            background:rgba(219, 55, 55, 0.3);
            color:#c23030; }
          .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
            background:none;
            color:rgba(194, 48, 48, 0.5); }
            .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{
              background:rgba(219, 55, 55, 0.3); }
          .bp3-button.bp3-outlined.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
            stroke:#c23030; }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{
            color:#ff7373; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:hover{
              background:rgba(219, 55, 55, 0.2);
              color:#ff7373; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-active{
              background:rgba(219, 55, 55, 0.3);
              color:#ff7373; }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
              background:none;
              color:rgba(255, 115, 115, 0.5); }
              .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled.bp3-active{
                background:rgba(219, 55, 55, 0.3); }
        .bp3-button.bp3-outlined:disabled, .bp3-button.bp3-outlined.bp3-disabled, .bp3-button.bp3-outlined:disabled:hover, .bp3-button.bp3-outlined.bp3-disabled:hover{
          border-color:rgba(92, 112, 128, 0.1); }
        .bp3-dark .bp3-button.bp3-outlined{
          border-color:rgba(255, 255, 255, 0.4); }
          .bp3-dark .bp3-button.bp3-outlined:disabled, .bp3-dark .bp3-button.bp3-outlined:disabled:hover, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-disabled:hover{
            border-color:rgba(255, 255, 255, 0.2); }
        .bp3-button.bp3-outlined.bp3-intent-primary{
          border-color:rgba(16, 107, 163, 0.6); }
          .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
            border-color:rgba(16, 107, 163, 0.2); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary{
            border-color:rgba(72, 175, 240, 0.6); }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-primary.bp3-disabled{
              border-color:rgba(72, 175, 240, 0.2); }
        .bp3-button.bp3-outlined.bp3-intent-success{
          border-color:rgba(13, 128, 80, 0.6); }
          .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
            border-color:rgba(13, 128, 80, 0.2); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success{
            border-color:rgba(61, 204, 145, 0.6); }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-success.bp3-disabled{
              border-color:rgba(61, 204, 145, 0.2); }
        .bp3-button.bp3-outlined.bp3-intent-warning{
          border-color:rgba(191, 115, 38, 0.6); }
          .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
            border-color:rgba(191, 115, 38, 0.2); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning{
            border-color:rgba(255, 179, 102, 0.6); }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-warning.bp3-disabled{
              border-color:rgba(255, 179, 102, 0.2); }
        .bp3-button.bp3-outlined.bp3-intent-danger{
          border-color:rgba(194, 48, 48, 0.6); }
          .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
            border-color:rgba(194, 48, 48, 0.2); }
          .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger{
            border-color:rgba(255, 115, 115, 0.6); }
            .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger:disabled, .bp3-dark .bp3-button.bp3-outlined.bp3-intent-danger.bp3-disabled{
              border-color:rgba(255, 115, 115, 0.2); }
    
    a.bp3-button{
      text-align:center;
      text-decoration:none;
      -webkit-transition:none;
      transition:none; }
      a.bp3-button, a.bp3-button:hover, a.bp3-button:active{
        color:#182026; }
      a.bp3-button.bp3-disabled{
        color:rgba(92, 112, 128, 0.6); }
    
    .bp3-button-text{
      -webkit-box-flex:0;
          -ms-flex:0 1 auto;
              flex:0 1 auto; }
    
    .bp3-button.bp3-align-left .bp3-button-text, .bp3-button.bp3-align-right .bp3-button-text,
    .bp3-button-group.bp3-align-left .bp3-button-text,
    .bp3-button-group.bp3-align-right .bp3-button-text{
      -webkit-box-flex:1;
          -ms-flex:1 1 auto;
              flex:1 1 auto; }
    .bp3-button-group{
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex; }
      .bp3-button-group .bp3-button{
        -webkit-box-flex:0;
            -ms-flex:0 0 auto;
                flex:0 0 auto;
        position:relative;
        z-index:4; }
        .bp3-button-group .bp3-button:focus{
          z-index:5; }
        .bp3-button-group .bp3-button:hover{
          z-index:6; }
        .bp3-button-group .bp3-button:active, .bp3-button-group .bp3-button.bp3-active{
          z-index:7; }
        .bp3-button-group .bp3-button:disabled, .bp3-button-group .bp3-button.bp3-disabled{
          z-index:3; }
        .bp3-button-group .bp3-button[class*="bp3-intent-"]{
          z-index:9; }
          .bp3-button-group .bp3-button[class*="bp3-intent-"]:focus{
            z-index:10; }
          .bp3-button-group .bp3-button[class*="bp3-intent-"]:hover{
            z-index:11; }
          .bp3-button-group .bp3-button[class*="bp3-intent-"]:active, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-active{
            z-index:12; }
          .bp3-button-group .bp3-button[class*="bp3-intent-"]:disabled, .bp3-button-group .bp3-button[class*="bp3-intent-"].bp3-disabled{
            z-index:8; }
      .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:first-child) .bp3-button,
      .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:first-child){
        border-bottom-left-radius:0;
        border-top-left-radius:0; }
      .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
      .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){
        border-bottom-right-radius:0;
        border-top-right-radius:0;
        margin-right:-1px; }
      .bp3-button-group.bp3-minimal .bp3-button{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none; }
        .bp3-button-group.bp3-minimal .bp3-button:hover{
          background:rgba(167, 182, 194, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026;
          text-decoration:none; }
        .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
          background:rgba(115, 134, 148, 0.3);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#182026; }
        .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{
          background:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed; }
          .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{
            background:rgba(115, 134, 148, 0.3); }
        .bp3-dark .bp3-button-group.bp3-minimal .bp3-button{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:inherit; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:hover{
            background:rgba(138, 155, 168, 0.15); }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-active{
            background:rgba(138, 155, 168, 0.3);
            color:#f5f8fa; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover{
            background:none;
            color:rgba(167, 182, 194, 0.6);
            cursor:not-allowed; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button:disabled:hover.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-disabled:hover.bp3-active{
              background:rgba(138, 155, 168, 0.3); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{
          color:#106ba3; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#106ba3; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{
            background:rgba(19, 124, 189, 0.15);
            color:#106ba3; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
            background:rgba(19, 124, 189, 0.3);
            color:#106ba3; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{
            background:none;
            color:rgba(16, 107, 163, 0.5); }
            .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{
              background:rgba(19, 124, 189, 0.3); }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
            stroke:#106ba3; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary{
            color:#48aff0; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:hover{
              background:rgba(19, 124, 189, 0.2);
              color:#48aff0; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-active{
              background:rgba(19, 124, 189, 0.3);
              color:#48aff0; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled{
              background:none;
              color:rgba(72, 175, 240, 0.5); }
              .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-primary.bp3-disabled.bp3-active{
                background:rgba(19, 124, 189, 0.3); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{
          color:#0d8050; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#0d8050; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{
            background:rgba(15, 153, 96, 0.15);
            color:#0d8050; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
            background:rgba(15, 153, 96, 0.3);
            color:#0d8050; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{
            background:none;
            color:rgba(13, 128, 80, 0.5); }
            .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{
              background:rgba(15, 153, 96, 0.3); }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
            stroke:#0d8050; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success{
            color:#3dcc91; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:hover{
              background:rgba(15, 153, 96, 0.2);
              color:#3dcc91; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-active{
              background:rgba(15, 153, 96, 0.3);
              color:#3dcc91; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled{
              background:none;
              color:rgba(61, 204, 145, 0.5); }
              .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-success.bp3-disabled.bp3-active{
                background:rgba(15, 153, 96, 0.3); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{
          color:#bf7326; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#bf7326; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{
            background:rgba(217, 130, 43, 0.15);
            color:#bf7326; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
            background:rgba(217, 130, 43, 0.3);
            color:#bf7326; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{
            background:none;
            color:rgba(191, 115, 38, 0.5); }
            .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{
              background:rgba(217, 130, 43, 0.3); }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
            stroke:#bf7326; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning{
            color:#ffb366; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:hover{
              background:rgba(217, 130, 43, 0.2);
              color:#ffb366; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-active{
              background:rgba(217, 130, 43, 0.3);
              color:#ffb366; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled{
              background:none;
              color:rgba(255, 179, 102, 0.5); }
              .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-warning.bp3-disabled.bp3-active{
                background:rgba(217, 130, 43, 0.3); }
        .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{
          color:#c23030; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
            background:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:#c23030; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{
            background:rgba(219, 55, 55, 0.15);
            color:#c23030; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
            background:rgba(219, 55, 55, 0.3);
            color:#c23030; }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{
            background:none;
            color:rgba(194, 48, 48, 0.5); }
            .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{
              background:rgba(219, 55, 55, 0.3); }
          .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
            stroke:#c23030; }
          .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger{
            color:#ff7373; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:hover{
              background:rgba(219, 55, 55, 0.2);
              color:#ff7373; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-active{
              background:rgba(219, 55, 55, 0.3);
              color:#ff7373; }
            .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled{
              background:none;
              color:rgba(255, 115, 115, 0.5); }
              .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-button-group.bp3-minimal .bp3-button.bp3-intent-danger.bp3-disabled.bp3-active{
                background:rgba(219, 55, 55, 0.3); }
      .bp3-button-group .bp3-popover-wrapper,
      .bp3-button-group .bp3-popover-target{
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto; }
      .bp3-button-group.bp3-fill{
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        width:100%; }
      .bp3-button-group .bp3-button.bp3-fill,
      .bp3-button-group.bp3-fill .bp3-button:not(.bp3-fixed){
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto; }
      .bp3-button-group.bp3-vertical{
        -webkit-box-align:stretch;
            -ms-flex-align:stretch;
                align-items:stretch;
        -webkit-box-orient:vertical;
        -webkit-box-direction:normal;
            -ms-flex-direction:column;
                flex-direction:column;
        vertical-align:top; }
        .bp3-button-group.bp3-vertical.bp3-fill{
          height:100%;
          width:unset; }
        .bp3-button-group.bp3-vertical .bp3-button{
          margin-right:0 !important;
          width:100%; }
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:first-child .bp3-button,
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:first-child{
          border-radius:3px 3px 0 0; }
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:last-child .bp3-button,
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:last-child{
          border-radius:0 0 3px 3px; }
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
        .bp3-button-group.bp3-vertical:not(.bp3-minimal) > .bp3-button:not(:last-child){
          margin-bottom:-1px; }
      .bp3-button-group.bp3-align-left .bp3-button{
        text-align:left; }
      .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-popover-wrapper:not(:last-child) .bp3-button,
      .bp3-dark .bp3-button-group:not(.bp3-minimal) > .bp3-button:not(:last-child){
        margin-right:1px; }
      .bp3-dark .bp3-button-group.bp3-vertical > .bp3-popover-wrapper:not(:last-child) .bp3-button,
      .bp3-dark .bp3-button-group.bp3-vertical > .bp3-button:not(:last-child){
        margin-bottom:1px; }
    .bp3-callout{
      font-size:14px;
      line-height:1.5;
      background-color:rgba(138, 155, 168, 0.15);
      border-radius:3px;
      padding:10px 12px 9px;
      position:relative;
      width:100%; }
      .bp3-callout[class*="bp3-icon-"]{
        padding-left:40px; }
        .bp3-callout[class*="bp3-icon-"]::before{
          font-family:"Icons20", sans-serif;
          font-size:20px;
          font-style:normal;
          font-weight:400;
          line-height:1;
          -moz-osx-font-smoothing:grayscale;
          -webkit-font-smoothing:antialiased;
          color:#5c7080;
          left:10px;
          position:absolute;
          top:10px; }
      .bp3-callout.bp3-callout-icon{
        padding-left:40px; }
        .bp3-callout.bp3-callout-icon > .bp3-icon:first-child{
          color:#5c7080;
          left:10px;
          position:absolute;
          top:10px; }
      .bp3-callout .bp3-heading{
        line-height:20px;
        margin-bottom:5px;
        margin-top:0; }
        .bp3-callout .bp3-heading:last-child{
          margin-bottom:0; }
      .bp3-dark .bp3-callout{
        background-color:rgba(138, 155, 168, 0.2); }
        .bp3-dark .bp3-callout[class*="bp3-icon-"]::before{
          color:#a7b6c2; }
      .bp3-callout.bp3-intent-primary{
        background-color:rgba(19, 124, 189, 0.15); }
        .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before,
        .bp3-callout.bp3-intent-primary > .bp3-icon:first-child,
        .bp3-callout.bp3-intent-primary .bp3-heading{
          color:#106ba3; }
        .bp3-dark .bp3-callout.bp3-intent-primary{
          background-color:rgba(19, 124, 189, 0.25); }
          .bp3-dark .bp3-callout.bp3-intent-primary[class*="bp3-icon-"]::before,
          .bp3-dark .bp3-callout.bp3-intent-primary > .bp3-icon:first-child,
          .bp3-dark .bp3-callout.bp3-intent-primary .bp3-heading{
            color:#48aff0; }
      .bp3-callout.bp3-intent-success{
        background-color:rgba(15, 153, 96, 0.15); }
        .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before,
        .bp3-callout.bp3-intent-success > .bp3-icon:first-child,
        .bp3-callout.bp3-intent-success .bp3-heading{
          color:#0d8050; }
        .bp3-dark .bp3-callout.bp3-intent-success{
          background-color:rgba(15, 153, 96, 0.25); }
          .bp3-dark .bp3-callout.bp3-intent-success[class*="bp3-icon-"]::before,
          .bp3-dark .bp3-callout.bp3-intent-success > .bp3-icon:first-child,
          .bp3-dark .bp3-callout.bp3-intent-success .bp3-heading{
            color:#3dcc91; }
      .bp3-callout.bp3-intent-warning{
        background-color:rgba(217, 130, 43, 0.15); }
        .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before,
        .bp3-callout.bp3-intent-warning > .bp3-icon:first-child,
        .bp3-callout.bp3-intent-warning .bp3-heading{
          color:#bf7326; }
        .bp3-dark .bp3-callout.bp3-intent-warning{
          background-color:rgba(217, 130, 43, 0.25); }
          .bp3-dark .bp3-callout.bp3-intent-warning[class*="bp3-icon-"]::before,
          .bp3-dark .bp3-callout.bp3-intent-warning > .bp3-icon:first-child,
          .bp3-dark .bp3-callout.bp3-intent-warning .bp3-heading{
            color:#ffb366; }
      .bp3-callout.bp3-intent-danger{
        background-color:rgba(219, 55, 55, 0.15); }
        .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before,
        .bp3-callout.bp3-intent-danger > .bp3-icon:first-child,
        .bp3-callout.bp3-intent-danger .bp3-heading{
          color:#c23030; }
        .bp3-dark .bp3-callout.bp3-intent-danger{
          background-color:rgba(219, 55, 55, 0.25); }
          .bp3-dark .bp3-callout.bp3-intent-danger[class*="bp3-icon-"]::before,
          .bp3-dark .bp3-callout.bp3-intent-danger > .bp3-icon:first-child,
          .bp3-dark .bp3-callout.bp3-intent-danger .bp3-heading{
            color:#ff7373; }
      .bp3-running-text .bp3-callout{
        margin:20px 0; }
    .bp3-card{
      background-color:#ffffff;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
      padding:20px;
      -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-card.bp3-dark,
      .bp3-dark .bp3-card{
        background-color:#30404d;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }
    
    .bp3-elevation-0{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.15), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }
      .bp3-elevation-0.bp3-dark,
      .bp3-dark .bp3-elevation-0{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), 0 0 0 rgba(16, 22, 26, 0), 0 0 0 rgba(16, 22, 26, 0); }
    
    .bp3-elevation-1{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-elevation-1.bp3-dark,
      .bp3-dark .bp3-elevation-1{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
    
    .bp3-elevation-2{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 1px 1px rgba(16, 22, 26, 0.2), 0 2px 6px rgba(16, 22, 26, 0.2); }
      .bp3-elevation-2.bp3-dark,
      .bp3-dark .bp3-elevation-2{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.4), 0 2px 6px rgba(16, 22, 26, 0.4); }
    
    .bp3-elevation-3{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); }
      .bp3-elevation-3.bp3-dark,
      .bp3-dark .bp3-elevation-3{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    
    .bp3-elevation-4{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2); }
      .bp3-elevation-4.bp3-dark,
      .bp3-dark .bp3-elevation-4{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); }
    
    .bp3-card.bp3-interactive:hover{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
      cursor:pointer; }
      .bp3-card.bp3-interactive:hover.bp3-dark,
      .bp3-dark .bp3-card.bp3-interactive:hover{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    
    .bp3-card.bp3-interactive:active{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
      opacity:0.9;
      -webkit-transition-duration:0;
              transition-duration:0; }
      .bp3-card.bp3-interactive:active.bp3-dark,
      .bp3-dark .bp3-card.bp3-interactive:active{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
    
    .bp3-collapse{
      height:0;
      overflow-y:hidden;
      -webkit-transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:height 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-collapse .bp3-collapse-body{
        -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-collapse .bp3-collapse-body[aria-hidden="true"]{
          display:none; }
    
    .bp3-context-menu .bp3-popover-target{
      display:block; }
    
    .bp3-context-menu-popover-target{
      position:fixed; }
    
    .bp3-divider{
      border-bottom:1px solid rgba(16, 22, 26, 0.15);
      border-right:1px solid rgba(16, 22, 26, 0.15);
      margin:5px; }
      .bp3-dark .bp3-divider{
        border-color:rgba(16, 22, 26, 0.4); }
    .bp3-dialog-container{
      opacity:1;
      -webkit-transform:scale(1);
              transform:scale(1);
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      min-height:100%;
      pointer-events:none;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none;
      width:100%; }
      .bp3-dialog-container.bp3-overlay-enter > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear > .bp3-dialog{
        opacity:0;
        -webkit-transform:scale(0.5);
                transform:scale(0.5); }
      .bp3-dialog-container.bp3-overlay-enter-active > .bp3-dialog, .bp3-dialog-container.bp3-overlay-appear-active > .bp3-dialog{
        opacity:1;
        -webkit-transform:scale(1);
                transform:scale(1);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:opacity, -webkit-transform;
        transition-property:opacity, -webkit-transform;
        transition-property:opacity, transform;
        transition-property:opacity, transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
      .bp3-dialog-container.bp3-overlay-exit > .bp3-dialog{
        opacity:1;
        -webkit-transform:scale(1);
                transform:scale(1); }
      .bp3-dialog-container.bp3-overlay-exit-active > .bp3-dialog{
        opacity:0;
        -webkit-transform:scale(0.5);
                transform:scale(0.5);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:opacity, -webkit-transform;
        transition-property:opacity, -webkit-transform;
        transition-property:opacity, transform;
        transition-property:opacity, transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
    
    .bp3-dialog{
      background:#ebf1f5;
      border-radius:6px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      margin:30px 0;
      padding-bottom:20px;
      pointer-events:all;
      -webkit-user-select:text;
         -moz-user-select:text;
          -ms-user-select:text;
              user-select:text;
      width:500px; }
      .bp3-dialog:focus{
        outline:0; }
      .bp3-dialog.bp3-dark,
      .bp3-dark .bp3-dialog{
        background:#293742;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
    
    .bp3-dialog-header{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      background:#ffffff;
      border-radius:6px 6px 0 0;
      -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
              box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      min-height:40px;
      padding-left:20px;
      padding-right:5px;
      z-index:30; }
      .bp3-dialog-header .bp3-icon-large,
      .bp3-dialog-header .bp3-icon{
        color:#5c7080;
        -webkit-box-flex:0;
            -ms-flex:0 0 auto;
                flex:0 0 auto;
        margin-right:10px; }
      .bp3-dialog-header .bp3-heading{
        overflow:hidden;
        text-overflow:ellipsis;
        white-space:nowrap;
        word-wrap:normal;
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto;
        line-height:inherit;
        margin:0; }
        .bp3-dialog-header .bp3-heading:last-child{
          margin-right:20px; }
      .bp3-dark .bp3-dialog-header{
        background:#30404d;
        -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
                box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-dialog-header .bp3-icon-large,
        .bp3-dark .bp3-dialog-header .bp3-icon{
          color:#a7b6c2; }
    
    .bp3-dialog-body{
      -webkit-box-flex:1;
          -ms-flex:1 1 auto;
              flex:1 1 auto;
      line-height:18px;
      margin:20px; }
    
    .bp3-dialog-footer{
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      margin:0 20px; }
    
    .bp3-dialog-footer-actions{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-pack:end;
          -ms-flex-pack:end;
              justify-content:flex-end; }
      .bp3-dialog-footer-actions .bp3-button{
        margin-left:10px; }
    .bp3-multistep-dialog-panels{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex; }
    
    .bp3-multistep-dialog-left-panel{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-flex:1;
          -ms-flex:1;
              flex:1;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column; }
      .bp3-dark .bp3-multistep-dialog-left-panel{
        background:#202b33; }
    
    .bp3-multistep-dialog-right-panel{
      background-color:#f5f8fa;
      border-left:1px solid rgba(16, 22, 26, 0.15);
      border-radius:0 0 6px 0;
      -webkit-box-flex:3;
          -ms-flex:3;
              flex:3;
      min-width:0; }
      .bp3-dark .bp3-multistep-dialog-right-panel{
        background-color:#293742;
        border-left:1px solid rgba(16, 22, 26, 0.4); }
    
    .bp3-multistep-dialog-footer{
      background-color:#ffffff;
      border-radius:0 0 6px 0;
      border-top:1px solid rgba(16, 22, 26, 0.15);
      padding:10px; }
      .bp3-dark .bp3-multistep-dialog-footer{
        background:#30404d;
        border-top:1px solid rgba(16, 22, 26, 0.4); }
    
    .bp3-dialog-step-container{
      background-color:#f5f8fa;
      border-bottom:1px solid rgba(16, 22, 26, 0.15); }
      .bp3-dark .bp3-dialog-step-container{
        background:#293742;
        border-bottom:1px solid rgba(16, 22, 26, 0.4); }
      .bp3-dialog-step-container.bp3-dialog-step-viewed{
        background-color:#ffffff; }
        .bp3-dark .bp3-dialog-step-container.bp3-dialog-step-viewed{
          background:#30404d; }
    
    .bp3-dialog-step{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      background-color:#f5f8fa;
      border-radius:6px;
      cursor:not-allowed;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      margin:4px;
      padding:6px 14px; }
      .bp3-dark .bp3-dialog-step{
        background:#293742; }
      .bp3-dialog-step-viewed .bp3-dialog-step{
        background-color:#ffffff;
        cursor:pointer; }
        .bp3-dark .bp3-dialog-step-viewed .bp3-dialog-step{
          background:#30404d; }
      .bp3-dialog-step:hover{
        background-color:#f5f8fa; }
        .bp3-dark .bp3-dialog-step:hover{
          background:#293742; }
    
    .bp3-dialog-step-icon{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      background-color:rgba(92, 112, 128, 0.6);
      border-radius:50%;
      color:#ffffff;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      height:25px;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      width:25px; }
      .bp3-dark .bp3-dialog-step-icon{
        background-color:rgba(167, 182, 194, 0.6); }
      .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-icon{
        background-color:#2b95d6; }
      .bp3-dialog-step-viewed .bp3-dialog-step-icon{
        background-color:#8a9ba8; }
    
    .bp3-dialog-step-title{
      color:rgba(92, 112, 128, 0.6);
      -webkit-box-flex:1;
          -ms-flex:1;
              flex:1;
      padding-left:10px; }
      .bp3-dark .bp3-dialog-step-title{
        color:rgba(167, 182, 194, 0.6); }
      .bp3-active.bp3-dialog-step-viewed .bp3-dialog-step-title{
        color:#2b95d6; }
      .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{
        color:#182026; }
        .bp3-dark .bp3-dialog-step-viewed:not(.bp3-active) .bp3-dialog-step-title{
          color:#f5f8fa; }
    .bp3-drawer{
      background:#ffffff;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      margin:0;
      padding:0; }
      .bp3-drawer:focus{
        outline:0; }
      .bp3-drawer.bp3-position-top{
        height:50%;
        left:0;
        right:0;
        top:0; }
        .bp3-drawer.bp3-position-top.bp3-overlay-enter, .bp3-drawer.bp3-position-top.bp3-overlay-appear{
          -webkit-transform:translateY(-100%);
                  transform:translateY(-100%); }
        .bp3-drawer.bp3-position-top.bp3-overlay-enter-active, .bp3-drawer.bp3-position-top.bp3-overlay-appear-active{
          -webkit-transform:translateY(0);
                  transform:translateY(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer.bp3-position-top.bp3-overlay-exit{
          -webkit-transform:translateY(0);
                  transform:translateY(0); }
        .bp3-drawer.bp3-position-top.bp3-overlay-exit-active{
          -webkit-transform:translateY(-100%);
                  transform:translateY(-100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer.bp3-position-bottom{
        bottom:0;
        height:50%;
        left:0;
        right:0; }
        .bp3-drawer.bp3-position-bottom.bp3-overlay-enter, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear{
          -webkit-transform:translateY(100%);
                  transform:translateY(100%); }
        .bp3-drawer.bp3-position-bottom.bp3-overlay-enter-active, .bp3-drawer.bp3-position-bottom.bp3-overlay-appear-active{
          -webkit-transform:translateY(0);
                  transform:translateY(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer.bp3-position-bottom.bp3-overlay-exit{
          -webkit-transform:translateY(0);
                  transform:translateY(0); }
        .bp3-drawer.bp3-position-bottom.bp3-overlay-exit-active{
          -webkit-transform:translateY(100%);
                  transform:translateY(100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer.bp3-position-left{
        bottom:0;
        left:0;
        top:0;
        width:50%; }
        .bp3-drawer.bp3-position-left.bp3-overlay-enter, .bp3-drawer.bp3-position-left.bp3-overlay-appear{
          -webkit-transform:translateX(-100%);
                  transform:translateX(-100%); }
        .bp3-drawer.bp3-position-left.bp3-overlay-enter-active, .bp3-drawer.bp3-position-left.bp3-overlay-appear-active{
          -webkit-transform:translateX(0);
                  transform:translateX(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer.bp3-position-left.bp3-overlay-exit{
          -webkit-transform:translateX(0);
                  transform:translateX(0); }
        .bp3-drawer.bp3-position-left.bp3-overlay-exit-active{
          -webkit-transform:translateX(-100%);
                  transform:translateX(-100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer.bp3-position-right{
        bottom:0;
        right:0;
        top:0;
        width:50%; }
        .bp3-drawer.bp3-position-right.bp3-overlay-enter, .bp3-drawer.bp3-position-right.bp3-overlay-appear{
          -webkit-transform:translateX(100%);
                  transform:translateX(100%); }
        .bp3-drawer.bp3-position-right.bp3-overlay-enter-active, .bp3-drawer.bp3-position-right.bp3-overlay-appear-active{
          -webkit-transform:translateX(0);
                  transform:translateX(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer.bp3-position-right.bp3-overlay-exit{
          -webkit-transform:translateX(0);
                  transform:translateX(0); }
        .bp3-drawer.bp3-position-right.bp3-overlay-exit-active{
          -webkit-transform:translateX(100%);
                  transform:translateX(100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
      .bp3-position-right):not(.bp3-vertical){
        bottom:0;
        right:0;
        top:0;
        width:50%; }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear{
          -webkit-transform:translateX(100%);
                  transform:translateX(100%); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-appear-active{
          -webkit-transform:translateX(0);
                  transform:translateX(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit{
          -webkit-transform:translateX(0);
                  transform:translateX(0); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right):not(.bp3-vertical).bp3-overlay-exit-active{
          -webkit-transform:translateX(100%);
                  transform:translateX(100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
      .bp3-position-right).bp3-vertical{
        bottom:0;
        height:50%;
        left:0;
        right:0; }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-enter, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-appear{
          -webkit-transform:translateY(100%);
                  transform:translateY(100%); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-enter-active, .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-appear-active{
          -webkit-transform:translateY(0);
                  transform:translateY(0);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:200ms;
                  transition-duration:200ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-exit{
          -webkit-transform:translateY(0);
                  transform:translateY(0); }
        .bp3-drawer:not(.bp3-position-top):not(.bp3-position-bottom):not(.bp3-position-left):not(
        .bp3-position-right).bp3-vertical.bp3-overlay-exit-active{
          -webkit-transform:translateY(100%);
                  transform:translateY(100%);
          -webkit-transition-delay:0;
                  transition-delay:0;
          -webkit-transition-duration:100ms;
                  transition-duration:100ms;
          -webkit-transition-property:-webkit-transform;
          transition-property:-webkit-transform;
          transition-property:transform;
          transition-property:transform, -webkit-transform;
          -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                  transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-drawer.bp3-dark,
      .bp3-dark .bp3-drawer{
        background:#30404d;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
    
    .bp3-drawer-header{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      border-radius:0;
      -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
              box-shadow:0 1px 0 rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      min-height:40px;
      padding:5px;
      padding-left:20px;
      position:relative; }
      .bp3-drawer-header .bp3-icon-large,
      .bp3-drawer-header .bp3-icon{
        color:#5c7080;
        -webkit-box-flex:0;
            -ms-flex:0 0 auto;
                flex:0 0 auto;
        margin-right:10px; }
      .bp3-drawer-header .bp3-heading{
        overflow:hidden;
        text-overflow:ellipsis;
        white-space:nowrap;
        word-wrap:normal;
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto;
        line-height:inherit;
        margin:0; }
        .bp3-drawer-header .bp3-heading:last-child{
          margin-right:20px; }
      .bp3-dark .bp3-drawer-header{
        -webkit-box-shadow:0 1px 0 rgba(16, 22, 26, 0.4);
                box-shadow:0 1px 0 rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-drawer-header .bp3-icon-large,
        .bp3-dark .bp3-drawer-header .bp3-icon{
          color:#a7b6c2; }
    
    .bp3-drawer-body{
      -webkit-box-flex:1;
          -ms-flex:1 1 auto;
              flex:1 1 auto;
      line-height:18px;
      overflow:auto; }
    
    .bp3-drawer-footer{
      -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
              box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      padding:10px 20px;
      position:relative; }
      .bp3-dark .bp3-drawer-footer{
        -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4);
                box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.4); }
    .bp3-editable-text{
      cursor:text;
      display:inline-block;
      max-width:100%;
      position:relative;
      vertical-align:top;
      white-space:nowrap; }
      .bp3-editable-text::before{
        bottom:-3px;
        left:-3px;
        position:absolute;
        right:-3px;
        top:-3px;
        border-radius:3px;
        content:"";
        -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9), box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-editable-text:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
      .bp3-editable-text.bp3-editable-text-editing::before{
        background-color:#ffffff;
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-editable-text.bp3-disabled::before{
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-editable-text.bp3-intent-primary .bp3-editable-text-input,
      .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{
        color:#137cbd; }
      .bp3-editable-text.bp3-intent-primary:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(19, 124, 189, 0.4); }
      .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-editable-text.bp3-intent-success .bp3-editable-text-input,
      .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{
        color:#0f9960; }
      .bp3-editable-text.bp3-intent-success:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4);
                box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px rgba(15, 153, 96, 0.4); }
      .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-editable-text.bp3-intent-warning .bp3-editable-text-input,
      .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{
        color:#d9822b; }
      .bp3-editable-text.bp3-intent-warning:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4);
                box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px rgba(217, 130, 43, 0.4); }
      .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-editable-text.bp3-intent-danger .bp3-editable-text-input,
      .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{
        color:#db3737; }
      .bp3-editable-text.bp3-intent-danger:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4);
                box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px rgba(219, 55, 55, 0.4); }
      .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-editable-text:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(255, 255, 255, 0.15); }
      .bp3-dark .bp3-editable-text.bp3-editable-text-editing::before{
        background-color:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-disabled::before{
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-editable-text.bp3-intent-primary .bp3-editable-text-content{
        color:#48aff0; }
      .bp3-dark .bp3-editable-text.bp3-intent-primary:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4);
                box-shadow:0 0 0 0 rgba(72, 175, 240, 0), 0 0 0 0 rgba(72, 175, 240, 0), inset 0 0 0 1px rgba(72, 175, 240, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-primary.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #48aff0, 0 0 0 3px rgba(72, 175, 240, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-success .bp3-editable-text-content{
        color:#3dcc91; }
      .bp3-dark .bp3-editable-text.bp3-intent-success:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4);
                box-shadow:0 0 0 0 rgba(61, 204, 145, 0), 0 0 0 0 rgba(61, 204, 145, 0), inset 0 0 0 1px rgba(61, 204, 145, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-success.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #3dcc91, 0 0 0 3px rgba(61, 204, 145, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-warning .bp3-editable-text-content{
        color:#ffb366; }
      .bp3-dark .bp3-editable-text.bp3-intent-warning:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4);
                box-shadow:0 0 0 0 rgba(255, 179, 102, 0), 0 0 0 0 rgba(255, 179, 102, 0), inset 0 0 0 1px rgba(255, 179, 102, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-warning.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #ffb366, 0 0 0 3px rgba(255, 179, 102, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-danger .bp3-editable-text-content{
        color:#ff7373; }
      .bp3-dark .bp3-editable-text.bp3-intent-danger:hover::before{
        -webkit-box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4);
                box-shadow:0 0 0 0 rgba(255, 115, 115, 0), 0 0 0 0 rgba(255, 115, 115, 0), inset 0 0 0 1px rgba(255, 115, 115, 0.4); }
      .bp3-dark .bp3-editable-text.bp3-intent-danger.bp3-editable-text-editing::before{
        -webkit-box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #ff7373, 0 0 0 3px rgba(255, 115, 115, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    
    .bp3-editable-text-input,
    .bp3-editable-text-content{
      color:inherit;
      display:inherit;
      font:inherit;
      letter-spacing:inherit;
      max-width:inherit;
      min-width:inherit;
      position:relative;
      resize:none;
      text-transform:inherit;
      vertical-align:top; }
    
    .bp3-editable-text-input{
      background:none;
      border:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      padding:0;
      white-space:pre-wrap;
      width:100%; }
      .bp3-editable-text-input::-webkit-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-editable-text-input::-moz-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-editable-text-input:-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-editable-text-input::-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-editable-text-input::placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-editable-text-input:focus{
        outline:none; }
      .bp3-editable-text-input::-ms-clear{
        display:none; }
    
    .bp3-editable-text-content{
      overflow:hidden;
      padding-right:2px;
      text-overflow:ellipsis;
      white-space:pre; }
      .bp3-editable-text-editing > .bp3-editable-text-content{
        left:0;
        position:absolute;
        visibility:hidden; }
      .bp3-editable-text-placeholder > .bp3-editable-text-content{
        color:rgba(92, 112, 128, 0.6); }
        .bp3-dark .bp3-editable-text-placeholder > .bp3-editable-text-content{
          color:rgba(167, 182, 194, 0.6); }
    
    .bp3-editable-text.bp3-multiline{
      display:block; }
      .bp3-editable-text.bp3-multiline .bp3-editable-text-content{
        overflow:auto;
        white-space:pre-wrap;
        word-wrap:break-word; }
    .bp3-divider{
      border-bottom:1px solid rgba(16, 22, 26, 0.15);
      border-right:1px solid rgba(16, 22, 26, 0.15);
      margin:5px; }
      .bp3-dark .bp3-divider{
        border-color:rgba(16, 22, 26, 0.4); }
    .bp3-control-group{
      -webkit-transform:translateZ(0);
              transform:translateZ(0);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:stretch;
          -ms-flex-align:stretch;
              align-items:stretch; }
      .bp3-control-group > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-control-group > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-control-group .bp3-button,
      .bp3-control-group .bp3-html-select,
      .bp3-control-group .bp3-input,
      .bp3-control-group .bp3-select{
        position:relative; }
      .bp3-control-group .bp3-input{
        border-radius:inherit;
        z-index:2; }
        .bp3-control-group .bp3-input:focus{
          border-radius:3px;
          z-index:14; }
        .bp3-control-group .bp3-input[class*="bp3-intent"]{
          z-index:13; }
          .bp3-control-group .bp3-input[class*="bp3-intent"]:focus{
            z-index:15; }
        .bp3-control-group .bp3-input[readonly], .bp3-control-group .bp3-input:disabled, .bp3-control-group .bp3-input.bp3-disabled{
          z-index:1; }
      .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input{
        z-index:13; }
        .bp3-control-group .bp3-input-group[class*="bp3-intent"] .bp3-input:focus{
          z-index:15; }
      .bp3-control-group .bp3-button,
      .bp3-control-group .bp3-html-select select,
      .bp3-control-group .bp3-select select{
        -webkit-transform:translateZ(0);
                transform:translateZ(0);
        border-radius:inherit;
        z-index:4; }
        .bp3-control-group .bp3-button:focus,
        .bp3-control-group .bp3-html-select select:focus,
        .bp3-control-group .bp3-select select:focus{
          z-index:5; }
        .bp3-control-group .bp3-button:hover,
        .bp3-control-group .bp3-html-select select:hover,
        .bp3-control-group .bp3-select select:hover{
          z-index:6; }
        .bp3-control-group .bp3-button:active,
        .bp3-control-group .bp3-html-select select:active,
        .bp3-control-group .bp3-select select:active{
          z-index:7; }
        .bp3-control-group .bp3-button[readonly], .bp3-control-group .bp3-button:disabled, .bp3-control-group .bp3-button.bp3-disabled,
        .bp3-control-group .bp3-html-select select[readonly],
        .bp3-control-group .bp3-html-select select:disabled,
        .bp3-control-group .bp3-html-select select.bp3-disabled,
        .bp3-control-group .bp3-select select[readonly],
        .bp3-control-group .bp3-select select:disabled,
        .bp3-control-group .bp3-select select.bp3-disabled{
          z-index:3; }
        .bp3-control-group .bp3-button[class*="bp3-intent"],
        .bp3-control-group .bp3-html-select select[class*="bp3-intent"],
        .bp3-control-group .bp3-select select[class*="bp3-intent"]{
          z-index:9; }
          .bp3-control-group .bp3-button[class*="bp3-intent"]:focus,
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:focus,
          .bp3-control-group .bp3-select select[class*="bp3-intent"]:focus{
            z-index:10; }
          .bp3-control-group .bp3-button[class*="bp3-intent"]:hover,
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:hover,
          .bp3-control-group .bp3-select select[class*="bp3-intent"]:hover{
            z-index:11; }
          .bp3-control-group .bp3-button[class*="bp3-intent"]:active,
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:active,
          .bp3-control-group .bp3-select select[class*="bp3-intent"]:active{
            z-index:12; }
          .bp3-control-group .bp3-button[class*="bp3-intent"][readonly], .bp3-control-group .bp3-button[class*="bp3-intent"]:disabled, .bp3-control-group .bp3-button[class*="bp3-intent"].bp3-disabled,
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"][readonly],
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"]:disabled,
          .bp3-control-group .bp3-html-select select[class*="bp3-intent"].bp3-disabled,
          .bp3-control-group .bp3-select select[class*="bp3-intent"][readonly],
          .bp3-control-group .bp3-select select[class*="bp3-intent"]:disabled,
          .bp3-control-group .bp3-select select[class*="bp3-intent"].bp3-disabled{
            z-index:8; }
      .bp3-control-group .bp3-input-group > .bp3-icon,
      .bp3-control-group .bp3-input-group > .bp3-button,
      .bp3-control-group .bp3-input-group > .bp3-input-left-container,
      .bp3-control-group .bp3-input-group > .bp3-input-action{
        z-index:16; }
      .bp3-control-group .bp3-select::after,
      .bp3-control-group .bp3-html-select::after,
      .bp3-control-group .bp3-select > .bp3-icon,
      .bp3-control-group .bp3-html-select > .bp3-icon{
        z-index:17; }
      .bp3-control-group .bp3-select:focus-within{
        z-index:5; }
      .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){
        margin-right:-1px; }
      .bp3-control-group:not(.bp3-vertical) > .bp3-divider:not(:first-child){
        margin-left:6px; }
      .bp3-dark .bp3-control-group:not(.bp3-vertical) > *:not(.bp3-divider){
        margin-right:0; }
      .bp3-dark .bp3-control-group:not(.bp3-vertical) > .bp3-button + .bp3-button{
        margin-left:1px; }
      .bp3-control-group .bp3-popover-wrapper,
      .bp3-control-group .bp3-popover-target{
        border-radius:inherit; }
      .bp3-control-group > :first-child{
        border-radius:3px 0 0 3px; }
      .bp3-control-group > :last-child{
        border-radius:0 3px 3px 0;
        margin-right:0; }
      .bp3-control-group > :only-child{
        border-radius:3px;
        margin-right:0; }
      .bp3-control-group .bp3-input-group .bp3-button{
        border-radius:3px; }
      .bp3-control-group .bp3-numeric-input:not(:first-child) .bp3-input-group{
        border-bottom-left-radius:0;
        border-top-left-radius:0; }
      .bp3-control-group.bp3-fill{
        width:100%; }
      .bp3-control-group > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto; }
      .bp3-control-group.bp3-fill > *:not(.bp3-fixed){
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto; }
      .bp3-control-group.bp3-vertical{
        -webkit-box-orient:vertical;
        -webkit-box-direction:normal;
            -ms-flex-direction:column;
                flex-direction:column; }
        .bp3-control-group.bp3-vertical > *{
          margin-top:-1px; }
        .bp3-control-group.bp3-vertical > :first-child{
          border-radius:3px 3px 0 0;
          margin-top:0; }
        .bp3-control-group.bp3-vertical > :last-child{
          border-radius:0 0 3px 3px; }
    .bp3-control{
      cursor:pointer;
      display:block;
      margin-bottom:10px;
      position:relative;
      text-transform:none; }
      .bp3-control input:checked ~ .bp3-control-indicator{
        background-color:#137cbd;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
      .bp3-control:hover input:checked ~ .bp3-control-indicator{
        background-color:#106ba3;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
      .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
        background:#0e5a8a;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-control input:disabled:checked ~ .bp3-control-indicator{
        background:rgba(19, 124, 189, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-control input:checked ~ .bp3-control-indicator{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control:hover input:checked ~ .bp3-control-indicator{
        background-color:#106ba3;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control input:not(:disabled):active:checked ~ .bp3-control-indicator{
        background-color:#0e5a8a;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-control input:disabled:checked ~ .bp3-control-indicator{
        background:rgba(14, 90, 138, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-control:not(.bp3-align-right){
        padding-left:26px; }
        .bp3-control:not(.bp3-align-right) .bp3-control-indicator{
          margin-left:-26px; }
      .bp3-control.bp3-align-right{
        padding-right:26px; }
        .bp3-control.bp3-align-right .bp3-control-indicator{
          margin-right:-26px; }
      .bp3-control.bp3-disabled{
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed; }
      .bp3-control.bp3-inline{
        display:inline-block;
        margin-right:20px; }
      .bp3-control input{
        left:0;
        opacity:0;
        position:absolute;
        top:0;
        z-index:-1; }
      .bp3-control .bp3-control-indicator{
        background-clip:padding-box;
        background-color:#f5f8fa;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
        border:none;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
        cursor:pointer;
        display:inline-block;
        font-size:16px;
        height:1em;
        margin-right:10px;
        margin-top:-3px;
        position:relative;
        -webkit-user-select:none;
           -moz-user-select:none;
            -ms-user-select:none;
                user-select:none;
        vertical-align:middle;
        width:1em; }
        .bp3-control .bp3-control-indicator::before{
          content:"";
          display:block;
          height:1em;
          width:1em; }
      .bp3-control:hover .bp3-control-indicator{
        background-color:#ebf1f5; }
      .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
        background:#d8e1e8;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-control input:disabled ~ .bp3-control-indicator{
        background:rgba(206, 217, 224, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none;
        cursor:not-allowed; }
      .bp3-control input:focus ~ .bp3-control-indicator{
        outline:rgba(19, 124, 189, 0.6) auto 2px;
        outline-offset:2px;
        -moz-outline-radius:6px; }
      .bp3-control.bp3-align-right .bp3-control-indicator{
        float:right;
        margin-left:10px;
        margin-top:1px; }
      .bp3-control.bp3-large{
        font-size:16px; }
        .bp3-control.bp3-large:not(.bp3-align-right){
          padding-left:30px; }
          .bp3-control.bp3-large:not(.bp3-align-right) .bp3-control-indicator{
            margin-left:-30px; }
        .bp3-control.bp3-large.bp3-align-right{
          padding-right:30px; }
          .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{
            margin-right:-30px; }
        .bp3-control.bp3-large .bp3-control-indicator{
          font-size:20px; }
        .bp3-control.bp3-large.bp3-align-right .bp3-control-indicator{
          margin-top:0; }
      .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{
        background-color:#137cbd;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.1)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
        color:#ffffff; }
      .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{
        background-color:#106ba3;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 -1px 0 rgba(16, 22, 26, 0.2); }
      .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
        background:#0e5a8a;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
        background:rgba(19, 124, 189, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-dark .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control.bp3-checkbox:hover input:indeterminate ~ .bp3-control-indicator{
        background-color:#106ba3;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control.bp3-checkbox input:not(:disabled):active:indeterminate ~ .bp3-control-indicator{
        background-color:#0e5a8a;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
        background:rgba(14, 90, 138, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-control.bp3-checkbox .bp3-control-indicator{
        border-radius:3px; }
      .bp3-control.bp3-checkbox input:checked ~ .bp3-control-indicator::before{
        background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M12 5c-.28 0-.53.11-.71.29L7 9.59l-2.29-2.3a1.003 1.003 0 00-1.42 1.42l3 3c.18.18.43.29.71.29s.53-.11.71-.29l5-5A1.003 1.003 0 0012 5z' fill='white'/%3e%3c/svg%3e"); }
      .bp3-control.bp3-checkbox input:indeterminate ~ .bp3-control-indicator::before{
        background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M11 7H5c-.55 0-1 .45-1 1s.45 1 1 1h6c.55 0 1-.45 1-1s-.45-1-1-1z' fill='white'/%3e%3c/svg%3e"); }
      .bp3-control.bp3-radio .bp3-control-indicator{
        border-radius:50%; }
      .bp3-control.bp3-radio input:checked ~ .bp3-control-indicator::before{
        background-image:radial-gradient(#ffffff, #ffffff 28%, transparent 32%); }
      .bp3-control.bp3-radio input:checked:disabled ~ .bp3-control-indicator::before{
        opacity:0.5; }
      .bp3-control.bp3-radio input:focus ~ .bp3-control-indicator{
        -moz-outline-radius:16px; }
      .bp3-control.bp3-switch input ~ .bp3-control-indicator{
        background:rgba(167, 182, 194, 0.5); }
      .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{
        background:rgba(115, 134, 148, 0.5); }
      .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{
        background:rgba(92, 112, 128, 0.5); }
      .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{
        background:rgba(206, 217, 224, 0.5); }
        .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{
          background:rgba(255, 255, 255, 0.8); }
      .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{
        background:#137cbd; }
      .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{
        background:#106ba3; }
      .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{
        background:#0e5a8a; }
      .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{
        background:rgba(19, 124, 189, 0.5); }
        .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{
          background:rgba(255, 255, 255, 0.8); }
      .bp3-control.bp3-switch:not(.bp3-align-right){
        padding-left:38px; }
        .bp3-control.bp3-switch:not(.bp3-align-right) .bp3-control-indicator{
          margin-left:-38px; }
      .bp3-control.bp3-switch.bp3-align-right{
        padding-right:38px; }
        .bp3-control.bp3-switch.bp3-align-right .bp3-control-indicator{
          margin-right:-38px; }
      .bp3-control.bp3-switch .bp3-control-indicator{
        border:none;
        border-radius:1.75em;
        -webkit-box-shadow:none !important;
                box-shadow:none !important;
        min-width:1.75em;
        -webkit-transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:background-color 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
        width:auto; }
        .bp3-control.bp3-switch .bp3-control-indicator::before{
          background:#ffffff;
          border-radius:50%;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
          height:calc(1em - 4px);
          left:0;
          margin:2px;
          position:absolute;
          -webkit-transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
          transition:left 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
          width:calc(1em - 4px); }
      .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{
        left:calc(100% - 1em); }
      .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right){
        padding-left:45px; }
        .bp3-control.bp3-switch.bp3-large:not(.bp3-align-right) .bp3-control-indicator{
          margin-left:-45px; }
      .bp3-control.bp3-switch.bp3-large.bp3-align-right{
        padding-right:45px; }
        .bp3-control.bp3-switch.bp3-large.bp3-align-right .bp3-control-indicator{
          margin-right:-45px; }
      .bp3-dark .bp3-control.bp3-switch input ~ .bp3-control-indicator{
        background:rgba(16, 22, 26, 0.5); }
      .bp3-dark .bp3-control.bp3-switch:hover input ~ .bp3-control-indicator{
        background:rgba(16, 22, 26, 0.7); }
      .bp3-dark .bp3-control.bp3-switch input:not(:disabled):active ~ .bp3-control-indicator{
        background:rgba(16, 22, 26, 0.9); }
      .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator{
        background:rgba(57, 75, 89, 0.5); }
        .bp3-dark .bp3-control.bp3-switch input:disabled ~ .bp3-control-indicator::before{
          background:rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator{
        background:#137cbd; }
      .bp3-dark .bp3-control.bp3-switch:hover input:checked ~ .bp3-control-indicator{
        background:#106ba3; }
      .bp3-dark .bp3-control.bp3-switch input:checked:not(:disabled):active ~ .bp3-control-indicator{
        background:#0e5a8a; }
      .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator{
        background:rgba(14, 90, 138, 0.5); }
        .bp3-dark .bp3-control.bp3-switch input:checked:disabled ~ .bp3-control-indicator::before{
          background:rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control.bp3-switch .bp3-control-indicator::before{
        background:#394b59;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator::before{
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-control.bp3-switch .bp3-switch-inner-text{
        font-size:0.7em;
        text-align:center; }
      .bp3-control.bp3-switch .bp3-control-indicator-child:first-child{
        line-height:0;
        margin-left:0.5em;
        margin-right:1.2em;
        visibility:hidden; }
      .bp3-control.bp3-switch .bp3-control-indicator-child:last-child{
        line-height:1em;
        margin-left:1.2em;
        margin-right:0.5em;
        visibility:visible; }
      .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:first-child{
        line-height:1em;
        visibility:visible; }
      .bp3-control.bp3-switch input:checked ~ .bp3-control-indicator .bp3-control-indicator-child:last-child{
        line-height:0;
        visibility:hidden; }
      .bp3-dark .bp3-control{
        color:#f5f8fa; }
        .bp3-dark .bp3-control.bp3-disabled{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-control .bp3-control-indicator{
          background-color:#394b59;
          background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
          background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-control:hover .bp3-control-indicator{
          background-color:#30404d; }
        .bp3-dark .bp3-control input:not(:disabled):active ~ .bp3-control-indicator{
          background:#202b33;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-dark .bp3-control input:disabled ~ .bp3-control-indicator{
          background:rgba(57, 75, 89, 0.5);
          -webkit-box-shadow:none;
                  box-shadow:none;
          cursor:not-allowed; }
        .bp3-dark .bp3-control.bp3-checkbox input:disabled:checked ~ .bp3-control-indicator, .bp3-dark .bp3-control.bp3-checkbox input:disabled:indeterminate ~ .bp3-control-indicator{
          color:rgba(167, 182, 194, 0.6); }
    .bp3-file-input{
      cursor:pointer;
      display:inline-block;
      height:30px;
      position:relative; }
      .bp3-file-input input{
        margin:0;
        min-width:200px;
        opacity:0; }
        .bp3-file-input input:disabled + .bp3-file-upload-input,
        .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{
          background:rgba(206, 217, 224, 0.5);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed;
          resize:none; }
          .bp3-file-input input:disabled + .bp3-file-upload-input::after,
          .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{
            background-color:rgba(206, 217, 224, 0.5);
            background-image:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:rgba(92, 112, 128, 0.6);
            cursor:not-allowed;
            outline:none; }
            .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active:hover,
            .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active,
            .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active:hover{
              background:rgba(206, 217, 224, 0.7); }
          .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input, .bp3-dark
          .bp3-file-input input.bp3-disabled + .bp3-file-upload-input{
            background:rgba(57, 75, 89, 0.5);
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:rgba(167, 182, 194, 0.6); }
            .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after, .bp3-dark
            .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after{
              background-color:rgba(57, 75, 89, 0.5);
              background-image:none;
              -webkit-box-shadow:none;
                      box-shadow:none;
              color:rgba(167, 182, 194, 0.6); }
              .bp3-dark .bp3-file-input input:disabled + .bp3-file-upload-input::after.bp3-active, .bp3-dark
              .bp3-file-input input.bp3-disabled + .bp3-file-upload-input::after.bp3-active{
                background:rgba(57, 75, 89, 0.7); }
      .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{
        color:#182026; }
      .bp3-dark .bp3-file-input.bp3-file-input-has-selection .bp3-file-upload-input{
        color:#f5f8fa; }
      .bp3-file-input.bp3-fill{
        width:100%; }
      .bp3-file-input.bp3-large,
      .bp3-large .bp3-file-input{
        height:40px; }
      .bp3-file-input .bp3-file-upload-input-custom-text::after{
        content:attr(bp3-button-text); }
    
    .bp3-file-upload-input{
      -webkit-appearance:none;
         -moz-appearance:none;
              appearance:none;
      background:#ffffff;
      border:none;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
      color:#182026;
      font-size:14px;
      font-weight:400;
      height:30px;
      line-height:30px;
      outline:none;
      padding:0 10px;
      -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      vertical-align:middle;
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
      word-wrap:normal;
      color:rgba(92, 112, 128, 0.6);
      left:0;
      padding-right:80px;
      position:absolute;
      right:0;
      top:0;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-file-upload-input::-webkit-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-file-upload-input::-moz-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-file-upload-input:-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-file-upload-input::-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-file-upload-input::placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-file-upload-input:focus, .bp3-file-upload-input.bp3-active{
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-file-upload-input[type="search"], .bp3-file-upload-input.bp3-round{
        border-radius:30px;
        -webkit-box-sizing:border-box;
                box-sizing:border-box;
        padding-left:10px; }
      .bp3-file-upload-input[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
      .bp3-file-upload-input:disabled, .bp3-file-upload-input.bp3-disabled{
        background:rgba(206, 217, 224, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed;
        resize:none; }
      .bp3-file-upload-input::after{
        background-color:#f5f8fa;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
        color:#182026;
        min-height:24px;
        min-width:24px;
        overflow:hidden;
        text-overflow:ellipsis;
        white-space:nowrap;
        word-wrap:normal;
        border-radius:3px;
        content:"Browse";
        line-height:24px;
        margin:3px;
        position:absolute;
        right:0;
        text-align:center;
        top:0;
        width:70px; }
        .bp3-file-upload-input::after:hover{
          background-clip:padding-box;
          background-color:#ebf1f5;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
        .bp3-file-upload-input::after:active, .bp3-file-upload-input::after.bp3-active{
          background-color:#d8e1e8;
          background-image:none;
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-file-upload-input::after:disabled, .bp3-file-upload-input::after.bp3-disabled{
          background-color:rgba(206, 217, 224, 0.5);
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(92, 112, 128, 0.6);
          cursor:not-allowed;
          outline:none; }
          .bp3-file-upload-input::after:disabled.bp3-active, .bp3-file-upload-input::after:disabled.bp3-active:hover, .bp3-file-upload-input::after.bp3-disabled.bp3-active, .bp3-file-upload-input::after.bp3-disabled.bp3-active:hover{
            background:rgba(206, 217, 224, 0.7); }
      .bp3-file-upload-input:hover::after{
        background-clip:padding-box;
        background-color:#ebf1f5;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
      .bp3-file-upload-input:active::after{
        background-color:#d8e1e8;
        background-image:none;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-large .bp3-file-upload-input{
        font-size:16px;
        height:40px;
        line-height:40px;
        padding-right:95px; }
        .bp3-large .bp3-file-upload-input[type="search"], .bp3-large .bp3-file-upload-input.bp3-round{
          padding:0 15px; }
        .bp3-large .bp3-file-upload-input::after{
          min-height:30px;
          min-width:30px;
          line-height:30px;
          margin:5px;
          width:85px; }
      .bp3-dark .bp3-file-upload-input{
        background:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa;
        color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::-webkit-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::-moz-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input:-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input:focus{
          -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-file-upload-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-file-upload-input:disabled, .bp3-dark .bp3-file-upload-input.bp3-disabled{
          background:rgba(57, 75, 89, 0.5);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-file-upload-input::after{
          background-color:#394b59;
          background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
          background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
          color:#f5f8fa; }
          .bp3-dark .bp3-file-upload-input::after:hover, .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{
            color:#f5f8fa; }
          .bp3-dark .bp3-file-upload-input::after:hover{
            background-color:#30404d;
            -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                    box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-file-upload-input::after:active, .bp3-dark .bp3-file-upload-input::after.bp3-active{
            background-color:#202b33;
            background-image:none;
            -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                    box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
          .bp3-dark .bp3-file-upload-input::after:disabled, .bp3-dark .bp3-file-upload-input::after.bp3-disabled{
            background-color:rgba(57, 75, 89, 0.5);
            background-image:none;
            -webkit-box-shadow:none;
                    box-shadow:none;
            color:rgba(167, 182, 194, 0.6); }
            .bp3-dark .bp3-file-upload-input::after:disabled.bp3-active, .bp3-dark .bp3-file-upload-input::after.bp3-disabled.bp3-active{
              background:rgba(57, 75, 89, 0.7); }
          .bp3-dark .bp3-file-upload-input::after .bp3-button-spinner .bp3-spinner-head{
            background:rgba(16, 22, 26, 0.5);
            stroke:#8a9ba8; }
        .bp3-dark .bp3-file-upload-input:hover::after{
          background-color:#30404d;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-file-upload-input:active::after{
          background-color:#202b33;
          background-image:none;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
    .bp3-file-upload-input::after{
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
    .bp3-form-group{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      margin:0 0 15px; }
      .bp3-form-group label.bp3-label{
        margin-bottom:5px; }
      .bp3-form-group .bp3-control{
        margin-top:7px; }
      .bp3-form-group .bp3-form-helper-text{
        color:#5c7080;
        font-size:12px;
        margin-top:5px; }
      .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{
        color:#106ba3; }
      .bp3-form-group.bp3-intent-success .bp3-form-helper-text{
        color:#0d8050; }
      .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{
        color:#bf7326; }
      .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{
        color:#c23030; }
      .bp3-form-group.bp3-inline{
        -webkit-box-align:start;
            -ms-flex-align:start;
                align-items:flex-start;
        -webkit-box-orient:horizontal;
        -webkit-box-direction:normal;
            -ms-flex-direction:row;
                flex-direction:row; }
        .bp3-form-group.bp3-inline.bp3-large label.bp3-label{
          line-height:40px;
          margin:0 10px 0 0; }
        .bp3-form-group.bp3-inline label.bp3-label{
          line-height:30px;
          margin:0 10px 0 0; }
      .bp3-form-group.bp3-disabled .bp3-label,
      .bp3-form-group.bp3-disabled .bp3-text-muted,
      .bp3-form-group.bp3-disabled .bp3-form-helper-text{
        color:rgba(92, 112, 128, 0.6) !important; }
      .bp3-dark .bp3-form-group.bp3-intent-primary .bp3-form-helper-text{
        color:#48aff0; }
      .bp3-dark .bp3-form-group.bp3-intent-success .bp3-form-helper-text{
        color:#3dcc91; }
      .bp3-dark .bp3-form-group.bp3-intent-warning .bp3-form-helper-text{
        color:#ffb366; }
      .bp3-dark .bp3-form-group.bp3-intent-danger .bp3-form-helper-text{
        color:#ff7373; }
      .bp3-dark .bp3-form-group .bp3-form-helper-text{
        color:#a7b6c2; }
      .bp3-dark .bp3-form-group.bp3-disabled .bp3-label,
      .bp3-dark .bp3-form-group.bp3-disabled .bp3-text-muted,
      .bp3-dark .bp3-form-group.bp3-disabled .bp3-form-helper-text{
        color:rgba(167, 182, 194, 0.6) !important; }
    .bp3-input-group{
      display:block;
      position:relative; }
      .bp3-input-group .bp3-input{
        position:relative;
        width:100%; }
        .bp3-input-group .bp3-input:not(:first-child){
          padding-left:30px; }
        .bp3-input-group .bp3-input:not(:last-child){
          padding-right:30px; }
      .bp3-input-group .bp3-input-action,
      .bp3-input-group > .bp3-input-left-container,
      .bp3-input-group > .bp3-button,
      .bp3-input-group > .bp3-icon{
        position:absolute;
        top:0; }
        .bp3-input-group .bp3-input-action:first-child,
        .bp3-input-group > .bp3-input-left-container:first-child,
        .bp3-input-group > .bp3-button:first-child,
        .bp3-input-group > .bp3-icon:first-child{
          left:0; }
        .bp3-input-group .bp3-input-action:last-child,
        .bp3-input-group > .bp3-input-left-container:last-child,
        .bp3-input-group > .bp3-button:last-child,
        .bp3-input-group > .bp3-icon:last-child{
          right:0; }
      .bp3-input-group .bp3-button{
        min-height:24px;
        min-width:24px;
        margin:3px;
        padding:0 7px; }
        .bp3-input-group .bp3-button:empty{
          padding:0; }
      .bp3-input-group > .bp3-input-left-container,
      .bp3-input-group > .bp3-icon{
        z-index:1; }
      .bp3-input-group > .bp3-input-left-container > .bp3-icon,
      .bp3-input-group > .bp3-icon{
        color:#5c7080; }
        .bp3-input-group > .bp3-input-left-container > .bp3-icon:empty,
        .bp3-input-group > .bp3-icon:empty{
          font-family:"Icons16", sans-serif;
          font-size:16px;
          font-style:normal;
          font-weight:400;
          line-height:1;
          -moz-osx-font-smoothing:grayscale;
          -webkit-font-smoothing:antialiased; }
      .bp3-input-group > .bp3-input-left-container > .bp3-icon,
      .bp3-input-group > .bp3-icon,
      .bp3-input-group .bp3-input-action > .bp3-spinner{
        margin:7px; }
      .bp3-input-group .bp3-tag{
        margin:5px; }
      .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus),
      .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){
        color:#5c7080; }
        .bp3-dark .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus), .bp3-dark
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus){
          color:#a7b6c2; }
        .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-standard,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:not(:hover):not(:focus) .bp3-icon-large{
          color:#5c7080; }
      .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled,
      .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled{
        color:rgba(92, 112, 128, 0.6) !important; }
        .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-standard, .bp3-input-group .bp3-input:not(:focus) + .bp3-button.bp3-minimal:disabled .bp3-icon-large,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-standard,
        .bp3-input-group .bp3-input:not(:focus) + .bp3-input-action .bp3-button.bp3-minimal:disabled .bp3-icon-large{
          color:rgba(92, 112, 128, 0.6) !important; }
      .bp3-input-group.bp3-disabled{
        cursor:not-allowed; }
        .bp3-input-group.bp3-disabled .bp3-icon{
          color:rgba(92, 112, 128, 0.6); }
      .bp3-input-group.bp3-large .bp3-button{
        min-height:30px;
        min-width:30px;
        margin:5px; }
      .bp3-input-group.bp3-large > .bp3-input-left-container > .bp3-icon,
      .bp3-input-group.bp3-large > .bp3-icon,
      .bp3-input-group.bp3-large .bp3-input-action > .bp3-spinner{
        margin:12px; }
      .bp3-input-group.bp3-large .bp3-input{
        font-size:16px;
        height:40px;
        line-height:40px; }
        .bp3-input-group.bp3-large .bp3-input[type="search"], .bp3-input-group.bp3-large .bp3-input.bp3-round{
          padding:0 15px; }
        .bp3-input-group.bp3-large .bp3-input:not(:first-child){
          padding-left:40px; }
        .bp3-input-group.bp3-large .bp3-input:not(:last-child){
          padding-right:40px; }
      .bp3-input-group.bp3-small .bp3-button{
        min-height:20px;
        min-width:20px;
        margin:2px; }
      .bp3-input-group.bp3-small .bp3-tag{
        min-height:20px;
        min-width:20px;
        margin:2px; }
      .bp3-input-group.bp3-small > .bp3-input-left-container > .bp3-icon,
      .bp3-input-group.bp3-small > .bp3-icon,
      .bp3-input-group.bp3-small .bp3-input-action > .bp3-spinner{
        margin:4px; }
      .bp3-input-group.bp3-small .bp3-input{
        font-size:12px;
        height:24px;
        line-height:24px;
        padding-left:8px;
        padding-right:8px; }
        .bp3-input-group.bp3-small .bp3-input[type="search"], .bp3-input-group.bp3-small .bp3-input.bp3-round{
          padding:0 12px; }
        .bp3-input-group.bp3-small .bp3-input:not(:first-child){
          padding-left:24px; }
        .bp3-input-group.bp3-small .bp3-input:not(:last-child){
          padding-right:24px; }
      .bp3-input-group.bp3-fill{
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto;
        width:100%; }
      .bp3-input-group.bp3-round .bp3-button,
      .bp3-input-group.bp3-round .bp3-input,
      .bp3-input-group.bp3-round .bp3-tag{
        border-radius:30px; }
      .bp3-dark .bp3-input-group .bp3-icon{
        color:#a7b6c2; }
      .bp3-dark .bp3-input-group.bp3-disabled .bp3-icon{
        color:rgba(167, 182, 194, 0.6); }
      .bp3-input-group.bp3-intent-primary .bp3-input{
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-primary .bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-primary .bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #137cbd;
                  box-shadow:inset 0 0 0 1px #137cbd; }
        .bp3-input-group.bp3-intent-primary .bp3-input:disabled, .bp3-input-group.bp3-intent-primary .bp3-input.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-input-group.bp3-intent-primary > .bp3-icon{
        color:#106ba3; }
        .bp3-dark .bp3-input-group.bp3-intent-primary > .bp3-icon{
          color:#48aff0; }
      .bp3-input-group.bp3-intent-success .bp3-input{
        -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-success .bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-success .bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #0f9960;
                  box-shadow:inset 0 0 0 1px #0f9960; }
        .bp3-input-group.bp3-intent-success .bp3-input:disabled, .bp3-input-group.bp3-intent-success .bp3-input.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-input-group.bp3-intent-success > .bp3-icon{
        color:#0d8050; }
        .bp3-dark .bp3-input-group.bp3-intent-success > .bp3-icon{
          color:#3dcc91; }
      .bp3-input-group.bp3-intent-warning .bp3-input{
        -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-warning .bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-warning .bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #d9822b;
                  box-shadow:inset 0 0 0 1px #d9822b; }
        .bp3-input-group.bp3-intent-warning .bp3-input:disabled, .bp3-input-group.bp3-intent-warning .bp3-input.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-input-group.bp3-intent-warning > .bp3-icon{
        color:#bf7326; }
        .bp3-dark .bp3-input-group.bp3-intent-warning > .bp3-icon{
          color:#ffb366; }
      .bp3-input-group.bp3-intent-danger .bp3-input{
        -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-danger .bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input-group.bp3-intent-danger .bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #db3737;
                  box-shadow:inset 0 0 0 1px #db3737; }
        .bp3-input-group.bp3-intent-danger .bp3-input:disabled, .bp3-input-group.bp3-intent-danger .bp3-input.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-input-group.bp3-intent-danger > .bp3-icon{
        color:#c23030; }
        .bp3-dark .bp3-input-group.bp3-intent-danger > .bp3-icon{
          color:#ff7373; }
    .bp3-input{
      -webkit-appearance:none;
         -moz-appearance:none;
              appearance:none;
      background:#ffffff;
      border:none;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
      color:#182026;
      font-size:14px;
      font-weight:400;
      height:30px;
      line-height:30px;
      outline:none;
      padding:0 10px;
      -webkit-transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:-webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-box-shadow 100ms cubic-bezier(0.4, 1, 0.75, 0.9);
      vertical-align:middle; }
      .bp3-input::-webkit-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input::-moz-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input:-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input::-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input::placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input:focus, .bp3-input.bp3-active{
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-input[type="search"], .bp3-input.bp3-round{
        border-radius:30px;
        -webkit-box-sizing:border-box;
                box-sizing:border-box;
        padding-left:10px; }
      .bp3-input[readonly]{
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.15); }
      .bp3-input:disabled, .bp3-input.bp3-disabled{
        background:rgba(206, 217, 224, 0.5);
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed;
        resize:none; }
      .bp3-input.bp3-large{
        font-size:16px;
        height:40px;
        line-height:40px; }
        .bp3-input.bp3-large[type="search"], .bp3-input.bp3-large.bp3-round{
          padding:0 15px; }
      .bp3-input.bp3-small{
        font-size:12px;
        height:24px;
        line-height:24px;
        padding-left:8px;
        padding-right:8px; }
        .bp3-input.bp3-small[type="search"], .bp3-input.bp3-small.bp3-round{
          padding:0 12px; }
      .bp3-input.bp3-fill{
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto;
        width:100%; }
      .bp3-dark .bp3-input{
        background:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
        .bp3-dark .bp3-input::-webkit-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-input::-moz-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-input:-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-input::-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-input::placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-input:disabled, .bp3-dark .bp3-input.bp3-disabled{
          background:rgba(57, 75, 89, 0.5);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
      .bp3-input.bp3-intent-primary{
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-primary:focus{
          -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-primary[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #137cbd;
                  box-shadow:inset 0 0 0 1px #137cbd; }
        .bp3-input.bp3-intent-primary:disabled, .bp3-input.bp3-intent-primary.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
        .bp3-dark .bp3-input.bp3-intent-primary{
          -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px #137cbd, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-primary:focus{
            -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                    box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-primary[readonly]{
            -webkit-box-shadow:inset 0 0 0 1px #137cbd;
                    box-shadow:inset 0 0 0 1px #137cbd; }
          .bp3-dark .bp3-input.bp3-intent-primary:disabled, .bp3-dark .bp3-input.bp3-intent-primary.bp3-disabled{
            -webkit-box-shadow:none;
                    box-shadow:none; }
      .bp3-input.bp3-intent-success{
        -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-success:focus{
          -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-success[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #0f9960;
                  box-shadow:inset 0 0 0 1px #0f9960; }
        .bp3-input.bp3-intent-success:disabled, .bp3-input.bp3-intent-success.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
        .bp3-dark .bp3-input.bp3-intent-success{
          -webkit-box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), 0 0 0 0 rgba(15, 153, 96, 0), inset 0 0 0 1px #0f9960, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-success:focus{
            -webkit-box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                    box-shadow:0 0 0 1px #0f9960, 0 0 0 1px #0f9960, 0 0 0 3px rgba(15, 153, 96, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-success[readonly]{
            -webkit-box-shadow:inset 0 0 0 1px #0f9960;
                    box-shadow:inset 0 0 0 1px #0f9960; }
          .bp3-dark .bp3-input.bp3-intent-success:disabled, .bp3-dark .bp3-input.bp3-intent-success.bp3-disabled{
            -webkit-box-shadow:none;
                    box-shadow:none; }
      .bp3-input.bp3-intent-warning{
        -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-warning:focus{
          -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-warning[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #d9822b;
                  box-shadow:inset 0 0 0 1px #d9822b; }
        .bp3-input.bp3-intent-warning:disabled, .bp3-input.bp3-intent-warning.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
        .bp3-dark .bp3-input.bp3-intent-warning{
          -webkit-box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), 0 0 0 0 rgba(217, 130, 43, 0), inset 0 0 0 1px #d9822b, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-warning:focus{
            -webkit-box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                    box-shadow:0 0 0 1px #d9822b, 0 0 0 1px #d9822b, 0 0 0 3px rgba(217, 130, 43, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-warning[readonly]{
            -webkit-box-shadow:inset 0 0 0 1px #d9822b;
                    box-shadow:inset 0 0 0 1px #d9822b; }
          .bp3-dark .bp3-input.bp3-intent-warning:disabled, .bp3-dark .bp3-input.bp3-intent-warning.bp3-disabled{
            -webkit-box-shadow:none;
                    box-shadow:none; }
      .bp3-input.bp3-intent-danger{
        -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.15), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-danger:focus{
          -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-input.bp3-intent-danger[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px #db3737;
                  box-shadow:inset 0 0 0 1px #db3737; }
        .bp3-input.bp3-intent-danger:disabled, .bp3-input.bp3-intent-danger.bp3-disabled{
          -webkit-box-shadow:none;
                  box-shadow:none; }
        .bp3-dark .bp3-input.bp3-intent-danger{
          -webkit-box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), 0 0 0 0 rgba(219, 55, 55, 0), inset 0 0 0 1px #db3737, inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-danger:focus{
            -webkit-box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                    box-shadow:0 0 0 1px #db3737, 0 0 0 1px #db3737, 0 0 0 3px rgba(219, 55, 55, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
          .bp3-dark .bp3-input.bp3-intent-danger[readonly]{
            -webkit-box-shadow:inset 0 0 0 1px #db3737;
                    box-shadow:inset 0 0 0 1px #db3737; }
          .bp3-dark .bp3-input.bp3-intent-danger:disabled, .bp3-dark .bp3-input.bp3-intent-danger.bp3-disabled{
            -webkit-box-shadow:none;
                    box-shadow:none; }
      .bp3-input::-ms-clear{
        display:none; }
    textarea.bp3-input{
      max-width:100%;
      padding:10px; }
      textarea.bp3-input, textarea.bp3-input.bp3-large, textarea.bp3-input.bp3-small{
        height:auto;
        line-height:inherit; }
      textarea.bp3-input.bp3-small{
        padding:8px; }
      .bp3-dark textarea.bp3-input{
        background:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), 0 0 0 0 rgba(19, 124, 189, 0), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
        .bp3-dark textarea.bp3-input::-webkit-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark textarea.bp3-input::-moz-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark textarea.bp3-input:-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark textarea.bp3-input::-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark textarea.bp3-input::placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark textarea.bp3-input:focus{
          -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark textarea.bp3-input[readonly]{
          -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark textarea.bp3-input:disabled, .bp3-dark textarea.bp3-input.bp3-disabled{
          background:rgba(57, 75, 89, 0.5);
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
    label.bp3-label{
      display:block;
      margin-bottom:15px;
      margin-top:0; }
      label.bp3-label .bp3-html-select,
      label.bp3-label .bp3-input,
      label.bp3-label .bp3-select,
      label.bp3-label .bp3-slider,
      label.bp3-label .bp3-popover-wrapper{
        display:block;
        margin-top:5px;
        text-transform:none; }
      label.bp3-label .bp3-button-group{
        margin-top:5px; }
      label.bp3-label .bp3-select select,
      label.bp3-label .bp3-html-select select{
        font-weight:400;
        vertical-align:top;
        width:100%; }
      label.bp3-label.bp3-disabled,
      label.bp3-label.bp3-disabled .bp3-text-muted{
        color:rgba(92, 112, 128, 0.6); }
      label.bp3-label.bp3-inline{
        line-height:30px; }
        label.bp3-label.bp3-inline .bp3-html-select,
        label.bp3-label.bp3-inline .bp3-input,
        label.bp3-label.bp3-inline .bp3-input-group,
        label.bp3-label.bp3-inline .bp3-select,
        label.bp3-label.bp3-inline .bp3-popover-wrapper{
          display:inline-block;
          margin:0 0 0 5px;
          vertical-align:top; }
        label.bp3-label.bp3-inline .bp3-button-group{
          margin:0 0 0 5px; }
        label.bp3-label.bp3-inline .bp3-input-group .bp3-input{
          margin-left:0; }
        label.bp3-label.bp3-inline.bp3-large{
          line-height:40px; }
      label.bp3-label:not(.bp3-inline) .bp3-popover-target{
        display:block; }
      .bp3-dark label.bp3-label{
        color:#f5f8fa; }
        .bp3-dark label.bp3-label.bp3-disabled,
        .bp3-dark label.bp3-label.bp3-disabled .bp3-text-muted{
          color:rgba(167, 182, 194, 0.6); }
    .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button{
      -webkit-box-flex:1;
          -ms-flex:1 1 14px;
              flex:1 1 14px;
      min-height:0;
      padding:0;
      width:30px; }
      .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:first-child{
        border-radius:0 3px 0 0; }
      .bp3-numeric-input .bp3-button-group.bp3-vertical > .bp3-button:last-child{
        border-radius:0 0 3px 0; }
    
    .bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:first-child{
      border-radius:3px 0 0 0; }
    
    .bp3-numeric-input .bp3-button-group.bp3-vertical:first-child > .bp3-button:last-child{
      border-radius:0 0 0 3px; }
    
    .bp3-numeric-input.bp3-large .bp3-button-group.bp3-vertical > .bp3-button{
      width:40px; }
    
    form{
      display:block; }
    .bp3-html-select select,
    .bp3-select select{
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      border:none;
      border-radius:3px;
      cursor:pointer;
      font-size:14px;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      padding:5px 10px;
      text-align:left;
      vertical-align:middle;
      background-color:#f5f8fa;
      background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
      background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
      color:#182026;
      -moz-appearance:none;
      -webkit-appearance:none;
      border-radius:3px;
      height:30px;
      padding:0 25px 0 10px;
      width:100%; }
      .bp3-html-select select > *, .bp3-select select > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-html-select select > .bp3-fill, .bp3-select select > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-html-select select::before,
      .bp3-select select::before, .bp3-html-select select > *, .bp3-select select > *{
        margin-right:7px; }
      .bp3-html-select select:empty::before,
      .bp3-select select:empty::before,
      .bp3-html-select select > :last-child,
      .bp3-select select > :last-child{
        margin-right:0; }
      .bp3-html-select select:hover,
      .bp3-select select:hover{
        background-clip:padding-box;
        background-color:#ebf1f5;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
      .bp3-html-select select:active,
      .bp3-select select:active, .bp3-html-select select.bp3-active,
      .bp3-select select.bp3-active{
        background-color:#d8e1e8;
        background-image:none;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-html-select select:disabled,
      .bp3-select select:disabled, .bp3-html-select select.bp3-disabled,
      .bp3-select select.bp3-disabled{
        background-color:rgba(206, 217, 224, 0.5);
        background-image:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed;
        outline:none; }
        .bp3-html-select select:disabled.bp3-active,
        .bp3-select select:disabled.bp3-active, .bp3-html-select select:disabled.bp3-active:hover,
        .bp3-select select:disabled.bp3-active:hover, .bp3-html-select select.bp3-disabled.bp3-active,
        .bp3-select select.bp3-disabled.bp3-active, .bp3-html-select select.bp3-disabled.bp3-active:hover,
        .bp3-select select.bp3-disabled.bp3-active:hover{
          background:rgba(206, 217, 224, 0.7); }
    
    .bp3-html-select.bp3-minimal select,
    .bp3-select.bp3-minimal select{
      background:none;
      -webkit-box-shadow:none;
              box-shadow:none; }
      .bp3-html-select.bp3-minimal select:hover,
      .bp3-select.bp3-minimal select:hover{
        background:rgba(167, 182, 194, 0.3);
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#182026;
        text-decoration:none; }
      .bp3-html-select.bp3-minimal select:active,
      .bp3-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal select.bp3-active,
      .bp3-select.bp3-minimal select.bp3-active{
        background:rgba(115, 134, 148, 0.3);
        -webkit-box-shadow:none;
                box-shadow:none;
        color:#182026; }
      .bp3-html-select.bp3-minimal select:disabled,
      .bp3-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal select:disabled:hover,
      .bp3-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal select.bp3-disabled,
      .bp3-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal select.bp3-disabled:hover,
      .bp3-select.bp3-minimal select.bp3-disabled:hover{
        background:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed; }
        .bp3-html-select.bp3-minimal select:disabled.bp3-active,
        .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active,
        .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active,
        .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active,
        .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active{
          background:rgba(115, 134, 148, 0.3); }
      .bp3-dark .bp3-html-select.bp3-minimal select, .bp3-html-select.bp3-minimal .bp3-dark select,
      .bp3-dark .bp3-select.bp3-minimal select, .bp3-select.bp3-minimal .bp3-dark select{
        background:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:inherit; }
        .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover,
        .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover, .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active,
        .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none; }
        .bp3-dark .bp3-html-select.bp3-minimal select:hover, .bp3-html-select.bp3-minimal .bp3-dark select:hover,
        .bp3-dark .bp3-select.bp3-minimal select:hover, .bp3-select.bp3-minimal .bp3-dark select:hover{
          background:rgba(138, 155, 168, 0.15); }
        .bp3-dark .bp3-html-select.bp3-minimal select:active, .bp3-html-select.bp3-minimal .bp3-dark select:active,
        .bp3-dark .bp3-select.bp3-minimal select:active, .bp3-select.bp3-minimal .bp3-dark select:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-active,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-active{
          background:rgba(138, 155, 168, 0.3);
          color:#f5f8fa; }
        .bp3-dark .bp3-html-select.bp3-minimal select:disabled, .bp3-html-select.bp3-minimal .bp3-dark select:disabled,
        .bp3-dark .bp3-select.bp3-minimal select:disabled, .bp3-select.bp3-minimal .bp3-dark select:disabled, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover,
        .bp3-dark .bp3-select.bp3-minimal select:disabled:hover, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover{
          background:none;
          color:rgba(167, 182, 194, 0.6);
          cursor:not-allowed; }
          .bp3-dark .bp3-html-select.bp3-minimal select:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select:disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select:disabled:hover.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-disabled:hover.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-disabled:hover.bp3-active{
            background:rgba(138, 155, 168, 0.3); }
      .bp3-html-select.bp3-minimal select.bp3-intent-primary,
      .bp3-select.bp3-minimal select.bp3-intent-primary{
        color:#106ba3; }
        .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover,
        .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal select.bp3-intent-primary:active,
        .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#106ba3; }
        .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover,
        .bp3-select.bp3-minimal select.bp3-intent-primary:hover{
          background:rgba(19, 124, 189, 0.15);
          color:#106ba3; }
        .bp3-html-select.bp3-minimal select.bp3-intent-primary:active,
        .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active{
          background:rgba(19, 124, 189, 0.3);
          color:#106ba3; }
        .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled,
        .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled,
        .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled{
          background:none;
          color:rgba(16, 107, 163, 0.5); }
          .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active{
            background:rgba(19, 124, 189, 0.3); }
        .bp3-html-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-primary .bp3-button-spinner .bp3-spinner-head{
          stroke:#106ba3; }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary{
          color:#48aff0; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:hover{
            background:rgba(19, 124, 189, 0.2);
            color:#48aff0; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-active{
            background:rgba(19, 124, 189, 0.3);
            color:#48aff0; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled{
            background:none;
            color:rgba(72, 175, 240, 0.5); }
            .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-primary.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-primary.bp3-disabled.bp3-active{
              background:rgba(19, 124, 189, 0.3); }
      .bp3-html-select.bp3-minimal select.bp3-intent-success,
      .bp3-select.bp3-minimal select.bp3-intent-success{
        color:#0d8050; }
        .bp3-html-select.bp3-minimal select.bp3-intent-success:hover,
        .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal select.bp3-intent-success:active,
        .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#0d8050; }
        .bp3-html-select.bp3-minimal select.bp3-intent-success:hover,
        .bp3-select.bp3-minimal select.bp3-intent-success:hover{
          background:rgba(15, 153, 96, 0.15);
          color:#0d8050; }
        .bp3-html-select.bp3-minimal select.bp3-intent-success:active,
        .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active{
          background:rgba(15, 153, 96, 0.3);
          color:#0d8050; }
        .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled,
        .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled,
        .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled{
          background:none;
          color:rgba(13, 128, 80, 0.5); }
          .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active{
            background:rgba(15, 153, 96, 0.3); }
        .bp3-html-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-success .bp3-button-spinner .bp3-spinner-head{
          stroke:#0d8050; }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success{
          color:#3dcc91; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:hover{
            background:rgba(15, 153, 96, 0.2);
            color:#3dcc91; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-active{
            background:rgba(15, 153, 96, 0.3);
            color:#3dcc91; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled{
            background:none;
            color:rgba(61, 204, 145, 0.5); }
            .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-success.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-success.bp3-disabled.bp3-active{
              background:rgba(15, 153, 96, 0.3); }
      .bp3-html-select.bp3-minimal select.bp3-intent-warning,
      .bp3-select.bp3-minimal select.bp3-intent-warning{
        color:#bf7326; }
        .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover,
        .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal select.bp3-intent-warning:active,
        .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#bf7326; }
        .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover,
        .bp3-select.bp3-minimal select.bp3-intent-warning:hover{
          background:rgba(217, 130, 43, 0.15);
          color:#bf7326; }
        .bp3-html-select.bp3-minimal select.bp3-intent-warning:active,
        .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active{
          background:rgba(217, 130, 43, 0.3);
          color:#bf7326; }
        .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled,
        .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled,
        .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled{
          background:none;
          color:rgba(191, 115, 38, 0.5); }
          .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active{
            background:rgba(217, 130, 43, 0.3); }
        .bp3-html-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-warning .bp3-button-spinner .bp3-spinner-head{
          stroke:#bf7326; }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning{
          color:#ffb366; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:hover{
            background:rgba(217, 130, 43, 0.2);
            color:#ffb366; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-active{
            background:rgba(217, 130, 43, 0.3);
            color:#ffb366; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled{
            background:none;
            color:rgba(255, 179, 102, 0.5); }
            .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-warning.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-warning.bp3-disabled.bp3-active{
              background:rgba(217, 130, 43, 0.3); }
      .bp3-html-select.bp3-minimal select.bp3-intent-danger,
      .bp3-select.bp3-minimal select.bp3-intent-danger{
        color:#c23030; }
        .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover,
        .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal select.bp3-intent-danger:active,
        .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{
          background:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:#c23030; }
        .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover,
        .bp3-select.bp3-minimal select.bp3-intent-danger:hover{
          background:rgba(219, 55, 55, 0.15);
          color:#c23030; }
        .bp3-html-select.bp3-minimal select.bp3-intent-danger:active,
        .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active,
        .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active{
          background:rgba(219, 55, 55, 0.3);
          color:#c23030; }
        .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled,
        .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled,
        .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled{
          background:none;
          color:rgba(194, 48, 48, 0.5); }
          .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active,
          .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active{
            background:rgba(219, 55, 55, 0.3); }
        .bp3-html-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head, .bp3-select.bp3-minimal select.bp3-intent-danger .bp3-button-spinner .bp3-spinner-head{
          stroke:#c23030; }
        .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger,
        .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger{
          color:#ff7373; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:hover, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:hover{
            background:rgba(219, 55, 55, 0.2);
            color:#ff7373; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-active{
            background:rgba(219, 55, 55, 0.3);
            color:#ff7373; }
          .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled,
          .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled{
            background:none;
            color:rgba(255, 115, 115, 0.5); }
            .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger:disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger:disabled.bp3-active, .bp3-dark .bp3-html-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-html-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active,
            .bp3-dark .bp3-select.bp3-minimal select.bp3-intent-danger.bp3-disabled.bp3-active, .bp3-select.bp3-minimal .bp3-dark select.bp3-intent-danger.bp3-disabled.bp3-active{
              background:rgba(219, 55, 55, 0.3); }
    
    .bp3-html-select.bp3-large select,
    .bp3-select.bp3-large select{
      font-size:16px;
      height:40px;
      padding-right:35px; }
    
    .bp3-dark .bp3-html-select select, .bp3-dark .bp3-select select{
      background-color:#394b59;
      background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
      background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
      color:#f5f8fa; }
      .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover, .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{
        color:#f5f8fa; }
      .bp3-dark .bp3-html-select select:hover, .bp3-dark .bp3-select select:hover{
        background-color:#30404d;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-html-select select:active, .bp3-dark .bp3-select select:active, .bp3-dark .bp3-html-select select.bp3-active, .bp3-dark .bp3-select select.bp3-active{
        background-color:#202b33;
        background-image:none;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-html-select select:disabled, .bp3-dark .bp3-select select:disabled, .bp3-dark .bp3-html-select select.bp3-disabled, .bp3-dark .bp3-select select.bp3-disabled{
        background-color:rgba(57, 75, 89, 0.5);
        background-image:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-html-select select:disabled.bp3-active, .bp3-dark .bp3-select select:disabled.bp3-active, .bp3-dark .bp3-html-select select.bp3-disabled.bp3-active, .bp3-dark .bp3-select select.bp3-disabled.bp3-active{
          background:rgba(57, 75, 89, 0.7); }
      .bp3-dark .bp3-html-select select .bp3-button-spinner .bp3-spinner-head, .bp3-dark .bp3-select select .bp3-button-spinner .bp3-spinner-head{
        background:rgba(16, 22, 26, 0.5);
        stroke:#8a9ba8; }
    
    .bp3-html-select select:disabled,
    .bp3-select select:disabled{
      background-color:rgba(206, 217, 224, 0.5);
      -webkit-box-shadow:none;
              box-shadow:none;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
    
    .bp3-html-select .bp3-icon,
    .bp3-select .bp3-icon, .bp3-select::after{
      color:#5c7080;
      pointer-events:none;
      position:absolute;
      right:7px;
      top:7px; }
      .bp3-html-select .bp3-disabled.bp3-icon,
      .bp3-select .bp3-disabled.bp3-icon, .bp3-disabled.bp3-select::after{
        color:rgba(92, 112, 128, 0.6); }
    .bp3-html-select,
    .bp3-select{
      display:inline-block;
      letter-spacing:normal;
      position:relative;
      vertical-align:middle; }
      .bp3-html-select select::-ms-expand,
      .bp3-select select::-ms-expand{
        display:none; }
      .bp3-html-select .bp3-icon,
      .bp3-select .bp3-icon{
        color:#5c7080; }
        .bp3-html-select .bp3-icon:hover,
        .bp3-select .bp3-icon:hover{
          color:#182026; }
        .bp3-dark .bp3-html-select .bp3-icon, .bp3-dark
        .bp3-select .bp3-icon{
          color:#a7b6c2; }
          .bp3-dark .bp3-html-select .bp3-icon:hover, .bp3-dark
          .bp3-select .bp3-icon:hover{
            color:#f5f8fa; }
      .bp3-html-select.bp3-large::after,
      .bp3-html-select.bp3-large .bp3-icon,
      .bp3-select.bp3-large::after,
      .bp3-select.bp3-large .bp3-icon{
        right:12px;
        top:12px; }
      .bp3-html-select.bp3-fill,
      .bp3-html-select.bp3-fill select,
      .bp3-select.bp3-fill,
      .bp3-select.bp3-fill select{
        width:100%; }
      .bp3-dark .bp3-html-select option, .bp3-dark
      .bp3-select option{
        background-color:#30404d;
        color:#f5f8fa; }
      .bp3-dark .bp3-html-select option:disabled, .bp3-dark
      .bp3-select option:disabled{
        color:rgba(167, 182, 194, 0.6); }
      .bp3-dark .bp3-html-select::after, .bp3-dark
      .bp3-select::after{
        color:#a7b6c2; }
    
    .bp3-select::after{
      font-family:"Icons16", sans-serif;
      font-size:16px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased;
      content:""; }
    .bp3-running-text table, table.bp3-html-table{
      border-spacing:0;
      font-size:14px; }
      .bp3-running-text table th, table.bp3-html-table th,
      .bp3-running-text table td,
      table.bp3-html-table td{
        padding:11px;
        text-align:left;
        vertical-align:top; }
      .bp3-running-text table th, table.bp3-html-table th{
        color:#182026;
        font-weight:600; }
      
      .bp3-running-text table td,
      table.bp3-html-table td{
        color:#182026; }
      .bp3-running-text table tbody tr:first-child th, table.bp3-html-table tbody tr:first-child th,
      .bp3-running-text table tbody tr:first-child td,
      table.bp3-html-table tbody tr:first-child td,
      .bp3-running-text table tfoot tr:first-child th,
      table.bp3-html-table tfoot tr:first-child th,
      .bp3-running-text table tfoot tr:first-child td,
      table.bp3-html-table tfoot 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,
      .bp3-dark .bp3-running-text table tfoot tr:first-child th,
      .bp3-running-text .bp3-dark table tfoot tr:first-child th,
      .bp3-dark table.bp3-html-table tfoot tr:first-child th,
      .bp3-dark .bp3-running-text table tfoot tr:first-child td,
      .bp3-running-text .bp3-dark table tfoot tr:first-child td,
      .bp3-dark table.bp3-html-table tfoot tr:first-child td{
        -webkit-box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15);
                box-shadow:inset 0 1px 0 0 rgba(255, 255, 255, 0.15); }
    
    table.bp3-html-table.bp3-html-table-condensed th,
    table.bp3-html-table.bp3-html-table-condensed td, table.bp3-html-table.bp3-small th,
    table.bp3-html-table.bp3-small td{
      padding-bottom:6px;
      padding-top:6px; }
    
    table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{
      background:rgba(191, 204, 214, 0.15); }
    
    table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){
      -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15);
              box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); }
    
    table.bp3-html-table.bp3-html-table-bordered tbody tr td,
    table.bp3-html-table.bp3-html-table-bordered tfoot 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),
      table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){
        -webkit-box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15);
                box-shadow:inset 1px 1px 0 0 rgba(16, 22, 26, 0.15); }
    
    table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{
      -webkit-box-shadow:none;
              box-shadow:none; }
      table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:not(:first-child){
        -webkit-box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15);
                box-shadow:inset 1px 0 0 0 rgba(16, 22, 26, 0.15); }
    
    table.bp3-html-table.bp3-interactive tbody tr:hover td{
      background-color:rgba(191, 204, 214, 0.3);
      cursor:pointer; }
    
    table.bp3-html-table.bp3-interactive tbody tr:active td{
      background-color:rgba(191, 204, 214, 0.4); }
    
    .bp3-dark table.bp3-html-table{ }
      .bp3-dark table.bp3-html-table.bp3-html-table-striped tbody tr:nth-child(odd) td{
        background:rgba(92, 112, 128, 0.15); }
      .bp3-dark table.bp3-html-table.bp3-html-table-bordered th:not(:first-child){
        -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15);
                box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); }
      .bp3-dark table.bp3-html-table.bp3-html-table-bordered tbody tr td,
      .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot 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),
        .bp3-dark table.bp3-html-table.bp3-html-table-bordered tfoot tr td:not(:first-child){
          -webkit-box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15);
                  box-shadow:inset 1px 1px 0 0 rgba(255, 255, 255, 0.15); }
      .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td{
        -webkit-box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15);
                box-shadow:inset 1px 0 0 0 rgba(255, 255, 255, 0.15); }
        .bp3-dark table.bp3-html-table.bp3-html-table-bordered.bp3-html-table-striped tbody tr:not(:first-child) td:first-child{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:hover td{
        background-color:rgba(92, 112, 128, 0.3);
        cursor:pointer; }
      .bp3-dark table.bp3-html-table.bp3-interactive tbody tr:active td{
        background-color:rgba(92, 112, 128, 0.4); }
    
    .bp3-key-combo{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center; }
      .bp3-key-combo > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-key-combo > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-key-combo::before,
      .bp3-key-combo > *{
        margin-right:5px; }
      .bp3-key-combo:empty::before,
      .bp3-key-combo > :last-child{
        margin-right:0; }
    
    .bp3-hotkey-dialog{
      padding-bottom:0;
      top:40px; }
      .bp3-hotkey-dialog .bp3-dialog-body{
        margin:0;
        padding:0; }
      .bp3-hotkey-dialog .bp3-hotkey-label{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1; }
    
    .bp3-hotkey-column{
      margin:auto;
      max-height:80vh;
      overflow-y:auto;
      padding:30px; }
      .bp3-hotkey-column .bp3-heading{
        margin-bottom:20px; }
        .bp3-hotkey-column .bp3-heading:not(:first-child){
          margin-top:40px; }
    
    .bp3-hotkey{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-pack:justify;
          -ms-flex-pack:justify;
              justify-content:space-between;
      margin-left:0;
      margin-right:0; }
      .bp3-hotkey:not(:last-child){
        margin-bottom:10px; }
    .bp3-icon{
      display:inline-block;
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      vertical-align:text-bottom; }
      .bp3-icon:not(:empty)::before{
        content:"" !important;
        content:unset !important; }
      .bp3-icon > svg{
        display:block; }
        .bp3-icon > svg:not([fill]){
          fill:currentColor; }
    
    .bp3-icon.bp3-intent-primary, .bp3-icon-standard.bp3-intent-primary, .bp3-icon-large.bp3-intent-primary{
      color:#106ba3; }
      .bp3-dark .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-icon-large.bp3-intent-primary{
        color:#48aff0; }
    
    .bp3-icon.bp3-intent-success, .bp3-icon-standard.bp3-intent-success, .bp3-icon-large.bp3-intent-success{
      color:#0d8050; }
      .bp3-dark .bp3-icon.bp3-intent-success, .bp3-dark .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-icon-large.bp3-intent-success{
        color:#3dcc91; }
    
    .bp3-icon.bp3-intent-warning, .bp3-icon-standard.bp3-intent-warning, .bp3-icon-large.bp3-intent-warning{
      color:#bf7326; }
      .bp3-dark .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-icon-large.bp3-intent-warning{
        color:#ffb366; }
    
    .bp3-icon.bp3-intent-danger, .bp3-icon-standard.bp3-intent-danger, .bp3-icon-large.bp3-intent-danger{
      color:#c23030; }
      .bp3-dark .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-icon-large.bp3-intent-danger{
        color:#ff7373; }
    
    span.bp3-icon-standard{
      font-family:"Icons16", sans-serif;
      font-size:16px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased;
      display:inline-block; }
    
    span.bp3-icon-large{
      font-family:"Icons20", sans-serif;
      font-size:20px;
      font-style:normal;
      font-weight:400;
      line-height:1;
      -moz-osx-font-smoothing:grayscale;
      -webkit-font-smoothing:antialiased;
      display:inline-block; }
    
    span.bp3-icon:empty{
      font-family:"Icons20";
      font-size:inherit;
      font-style:normal;
      font-weight:400;
      line-height:1; }
      span.bp3-icon:empty::before{
        -moz-osx-font-smoothing:grayscale;
        -webkit-font-smoothing:antialiased; }
    
    .bp3-icon-add::before{
      content:""; }
    
    .bp3-icon-add-column-left::before{
      content:""; }
    
    .bp3-icon-add-column-right::before{
      content:""; }
    
    .bp3-icon-add-row-bottom::before{
      content:""; }
    
    .bp3-icon-add-row-top::before{
      content:""; }
    
    .bp3-icon-add-to-artifact::before{
      content:""; }
    
    .bp3-icon-add-to-folder::before{
      content:""; }
    
    .bp3-icon-airplane::before{
      content:""; }
    
    .bp3-icon-align-center::before{
      content:""; }
    
    .bp3-icon-align-justify::before{
      content:""; }
    
    .bp3-icon-align-left::before{
      content:""; }
    
    .bp3-icon-align-right::before{
      content:""; }
    
    .bp3-icon-alignment-bottom::before{
      content:""; }
    
    .bp3-icon-alignment-horizontal-center::before{
      content:""; }
    
    .bp3-icon-alignment-left::before{
      content:""; }
    
    .bp3-icon-alignment-right::before{
      content:""; }
    
    .bp3-icon-alignment-top::before{
      content:""; }
    
    .bp3-icon-alignment-vertical-center::before{
      content:""; }
    
    .bp3-icon-annotation::before{
      content:""; }
    
    .bp3-icon-application::before{
      content:""; }
    
    .bp3-icon-applications::before{
      content:""; }
    
    .bp3-icon-archive::before{
      content:""; }
    
    .bp3-icon-arrow-bottom-left::before{
      content:"↙"; }
    
    .bp3-icon-arrow-bottom-right::before{
      content:"↘"; }
    
    .bp3-icon-arrow-down::before{
      content:"↓"; }
    
    .bp3-icon-arrow-left::before{
      content:"←"; }
    
    .bp3-icon-arrow-right::before{
      content:"→"; }
    
    .bp3-icon-arrow-top-left::before{
      content:"↖"; }
    
    .bp3-icon-arrow-top-right::before{
      content:"↗"; }
    
    .bp3-icon-arrow-up::before{
      content:"↑"; }
    
    .bp3-icon-arrows-horizontal::before{
      content:"↔"; }
    
    .bp3-icon-arrows-vertical::before{
      content:"↕"; }
    
    .bp3-icon-asterisk::before{
      content:"*"; }
    
    .bp3-icon-automatic-updates::before{
      content:""; }
    
    .bp3-icon-badge::before{
      content:""; }
    
    .bp3-icon-ban-circle::before{
      content:""; }
    
    .bp3-icon-bank-account::before{
      content:""; }
    
    .bp3-icon-barcode::before{
      content:""; }
    
    .bp3-icon-blank::before{
      content:""; }
    
    .bp3-icon-blocked-person::before{
      content:""; }
    
    .bp3-icon-bold::before{
      content:""; }
    
    .bp3-icon-book::before{
      content:""; }
    
    .bp3-icon-bookmark::before{
      content:""; }
    
    .bp3-icon-box::before{
      content:""; }
    
    .bp3-icon-briefcase::before{
      content:""; }
    
    .bp3-icon-bring-data::before{
      content:""; }
    
    .bp3-icon-build::before{
      content:""; }
    
    .bp3-icon-calculator::before{
      content:""; }
    
    .bp3-icon-calendar::before{
      content:""; }
    
    .bp3-icon-camera::before{
      content:""; }
    
    .bp3-icon-caret-down::before{
      content:"⌄"; }
    
    .bp3-icon-caret-left::before{
      content:"〈"; }
    
    .bp3-icon-caret-right::before{
      content:"〉"; }
    
    .bp3-icon-caret-up::before{
      content:"⌃"; }
    
    .bp3-icon-cell-tower::before{
      content:""; }
    
    .bp3-icon-changes::before{
      content:""; }
    
    .bp3-icon-chart::before{
      content:""; }
    
    .bp3-icon-chat::before{
      content:""; }
    
    .bp3-icon-chevron-backward::before{
      content:""; }
    
    .bp3-icon-chevron-down::before{
      content:""; }
    
    .bp3-icon-chevron-forward::before{
      content:""; }
    
    .bp3-icon-chevron-left::before{
      content:""; }
    
    .bp3-icon-chevron-right::before{
      content:""; }
    
    .bp3-icon-chevron-up::before{
      content:""; }
    
    .bp3-icon-circle::before{
      content:""; }
    
    .bp3-icon-circle-arrow-down::before{
      content:""; }
    
    .bp3-icon-circle-arrow-left::before{
      content:""; }
    
    .bp3-icon-circle-arrow-right::before{
      content:""; }
    
    .bp3-icon-circle-arrow-up::before{
      content:""; }
    
    .bp3-icon-citation::before{
      content:""; }
    
    .bp3-icon-clean::before{
      content:""; }
    
    .bp3-icon-clipboard::before{
      content:""; }
    
    .bp3-icon-cloud::before{
      content:"☁"; }
    
    .bp3-icon-cloud-download::before{
      content:""; }
    
    .bp3-icon-cloud-upload::before{
      content:""; }
    
    .bp3-icon-code::before{
      content:""; }
    
    .bp3-icon-code-block::before{
      content:""; }
    
    .bp3-icon-cog::before{
      content:""; }
    
    .bp3-icon-collapse-all::before{
      content:""; }
    
    .bp3-icon-column-layout::before{
      content:""; }
    
    .bp3-icon-comment::before{
      content:""; }
    
    .bp3-icon-comparison::before{
      content:""; }
    
    .bp3-icon-compass::before{
      content:""; }
    
    .bp3-icon-compressed::before{
      content:""; }
    
    .bp3-icon-confirm::before{
      content:""; }
    
    .bp3-icon-console::before{
      content:""; }
    
    .bp3-icon-contrast::before{
      content:""; }
    
    .bp3-icon-control::before{
      content:""; }
    
    .bp3-icon-credit-card::before{
      content:""; }
    
    .bp3-icon-cross::before{
      content:"✗"; }
    
    .bp3-icon-crown::before{
      content:""; }
    
    .bp3-icon-cube::before{
      content:""; }
    
    .bp3-icon-cube-add::before{
      content:""; }
    
    .bp3-icon-cube-remove::before{
      content:""; }
    
    .bp3-icon-curved-range-chart::before{
      content:""; }
    
    .bp3-icon-cut::before{
      content:""; }
    
    .bp3-icon-dashboard::before{
      content:""; }
    
    .bp3-icon-data-lineage::before{
      content:""; }
    
    .bp3-icon-database::before{
      content:""; }
    
    .bp3-icon-delete::before{
      content:""; }
    
    .bp3-icon-delta::before{
      content:"Δ"; }
    
    .bp3-icon-derive-column::before{
      content:""; }
    
    .bp3-icon-desktop::before{
      content:""; }
    
    .bp3-icon-diagnosis::before{
      content:""; }
    
    .bp3-icon-diagram-tree::before{
      content:""; }
    
    .bp3-icon-direction-left::before{
      content:""; }
    
    .bp3-icon-direction-right::before{
      content:""; }
    
    .bp3-icon-disable::before{
      content:""; }
    
    .bp3-icon-document::before{
      content:""; }
    
    .bp3-icon-document-open::before{
      content:""; }
    
    .bp3-icon-document-share::before{
      content:""; }
    
    .bp3-icon-dollar::before{
      content:"$"; }
    
    .bp3-icon-dot::before{
      content:"•"; }
    
    .bp3-icon-double-caret-horizontal::before{
      content:""; }
    
    .bp3-icon-double-caret-vertical::before{
      content:""; }
    
    .bp3-icon-double-chevron-down::before{
      content:""; }
    
    .bp3-icon-double-chevron-left::before{
      content:""; }
    
    .bp3-icon-double-chevron-right::before{
      content:""; }
    
    .bp3-icon-double-chevron-up::before{
      content:""; }
    
    .bp3-icon-doughnut-chart::before{
      content:""; }
    
    .bp3-icon-download::before{
      content:""; }
    
    .bp3-icon-drag-handle-horizontal::before{
      content:""; }
    
    .bp3-icon-drag-handle-vertical::before{
      content:""; }
    
    .bp3-icon-draw::before{
      content:""; }
    
    .bp3-icon-drive-time::before{
      content:""; }
    
    .bp3-icon-duplicate::before{
      content:""; }
    
    .bp3-icon-edit::before{
      content:"✎"; }
    
    .bp3-icon-eject::before{
      content:"⏏"; }
    
    .bp3-icon-endorsed::before{
      content:""; }
    
    .bp3-icon-envelope::before{
      content:"✉"; }
    
    .bp3-icon-equals::before{
      content:""; }
    
    .bp3-icon-eraser::before{
      content:""; }
    
    .bp3-icon-error::before{
      content:""; }
    
    .bp3-icon-euro::before{
      content:"€"; }
    
    .bp3-icon-exchange::before{
      content:""; }
    
    .bp3-icon-exclude-row::before{
      content:""; }
    
    .bp3-icon-expand-all::before{
      content:""; }
    
    .bp3-icon-export::before{
      content:""; }
    
    .bp3-icon-eye-off::before{
      content:""; }
    
    .bp3-icon-eye-on::before{
      content:""; }
    
    .bp3-icon-eye-open::before{
      content:""; }
    
    .bp3-icon-fast-backward::before{
      content:""; }
    
    .bp3-icon-fast-forward::before{
      content:""; }
    
    .bp3-icon-feed::before{
      content:""; }
    
    .bp3-icon-feed-subscribed::before{
      content:""; }
    
    .bp3-icon-film::before{
      content:""; }
    
    .bp3-icon-filter::before{
      content:""; }
    
    .bp3-icon-filter-keep::before{
      content:""; }
    
    .bp3-icon-filter-list::before{
      content:""; }
    
    .bp3-icon-filter-open::before{
      content:""; }
    
    .bp3-icon-filter-remove::before{
      content:""; }
    
    .bp3-icon-flag::before{
      content:"⚑"; }
    
    .bp3-icon-flame::before{
      content:""; }
    
    .bp3-icon-flash::before{
      content:""; }
    
    .bp3-icon-floppy-disk::before{
      content:""; }
    
    .bp3-icon-flow-branch::before{
      content:""; }
    
    .bp3-icon-flow-end::before{
      content:""; }
    
    .bp3-icon-flow-linear::before{
      content:""; }
    
    .bp3-icon-flow-review::before{
      content:""; }
    
    .bp3-icon-flow-review-branch::before{
      content:""; }
    
    .bp3-icon-flows::before{
      content:""; }
    
    .bp3-icon-folder-close::before{
      content:""; }
    
    .bp3-icon-folder-new::before{
      content:""; }
    
    .bp3-icon-folder-open::before{
      content:""; }
    
    .bp3-icon-folder-shared::before{
      content:""; }
    
    .bp3-icon-folder-shared-open::before{
      content:""; }
    
    .bp3-icon-follower::before{
      content:""; }
    
    .bp3-icon-following::before{
      content:""; }
    
    .bp3-icon-font::before{
      content:""; }
    
    .bp3-icon-fork::before{
      content:""; }
    
    .bp3-icon-form::before{
      content:""; }
    
    .bp3-icon-full-circle::before{
      content:""; }
    
    .bp3-icon-full-stacked-chart::before{
      content:""; }
    
    .bp3-icon-fullscreen::before{
      content:""; }
    
    .bp3-icon-function::before{
      content:""; }
    
    .bp3-icon-gantt-chart::before{
      content:""; }
    
    .bp3-icon-geolocation::before{
      content:""; }
    
    .bp3-icon-geosearch::before{
      content:""; }
    
    .bp3-icon-git-branch::before{
      content:""; }
    
    .bp3-icon-git-commit::before{
      content:""; }
    
    .bp3-icon-git-merge::before{
      content:""; }
    
    .bp3-icon-git-new-branch::before{
      content:""; }
    
    .bp3-icon-git-pull::before{
      content:""; }
    
    .bp3-icon-git-push::before{
      content:""; }
    
    .bp3-icon-git-repo::before{
      content:""; }
    
    .bp3-icon-glass::before{
      content:""; }
    
    .bp3-icon-globe::before{
      content:""; }
    
    .bp3-icon-globe-network::before{
      content:""; }
    
    .bp3-icon-graph::before{
      content:""; }
    
    .bp3-icon-graph-remove::before{
      content:""; }
    
    .bp3-icon-greater-than::before{
      content:""; }
    
    .bp3-icon-greater-than-or-equal-to::before{
      content:""; }
    
    .bp3-icon-grid::before{
      content:""; }
    
    .bp3-icon-grid-view::before{
      content:""; }
    
    .bp3-icon-group-objects::before{
      content:""; }
    
    .bp3-icon-grouped-bar-chart::before{
      content:""; }
    
    .bp3-icon-hand::before{
      content:""; }
    
    .bp3-icon-hand-down::before{
      content:""; }
    
    .bp3-icon-hand-left::before{
      content:""; }
    
    .bp3-icon-hand-right::before{
      content:""; }
    
    .bp3-icon-hand-up::before{
      content:""; }
    
    .bp3-icon-header::before{
      content:""; }
    
    .bp3-icon-header-one::before{
      content:""; }
    
    .bp3-icon-header-two::before{
      content:""; }
    
    .bp3-icon-headset::before{
      content:""; }
    
    .bp3-icon-heart::before{
      content:"♥"; }
    
    .bp3-icon-heart-broken::before{
      content:""; }
    
    .bp3-icon-heat-grid::before{
      content:""; }
    
    .bp3-icon-heatmap::before{
      content:""; }
    
    .bp3-icon-help::before{
      content:"?"; }
    
    .bp3-icon-helper-management::before{
      content:""; }
    
    .bp3-icon-highlight::before{
      content:""; }
    
    .bp3-icon-history::before{
      content:""; }
    
    .bp3-icon-home::before{
      content:"⌂"; }
    
    .bp3-icon-horizontal-bar-chart::before{
      content:""; }
    
    .bp3-icon-horizontal-bar-chart-asc::before{
      content:""; }
    
    .bp3-icon-horizontal-bar-chart-desc::before{
      content:""; }
    
    .bp3-icon-horizontal-distribution::before{
      content:""; }
    
    .bp3-icon-id-number::before{
      content:""; }
    
    .bp3-icon-image-rotate-left::before{
      content:""; }
    
    .bp3-icon-image-rotate-right::before{
      content:""; }
    
    .bp3-icon-import::before{
      content:""; }
    
    .bp3-icon-inbox::before{
      content:""; }
    
    .bp3-icon-inbox-filtered::before{
      content:""; }
    
    .bp3-icon-inbox-geo::before{
      content:""; }
    
    .bp3-icon-inbox-search::before{
      content:""; }
    
    .bp3-icon-inbox-update::before{
      content:""; }
    
    .bp3-icon-info-sign::before{
      content:"ℹ"; }
    
    .bp3-icon-inheritance::before{
      content:""; }
    
    .bp3-icon-inner-join::before{
      content:""; }
    
    .bp3-icon-insert::before{
      content:""; }
    
    .bp3-icon-intersection::before{
      content:""; }
    
    .bp3-icon-ip-address::before{
      content:""; }
    
    .bp3-icon-issue::before{
      content:""; }
    
    .bp3-icon-issue-closed::before{
      content:""; }
    
    .bp3-icon-issue-new::before{
      content:""; }
    
    .bp3-icon-italic::before{
      content:""; }
    
    .bp3-icon-join-table::before{
      content:""; }
    
    .bp3-icon-key::before{
      content:""; }
    
    .bp3-icon-key-backspace::before{
      content:""; }
    
    .bp3-icon-key-command::before{
      content:""; }
    
    .bp3-icon-key-control::before{
      content:""; }
    
    .bp3-icon-key-delete::before{
      content:""; }
    
    .bp3-icon-key-enter::before{
      content:""; }
    
    .bp3-icon-key-escape::before{
      content:""; }
    
    .bp3-icon-key-option::before{
      content:""; }
    
    .bp3-icon-key-shift::before{
      content:""; }
    
    .bp3-icon-key-tab::before{
      content:""; }
    
    .bp3-icon-known-vehicle::before{
      content:""; }
    
    .bp3-icon-lab-test::before{
      content:""; }
    
    .bp3-icon-label::before{
      content:""; }
    
    .bp3-icon-layer::before{
      content:""; }
    
    .bp3-icon-layers::before{
      content:""; }
    
    .bp3-icon-layout::before{
      content:""; }
    
    .bp3-icon-layout-auto::before{
      content:""; }
    
    .bp3-icon-layout-balloon::before{
      content:""; }
    
    .bp3-icon-layout-circle::before{
      content:""; }
    
    .bp3-icon-layout-grid::before{
      content:""; }
    
    .bp3-icon-layout-group-by::before{
      content:""; }
    
    .bp3-icon-layout-hierarchy::before{
      content:""; }
    
    .bp3-icon-layout-linear::before{
      content:""; }
    
    .bp3-icon-layout-skew-grid::before{
      content:""; }
    
    .bp3-icon-layout-sorted-clusters::before{
      content:""; }
    
    .bp3-icon-learning::before{
      content:""; }
    
    .bp3-icon-left-join::before{
      content:""; }
    
    .bp3-icon-less-than::before{
      content:""; }
    
    .bp3-icon-less-than-or-equal-to::before{
      content:""; }
    
    .bp3-icon-lifesaver::before{
      content:""; }
    
    .bp3-icon-lightbulb::before{
      content:""; }
    
    .bp3-icon-link::before{
      content:""; }
    
    .bp3-icon-list::before{
      content:"☰"; }
    
    .bp3-icon-list-columns::before{
      content:""; }
    
    .bp3-icon-list-detail-view::before{
      content:""; }
    
    .bp3-icon-locate::before{
      content:""; }
    
    .bp3-icon-lock::before{
      content:""; }
    
    .bp3-icon-log-in::before{
      content:""; }
    
    .bp3-icon-log-out::before{
      content:""; }
    
    .bp3-icon-manual::before{
      content:""; }
    
    .bp3-icon-manually-entered-data::before{
      content:""; }
    
    .bp3-icon-map::before{
      content:""; }
    
    .bp3-icon-map-create::before{
      content:""; }
    
    .bp3-icon-map-marker::before{
      content:""; }
    
    .bp3-icon-maximize::before{
      content:""; }
    
    .bp3-icon-media::before{
      content:""; }
    
    .bp3-icon-menu::before{
      content:""; }
    
    .bp3-icon-menu-closed::before{
      content:""; }
    
    .bp3-icon-menu-open::before{
      content:""; }
    
    .bp3-icon-merge-columns::before{
      content:""; }
    
    .bp3-icon-merge-links::before{
      content:""; }
    
    .bp3-icon-minimize::before{
      content:""; }
    
    .bp3-icon-minus::before{
      content:"−"; }
    
    .bp3-icon-mobile-phone::before{
      content:""; }
    
    .bp3-icon-mobile-video::before{
      content:""; }
    
    .bp3-icon-moon::before{
      content:""; }
    
    .bp3-icon-more::before{
      content:""; }
    
    .bp3-icon-mountain::before{
      content:""; }
    
    .bp3-icon-move::before{
      content:""; }
    
    .bp3-icon-mugshot::before{
      content:""; }
    
    .bp3-icon-multi-select::before{
      content:""; }
    
    .bp3-icon-music::before{
      content:""; }
    
    .bp3-icon-new-drawing::before{
      content:""; }
    
    .bp3-icon-new-grid-item::before{
      content:""; }
    
    .bp3-icon-new-layer::before{
      content:""; }
    
    .bp3-icon-new-layers::before{
      content:""; }
    
    .bp3-icon-new-link::before{
      content:""; }
    
    .bp3-icon-new-object::before{
      content:""; }
    
    .bp3-icon-new-person::before{
      content:""; }
    
    .bp3-icon-new-prescription::before{
      content:""; }
    
    .bp3-icon-new-text-box::before{
      content:""; }
    
    .bp3-icon-ninja::before{
      content:""; }
    
    .bp3-icon-not-equal-to::before{
      content:""; }
    
    .bp3-icon-notifications::before{
      content:""; }
    
    .bp3-icon-notifications-updated::before{
      content:""; }
    
    .bp3-icon-numbered-list::before{
      content:""; }
    
    .bp3-icon-numerical::before{
      content:""; }
    
    .bp3-icon-office::before{
      content:""; }
    
    .bp3-icon-offline::before{
      content:""; }
    
    .bp3-icon-oil-field::before{
      content:""; }
    
    .bp3-icon-one-column::before{
      content:""; }
    
    .bp3-icon-outdated::before{
      content:""; }
    
    .bp3-icon-page-layout::before{
      content:""; }
    
    .bp3-icon-panel-stats::before{
      content:""; }
    
    .bp3-icon-panel-table::before{
      content:""; }
    
    .bp3-icon-paperclip::before{
      content:""; }
    
    .bp3-icon-paragraph::before{
      content:""; }
    
    .bp3-icon-path::before{
      content:""; }
    
    .bp3-icon-path-search::before{
      content:""; }
    
    .bp3-icon-pause::before{
      content:""; }
    
    .bp3-icon-people::before{
      content:""; }
    
    .bp3-icon-percentage::before{
      content:""; }
    
    .bp3-icon-person::before{
      content:""; }
    
    .bp3-icon-phone::before{
      content:"☎"; }
    
    .bp3-icon-pie-chart::before{
      content:""; }
    
    .bp3-icon-pin::before{
      content:""; }
    
    .bp3-icon-pivot::before{
      content:""; }
    
    .bp3-icon-pivot-table::before{
      content:""; }
    
    .bp3-icon-play::before{
      content:""; }
    
    .bp3-icon-plus::before{
      content:"+"; }
    
    .bp3-icon-polygon-filter::before{
      content:""; }
    
    .bp3-icon-power::before{
      content:""; }
    
    .bp3-icon-predictive-analysis::before{
      content:""; }
    
    .bp3-icon-prescription::before{
      content:""; }
    
    .bp3-icon-presentation::before{
      content:""; }
    
    .bp3-icon-print::before{
      content:"⎙"; }
    
    .bp3-icon-projects::before{
      content:""; }
    
    .bp3-icon-properties::before{
      content:""; }
    
    .bp3-icon-property::before{
      content:""; }
    
    .bp3-icon-publish-function::before{
      content:""; }
    
    .bp3-icon-pulse::before{
      content:""; }
    
    .bp3-icon-random::before{
      content:""; }
    
    .bp3-icon-record::before{
      content:""; }
    
    .bp3-icon-redo::before{
      content:""; }
    
    .bp3-icon-refresh::before{
      content:""; }
    
    .bp3-icon-regression-chart::before{
      content:""; }
    
    .bp3-icon-remove::before{
      content:""; }
    
    .bp3-icon-remove-column::before{
      content:""; }
    
    .bp3-icon-remove-column-left::before{
      content:""; }
    
    .bp3-icon-remove-column-right::before{
      content:""; }
    
    .bp3-icon-remove-row-bottom::before{
      content:""; }
    
    .bp3-icon-remove-row-top::before{
      content:""; }
    
    .bp3-icon-repeat::before{
      content:""; }
    
    .bp3-icon-reset::before{
      content:""; }
    
    .bp3-icon-resolve::before{
      content:""; }
    
    .bp3-icon-rig::before{
      content:""; }
    
    .bp3-icon-right-join::before{
      content:""; }
    
    .bp3-icon-ring::before{
      content:""; }
    
    .bp3-icon-rotate-document::before{
      content:""; }
    
    .bp3-icon-rotate-page::before{
      content:""; }
    
    .bp3-icon-satellite::before{
      content:""; }
    
    .bp3-icon-saved::before{
      content:""; }
    
    .bp3-icon-scatter-plot::before{
      content:""; }
    
    .bp3-icon-search::before{
      content:""; }
    
    .bp3-icon-search-around::before{
      content:""; }
    
    .bp3-icon-search-template::before{
      content:""; }
    
    .bp3-icon-search-text::before{
      content:""; }
    
    .bp3-icon-segmented-control::before{
      content:""; }
    
    .bp3-icon-select::before{
      content:""; }
    
    .bp3-icon-selection::before{
      content:"⦿"; }
    
    .bp3-icon-send-to::before{
      content:""; }
    
    .bp3-icon-send-to-graph::before{
      content:""; }
    
    .bp3-icon-send-to-map::before{
      content:""; }
    
    .bp3-icon-series-add::before{
      content:""; }
    
    .bp3-icon-series-configuration::before{
      content:""; }
    
    .bp3-icon-series-derived::before{
      content:""; }
    
    .bp3-icon-series-filtered::before{
      content:""; }
    
    .bp3-icon-series-search::before{
      content:""; }
    
    .bp3-icon-settings::before{
      content:""; }
    
    .bp3-icon-share::before{
      content:""; }
    
    .bp3-icon-shield::before{
      content:""; }
    
    .bp3-icon-shop::before{
      content:""; }
    
    .bp3-icon-shopping-cart::before{
      content:""; }
    
    .bp3-icon-signal-search::before{
      content:""; }
    
    .bp3-icon-sim-card::before{
      content:""; }
    
    .bp3-icon-slash::before{
      content:""; }
    
    .bp3-icon-small-cross::before{
      content:""; }
    
    .bp3-icon-small-minus::before{
      content:""; }
    
    .bp3-icon-small-plus::before{
      content:""; }
    
    .bp3-icon-small-tick::before{
      content:""; }
    
    .bp3-icon-snowflake::before{
      content:""; }
    
    .bp3-icon-social-media::before{
      content:""; }
    
    .bp3-icon-sort::before{
      content:""; }
    
    .bp3-icon-sort-alphabetical::before{
      content:""; }
    
    .bp3-icon-sort-alphabetical-desc::before{
      content:""; }
    
    .bp3-icon-sort-asc::before{
      content:""; }
    
    .bp3-icon-sort-desc::before{
      content:""; }
    
    .bp3-icon-sort-numerical::before{
      content:""; }
    
    .bp3-icon-sort-numerical-desc::before{
      content:""; }
    
    .bp3-icon-split-columns::before{
      content:""; }
    
    .bp3-icon-square::before{
      content:""; }
    
    .bp3-icon-stacked-chart::before{
      content:""; }
    
    .bp3-icon-star::before{
      content:"★"; }
    
    .bp3-icon-star-empty::before{
      content:"☆"; }
    
    .bp3-icon-step-backward::before{
      content:""; }
    
    .bp3-icon-step-chart::before{
      content:""; }
    
    .bp3-icon-step-forward::before{
      content:""; }
    
    .bp3-icon-stop::before{
      content:""; }
    
    .bp3-icon-stopwatch::before{
      content:""; }
    
    .bp3-icon-strikethrough::before{
      content:""; }
    
    .bp3-icon-style::before{
      content:""; }
    
    .bp3-icon-swap-horizontal::before{
      content:""; }
    
    .bp3-icon-swap-vertical::before{
      content:""; }
    
    .bp3-icon-symbol-circle::before{
      content:""; }
    
    .bp3-icon-symbol-cross::before{
      content:""; }
    
    .bp3-icon-symbol-diamond::before{
      content:""; }
    
    .bp3-icon-symbol-square::before{
      content:""; }
    
    .bp3-icon-symbol-triangle-down::before{
      content:""; }
    
    .bp3-icon-symbol-triangle-up::before{
      content:""; }
    
    .bp3-icon-tag::before{
      content:""; }
    
    .bp3-icon-take-action::before{
      content:""; }
    
    .bp3-icon-taxi::before{
      content:""; }
    
    .bp3-icon-text-highlight::before{
      content:""; }
    
    .bp3-icon-th::before{
      content:""; }
    
    .bp3-icon-th-derived::before{
      content:""; }
    
    .bp3-icon-th-disconnect::before{
      content:""; }
    
    .bp3-icon-th-filtered::before{
      content:""; }
    
    .bp3-icon-th-list::before{
      content:""; }
    
    .bp3-icon-thumbs-down::before{
      content:""; }
    
    .bp3-icon-thumbs-up::before{
      content:""; }
    
    .bp3-icon-tick::before{
      content:"✓"; }
    
    .bp3-icon-tick-circle::before{
      content:""; }
    
    .bp3-icon-time::before{
      content:"⏲"; }
    
    .bp3-icon-timeline-area-chart::before{
      content:""; }
    
    .bp3-icon-timeline-bar-chart::before{
      content:""; }
    
    .bp3-icon-timeline-events::before{
      content:""; }
    
    .bp3-icon-timeline-line-chart::before{
      content:""; }
    
    .bp3-icon-tint::before{
      content:""; }
    
    .bp3-icon-torch::before{
      content:""; }
    
    .bp3-icon-tractor::before{
      content:""; }
    
    .bp3-icon-train::before{
      content:""; }
    
    .bp3-icon-translate::before{
      content:""; }
    
    .bp3-icon-trash::before{
      content:""; }
    
    .bp3-icon-tree::before{
      content:""; }
    
    .bp3-icon-trending-down::before{
      content:""; }
    
    .bp3-icon-trending-up::before{
      content:""; }
    
    .bp3-icon-truck::before{
      content:""; }
    
    .bp3-icon-two-columns::before{
      content:""; }
    
    .bp3-icon-unarchive::before{
      content:""; }
    
    .bp3-icon-underline::before{
      content:"⎁"; }
    
    .bp3-icon-undo::before{
      content:"⎌"; }
    
    .bp3-icon-ungroup-objects::before{
      content:""; }
    
    .bp3-icon-unknown-vehicle::before{
      content:""; }
    
    .bp3-icon-unlock::before{
      content:""; }
    
    .bp3-icon-unpin::before{
      content:""; }
    
    .bp3-icon-unresolve::before{
      content:""; }
    
    .bp3-icon-updated::before{
      content:""; }
    
    .bp3-icon-upload::before{
      content:""; }
    
    .bp3-icon-user::before{
      content:""; }
    
    .bp3-icon-variable::before{
      content:""; }
    
    .bp3-icon-vertical-bar-chart-asc::before{
      content:""; }
    
    .bp3-icon-vertical-bar-chart-desc::before{
      content:""; }
    
    .bp3-icon-vertical-distribution::before{
      content:""; }
    
    .bp3-icon-video::before{
      content:""; }
    
    .bp3-icon-volume-down::before{
      content:""; }
    
    .bp3-icon-volume-off::before{
      content:""; }
    
    .bp3-icon-volume-up::before{
      content:""; }
    
    .bp3-icon-walk::before{
      content:""; }
    
    .bp3-icon-warning-sign::before{
      content:""; }
    
    .bp3-icon-waterfall-chart::before{
      content:""; }
    
    .bp3-icon-widget::before{
      content:""; }
    
    .bp3-icon-widget-button::before{
      content:""; }
    
    .bp3-icon-widget-footer::before{
      content:""; }
    
    .bp3-icon-widget-header::before{
      content:""; }
    
    .bp3-icon-wrench::before{
      content:""; }
    
    .bp3-icon-zoom-in::before{
      content:""; }
    
    .bp3-icon-zoom-out::before{
      content:""; }
    
    .bp3-icon-zoom-to-fit::before{
      content:""; }
    .bp3-submenu > .bp3-popover-wrapper{
      display:block; }
    
    .bp3-submenu .bp3-popover-target{
      display:block; }
      .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{ }
    
    .bp3-submenu.bp3-popover{
      -webkit-box-shadow:none;
              box-shadow:none;
      padding:0 5px; }
      .bp3-submenu.bp3-popover > .bp3-popover-content{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-submenu.bp3-popover, .bp3-submenu.bp3-popover.bp3-dark{
        -webkit-box-shadow:none;
                box-shadow:none; }
        .bp3-dark .bp3-submenu.bp3-popover > .bp3-popover-content, .bp3-submenu.bp3-popover.bp3-dark > .bp3-popover-content{
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
    .bp3-menu{
      background:#ffffff;
      border-radius:3px;
      color:#182026;
      list-style:none;
      margin:0;
      min-width:180px;
      padding:5px;
      text-align:left; }
    
    .bp3-menu-divider{
      border-top:1px solid rgba(16, 22, 26, 0.15);
      display:block;
      margin:5px; }
      .bp3-dark .bp3-menu-divider{
        border-top-color:rgba(255, 255, 255, 0.15); }
    
    .bp3-menu-item{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:start;
          -ms-flex-align:start;
              align-items:flex-start;
      border-radius:2px;
      color:inherit;
      line-height:20px;
      padding:5px 7px;
      text-decoration:none;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-menu-item > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-menu-item > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-menu-item::before,
      .bp3-menu-item > *{
        margin-right:7px; }
      .bp3-menu-item:empty::before,
      .bp3-menu-item > :last-child{
        margin-right:0; }
      .bp3-menu-item > .bp3-fill{
        word-break:break-word; }
      .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
        background-color:rgba(167, 182, 194, 0.3);
        cursor:pointer;
        text-decoration:none; }
      .bp3-menu-item.bp3-disabled{
        background-color:inherit;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed; }
      .bp3-dark .bp3-menu-item{
        color:inherit; }
        .bp3-dark .bp3-menu-item:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
          background-color:rgba(138, 155, 168, 0.15);
          color:inherit; }
        .bp3-dark .bp3-menu-item.bp3-disabled{
          background-color:inherit;
          color:rgba(167, 182, 194, 0.6); }
      .bp3-menu-item.bp3-intent-primary{
        color:#106ba3; }
        .bp3-menu-item.bp3-intent-primary .bp3-icon{
          color:inherit; }
        .bp3-menu-item.bp3-intent-primary::before, .bp3-menu-item.bp3-intent-primary::after,
        .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{
          color:#106ba3; }
        .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary.bp3-active{
          background-color:#137cbd; }
        .bp3-menu-item.bp3-intent-primary:active{
          background-color:#106ba3; }
        .bp3-menu-item.bp3-intent-primary:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after,
        .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label,
        .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary:active, .bp3-menu-item.bp3-intent-primary:active::before, .bp3-menu-item.bp3-intent-primary:active::after,
        .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-menu-item.bp3-intent-primary.bp3-active::after,
        .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-menu-item.bp3-intent-success{
        color:#0d8050; }
        .bp3-menu-item.bp3-intent-success .bp3-icon{
          color:inherit; }
        .bp3-menu-item.bp3-intent-success::before, .bp3-menu-item.bp3-intent-success::after,
        .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{
          color:#0d8050; }
        .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success.bp3-active{
          background-color:#0f9960; }
        .bp3-menu-item.bp3-intent-success:active{
          background-color:#0d8050; }
        .bp3-menu-item.bp3-intent-success:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-menu-item.bp3-intent-success:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-menu-item.bp3-intent-success:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after,
        .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label,
        .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success:active, .bp3-menu-item.bp3-intent-success:active::before, .bp3-menu-item.bp3-intent-success:active::after,
        .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-menu-item.bp3-intent-success.bp3-active::after,
        .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-menu-item.bp3-intent-warning{
        color:#bf7326; }
        .bp3-menu-item.bp3-intent-warning .bp3-icon{
          color:inherit; }
        .bp3-menu-item.bp3-intent-warning::before, .bp3-menu-item.bp3-intent-warning::after,
        .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{
          color:#bf7326; }
        .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning.bp3-active{
          background-color:#d9822b; }
        .bp3-menu-item.bp3-intent-warning:active{
          background-color:#bf7326; }
        .bp3-menu-item.bp3-intent-warning:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after,
        .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label,
        .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning:active, .bp3-menu-item.bp3-intent-warning:active::before, .bp3-menu-item.bp3-intent-warning:active::after,
        .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-menu-item.bp3-intent-warning.bp3-active::after,
        .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-menu-item.bp3-intent-danger{
        color:#c23030; }
        .bp3-menu-item.bp3-intent-danger .bp3-icon{
          color:inherit; }
        .bp3-menu-item.bp3-intent-danger::before, .bp3-menu-item.bp3-intent-danger::after,
        .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{
          color:#c23030; }
        .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger.bp3-active{
          background-color:#db3737; }
        .bp3-menu-item.bp3-intent-danger:active{
          background-color:#c23030; }
        .bp3-menu-item.bp3-intent-danger:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after,
        .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label,
        .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger:active, .bp3-menu-item.bp3-intent-danger:active::before, .bp3-menu-item.bp3-intent-danger:active::after,
        .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-menu-item.bp3-intent-danger.bp3-active::after,
        .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-menu-item::before{
        font-family:"Icons16", sans-serif;
        font-size:16px;
        font-style:normal;
        font-weight:400;
        line-height:1;
        -moz-osx-font-smoothing:grayscale;
        -webkit-font-smoothing:antialiased;
        margin-right:7px; }
      .bp3-menu-item::before,
      .bp3-menu-item > .bp3-icon{
        color:#5c7080;
        margin-top:2px; }
      .bp3-menu-item .bp3-menu-item-label{
        color:#5c7080; }
      .bp3-menu-item:hover, .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-menu-item{
        color:inherit; }
      .bp3-menu-item.bp3-active, .bp3-menu-item:active{
        background-color:rgba(115, 134, 148, 0.3); }
      .bp3-menu-item.bp3-disabled{
        background-color:inherit !important;
        color:rgba(92, 112, 128, 0.6) !important;
        cursor:not-allowed !important;
        outline:none !important; }
        .bp3-menu-item.bp3-disabled::before,
        .bp3-menu-item.bp3-disabled > .bp3-icon,
        .bp3-menu-item.bp3-disabled .bp3-menu-item-label{
          color:rgba(92, 112, 128, 0.6) !important; }
      .bp3-large .bp3-menu-item{
        font-size:16px;
        line-height:22px;
        padding:9px 7px; }
        .bp3-large .bp3-menu-item .bp3-icon{
          margin-top:3px; }
        .bp3-large .bp3-menu-item::before{
          font-family:"Icons20", sans-serif;
          font-size:20px;
          font-style:normal;
          font-weight:400;
          line-height:1;
          -moz-osx-font-smoothing:grayscale;
          -webkit-font-smoothing:antialiased;
          margin-right:10px;
          margin-top:1px; }
    
    button.bp3-menu-item{
      background:none;
      border:none;
      text-align:left;
      width:100%; }
    .bp3-menu-header{
      border-top:1px solid rgba(16, 22, 26, 0.15);
      display:block;
      margin:5px;
      cursor:default;
      padding-left:2px; }
      .bp3-dark .bp3-menu-header{
        border-top-color:rgba(255, 255, 255, 0.15); }
      .bp3-menu-header:first-of-type{
        border-top:none; }
      .bp3-menu-header > h6{
        color:#182026;
        font-weight:600;
        overflow:hidden;
        text-overflow:ellipsis;
        white-space:nowrap;
        word-wrap:normal;
        line-height:17px;
        margin:0;
        padding:10px 7px 0 1px; }
        .bp3-dark .bp3-menu-header > h6{
          color:#f5f8fa; }
      .bp3-menu-header:first-of-type > h6{
        padding-top:0; }
      .bp3-large .bp3-menu-header > h6{
        font-size:18px;
        padding-bottom:5px;
        padding-top:15px; }
      .bp3-large .bp3-menu-header:first-of-type > h6{
        padding-top:0; }
    
    .bp3-dark .bp3-menu{
      background:#30404d;
      color:#f5f8fa; }
    
    .bp3-dark .bp3-menu-item{ }
      .bp3-dark .bp3-menu-item.bp3-intent-primary{
        color:#48aff0; }
        .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-icon{
          color:inherit; }
        .bp3-dark .bp3-menu-item.bp3-intent-primary::before, .bp3-dark .bp3-menu-item.bp3-intent-primary::after,
        .bp3-dark .bp3-menu-item.bp3-intent-primary .bp3-menu-item-label{
          color:#48aff0; }
        .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active{
          background-color:#137cbd; }
        .bp3-dark .bp3-menu-item.bp3-intent-primary:active{
          background-color:#106ba3; }
        .bp3-dark .bp3-menu-item.bp3-intent-primary:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item::after,
        .bp3-dark .bp3-menu-item.bp3-intent-primary:hover .bp3-menu-item-label,
        .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label,
        .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-primary.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary:active, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary:active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-primary:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-primary.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-dark .bp3-menu-item.bp3-intent-success{
        color:#3dcc91; }
        .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-icon{
          color:inherit; }
        .bp3-dark .bp3-menu-item.bp3-intent-success::before, .bp3-dark .bp3-menu-item.bp3-intent-success::after,
        .bp3-dark .bp3-menu-item.bp3-intent-success .bp3-menu-item-label{
          color:#3dcc91; }
        .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active{
          background-color:#0f9960; }
        .bp3-dark .bp3-menu-item.bp3-intent-success:active{
          background-color:#0d8050; }
        .bp3-dark .bp3-menu-item.bp3-intent-success:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-success:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item::after,
        .bp3-dark .bp3-menu-item.bp3-intent-success:hover .bp3-menu-item-label,
        .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label,
        .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-success.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success:active, .bp3-dark .bp3-menu-item.bp3-intent-success:active::before, .bp3-dark .bp3-menu-item.bp3-intent-success:active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-success:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-success.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-dark .bp3-menu-item.bp3-intent-warning{
        color:#ffb366; }
        .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-icon{
          color:inherit; }
        .bp3-dark .bp3-menu-item.bp3-intent-warning::before, .bp3-dark .bp3-menu-item.bp3-intent-warning::after,
        .bp3-dark .bp3-menu-item.bp3-intent-warning .bp3-menu-item-label{
          color:#ffb366; }
        .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active{
          background-color:#d9822b; }
        .bp3-dark .bp3-menu-item.bp3-intent-warning:active{
          background-color:#bf7326; }
        .bp3-dark .bp3-menu-item.bp3-intent-warning:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item::after,
        .bp3-dark .bp3-menu-item.bp3-intent-warning:hover .bp3-menu-item-label,
        .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label,
        .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-warning.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning:active, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning:active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-warning:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-warning.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-dark .bp3-menu-item.bp3-intent-danger{
        color:#ff7373; }
        .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-icon{
          color:inherit; }
        .bp3-dark .bp3-menu-item.bp3-intent-danger::before, .bp3-dark .bp3-menu-item.bp3-intent-danger::after,
        .bp3-dark .bp3-menu-item.bp3-intent-danger .bp3-menu-item-label{
          color:#ff7373; }
        .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active{
          background-color:#db3737; }
        .bp3-dark .bp3-menu-item.bp3-intent-danger:active{
          background-color:#c23030; }
        .bp3-dark .bp3-menu-item.bp3-intent-danger:hover, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::before, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:hover::after, .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after, .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item::after,
        .bp3-dark .bp3-menu-item.bp3-intent-danger:hover .bp3-menu-item-label,
        .bp3-dark .bp3-submenu .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label,
        .bp3-submenu .bp3-dark .bp3-popover-target.bp3-popover-open > .bp3-intent-danger.bp3-menu-item .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger:active, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger:active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-danger:active .bp3-menu-item-label, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::before, .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active::after,
        .bp3-dark .bp3-menu-item.bp3-intent-danger.bp3-active .bp3-menu-item-label{
          color:#ffffff; }
      .bp3-dark .bp3-menu-item::before,
      .bp3-dark .bp3-menu-item > .bp3-icon{
        color:#a7b6c2; }
      .bp3-dark .bp3-menu-item .bp3-menu-item-label{
        color:#a7b6c2; }
      .bp3-dark .bp3-menu-item.bp3-active, .bp3-dark .bp3-menu-item:active{
        background-color:rgba(138, 155, 168, 0.3); }
      .bp3-dark .bp3-menu-item.bp3-disabled{
        color:rgba(167, 182, 194, 0.6) !important; }
        .bp3-dark .bp3-menu-item.bp3-disabled::before,
        .bp3-dark .bp3-menu-item.bp3-disabled > .bp3-icon,
        .bp3-dark .bp3-menu-item.bp3-disabled .bp3-menu-item-label{
          color:rgba(167, 182, 194, 0.6) !important; }
    
    .bp3-dark .bp3-menu-divider,
    .bp3-dark .bp3-menu-header{
      border-color:rgba(255, 255, 255, 0.15); }
    
    .bp3-dark .bp3-menu-header > h6{
      color:#f5f8fa; }
    
    .bp3-label .bp3-menu{
      margin-top:5px; }
    .bp3-navbar{
      background-color:#ffffff;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.2);
      height:50px;
      padding:0 15px;
      position:relative;
      width:100%;
      z-index:10; }
      .bp3-navbar.bp3-dark,
      .bp3-dark .bp3-navbar{
        background-color:#394b59; }
      .bp3-navbar.bp3-dark{
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-dark .bp3-navbar{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 0 0 rgba(16, 22, 26, 0), 0 1px 1px rgba(16, 22, 26, 0.4); }
      .bp3-navbar.bp3-fixed-top{
        left:0;
        position:fixed;
        right:0;
        top:0; }
    
    .bp3-navbar-heading{
      font-size:16px;
      margin-right:15px; }
    
    .bp3-navbar-group{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      height:50px; }
      .bp3-navbar-group.bp3-align-left{
        float:left; }
      .bp3-navbar-group.bp3-align-right{
        float:right; }
    
    .bp3-navbar-divider{
      border-left:1px solid rgba(16, 22, 26, 0.15);
      height:20px;
      margin:0 10px; }
      .bp3-dark .bp3-navbar-divider{
        border-left-color:rgba(255, 255, 255, 0.15); }
    .bp3-non-ideal-state{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      height:100%;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      text-align:center;
      width:100%; }
      .bp3-non-ideal-state > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-non-ideal-state > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-non-ideal-state::before,
      .bp3-non-ideal-state > *{
        margin-bottom:20px; }
      .bp3-non-ideal-state:empty::before,
      .bp3-non-ideal-state > :last-child{
        margin-bottom:0; }
      .bp3-non-ideal-state > *{
        max-width:400px; }
    
    .bp3-non-ideal-state-visual{
      color:rgba(92, 112, 128, 0.6);
      font-size:60px; }
      .bp3-dark .bp3-non-ideal-state-visual{
        color:rgba(167, 182, 194, 0.6); }
    
    .bp3-overflow-list{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -ms-flex-wrap:nowrap;
          flex-wrap:nowrap;
      min-width:0; }
    
    .bp3-overflow-list-spacer{
      -ms-flex-negative:1;
          flex-shrink:1;
      width:1px; }
    
    body.bp3-overlay-open{
      overflow:hidden; }
    
    .bp3-overlay{
      bottom:0;
      left:0;
      position:static;
      right:0;
      top:0;
      z-index:20; }
      .bp3-overlay:not(.bp3-overlay-open){
        pointer-events:none; }
      .bp3-overlay.bp3-overlay-container{
        overflow:hidden;
        position:fixed; }
        .bp3-overlay.bp3-overlay-container.bp3-overlay-inline{
          position:absolute; }
      .bp3-overlay.bp3-overlay-scroll-container{
        overflow:auto;
        position:fixed; }
        .bp3-overlay.bp3-overlay-scroll-container.bp3-overlay-inline{
          position:absolute; }
      .bp3-overlay.bp3-overlay-inline{
        display:inline;
        overflow:visible; }
    
    .bp3-overlay-content{
      position:fixed;
      z-index:20; }
      .bp3-overlay-inline .bp3-overlay-content,
      .bp3-overlay-scroll-container .bp3-overlay-content{
        position:absolute; }
    
    .bp3-overlay-backdrop{
      bottom:0;
      left:0;
      position:fixed;
      right:0;
      top:0;
      opacity:1;
      background-color:rgba(16, 22, 26, 0.7);
      overflow:auto;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none;
      z-index:20; }
      .bp3-overlay-backdrop.bp3-overlay-enter, .bp3-overlay-backdrop.bp3-overlay-appear{
        opacity:0; }
      .bp3-overlay-backdrop.bp3-overlay-enter-active, .bp3-overlay-backdrop.bp3-overlay-appear-active{
        opacity:1;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:200ms;
                transition-duration:200ms;
        -webkit-transition-property:opacity;
        transition-property:opacity;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-overlay-backdrop.bp3-overlay-exit{
        opacity:1; }
      .bp3-overlay-backdrop.bp3-overlay-exit-active{
        opacity:0;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:200ms;
                transition-duration:200ms;
        -webkit-transition-property:opacity;
        transition-property:opacity;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-overlay-backdrop:focus{
        outline:none; }
      .bp3-overlay-inline .bp3-overlay-backdrop{
        position:absolute; }
    .bp3-panel-stack{
      overflow:hidden;
      position:relative; }
    
    .bp3-panel-stack-header{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15);
              box-shadow:0 1px rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -ms-flex-negative:0;
          flex-shrink:0;
      height:30px;
      z-index:1; }
      .bp3-dark .bp3-panel-stack-header{
        -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15);
                box-shadow:0 1px rgba(255, 255, 255, 0.15); }
      .bp3-panel-stack-header > span{
        -webkit-box-align:stretch;
            -ms-flex-align:stretch;
                align-items:stretch;
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        -webkit-box-flex:1;
            -ms-flex:1;
                flex:1; }
      .bp3-panel-stack-header .bp3-heading{
        margin:0 5px; }
    
    .bp3-button.bp3-panel-stack-header-back{
      margin-left:5px;
      padding-left:0;
      white-space:nowrap; }
      .bp3-button.bp3-panel-stack-header-back .bp3-icon{
        margin:0 2px; }
    
    .bp3-panel-stack-view{
      bottom:0;
      left:0;
      position:absolute;
      right:0;
      top:0;
      background-color:#ffffff;
      border-right:1px solid rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      margin-right:-1px;
      overflow-y:auto;
      z-index:1; }
      .bp3-dark .bp3-panel-stack-view{
        background-color:#30404d; }
      .bp3-panel-stack-view:nth-last-child(n + 4){
        display:none; }
    
    .bp3-panel-stack-push .bp3-panel-stack-enter, .bp3-panel-stack-push .bp3-panel-stack-appear{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      opacity:0; }
    
    .bp3-panel-stack-push .bp3-panel-stack-enter-active, .bp3-panel-stack-push .bp3-panel-stack-appear-active{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack-push .bp3-panel-stack-exit{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1; }
    
    .bp3-panel-stack-push .bp3-panel-stack-exit-active{
      -webkit-transform:translateX(-50%);
              transform:translateX(-50%);
      opacity:0;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack-pop .bp3-panel-stack-enter, .bp3-panel-stack-pop .bp3-panel-stack-appear{
      -webkit-transform:translateX(-50%);
              transform:translateX(-50%);
      opacity:0; }
    
    .bp3-panel-stack-pop .bp3-panel-stack-enter-active, .bp3-panel-stack-pop .bp3-panel-stack-appear-active{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack-pop .bp3-panel-stack-exit{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1; }
    
    .bp3-panel-stack-pop .bp3-panel-stack-exit-active{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      opacity:0;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    .bp3-panel-stack2{
      overflow:hidden;
      position:relative; }
    
    .bp3-panel-stack2-header{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      -webkit-box-shadow:0 1px rgba(16, 22, 26, 0.15);
              box-shadow:0 1px rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -ms-flex-negative:0;
          flex-shrink:0;
      height:30px;
      z-index:1; }
      .bp3-dark .bp3-panel-stack2-header{
        -webkit-box-shadow:0 1px rgba(255, 255, 255, 0.15);
                box-shadow:0 1px rgba(255, 255, 255, 0.15); }
      .bp3-panel-stack2-header > span{
        -webkit-box-align:stretch;
            -ms-flex-align:stretch;
                align-items:stretch;
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        -webkit-box-flex:1;
            -ms-flex:1;
                flex:1; }
      .bp3-panel-stack2-header .bp3-heading{
        margin:0 5px; }
    
    .bp3-button.bp3-panel-stack2-header-back{
      margin-left:5px;
      padding-left:0;
      white-space:nowrap; }
      .bp3-button.bp3-panel-stack2-header-back .bp3-icon{
        margin:0 2px; }
    
    .bp3-panel-stack2-view{
      bottom:0;
      left:0;
      position:absolute;
      right:0;
      top:0;
      background-color:#ffffff;
      border-right:1px solid rgba(16, 22, 26, 0.15);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      margin-right:-1px;
      overflow-y:auto;
      z-index:1; }
      .bp3-dark .bp3-panel-stack2-view{
        background-color:#30404d; }
      .bp3-panel-stack2-view:nth-last-child(n + 4){
        display:none; }
    
    .bp3-panel-stack2-push .bp3-panel-stack2-enter, .bp3-panel-stack2-push .bp3-panel-stack2-appear{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      opacity:0; }
    
    .bp3-panel-stack2-push .bp3-panel-stack2-enter-active, .bp3-panel-stack2-push .bp3-panel-stack2-appear-active{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack2-push .bp3-panel-stack2-exit{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1; }
    
    .bp3-panel-stack2-push .bp3-panel-stack2-exit-active{
      -webkit-transform:translateX(-50%);
              transform:translateX(-50%);
      opacity:0;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack2-pop .bp3-panel-stack2-enter, .bp3-panel-stack2-pop .bp3-panel-stack2-appear{
      -webkit-transform:translateX(-50%);
              transform:translateX(-50%);
      opacity:0; }
    
    .bp3-panel-stack2-pop .bp3-panel-stack2-enter-active, .bp3-panel-stack2-pop .bp3-panel-stack2-appear-active{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    
    .bp3-panel-stack2-pop .bp3-panel-stack2-exit{
      -webkit-transform:translate(0%);
              transform:translate(0%);
      opacity:1; }
    
    .bp3-panel-stack2-pop .bp3-panel-stack2-exit-active{
      -webkit-transform:translateX(100%);
              transform:translateX(100%);
      opacity:0;
      -webkit-transition-delay:0;
              transition-delay:0;
      -webkit-transition-duration:400ms;
              transition-duration:400ms;
      -webkit-transition-property:opacity, -webkit-transform;
      transition-property:opacity, -webkit-transform;
      transition-property:transform, opacity;
      transition-property:transform, opacity, -webkit-transform;
      -webkit-transition-timing-function:ease;
              transition-timing-function:ease; }
    .bp3-popover{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
      -webkit-transform:scale(1);
              transform:scale(1);
      border-radius:3px;
      display:inline-block;
      z-index:20; }
      .bp3-popover .bp3-popover-arrow{
        height:30px;
        position:absolute;
        width:30px; }
        .bp3-popover .bp3-popover-arrow::before{
          height:20px;
          margin:5px;
          width:20px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover{
        margin-bottom:17px;
        margin-top:-17px; }
        .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{
          bottom:-11px; }
          .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow svg{
            -webkit-transform:rotate(-90deg);
                    transform:rotate(-90deg); }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover{
        margin-left:17px; }
        .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{
          left:-11px; }
          .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow svg{
            -webkit-transform:rotate(0);
                    transform:rotate(0); }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover{
        margin-top:17px; }
        .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{
          top:-11px; }
          .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow svg{
            -webkit-transform:rotate(90deg);
                    transform:rotate(90deg); }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover{
        margin-left:-17px;
        margin-right:17px; }
        .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{
          right:-11px; }
          .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow svg{
            -webkit-transform:rotate(180deg);
                    transform:rotate(180deg); }
      .bp3-tether-element-attached-middle > .bp3-popover > .bp3-popover-arrow{
        top:50%;
        -webkit-transform:translateY(-50%);
                transform:translateY(-50%); }
      .bp3-tether-element-attached-center > .bp3-popover > .bp3-popover-arrow{
        right:50%;
        -webkit-transform:translateX(50%);
                transform:translateX(50%); }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-popover > .bp3-popover-arrow{
        top:-0.3934px; }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-popover > .bp3-popover-arrow{
        right:-0.3934px; }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-popover > .bp3-popover-arrow{
        left:-0.3934px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-popover > .bp3-popover-arrow{
        bottom:-0.3934px; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-popover{
        -webkit-transform-origin:top left;
                transform-origin:top left; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-popover{
        -webkit-transform-origin:top center;
                transform-origin:top center; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-popover{
        -webkit-transform-origin:top right;
                transform-origin:top right; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-popover{
        -webkit-transform-origin:center left;
                transform-origin:center left; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-popover{
        -webkit-transform-origin:center center;
                transform-origin:center center; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-popover{
        -webkit-transform-origin:center right;
                transform-origin:center right; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-popover{
        -webkit-transform-origin:bottom left;
                transform-origin:bottom left; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-popover{
        -webkit-transform-origin:bottom center;
                transform-origin:bottom center; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-popover{
        -webkit-transform-origin:bottom right;
                transform-origin:bottom right; }
      .bp3-popover .bp3-popover-content{
        background:#ffffff;
        color:inherit; }
      .bp3-popover .bp3-popover-arrow::before{
        -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2);
                box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); }
      .bp3-popover .bp3-popover-arrow-border{
        fill:#10161a;
        fill-opacity:0.1; }
      .bp3-popover .bp3-popover-arrow-fill{
        fill:#ffffff; }
      .bp3-popover-enter > .bp3-popover, .bp3-popover-appear > .bp3-popover{
        -webkit-transform:scale(0.3);
                transform:scale(0.3); }
      .bp3-popover-enter-active > .bp3-popover, .bp3-popover-appear-active > .bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
      .bp3-popover-exit > .bp3-popover{
        -webkit-transform:scale(1);
                transform:scale(1); }
      .bp3-popover-exit-active > .bp3-popover{
        -webkit-transform:scale(0.3);
                transform:scale(0.3);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
      .bp3-popover .bp3-popover-content{
        border-radius:3px;
        position:relative; }
      .bp3-popover.bp3-popover-content-sizing .bp3-popover-content{
        max-width:350px;
        padding:20px; }
      .bp3-popover-target + .bp3-overlay .bp3-popover.bp3-popover-content-sizing{
        width:350px; }
      .bp3-popover.bp3-minimal{
        margin:0 !important; }
        .bp3-popover.bp3-minimal .bp3-popover-arrow{
          display:none; }
        .bp3-popover.bp3-minimal.bp3-popover{
          -webkit-transform:scale(1);
                  transform:scale(1); }
          .bp3-popover-enter > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear > .bp3-popover.bp3-minimal.bp3-popover{
            -webkit-transform:scale(1);
                    transform:scale(1); }
          .bp3-popover-enter-active > .bp3-popover.bp3-minimal.bp3-popover, .bp3-popover-appear-active > .bp3-popover.bp3-minimal.bp3-popover{
            -webkit-transform:scale(1);
                    transform:scale(1);
            -webkit-transition-delay:0;
                    transition-delay:0;
            -webkit-transition-duration:100ms;
                    transition-duration:100ms;
            -webkit-transition-property:-webkit-transform;
            transition-property:-webkit-transform;
            transition-property:transform;
            transition-property:transform, -webkit-transform;
            -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                    transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
          .bp3-popover-exit > .bp3-popover.bp3-minimal.bp3-popover{
            -webkit-transform:scale(1);
                    transform:scale(1); }
          .bp3-popover-exit-active > .bp3-popover.bp3-minimal.bp3-popover{
            -webkit-transform:scale(1);
                    transform:scale(1);
            -webkit-transition-delay:0;
                    transition-delay:0;
            -webkit-transition-duration:100ms;
                    transition-duration:100ms;
            -webkit-transition-property:-webkit-transform;
            transition-property:-webkit-transform;
            transition-property:transform;
            transition-property:transform, -webkit-transform;
            -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                    transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-popover.bp3-dark,
      .bp3-dark .bp3-popover{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
        .bp3-popover.bp3-dark .bp3-popover-content,
        .bp3-dark .bp3-popover .bp3-popover-content{
          background:#30404d;
          color:inherit; }
        .bp3-popover.bp3-dark .bp3-popover-arrow::before,
        .bp3-dark .bp3-popover .bp3-popover-arrow::before{
          -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4);
                  box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); }
        .bp3-popover.bp3-dark .bp3-popover-arrow-border,
        .bp3-dark .bp3-popover .bp3-popover-arrow-border{
          fill:#10161a;
          fill-opacity:0.2; }
        .bp3-popover.bp3-dark .bp3-popover-arrow-fill,
        .bp3-dark .bp3-popover .bp3-popover-arrow-fill{
          fill:#30404d; }
    
    .bp3-popover-arrow::before{
      border-radius:2px;
      content:"";
      display:block;
      position:absolute;
      -webkit-transform:rotate(45deg);
              transform:rotate(45deg); }
    
    .bp3-tether-pinned .bp3-popover-arrow{
      display:none; }
    
    .bp3-popover-backdrop{
      background:rgba(255, 255, 255, 0); }
    
    .bp3-transition-container{
      opacity:1;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      z-index:20; }
      .bp3-transition-container.bp3-popover-enter, .bp3-transition-container.bp3-popover-appear{
        opacity:0; }
      .bp3-transition-container.bp3-popover-enter-active, .bp3-transition-container.bp3-popover-appear-active{
        opacity:1;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:opacity;
        transition-property:opacity;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-transition-container.bp3-popover-exit{
        opacity:1; }
      .bp3-transition-container.bp3-popover-exit-active{
        opacity:0;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:opacity;
        transition-property:opacity;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-transition-container:focus{
        outline:none; }
      .bp3-transition-container.bp3-popover-leave .bp3-popover-content{
        pointer-events:none; }
      .bp3-transition-container[data-x-out-of-boundaries]{
        display:none; }
    
    span.bp3-popover-target{
      display:inline-block; }
    
    .bp3-popover-wrapper.bp3-fill{
      width:100%; }
    
    .bp3-portal{
      left:0;
      position:absolute;
      right:0;
      top:0; }
    @-webkit-keyframes linear-progress-bar-stripes{
      from{
        background-position:0 0; }
      to{
        background-position:30px 0; } }
    @keyframes linear-progress-bar-stripes{
      from{
        background-position:0 0; }
      to{
        background-position:30px 0; } }
    
    .bp3-progress-bar{
      background:rgba(92, 112, 128, 0.2);
      border-radius:40px;
      display:block;
      height:8px;
      overflow:hidden;
      position:relative;
      width:100%; }
      .bp3-progress-bar .bp3-progress-meter{
        background:linear-gradient(-45deg, rgba(255, 255, 255, 0.2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.2) 50%, rgba(255, 255, 255, 0.2) 75%, transparent 75%);
        background-color:rgba(92, 112, 128, 0.8);
        background-size:30px 30px;
        border-radius:40px;
        height:100%;
        position:absolute;
        -webkit-transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:width 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        width:100%; }
      .bp3-progress-bar:not(.bp3-no-animation):not(.bp3-no-stripes) .bp3-progress-meter{
        animation:linear-progress-bar-stripes 300ms linear infinite reverse; }
      .bp3-progress-bar.bp3-no-stripes .bp3-progress-meter{
        background-image:none; }
    
    .bp3-dark .bp3-progress-bar{
      background:rgba(16, 22, 26, 0.5); }
      .bp3-dark .bp3-progress-bar .bp3-progress-meter{
        background-color:#8a9ba8; }
    
    .bp3-progress-bar.bp3-intent-primary .bp3-progress-meter{
      background-color:#137cbd; }
    
    .bp3-progress-bar.bp3-intent-success .bp3-progress-meter{
      background-color:#0f9960; }
    
    .bp3-progress-bar.bp3-intent-warning .bp3-progress-meter{
      background-color:#d9822b; }
    
    .bp3-progress-bar.bp3-intent-danger .bp3-progress-meter{
      background-color:#db3737; }
    @-webkit-keyframes skeleton-glow{
      from{
        background:rgba(206, 217, 224, 0.2);
        border-color:rgba(206, 217, 224, 0.2); }
      to{
        background:rgba(92, 112, 128, 0.2);
        border-color:rgba(92, 112, 128, 0.2); } }
    @keyframes skeleton-glow{
      from{
        background:rgba(206, 217, 224, 0.2);
        border-color:rgba(206, 217, 224, 0.2); }
      to{
        background:rgba(92, 112, 128, 0.2);
        border-color:rgba(92, 112, 128, 0.2); } }
    .bp3-skeleton{
      -webkit-animation:1000ms linear infinite alternate skeleton-glow;
              animation:1000ms linear infinite alternate skeleton-glow;
      background:rgba(206, 217, 224, 0.2);
      background-clip:padding-box !important;
      border-color:rgba(206, 217, 224, 0.2) !important;
      border-radius:2px;
      -webkit-box-shadow:none !important;
              box-shadow:none !important;
      color:transparent !important;
      cursor:default;
      pointer-events:none;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-skeleton::before, .bp3-skeleton::after,
      .bp3-skeleton *{
        visibility:hidden !important; }
    .bp3-slider{
      height:40px;
      min-width:150px;
      width:100%;
      cursor:default;
      outline:none;
      position:relative;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-slider:hover{
        cursor:pointer; }
      .bp3-slider:active{
        cursor:-webkit-grabbing;
        cursor:grabbing; }
      .bp3-slider.bp3-disabled{
        cursor:not-allowed;
        opacity:0.5; }
      .bp3-slider.bp3-slider-unlabeled{
        height:16px; }
    
    .bp3-slider-track,
    .bp3-slider-progress{
      height:6px;
      left:0;
      right:0;
      top:5px;
      position:absolute; }
    
    .bp3-slider-track{
      border-radius:3px;
      overflow:hidden; }
    
    .bp3-slider-progress{
      background:rgba(92, 112, 128, 0.2); }
      .bp3-dark .bp3-slider-progress{
        background:rgba(16, 22, 26, 0.5); }
      .bp3-slider-progress.bp3-intent-primary{
        background-color:#137cbd; }
      .bp3-slider-progress.bp3-intent-success{
        background-color:#0f9960; }
      .bp3-slider-progress.bp3-intent-warning{
        background-color:#d9822b; }
      .bp3-slider-progress.bp3-intent-danger{
        background-color:#db3737; }
    
    .bp3-slider-handle{
      background-color:#f5f8fa;
      background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.8)), to(rgba(255, 255, 255, 0)));
      background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0));
      -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
              box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
      color:#182026;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
      cursor:pointer;
      height:16px;
      left:0;
      position:absolute;
      top:0;
      width:16px; }
      .bp3-slider-handle:hover{
        background-clip:padding-box;
        background-color:#ebf1f5;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1); }
      .bp3-slider-handle:active, .bp3-slider-handle.bp3-active{
        background-color:#d8e1e8;
        background-image:none;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
      .bp3-slider-handle:disabled, .bp3-slider-handle.bp3-disabled{
        background-color:rgba(206, 217, 224, 0.5);
        background-image:none;
        -webkit-box-shadow:none;
                box-shadow:none;
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed;
        outline:none; }
        .bp3-slider-handle:disabled.bp3-active, .bp3-slider-handle:disabled.bp3-active:hover, .bp3-slider-handle.bp3-disabled.bp3-active, .bp3-slider-handle.bp3-disabled.bp3-active:hover{
          background:rgba(206, 217, 224, 0.7); }
      .bp3-slider-handle:focus{
        z-index:1; }
      .bp3-slider-handle:hover{
        background-clip:padding-box;
        background-color:#ebf1f5;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 -1px 0 rgba(16, 22, 26, 0.1);
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 1px 1px rgba(16, 22, 26, 0.2);
        cursor:-webkit-grab;
        cursor:grab;
        z-index:2; }
      .bp3-slider-handle.bp3-active{
        background-color:#d8e1e8;
        background-image:none;
        -webkit-box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                box-shadow:inset 0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 2px rgba(16, 22, 26, 0.2);
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), inset 0 1px 1px rgba(16, 22, 26, 0.1);
        cursor:-webkit-grabbing;
        cursor:grabbing; }
      .bp3-disabled .bp3-slider-handle{
        background:#bfccd6;
        -webkit-box-shadow:none;
                box-shadow:none;
        pointer-events:none; }
      .bp3-dark .bp3-slider-handle{
        background-color:#394b59;
        background-image:-webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0.05)), to(rgba(255, 255, 255, 0)));
        background-image:linear-gradient(to bottom, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0));
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
        color:#f5f8fa; }
        .bp3-dark .bp3-slider-handle:hover, .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{
          color:#f5f8fa; }
        .bp3-dark .bp3-slider-handle:hover{
          background-color:#30404d;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-slider-handle:active, .bp3-dark .bp3-slider-handle.bp3-active{
          background-color:#202b33;
          background-image:none;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.6), inset 0 1px 2px rgba(16, 22, 26, 0.2); }
        .bp3-dark .bp3-slider-handle:disabled, .bp3-dark .bp3-slider-handle.bp3-disabled{
          background-color:rgba(57, 75, 89, 0.5);
          background-image:none;
          -webkit-box-shadow:none;
                  box-shadow:none;
          color:rgba(167, 182, 194, 0.6); }
          .bp3-dark .bp3-slider-handle:disabled.bp3-active, .bp3-dark .bp3-slider-handle.bp3-disabled.bp3-active{
            background:rgba(57, 75, 89, 0.7); }
        .bp3-dark .bp3-slider-handle .bp3-button-spinner .bp3-spinner-head{
          background:rgba(16, 22, 26, 0.5);
          stroke:#8a9ba8; }
        .bp3-dark .bp3-slider-handle, .bp3-dark .bp3-slider-handle:hover{
          background-color:#394b59; }
        .bp3-dark .bp3-slider-handle.bp3-active{
          background-color:#293742; }
      .bp3-dark .bp3-disabled .bp3-slider-handle{
        background:#5c7080;
        border-color:#5c7080;
        -webkit-box-shadow:none;
                box-shadow:none; }
      .bp3-slider-handle .bp3-slider-label{
        background:#394b59;
        border-radius:3px;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
        color:#f5f8fa;
        margin-left:8px; }
        .bp3-dark .bp3-slider-handle .bp3-slider-label{
          background:#e1e8ed;
          -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
          color:#394b59; }
        .bp3-disabled .bp3-slider-handle .bp3-slider-label{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-slider-handle.bp3-start, .bp3-slider-handle.bp3-end{
        width:8px; }
      .bp3-slider-handle.bp3-start{
        border-bottom-right-radius:0;
        border-top-right-radius:0; }
      .bp3-slider-handle.bp3-end{
        border-bottom-left-radius:0;
        border-top-left-radius:0;
        margin-left:8px; }
        .bp3-slider-handle.bp3-end .bp3-slider-label{
          margin-left:0; }
    
    .bp3-slider-label{
      -webkit-transform:translate(-50%, 20px);
              transform:translate(-50%, 20px);
      display:inline-block;
      font-size:12px;
      line-height:1;
      padding:2px 5px;
      position:absolute;
      vertical-align:top; }
    
    .bp3-slider.bp3-vertical{
      height:150px;
      min-width:40px;
      width:40px; }
      .bp3-slider.bp3-vertical .bp3-slider-track,
      .bp3-slider.bp3-vertical .bp3-slider-progress{
        bottom:0;
        height:auto;
        left:5px;
        top:0;
        width:6px; }
      .bp3-slider.bp3-vertical .bp3-slider-progress{
        top:auto; }
      .bp3-slider.bp3-vertical .bp3-slider-label{
        -webkit-transform:translate(20px, 50%);
                transform:translate(20px, 50%); }
      .bp3-slider.bp3-vertical .bp3-slider-handle{
        top:auto; }
        .bp3-slider.bp3-vertical .bp3-slider-handle .bp3-slider-label{
          margin-left:0;
          margin-top:-8px; }
        .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end, .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
          height:8px;
          margin-left:0;
          width:16px; }
        .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start{
          border-bottom-right-radius:3px;
          border-top-left-radius:0; }
          .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-start .bp3-slider-label{
            -webkit-transform:translate(20px);
                    transform:translate(20px); }
        .bp3-slider.bp3-vertical .bp3-slider-handle.bp3-end{
          border-bottom-left-radius:0;
          border-bottom-right-radius:0;
          border-top-left-radius:3px;
          margin-bottom:8px; }
    
    @-webkit-keyframes pt-spinner-animation{
      from{
        -webkit-transform:rotate(0deg);
                transform:rotate(0deg); }
      to{
        -webkit-transform:rotate(360deg);
                transform:rotate(360deg); } }
    
    @keyframes pt-spinner-animation{
      from{
        -webkit-transform:rotate(0deg);
                transform:rotate(0deg); }
      to{
        -webkit-transform:rotate(360deg);
                transform:rotate(360deg); } }
    
    .bp3-spinner{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-pack:center;
          -ms-flex-pack:center;
              justify-content:center;
      overflow:visible;
      vertical-align:middle; }
      .bp3-spinner svg{
        display:block; }
      .bp3-spinner path{
        fill-opacity:0; }
      .bp3-spinner .bp3-spinner-head{
        stroke:rgba(92, 112, 128, 0.8);
        stroke-linecap:round;
        -webkit-transform-origin:center;
                transform-origin:center;
        -webkit-transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
        transition:stroke-dashoffset 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-spinner .bp3-spinner-track{
        stroke:rgba(92, 112, 128, 0.2); }
    
    .bp3-spinner-animation{
      -webkit-animation:pt-spinner-animation 500ms linear infinite;
              animation:pt-spinner-animation 500ms linear infinite; }
      .bp3-no-spin > .bp3-spinner-animation{
        -webkit-animation:none;
                animation:none; }
    
    .bp3-dark .bp3-spinner .bp3-spinner-head{
      stroke:#8a9ba8; }
    
    .bp3-dark .bp3-spinner .bp3-spinner-track{
      stroke:rgba(16, 22, 26, 0.5); }
    
    .bp3-spinner.bp3-intent-primary .bp3-spinner-head{
      stroke:#137cbd; }
    
    .bp3-spinner.bp3-intent-success .bp3-spinner-head{
      stroke:#0f9960; }
    
    .bp3-spinner.bp3-intent-warning .bp3-spinner-head{
      stroke:#d9822b; }
    
    .bp3-spinner.bp3-intent-danger .bp3-spinner-head{
      stroke:#db3737; }
    .bp3-tabs.bp3-vertical{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex; }
      .bp3-tabs.bp3-vertical > .bp3-tab-list{
        -webkit-box-align:start;
            -ms-flex-align:start;
                align-items:flex-start;
        -webkit-box-orient:vertical;
        -webkit-box-direction:normal;
            -ms-flex-direction:column;
                flex-direction:column; }
        .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab{
          border-radius:3px;
          padding:0 10px;
          width:100%; }
          .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab[aria-selected="true"]{
            background-color:rgba(19, 124, 189, 0.2);
            -webkit-box-shadow:none;
                    box-shadow:none; }
        .bp3-tabs.bp3-vertical > .bp3-tab-list .bp3-tab-indicator-wrapper .bp3-tab-indicator{
          background-color:rgba(19, 124, 189, 0.2);
          border-radius:3px;
          bottom:0;
          height:auto;
          left:0;
          right:0;
          top:0; }
      .bp3-tabs.bp3-vertical > .bp3-tab-panel{
        margin-top:0;
        padding-left:20px; }
    
    .bp3-tab-list{
      -webkit-box-align:end;
          -ms-flex-align:end;
              align-items:flex-end;
      border:none;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      list-style:none;
      margin:0;
      padding:0;
      position:relative; }
      .bp3-tab-list > *:not(:last-child){
        margin-right:20px; }
    
    .bp3-tab{
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
      word-wrap:normal;
      color:#182026;
      cursor:pointer;
      -webkit-box-flex:0;
          -ms-flex:0 0 auto;
              flex:0 0 auto;
      font-size:14px;
      line-height:30px;
      max-width:100%;
      position:relative;
      vertical-align:top; }
      .bp3-tab a{
        color:inherit;
        display:block;
        text-decoration:none; }
      .bp3-tab-indicator-wrapper ~ .bp3-tab{
        background-color:transparent !important;
        -webkit-box-shadow:none !important;
                box-shadow:none !important; }
      .bp3-tab[aria-disabled="true"]{
        color:rgba(92, 112, 128, 0.6);
        cursor:not-allowed; }
      .bp3-tab[aria-selected="true"]{
        border-radius:0;
        -webkit-box-shadow:inset 0 -3px 0 #106ba3;
                box-shadow:inset 0 -3px 0 #106ba3; }
      .bp3-tab[aria-selected="true"], .bp3-tab:not([aria-disabled="true"]):hover{
        color:#106ba3; }
      .bp3-tab:focus{
        -moz-outline-radius:0; }
      .bp3-large > .bp3-tab{
        font-size:16px;
        line-height:40px; }
    
    .bp3-tab-panel{
      margin-top:20px; }
      .bp3-tab-panel[aria-hidden="true"]{
        display:none; }
    
    .bp3-tab-indicator-wrapper{
      left:0;
      pointer-events:none;
      position:absolute;
      top:0;
      -webkit-transform:translateX(0), translateY(0);
              transform:translateX(0), translateY(0);
      -webkit-transition:height, width, -webkit-transform;
      transition:height, width, -webkit-transform;
      transition:height, transform, width;
      transition:height, transform, width, -webkit-transform;
      -webkit-transition-duration:200ms;
              transition-duration:200ms;
      -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
              transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-tab-indicator-wrapper .bp3-tab-indicator{
        background-color:#106ba3;
        bottom:0;
        height:3px;
        left:0;
        position:absolute;
        right:0; }
      .bp3-tab-indicator-wrapper.bp3-no-animation{
        -webkit-transition:none;
        transition:none; }
    
    .bp3-dark .bp3-tab{
      color:#f5f8fa; }
      .bp3-dark .bp3-tab[aria-disabled="true"]{
        color:rgba(167, 182, 194, 0.6); }
      .bp3-dark .bp3-tab[aria-selected="true"]{
        -webkit-box-shadow:inset 0 -3px 0 #48aff0;
                box-shadow:inset 0 -3px 0 #48aff0; }
      .bp3-dark .bp3-tab[aria-selected="true"], .bp3-dark .bp3-tab:not([aria-disabled="true"]):hover{
        color:#48aff0; }
    
    .bp3-dark .bp3-tab-indicator{
      background-color:#48aff0; }
    
    .bp3-flex-expander{
      -webkit-box-flex:1;
          -ms-flex:1 1;
              flex:1 1; }
    .bp3-tag{
      display:-webkit-inline-box;
      display:-ms-inline-flexbox;
      display:inline-flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      background-color:#5c7080;
      border:none;
      border-radius:3px;
      -webkit-box-shadow:none;
              box-shadow:none;
      color:#f5f8fa;
      font-size:12px;
      line-height:16px;
      max-width:100%;
      min-height:20px;
      min-width:20px;
      padding:2px 6px;
      position:relative; }
      .bp3-tag.bp3-interactive{
        cursor:pointer; }
        .bp3-tag.bp3-interactive:hover{
          background-color:rgba(92, 112, 128, 0.85); }
        .bp3-tag.bp3-interactive.bp3-active, .bp3-tag.bp3-interactive:active{
          background-color:rgba(92, 112, 128, 0.7); }
      .bp3-tag > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-tag > .bp3-fill{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-tag::before,
      .bp3-tag > *{
        margin-right:4px; }
      .bp3-tag:empty::before,
      .bp3-tag > :last-child{
        margin-right:0; }
      .bp3-tag:focus{
        outline:rgba(19, 124, 189, 0.6) auto 2px;
        outline-offset:0;
        -moz-outline-radius:6px; }
      .bp3-tag.bp3-round{
        border-radius:30px;
        padding-left:8px;
        padding-right:8px; }
      .bp3-dark .bp3-tag{
        background-color:#bfccd6;
        color:#182026; }
        .bp3-dark .bp3-tag.bp3-interactive{
          cursor:pointer; }
          .bp3-dark .bp3-tag.bp3-interactive:hover{
            background-color:rgba(191, 204, 214, 0.85); }
          .bp3-dark .bp3-tag.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-interactive:active{
            background-color:rgba(191, 204, 214, 0.7); }
        .bp3-dark .bp3-tag > .bp3-icon, .bp3-dark .bp3-tag .bp3-icon-standard, .bp3-dark .bp3-tag .bp3-icon-large{
          fill:currentColor; }
      .bp3-tag > .bp3-icon, .bp3-tag .bp3-icon-standard, .bp3-tag .bp3-icon-large{
        fill:#ffffff; }
      .bp3-tag.bp3-large,
      .bp3-large .bp3-tag{
        font-size:14px;
        line-height:20px;
        min-height:30px;
        min-width:30px;
        padding:5px 10px; }
        .bp3-tag.bp3-large::before,
        .bp3-tag.bp3-large > *,
        .bp3-large .bp3-tag::before,
        .bp3-large .bp3-tag > *{
          margin-right:7px; }
        .bp3-tag.bp3-large:empty::before,
        .bp3-tag.bp3-large > :last-child,
        .bp3-large .bp3-tag:empty::before,
        .bp3-large .bp3-tag > :last-child{
          margin-right:0; }
        .bp3-tag.bp3-large.bp3-round,
        .bp3-large .bp3-tag.bp3-round{
          padding-left:12px;
          padding-right:12px; }
      .bp3-tag.bp3-intent-primary{
        background:#137cbd;
        color:#ffffff; }
        .bp3-tag.bp3-intent-primary.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-intent-primary.bp3-interactive:hover{
            background-color:rgba(19, 124, 189, 0.85); }
          .bp3-tag.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-primary.bp3-interactive:active{
            background-color:rgba(19, 124, 189, 0.7); }
      .bp3-tag.bp3-intent-success{
        background:#0f9960;
        color:#ffffff; }
        .bp3-tag.bp3-intent-success.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-intent-success.bp3-interactive:hover{
            background-color:rgba(15, 153, 96, 0.85); }
          .bp3-tag.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-success.bp3-interactive:active{
            background-color:rgba(15, 153, 96, 0.7); }
      .bp3-tag.bp3-intent-warning{
        background:#d9822b;
        color:#ffffff; }
        .bp3-tag.bp3-intent-warning.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-intent-warning.bp3-interactive:hover{
            background-color:rgba(217, 130, 43, 0.85); }
          .bp3-tag.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-warning.bp3-interactive:active{
            background-color:rgba(217, 130, 43, 0.7); }
      .bp3-tag.bp3-intent-danger{
        background:#db3737;
        color:#ffffff; }
        .bp3-tag.bp3-intent-danger.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-intent-danger.bp3-interactive:hover{
            background-color:rgba(219, 55, 55, 0.85); }
          .bp3-tag.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-intent-danger.bp3-interactive:active{
            background-color:rgba(219, 55, 55, 0.7); }
      .bp3-tag.bp3-fill{
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        width:100%; }
      .bp3-tag.bp3-minimal > .bp3-icon, .bp3-tag.bp3-minimal .bp3-icon-standard, .bp3-tag.bp3-minimal .bp3-icon-large{
        fill:#5c7080; }
      .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){
        background-color:rgba(138, 155, 168, 0.2);
        color:#182026; }
        .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{
            background-color:rgba(92, 112, 128, 0.3); }
          .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{
            background-color:rgba(92, 112, 128, 0.4); }
        .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]){
          color:#f5f8fa; }
          .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive{
            cursor:pointer; }
            .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:hover{
              background-color:rgba(191, 204, 214, 0.3); }
            .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]).bp3-interactive:active{
              background-color:rgba(191, 204, 214, 0.4); }
          .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) > .bp3-icon, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-standard, .bp3-dark .bp3-tag.bp3-minimal:not([class*="bp3-intent-"]) .bp3-icon-large{
            fill:#a7b6c2; }
      .bp3-tag.bp3-minimal.bp3-intent-primary{
        background-color:rgba(19, 124, 189, 0.15);
        color:#106ba3; }
        .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{
            background-color:rgba(19, 124, 189, 0.25); }
          .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{
            background-color:rgba(19, 124, 189, 0.35); }
        .bp3-tag.bp3-minimal.bp3-intent-primary > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-primary .bp3-icon-large{
          fill:#137cbd; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary{
          background-color:rgba(19, 124, 189, 0.25);
          color:#48aff0; }
          .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive{
            cursor:pointer; }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:hover{
              background-color:rgba(19, 124, 189, 0.35); }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-primary.bp3-interactive:active{
              background-color:rgba(19, 124, 189, 0.45); }
      .bp3-tag.bp3-minimal.bp3-intent-success{
        background-color:rgba(15, 153, 96, 0.15);
        color:#0d8050; }
        .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{
            background-color:rgba(15, 153, 96, 0.25); }
          .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{
            background-color:rgba(15, 153, 96, 0.35); }
        .bp3-tag.bp3-minimal.bp3-intent-success > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-success .bp3-icon-large{
          fill:#0f9960; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success{
          background-color:rgba(15, 153, 96, 0.25);
          color:#3dcc91; }
          .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive{
            cursor:pointer; }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:hover{
              background-color:rgba(15, 153, 96, 0.35); }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-success.bp3-interactive:active{
              background-color:rgba(15, 153, 96, 0.45); }
      .bp3-tag.bp3-minimal.bp3-intent-warning{
        background-color:rgba(217, 130, 43, 0.15);
        color:#bf7326; }
        .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{
            background-color:rgba(217, 130, 43, 0.25); }
          .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{
            background-color:rgba(217, 130, 43, 0.35); }
        .bp3-tag.bp3-minimal.bp3-intent-warning > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-warning .bp3-icon-large{
          fill:#d9822b; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning{
          background-color:rgba(217, 130, 43, 0.25);
          color:#ffb366; }
          .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive{
            cursor:pointer; }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:hover{
              background-color:rgba(217, 130, 43, 0.35); }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-warning.bp3-interactive:active{
              background-color:rgba(217, 130, 43, 0.45); }
      .bp3-tag.bp3-minimal.bp3-intent-danger{
        background-color:rgba(219, 55, 55, 0.15);
        color:#c23030; }
        .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{
          cursor:pointer; }
          .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{
            background-color:rgba(219, 55, 55, 0.25); }
          .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{
            background-color:rgba(219, 55, 55, 0.35); }
        .bp3-tag.bp3-minimal.bp3-intent-danger > .bp3-icon, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-standard, .bp3-tag.bp3-minimal.bp3-intent-danger .bp3-icon-large{
          fill:#db3737; }
        .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger{
          background-color:rgba(219, 55, 55, 0.25);
          color:#ff7373; }
          .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive{
            cursor:pointer; }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:hover{
              background-color:rgba(219, 55, 55, 0.35); }
            .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive.bp3-active, .bp3-dark .bp3-tag.bp3-minimal.bp3-intent-danger.bp3-interactive:active{
              background-color:rgba(219, 55, 55, 0.45); }
    
    .bp3-tag-remove{
      background:none;
      border:none;
      color:inherit;
      cursor:pointer;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      margin-bottom:-2px;
      margin-right:-6px !important;
      margin-top:-2px;
      opacity:0.5;
      padding:2px;
      padding-left:0; }
      .bp3-tag-remove:hover{
        background:none;
        opacity:0.8;
        text-decoration:none; }
      .bp3-tag-remove:active{
        opacity:1; }
      .bp3-tag-remove:empty::before{
        font-family:"Icons16", sans-serif;
        font-size:16px;
        font-style:normal;
        font-weight:400;
        line-height:1;
        -moz-osx-font-smoothing:grayscale;
        -webkit-font-smoothing:antialiased;
        content:""; }
      .bp3-large .bp3-tag-remove{
        margin-right:-10px !important;
        padding:0 5px 0 0; }
        .bp3-large .bp3-tag-remove:empty::before{
          font-family:"Icons20", sans-serif;
          font-size:20px;
          font-style:normal;
          font-weight:400;
          line-height:1; }
    .bp3-tag-input{
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      -webkit-box-orient:horizontal;
      -webkit-box-direction:normal;
          -ms-flex-direction:row;
              flex-direction:row;
      -webkit-box-align:start;
          -ms-flex-align:start;
              align-items:flex-start;
      cursor:text;
      height:auto;
      line-height:inherit;
      min-height:30px;
      padding-left:5px;
      padding-right:0; }
      .bp3-tag-input > *{
        -webkit-box-flex:0;
            -ms-flex-positive:0;
                flex-grow:0;
        -ms-flex-negative:0;
            flex-shrink:0; }
      .bp3-tag-input > .bp3-tag-input-values{
        -webkit-box-flex:1;
            -ms-flex-positive:1;
                flex-grow:1;
        -ms-flex-negative:1;
            flex-shrink:1; }
      .bp3-tag-input .bp3-tag-input-icon{
        color:#5c7080;
        margin-left:2px;
        margin-right:7px;
        margin-top:7px; }
      .bp3-tag-input .bp3-tag-input-values{
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex;
        -webkit-box-orient:horizontal;
        -webkit-box-direction:normal;
            -ms-flex-direction:row;
                flex-direction:row;
        -webkit-box-align:center;
            -ms-flex-align:center;
                align-items:center;
        -ms-flex-item-align:stretch;
            align-self:stretch;
        -ms-flex-wrap:wrap;
            flex-wrap:wrap;
        margin-right:7px;
        margin-top:5px;
        min-width:0; }
        .bp3-tag-input .bp3-tag-input-values > *{
          -webkit-box-flex:0;
              -ms-flex-positive:0;
                  flex-grow:0;
          -ms-flex-negative:0;
              flex-shrink:0; }
        .bp3-tag-input .bp3-tag-input-values > .bp3-fill{
          -webkit-box-flex:1;
              -ms-flex-positive:1;
                  flex-grow:1;
          -ms-flex-negative:1;
              flex-shrink:1; }
        .bp3-tag-input .bp3-tag-input-values::before,
        .bp3-tag-input .bp3-tag-input-values > *{
          margin-right:5px; }
        .bp3-tag-input .bp3-tag-input-values:empty::before,
        .bp3-tag-input .bp3-tag-input-values > :last-child{
          margin-right:0; }
        .bp3-tag-input .bp3-tag-input-values:first-child .bp3-input-ghost:first-child{
          padding-left:5px; }
        .bp3-tag-input .bp3-tag-input-values > *{
          margin-bottom:5px; }
      .bp3-tag-input .bp3-tag{
        overflow-wrap:break-word; }
        .bp3-tag-input .bp3-tag.bp3-active{
          outline:rgba(19, 124, 189, 0.6) auto 2px;
          outline-offset:0;
          -moz-outline-radius:6px; }
      .bp3-tag-input .bp3-input-ghost{
        -webkit-box-flex:1;
            -ms-flex:1 1 auto;
                flex:1 1 auto;
        line-height:20px;
        width:80px; }
        .bp3-tag-input .bp3-input-ghost:disabled, .bp3-tag-input .bp3-input-ghost.bp3-disabled{
          cursor:not-allowed; }
      .bp3-tag-input .bp3-button,
      .bp3-tag-input .bp3-spinner{
        margin:3px;
        margin-left:0; }
      .bp3-tag-input .bp3-button{
        min-height:24px;
        min-width:24px;
        padding:0 7px; }
      .bp3-tag-input.bp3-large{
        height:auto;
        min-height:40px; }
        .bp3-tag-input.bp3-large::before,
        .bp3-tag-input.bp3-large > *{
          margin-right:10px; }
        .bp3-tag-input.bp3-large:empty::before,
        .bp3-tag-input.bp3-large > :last-child{
          margin-right:0; }
        .bp3-tag-input.bp3-large .bp3-tag-input-icon{
          margin-left:5px;
          margin-top:10px; }
        .bp3-tag-input.bp3-large .bp3-input-ghost{
          line-height:30px; }
        .bp3-tag-input.bp3-large .bp3-button{
          min-height:30px;
          min-width:30px;
          padding:5px 10px;
          margin:5px;
          margin-left:0; }
        .bp3-tag-input.bp3-large .bp3-spinner{
          margin:8px;
          margin-left:0; }
      .bp3-tag-input.bp3-active{
        background-color:#ffffff;
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-tag-input.bp3-active.bp3-intent-primary{
          -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-tag-input.bp3-active.bp3-intent-success{
          -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-tag-input.bp3-active.bp3-intent-warning{
          -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
        .bp3-tag-input.bp3-active.bp3-intent-danger{
          -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2);
                  box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.2); }
      .bp3-dark .bp3-tag-input .bp3-tag-input-icon, .bp3-tag-input.bp3-dark .bp3-tag-input-icon{
        color:#a7b6c2; }
      .bp3-dark .bp3-tag-input .bp3-input-ghost, .bp3-tag-input.bp3-dark .bp3-input-ghost{
        color:#f5f8fa; }
        .bp3-dark .bp3-tag-input .bp3-input-ghost::-webkit-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-webkit-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-tag-input .bp3-input-ghost::-moz-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-moz-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-tag-input .bp3-input-ghost:-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost:-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-tag-input .bp3-input-ghost::-ms-input-placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::-ms-input-placeholder{
          color:rgba(167, 182, 194, 0.6); }
        .bp3-dark .bp3-tag-input .bp3-input-ghost::placeholder, .bp3-tag-input.bp3-dark .bp3-input-ghost::placeholder{
          color:rgba(167, 182, 194, 0.6); }
      .bp3-dark .bp3-tag-input.bp3-active, .bp3-tag-input.bp3-dark.bp3-active{
        background-color:rgba(16, 22, 26, 0.3);
        -webkit-box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px #137cbd, 0 0 0 1px #137cbd, 0 0 0 3px rgba(19, 124, 189, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-primary, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-primary{
          -webkit-box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #106ba3, 0 0 0 3px rgba(16, 107, 163, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-success, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-success{
          -webkit-box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #0d8050, 0 0 0 3px rgba(13, 128, 80, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-warning, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-warning{
          -webkit-box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #bf7326, 0 0 0 3px rgba(191, 115, 38, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
        .bp3-dark .bp3-tag-input.bp3-active.bp3-intent-danger, .bp3-tag-input.bp3-dark.bp3-active.bp3-intent-danger{
          -webkit-box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4);
                  box-shadow:0 0 0 1px #c23030, 0 0 0 3px rgba(194, 48, 48, 0.3), inset 0 0 0 1px rgba(16, 22, 26, 0.3), inset 0 1px 1px rgba(16, 22, 26, 0.4); }
    
    .bp3-input-ghost{
      background:none;
      border:none;
      -webkit-box-shadow:none;
              box-shadow:none;
      padding:0; }
      .bp3-input-ghost::-webkit-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input-ghost::-moz-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input-ghost:-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input-ghost::-ms-input-placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input-ghost::placeholder{
        color:rgba(92, 112, 128, 0.6);
        opacity:1; }
      .bp3-input-ghost:focus{
        outline:none !important; }
    .bp3-toast{
      -webkit-box-align:start;
          -ms-flex-align:start;
              align-items:flex-start;
      background-color:#ffffff;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      margin:20px 0 0;
      max-width:500px;
      min-width:300px;
      pointer-events:all;
      position:relative !important; }
      .bp3-toast.bp3-toast-enter, .bp3-toast.bp3-toast-appear{
        -webkit-transform:translateY(-40px);
                transform:translateY(-40px); }
      .bp3-toast.bp3-toast-enter-active, .bp3-toast.bp3-toast-appear-active{
        -webkit-transform:translateY(0);
                transform:translateY(0);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
      .bp3-toast.bp3-toast-enter ~ .bp3-toast, .bp3-toast.bp3-toast-appear ~ .bp3-toast{
        -webkit-transform:translateY(-40px);
                transform:translateY(-40px); }
      .bp3-toast.bp3-toast-enter-active ~ .bp3-toast, .bp3-toast.bp3-toast-appear-active ~ .bp3-toast{
        -webkit-transform:translateY(0);
                transform:translateY(0);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11);
                transition-timing-function:cubic-bezier(0.54, 1.12, 0.38, 1.11); }
      .bp3-toast.bp3-toast-exit{
        opacity:1;
        -webkit-filter:blur(0);
                filter:blur(0); }
      .bp3-toast.bp3-toast-exit-active{
        opacity:0;
        -webkit-filter:blur(10px);
                filter:blur(10px);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:300ms;
                transition-duration:300ms;
        -webkit-transition-property:opacity, -webkit-filter;
        transition-property:opacity, -webkit-filter;
        transition-property:opacity, filter;
        transition-property:opacity, filter, -webkit-filter;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-toast.bp3-toast-exit ~ .bp3-toast{
        -webkit-transform:translateY(0);
                transform:translateY(0); }
      .bp3-toast.bp3-toast-exit-active ~ .bp3-toast{
        -webkit-transform:translateY(-40px);
                transform:translateY(-40px);
        -webkit-transition-delay:50ms;
                transition-delay:50ms;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-toast .bp3-button-group{
        -webkit-box-flex:0;
            -ms-flex:0 0 auto;
                flex:0 0 auto;
        padding:5px;
        padding-left:0; }
      .bp3-toast > .bp3-icon{
        color:#5c7080;
        margin:12px;
        margin-right:0; }
      .bp3-toast.bp3-dark,
      .bp3-dark .bp3-toast{
        background-color:#394b59;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
        .bp3-toast.bp3-dark > .bp3-icon,
        .bp3-dark .bp3-toast > .bp3-icon{
          color:#a7b6c2; }
      .bp3-toast[class*="bp3-intent-"] a{
        color:rgba(255, 255, 255, 0.7); }
        .bp3-toast[class*="bp3-intent-"] a:hover{
          color:#ffffff; }
      .bp3-toast[class*="bp3-intent-"] > .bp3-icon{
        color:#ffffff; }
      .bp3-toast[class*="bp3-intent-"] .bp3-button, .bp3-toast[class*="bp3-intent-"] .bp3-button::before,
      .bp3-toast[class*="bp3-intent-"] .bp3-button .bp3-icon, .bp3-toast[class*="bp3-intent-"] .bp3-button:active{
        color:rgba(255, 255, 255, 0.7) !important; }
      .bp3-toast[class*="bp3-intent-"] .bp3-button:focus{
        outline-color:rgba(255, 255, 255, 0.5); }
      .bp3-toast[class*="bp3-intent-"] .bp3-button:hover{
        background-color:rgba(255, 255, 255, 0.15) !important;
        color:#ffffff !important; }
      .bp3-toast[class*="bp3-intent-"] .bp3-button:active{
        background-color:rgba(255, 255, 255, 0.3) !important;
        color:#ffffff !important; }
      .bp3-toast[class*="bp3-intent-"] .bp3-button::after{
        background:rgba(255, 255, 255, 0.3) !important; }
      .bp3-toast.bp3-intent-primary{
        background-color:#137cbd;
        color:#ffffff; }
      .bp3-toast.bp3-intent-success{
        background-color:#0f9960;
        color:#ffffff; }
      .bp3-toast.bp3-intent-warning{
        background-color:#d9822b;
        color:#ffffff; }
      .bp3-toast.bp3-intent-danger{
        background-color:#db3737;
        color:#ffffff; }
    
    .bp3-toast-message{
      -webkit-box-flex:1;
          -ms-flex:1 1 auto;
              flex:1 1 auto;
      padding:11px;
      word-break:break-word; }
    
    .bp3-toast-container{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box !important;
      display:-ms-flexbox !important;
      display:flex !important;
      -webkit-box-orient:vertical;
      -webkit-box-direction:normal;
          -ms-flex-direction:column;
              flex-direction:column;
      left:0;
      overflow:hidden;
      padding:0 20px 20px;
      pointer-events:none;
      right:0;
      z-index:40; }
      .bp3-toast-container.bp3-toast-container-in-portal{
        position:fixed; }
      .bp3-toast-container.bp3-toast-container-inline{
        position:absolute; }
      .bp3-toast-container.bp3-toast-container-top{
        top:0; }
      .bp3-toast-container.bp3-toast-container-bottom{
        bottom:0;
        -webkit-box-orient:vertical;
        -webkit-box-direction:reverse;
            -ms-flex-direction:column-reverse;
                flex-direction:column-reverse;
        top:auto; }
      .bp3-toast-container.bp3-toast-container-left{
        -webkit-box-align:start;
            -ms-flex-align:start;
                align-items:flex-start; }
      .bp3-toast-container.bp3-toast-container-right{
        -webkit-box-align:end;
            -ms-flex-align:end;
                align-items:flex-end; }
    
    .bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active),
    .bp3-toast-container-bottom .bp3-toast.bp3-toast-enter:not(.bp3-toast-enter-active) ~ .bp3-toast, .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active),
    .bp3-toast-container-bottom .bp3-toast.bp3-toast-appear:not(.bp3-toast-appear-active) ~ .bp3-toast,
    .bp3-toast-container-bottom .bp3-toast.bp3-toast-exit-active ~ .bp3-toast,
    .bp3-toast-container-bottom .bp3-toast.bp3-toast-leave-active ~ .bp3-toast{
      -webkit-transform:translateY(60px);
              transform:translateY(60px); }
    .bp3-tooltip{
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 2px 4px rgba(16, 22, 26, 0.2), 0 8px 24px rgba(16, 22, 26, 0.2);
      -webkit-transform:scale(1);
              transform:scale(1); }
      .bp3-tooltip .bp3-popover-arrow{
        height:22px;
        position:absolute;
        width:22px; }
        .bp3-tooltip .bp3-popover-arrow::before{
          height:14px;
          margin:4px;
          width:14px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip{
        margin-bottom:11px;
        margin-top:-11px; }
        .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{
          bottom:-8px; }
          .bp3-tether-element-attached-bottom.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow svg{
            -webkit-transform:rotate(-90deg);
                    transform:rotate(-90deg); }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip{
        margin-left:11px; }
        .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{
          left:-8px; }
          .bp3-tether-element-attached-left.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow svg{
            -webkit-transform:rotate(0);
                    transform:rotate(0); }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip{
        margin-top:11px; }
        .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{
          top:-8px; }
          .bp3-tether-element-attached-top.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow svg{
            -webkit-transform:rotate(90deg);
                    transform:rotate(90deg); }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip{
        margin-left:-11px;
        margin-right:11px; }
        .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{
          right:-8px; }
          .bp3-tether-element-attached-right.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow svg{
            -webkit-transform:rotate(180deg);
                    transform:rotate(180deg); }
      .bp3-tether-element-attached-middle > .bp3-tooltip > .bp3-popover-arrow{
        top:50%;
        -webkit-transform:translateY(-50%);
                transform:translateY(-50%); }
      .bp3-tether-element-attached-center > .bp3-tooltip > .bp3-popover-arrow{
        right:50%;
        -webkit-transform:translateX(50%);
                transform:translateX(50%); }
      .bp3-tether-element-attached-top.bp3-tether-target-attached-top > .bp3-tooltip > .bp3-popover-arrow{
        top:-0.22183px; }
      .bp3-tether-element-attached-right.bp3-tether-target-attached-right > .bp3-tooltip > .bp3-popover-arrow{
        right:-0.22183px; }
      .bp3-tether-element-attached-left.bp3-tether-target-attached-left > .bp3-tooltip > .bp3-popover-arrow{
        left:-0.22183px; }
      .bp3-tether-element-attached-bottom.bp3-tether-target-attached-bottom > .bp3-tooltip > .bp3-popover-arrow{
        bottom:-0.22183px; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-left > .bp3-tooltip{
        -webkit-transform-origin:top left;
                transform-origin:top left; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-center > .bp3-tooltip{
        -webkit-transform-origin:top center;
                transform-origin:top center; }
      .bp3-tether-element-attached-top.bp3-tether-element-attached-right > .bp3-tooltip{
        -webkit-transform-origin:top right;
                transform-origin:top right; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-left > .bp3-tooltip{
        -webkit-transform-origin:center left;
                transform-origin:center left; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-center > .bp3-tooltip{
        -webkit-transform-origin:center center;
                transform-origin:center center; }
      .bp3-tether-element-attached-middle.bp3-tether-element-attached-right > .bp3-tooltip{
        -webkit-transform-origin:center right;
                transform-origin:center right; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-left > .bp3-tooltip{
        -webkit-transform-origin:bottom left;
                transform-origin:bottom left; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-center > .bp3-tooltip{
        -webkit-transform-origin:bottom center;
                transform-origin:bottom center; }
      .bp3-tether-element-attached-bottom.bp3-tether-element-attached-right > .bp3-tooltip{
        -webkit-transform-origin:bottom right;
                transform-origin:bottom right; }
      .bp3-tooltip .bp3-popover-content{
        background:#394b59;
        color:#f5f8fa; }
      .bp3-tooltip .bp3-popover-arrow::before{
        -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2);
                box-shadow:1px 1px 6px rgba(16, 22, 26, 0.2); }
      .bp3-tooltip .bp3-popover-arrow-border{
        fill:#10161a;
        fill-opacity:0.1; }
      .bp3-tooltip .bp3-popover-arrow-fill{
        fill:#394b59; }
      .bp3-popover-enter > .bp3-tooltip, .bp3-popover-appear > .bp3-tooltip{
        -webkit-transform:scale(0.8);
                transform:scale(0.8); }
      .bp3-popover-enter-active > .bp3-tooltip, .bp3-popover-appear-active > .bp3-tooltip{
        -webkit-transform:scale(1);
                transform:scale(1);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-popover-exit > .bp3-tooltip{
        -webkit-transform:scale(1);
                transform:scale(1); }
      .bp3-popover-exit-active > .bp3-tooltip{
        -webkit-transform:scale(0.8);
                transform:scale(0.8);
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:100ms;
                transition-duration:100ms;
        -webkit-transition-property:-webkit-transform;
        transition-property:-webkit-transform;
        transition-property:transform;
        transition-property:transform, -webkit-transform;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-tooltip .bp3-popover-content{
        padding:10px 12px; }
      .bp3-tooltip.bp3-dark,
      .bp3-dark .bp3-tooltip{
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 2px 4px rgba(16, 22, 26, 0.4), 0 8px 24px rgba(16, 22, 26, 0.4); }
        .bp3-tooltip.bp3-dark .bp3-popover-content,
        .bp3-dark .bp3-tooltip .bp3-popover-content{
          background:#e1e8ed;
          color:#394b59; }
        .bp3-tooltip.bp3-dark .bp3-popover-arrow::before,
        .bp3-dark .bp3-tooltip .bp3-popover-arrow::before{
          -webkit-box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4);
                  box-shadow:1px 1px 6px rgba(16, 22, 26, 0.4); }
        .bp3-tooltip.bp3-dark .bp3-popover-arrow-border,
        .bp3-dark .bp3-tooltip .bp3-popover-arrow-border{
          fill:#10161a;
          fill-opacity:0.2; }
        .bp3-tooltip.bp3-dark .bp3-popover-arrow-fill,
        .bp3-dark .bp3-tooltip .bp3-popover-arrow-fill{
          fill:#e1e8ed; }
      .bp3-tooltip.bp3-intent-primary .bp3-popover-content{
        background:#137cbd;
        color:#ffffff; }
      .bp3-tooltip.bp3-intent-primary .bp3-popover-arrow-fill{
        fill:#137cbd; }
      .bp3-tooltip.bp3-intent-success .bp3-popover-content{
        background:#0f9960;
        color:#ffffff; }
      .bp3-tooltip.bp3-intent-success .bp3-popover-arrow-fill{
        fill:#0f9960; }
      .bp3-tooltip.bp3-intent-warning .bp3-popover-content{
        background:#d9822b;
        color:#ffffff; }
      .bp3-tooltip.bp3-intent-warning .bp3-popover-arrow-fill{
        fill:#d9822b; }
      .bp3-tooltip.bp3-intent-danger .bp3-popover-content{
        background:#db3737;
        color:#ffffff; }
      .bp3-tooltip.bp3-intent-danger .bp3-popover-arrow-fill{
        fill:#db3737; }
    
    .bp3-tooltip-indicator{
      border-bottom:dotted 1px;
      cursor:help; }
    .bp3-tree .bp3-icon, .bp3-tree .bp3-icon-standard, .bp3-tree .bp3-icon-large{
      color:#5c7080; }
      .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-tree .bp3-icon-large.bp3-intent-primary{
        color:#137cbd; }
      .bp3-tree .bp3-icon.bp3-intent-success, .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-tree .bp3-icon-large.bp3-intent-success{
        color:#0f9960; }
      .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-tree .bp3-icon-large.bp3-intent-warning{
        color:#d9822b; }
      .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-tree .bp3-icon-large.bp3-intent-danger{
        color:#db3737; }
    
    .bp3-tree-node-list{
      list-style:none;
      margin:0;
      padding-left:0; }
    
    .bp3-tree-root{
      background-color:transparent;
      cursor:default;
      padding-left:0;
      position:relative; }
    
    .bp3-tree-node-content-0{
      padding-left:0px; }
    
    .bp3-tree-node-content-1{
      padding-left:23px; }
    
    .bp3-tree-node-content-2{
      padding-left:46px; }
    
    .bp3-tree-node-content-3{
      padding-left:69px; }
    
    .bp3-tree-node-content-4{
      padding-left:92px; }
    
    .bp3-tree-node-content-5{
      padding-left:115px; }
    
    .bp3-tree-node-content-6{
      padding-left:138px; }
    
    .bp3-tree-node-content-7{
      padding-left:161px; }
    
    .bp3-tree-node-content-8{
      padding-left:184px; }
    
    .bp3-tree-node-content-9{
      padding-left:207px; }
    
    .bp3-tree-node-content-10{
      padding-left:230px; }
    
    .bp3-tree-node-content-11{
      padding-left:253px; }
    
    .bp3-tree-node-content-12{
      padding-left:276px; }
    
    .bp3-tree-node-content-13{
      padding-left:299px; }
    
    .bp3-tree-node-content-14{
      padding-left:322px; }
    
    .bp3-tree-node-content-15{
      padding-left:345px; }
    
    .bp3-tree-node-content-16{
      padding-left:368px; }
    
    .bp3-tree-node-content-17{
      padding-left:391px; }
    
    .bp3-tree-node-content-18{
      padding-left:414px; }
    
    .bp3-tree-node-content-19{
      padding-left:437px; }
    
    .bp3-tree-node-content-20{
      padding-left:460px; }
    
    .bp3-tree-node-content{
      -webkit-box-align:center;
          -ms-flex-align:center;
              align-items:center;
      display:-webkit-box;
      display:-ms-flexbox;
      display:flex;
      height:30px;
      padding-right:5px;
      width:100%; }
      .bp3-tree-node-content:hover{
        background-color:rgba(191, 204, 214, 0.4); }
    
    .bp3-tree-node-caret,
    .bp3-tree-node-caret-none{
      min-width:30px; }
    
    .bp3-tree-node-caret{
      color:#5c7080;
      cursor:pointer;
      padding:7px;
      -webkit-transform:rotate(0deg);
              transform:rotate(0deg);
      -webkit-transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:-webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9);
      transition:transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9), -webkit-transform 200ms cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-tree-node-caret:hover{
        color:#182026; }
      .bp3-dark .bp3-tree-node-caret{
        color:#a7b6c2; }
        .bp3-dark .bp3-tree-node-caret:hover{
          color:#f5f8fa; }
      .bp3-tree-node-caret.bp3-tree-node-caret-open{
        -webkit-transform:rotate(90deg);
                transform:rotate(90deg); }
      .bp3-tree-node-caret.bp3-icon-standard::before{
        content:""; }
    
    .bp3-tree-node-icon{
      margin-right:7px;
      position:relative; }
    
    .bp3-tree-node-label{
      overflow:hidden;
      text-overflow:ellipsis;
      white-space:nowrap;
      word-wrap:normal;
      -webkit-box-flex:1;
          -ms-flex:1 1 auto;
              flex:1 1 auto;
      position:relative;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-tree-node-label span{
        display:inline; }
    
    .bp3-tree-node-secondary-label{
      padding:0 5px;
      -webkit-user-select:none;
         -moz-user-select:none;
          -ms-user-select:none;
              user-select:none; }
      .bp3-tree-node-secondary-label .bp3-popover-wrapper,
      .bp3-tree-node-secondary-label .bp3-popover-target{
        -webkit-box-align:center;
            -ms-flex-align:center;
                align-items:center;
        display:-webkit-box;
        display:-ms-flexbox;
        display:flex; }
    
    .bp3-tree-node.bp3-disabled .bp3-tree-node-content{
      background-color:inherit;
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
    
    .bp3-tree-node.bp3-disabled .bp3-tree-node-caret,
    .bp3-tree-node.bp3-disabled .bp3-tree-node-icon{
      color:rgba(92, 112, 128, 0.6);
      cursor:not-allowed; }
    
    .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{
      background-color:#137cbd; }
      .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content,
      .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-standard, .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-icon-large{
        color:#ffffff; }
      .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret::before{
        color:rgba(255, 255, 255, 0.7); }
      .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content .bp3-tree-node-caret:hover::before{
        color:#ffffff; }
    
    .bp3-dark .bp3-tree-node-content:hover{
      background-color:rgba(92, 112, 128, 0.3); }
    
    .bp3-dark .bp3-tree .bp3-icon, .bp3-dark .bp3-tree .bp3-icon-standard, .bp3-dark .bp3-tree .bp3-icon-large{
      color:#a7b6c2; }
      .bp3-dark .bp3-tree .bp3-icon.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-primary, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-primary{
        color:#137cbd; }
      .bp3-dark .bp3-tree .bp3-icon.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-success, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-success{
        color:#0f9960; }
      .bp3-dark .bp3-tree .bp3-icon.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-warning, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-warning{
        color:#d9822b; }
      .bp3-dark .bp3-tree .bp3-icon.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-standard.bp3-intent-danger, .bp3-dark .bp3-tree .bp3-icon-large.bp3-intent-danger{
        color:#db3737; }
    
    .bp3-dark .bp3-tree-node.bp3-tree-node-selected > .bp3-tree-node-content{
      background-color:#137cbd; }
    .bp3-omnibar{
      -webkit-filter:blur(0);
              filter:blur(0);
      opacity:1;
      background-color:#ffffff;
      border-radius:3px;
      -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
              box-shadow:0 0 0 1px rgba(16, 22, 26, 0.1), 0 4px 8px rgba(16, 22, 26, 0.2), 0 18px 46px 6px rgba(16, 22, 26, 0.2);
      left:calc(50% - 250px);
      top:20vh;
      width:500px;
      z-index:21; }
      .bp3-omnibar.bp3-overlay-enter, .bp3-omnibar.bp3-overlay-appear{
        -webkit-filter:blur(20px);
                filter:blur(20px);
        opacity:0.2; }
      .bp3-omnibar.bp3-overlay-enter-active, .bp3-omnibar.bp3-overlay-appear-active{
        -webkit-filter:blur(0);
                filter:blur(0);
        opacity:1;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:200ms;
                transition-duration:200ms;
        -webkit-transition-property:opacity, -webkit-filter;
        transition-property:opacity, -webkit-filter;
        transition-property:filter, opacity;
        transition-property:filter, opacity, -webkit-filter;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-omnibar.bp3-overlay-exit{
        -webkit-filter:blur(0);
                filter:blur(0);
        opacity:1; }
      .bp3-omnibar.bp3-overlay-exit-active{
        -webkit-filter:blur(20px);
                filter:blur(20px);
        opacity:0.2;
        -webkit-transition-delay:0;
                transition-delay:0;
        -webkit-transition-duration:200ms;
                transition-duration:200ms;
        -webkit-transition-property:opacity, -webkit-filter;
        transition-property:opacity, -webkit-filter;
        transition-property:filter, opacity;
        transition-property:filter, opacity, -webkit-filter;
        -webkit-transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9);
                transition-timing-function:cubic-bezier(0.4, 1, 0.75, 0.9); }
      .bp3-omnibar .bp3-input{
        background-color:transparent;
        border-radius:0; }
        .bp3-omnibar .bp3-input, .bp3-omnibar .bp3-input:focus{
          -webkit-box-shadow:none;
                  box-shadow:none; }
      .bp3-omnibar .bp3-menu{
        background-color:transparent;
        border-radius:0;
        -webkit-box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
                box-shadow:inset 0 1px 0 rgba(16, 22, 26, 0.15);
        max-height:calc(60vh - 40px);
        overflow:auto; }
        .bp3-omnibar .bp3-menu:empty{
          display:none; }
      .bp3-dark .bp3-omnibar, .bp3-omnibar.bp3-dark{
        background-color:#30404d;
        -webkit-box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4);
                box-shadow:0 0 0 1px rgba(16, 22, 26, 0.2), 0 4px 8px rgba(16, 22, 26, 0.4), 0 18px 46px 6px rgba(16, 22, 26, 0.4); }
    
    .bp3-omnibar-overlay .bp3-overlay-backdrop{
      background-color:rgba(16, 22, 26, 0.2); }
    
    .bp3-select-popover .bp3-popover-content{
      padding:5px; }
    
    .bp3-select-popover .bp3-input-group{
      margin-bottom:0; }
    
    .bp3-select-popover .bp3-menu{
      max-height:300px;
      max-width:400px;
      overflow:auto;
      padding:0; }
      .bp3-select-popover .bp3-menu:not(:first-child){
        padding-top:5px; }
    
    .bp3-multi-select{
      min-width:150px; }
    
    .bp3-multi-select-popover .bp3-menu{
      max-height:300px;
      max-width:400px;
      overflow:auto; }
    
    .bp3-select-popover .bp3-popover-content{
      padding:5px; }
    
    .bp3-select-popover .bp3-input-group{
      margin-bottom:0; }
    
    .bp3-select-popover .bp3-menu{
      max-height:300px;
      max-width:400px;
      overflow:auto;
      padding:0; }
      .bp3-select-popover .bp3-menu:not(:first-child){
        padding-top:5px; }
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /* This file was auto-generated by ensureUiComponents() in @jupyterlab/buildutils */
    
    /**
     * (DEPRECATED) Support for consuming icons as CSS background images
     */
    
    /* Icons urls */
    
    :root {
      --jp-icon-add: url();
      --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-code: url();
      --jp-icon-console: url();
      --jp-icon-copy: url();
      --jp-icon-copyright: 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-julia: 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-numbering: url();
      --jp-icon-offline-bolt: url();
      --jp-icon-palette: url();
      --jp-icon-paste: url();
      --jp-icon-pdf: url();
      --jp-icon-python: url();
      --jp-icon-r-kernel: url();
      --jp-icon-react: url();
      --jp-icon-redo: 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-table-rows: url();
      --jp-icon-tag: url();
      --jp-icon-terminal: url();
      --jp-icon-text-editor: url();
      --jp-icon-toc: url();
      --jp-icon-tree-view: 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-CodeIcon {
      background-image: var(--jp-icon-code);
    }
    .jp-ConsoleIcon {
      background-image: var(--jp-icon-console);
    }
    .jp-CopyIcon {
      background-image: var(--jp-icon-copy);
    }
    .jp-CopyrightIcon {
      background-image: var(--jp-icon-copyright);
    }
    .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-JuliaIcon {
      background-image: var(--jp-icon-julia);
    }
    .jp-JupyterFaviconIcon {
      background-image: var(--jp-icon-jupyter-favicon);
    }
    .jp-JupyterIcon {
      background-image: var(--jp-icon-jupyter);
    }
    .jp-JupyterlabWordmarkIcon {
      background-image: var(--jp-icon-jupyterlab-wordmark);
    }
    .jp-KernelIcon {
      background-image: var(--jp-icon-kernel);
    }
    .jp-KeyboardIcon {
      background-image: var(--jp-icon-keyboard);
    }
    .jp-LauncherIcon {
      background-image: var(--jp-icon-launcher);
    }
    .jp-LineFormIcon {
      background-image: var(--jp-icon-line-form);
    }
    .jp-LinkIcon {
      background-image: var(--jp-icon-link);
    }
    .jp-ListIcon {
      background-image: var(--jp-icon-list);
    }
    .jp-ListingsInfoIcon {
      background-image: var(--jp-icon-listings-info);
    }
    .jp-MarkdownIcon {
      background-image: var(--jp-icon-markdown);
    }
    .jp-NewFolderIcon {
      background-image: var(--jp-icon-new-folder);
    }
    .jp-NotTrustedIcon {
      background-image: var(--jp-icon-not-trusted);
    }
    .jp-NotebookIcon {
      background-image: var(--jp-icon-notebook);
    }
    .jp-NumberingIcon {
      background-image: var(--jp-icon-numbering);
    }
    .jp-OfflineBoltIcon {
      background-image: var(--jp-icon-offline-bolt);
    }
    .jp-PaletteIcon {
      background-image: var(--jp-icon-palette);
    }
    .jp-PasteIcon {
      background-image: var(--jp-icon-paste);
    }
    .jp-PdfIcon {
      background-image: var(--jp-icon-pdf);
    }
    .jp-PythonIcon {
      background-image: var(--jp-icon-python);
    }
    .jp-RKernelIcon {
      background-image: var(--jp-icon-r-kernel);
    }
    .jp-ReactIcon {
      background-image: var(--jp-icon-react);
    }
    .jp-RedoIcon {
      background-image: var(--jp-icon-redo);
    }
    .jp-RefreshIcon {
      background-image: var(--jp-icon-refresh);
    }
    .jp-RegexIcon {
      background-image: var(--jp-icon-regex);
    }
    .jp-RunIcon {
      background-image: var(--jp-icon-run);
    }
    .jp-RunningIcon {
      background-image: var(--jp-icon-running);
    }
    .jp-SaveIcon {
      background-image: var(--jp-icon-save);
    }
    .jp-SearchIcon {
      background-image: var(--jp-icon-search);
    }
    .jp-SettingsIcon {
      background-image: var(--jp-icon-settings);
    }
    .jp-SpreadsheetIcon {
      background-image: var(--jp-icon-spreadsheet);
    }
    .jp-StopIcon {
      background-image: var(--jp-icon-stop);
    }
    .jp-TabIcon {
      background-image: var(--jp-icon-tab);
    }
    .jp-TableRowsIcon {
      background-image: var(--jp-icon-table-rows);
    }
    .jp-TagIcon {
      background-image: var(--jp-icon-tag);
    }
    .jp-TerminalIcon {
      background-image: var(--jp-icon-terminal);
    }
    .jp-TextEditorIcon {
      background-image: var(--jp-icon-text-editor);
    }
    .jp-TocIcon {
      background-image: var(--jp-icon-toc);
    }
    .jp-TreeViewIcon {
      background-image: var(--jp-icon-tree-view);
    }
    .jp-TrustedIcon {
      background-image: var(--jp-icon-trusted);
    }
    .jp-UndoIcon {
      background-image: var(--jp-icon-undo);
    }
    .jp-VegaIcon {
      background-image: var(--jp-icon-vega);
    }
    .jp-YamlIcon {
      background-image: var(--jp-icon-yaml);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /**
     * (DEPRECATED) Support for consuming icons as CSS background images
     */
    
    .jp-Icon,
    .jp-MaterialIcon {
      background-position: center;
      background-repeat: no-repeat;
      background-size: 16px;
      min-width: 16px;
      min-height: 16px;
    }
    
    .jp-Icon-cover {
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover;
    }
    
    /**
     * (DEPRECATED) Support for specific CSS icon sizes
     */
    
    .jp-Icon-16 {
      background-size: 16px;
      min-width: 16px;
      min-height: 16px;
    }
    
    .jp-Icon-18 {
      background-size: 18px;
      min-width: 18px;
      min-height: 18px;
    }
    
    .jp-Icon-20 {
      background-size: 20px;
      min-width: 20px;
      min-height: 20px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /**
     * Support for icons as inline SVG HTMLElements
     */
    
    /* recolor the primary elements of an icon */
    .jp-icon0[fill] {
      fill: var(--jp-inverse-layout-color0);
    }
    .jp-icon1[fill] {
      fill: var(--jp-inverse-layout-color1);
    }
    .jp-icon2[fill] {
      fill: var(--jp-inverse-layout-color2);
    }
    .jp-icon3[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    .jp-icon4[fill] {
      fill: var(--jp-inverse-layout-color4);
    }
    
    .jp-icon0[stroke] {
      stroke: var(--jp-inverse-layout-color0);
    }
    .jp-icon1[stroke] {
      stroke: var(--jp-inverse-layout-color1);
    }
    .jp-icon2[stroke] {
      stroke: var(--jp-inverse-layout-color2);
    }
    .jp-icon3[stroke] {
      stroke: var(--jp-inverse-layout-color3);
    }
    .jp-icon4[stroke] {
      stroke: var(--jp-inverse-layout-color4);
    }
    /* recolor the accent elements of an icon */
    .jp-icon-accent0[fill] {
      fill: var(--jp-layout-color0);
    }
    .jp-icon-accent1[fill] {
      fill: var(--jp-layout-color1);
    }
    .jp-icon-accent2[fill] {
      fill: var(--jp-layout-color2);
    }
    .jp-icon-accent3[fill] {
      fill: var(--jp-layout-color3);
    }
    .jp-icon-accent4[fill] {
      fill: var(--jp-layout-color4);
    }
    
    .jp-icon-accent0[stroke] {
      stroke: var(--jp-layout-color0);
    }
    .jp-icon-accent1[stroke] {
      stroke: var(--jp-layout-color1);
    }
    .jp-icon-accent2[stroke] {
      stroke: var(--jp-layout-color2);
    }
    .jp-icon-accent3[stroke] {
      stroke: var(--jp-layout-color3);
    }
    .jp-icon-accent4[stroke] {
      stroke: var(--jp-layout-color4);
    }
    /* set the color of an icon to transparent */
    .jp-icon-none[fill] {
      fill: none;
    }
    
    .jp-icon-none[stroke] {
      stroke: none;
    }
    /* brand icon colors. Same for light and dark */
    .jp-icon-brand0[fill] {
      fill: var(--jp-brand-color0);
    }
    .jp-icon-brand1[fill] {
      fill: var(--jp-brand-color1);
    }
    .jp-icon-brand2[fill] {
      fill: var(--jp-brand-color2);
    }
    .jp-icon-brand3[fill] {
      fill: var(--jp-brand-color3);
    }
    .jp-icon-brand4[fill] {
      fill: var(--jp-brand-color4);
    }
    
    .jp-icon-brand0[stroke] {
      stroke: var(--jp-brand-color0);
    }
    .jp-icon-brand1[stroke] {
      stroke: var(--jp-brand-color1);
    }
    .jp-icon-brand2[stroke] {
      stroke: var(--jp-brand-color2);
    }
    .jp-icon-brand3[stroke] {
      stroke: var(--jp-brand-color3);
    }
    .jp-icon-brand4[stroke] {
      stroke: var(--jp-brand-color4);
    }
    /* warn icon colors. Same for light and dark */
    .jp-icon-warn0[fill] {
      fill: var(--jp-warn-color0);
    }
    .jp-icon-warn1[fill] {
      fill: var(--jp-warn-color1);
    }
    .jp-icon-warn2[fill] {
      fill: var(--jp-warn-color2);
    }
    .jp-icon-warn3[fill] {
      fill: var(--jp-warn-color3);
    }
    
    .jp-icon-warn0[stroke] {
      stroke: var(--jp-warn-color0);
    }
    .jp-icon-warn1[stroke] {
      stroke: var(--jp-warn-color1);
    }
    .jp-icon-warn2[stroke] {
      stroke: var(--jp-warn-color2);
    }
    .jp-icon-warn3[stroke] {
      stroke: var(--jp-warn-color3);
    }
    /* icon colors that contrast well with each other and most backgrounds */
    .jp-icon-contrast0[fill] {
      fill: var(--jp-icon-contrast-color0);
    }
    .jp-icon-contrast1[fill] {
      fill: var(--jp-icon-contrast-color1);
    }
    .jp-icon-contrast2[fill] {
      fill: var(--jp-icon-contrast-color2);
    }
    .jp-icon-contrast3[fill] {
      fill: var(--jp-icon-contrast-color3);
    }
    
    .jp-icon-contrast0[stroke] {
      stroke: var(--jp-icon-contrast-color0);
    }
    .jp-icon-contrast1[stroke] {
      stroke: var(--jp-icon-contrast-color1);
    }
    .jp-icon-contrast2[stroke] {
      stroke: var(--jp-icon-contrast-color2);
    }
    .jp-icon-contrast3[stroke] {
      stroke: var(--jp-icon-contrast-color3);
    }
    
    /* CSS for icons in selected items in the settings editor */
    #setting-editor .jp-PluginList .jp-mod-selected .jp-icon-selectable[fill] {
      fill: #fff;
    }
    #setting-editor
      .jp-PluginList
      .jp-mod-selected
      .jp-icon-selectable-inverse[fill] {
      fill: var(--jp-brand-color1);
    }
    
    /* CSS for icons in selected filebrowser listing items */
    .jp-DirListing-item.jp-mod-selected .jp-icon-selectable[fill] {
      fill: #fff;
    }
    .jp-DirListing-item.jp-mod-selected .jp-icon-selectable-inverse[fill] {
      fill: var(--jp-brand-color1);
    }
    
    /* CSS for icons in selected tabs in the sidebar tab manager */
    #tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable[fill] {
      fill: #fff;
    }
    
    #tab-manager .lm-TabBar-tab.jp-mod-active .jp-icon-selectable-inverse[fill] {
      fill: var(--jp-brand-color1);
    }
    #tab-manager
      .lm-TabBar-tab.jp-mod-active
      .jp-icon-hover
      :hover
      .jp-icon-selectable[fill] {
      fill: var(--jp-brand-color1);
    }
    
    #tab-manager
      .lm-TabBar-tab.jp-mod-active
      .jp-icon-hover
      :hover
      .jp-icon-selectable-inverse[fill] {
      fill: #fff;
    }
    
    /**
     * TODO: come up with non css-hack solution for showing the busy icon on top
     *  of the close icon
     * CSS for complex behavior of close icon of tabs in the sidebar tab manager
     */
    #tab-manager
      .lm-TabBar-tab.jp-mod-dirty
      > .lm-TabBar-tabCloseIcon
      > :not(:hover)
      > .jp-icon3[fill] {
      fill: none;
    }
    #tab-manager
      .lm-TabBar-tab.jp-mod-dirty
      > .lm-TabBar-tabCloseIcon
      > :not(:hover)
      > .jp-icon-busy[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    
    #tab-manager
      .lm-TabBar-tab.jp-mod-dirty.jp-mod-active
      > .lm-TabBar-tabCloseIcon
      > :not(:hover)
      > .jp-icon-busy[fill] {
      fill: #fff;
    }
    
    /**
    * TODO: come up with non css-hack solution for showing the busy icon on top
    *  of the close icon
    * CSS for complex behavior of close icon of tabs in the main area tabbar
    */
    .lm-DockPanel-tabBar
      .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
      > .lm-TabBar-tabCloseIcon
      > :not(:hover)
      > .jp-icon3[fill] {
      fill: none;
    }
    .lm-DockPanel-tabBar
      .lm-TabBar-tab.lm-mod-closable.jp-mod-dirty
      > .lm-TabBar-tabCloseIcon
      > :not(:hover)
      > .jp-icon-busy[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    
    /* CSS for icons in status bar */
    #jp-main-statusbar .jp-mod-selected .jp-icon-selectable[fill] {
      fill: #fff;
    }
    
    #jp-main-statusbar .jp-mod-selected .jp-icon-selectable-inverse[fill] {
      fill: var(--jp-brand-color1);
    }
    /* special handling for splash icon CSS. While the theme CSS reloads during
       splash, the splash icon can loose theming. To prevent that, we set a
       default for its color variable */
    :root {
      --jp-warn-color0: var(--md-orange-700);
    }
    
    /* not sure what to do with this one, used in filebrowser listing */
    .jp-DragIcon {
      margin-right: 4px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /**
     * Support for alt colors for icons as inline SVG HTMLElements
     */
    
    /* alt recolor the primary elements of an icon */
    .jp-icon-alt .jp-icon0[fill] {
      fill: var(--jp-layout-color0);
    }
    .jp-icon-alt .jp-icon1[fill] {
      fill: var(--jp-layout-color1);
    }
    .jp-icon-alt .jp-icon2[fill] {
      fill: var(--jp-layout-color2);
    }
    .jp-icon-alt .jp-icon3[fill] {
      fill: var(--jp-layout-color3);
    }
    .jp-icon-alt .jp-icon4[fill] {
      fill: var(--jp-layout-color4);
    }
    
    .jp-icon-alt .jp-icon0[stroke] {
      stroke: var(--jp-layout-color0);
    }
    .jp-icon-alt .jp-icon1[stroke] {
      stroke: var(--jp-layout-color1);
    }
    .jp-icon-alt .jp-icon2[stroke] {
      stroke: var(--jp-layout-color2);
    }
    .jp-icon-alt .jp-icon3[stroke] {
      stroke: var(--jp-layout-color3);
    }
    .jp-icon-alt .jp-icon4[stroke] {
      stroke: var(--jp-layout-color4);
    }
    
    /* alt recolor the accent elements of an icon */
    .jp-icon-alt .jp-icon-accent0[fill] {
      fill: var(--jp-inverse-layout-color0);
    }
    .jp-icon-alt .jp-icon-accent1[fill] {
      fill: var(--jp-inverse-layout-color1);
    }
    .jp-icon-alt .jp-icon-accent2[fill] {
      fill: var(--jp-inverse-layout-color2);
    }
    .jp-icon-alt .jp-icon-accent3[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    .jp-icon-alt .jp-icon-accent4[fill] {
      fill: var(--jp-inverse-layout-color4);
    }
    
    .jp-icon-alt .jp-icon-accent0[stroke] {
      stroke: var(--jp-inverse-layout-color0);
    }
    .jp-icon-alt .jp-icon-accent1[stroke] {
      stroke: var(--jp-inverse-layout-color1);
    }
    .jp-icon-alt .jp-icon-accent2[stroke] {
      stroke: var(--jp-inverse-layout-color2);
    }
    .jp-icon-alt .jp-icon-accent3[stroke] {
      stroke: var(--jp-inverse-layout-color3);
    }
    .jp-icon-alt .jp-icon-accent4[stroke] {
      stroke: var(--jp-inverse-layout-color4);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-icon-hoverShow:not(:hover) svg {
      display: none !important;
    }
    
    /**
     * Support for hover colors for icons as inline SVG HTMLElements
     */
    
    /**
     * regular colors
     */
    
    /* recolor the primary elements of an icon */
    .jp-icon-hover :hover .jp-icon0-hover[fill] {
      fill: var(--jp-inverse-layout-color0);
    }
    .jp-icon-hover :hover .jp-icon1-hover[fill] {
      fill: var(--jp-inverse-layout-color1);
    }
    .jp-icon-hover :hover .jp-icon2-hover[fill] {
      fill: var(--jp-inverse-layout-color2);
    }
    .jp-icon-hover :hover .jp-icon3-hover[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    .jp-icon-hover :hover .jp-icon4-hover[fill] {
      fill: var(--jp-inverse-layout-color4);
    }
    
    .jp-icon-hover :hover .jp-icon0-hover[stroke] {
      stroke: var(--jp-inverse-layout-color0);
    }
    .jp-icon-hover :hover .jp-icon1-hover[stroke] {
      stroke: var(--jp-inverse-layout-color1);
    }
    .jp-icon-hover :hover .jp-icon2-hover[stroke] {
      stroke: var(--jp-inverse-layout-color2);
    }
    .jp-icon-hover :hover .jp-icon3-hover[stroke] {
      stroke: var(--jp-inverse-layout-color3);
    }
    .jp-icon-hover :hover .jp-icon4-hover[stroke] {
      stroke: var(--jp-inverse-layout-color4);
    }
    
    /* recolor the accent elements of an icon */
    .jp-icon-hover :hover .jp-icon-accent0-hover[fill] {
      fill: var(--jp-layout-color0);
    }
    .jp-icon-hover :hover .jp-icon-accent1-hover[fill] {
      fill: var(--jp-layout-color1);
    }
    .jp-icon-hover :hover .jp-icon-accent2-hover[fill] {
      fill: var(--jp-layout-color2);
    }
    .jp-icon-hover :hover .jp-icon-accent3-hover[fill] {
      fill: var(--jp-layout-color3);
    }
    .jp-icon-hover :hover .jp-icon-accent4-hover[fill] {
      fill: var(--jp-layout-color4);
    }
    
    .jp-icon-hover :hover .jp-icon-accent0-hover[stroke] {
      stroke: var(--jp-layout-color0);
    }
    .jp-icon-hover :hover .jp-icon-accent1-hover[stroke] {
      stroke: var(--jp-layout-color1);
    }
    .jp-icon-hover :hover .jp-icon-accent2-hover[stroke] {
      stroke: var(--jp-layout-color2);
    }
    .jp-icon-hover :hover .jp-icon-accent3-hover[stroke] {
      stroke: var(--jp-layout-color3);
    }
    .jp-icon-hover :hover .jp-icon-accent4-hover[stroke] {
      stroke: var(--jp-layout-color4);
    }
    
    /* set the color of an icon to transparent */
    .jp-icon-hover :hover .jp-icon-none-hover[fill] {
      fill: none;
    }
    
    .jp-icon-hover :hover .jp-icon-none-hover[stroke] {
      stroke: none;
    }
    
    /**
     * inverse colors
     */
    
    /* inverse recolor the primary elements of an icon */
    .jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[fill] {
      fill: var(--jp-layout-color0);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[fill] {
      fill: var(--jp-layout-color1);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[fill] {
      fill: var(--jp-layout-color2);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[fill] {
      fill: var(--jp-layout-color3);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[fill] {
      fill: var(--jp-layout-color4);
    }
    
    .jp-icon-hover.jp-icon-alt :hover .jp-icon0-hover[stroke] {
      stroke: var(--jp-layout-color0);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon1-hover[stroke] {
      stroke: var(--jp-layout-color1);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon2-hover[stroke] {
      stroke: var(--jp-layout-color2);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon3-hover[stroke] {
      stroke: var(--jp-layout-color3);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon4-hover[stroke] {
      stroke: var(--jp-layout-color4);
    }
    
    /* inverse recolor the accent elements of an icon */
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[fill] {
      fill: var(--jp-inverse-layout-color0);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[fill] {
      fill: var(--jp-inverse-layout-color1);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[fill] {
      fill: var(--jp-inverse-layout-color2);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[fill] {
      fill: var(--jp-inverse-layout-color3);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[fill] {
      fill: var(--jp-inverse-layout-color4);
    }
    
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent0-hover[stroke] {
      stroke: var(--jp-inverse-layout-color0);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent1-hover[stroke] {
      stroke: var(--jp-inverse-layout-color1);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent2-hover[stroke] {
      stroke: var(--jp-inverse-layout-color2);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent3-hover[stroke] {
      stroke: var(--jp-inverse-layout-color3);
    }
    .jp-icon-hover.jp-icon-alt :hover .jp-icon-accent4-hover[stroke] {
      stroke: var(--jp-inverse-layout-color4);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-switch {
      display: flex;
      align-items: center;
      padding-left: 4px;
      padding-right: 4px;
      font-size: var(--jp-ui-font-size1);
      background-color: transparent;
      color: var(--jp-ui-font-color1);
      border: none;
      height: 20px;
    }
    
    .jp-switch:hover {
      background-color: var(--jp-layout-color2);
    }
    
    .jp-switch-label {
      margin-right: 5px;
    }
    
    .jp-switch-track {
      cursor: pointer;
      background-color: var(--jp-border-color1);
      -webkit-transition: 0.4s;
      transition: 0.4s;
      border-radius: 34px;
      height: 16px;
      width: 35px;
      position: relative;
    }
    
    .jp-switch-track::before {
      content: '';
      position: absolute;
      height: 10px;
      width: 10px;
      margin: 3px;
      left: 0px;
      background-color: var(--jp-ui-inverse-font-color1);
      -webkit-transition: 0.4s;
      transition: 0.4s;
      border-radius: 50%;
    }
    
    .jp-switch[aria-checked='true'] .jp-switch-track {
      background-color: var(--jp-warn-color0);
    }
    
    .jp-switch[aria-checked='true'] .jp-switch-track::before {
      /* track width (35) - margins (3 + 3) - thumb width (10) */
      left: 19px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /* Sibling imports */
    
    /* Override Blueprint's _reset.scss styles */
    html {
      box-sizing: unset;
    }
    
    *,
    *::before,
    *::after {
      box-sizing: unset;
    }
    
    body {
      color: unset;
      font-family: var(--jp-ui-font-family);
    }
    
    p {
      margin-top: unset;
      margin-bottom: unset;
    }
    
    small {
      font-size: unset;
    }
    
    strong {
      font-weight: unset;
    }
    
    /* Override Blueprint's _typography.scss styles */
    a {
      text-decoration: unset;
      color: unset;
    }
    a:hover {
      text-decoration: unset;
      color: unset;
    }
    
    /* Override Blueprint's _accessibility.scss styles */
    :focus {
      outline: unset;
      outline-offset: unset;
      -moz-outline-radius: unset;
    }
    
    /* Styles for ui-components */
    .jp-Button {
      border-radius: var(--jp-border-radius);
      padding: 0px 12px;
      font-size: var(--jp-ui-font-size1);
    }
    
    /* Use our own theme for hover styles */
    button.jp-Button.bp3-button.bp3-minimal:hover {
      background-color: var(--jp-layout-color2);
    }
    .jp-Button.minimal {
      color: unset !important;
    }
    
    .jp-Button.jp-ToolbarButtonComponent {
      text-transform: none;
    }
    
    .jp-InputGroup input {
      box-sizing: border-box;
      border-radius: 0;
      background-color: transparent;
      color: var(--jp-ui-font-color0);
      box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
    }
    
    .jp-InputGroup input:focus {
      box-shadow: inset 0 0 0 var(--jp-border-width)
          var(--jp-input-active-box-shadow-color),
        inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
    }
    
    .jp-InputGroup input::placeholder,
    input::placeholder {
      color: var(--jp-ui-font-color3);
    }
    
    .jp-BPIcon {
      display: inline-block;
      vertical-align: middle;
      margin: auto;
    }
    
    /* Stop blueprint futzing with our icon fills */
    .bp3-icon.jp-BPIcon > svg:not([fill]) {
      fill: var(--jp-inverse-layout-color3);
    }
    
    .jp-InputGroupAction {
      padding: 6px;
    }
    
    .jp-HTMLSelect.jp-DefaultStyle select {
      background-color: initial;
      border: none;
      border-radius: 0;
      box-shadow: none;
      color: var(--jp-ui-font-color0);
      display: block;
      font-size: var(--jp-ui-font-size1);
      height: 24px;
      line-height: 14px;
      padding: 0 25px 0 10px;
      text-align: left;
      -moz-appearance: none;
      -webkit-appearance: none;
    }
    
    /* Use our own theme for hover and option styles */
    .jp-HTMLSelect.jp-DefaultStyle select:hover,
    .jp-HTMLSelect.jp-DefaultStyle select > option {
      background-color: var(--jp-layout-color2);
      color: var(--jp-ui-font-color0);
    }
    select {
      box-sizing: border-box;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-Collapse {
      display: flex;
      flex-direction: column;
      align-items: stretch;
      border-top: 1px solid var(--jp-border-color2);
      border-bottom: 1px solid var(--jp-border-color2);
    }
    
    .jp-Collapse-header {
      padding: 1px 12px;
      color: var(--jp-ui-font-color1);
      background-color: var(--jp-layout-color1);
      font-size: var(--jp-ui-font-size2);
    }
    
    .jp-Collapse-header:hover {
      background-color: var(--jp-layout-color2);
    }
    
    .jp-Collapse-contents {
      padding: 0px 12px 0px 12px;
      background-color: var(--jp-layout-color1);
      color: var(--jp-ui-font-color1);
      overflow: auto;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Variables
    |----------------------------------------------------------------------------*/
    
    :root {
      --jp-private-commandpalette-search-height: 28px;
    }
    
    /*-----------------------------------------------------------------------------
    | Overall styles
    |----------------------------------------------------------------------------*/
    
    .lm-CommandPalette {
      padding-bottom: 0px;
      color: var(--jp-ui-font-color1);
      background: var(--jp-layout-color1);
      /* This is needed so that all font sizing of children done in ems is
       * relative to this base size */
      font-size: var(--jp-ui-font-size1);
    }
    
    /*-----------------------------------------------------------------------------
    | Modal variant
    |----------------------------------------------------------------------------*/
    
    .jp-ModalCommandPalette {
      position: absolute;
      z-index: 10000;
      top: 38px;
      left: 30%;
      margin: 0;
      padding: 4px;
      width: 40%;
      box-shadow: var(--jp-elevation-z4);
      border-radius: 4px;
      background: var(--jp-layout-color0);
    }
    
    .jp-ModalCommandPalette .lm-CommandPalette {
      max-height: 40vh;
    }
    
    .jp-ModalCommandPalette .lm-CommandPalette .lm-close-icon::after {
      display: none;
    }
    
    .jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-header {
      display: none;
    }
    
    .jp-ModalCommandPalette .lm-CommandPalette .lm-CommandPalette-item {
      margin-left: 4px;
      margin-right: 4px;
    }
    
    .jp-ModalCommandPalette
      .lm-CommandPalette
      .lm-CommandPalette-item.lm-mod-disabled {
      display: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Search
    |----------------------------------------------------------------------------*/
    
    .lm-CommandPalette-search {
      padding: 4px;
      background-color: var(--jp-layout-color1);
      z-index: 2;
    }
    
    .lm-CommandPalette-wrapper {
      overflow: overlay;
      padding: 0px 9px;
      background-color: var(--jp-input-active-background);
      height: 30px;
      box-shadow: inset 0 0 0 var(--jp-border-width) var(--jp-input-border-color);
    }
    
    .lm-CommandPalette.lm-mod-focused .lm-CommandPalette-wrapper {
      box-shadow: inset 0 0 0 1px var(--jp-input-active-box-shadow-color),
        inset 0 0 0 3px var(--jp-input-active-box-shadow-color);
    }
    
    .jp-SearchIconGroup {
      color: white;
      background-color: var(--jp-brand-color1);
      position: absolute;
      top: 4px;
      right: 4px;
      padding: 5px 5px 1px 5px;
    }
    
    .jp-SearchIconGroup svg {
      height: 20px;
      width: 20px;
    }
    
    .jp-SearchIconGroup .jp-icon3[fill] {
      fill: var(--jp-layout-color0);
    }
    
    .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-color2);
      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-color2);
    }
    
    .lm-CommandPalette-item.lm-mod-active {
      color: var(--jp-ui-inverse-font-color1);
      background: var(--jp-brand-color1);
    }
    
    .lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark {
      color: var(--jp-ui-inverse-font-color0);
    }
    
    .lm-CommandPalette-item.lm-mod-active .jp-icon-selectable[fill] {
      fill: var(--jp-layout-color0);
    }
    
    .lm-CommandPalette-item.lm-mod-active .lm-CommandPalette-itemLabel > mark {
      color: var(--jp-ui-inverse-font-color0);
    }
    
    .lm-CommandPalette-item.lm-mod-active:hover:not(.lm-mod-disabled) {
      color: var(--jp-ui-inverse-font-color1);
      background: var(--jp-brand-color1);
    }
    
    .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-color2);
    }
    
    .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.6;
    }
    
    .lm-CommandPalette-item .lm-CommandPalette-itemShortcut {
      flex: 0 0 auto;
    }
    
    .lm-CommandPalette-itemCaption {
      display: none;
    }
    
    .lm-CommandPalette-content {
      background-color: var(--jp-layout-color1);
    }
    
    .lm-CommandPalette-content:empty:after {
      content: 'No results';
      margin: auto;
      margin-top: 20px;
      width: 100px;
      display: block;
      font-size: var(--jp-ui-font-size2);
      font-family: var(--jp-ui-font-family);
      font-weight: lighter;
    }
    
    .lm-CommandPalette-emptyMessage {
      text-align: center;
      margin-top: 24px;
      line-height: 1.32;
      padding: 0px 8px;
      color: var(--jp-content-font-color3);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) 2014-2017, Jupyter Development Team.
    |
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-Dialog {
      position: absolute;
      z-index: 10000;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      top: 0px;
      left: 0px;
      margin: 0;
      padding: 0;
      width: 100%;
      height: 100%;
      background: var(--jp-dialog-background);
    }
    
    .jp-Dialog-content {
      display: flex;
      flex-direction: column;
      margin-left: auto;
      margin-right: auto;
      background: var(--jp-layout-color1);
      padding: 24px;
      padding-bottom: 12px;
      min-width: 300px;
      min-height: 150px;
      max-width: 1000px;
      max-height: 500px;
      box-sizing: border-box;
      box-shadow: var(--jp-elevation-z20);
      word-wrap: break-word;
      border-radius: var(--jp-border-radius);
      /* This is needed so that all font sizing of children done in ems is
       * relative to this base size */
      font-size: var(--jp-ui-font-size1);
      color: var(--jp-ui-font-color1);
      resize: both;
    }
    
    .jp-Dialog-button {
      overflow: visible;
    }
    
    button.jp-Dialog-button:focus {
      outline: 1px solid var(--jp-brand-color1);
      outline-offset: 4px;
      -moz-outline-radius: 0px;
    }
    
    button.jp-Dialog-button:focus::-moz-focus-inner {
      border: 0;
    }
    
    button.jp-Dialog-close-button {
      padding: 0;
      height: 100%;
      min-width: unset;
      min-height: unset;
    }
    
    .jp-Dialog-header {
      display: flex;
      justify-content: space-between;
      flex: 0 0 auto;
      padding-bottom: 12px;
      font-size: var(--jp-ui-font-size3);
      font-weight: 400;
      color: var(--jp-ui-font-color0);
    }
    
    .jp-Dialog-body {
      display: flex;
      flex-direction: column;
      flex: 1 1 auto;
      font-size: var(--jp-ui-font-size1);
      background: var(--jp-layout-color1);
      overflow: auto;
    }
    
    .jp-Dialog-footer {
      display: flex;
      flex-direction: row;
      justify-content: flex-end;
      flex: 0 0 auto;
      margin-left: -12px;
      margin-right: -12px;
      padding: 12px;
    }
    
    .jp-Dialog-title {
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
    }
    
    .jp-Dialog-body > .jp-select-wrapper {
      width: 100%;
    }
    
    .jp-Dialog-body > button {
      padding: 0px 16px;
    }
    
    .jp-Dialog-body > label {
      line-height: 1.4;
      color: var(--jp-ui-font-color0);
    }
    
    .jp-Dialog-button.jp-mod-styled:not(:last-child) {
      margin-right: 12px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) 2014-2016, Jupyter Development Team.
    |
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-HoverBox {
      position: fixed;
    }
    
    .jp-HoverBox.jp-mod-outofview {
      display: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-IFrame {
      width: 100%;
      height: 100%;
    }
    
    .jp-IFrame > iframe {
      border: none;
    }
    
    /*
    When drag events occur, `p-mod-override-cursor` is added to the body.
    Because iframes steal all cursor events, the following two rules are necessary
    to suppress pointer events while resize drags are occurring. There may be a
    better solution to this problem.
    */
    body.lm-mod-override-cursor .jp-IFrame {
      position: relative;
    }
    
    body.lm-mod-override-cursor .jp-IFrame:before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: transparent;
    }
    
    .jp-Input-Boolean-Dialog {
      flex-direction: row-reverse;
      align-items: end;
      width: 100%;
    }
    
    .jp-Input-Boolean-Dialog > label {
      flex: 1 1 auto;
    }
    
    /*-----------------------------------------------------------------------------
    | 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[type='checkbox'].jp-mod-styled {
      appearance: checkbox;
      -webkit-appearance: checkbox;
      -moz-appearance: checkbox;
      height: auto;
    }
    
    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-FileDialog-Checkbox {
      margin-top: 35px;
      display: flex;
      flex-direction: row;
      align-items: end;
      width: 100%;
    }
    
    .jp-FileDialog-Checkbox > label {
      flex: 1 1 auto;
    }
    
    .jp-select-wrapper {
      display: flex;
      position: relative;
      flex-direction: column;
      padding: 1px;
      background-color: var(--jp-layout-color1);
      height: 28px;
      box-sizing: border-box;
      margin-bottom: 12px;
    }
    
    .jp-select-wrapper.jp-mod-focused select.jp-mod-styled {
      border: var(--jp-border-width) solid var(--jp-input-active-border-color);
      box-shadow: var(--jp-input-box-shadow);
      background-color: var(--jp-input-active-background);
    }
    
    select.jp-mod-styled:hover {
      background-color: var(--jp-layout-color1);
      cursor: pointer;
      color: var(--jp-ui-font-color0);
      background-color: var(--jp-input-hover-background);
      box-shadow: inset 0 0px 1px rgba(0, 0, 0, 0.5);
    }
    
    select.jp-mod-styled {
      flex: 1 1 auto;
      height: 32px;
      width: 100%;
      font-size: var(--jp-ui-font-size2);
      background: var(--jp-input-background);
      color: var(--jp-ui-font-color0);
      padding: 0 25px 0 8px;
      border: var(--jp-border-width) solid var(--jp-input-border-color);
      border-radius: 0px;
      outline: none;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) 2014-2016, Jupyter Development Team.
    |
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    :root {
      --jp-private-toolbar-height: calc(
        28px + var(--jp-border-width)
      ); /* leave 28px for content */
    }
    
    .jp-Toolbar {
      color: var(--jp-ui-font-color1);
      flex: 0 0 auto;
      display: flex;
      flex-direction: row;
      border-bottom: var(--jp-border-width) solid var(--jp-toolbar-border-color);
      box-shadow: var(--jp-toolbar-box-shadow);
      background: var(--jp-toolbar-background);
      min-height: var(--jp-toolbar-micro-height);
      padding: 2px;
      z-index: 1;
      overflow-x: auto;
    }
    
    /* Toolbar items */
    
    .jp-Toolbar > .jp-Toolbar-item.jp-Toolbar-spacer {
      flex-grow: 1;
      flex-shrink: 1;
    }
    
    .jp-Toolbar-item.jp-Toolbar-kernelStatus {
      display: inline-block;
      width: 32px;
      background-repeat: no-repeat;
      background-position: center;
      background-size: 16px;
    }
    
    .jp-Toolbar > .jp-Toolbar-item {
      flex: 0 0 auto;
      display: flex;
      padding-left: 1px;
      padding-right: 1px;
      font-size: var(--jp-ui-font-size1);
      line-height: var(--jp-private-toolbar-height);
      height: 100%;
    }
    
    /* Toolbar buttons */
    
    /* This is the div we use to wrap the react component into a Widget */
    div.jp-ToolbarButton {
      color: transparent;
      border: none;
      box-sizing: border-box;
      outline: none;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      padding: 0px;
      margin: 0px;
    }
    
    button.jp-ToolbarButtonComponent {
      background: var(--jp-layout-color1);
      border: none;
      box-sizing: border-box;
      outline: none;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      padding: 0px 6px;
      margin: 0px;
      height: 24px;
      border-radius: var(--jp-border-radius);
      display: flex;
      align-items: center;
      text-align: center;
      font-size: 14px;
      min-width: unset;
      min-height: unset;
    }
    
    button.jp-ToolbarButtonComponent:disabled {
      opacity: 0.4;
    }
    
    button.jp-ToolbarButtonComponent span {
      padding: 0px;
      flex: 0 0 auto;
    }
    
    button.jp-ToolbarButtonComponent .jp-ToolbarButtonComponent-label {
      font-size: var(--jp-ui-font-size1);
      line-height: 100%;
      padding-left: 2px;
      color: var(--jp-ui-font-color1);
    }
    
    #jp-main-dock-panel[data-mode='single-document']
      .jp-MainAreaWidget
      > .jp-Toolbar.jp-Toolbar-micro {
      padding: 0;
      min-height: 0;
    }
    
    #jp-main-dock-panel[data-mode='single-document']
      .jp-MainAreaWidget
      > .jp-Toolbar {
      border: none;
      box-shadow: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) 2014-2017, Jupyter Development Team.
    |
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Copyright (c) 2014-2017, PhosphorJS Contributors
    |
    | Distributed under the terms of the BSD 3-Clause License.
    |
    | The full license is in the file LICENSE, distributed with this software.
    |----------------------------------------------------------------------------*/
    
    
    /* <DEPRECATED> */ body.p-mod-override-cursor *, /* </DEPRECATED> */
    body.lm-mod-override-cursor * {
      cursor: inherit !important;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) 2014-2016, Jupyter Development Team.
    |
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-JSONEditor {
      display: flex;
      flex-direction: column;
      width: 100%;
    }
    
    .jp-JSONEditor-host {
      flex: 1 1 auto;
      border: var(--jp-border-width) solid var(--jp-input-border-color);
      border-radius: 0px;
      background: var(--jp-layout-color0);
      min-height: 50px;
      padding: 1px;
    }
    
    .jp-JSONEditor.jp-mod-error .jp-JSONEditor-host {
      border-color: red;
      outline-color: red;
    }
    
    .jp-JSONEditor-header {
      display: flex;
      flex: 1 0 auto;
      padding: 0 0 0 12px;
    }
    
    .jp-JSONEditor-header label {
      flex: 0 0 auto;
    }
    
    .jp-JSONEditor-commitButton {
      height: 16px;
      width: 16px;
      background-size: 18px;
      background-repeat: no-repeat;
      background-position: center;
    }
    
    .jp-JSONEditor-host.jp-mod-focused {
      background-color: var(--jp-input-active-background);
      border: 1px solid var(--jp-input-active-border-color);
      box-shadow: var(--jp-input-box-shadow);
    }
    
    .jp-Editor.jp-mod-dropTarget {
      border: var(--jp-border-width) solid var(--jp-input-active-border-color);
      box-shadow: var(--jp-input-box-shadow);
    }
    
    /* BASICS */
    
    .CodeMirror {
      /* Set height, width, borders, and global font properties here */
      font-family: monospace;
      height: 300px;
      color: black;
      direction: ltr;
    }
    
    /* PADDING */
    
    .CodeMirror-lines {
      padding: 4px 0; /* Vertical padding around content */
    }
    .CodeMirror pre.CodeMirror-line,
    .CodeMirror pre.CodeMirror-line-like {
      padding: 0 4px; /* Horizontal padding of content */
    }
    
    .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
      background-color: white; /* The little square between H and V scrollbars */
    }
    
    /* GUTTER */
    
    .CodeMirror-gutters {
      border-right: 1px solid #ddd;
      background-color: #f7f7f7;
      white-space: nowrap;
    }
    .CodeMirror-linenumbers {}
    .CodeMirror-linenumber {
      padding: 0 3px 0 5px;
      min-width: 20px;
      text-align: right;
      color: #999;
      white-space: nowrap;
    }
    
    .CodeMirror-guttermarker { color: black; }
    .CodeMirror-guttermarker-subtle { color: #999; }
    
    /* CURSOR */
    
    .CodeMirror-cursor {
      border-left: 1px solid black;
      border-right: none;
      width: 0;
    }
    /* Shown when moving in bi-directional text */
    .CodeMirror div.CodeMirror-secondarycursor {
      border-left: 1px solid silver;
    }
    .cm-fat-cursor .CodeMirror-cursor {
      width: auto;
      border: 0 !important;
      background: #7e7;
    }
    .cm-fat-cursor div.CodeMirror-cursors {
      z-index: 1;
    }
    .cm-fat-cursor-mark {
      background-color: rgba(20, 255, 20, 0.5);
      -webkit-animation: blink 1.06s steps(1) infinite;
      -moz-animation: blink 1.06s steps(1) infinite;
      animation: blink 1.06s steps(1) infinite;
    }
    .cm-animate-fat-cursor {
      width: auto;
      border: 0;
      -webkit-animation: blink 1.06s steps(1) infinite;
      -moz-animation: blink 1.06s steps(1) infinite;
      animation: blink 1.06s steps(1) infinite;
      background-color: #7e7;
    }
    @-moz-keyframes blink {
      0% {}
      50% { background-color: transparent; }
      100% {}
    }
    @-webkit-keyframes blink {
      0% {}
      50% { background-color: transparent; }
      100% {}
    }
    @keyframes blink {
      0% {}
      50% { background-color: transparent; }
      100% {}
    }
    
    /* Can style cursor different in overwrite (non-insert) mode */
    .CodeMirror-overwrite .CodeMirror-cursor {}
    
    .cm-tab { display: inline-block; text-decoration: inherit; }
    
    .CodeMirror-rulers {
      position: absolute;
      left: 0; right: 0; top: -50px; bottom: 0;
      overflow: hidden;
    }
    .CodeMirror-ruler {
      border-left: 1px solid #ccc;
      top: 0; bottom: 0;
      position: absolute;
    }
    
    /* DEFAULT THEME */
    
    .cm-s-default .cm-header {color: blue;}
    .cm-s-default .cm-quote {color: #090;}
    .cm-negative {color: #d44;}
    .cm-positive {color: #292;}
    .cm-header, .cm-strong {font-weight: bold;}
    .cm-em {font-style: italic;}
    .cm-link {text-decoration: underline;}
    .cm-strikethrough {text-decoration: line-through;}
    
    .cm-s-default .cm-keyword {color: #708;}
    .cm-s-default .cm-atom {color: #219;}
    .cm-s-default .cm-number {color: #164;}
    .cm-s-default .cm-def {color: #00f;}
    .cm-s-default .cm-variable,
    .cm-s-default .cm-punctuation,
    .cm-s-default .cm-property,
    .cm-s-default .cm-operator {}
    .cm-s-default .cm-variable-2 {color: #05a;}
    .cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}
    .cm-s-default .cm-comment {color: #a50;}
    .cm-s-default .cm-string {color: #a11;}
    .cm-s-default .cm-string-2 {color: #f50;}
    .cm-s-default .cm-meta {color: #555;}
    .cm-s-default .cm-qualifier {color: #555;}
    .cm-s-default .cm-builtin {color: #30a;}
    .cm-s-default .cm-bracket {color: #997;}
    .cm-s-default .cm-tag {color: #170;}
    .cm-s-default .cm-attribute {color: #00c;}
    .cm-s-default .cm-hr {color: #999;}
    .cm-s-default .cm-link {color: #00c;}
    
    .cm-s-default .cm-error {color: #f00;}
    .cm-invalidchar {color: #f00;}
    
    .CodeMirror-composing { border-bottom: 2px solid; }
    
    /* Default styles for common addons */
    
    div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}
    div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}
    .CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
    .CodeMirror-activeline-background {background: #e8f2ff;}
    
    /* STOP */
    
    /* The rest of this file contains styles related to the mechanics of
       the editor. You probably shouldn't touch them. */
    
    .CodeMirror {
      position: relative;
      overflow: hidden;
      background: white;
    }
    
    .CodeMirror-scroll {
      overflow: scroll !important; /* Things will break if this is overridden */
      /* 50px is the magic margin used to hide the element's real scrollbars */
      /* See overflow: hidden in .CodeMirror */
      margin-bottom: -50px; margin-right: -50px;
      padding-bottom: 50px;
      height: 100%;
      outline: none; /* Prevent dragging from highlighting the element */
      position: relative;
    }
    .CodeMirror-sizer {
      position: relative;
      border-right: 50px solid transparent;
    }
    
    /* The fake, visible scrollbars. Used to force redraw during scrolling
       before actual scrolling happens, thus preventing shaking and
       flickering artifacts. */
    .CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
      position: absolute;
      z-index: 6;
      display: none;
      outline: none;
    }
    .CodeMirror-vscrollbar {
      right: 0; top: 0;
      overflow-x: hidden;
      overflow-y: scroll;
    }
    .CodeMirror-hscrollbar {
      bottom: 0; left: 0;
      overflow-y: hidden;
      overflow-x: scroll;
    }
    .CodeMirror-scrollbar-filler {
      right: 0; bottom: 0;
    }
    .CodeMirror-gutter-filler {
      left: 0; bottom: 0;
    }
    
    .CodeMirror-gutters {
      position: absolute; left: 0; top: 0;
      min-height: 100%;
      z-index: 3;
    }
    .CodeMirror-gutter {
      white-space: normal;
      height: 100%;
      display: inline-block;
      vertical-align: top;
      margin-bottom: -50px;
    }
    .CodeMirror-gutter-wrapper {
      position: absolute;
      z-index: 4;
      background: none !important;
      border: none !important;
    }
    .CodeMirror-gutter-background {
      position: absolute;
      top: 0; bottom: 0;
      z-index: 4;
    }
    .CodeMirror-gutter-elt {
      position: absolute;
      cursor: default;
      z-index: 4;
    }
    .CodeMirror-gutter-wrapper ::selection { background-color: transparent }
    .CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }
    
    .CodeMirror-lines {
      cursor: text;
      min-height: 1px; /* prevents collapsing before first draw */
    }
    .CodeMirror pre.CodeMirror-line,
    .CodeMirror pre.CodeMirror-line-like {
      /* Reset some styles that the rest of the page might have set */
      -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
      border-width: 0;
      background: transparent;
      font-family: inherit;
      font-size: inherit;
      margin: 0;
      white-space: pre;
      word-wrap: normal;
      line-height: inherit;
      color: inherit;
      z-index: 2;
      position: relative;
      overflow: visible;
      -webkit-tap-highlight-color: transparent;
      -webkit-font-variant-ligatures: contextual;
      font-variant-ligatures: contextual;
    }
    .CodeMirror-wrap pre.CodeMirror-line,
    .CodeMirror-wrap pre.CodeMirror-line-like {
      word-wrap: break-word;
      white-space: pre-wrap;
      word-break: normal;
    }
    
    .CodeMirror-linebackground {
      position: absolute;
      left: 0; right: 0; top: 0; bottom: 0;
      z-index: 0;
    }
    
    .CodeMirror-linewidget {
      position: relative;
      z-index: 2;
      padding: 0.1px; /* Force widget margins to stay inside of the container */
    }
    
    .CodeMirror-widget {}
    
    .CodeMirror-rtl pre { direction: rtl; }
    
    .CodeMirror-code {
      outline: none;
    }
    
    /* Force content-box sizing for the elements where we expect it */
    .CodeMirror-scroll,
    .CodeMirror-sizer,
    .CodeMirror-gutter,
    .CodeMirror-gutters,
    .CodeMirror-linenumber {
      -moz-box-sizing: content-box;
      box-sizing: content-box;
    }
    
    .CodeMirror-measure {
      position: absolute;
      width: 100%;
      height: 0;
      overflow: hidden;
      visibility: hidden;
    }
    
    .CodeMirror-cursor {
      position: absolute;
      pointer-events: none;
    }
    .CodeMirror-measure pre { position: static; }
    
    div.CodeMirror-cursors {
      visibility: hidden;
      position: relative;
      z-index: 3;
    }
    div.CodeMirror-dragcursors {
      visibility: visible;
    }
    
    .CodeMirror-focused div.CodeMirror-cursors {
      visibility: visible;
    }
    
    .CodeMirror-selected { background: #d9d9d9; }
    .CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
    .CodeMirror-crosshair { cursor: crosshair; }
    .CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
    .CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }
    
    .cm-searching {
      background-color: #ffa;
      background-color: rgba(255, 255, 0, .4);
    }
    
    /* Used to force a border model for a node */
    .cm-force-border { padding-right: .1px; }
    
    @media print {
      /* Hide the cursor when printing */
      .CodeMirror div.CodeMirror-cursors {
        visibility: hidden;
      }
    }
    
    /* See issue #2901 */
    .cm-tab-wrap-hack:after { content: ''; }
    
    /* Help users use markselection to safely style text background */
    span.CodeMirror-selectedtext { background: none; }
    
    .CodeMirror-dialog {
      position: absolute;
      left: 0; right: 0;
      background: inherit;
      z-index: 15;
      padding: .1em .8em;
      overflow: hidden;
      color: inherit;
    }
    
    .CodeMirror-dialog-top {
      border-bottom: 1px solid #eee;
      top: 0;
    }
    
    .CodeMirror-dialog-bottom {
      border-top: 1px solid #eee;
      bottom: 0;
    }
    
    .CodeMirror-dialog input {
      border: none;
      outline: none;
      background: transparent;
      width: 20em;
      color: inherit;
      font-family: monospace;
    }
    
    .CodeMirror-dialog button {
      font-size: 70%;
    }
    
    .CodeMirror-foldmarker {
      color: blue;
      text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px;
      font-family: arial;
      line-height: .3;
      cursor: pointer;
    }
    .CodeMirror-foldgutter {
      width: .7em;
    }
    .CodeMirror-foldgutter-open,
    .CodeMirror-foldgutter-folded {
      cursor: pointer;
    }
    .CodeMirror-foldgutter-open:after {
      content: "\25BE";
    }
    .CodeMirror-foldgutter-folded:after {
      content: "\25B8";
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .CodeMirror {
      line-height: var(--jp-code-line-height);
      font-size: var(--jp-code-font-size);
      font-family: var(--jp-code-font-family);
      border: 0;
      border-radius: 0;
      height: auto;
      /* Changed to auto to autogrow */
    }
    
    .CodeMirror pre {
      padding: 0 var(--jp-code-padding);
    }
    
    .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-dialog {
      background-color: var(--jp-layout-color0);
      color: var(--jp-content-font-color1);
    }
    
    /* This causes https://github.com/jupyter/jupyterlab/issues/522 */
    /* May not cause it not because we changed it! */
    .CodeMirror-lines {
      padding: var(--jp-code-padding) 0;
    }
    
    .CodeMirror-linenumber {
      padding: 0 8px;
    }
    
    .jp-CodeMirrorEditor {
      cursor: text;
    }
    
    .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
      border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color);
    }
    
    /* When zoomed out 67% and 33% on a screen of 1440 width x 900 height */
    @media screen and (min-width: 2138px) and (max-width: 4319px) {
      .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
        border-left: var(--jp-code-cursor-width1) solid
          var(--jp-editor-cursor-color);
      }
    }
    
    /* When zoomed out less than 33% */
    @media screen and (min-width: 4320px) {
      .jp-CodeMirrorEditor[data-type='inline'] .CodeMirror-cursor {
        border-left: var(--jp-code-cursor-width2) solid
          var(--jp-editor-cursor-color);
      }
    }
    
    .CodeMirror.jp-mod-readOnly .CodeMirror-cursor {
      display: none;
    }
    
    .CodeMirror-gutters {
      border-right: 1px solid var(--jp-border-color2);
      background-color: var(--jp-layout-color0);
    }
    
    .jp-CollaboratorCursor {
      border-left: 5px solid transparent;
      border-right: 5px solid transparent;
      border-top: none;
      border-bottom: 3px solid;
      background-clip: content-box;
      margin-left: -5px;
      margin-right: -5px;
    }
    
    .CodeMirror-selectedtext.cm-searching {
      background-color: var(--jp-search-selected-match-background-color) !important;
      color: var(--jp-search-selected-match-color) !important;
    }
    
    .cm-searching {
      background-color: var(
        --jp-search-unselected-match-background-color
      ) !important;
      color: var(--jp-search-unselected-match-color) !important;
    }
    
    .CodeMirror-focused .CodeMirror-selected {
      background-color: var(--jp-editor-selected-focused-background);
    }
    
    .CodeMirror-selected {
      background-color: var(--jp-editor-selected-background);
    }
    
    .jp-CollaboratorCursor-hover {
      position: absolute;
      z-index: 1;
      transform: translateX(-50%);
      color: white;
      border-radius: 3px;
      padding-left: 4px;
      padding-right: 4px;
      padding-top: 1px;
      padding-bottom: 1px;
      text-align: center;
      font-size: var(--jp-ui-font-size1);
      white-space: nowrap;
    }
    
    .jp-CodeMirror-ruler {
      border-left: 1px dashed var(--jp-border-color2);
    }
    
    /**
     * Here is our jupyter theme for CodeMirror syntax highlighting
     * This is used in our marked.js syntax highlighting and CodeMirror itself
     * The string "jupyter" is set in ../codemirror/widget.DEFAULT_CODEMIRROR_THEME
     * This came from the classic notebook, which came form highlight.js/GitHub
     */
    
    /**
     * CodeMirror themes are handling the background/color in this way. This works
     * fine for CodeMirror editors outside the notebook, but the notebook styles
     * these things differently.
     */
    .CodeMirror.cm-s-jupyter {
      background: var(--jp-layout-color0);
      color: var(--jp-content-font-color1);
    }
    
    /* In the notebook, we want this styling to be handled by its container */
    .jp-CodeConsole .CodeMirror.cm-s-jupyter,
    .jp-Notebook .CodeMirror.cm-s-jupyter {
      background: transparent;
    }
    
    .cm-s-jupyter .CodeMirror-cursor {
      border-left: var(--jp-code-cursor-width0) solid var(--jp-editor-cursor-color);
    }
    .cm-s-jupyter span.cm-keyword {
      color: var(--jp-mirror-editor-keyword-color);
      font-weight: bold;
    }
    .cm-s-jupyter span.cm-atom {
      color: var(--jp-mirror-editor-atom-color);
    }
    .cm-s-jupyter span.cm-number {
      color: var(--jp-mirror-editor-number-color);
    }
    .cm-s-jupyter span.cm-def {
      color: var(--jp-mirror-editor-def-color);
    }
    .cm-s-jupyter span.cm-variable {
      color: var(--jp-mirror-editor-variable-color);
    }
    .cm-s-jupyter span.cm-variable-2 {
      color: var(--jp-mirror-editor-variable-2-color);
    }
    .cm-s-jupyter span.cm-variable-3 {
      color: var(--jp-mirror-editor-variable-3-color);
    }
    .cm-s-jupyter span.cm-punctuation {
      color: var(--jp-mirror-editor-punctuation-color);
    }
    .cm-s-jupyter span.cm-property {
      color: var(--jp-mirror-editor-property-color);
    }
    .cm-s-jupyter span.cm-operator {
      color: var(--jp-mirror-editor-operator-color);
      font-weight: bold;
    }
    .cm-s-jupyter span.cm-comment {
      color: var(--jp-mirror-editor-comment-color);
      font-style: italic;
    }
    .cm-s-jupyter span.cm-string {
      color: var(--jp-mirror-editor-string-color);
    }
    .cm-s-jupyter span.cm-string-2 {
      color: var(--jp-mirror-editor-string-2-color);
    }
    .cm-s-jupyter span.cm-meta {
      color: var(--jp-mirror-editor-meta-color);
    }
    .cm-s-jupyter span.cm-qualifier {
      color: var(--jp-mirror-editor-qualifier-color);
    }
    .cm-s-jupyter span.cm-builtin {
      color: var(--jp-mirror-editor-builtin-color);
    }
    .cm-s-jupyter span.cm-bracket {
      color: var(--jp-mirror-editor-bracket-color);
    }
    .cm-s-jupyter span.cm-tag {
      color: var(--jp-mirror-editor-tag-color);
    }
    .cm-s-jupyter span.cm-attribute {
      color: var(--jp-mirror-editor-attribute-color);
    }
    .cm-s-jupyter span.cm-header {
      color: var(--jp-mirror-editor-header-color);
    }
    .cm-s-jupyter span.cm-quote {
      color: var(--jp-mirror-editor-quote-color);
    }
    .cm-s-jupyter span.cm-link {
      color: var(--jp-mirror-editor-link-color);
    }
    .cm-s-jupyter span.cm-error {
      color: var(--jp-mirror-editor-error-color);
    }
    .cm-s-jupyter span.cm-hr {
      color: #999;
    }
    
    .cm-s-jupyter span.cm-tab {
      background: url();
      background-position: right;
      background-repeat: no-repeat;
    }
    
    .cm-s-jupyter .CodeMirror-activeline-background,
    .cm-s-jupyter .CodeMirror-gutter {
      background-color: var(--jp-layout-color2);
    }
    
    /* Styles for shared cursors (remote cursor locations and selected ranges) */
    .jp-CodeMirrorEditor .remote-caret {
      position: relative;
      border-left: 2px solid black;
      margin-left: -1px;
      margin-right: -1px;
      box-sizing: border-box;
    }
    
    .jp-CodeMirrorEditor .remote-caret > div {
      white-space: nowrap;
      position: absolute;
      top: -1.15em;
      padding-bottom: 0.05em;
      left: -2px;
      font-size: 0.95em;
      background-color: rgb(250, 129, 0);
      font-family: var(--jp-ui-font-family);
      font-weight: bold;
      line-height: normal;
      user-select: none;
      color: white;
      padding-left: 2px;
      padding-right: 2px;
      z-index: 3;
      transition: opacity 0.3s ease-in-out;
    }
    
    .jp-CodeMirrorEditor .remote-caret.hide-name > div {
      transition-delay: 0.7s;
      opacity: 0;
    }
    
    .jp-CodeMirrorEditor .remote-caret:hover > div {
      opacity: 1;
      transition-delay: 0s;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | RenderedText
    |----------------------------------------------------------------------------*/
    
    :root {
      /* This is the padding value to fill the gaps between lines containing spans with background color. */
      --jp-private-code-span-padding: calc(
        (var(--jp-code-line-height) - 1) * var(--jp-code-font-size) / 2
      );
    }
    
    .jp-RenderedText {
      text-align: left;
      padding-left: var(--jp-code-padding);
      line-height: var(--jp-code-line-height);
      font-family: var(--jp-code-font-family);
    }
    
    .jp-RenderedText pre,
    .jp-RenderedJavaScript pre,
    .jp-RenderedHTMLCommon pre {
      color: var(--jp-content-font-color1);
      font-size: var(--jp-code-font-size);
      border: none;
      margin: 0px;
      padding: 0px;
    }
    
    .jp-RenderedText pre a:link {
      text-decoration: none;
      color: var(--jp-content-link-color);
    }
    .jp-RenderedText pre a:hover {
      text-decoration: underline;
      color: var(--jp-content-link-color);
    }
    .jp-RenderedText pre a:visited {
      text-decoration: none;
      color: var(--jp-content-link-color);
    }
    
    /* console foregrounds and backgrounds */
    .jp-RenderedText pre .ansi-black-fg {
      color: #3e424d;
    }
    .jp-RenderedText pre .ansi-red-fg {
      color: #e75c58;
    }
    .jp-RenderedText pre .ansi-green-fg {
      color: #00a250;
    }
    .jp-RenderedText pre .ansi-yellow-fg {
      color: #ddb62b;
    }
    .jp-RenderedText pre .ansi-blue-fg {
      color: #208ffb;
    }
    .jp-RenderedText pre .ansi-magenta-fg {
      color: #d160c4;
    }
    .jp-RenderedText pre .ansi-cyan-fg {
      color: #60c6c8;
    }
    .jp-RenderedText pre .ansi-white-fg {
      color: #c5c1b4;
    }
    
    .jp-RenderedText pre .ansi-black-bg {
      background-color: #3e424d;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-red-bg {
      background-color: #e75c58;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-green-bg {
      background-color: #00a250;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-yellow-bg {
      background-color: #ddb62b;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-blue-bg {
      background-color: #208ffb;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-magenta-bg {
      background-color: #d160c4;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-cyan-bg {
      background-color: #60c6c8;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-white-bg {
      background-color: #c5c1b4;
      padding: var(--jp-private-code-span-padding) 0;
    }
    
    .jp-RenderedText pre .ansi-black-intense-fg {
      color: #282c36;
    }
    .jp-RenderedText pre .ansi-red-intense-fg {
      color: #b22b31;
    }
    .jp-RenderedText pre .ansi-green-intense-fg {
      color: #007427;
    }
    .jp-RenderedText pre .ansi-yellow-intense-fg {
      color: #b27d12;
    }
    .jp-RenderedText pre .ansi-blue-intense-fg {
      color: #0065ca;
    }
    .jp-RenderedText pre .ansi-magenta-intense-fg {
      color: #a03196;
    }
    .jp-RenderedText pre .ansi-cyan-intense-fg {
      color: #258f8f;
    }
    .jp-RenderedText pre .ansi-white-intense-fg {
      color: #a1a6b2;
    }
    
    .jp-RenderedText pre .ansi-black-intense-bg {
      background-color: #282c36;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-red-intense-bg {
      background-color: #b22b31;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-green-intense-bg {
      background-color: #007427;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-yellow-intense-bg {
      background-color: #b27d12;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-blue-intense-bg {
      background-color: #0065ca;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-magenta-intense-bg {
      background-color: #a03196;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-cyan-intense-bg {
      background-color: #258f8f;
      padding: var(--jp-private-code-span-padding) 0;
    }
    .jp-RenderedText pre .ansi-white-intense-bg {
      background-color: #a1a6b2;
      padding: var(--jp-private-code-span-padding) 0;
    }
    
    .jp-RenderedText pre .ansi-default-inverse-fg {
      color: var(--jp-ui-inverse-font-color0);
    }
    .jp-RenderedText pre .ansi-default-inverse-bg {
      background-color: var(--jp-inverse-layout-color0);
      padding: var(--jp-private-code-span-padding) 0;
    }
    
    .jp-RenderedText pre .ansi-bold {
      font-weight: bold;
    }
    .jp-RenderedText pre .ansi-underline {
      text-decoration: underline;
    }
    
    .jp-RenderedText[data-mime-type='application/vnd.jupyter.stderr'] {
      background: var(--jp-rendermime-error-background);
      padding-top: var(--jp-code-padding);
    }
    
    /*-----------------------------------------------------------------------------
    | RenderedLatex
    |----------------------------------------------------------------------------*/
    
    .jp-RenderedLatex {
      color: var(--jp-content-font-color1);
      font-size: var(--jp-content-font-size1);
      line-height: var(--jp-content-line-height);
    }
    
    /* Left-justify outputs.*/
    .jp-OutputArea-output.jp-RenderedLatex {
      padding: var(--jp-code-padding);
      text-align: left;
    }
    
    /*-----------------------------------------------------------------------------
    | RenderedHTML
    |----------------------------------------------------------------------------*/
    
    .jp-RenderedHTMLCommon {
      color: var(--jp-content-font-color1);
      font-family: var(--jp-content-font-family);
      font-size: var(--jp-content-font-size1);
      line-height: var(--jp-content-line-height);
      /* Give a bit more R padding on Markdown text to keep line lengths reasonable */
      padding-right: 20px;
    }
    
    .jp-RenderedHTMLCommon em {
      font-style: italic;
    }
    
    .jp-RenderedHTMLCommon strong {
      font-weight: bold;
    }
    
    .jp-RenderedHTMLCommon u {
      text-decoration: underline;
    }
    
    .jp-RenderedHTMLCommon a:link {
      text-decoration: none;
      color: var(--jp-content-link-color);
    }
    
    .jp-RenderedHTMLCommon a:hover {
      text-decoration: underline;
      color: var(--jp-content-link-color);
    }
    
    .jp-RenderedHTMLCommon a:visited {
      text-decoration: none;
      color: var(--jp-content-link-color);
    }
    
    /* Headings */
    
    .jp-RenderedHTMLCommon h1,
    .jp-RenderedHTMLCommon h2,
    .jp-RenderedHTMLCommon h3,
    .jp-RenderedHTMLCommon h4,
    .jp-RenderedHTMLCommon h5,
    .jp-RenderedHTMLCommon h6 {
      line-height: var(--jp-content-heading-line-height);
      font-weight: var(--jp-content-heading-font-weight);
      font-style: normal;
      margin: var(--jp-content-heading-margin-top) 0
        var(--jp-content-heading-margin-bottom) 0;
    }
    
    .jp-RenderedHTMLCommon h1:first-child,
    .jp-RenderedHTMLCommon h2:first-child,
    .jp-RenderedHTMLCommon h3:first-child,
    .jp-RenderedHTMLCommon h4:first-child,
    .jp-RenderedHTMLCommon h5:first-child,
    .jp-RenderedHTMLCommon h6:first-child {
      margin-top: calc(0.5 * var(--jp-content-heading-margin-top));
    }
    
    .jp-RenderedHTMLCommon h1:last-child,
    .jp-RenderedHTMLCommon h2:last-child,
    .jp-RenderedHTMLCommon h3:last-child,
    .jp-RenderedHTMLCommon h4:last-child,
    .jp-RenderedHTMLCommon h5:last-child,
    .jp-RenderedHTMLCommon h6:last-child {
      margin-bottom: calc(0.5 * var(--jp-content-heading-margin-bottom));
    }
    
    .jp-RenderedHTMLCommon h1 {
      font-size: var(--jp-content-font-size5);
    }
    
    .jp-RenderedHTMLCommon h2 {
      font-size: var(--jp-content-font-size4);
    }
    
    .jp-RenderedHTMLCommon h3 {
      font-size: var(--jp-content-font-size3);
    }
    
    .jp-RenderedHTMLCommon h4 {
      font-size: var(--jp-content-font-size2);
    }
    
    .jp-RenderedHTMLCommon h5 {
      font-size: var(--jp-content-font-size1);
    }
    
    .jp-RenderedHTMLCommon h6 {
      font-size: var(--jp-content-font-size0);
    }
    
    /* Lists */
    
    .jp-RenderedHTMLCommon ul:not(.list-inline),
    .jp-RenderedHTMLCommon ol:not(.list-inline) {
      padding-left: 2em;
    }
    
    .jp-RenderedHTMLCommon ul {
      list-style: disc;
    }
    
    .jp-RenderedHTMLCommon ul ul {
      list-style: square;
    }
    
    .jp-RenderedHTMLCommon ul ul ul {
      list-style: circle;
    }
    
    .jp-RenderedHTMLCommon ol {
      list-style: decimal;
    }
    
    .jp-RenderedHTMLCommon ol ol {
      list-style: upper-alpha;
    }
    
    .jp-RenderedHTMLCommon ol ol ol {
      list-style: lower-alpha;
    }
    
    .jp-RenderedHTMLCommon ol ol ol ol {
      list-style: lower-roman;
    }
    
    .jp-RenderedHTMLCommon ol ol ol ol ol {
      list-style: decimal;
    }
    
    .jp-RenderedHTMLCommon ol,
    .jp-RenderedHTMLCommon ul {
      margin-bottom: 1em;
    }
    
    .jp-RenderedHTMLCommon ul ul,
    .jp-RenderedHTMLCommon ul ol,
    .jp-RenderedHTMLCommon ol ul,
    .jp-RenderedHTMLCommon ol ol {
      margin-bottom: 0em;
    }
    
    .jp-RenderedHTMLCommon hr {
      color: var(--jp-border-color2);
      background-color: var(--jp-border-color1);
      margin-top: 1em;
      margin-bottom: 1em;
    }
    
    .jp-RenderedHTMLCommon > pre {
      margin: 1.5em 2em;
    }
    
    .jp-RenderedHTMLCommon pre,
    .jp-RenderedHTMLCommon code {
      border: 0;
      background-color: var(--jp-layout-color0);
      color: var(--jp-content-font-color1);
      font-family: var(--jp-code-font-family);
      font-size: inherit;
      line-height: var(--jp-code-line-height);
      padding: 0;
      white-space: pre-wrap;
    }
    
    .jp-RenderedHTMLCommon :not(pre) > code {
      background-color: var(--jp-layout-color2);
      padding: 1px 5px;
    }
    
    /* Tables */
    
    .jp-RenderedHTMLCommon table {
      border-collapse: collapse;
      border-spacing: 0;
      border: none;
      color: var(--jp-ui-font-color1);
      font-size: 12px;
      table-layout: fixed;
      margin-left: auto;
      margin-right: auto;
    }
    
    .jp-RenderedHTMLCommon thead {
      border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
      vertical-align: bottom;
    }
    
    .jp-RenderedHTMLCommon td,
    .jp-RenderedHTMLCommon th,
    .jp-RenderedHTMLCommon tr {
      vertical-align: middle;
      padding: 0.5em 0.5em;
      line-height: normal;
      white-space: normal;
      max-width: none;
      border: none;
    }
    
    .jp-RenderedMarkdown.jp-RenderedHTMLCommon td,
    .jp-RenderedMarkdown.jp-RenderedHTMLCommon th {
      max-width: none;
    }
    
    :not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon td,
    :not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon th,
    :not(.jp-RenderedMarkdown).jp-RenderedHTMLCommon tr {
      text-align: right;
    }
    
    .jp-RenderedHTMLCommon th {
      font-weight: bold;
    }
    
    .jp-RenderedHTMLCommon tbody tr:nth-child(odd) {
      background: var(--jp-layout-color0);
    }
    
    .jp-RenderedHTMLCommon tbody tr:nth-child(even) {
      background: var(--jp-rendermime-table-row-background);
    }
    
    .jp-RenderedHTMLCommon tbody tr:hover {
      background: var(--jp-rendermime-table-row-hover-background);
    }
    
    .jp-RenderedHTMLCommon table {
      margin-bottom: 1em;
    }
    
    .jp-RenderedHTMLCommon p {
      text-align: left;
      margin: 0px;
    }
    
    .jp-RenderedHTMLCommon p {
      margin-bottom: 1em;
    }
    
    .jp-RenderedHTMLCommon img {
      -moz-force-broken-image-icon: 1;
    }
    
    /* Restrict to direct children as other images could be nested in other content. */
    .jp-RenderedHTMLCommon > img {
      display: block;
      margin-left: 0;
      margin-right: 0;
      margin-bottom: 1em;
    }
    
    /* Change color behind transparent images if they need it... */
    [data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-light-background {
      background-color: var(--jp-inverse-layout-color1);
    }
    [data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-dark-background {
      background-color: var(--jp-inverse-layout-color1);
    }
    /* ...or leave it untouched if they don't */
    [data-jp-theme-light='false'] .jp-RenderedImage img.jp-needs-dark-background {
    }
    [data-jp-theme-light='true'] .jp-RenderedImage img.jp-needs-light-background {
    }
    
    .jp-RenderedHTMLCommon img,
    .jp-RenderedImage img,
    .jp-RenderedHTMLCommon svg,
    .jp-RenderedSVG svg {
      max-width: 100%;
      height: auto;
    }
    
    .jp-RenderedHTMLCommon img.jp-mod-unconfined,
    .jp-RenderedImage img.jp-mod-unconfined,
    .jp-RenderedHTMLCommon svg.jp-mod-unconfined,
    .jp-RenderedSVG svg.jp-mod-unconfined {
      max-width: none;
    }
    
    .jp-RenderedHTMLCommon .alert {
      padding: var(--jp-notebook-padding);
      border: var(--jp-border-width) solid transparent;
      border-radius: var(--jp-border-radius);
      margin-bottom: 1em;
    }
    
    .jp-RenderedHTMLCommon .alert-info {
      color: var(--jp-info-color0);
      background-color: var(--jp-info-color3);
      border-color: var(--jp-info-color2);
    }
    .jp-RenderedHTMLCommon .alert-info hr {
      border-color: var(--jp-info-color3);
    }
    .jp-RenderedHTMLCommon .alert-info > p:last-child,
    .jp-RenderedHTMLCommon .alert-info > ul:last-child {
      margin-bottom: 0;
    }
    
    .jp-RenderedHTMLCommon .alert-warning {
      color: var(--jp-warn-color0);
      background-color: var(--jp-warn-color3);
      border-color: var(--jp-warn-color2);
    }
    .jp-RenderedHTMLCommon .alert-warning hr {
      border-color: var(--jp-warn-color3);
    }
    .jp-RenderedHTMLCommon .alert-warning > p:last-child,
    .jp-RenderedHTMLCommon .alert-warning > ul:last-child {
      margin-bottom: 0;
    }
    
    .jp-RenderedHTMLCommon .alert-success {
      color: var(--jp-success-color0);
      background-color: var(--jp-success-color3);
      border-color: var(--jp-success-color2);
    }
    .jp-RenderedHTMLCommon .alert-success hr {
      border-color: var(--jp-success-color3);
    }
    .jp-RenderedHTMLCommon .alert-success > p:last-child,
    .jp-RenderedHTMLCommon .alert-success > ul:last-child {
      margin-bottom: 0;
    }
    
    .jp-RenderedHTMLCommon .alert-danger {
      color: var(--jp-error-color0);
      background-color: var(--jp-error-color3);
      border-color: var(--jp-error-color2);
    }
    .jp-RenderedHTMLCommon .alert-danger hr {
      border-color: var(--jp-error-color3);
    }
    .jp-RenderedHTMLCommon .alert-danger > p:last-child,
    .jp-RenderedHTMLCommon .alert-danger > ul:last-child {
      margin-bottom: 0;
    }
    
    .jp-RenderedHTMLCommon blockquote {
      margin: 1em 2em;
      padding: 0 1em;
      border-left: 5px solid var(--jp-border-color2);
    }
    
    a.jp-InternalAnchorLink {
      visibility: hidden;
      margin-left: 8px;
      color: var(--md-blue-800);
    }
    
    h1:hover .jp-InternalAnchorLink,
    h2:hover .jp-InternalAnchorLink,
    h3:hover .jp-InternalAnchorLink,
    h4:hover .jp-InternalAnchorLink,
    h5:hover .jp-InternalAnchorLink,
    h6:hover .jp-InternalAnchorLink {
      visibility: visible;
    }
    
    .jp-RenderedHTMLCommon kbd {
      background-color: var(--jp-rendermime-table-row-background);
      border: 1px solid var(--jp-border-color0);
      border-bottom-color: var(--jp-border-color2);
      border-radius: 3px;
      box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.25);
      display: inline-block;
      font-size: 0.8em;
      line-height: 1em;
      padding: 0.2em 0.5em;
    }
    
    /* Most direct children of .jp-RenderedHTMLCommon have a margin-bottom of 1.0.
     * At the bottom of cells this is a bit too much as there is also spacing
     * between cells. Going all the way to 0 gets too tight between markdown and
     * code cells.
     */
    .jp-RenderedHTMLCommon > *:last-child {
      margin-bottom: 0.5em;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-MimeDocument {
      outline: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Variables
    |----------------------------------------------------------------------------*/
    
    :root {
      --jp-private-filebrowser-button-height: 28px;
      --jp-private-filebrowser-button-width: 48px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-FileBrowser {
      display: flex;
      flex-direction: column;
      color: var(--jp-ui-font-color1);
      background: var(--jp-layout-color1);
      /* This is needed so that all font sizing of children done in ems is
       * relative to this base size */
      font-size: var(--jp-ui-font-size1);
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar {
      border-bottom: none;
      height: auto;
      margin: var(--jp-toolbar-header-margin);
      box-shadow: none;
    }
    
    .jp-BreadCrumbs {
      flex: 0 0 auto;
      margin: 8px 12px 8px 12px;
    }
    
    .jp-BreadCrumbs-item {
      margin: 0px 2px;
      padding: 0px 2px;
      border-radius: var(--jp-border-radius);
      cursor: pointer;
    }
    
    .jp-BreadCrumbs-item:hover {
      background-color: var(--jp-layout-color2);
    }
    
    .jp-BreadCrumbs-item:first-child {
      margin-left: 0px;
    }
    
    .jp-BreadCrumbs-item.jp-mod-dropTarget {
      background-color: var(--jp-brand-color2);
      opacity: 0.7;
    }
    
    /*-----------------------------------------------------------------------------
    | Buttons
    |----------------------------------------------------------------------------*/
    
    .jp-FileBrowser-toolbar.jp-Toolbar {
      padding: 0px;
      margin: 8px 12px 0px 12px;
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar {
      justify-content: flex-start;
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar .jp-Toolbar-item {
      flex: 0 0 auto;
      padding-left: 0px;
      padding-right: 2px;
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar .jp-ToolbarButtonComponent {
      width: 40px;
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar
      .jp-Toolbar-item:first-child
      .jp-ToolbarButtonComponent {
      width: 72px;
      background: var(--jp-brand-color1);
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar
      .jp-Toolbar-item:first-child
      .jp-ToolbarButtonComponent:focus-visible {
      background-color: var(--jp-brand-color0);
    }
    
    .jp-FileBrowser-toolbar.jp-Toolbar
      .jp-Toolbar-item:first-child
      .jp-ToolbarButtonComponent
      .jp-icon3 {
      fill: white;
    }
    
    /*-----------------------------------------------------------------------------
    | Other styles
    |----------------------------------------------------------------------------*/
    
    .jp-FileDialog.jp-mod-conflict input {
      color: var(--jp-error-color1);
    }
    
    .jp-FileDialog .jp-new-name-title {
      margin-top: 12px;
    }
    
    .jp-LastModified-hidden {
      display: none;
    }
    
    .jp-FileBrowser-filterBox {
      padding: 0px;
      flex: 0 0 auto;
      margin: 8px 12px 0px 12px;
    }
    
    /*-----------------------------------------------------------------------------
    | DirListing
    |----------------------------------------------------------------------------*/
    
    .jp-DirListing {
      flex: 1 1 auto;
      display: flex;
      flex-direction: column;
      outline: 0;
    }
    
    .jp-DirListing:focus-visible {
      border: 1px solid var(--jp-brand-color1);
    }
    
    .jp-DirListing-header {
      flex: 0 0 auto;
      display: flex;
      flex-direction: row;
      overflow: hidden;
      border-top: var(--jp-border-width) solid var(--jp-border-color2);
      border-bottom: var(--jp-border-width) solid var(--jp-border-color1);
      box-shadow: var(--jp-toolbar-box-shadow);
      z-index: 2;
    }
    
    .jp-DirListing-headerItem {
      padding: 4px 12px 2px 12px;
      font-weight: 500;
    }
    
    .jp-DirListing-headerItem:hover {
      background: var(--jp-layout-color2);
    }
    
    .jp-DirListing-headerItem.jp-id-name {
      flex: 1 0 84px;
    }
    
    .jp-DirListing-headerItem.jp-id-modified {
      flex: 0 0 112px;
      border-left: var(--jp-border-width) solid var(--jp-border-color2);
      text-align: right;
    }
    
    .jp-id-narrow {
      display: none;
      flex: 0 0 5px;
      padding: 4px 4px;
      border-left: var(--jp-border-width) solid var(--jp-border-color2);
      text-align: right;
      color: var(--jp-border-color2);
    }
    
    .jp-DirListing-narrow .jp-id-narrow {
      display: block;
    }
    
    .jp-DirListing-narrow .jp-id-modified,
    .jp-DirListing-narrow .jp-DirListing-itemModified {
      display: none;
    }
    
    .jp-DirListing-headerItem.jp-mod-selected {
      font-weight: 600;
    }
    
    /* increase specificity to override bundled default */
    .jp-DirListing-content {
      flex: 1 1 auto;
      margin: 0;
      padding: 0;
      list-style-type: none;
      overflow: auto;
      background-color: var(--jp-layout-color1);
    }
    
    .jp-DirListing-content mark {
      color: var(--jp-ui-font-color0);
      background-color: transparent;
      font-weight: bold;
    }
    
    .jp-DirListing-content .jp-DirListing-item.jp-mod-selected mark {
      color: var(--jp-ui-inverse-font-color0);
    }
    
    /* Style the directory listing content when a user drops a file to upload */
    .jp-DirListing.jp-mod-native-drop .jp-DirListing-content {
      outline: 5px dashed rgba(128, 128, 128, 0.5);
      outline-offset: -10px;
      cursor: copy;
    }
    
    .jp-DirListing-item {
      display: flex;
      flex-direction: row;
      padding: 4px 12px;
      -webkit-user-select: none;
      -moz-user-select: none;
      -ms-user-select: none;
      user-select: none;
    }
    
    .jp-DirListing-item[data-is-dot] {
      opacity: 75%;
    }
    
    .jp-DirListing-item.jp-mod-selected {
      color: var(--jp-ui-inverse-font-color1);
      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: var(--jp-success-color1);
      content: '\25CF';
      font-size: 8px;
      position: absolute;
      left: -8px;
    }
    
    .jp-DirListing-item.jp-mod-running.jp-mod-selected
      .jp-DirListing-itemIcon:before {
      color: var(--jp-ui-inverse-font-color1);
    }
    
    .jp-DirListing-item.lm-mod-drag-image,
    .jp-DirListing-item.jp-mod-selected.lm-mod-drag-image {
      font-size: var(--jp-ui-font-size1);
      padding-left: 4px;
      margin-left: 4px;
      width: 160px;
      background-color: var(--jp-ui-inverse-font-color2);
      box-shadow: var(--jp-elevation-z2);
      border-radius: 0px;
      color: var(--jp-ui-font-color1);
      transform: translateX(-40%) translateY(-58%);
    }
    
    .jp-DirListing-deadSpace {
      flex: 1 1 auto;
      margin: 0;
      padding: 0;
      list-style-type: none;
      overflow: auto;
      background-color: var(--jp-layout-color1);
    }
    
    .jp-Document {
      min-width: 120px;
      min-height: 120px;
      outline: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Private CSS variables
    |----------------------------------------------------------------------------*/
    
    :root {
    }
    
    /*-----------------------------------------------------------------------------
    | Main OutputArea
    | OutputArea has a list of Outputs
    |----------------------------------------------------------------------------*/
    
    .jp-OutputArea {
      overflow-y: auto;
    }
    
    .jp-OutputArea-child {
      display: flex;
      flex-direction: row;
    }
    
    body[data-format='mobile'] .jp-OutputArea-child {
      flex-direction: column;
    }
    
    .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;
    }
    
    body[data-format='mobile'] .jp-OutputPrompt {
      flex: 0 0 auto;
      text-align: left;
    }
    
    .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;
    }
    
    body[data-format='mobile'] .jp-OutputArea-child .jp-OutputArea-output {
      margin-left: var(--jp-notebook-padding);
    }
    
    /**
     * Isolated output.
     */
    .jp-OutputArea-output.jp-mod-isolated {
      width: 100%;
      display: block;
    }
    
    /*
    When drag events occur, `p-mod-override-cursor` is added to the body.
    Because iframes steal all cursor events, the following two rules are necessary
    to suppress pointer events while resize drags are occurring. There may be a
    better solution to this problem.
    */
    body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated {
      position: relative;
    }
    
    body.lm-mod-override-cursor .jp-OutputArea-output.jp-mod-isolated:before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: transparent;
    }
    
    /* pre */
    
    .jp-OutputArea-output pre {
      border: none;
      margin: 0px;
      padding: 0px;
      overflow-x: auto;
      overflow-y: auto;
      word-break: break-all;
      word-wrap: break-word;
      white-space: pre-wrap;
    }
    
    /* tables */
    
    .jp-OutputArea-output.jp-RenderedHTMLCommon table {
      margin-left: 0;
      margin-right: 0;
    }
    
    /* description lists */
    
    .jp-OutputArea-output dl,
    .jp-OutputArea-output dt,
    .jp-OutputArea-output dd {
      display: block;
    }
    
    .jp-OutputArea-output dl {
      width: 100%;
      overflow: hidden;
      padding: 0;
      margin: 0;
    }
    
    .jp-OutputArea-output dt {
      font-weight: bold;
      float: left;
      width: 20%;
      padding: 0;
      margin: 0;
    }
    
    .jp-OutputArea-output dd {
      float: left;
      width: 80%;
      padding: 0;
      margin: 0;
    }
    
    /* Hide the gutter in case of
     *  - nested output areas (e.g. in the case of output widgets)
     *  - mirrored output areas
     */
    .jp-OutputArea .jp-OutputArea .jp-OutputArea-prompt {
      display: none;
    }
    
    /*-----------------------------------------------------------------------------
    | executeResult is added to any Output-result for the display of the object
    | returned by a cell
    |----------------------------------------------------------------------------*/
    
    .jp-OutputArea-output.jp-OutputArea-executeResult {
      margin-left: 0px;
      flex: 1 1 auto;
    }
    
    /* Text output with the Out[] prompt needs a top padding to match the
     * alignment of the Out[] prompt itself.
     */
    .jp-OutputArea-executeResult .jp-RenderedText.jp-OutputArea-output {
      padding-top: var(--jp-code-padding);
      border-top: var(--jp-border-width) solid transparent;
    }
    
    /*-----------------------------------------------------------------------------
    | The Stdin output
    |----------------------------------------------------------------------------*/
    
    .jp-OutputArea-stdin {
      line-height: var(--jp-code-line-height);
      padding-top: var(--jp-code-padding);
      display: flex;
    }
    
    .jp-Stdin-prompt {
      color: var(--jp-content-font-color0);
      padding-right: var(--jp-code-padding);
      vertical-align: baseline;
      flex: 0 0 auto;
    }
    
    .jp-Stdin-input {
      font-family: var(--jp-code-font-family);
      font-size: inherit;
      color: inherit;
      background-color: inherit;
      width: 42%;
      min-width: 200px;
      /* make sure input baseline aligns with prompt */
      vertical-align: baseline;
      /* padding + margin = 0.5em between prompt and cursor */
      padding: 0em 0.25em;
      margin: 0em 0.25em;
      flex: 0 0 70%;
    }
    
    .jp-Stdin-input:focus {
      box-shadow: none;
    }
    
    /*-----------------------------------------------------------------------------
    | Output Area View
    |----------------------------------------------------------------------------*/
    
    .jp-LinkedOutputView .jp-OutputArea {
      height: 100%;
      display: block;
    }
    
    .jp-LinkedOutputView .jp-OutputArea-output:only-child {
      height: 100%;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    .jp-Collapser {
      flex: 0 0 var(--jp-cell-collapser-width);
      padding: 0px;
      margin: 0px;
      border: none;
      outline: none;
      background: transparent;
      border-radius: var(--jp-border-radius);
      opacity: 1;
    }
    
    .jp-Collapser-child {
      display: block;
      width: 100%;
      box-sizing: border-box;
      /* height: 100% doesn't work because the height of its parent is computed from content */
      position: absolute;
      top: 0px;
      bottom: 0px;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Header/Footer
    |----------------------------------------------------------------------------*/
    
    /* Hidden by zero height by default */
    .jp-CellHeader,
    .jp-CellFooter {
      height: 0px;
      width: 100%;
      padding: 0px;
      margin: 0px;
      border: none;
      outline: none;
      background: transparent;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Input
    |----------------------------------------------------------------------------*/
    
    /* All input areas */
    .jp-InputArea {
      display: flex;
      flex-direction: row;
      overflow: hidden;
    }
    
    body[data-format='mobile'] .jp-InputArea {
      flex-direction: column;
    }
    
    .jp-InputArea-editor {
      flex: 1 1 auto;
      overflow: hidden;
    }
    
    .jp-InputArea-editor {
      /* This is the non-active, default styling */
      border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
      border-radius: 0px;
      background: var(--jp-cell-editor-background);
    }
    
    body[data-format='mobile'] .jp-InputArea-editor {
      margin-left: var(--jp-notebook-padding);
    }
    
    .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;
    }
    
    body[data-format='mobile'] .jp-InputPrompt {
      flex: 0 0 auto;
      text-align: left;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Placeholder
    |----------------------------------------------------------------------------*/
    
    .jp-Placeholder {
      display: flex;
      flex-direction: row;
      flex: 1 1 auto;
    }
    
    .jp-Placeholder-prompt {
      box-sizing: border-box;
    }
    
    .jp-Placeholder-content {
      flex: 1 1 auto;
      border: none;
      background: transparent;
      height: 20px;
      box-sizing: border-box;
    }
    
    .jp-Placeholder-content .jp-MoreHorizIcon {
      width: 32px;
      height: 16px;
      border: 1px solid transparent;
      border-radius: var(--jp-border-radius);
    }
    
    .jp-Placeholder-content .jp-MoreHorizIcon:hover {
      border: 1px solid var(--jp-border-color1);
      box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.25);
      background-color: var(--jp-layout-color0);
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Private CSS variables
    |----------------------------------------------------------------------------*/
    
    :root {
      --jp-private-cell-scrolling-output-offset: 5px;
    }
    
    /*-----------------------------------------------------------------------------
    | Cell
    |----------------------------------------------------------------------------*/
    
    .jp-Cell {
      padding: var(--jp-cell-padding);
      margin: 0px;
      border: none;
      outline: none;
      background: transparent;
    }
    
    /*-----------------------------------------------------------------------------
    | Common input/output
    |----------------------------------------------------------------------------*/
    
    .jp-Cell-inputWrapper,
    .jp-Cell-outputWrapper {
      display: flex;
      flex-direction: row;
      padding: 0px;
      margin: 0px;
      /* Added to reveal the box-shadow on the input and output collapsers. */
      overflow: visible;
    }
    
    /* Only input/output areas inside cells */
    .jp-Cell-inputArea,
    .jp-Cell-outputArea {
      flex: 1 1 auto;
    }
    
    /*-----------------------------------------------------------------------------
    | Collapser
    |----------------------------------------------------------------------------*/
    
    /* Make the output collapser disappear when there is not output, but do so
     * in a manner that leaves it in the layout and preserves its width.
     */
    .jp-Cell.jp-mod-noOutputs .jp-Cell-outputCollapser {
      border: none !important;
      background: transparent !important;
    }
    
    .jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputCollapser {
      min-height: var(--jp-cell-collapser-min-height);
    }
    
    /*-----------------------------------------------------------------------------
    | Output
    |----------------------------------------------------------------------------*/
    
    /* Put a space between input and output when there IS output */
    .jp-Cell:not(.jp-mod-noOutputs) .jp-Cell-outputWrapper {
      margin-top: 5px;
    }
    
    .jp-CodeCell.jp-mod-outputsScrolled .jp-Cell-outputArea {
      overflow-y: auto;
      max-height: 200px;
      box-shadow: inset 0 0 6px 2px rgba(0, 0, 0, 0.3);
      margin-left: var(--jp-private-cell-scrolling-output-offset);
    }
    
    .jp-CodeCell.jp-mod-outputsScrolled .jp-OutputArea-prompt {
      flex: 0 0
        calc(
          var(--jp-cell-prompt-width) -
            var(--jp-private-cell-scrolling-output-offset)
        );
    }
    
    /*-----------------------------------------------------------------------------
    | CodeCell
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | MarkdownCell
    |----------------------------------------------------------------------------*/
    
    .jp-MarkdownOutput {
      flex: 1 1 auto;
      margin-top: 0;
      margin-bottom: 0;
      padding-left: var(--jp-code-padding);
    }
    
    .jp-MarkdownOutput.jp-RenderedHTMLCommon {
      overflow: auto;
    }
    
    .jp-showHiddenCellsButton {
      margin-left: calc(var(--jp-cell-prompt-width) + 2 * var(--jp-code-padding));
      margin-top: var(--jp-code-padding);
      border: 1px solid var(--jp-border-color2);
      background-color: var(--jp-border-color3) !important;
      color: var(--jp-content-font-color0) !important;
    }
    
    .jp-showHiddenCellsButton:hover {
      background-color: var(--jp-border-color2) !important;
    }
    
    .jp-collapseHeadingButton {
      display: none;
    }
    
    .jp-MarkdownCell:hover .jp-collapseHeadingButton {
      display: flex;
      min-height: var(--jp-cell-collapser-min-height);
      position: absolute;
      right: 0;
      top: 0;
      bottom: 0;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Variables
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    
    /*-----------------------------------------------------------------------------
    | Styles
    |----------------------------------------------------------------------------*/
    
    .jp-NotebookPanel-toolbar {
      padding: 2px;
    }
    
    .jp-Toolbar-item.jp-Notebook-toolbarCellType .jp-select-wrapper.jp-mod-focused {
      border: none;
      box-shadow: none;
    }
    
    .jp-Notebook-toolbarCellTypeDropdown select {
      height: 24px;
      font-size: var(--jp-ui-font-size1);
      line-height: 14px;
      border-radius: 0;
      display: block;
    }
    
    .jp-Notebook-toolbarCellTypeDropdown span {
      top: 5px !important;
    }
    
    /*-----------------------------------------------------------------------------
    | Copyright (c) Jupyter Development Team.
    | Distributed under the terms of the Modified BSD License.
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Private CSS variables
    |----------------------------------------------------------------------------*/
    
    :root {
      --jp-private-notebook-dragImage-width: 304px;
      --jp-private-notebook-dragImage-height: 36px;
      --jp-private-notebook-selected-color: var(--md-blue-400);
      --jp-private-notebook-active-color: var(--md-green-400);
    }
    
    /*-----------------------------------------------------------------------------
    | Imports
    |----------------------------------------------------------------------------*/
    
    /*-----------------------------------------------------------------------------
    | Notebook
    |----------------------------------------------------------------------------*/
    
    .jp-NotebookPanel {
      display: block;
      height: 100%;
    }
    
    .jp-NotebookPanel.jp-Document {
      min-width: 240px;
      min-height: 120px;
    }
    
    .jp-Notebook {
      padding: var(--jp-notebook-padding);
      outline: none;
      overflow: auto;
      background: var(--jp-layout-color0);
    }
    
    .jp-Notebook.jp-mod-scrollPastEnd::after {
      display: block;
      content: '';
      min-height: var(--jp-notebook-scroll-padding);
    }
    
    .jp-MainAreaWidget-ContainStrict .jp-Notebook * {
      contain: strict;
    }
    
    .jp-Notebook-render * {
      contain: none !important;
    }
    
    .jp-Notebook .jp-Cell {
      overflow: visible;
    }
    
    .jp-Notebook .jp-Cell .jp-InputPrompt {
      cursor: move;
      float: left;
    }
    
    /*-----------------------------------------------------------------------------
    | 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);
    }
    
    /* cell is dirty */
    .jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt {
      color: var(--jp-warn-color1);
    }
    .jp-Notebook .jp-Cell.jp-mod-dirty .jp-InputPrompt:before {
      color: var(--jp-warn-color1);
      content: '•';
    }
    
    .jp-Notebook .jp-Cell.jp-mod-active.jp-mod-dirty .jp-Collapser {
      background: var(--jp-warn-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: block;
      flex-direction: row;
      width: var(--jp-private-notebook-dragImage-width);
      height: var(--jp-private-notebook-dragImage-height);
      border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
      background: var(--jp-cell-editor-background);
      overflow: visible;
    }
    
    .jp-dragImage-singlePrompt {
      box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12);
    }
    
    .jp-dragImage .jp-dragImage-content {
      flex: 1 1 auto;
      z-index: 2;
      font-size: var(--jp-code-font-size);
      font-family: var(--jp-code-font-family);
      line-height: var(--jp-code-line-height);
      padding: var(--jp-code-padding);
      border: var(--jp-border-width) solid var(--jp-cell-editor-border-color);
      background: var(--jp-cell-editor-background-color);
      color: var(--jp-content-font-color3);
      text-align: left;
      margin: 4px 4px 4px 0px;
    }
    
    .jp-dragImage .jp-dragImage-prompt {
      flex: 0 0 auto;
      min-width: 36px;
      color: var(--jp-cell-inprompt-font-color);
      padding: var(--jp-code-padding);
      padding-left: 12px;
      font-family: var(--jp-cell-prompt-font-family);
      letter-spacing: var(--jp-cell-prompt-letter-spacing);
      line-height: 1.9;
      font-size: var(--jp-code-font-size);
      border: var(--jp-border-width) solid transparent;
    }
    
    .jp-dragImage-multipleBack {
      z-index: -1;
      position: absolute;
      height: 32px;
      width: 300px;
      top: 8px;
      left: 8px;
      background: var(--jp-layout-color2);
      border: var(--jp-border-width) solid var(--jp-input-border-color);
      box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.12);
    }
    
    /*-----------------------------------------------------------------------------
    | Cell toolbar
    |----------------------------------------------------------------------------*/
    
    .jp-NotebookTools {
      display: block;
      min-width: var(--jp-sidebar-min-width);
      color: var(--jp-ui-font-color1);
      background: var(--jp-layout-color1);
      /* This is needed so that all font sizing of children done in ems is
        * relative to this base size */
      font-size: var(--jp-ui-font-size1);
      overflow: auto;
    }
    
    .jp-NotebookTools-tool {
      padding: 0px 12px 0 12px;
    }
    
    .jp-ActiveCellTool {
      padding: 12px;
      background-color: var(--jp-layout-color1);
      border-top: none !important;
    }
    
    .jp-ActiveCellTool .jp-InputArea-prompt {
      flex: 0 0 auto;
      padding-left: 0px;
    }
    
    .jp-ActiveCellTool .jp-InputArea-editor {
      flex: 1 1 auto;
      background: var(--jp-cell-editor-background);
      border-color: var(--jp-cell-editor-border-color);
    }
    
    .jp-ActiveCellTool .jp-InputArea-editor .CodeMirror {
      background: transparent;
    }
    
    .jp-MetadataEditorTool {
      flex-direction: column;
      padding: 12px 0px 12px 0px;
    }
    
    .jp-RankedPanel > :not(:first-child) {
      margin-top: 12px;
    }
    
    .jp-KeySelector select.jp-mod-styled {
      font-size: var(--jp-ui-font-size1);
      color: var(--jp-ui-font-color0);
      border: var(--jp-border-width) solid var(--jp-border-color1);
    }
    
    .jp-KeySelector label,
    .jp-MetadataEditorTool label {
      line-height: 1.4;
    }
    
    .jp-NotebookTools .jp-select-wrapper {
      margin-top: 4px;
      margin-bottom: 0px;
    }
    
    .jp-NotebookTools .jp-Collapse {
      margin-top: 16px;
    }
    
    /*-----------------------------------------------------------------------------
    | Presentation Mode (.jp-mod-presentationMode)
    |----------------------------------------------------------------------------*/
    
    .jp-mod-presentationMode .jp-Notebook {
      --jp-content-font-size1: var(--jp-content-presentation-font-size1);
      --jp-code-font-size: var(--jp-code-presentation-font-size);
    }
    
    .jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-InputPrompt,
    .jp-mod-presentationMode .jp-Notebook .jp-Cell .jp-OutputPrompt {
      flex: 0 0 110px;
    }
    
    /*-----------------------------------------------------------------------------
    | Placeholder
    |----------------------------------------------------------------------------*/
    
    .jp-Cell-Placeholder {
      padding-left: 55px;
    }
    
    .jp-Cell-Placeholder-wrapper {
      background: #fff;
      border: 1px solid;
      border-color: #e5e6e9 #dfe0e4 #d0d1d5;
      border-radius: 4px;
      -webkit-border-radius: 4px;
      margin: 10px 15px;
    }
    
    .jp-Cell-Placeholder-wrapper-inner {
      padding: 15px;
      position: relative;
    }
    
    .jp-Cell-Placeholder-wrapper-body {
      background-repeat: repeat;
      background-size: 50% auto;
    }
    
    .jp-Cell-Placeholder-wrapper-body div {
      background: #f6f7f8;
      background-image: -webkit-linear-gradient(
        left,
        #f6f7f8 0%,
        #edeef1 20%,
        #f6f7f8 40%,
        #f6f7f8 100%
      );
      background-repeat: no-repeat;
      background-size: 800px 104px;
      height: 104px;
      position: relative;
    }
    
    .jp-Cell-Placeholder-wrapper-body div {
      position: absolute;
      right: 15px;
      left: 15px;
      top: 15px;
    }
    
    div.jp-Cell-Placeholder-h1 {
      top: 20px;
      height: 20px;
      left: 15px;
      width: 150px;
    }
    
    div.jp-Cell-Placeholder-h2 {
      left: 15px;
      top: 50px;
      height: 10px;
      width: 100px;
    }
    
    div.jp-Cell-Placeholder-content-1,
    div.jp-Cell-Placeholder-content-2,
    div.jp-Cell-Placeholder-content-3 {
      left: 15px;
      right: 15px;
      height: 10px;
    }
    
    div.jp-Cell-Placeholder-content-1 {
      top: 100px;
    }
    
    div.jp-Cell-Placeholder-content-2 {
      top: 120px;
    }
    
    div.jp-Cell-Placeholder-content-3 {
      top: 140px;
    }
    
    </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-900);
      --jp-brand-color1: var(--md-blue-700);
      --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-900);
      --jp-accent-color1: var(--md-green-700);
      --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-900);
      --jp-warn-color1: var(--md-orange-700);
      --jp-warn-color2: var(--md-orange-300);
      --jp-warn-color3: var(--md-orange-100);
    
      --jp-error-color0: var(--md-red-900);
      --jp-error-color1: var(--md-red-700);
      --jp-error-color2: var(--md-red-300);
      --jp-error-color3: var(--md-red-100);
    
      --jp-success-color0: var(--md-green-900);
      --jp-success-color1: var(--md-green-700);
      --jp-success-color2: var(--md-green-300);
      --jp-success-color3: var(--md-green-100);
    
      --jp-info-color0: var(--md-cyan-900);
      --jp-info-color1: var(--md-cyan-700);
      --jp-info-color2: var(--md-cyan-300);
      --jp-info-color3: var(--md-cyan-100);
    
      /* Cell specific styles */
    
      --jp-cell-padding: 5px;
    
      --jp-cell-collapser-width: 8px;
      --jp-cell-collapser-min-height: 20px;
      --jp-cell-collapser-not-active-hover-opacity: 0.6;
    
      --jp-cell-editor-background: var(--md-grey-100);
      --jp-cell-editor-border-color: var(--md-grey-300);
      --jp-cell-editor-box-shadow: inset 0 0 2px var(--md-blue-300);
      --jp-cell-editor-active-background: var(--jp-layout-color0);
      --jp-cell-editor-active-border-color: var(--jp-brand-color1);
    
      --jp-cell-prompt-width: 64px;
      --jp-cell-prompt-font-family: var(--jp-code-font-family-default);
      --jp-cell-prompt-letter-spacing: 0px;
      --jp-cell-prompt-opacity: 1;
      --jp-cell-prompt-not-active-opacity: 0.5;
      --jp-cell-prompt-not-active-font-color: var(--md-grey-700);
      /* A custom blend of MD grey and blue 600
       * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
      --jp-cell-inprompt-font-color: #307fc1;
      /* A custom blend of MD grey and orange 600
       * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */
      --jp-cell-outprompt-font-color: #bf5b3d;
    
      /* Notebook specific styles */
    
      --jp-notebook-padding: 10px;
      --jp-notebook-select-background: var(--jp-layout-color1);
      --jp-notebook-multiselected-color: var(--md-blue-50);
    
      /* The scroll padding is calculated to fill enough space at the bottom of the
      notebook to show one single-line cell (with appropriate padding) at the top
      when the notebook is scrolled all the way to the bottom. We also subtract one
      pixel so that no scrollbar appears if we have just one single-line cell in the
      notebook. This padding is to enable a 'scroll past end' feature in a notebook.
      */
      --jp-notebook-scroll-padding: calc(
        100% - var(--jp-code-font-size) * var(--jp-code-line-height) -
          var(--jp-code-padding) - var(--jp-cell-padding) - 1px
      );
    
      /* Rendermime styles */
    
      --jp-rendermime-error-background: #fdd;
      --jp-rendermime-table-row-background: var(--md-grey-100);
      --jp-rendermime-table-row-hover-background: var(--md-light-blue-50);
    
      /* Dialog specific styles */
    
      --jp-dialog-background: rgba(0, 0, 0, 0.25);
    
      /* Console specific styles */
    
      --jp-console-padding: 10px;
    
      /* Toolbar specific styles */
    
      --jp-toolbar-border-color: var(--jp-border-color1);
      --jp-toolbar-micro-height: 8px;
      --jp-toolbar-background: var(--jp-layout-color1);
      --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.24);
      --jp-toolbar-header-margin: 4px 4px 0px 4px;
      --jp-toolbar-active-background: var(--md-grey-300);
    
      /* Statusbar specific styles */
    
      --jp-statusbar-height: 24px;
    
      /* Input field styles */
    
      --jp-input-box-shadow: inset 0 0 2px var(--md-blue-300);
      --jp-input-active-background: var(--jp-layout-color1);
      --jp-input-hover-background: var(--jp-layout-color1);
      --jp-input-background: var(--md-grey-100);
      --jp-input-border-color: var(--jp-border-color1);
      --jp-input-active-border-color: var(--jp-brand-color1);
      --jp-input-active-box-shadow-color: rgba(19, 124, 189, 0.3);
    
      /* General editor styles */
    
      --jp-editor-selected-background: #d9d9d9;
      --jp-editor-selected-focused-background: #d7d4f0;
      --jp-editor-cursor-color: var(--jp-ui-font-color0);
    
      /* Code mirror specific styles */
    
      --jp-mirror-editor-keyword-color: #008000;
      --jp-mirror-editor-atom-color: #88f;
      --jp-mirror-editor-number-color: #080;
      --jp-mirror-editor-def-color: #00f;
      --jp-mirror-editor-variable-color: var(--md-grey-900);
      --jp-mirror-editor-variable-2-color: #05a;
      --jp-mirror-editor-variable-3-color: #085;
      --jp-mirror-editor-punctuation-color: #05a;
      --jp-mirror-editor-property-color: #05a;
      --jp-mirror-editor-operator-color: #aa22ff;
      --jp-mirror-editor-comment-color: #408080;
      --jp-mirror-editor-string-color: #ba2121;
      --jp-mirror-editor-string-2-color: #708;
      --jp-mirror-editor-meta-color: #aa22ff;
      --jp-mirror-editor-qualifier-color: #555;
      --jp-mirror-editor-builtin-color: #008000;
      --jp-mirror-editor-bracket-color: #997;
      --jp-mirror-editor-tag-color: #170;
      --jp-mirror-editor-attribute-color: #00c;
      --jp-mirror-editor-header-color: blue;
      --jp-mirror-editor-quote-color: #090;
      --jp-mirror-editor-link-color: #00c;
      --jp-mirror-editor-error-color: #f00;
      --jp-mirror-editor-hr-color: #999;
    
      /* Vega extension styles */
    
      --jp-vega-background: white;
    
      /* Sidebar-related styles */
    
      --jp-sidebar-min-width: 250px;
    
      /* Search-related styles */
    
      --jp-search-toggle-off-opacity: 0.5;
      --jp-search-toggle-hover-opacity: 0.8;
      --jp-search-toggle-on-opacity: 1;
      --jp-search-selected-match-background-color: rgb(245, 200, 0);
      --jp-search-selected-match-color: black;
      --jp-search-unselected-match-background-color: var(
        --jp-inverse-layout-color0
      );
      --jp-search-unselected-match-color: var(--jp-ui-inverse-font-color0);
    
      /* Icon colors that work well with light or dark backgrounds */
      --jp-icon-contrast-color0: var(--md-purple-600);
      --jp-icon-contrast-color1: var(--md-green-600);
      --jp-icon-contrast-color2: var(--md-pink-600);
      --jp-icon-contrast-color3: var(--md-blue-600);
    }
    </style>
    
    <style type="text/css">
    a.anchor-link {
       display: none;
    }
    .highlight  {
        margin: 0.4em;
    }
    
    /* Input area styling */
    .jp-InputArea {
        overflow: hidden;
    }
    
    .jp-InputArea-editor {
        overflow: hidden;
    }
    
    @media print {
      body {
        margin: 0;
      }
    }
    </style>
    
    <!-- Load mathjax -->
        <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.7/latest.js?config=TeX-AMS_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 
                        }
                    }
                });
            
                MathJax.Hub.Queue(["Typeset", MathJax.Hub]);
            }
        }
        init_mathjax();
        </script>
        <!-- End of mathjax configuration --></head>
    <body class="jp-Notebook" data-jp-theme-light="true" data-jp-theme-name="JupyterLab Light">
    
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h1 id="TD2:-Deep-learning">TD2: Deep learning<a class="anchor-link" href="#TD2:-Deep-learning">&#182;</a></h1>
    </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>In this TD, you must modify this notebook to answer the questions. To do this,</p>
    <ol>
    <li>Fork this repository</li>
    <li>Clone your forked repository on your local computer</li>
    <li>Answer the questions</li>
    <li>Commit and push regularly</li>
    </ol>
    <p>The last commit is due on Sunday, December 1, 11:59 PM. Later commits will not be taken into account.</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>Install and test PyTorch from  <a href="https://pytorch.org/get-started/locally">https://pytorch.org/get-started/locally</a>.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#%pip install torch torchvision</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>To test run the following code</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">torch</span>
    
    <span class="n">N</span><span class="p">,</span> <span class="n">D</span> <span class="o">=</span> <span class="mi">14</span><span class="p">,</span> <span class="mi">10</span>
    <span class="n">x</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">randn</span><span class="p">(</span><span class="n">N</span><span class="p">,</span> <span class="n">D</span><span class="p">)</span><span class="o">.</span><span class="n">type</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">FloatTensor</span><span class="p">)</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
    
    <span class="kn">from</span> <span class="nn">torchvision</span> <span class="kn">import</span> <span class="n">models</span>
    
    <span class="n">alexnet</span> <span class="o">=</span> <span class="n">models</span><span class="o">.</span><span class="n">alexnet</span><span class="p">()</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">alexnet</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>tensor([[-9.6164e-01,  7.5175e-01,  2.2068e-01, -1.9287e+00,  1.2018e+00,
              8.3169e-01,  4.4855e-01, -3.9142e-01, -5.6906e-01,  2.7513e-02],
            [-1.7256e+00,  1.1839e+00,  6.1850e-01,  4.0442e-01, -2.4731e-03,
              2.0747e-01, -8.9610e-01,  1.0929e+00,  5.2957e-01,  1.2756e+00],
            [-1.4138e+00,  4.2878e-01, -2.5560e-01, -5.0247e-01,  3.3962e-01,
              7.6361e-01, -3.9553e-01,  3.0112e-01,  8.0323e-01, -6.5776e-01],
            [-3.8860e-01, -7.1832e-01,  9.4326e-02,  1.9248e+00, -1.7670e+00,
             -2.9427e-01,  1.5313e+00, -1.3358e+00,  9.3929e-01, -7.3859e-01],
            [-1.1374e+00,  8.9347e-02,  5.6253e-01,  1.1770e+00,  1.4455e+00,
             -3.0582e-01, -1.2385e+00, -3.1167e+00,  1.5320e+00,  8.1779e-01],
            [-4.0280e-01, -6.0394e-01, -3.3574e-01,  5.9772e-01,  9.9111e-01,
              1.9502e+00,  8.0123e-01,  5.8141e-01, -2.9559e-02,  5.2823e-01],
            [-2.6291e-01,  1.4760e-01,  7.5081e-01, -1.3812e+00,  3.8280e-01,
              7.1685e-02,  6.5621e-01,  1.7026e+00,  5.1833e-02, -7.5081e-01],
            [-1.1018e+00, -1.1544e+00,  7.6059e-01, -7.3267e-01,  1.4962e+00,
              3.2975e-01,  1.4480e+00, -1.2683e+00, -1.0807e+00,  1.2137e+00],
            [ 4.5243e-01,  3.2494e-01,  1.8584e+00,  9.1640e-01, -5.0231e-01,
              2.2226e-01,  9.6508e-01, -1.3855e+00, -4.0333e-01,  2.0664e-01],
            [-8.7366e-01,  5.7875e-01,  6.7228e-01,  1.2443e+00,  5.0369e-02,
             -7.0752e-02, -9.4983e-03, -1.0352e+00, -8.9707e-01, -8.4242e-01],
            [-5.1466e-01,  9.4534e-01, -1.5424e+00,  9.0490e-01,  2.2420e+00,
              1.3246e-01, -8.2010e-01,  1.0778e-02,  8.8466e-02,  1.1311e-01],
            [ 1.3198e-02,  1.3362e-01,  4.8558e-01,  3.6620e-01, -2.1507e+00,
              1.7068e+00,  4.3327e-01,  3.7356e-02, -9.8956e-01, -7.9939e-01],
            [ 1.1221e+00, -8.4034e-01, -2.1407e+00,  4.1205e-01, -8.2332e-01,
             -1.2031e+00, -1.1830e+00,  5.4147e-02,  1.0012e-01, -3.1518e-01],
            [ 5.3398e-01, -3.4557e-01,  5.1655e-01,  9.6549e-01,  1.0638e+00,
              7.1804e-02,  2.5193e-01,  6.3295e-02, -7.5503e-01,  2.4725e-01]])
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>AlexNet(
      (features): Sequential(
        (0): Conv2d(3, 64, kernel_size=(11, 11), stride=(4, 4), padding=(2, 2))
        (1): ReLU(inplace=True)
        (2): MaxPool2d(kernel_size=3, stride=2, padding=0, dilation=1, ceil_mode=False)
        (3): Conv2d(64, 192, kernel_size=(5, 5), stride=(1, 1), padding=(2, 2))
        (4): ReLU(inplace=True)
        (5): MaxPool2d(kernel_size=3, stride=2, padding=0, dilation=1, ceil_mode=False)
        (6): Conv2d(192, 384, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))
        (7): ReLU(inplace=True)
        (8): Conv2d(384, 256, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))
        (9): ReLU(inplace=True)
        (10): Conv2d(256, 256, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1))
        (11): ReLU(inplace=True)
        (12): MaxPool2d(kernel_size=3, stride=2, padding=0, dilation=1, ceil_mode=False)
      )
      (avgpool): AdaptiveAvgPool2d(output_size=(6, 6))
      (classifier): Sequential(
        (0): Dropout(p=0.5, inplace=False)
        (1): Linear(in_features=9216, out_features=4096, bias=True)
        (2): ReLU(inplace=True)
        (3): Dropout(p=0.5, inplace=False)
        (4): Linear(in_features=4096, out_features=4096, bias=True)
        (5): ReLU(inplace=True)
        (6): Linear(in_features=4096, out_features=1000, bias=True)
      )
    )
    </pre>
    </div>
    </div>
    
    </div>
    
    </div>
    
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h2 id="Exercise-1:-CNN-on-CIFAR10">Exercise 1: CNN on CIFAR10<a class="anchor-link" href="#Exercise-1:-CNN-on-CIFAR10">&#182;</a></h2><p>The goal is to apply a Convolutional Neural Net (CNN) model on the CIFAR10 image dataset and test the accuracy of the model on the basis of image classification. Compare the Accuracy VS the neural network implemented during TD1.</p>
    <p>Have a look at the following documentation to be familiar with PyTorch.</p>
    <p><a href="https://pytorch.org/tutorials/beginner/pytorch_with_examples.html">https://pytorch.org/tutorials/beginner/pytorch_with_examples.html</a></p>
    <p><a href="https://pytorch.org/tutorials/beginner/deep_learning_60min_blitz.html">https://pytorch.org/tutorials/beginner/deep_learning_60min_blitz.html</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>You can test if GPU is available on your machine and thus train on it to speed up the 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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">torch</span>
    
    <span class="c1"># check if CUDA is available</span>
    <span class="n">train_on_gpu</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">()</span>
    
    <span class="k">if</span> <span class="ow">not</span> <span class="n">train_on_gpu</span><span class="p">:</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;CUDA is not available.  Training on CPU ...&quot;</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;CUDA is available!  Training on GPU ...&quot;</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>CUDA is not available.  Training on CPU ...
    </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>Next we load the CIFAR10 dataset</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>
    <span class="kn">from</span> <span class="nn">torchvision</span> <span class="kn">import</span> <span class="n">datasets</span><span class="p">,</span> <span class="n">transforms</span>
    <span class="kn">from</span> <span class="nn">torch.utils.data.sampler</span> <span class="kn">import</span> <span class="n">SubsetRandomSampler</span>
    
    <span class="c1"># number of subprocesses to use for data loading</span>
    <span class="n">num_workers</span> <span class="o">=</span> <span class="mi">0</span>
    <span class="c1"># how many samples per batch to load</span>
    <span class="n">batch_size</span> <span class="o">=</span> <span class="mi">20</span>
    <span class="c1"># percentage of training set to use as validation</span>
    <span class="n">valid_size</span> <span class="o">=</span> <span class="mf">0.2</span>
    
    <span class="c1"># convert data to a normalized torch.FloatTensor</span>
    <span class="n">transform</span> <span class="o">=</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
        <span class="p">[</span><span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">((</span><span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">),</span> <span class="p">(</span><span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">,</span> <span class="mf">0.5</span><span class="p">))]</span>
    <span class="p">)</span>
    
    <span class="c1"># choose the training and test datasets</span>
    <span class="n">train_data</span> <span class="o">=</span> <span class="n">datasets</span><span class="o">.</span><span class="n">CIFAR10</span><span class="p">(</span><span class="s2">&quot;data&quot;</span><span class="p">,</span> <span class="n">train</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">download</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">transform</span><span class="o">=</span><span class="n">transform</span><span class="p">)</span>
    <span class="n">test_data</span> <span class="o">=</span> <span class="n">datasets</span><span class="o">.</span><span class="n">CIFAR10</span><span class="p">(</span><span class="s2">&quot;data&quot;</span><span class="p">,</span> <span class="n">train</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span> <span class="n">download</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">transform</span><span class="o">=</span><span class="n">transform</span><span class="p">)</span>
    
    <span class="c1"># obtain training indices that will be used for validation</span>
    <span class="n">num_train</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">train_data</span><span class="p">)</span>
    <span class="n">indices</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="nb">range</span><span class="p">(</span><span class="n">num_train</span><span class="p">))</span>
    <span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">shuffle</span><span class="p">(</span><span class="n">indices</span><span class="p">)</span>
    <span class="n">split</span> <span class="o">=</span> <span class="nb">int</span><span class="p">(</span><span class="n">np</span><span class="o">.</span><span class="n">floor</span><span class="p">(</span><span class="n">valid_size</span> <span class="o">*</span> <span class="n">num_train</span><span class="p">))</span>
    <span class="n">train_idx</span><span class="p">,</span> <span class="n">valid_idx</span> <span class="o">=</span> <span class="n">indices</span><span class="p">[</span><span class="n">split</span><span class="p">:],</span> <span class="n">indices</span><span class="p">[:</span><span class="n">split</span><span class="p">]</span>
    
    <span class="c1"># define samplers for obtaining training and validation batches</span>
    <span class="n">train_sampler</span> <span class="o">=</span> <span class="n">SubsetRandomSampler</span><span class="p">(</span><span class="n">train_idx</span><span class="p">)</span>
    <span class="n">valid_sampler</span> <span class="o">=</span> <span class="n">SubsetRandomSampler</span><span class="p">(</span><span class="n">valid_idx</span><span class="p">)</span>
    
    <span class="c1"># prepare data loaders (combine dataset and sampler)</span>
    <span class="n">train_loader</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
        <span class="n">train_data</span><span class="p">,</span> <span class="n">batch_size</span><span class="o">=</span><span class="n">batch_size</span><span class="p">,</span> <span class="n">sampler</span><span class="o">=</span><span class="n">train_sampler</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="n">num_workers</span>
    <span class="p">)</span>
    <span class="n">valid_loader</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
        <span class="n">train_data</span><span class="p">,</span> <span class="n">batch_size</span><span class="o">=</span><span class="n">batch_size</span><span class="p">,</span> <span class="n">sampler</span><span class="o">=</span><span class="n">valid_sampler</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="n">num_workers</span>
    <span class="p">)</span>
    <span class="n">test_loader</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
        <span class="n">test_data</span><span class="p">,</span> <span class="n">batch_size</span><span class="o">=</span><span class="n">batch_size</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="n">num_workers</span>
    <span class="p">)</span>
    
    <span class="c1"># specify the image classes</span>
    <span class="n">classes</span> <span class="o">=</span> <span class="p">[</span>
        <span class="s2">&quot;airplane&quot;</span><span class="p">,</span>
        <span class="s2">&quot;automobile&quot;</span><span class="p">,</span>
        <span class="s2">&quot;bird&quot;</span><span class="p">,</span>
        <span class="s2">&quot;cat&quot;</span><span class="p">,</span>
        <span class="s2">&quot;deer&quot;</span><span class="p">,</span>
        <span class="s2">&quot;dog&quot;</span><span class="p">,</span>
        <span class="s2">&quot;frog&quot;</span><span class="p">,</span>
        <span class="s2">&quot;horse&quot;</span><span class="p">,</span>
        <span class="s2">&quot;ship&quot;</span><span class="p">,</span>
        <span class="s2">&quot;truck&quot;</span><span class="p">,</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>Files already downloaded and verified
    Files already downloaded and verified
    </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>CNN definition (this one is an example)</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">torch.nn</span> <span class="k">as</span> <span class="nn">nn</span>
    <span class="kn">import</span> <span class="nn">torch.nn.functional</span> <span class="k">as</span> <span class="nn">F</span>
    
    <span class="c1"># define the CNN architecture</span>
    
    
    <span class="k">class</span> <span class="nc">Net</span><span class="p">(</span><span class="n">nn</span><span class="o">.</span><span class="n">Module</span><span class="p">):</span>
        <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="nb">super</span><span class="p">(</span><span class="n">Net</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span><span class="o">.</span><span class="fm">__init__</span><span class="p">()</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="mi">3</span><span class="p">,</span> <span class="mi">6</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">pool</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">MaxPool2d</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="mi">6</span><span class="p">,</span> <span class="mi">16</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">16</span> <span class="o">*</span> <span class="mi">5</span> <span class="o">*</span> <span class="mi">5</span><span class="p">,</span> <span class="mi">120</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">120</span><span class="p">,</span> <span class="mi">84</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">84</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
    
        <span class="k">def</span> <span class="nf">forward</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">x</span><span class="p">):</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv1</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv2</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">x</span><span class="o">.</span><span class="n">view</span><span class="p">(</span><span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">16</span> <span class="o">*</span> <span class="mi">5</span> <span class="o">*</span> <span class="mi">5</span><span class="p">)</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc1</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc2</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
            <span class="k">return</span> <span class="n">x</span>
    
    
    <span class="c1"># create a complete CNN</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">Net</span><span class="p">()</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">model</span><span class="p">)</span>
    <span class="c1"># move tensors to GPU if CUDA is available</span>
    <span class="k">if</span> <span class="n">train_on_gpu</span><span class="p">:</span>
        <span class="n">model</span><span class="o">.</span><span class="n">cuda</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>Net(
      (conv1): Conv2d(3, 6, kernel_size=(5, 5), stride=(1, 1))
      (pool): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
      (conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
      (fc1): Linear(in_features=400, out_features=120, bias=True)
      (fc2): Linear(in_features=120, out_features=84, bias=True)
      (fc3): Linear(in_features=84, out_features=10, bias=True)
    )
    </pre>
    </div>
    </div>
    
    </div>
    
    </div>
    
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <p>Loss function and training using SGD (Stochastic Gradient Descent) optimizer</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">torch.optim</span> <span class="k">as</span> <span class="nn">optim</span>
    
    
    <span class="k">def</span> <span class="nf">training</span><span class="p">(</span><span class="n">model_</span><span class="p">,</span><span class="n">name</span><span class="p">):</span>
        <span class="n">criterion</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">CrossEntropyLoss</span><span class="p">()</span>  <span class="c1"># specify loss function</span>
        <span class="n">optimizer</span> <span class="o">=</span> <span class="n">optim</span><span class="o">.</span><span class="n">SGD</span><span class="p">(</span><span class="n">model_</span><span class="o">.</span><span class="n">parameters</span><span class="p">(),</span> <span class="n">lr</span><span class="o">=</span><span class="mf">0.01</span><span class="p">)</span>  <span class="c1"># specify optimizer</span>
    
        <span class="n">n_epochs</span> <span class="o">=</span> <span class="mi">30</span>  <span class="c1"># number of epochs to train the model</span>
        <span class="n">train_loss_list</span> <span class="o">=</span> <span class="p">[]</span>  <span class="c1"># list to store loss to visualize</span>
        <span class="n">valid_loss_min</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">Inf</span>  <span class="c1"># track change in validation loss</span>
    
        <span class="k">for</span> <span class="n">epoch</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">n_epochs</span><span class="p">):</span>
            <span class="c1"># Keep track of training and validation loss</span>
            <span class="n">train_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
            <span class="n">valid_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
    
            <span class="c1"># Train the model</span>
            <span class="n">model_</span><span class="o">.</span><span class="n">train</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="ow">in</span> <span class="n">train_loader</span><span class="p">:</span>
                <span class="c1"># Move tensors to GPU if CUDA is available</span>
                <span class="k">if</span> <span class="n">train_on_gpu</span><span class="p">:</span>
                    <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="o">=</span> <span class="n">data</span><span class="o">.</span><span class="n">cuda</span><span class="p">(),</span> <span class="n">target</span><span class="o">.</span><span class="n">cuda</span><span class="p">()</span>
                <span class="c1"># Clear the gradients of all optimized variables</span>
                <span class="n">optimizer</span><span class="o">.</span><span class="n">zero_grad</span><span class="p">()</span>
                <span class="c1"># Forward pass: compute predicted outputs by passing inputs to the model</span>
                <span class="n">output</span> <span class="o">=</span> <span class="n">model_</span><span class="p">(</span><span class="n">data</span><span class="p">)</span>
                <span class="c1"># Calculate the batch loss</span>
                <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">target</span><span class="p">)</span>
                <span class="c1"># Backward pass: compute gradient of the loss with respect to model parameters</span>
                <span class="n">loss</span><span class="o">.</span><span class="n">backward</span><span class="p">()</span>
                <span class="c1"># Perform a single optimization step (parameter update)</span>
                <span class="n">optimizer</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
                <span class="c1"># Update training loss</span>
                <span class="n">train_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">data</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
    
            <span class="c1"># Validate the model</span>
            <span class="n">model_</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>
            <span class="k">for</span> <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="ow">in</span> <span class="n">valid_loader</span><span class="p">:</span>
                <span class="c1"># Move tensors to GPU if CUDA is available</span>
                <span class="k">if</span> <span class="n">train_on_gpu</span><span class="p">:</span>
                    <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="o">=</span> <span class="n">data</span><span class="o">.</span><span class="n">cuda</span><span class="p">(),</span> <span class="n">target</span><span class="o">.</span><span class="n">cuda</span><span class="p">()</span>
                <span class="c1"># Forward pass: compute predicted outputs by passing inputs to the model</span>
                <span class="n">output</span> <span class="o">=</span> <span class="n">model_</span><span class="p">(</span><span class="n">data</span><span class="p">)</span>
                <span class="c1"># Calculate the batch loss</span>
                <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">target</span><span class="p">)</span>
                <span class="c1"># Update average validation loss</span>
                <span class="n">valid_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">data</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
    
            <span class="c1"># Calculate average losses</span>
            <span class="n">train_loss</span> <span class="o">=</span> <span class="n">train_loss</span> <span class="o">/</span> <span class="nb">len</span><span class="p">(</span><span class="n">train_loader</span><span class="p">)</span>
            <span class="n">valid_loss</span> <span class="o">=</span> <span class="n">valid_loss</span> <span class="o">/</span> <span class="nb">len</span><span class="p">(</span><span class="n">valid_loader</span><span class="p">)</span>
            <span class="n">train_loss_list</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">train_loss</span><span class="p">)</span>
    
            <span class="c1"># Print training/validation statistics</span>
            <span class="nb">print</span><span class="p">(</span>
                <span class="s2">&quot;Epoch: </span><span class="si">{}</span><span class="s2"> </span><span class="se">\t</span><span class="s2">Training Loss: </span><span class="si">{:.6f}</span><span class="s2"> </span><span class="se">\t</span><span class="s2">Validation Loss: </span><span class="si">{:.6f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span>
                    <span class="n">epoch</span><span class="p">,</span> <span class="n">train_loss</span><span class="p">,</span> <span class="n">valid_loss</span>
                <span class="p">)</span>
            <span class="p">)</span>
    
            <span class="c1"># Save model if validation loss has decreased</span>
            <span class="k">if</span> <span class="n">valid_loss</span> <span class="o">&lt;=</span> <span class="n">valid_loss_min</span><span class="p">:</span>
                <span class="nb">print</span><span class="p">(</span>
                    <span class="s2">&quot;Validation loss decreased (</span><span class="si">{:.6f}</span><span class="s2"> --&gt; </span><span class="si">{:.6f}</span><span class="s2">).  Saving model ...&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span>
                        <span class="n">valid_loss_min</span><span class="p">,</span> <span class="n">valid_loss</span>
                    <span class="p">)</span>
                <span class="p">)</span>
                <span class="n">torch</span><span class="o">.</span><span class="n">save</span><span class="p">(</span><span class="n">model_</span><span class="o">.</span><span class="n">state_dict</span><span class="p">(),</span> <span class="n">name</span><span class="p">)</span>
                <span class="n">valid_loss_min</span> <span class="o">=</span> <span class="n">valid_loss</span>
        <span class="k">return</span> <span class="n">train_loss_list</span><span class="p">,</span><span class="n">n_epochs</span>
    
    <span class="n">train_loss_list</span><span class="p">,</span><span class="n">n_epochs</span><span class="o">=</span><span class="n">training</span><span class="p">(</span><span class="n">model</span><span class="p">,</span><span class="s2">&quot;model_cifar.pt&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Epoch: 0 	Training Loss: 43.322449 	Validation Loss: 37.534600
    Validation loss decreased (inf --&gt; 37.534600).  Saving model ...
    Epoch: 1 	Training Loss: 34.643701 	Validation Loss: 31.136308
    Validation loss decreased (37.534600 --&gt; 31.136308).  Saving model ...
    Epoch: 2 	Training Loss: 30.696749 	Validation Loss: 29.305418
    Validation loss decreased (31.136308 --&gt; 29.305418).  Saving model ...
    Epoch: 3 	Training Loss: 28.533169 	Validation Loss: 28.138255
    Validation loss decreased (29.305418 --&gt; 28.138255).  Saving model ...
    Epoch: 4 	Training Loss: 26.984089 	Validation Loss: 26.008851
    Validation loss decreased (28.138255 --&gt; 26.008851).  Saving model ...
    Epoch: 5 	Training Loss: 25.598758 	Validation Loss: 24.788705
    Validation loss decreased (26.008851 --&gt; 24.788705).  Saving model ...
    Epoch: 6 	Training Loss: 24.410424 	Validation Loss: 24.675400
    Validation loss decreased (24.788705 --&gt; 24.675400).  Saving model ...
    Epoch: 7 	Training Loss: 23.331779 	Validation Loss: 24.064556
    Validation loss decreased (24.675400 --&gt; 24.064556).  Saving model ...
    Epoch: 8 	Training Loss: 22.372174 	Validation Loss: 23.541685
    Validation loss decreased (24.064556 --&gt; 23.541685).  Saving model ...
    Epoch: 9 	Training Loss: 21.532750 	Validation Loss: 22.832895
    Validation loss decreased (23.541685 --&gt; 22.832895).  Saving model ...
    Epoch: 10 	Training Loss: 20.801076 	Validation Loss: 22.783772
    Validation loss decreased (22.832895 --&gt; 22.783772).  Saving model ...
    Epoch: 11 	Training Loss: 20.057448 	Validation Loss: 21.981297
    Validation loss decreased (22.783772 --&gt; 21.981297).  Saving model ...
    Epoch: 12 	Training Loss: 19.406093 	Validation Loss: 21.886178
    Validation loss decreased (21.981297 --&gt; 21.886178).  Saving model ...
    Epoch: 13 	Training Loss: 18.735991 	Validation Loss: 21.499771
    Validation loss decreased (21.886178 --&gt; 21.499771).  Saving model ...
    Epoch: 14 	Training Loss: 18.176201 	Validation Loss: 22.818723
    Epoch: 15 	Training Loss: 17.577495 	Validation Loss: 22.793243
    Epoch: 16 	Training Loss: 17.008231 	Validation Loss: 21.628658
    Epoch: 17 	Training Loss: 16.398250 	Validation Loss: 22.139813
    Epoch: 18 	Training Loss: 15.941069 	Validation Loss: 22.418324
    Epoch: 19 	Training Loss: 15.427645 	Validation Loss: 22.229620
    Epoch: 20 	Training Loss: 14.983954 	Validation Loss: 22.178547
    Epoch: 21 	Training Loss: 14.419324 	Validation Loss: 23.024117
    Epoch: 22 	Training Loss: 14.000020 	Validation Loss: 23.038742
    Epoch: 23 	Training Loss: 13.525463 	Validation Loss: 22.881500
    Epoch: 24 	Training Loss: 12.990559 	Validation Loss: 23.842180
    Epoch: 25 	Training Loss: 12.650270 	Validation Loss: 23.820795
    Epoch: 26 	Training Loss: 12.138135 	Validation Loss: 24.533619
    Epoch: 27 	Training Loss: 11.802696 	Validation Loss: 25.346910
    Epoch: 28 	Training Loss: 11.412316 	Validation Loss: 25.572966
    Epoch: 29 	Training Loss: 10.919574 	Validation Loss: 26.247145
    </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>Does overfit occur? If so, do an early stopping.</p>
    <p>Oui il y a de l'overfitting. A parir de l'epoche 11.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
    
    <span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="nb">range</span><span class="p">(</span><span class="n">n_epochs</span><span class="p">),</span> <span class="n">train_loss_list</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="s2">&quot;Epoch&quot;</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="s2">&quot;Loss&quot;</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="s2">&quot;Performance of Model 1&quot;</span><span class="p">)</span>
    <span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    
    
    <div class="jp-RenderedImage jp-OutputArea-output ">
    <img src=""
    >
    </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>Now loading the model with the lowest validation loss value</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#on définit la fonction test</span>
    <span class="k">def</span> <span class="nf">test</span><span class="p">(</span><span class="n">model_</span><span class="p">):</span>
    
        <span class="n">criterion</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">CrossEntropyLoss</span><span class="p">()</span>  <span class="c1"># specify loss function</span>
    
        <span class="c1"># track test loss</span>
        <span class="n">test_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
        <span class="n">class_correct</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="mf">0.0</span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">10</span><span class="p">))</span>
        <span class="n">class_total</span> <span class="o">=</span> <span class="nb">list</span><span class="p">(</span><span class="mf">0.0</span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">10</span><span class="p">))</span>
    
        <span class="n">model_</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>
        <span class="c1"># iterate over test data</span>
        <span class="k">for</span> <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="ow">in</span> <span class="n">test_loader</span><span class="p">:</span>
            <span class="c1"># move tensors to GPU if CUDA is available</span>
            <span class="k">if</span> <span class="n">train_on_gpu</span><span class="p">:</span>
                <span class="n">data</span><span class="p">,</span> <span class="n">target</span> <span class="o">=</span> <span class="n">data</span><span class="o">.</span><span class="n">cuda</span><span class="p">(),</span> <span class="n">target</span><span class="o">.</span><span class="n">cuda</span><span class="p">()</span>
            <span class="c1"># forward pass: compute predicted outputs by passing inputs to the model</span>
            <span class="n">output</span> <span class="o">=</span> <span class="n">model_</span><span class="p">(</span><span class="n">data</span><span class="p">)</span>
            <span class="c1"># calculate the batch loss</span>
            <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="n">target</span><span class="p">)</span>
            <span class="c1"># update test loss</span>
            <span class="n">test_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">data</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
            <span class="c1"># convert output probabilities to predicted class</span>
            <span class="n">_</span><span class="p">,</span> <span class="n">pred</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">max</span><span class="p">(</span><span class="n">output</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
            <span class="c1"># compare predictions to true label</span>
            <span class="n">correct_tensor</span> <span class="o">=</span> <span class="n">pred</span><span class="o">.</span><span class="n">eq</span><span class="p">(</span><span class="n">target</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">view_as</span><span class="p">(</span><span class="n">pred</span><span class="p">))</span>
            <span class="n">correct</span> <span class="o">=</span> <span class="p">(</span>
                <span class="n">np</span><span class="o">.</span><span class="n">squeeze</span><span class="p">(</span><span class="n">correct_tensor</span><span class="o">.</span><span class="n">numpy</span><span class="p">())</span>
                <span class="k">if</span> <span class="ow">not</span> <span class="n">train_on_gpu</span>
                <span class="k">else</span> <span class="n">np</span><span class="o">.</span><span class="n">squeeze</span><span class="p">(</span><span class="n">correct_tensor</span><span class="o">.</span><span class="n">cpu</span><span class="p">()</span><span class="o">.</span><span class="n">numpy</span><span class="p">())</span>
            <span class="p">)</span>
            <span class="c1"># calculate test accuracy for each object class</span>
            <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">batch_size</span><span class="p">):</span>
                <span class="n">label</span> <span class="o">=</span> <span class="n">target</span><span class="o">.</span><span class="n">data</span><span class="p">[</span><span class="n">i</span><span class="p">]</span>
                <span class="n">class_correct</span><span class="p">[</span><span class="n">label</span><span class="p">]</span> <span class="o">+=</span> <span class="n">correct</span><span class="p">[</span><span class="n">i</span><span class="p">]</span><span class="o">.</span><span class="n">item</span><span class="p">()</span>
                <span class="n">class_total</span><span class="p">[</span><span class="n">label</span><span class="p">]</span> <span class="o">+=</span> <span class="mi">1</span>
    
        <span class="c1"># average test loss</span>
        <span class="n">test_loss</span> <span class="o">=</span> <span class="n">test_loss</span> <span class="o">/</span> <span class="nb">len</span><span class="p">(</span><span class="n">test_loader</span><span class="p">)</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Test Loss: </span><span class="si">{:.6f}</span><span class="se">\n</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">test_loss</span><span class="p">))</span>
    
    
        <span class="nb">print</span><span class="p">(</span><span class="n">class_total</span><span class="p">)</span>
        <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">10</span><span class="p">):</span>
            <span class="k">if</span> <span class="n">class_total</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">&gt;</span> <span class="mi">0</span><span class="p">:</span>
                <span class="nb">print</span><span class="p">(</span>
                    <span class="s2">&quot;Test Accuracy of </span><span class="si">%5s</span><span class="s2">: </span><span class="si">%2d%%</span><span class="s2"> (</span><span class="si">%2d</span><span class="s2">/</span><span class="si">%2d</span><span class="s2">)&quot;</span>
                    <span class="o">%</span> <span class="p">(</span>
                        <span class="n">classes</span><span class="p">[</span><span class="n">i</span><span class="p">],</span>
                        <span class="mi">100</span> <span class="o">*</span> <span class="n">class_correct</span><span class="p">[</span><span class="n">i</span><span class="p">]</span> <span class="o">/</span> <span class="n">class_total</span><span class="p">[</span><span class="n">i</span><span class="p">],</span>
                        <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_correct</span><span class="p">[</span><span class="n">i</span><span class="p">]),</span>
                        <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_total</span><span class="p">[</span><span class="n">i</span><span class="p">]),</span>
                    <span class="p">)</span>
                <span class="p">)</span>
            <span class="k">else</span><span class="p">:</span>
                <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Test Accuracy of </span><span class="si">%5s</span><span class="s2">: N/A (no training examples)&quot;</span> <span class="o">%</span> <span class="p">(</span><span class="n">classes</span><span class="p">[</span><span class="n">i</span><span class="p">]))</span>
    
        <span class="nb">print</span><span class="p">(</span>
            <span class="s2">&quot;</span><span class="se">\n</span><span class="s2">Test Accuracy (Overall): </span><span class="si">%2d%%</span><span class="s2"> (</span><span class="si">%2d</span><span class="s2">/</span><span class="si">%2d</span><span class="s2">)&quot;</span>
            <span class="o">%</span> <span class="p">(</span>
                <span class="mf">100.0</span> <span class="o">*</span> <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_correct</span><span class="p">)</span> <span class="o">/</span> <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_total</span><span class="p">),</span>
                <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_correct</span><span class="p">),</span>
                <span class="n">np</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">class_total</span><span class="p">),</span>
            <span class="p">)</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># on load le model</span>
    <span class="n">model</span><span class="o">.</span><span class="n">load_state_dict</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="s2">&quot;./model_cifar.pt&quot;</span><span class="p">))</span>
    
    <span class="c1">#on teste le modele</span>
    <span class="n">test</span><span class="p">(</span><span class="n">model</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>Test Loss: 21.873704
    
    [1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0]
    Test Accuracy of airplane: 61% (613/1000)
    Test Accuracy of automobile: 68% (686/1000)
    Test Accuracy of  bird: 57% (573/1000)
    Test Accuracy of   cat: 47% (477/1000)
    Test Accuracy of  deer: 48% (486/1000)
    Test Accuracy of   dog: 45% (450/1000)
    Test Accuracy of  frog: 64% (648/1000)
    Test Accuracy of horse: 70% (702/1000)
    Test Accuracy of  ship: 81% (817/1000)
    Test Accuracy of truck: 71% (711/1000)
    
    Test Accuracy (Overall): 61% (6163/10000)
    </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>Build a new network with the following structure.</p>
    <ul>
    <li>It has 3 convolutional layers of kernel size 3 and padding of 1.</li>
    <li>The first convolutional layer must output 16 channels, the second 32 and the third 64.</li>
    <li>At each convolutional layer output, we apply a ReLU activation then a MaxPool with kernel size of 2.</li>
    <li>Then, three fully connected layers, the first two being followed by a ReLU activation and a dropout whose value you will suggest.</li>
    <li>The first fully connected layer will have an output size of 512.</li>
    <li>The second fully connected layer will have an output size of 64.</li>
    </ul>
    <p>Compare the results obtained with this new network to those obtained previously.</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="On-cr%C3%A9e-la-nouvelle-architecture-du-r%C3%A9seau-CNN-de-la-m%C3%AAme-mani%C3%A8re.-On-l'appellera-model-2.">On cr&#233;e la nouvelle architecture du r&#233;seau CNN de la m&#234;me mani&#232;re. On l'appellera model 2.<a class="anchor-link" href="#On-cr%C3%A9e-la-nouvelle-architecture-du-r%C3%A9seau-CNN-de-la-m%C3%AAme-mani%C3%A8re.-On-l'appellera-model-2.">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># define the CNN architecture</span>
    
    <span class="k">class</span> <span class="nc">Net</span><span class="p">(</span><span class="n">nn</span><span class="o">.</span><span class="n">Module</span><span class="p">):</span>
        <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="nb">super</span><span class="p">(</span><span class="n">Net</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span><span class="o">.</span><span class="fm">__init__</span><span class="p">()</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="n">in_channels</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span> <span class="n">out_channels</span><span class="o">=</span><span class="mi">16</span><span class="p">,</span> <span class="n">kernel_size</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span><span class="n">padding</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">pool</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">MaxPool2d</span><span class="p">(</span><span class="n">kernel_size</span><span class="o">=</span><span class="mi">2</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="n">in_channels</span><span class="o">=</span><span class="mi">16</span><span class="p">,</span> <span class="n">out_channels</span><span class="o">=</span><span class="mi">32</span><span class="p">,</span> <span class="n">kernel_size</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span><span class="n">padding</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv3</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="n">in_channels</span><span class="o">=</span><span class="mi">32</span><span class="p">,</span> <span class="n">out_channels</span><span class="o">=</span><span class="mi">64</span><span class="p">,</span> <span class="n">kernel_size</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span><span class="n">padding</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
    
            <span class="bp">self</span><span class="o">.</span><span class="n">fc1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">64</span><span class="o">*</span><span class="mi">4</span><span class="o">*</span><span class="mi">4</span><span class="p">,</span> <span class="mi">512</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">512</span><span class="p">,</span> <span class="mi">64</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">64</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
    
        <span class="k">def</span> <span class="nf">forward</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">x</span><span class="p">):</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv1</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv2</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv3</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
    
            <span class="n">x</span> <span class="o">=</span> <span class="n">x</span><span class="o">.</span><span class="n">view</span><span class="p">(</span><span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">64</span> <span class="o">*</span> <span class="mi">4</span> <span class="o">*</span> <span class="mi">4</span><span class="p">)</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc1</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc2</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
            <span class="k">return</span> <span class="n">x</span>
    
    
    <span class="c1"># create a complete CNN</span>
    <span class="n">model2</span> <span class="o">=</span> <span class="n">Net</span><span class="p">()</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">model</span><span class="p">)</span>
    <span class="c1"># move tensors to GPU if CUDA is available</span>
    <span class="k">if</span> <span class="n">train_on_gpu</span><span class="p">:</span>
        <span class="n">model2</span><span class="o">.</span><span class="n">cuda</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>Net(
      (conv1): Conv2d(3, 6, kernel_size=(5, 5), stride=(1, 1))
      (pool): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
      (conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
      (fc1): Linear(in_features=400, out_features=120, bias=True)
      (fc2): Linear(in_features=120, out_features=84, bias=True)
      (fc3): Linear(in_features=84, out_features=10, bias=True)
    )
    </pre>
    </div>
    </div>
    
    </div>
    
    </div>
    
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h3 id="On-entraine-maintenant-l'algorithme.">On entraine maintenant l'algorithme.<a class="anchor-link" href="#On-entraine-maintenant-l'algorithme.">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#train</span>
    <span class="n">train_loss_list</span><span class="p">,</span><span class="n">n_epochs</span><span class="o">=</span><span class="n">training</span><span class="p">(</span><span class="n">model2</span><span class="p">,</span><span class="s2">&quot;model_cifar_2.pt&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Epoch: 0 	Training Loss: 45.546517 	Validation Loss: 41.965355
    Validation loss decreased (inf --&gt; 41.965355).  Saving model ...
    Epoch: 1 	Training Loss: 37.506297 	Validation Loss: 32.462201
    Validation loss decreased (41.965355 --&gt; 32.462201).  Saving model ...
    Epoch: 2 	Training Loss: 30.826246 	Validation Loss: 28.965965
    Validation loss decreased (32.462201 --&gt; 28.965965).  Saving model ...
    Epoch: 3 	Training Loss: 27.725424 	Validation Loss: 26.256559
    Validation loss decreased (28.965965 --&gt; 26.256559).  Saving model ...
    Epoch: 4 	Training Loss: 25.409111 	Validation Loss: 23.947241
    Validation loss decreased (26.256559 --&gt; 23.947241).  Saving model ...
    Epoch: 5 	Training Loss: 23.199655 	Validation Loss: 22.190540
    Validation loss decreased (23.947241 --&gt; 22.190540).  Saving model ...
    Epoch: 6 	Training Loss: 21.171948 	Validation Loss: 21.483634
    Validation loss decreased (22.190540 --&gt; 21.483634).  Saving model ...
    Epoch: 7 	Training Loss: 19.252010 	Validation Loss: 19.125935
    Validation loss decreased (21.483634 --&gt; 19.125935).  Saving model ...
    Epoch: 8 	Training Loss: 17.624332 	Validation Loss: 18.777900
    Validation loss decreased (19.125935 --&gt; 18.777900).  Saving model ...
    Epoch: 9 	Training Loss: 16.178626 	Validation Loss: 17.967978
    Validation loss decreased (18.777900 --&gt; 17.967978).  Saving model ...
    Epoch: 10 	Training Loss: 14.790585 	Validation Loss: 17.401410
    Validation loss decreased (17.967978 --&gt; 17.401410).  Saving model ...
    Epoch: 11 	Training Loss: 13.436781 	Validation Loss: 16.391732
    Validation loss decreased (17.401410 --&gt; 16.391732).  Saving model ...
    Epoch: 12 	Training Loss: 12.091579 	Validation Loss: 18.383929
    Epoch: 13 	Training Loss: 10.885964 	Validation Loss: 16.164210
    Validation loss decreased (16.391732 --&gt; 16.164210).  Saving model ...
    Epoch: 14 	Training Loss: 9.642637 	Validation Loss: 17.355094
    Epoch: 15 	Training Loss: 8.420236 	Validation Loss: 18.205283
    Epoch: 16 	Training Loss: 7.142842 	Validation Loss: 17.389541
    Epoch: 17 	Training Loss: 6.121646 	Validation Loss: 19.769254
    Epoch: 18 	Training Loss: 4.971805 	Validation Loss: 20.793741
    Epoch: 19 	Training Loss: 4.208495 	Validation Loss: 23.089104
    Epoch: 20 	Training Loss: 3.380529 	Validation Loss: 23.717688
    Epoch: 21 	Training Loss: 2.708748 	Validation Loss: 25.890190
    Epoch: 22 	Training Loss: 2.314826 	Validation Loss: 26.893456
    Epoch: 23 	Training Loss: 1.924105 	Validation Loss: 30.196253
    Epoch: 24 	Training Loss: 1.555745 	Validation Loss: 28.148667
    Epoch: 25 	Training Loss: 1.266747 	Validation Loss: 30.644867
    Epoch: 26 	Training Loss: 1.780205 	Validation Loss: 32.042693
    Epoch: 27 	Training Loss: 1.415102 	Validation Loss: 33.207941
    Epoch: 28 	Training Loss: 1.071195 	Validation Loss: 35.509902
    Epoch: 29 	Training Loss: 0.989859 	Validation Loss: 37.337378
    </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="On-affiche-le-train-lost-en-fonction-du-nombre-d'%C3%A9poches.">On affiche le train lost en fonction du nombre d'&#233;poches.<a class="anchor-link" href="#On-affiche-le-train-lost-en-fonction-du-nombre-d'%C3%A9poches.">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
    
    <span class="n">plt</span><span class="o">.</span><span class="n">plot</span><span class="p">(</span><span class="nb">range</span><span class="p">(</span><span class="n">n_epochs</span><span class="p">),</span> <span class="n">train_loss_list</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="s2">&quot;Epoch&quot;</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="s2">&quot;Loss&quot;</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="s2">&quot;Performance of Model 2&quot;</span><span class="p">)</span>
    <span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    
    
    <div class="jp-RenderedImage jp-OutputArea-output ">
    <img src=""
    >
    </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="On-calcule-la-precision-du-mod%C3%A8le-sur-une-base-de-donn%C3%A9es-test.">On calcule la precision du mod&#232;le sur une base de donn&#233;es test.<a class="anchor-link" href="#On-calcule-la-precision-du-mod%C3%A8le-sur-une-base-de-donn%C3%A9es-test.">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">model2</span><span class="o">.</span><span class="n">load_state_dict</span><span class="p">(</span><span class="n">torch</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="s2">&quot;./model_cifar_2.pt&quot;</span><span class="p">))</span>
    
    <span class="n">test</span><span class="p">(</span><span class="n">model2</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>Test Loss: 16.504843
    
    [1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0]
    Test Accuracy of airplane: 78% (786/1000)
    Test Accuracy of automobile: 78% (780/1000)
    Test Accuracy of  bird: 62% (625/1000)
    Test Accuracy of   cat: 57% (578/1000)
    Test Accuracy of  deer: 67% (679/1000)
    Test Accuracy of   dog: 51% (514/1000)
    Test Accuracy of  frog: 79% (795/1000)
    Test Accuracy of horse: 80% (804/1000)
    Test Accuracy of  ship: 86% (863/1000)
    Test Accuracy of truck: 78% (781/1000)
    
    Test Accuracy (Overall): 72% (7205/10000)
    </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="La-pr%C3%A9cision-est-meilleure-pour-presque-toutes-les-classes-(la-classe-truck-a-une-pr%C3%A9cision-plus-faible).">La pr&#233;cision est meilleure pour presque toutes les classes (la classe truck a une pr&#233;cision plus faible).<a class="anchor-link" href="#La-pr%C3%A9cision-est-meilleure-pour-presque-toutes-les-classes-(la-classe-truck-a-une-pr%C3%A9cision-plus-faible).">&#182;</a></h3><h3 id="Au-global,-la-pr%C3%A9cision-avec-cette-nouvelle-architecture-est-meilleure-(71%25)-que-la-pr%C3%A9cedente-(62%25).">Au global, la pr&#233;cision avec cette nouvelle architecture est meilleure (71%) que la pr&#233;cedente (62%).<a class="anchor-link" href="#Au-global,-la-pr%C3%A9cision-avec-cette-nouvelle-architecture-est-meilleure-(71%25)-que-la-pr%C3%A9cedente-(62%25).">&#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">
    <h2 id="Exercise-2:-Quantization:-try-to-compress-the-CNN-to-save-space">Exercise 2: Quantization: try to compress the CNN to save space<a class="anchor-link" href="#Exercise-2:-Quantization:-try-to-compress-the-CNN-to-save-space">&#182;</a></h2><p>Quantization doc is available from <a href="https://pytorch.org/docs/stable/quantization.html#torch.quantization.quantize_dynamic">https://pytorch.org/docs/stable/quantization.html#torch.quantization.quantize_dynamic</a></p>
    <p>The Exercise is to quantize post training the above CNN model. Compare the size reduction and the impact on the classification accuracy</p>
    <p>The size of the model is simply the size of the file.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">os</span>
    
    
    <span class="k">def</span> <span class="nf">print_size_of_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">label</span><span class="o">=</span><span class="s2">&quot;&quot;</span><span class="p">):</span>
        <span class="n">torch</span><span class="o">.</span><span class="n">save</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">(),</span> <span class="s2">&quot;temp.p&quot;</span><span class="p">)</span>
        <span class="n">size</span> <span class="o">=</span> <span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">getsize</span><span class="p">(</span><span class="s2">&quot;temp.p&quot;</span><span class="p">)</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;model: &quot;</span><span class="p">,</span> <span class="n">label</span><span class="p">,</span> <span class="s2">&quot; </span><span class="se">\t</span><span class="s2">&quot;</span><span class="p">,</span> <span class="s2">&quot;Size (KB):&quot;</span><span class="p">,</span> <span class="n">size</span> <span class="o">/</span> <span class="mf">1e3</span><span class="p">)</span>
        <span class="n">os</span><span class="o">.</span><span class="n">remove</span><span class="p">(</span><span class="s2">&quot;temp.p&quot;</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">size</span>
    
    
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="s2">&quot;fp32&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>model:  fp32  	 Size (KB): 251.278
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[&nbsp;]:</div>
    
    
    
    
    <div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
    <pre>251278</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="La-taille-initial-du-mod%C3%A8le-1-est-de-251.278-KB">La taille initial du mod&#232;le 1 est de 251.278 KB<a class="anchor-link" href="#La-taille-initial-du-mod%C3%A8le-1-est-de-251.278-KB">&#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">
    <h3 id="On-va-compresser-ce-mod%C3%A8le-:">On va compresser ce mod&#232;le :<a class="anchor-link" href="#On-va-compresser-ce-mod%C3%A8le-:">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">torch.quantization</span>
    
    <span class="n">quantized_model</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">quantize_dynamic</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">torch</span><span class="o">.</span><span class="n">qint8</span><span class="p">)</span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">quantized_model</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>model:  int8  	 Size (KB): 76.522
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[&nbsp;]:</div>
    
    
    
    
    <div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
    <pre>76522</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="Le-mod%C3%A8le-compress%C3%A9-a-une-taille-de-76.522-KB.-Il-y-a-donc-eu-une-r%C3%A9duction-de-174.756-KB.">Le mod&#232;le compress&#233; a une taille de 76.522 KB. Il y a donc eu une r&#233;duction de 174.756 KB.<a class="anchor-link" href="#Le-mod%C3%A8le-compress%C3%A9-a-une-taille-de-76.522-KB.-Il-y-a-donc-eu-une-r%C3%A9duction-de-174.756-KB.">&#182;</a></h3>
    </div>
    </div><div class="jp-Cell jp-CodeCell jp-Notebook-cell   ">
    <div class="jp-Cell-inputWrapper">
    <div class="jp-InputArea jp-Cell-inputArea">
    <div class="jp-InputPrompt jp-InputArea-prompt">In&nbsp;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1"># on teste le modèle compressé</span>
    <span class="n">test</span><span class="p">(</span><span class="n">quantized_model</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>Test Loss: 21.884723
    
    [1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0]
    Test Accuracy of airplane: 61% (611/1000)
    Test Accuracy of automobile: 68% (688/1000)
    Test Accuracy of  bird: 56% (568/1000)
    Test Accuracy of   cat: 47% (476/1000)
    Test Accuracy of  deer: 48% (487/1000)
    Test Accuracy of   dog: 45% (450/1000)
    Test Accuracy of  frog: 64% (646/1000)
    Test Accuracy of horse: 70% (705/1000)
    Test Accuracy of  ship: 81% (812/1000)
    Test Accuracy of truck: 71% (714/1000)
    
    Test Accuracy (Overall): 61% (6157/10000)
    </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>En terme de précision, elle est la même en pourcentage pour presque toutes les classes (en comparaison avec le modèle non compressé).</p>
    <p>Elle différe de 1% pour la classe horse.</p>
    <p>Au global, la précision est la même.</p>
    <p>Le modèle compressé conserve la précision du modèle tout en réduisant sa taille.</p>
    <hr>
    
    </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 each class, compare the classification test accuracy of the initial model and the quantized model. Also give the overall test accuracy for both models.</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>Try training aware quantization to mitigate the impact on the accuracy (doc available here <a href="https://pytorch.org/docs/stable/quantization.html#torch.quantization.quantize_dynamic">https://pytorch.org/docs/stable/quantization.html#torch.quantization.quantize_dynamic</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">
    <h3 id="On-va-essayer-le-training-aware-quantization">On va essayer le training aware quantization<a class="anchor-link" href="#On-va-essayer-le-training-aware-quantization">&#182;</a></h3><p>On recrée un nouveau modèle à partir du modèle 1.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#on crée le modèle quantizé</span>
    
    <span class="k">class</span> <span class="nc">Net</span><span class="p">(</span><span class="n">nn</span><span class="o">.</span><span class="n">Module</span><span class="p">):</span>
        <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
            <span class="nb">super</span><span class="p">(</span><span class="n">Net</span><span class="p">,</span> <span class="bp">self</span><span class="p">)</span><span class="o">.</span><span class="fm">__init__</span><span class="p">()</span>
             <span class="c1"># QuantStub converts tensors from floating point to quantized</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">quant</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">ao</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">QuantStub</span><span class="p">()</span>
    
            <span class="bp">self</span><span class="o">.</span><span class="n">conv1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="mi">3</span><span class="p">,</span> <span class="mi">6</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">pool</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">MaxPool2d</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">conv2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">(</span><span class="mi">6</span><span class="p">,</span> <span class="mi">16</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc1</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">16</span> <span class="o">*</span> <span class="mi">5</span> <span class="o">*</span> <span class="mi">5</span><span class="p">,</span> <span class="mi">120</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc2</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">120</span><span class="p">,</span> <span class="mi">84</span><span class="p">)</span>
            <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">84</span><span class="p">,</span> <span class="mi">10</span><span class="p">)</span>
    
            <span class="bp">self</span><span class="o">.</span><span class="n">dequant</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">ao</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">DeQuantStub</span><span class="p">()</span>
    
    
    
        <span class="k">def</span> <span class="nf">forward</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">x</span><span class="p">):</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">quant</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv1</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">pool</span><span class="p">(</span><span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">conv2</span><span class="p">(</span><span class="n">x</span><span class="p">)))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">x</span><span class="o">.</span><span class="n">view</span><span class="p">(</span><span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="mi">16</span> <span class="o">*</span> <span class="mi">5</span> <span class="o">*</span> <span class="mi">5</span><span class="p">)</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc1</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="n">F</span><span class="o">.</span><span class="n">relu</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">fc2</span><span class="p">(</span><span class="n">x</span><span class="p">))</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">fc3</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
            <span class="n">x</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">dequant</span><span class="p">(</span><span class="n">x</span><span class="p">)</span>
            <span class="k">return</span> <span class="n">x</span>
    
    
    <span class="c1"># create a complete CNN</span>
    <span class="n">model_aware_quantization</span> <span class="o">=</span> <span class="n">Net</span><span class="p">()</span>
    
    <span class="n">model_aware_quantization</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[&nbsp;]:</div>
    
    
    
    
    <div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
    <pre>Net(
      (quant): QuantStub()
      (conv1): Conv2d(3, 6, kernel_size=(5, 5), stride=(1, 1))
      (pool): MaxPool2d(kernel_size=2, stride=2, padding=0, dilation=1, ceil_mode=False)
      (conv2): Conv2d(6, 16, kernel_size=(5, 5), stride=(1, 1))
      (fc1): Linear(in_features=400, out_features=120, bias=True)
      (fc2): Linear(in_features=120, out_features=84, bias=True)
      (fc3): Linear(in_features=84, out_features=10, bias=True)
      (dequant): DeQuantStub()
    )</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#train the model</span>
    <span class="n">train_loss_list</span><span class="p">,</span><span class="n">n_epochs</span><span class="o">=</span><span class="n">training</span><span class="p">(</span><span class="n">model_aware_quantization</span><span class="p">,</span><span class="s2">&quot;model_cifar_aware_quantization.pt&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Epoch: 0 	Training Loss: 44.515622 	Validation Loss: 39.651668
    Validation loss decreased (inf --&gt; 39.651668).  Saving model ...
    Epoch: 1 	Training Loss: 36.187454 	Validation Loss: 33.535019
    Validation loss decreased (39.651668 --&gt; 33.535019).  Saving model ...
    Epoch: 2 	Training Loss: 31.515289 	Validation Loss: 29.458190
    Validation loss decreased (33.535019 --&gt; 29.458190).  Saving model ...
    Epoch: 3 	Training Loss: 28.995076 	Validation Loss: 27.946637
    Validation loss decreased (29.458190 --&gt; 27.946637).  Saving model ...
    Epoch: 4 	Training Loss: 27.089252 	Validation Loss: 26.622712
    Validation loss decreased (27.946637 --&gt; 26.622712).  Saving model ...
    Epoch: 5 	Training Loss: 25.505706 	Validation Loss: 25.257544
    Validation loss decreased (26.622712 --&gt; 25.257544).  Saving model ...
    Epoch: 6 	Training Loss: 24.208821 	Validation Loss: 24.149545
    Validation loss decreased (25.257544 --&gt; 24.149545).  Saving model ...
    Epoch: 7 	Training Loss: 23.149960 	Validation Loss: 23.239544
    Validation loss decreased (24.149545 --&gt; 23.239544).  Saving model ...
    Epoch: 8 	Training Loss: 22.233548 	Validation Loss: 22.827516
    Validation loss decreased (23.239544 --&gt; 22.827516).  Saving model ...
    Epoch: 9 	Training Loss: 21.358925 	Validation Loss: 23.077734
    Epoch: 10 	Training Loss: 20.627038 	Validation Loss: 21.895032
    Validation loss decreased (22.827516 --&gt; 21.895032).  Saving model ...
    Epoch: 11 	Training Loss: 19.869867 	Validation Loss: 21.903653
    Epoch: 12 	Training Loss: 19.227587 	Validation Loss: 21.835049
    Validation loss decreased (21.895032 --&gt; 21.835049).  Saving model ...
    Epoch: 13 	Training Loss: 18.584631 	Validation Loss: 21.379109
    Validation loss decreased (21.835049 --&gt; 21.379109).  Saving model ...
    Epoch: 14 	Training Loss: 17.965375 	Validation Loss: 22.105847
    Epoch: 15 	Training Loss: 17.418559 	Validation Loss: 21.119945
    Validation loss decreased (21.379109 --&gt; 21.119945).  Saving model ...
    Epoch: 16 	Training Loss: 16.785295 	Validation Loss: 21.018267
    Validation loss decreased (21.119945 --&gt; 21.018267).  Saving model ...
    Epoch: 17 	Training Loss: 16.285102 	Validation Loss: 21.647233
    Epoch: 18 	Training Loss: 15.765099 	Validation Loss: 21.452533
    Epoch: 19 	Training Loss: 15.246105 	Validation Loss: 21.444231
    Epoch: 20 	Training Loss: 14.740839 	Validation Loss: 22.717484
    Epoch: 21 	Training Loss: 14.231403 	Validation Loss: 21.937744
    Epoch: 22 	Training Loss: 13.831682 	Validation Loss: 22.649114
    Epoch: 23 	Training Loss: 13.302803 	Validation Loss: 22.911363
    Epoch: 24 	Training Loss: 12.881577 	Validation Loss: 23.119514
    Epoch: 25 	Training Loss: 12.434679 	Validation Loss: 24.015339
    Epoch: 26 	Training Loss: 11.999609 	Validation Loss: 23.906202
    Epoch: 27 	Training Loss: 11.535745 	Validation Loss: 24.581035
    Epoch: 28 	Training Loss: 11.174014 	Validation Loss: 25.033342
    Epoch: 29 	Training Loss: 10.767195 	Validation Loss: 26.522749
    </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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#quantization</span>
    <span class="n">model_aware_quantization</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">quantize_dynamic</span><span class="p">(</span>
        <span class="n">model_aware_quantization</span><span class="p">,</span> <span class="p">{</span><span class="n">nn</span><span class="o">.</span><span class="n">Conv2d</span><span class="p">,</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">},</span> <span class="n">dtype</span><span class="o">=</span><span class="n">torch</span><span class="o">.</span><span class="n">qint8</span>
    <span class="p">)</span>
    
    <span class="c1">#on affiche la taille du nouveau modele</span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">model_aware_quantization</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    <span class="c1"># on teste le modèle compressé</span>
    <span class="nb">print</span><span class="p">(</span><span class="n">test</span><span class="p">(</span><span class="n">model_aware_quantization</span><span class="p">))</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>model:  int8  	 Size (KB): 76.522
    Test Loss: 28.386250
    
    [1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0, 1000.0]
    Test Accuracy of airplane: 59% (596/1000)
    Test Accuracy of automobile: 66% (666/1000)
    Test Accuracy of  bird: 50% (500/1000)
    Test Accuracy of   cat: 31% (313/1000)
    Test Accuracy of  deer: 57% (574/1000)
    Test Accuracy of   dog: 54% (549/1000)
    Test Accuracy of  frog: 79% (793/1000)
    Test Accuracy of horse: 57% (576/1000)
    Test Accuracy of  ship: 78% (784/1000)
    Test Accuracy of truck: 76% (767/1000)
    
    Test Accuracy (Overall): 61% (6118/10000)
    None
    </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>La taille du modèle compressé est de 76.522 KB.
    La précision globale est plus faible par rapport au modèle, elle est de 61%.</p>
    <p>Les performances sont équivalentes à la quantization précédente.</p>
    
    </div>
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h2 id="Exercise-3:-working-with-pre-trained-models.">Exercise 3: working with pre-trained models.<a class="anchor-link" href="#Exercise-3:-working-with-pre-trained-models.">&#182;</a></h2><p>PyTorch offers several pre-trained models <a href="https://pytorch.org/vision/0.8/models.html">https://pytorch.org/vision/0.8/models.html</a><br>
    We will use ResNet50 trained on ImageNet dataset (<a href="https://www.image-net.org/index.php">https://www.image-net.org/index.php</a>). Use the following code with the files <code>imagenet-simple-labels.json</code> that contains the imagenet labels and the image dog.png that we will use as test.</p>
    <p>La prédiction d'une image se fait en plusieurs étapes :</p>
    <p>-On resize l'image a la taille 224.</p>
    <p>-On transforme en tenseur.</p>
    <p>-On normalise</p>
    <p>-On charge le modèle pre-entrainé.</p>
    <p>-On fait la prédiction.</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>Experiments:</p>
    <p>Study the code and the results obtained. Possibly add other images downloaded from the internet.</p>
    <p>What is the size of the model? Quantize it and then check if the model is still able to correctly classify the other images.</p>
    <p>Experiment with other pre-trained CNN models.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">json</span>
    <span class="kn">from</span> <span class="nn">PIL</span> <span class="kn">import</span> <span class="n">Image</span>
    
    <span class="c1"># Choose an image to pass through the model</span>
    <span class="n">test_image</span> <span class="o">=</span> <span class="s2">&quot;dog.png&quot;</span>
    
    <span class="c1"># Configure matplotlib for pretty inline plots</span>
    <span class="c1">#%matplotlib inline</span>
    <span class="c1">#%config InlineBackend.figure_format = &#39;retina&#39;</span>
    
    <span class="c1"># Prepare the labels</span>
    <span class="k">with</span> <span class="nb">open</span><span class="p">(</span><span class="s2">&quot;imagenet-simple-labels.json&quot;</span><span class="p">)</span> <span class="k">as</span> <span class="n">f</span><span class="p">:</span>
        <span class="n">labels</span> <span class="o">=</span> <span class="n">json</span><span class="o">.</span><span class="n">load</span><span class="p">(</span><span class="n">f</span><span class="p">)</span>
    
    <span class="c1"># First prepare the transformations: resize the image to what the model was trained on and convert it to a tensor</span>
    <span class="n">data_transform</span> <span class="o">=</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
        <span class="p">[</span>
            <span class="n">transforms</span><span class="o">.</span><span class="n">Resize</span><span class="p">((</span><span class="mi">224</span><span class="p">,</span> <span class="mi">224</span><span class="p">)),</span>
            <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>
            <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]),</span>
        <span class="p">]</span>
    <span class="p">)</span>
    <span class="c1"># Load the image</span>
    
    <span class="n">image</span> <span class="o">=</span> <span class="n">Image</span><span class="o">.</span><span class="n">open</span><span class="p">(</span><span class="n">test_image</span><span class="p">)</span>
    <span class="n">plt</span><span class="o">.</span><span class="n">imshow</span><span class="p">(</span><span class="n">image</span><span class="p">),</span> <span class="n">plt</span><span class="o">.</span><span class="n">xticks</span><span class="p">([]),</span> <span class="n">plt</span><span class="o">.</span><span class="n">yticks</span><span class="p">([])</span>
    
    <span class="nb">print</span><span class="p">(</span><span class="n">image</span><span class="p">)</span>
    
    <span class="c1"># Now apply the transformation, expand the batch dimension, and send the image to the GPU</span>
    <span class="c1"># image = data_transform(image).unsqueeze(0).cuda()</span>
    <span class="n">image</span> <span class="o">=</span> <span class="n">data_transform</span><span class="p">(</span><span class="n">image</span><span class="p">)</span><span class="o">.</span><span class="n">unsqueeze</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
    
    <span class="c1"># Download the model if it&#39;s not there already. It will take a bit on the first run, after that it&#39;s fast</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">models</span><span class="o">.</span><span class="n">resnet50</span><span class="p">(</span><span class="n">pretrained</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
    <span class="c1"># Send the model to the GPU</span>
    <span class="c1"># model.cuda()</span>
    <span class="c1"># Set layers such as dropout and batchnorm in evaluation mode</span>
    <span class="n">model</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>
    
    <span class="c1"># Get the 1000-dimensional model output</span>
    <span class="n">out</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">image</span><span class="p">)</span>
    <span class="c1"># Find the predicted class</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out</span><span class="o">.</span><span class="n">argmax</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>&lt;PIL.PngImagePlugin.PngImageFile image mode=RGB size=188x282 at 0x121968FD0&gt;
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/torchvision/models/_utils.py:208: UserWarning: The parameter &#39;pretrained&#39; is deprecated since 0.13 and may be removed in the future, please use &#39;weights&#39; instead.
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/torchvision/models/_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for &#39;weights&#39; are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=ResNet50_Weights.IMAGENET1K_V1`. You can also use `weights=ResNet50_Weights.DEFAULT` to get the most up-to-date weights.
      warnings.warn(msg)
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Predicted class is: Golden Retriever
    </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-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <p>On va tester ce modèle sur une autre image : un king crab.</p>
    <p>Il faudra bien que l'image soit une image RGB.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">image_2</span> <span class="o">=</span> <span class="n">Image</span><span class="o">.</span><span class="n">open</span><span class="p">(</span><span class="s2">&quot;king_crab.png&quot;</span><span class="p">)</span>
    <span class="c1"># conversion en image RGB</span>
    <span class="n">image_2</span> <span class="o">=</span> <span class="n">image_2</span><span class="o">.</span><span class="n">convert</span><span class="p">(</span><span class="s2">&quot;RGB&quot;</span><span class="p">)</span>
    <span class="n">plt</span><span class="o">.</span><span class="n">imshow</span><span class="p">(</span><span class="n">image_2</span><span class="p">),</span> <span class="n">plt</span><span class="o">.</span><span class="n">xticks</span><span class="p">([]),</span> <span class="n">plt</span><span class="o">.</span><span class="n">yticks</span><span class="p">([])</span>
    
    <span class="c1"># Now apply the transformation, expand the batch dimension, and send the image to the GPU</span>
    <span class="c1"># image = data_transform(image).unsqueeze(0).cuda()</span>
    <span class="n">image_2</span> <span class="o">=</span> <span class="n">data_transform</span><span class="p">(</span><span class="n">image_2</span><span class="p">)</span><span class="o">.</span><span class="n">unsqueeze</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
    
    <span class="c1"># Get the 1000-dimensional model output</span>
    <span class="n">out</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">image_2</span><span class="p">)</span>
    <span class="c1"># Find the predicted class</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out</span><span class="o">.</span><span class="n">argmax</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>Predicted class is: red king crab
    </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-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <p>Les classifications pour le Golden Retriever et le King Crab sont bonnes. Le modèle semble être bon.</p>
    <hr>
    <p>Etudions la taille du modèle</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="c1">#taille du modèle</span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    <span class="c1">#quantization</span>
    <span class="n">quantized_model_pretrained</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">quantize_dynamic</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">torch</span><span class="o">.</span><span class="n">qint8</span><span class="p">)</span>
    <span class="c1"># taille du nouveau modèle </span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">quantized_model_pretrained</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>model:  int8  	 Size (KB): 102523.238
    model:  int8  	 Size (KB): 96379.996
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[&nbsp;]:</div>
    
    
    
    
    <div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
    <pre>96379996</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>Le modèle pré-entrainé a une taille de 102523.238 KB.
    Après compression sa taille est de 96379.996 KB.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">out</span> <span class="o">=</span> <span class="n">quantized_model_pretrained</span><span class="p">(</span><span class="n">image</span><span class="p">)</span>
    <span class="c1"># Find the predicted class</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out</span><span class="o">.</span><span class="n">argmax</span><span class="p">()]))</span>
    
    <span class="n">out_2</span> <span class="o">=</span> <span class="n">quantized_model_pretrained</span><span class="p">(</span><span class="n">image_2</span><span class="p">)</span>
    <span class="c1"># Find the predicted class</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out_2</span><span class="o">.</span><span class="n">argmax</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>Predicted class is: Golden Retriever
    Predicted class is: red king crab
    </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>Les prédictions sont toujours bonne avec le modèle compressé.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">alexnet</span> <span class="o">=</span> <span class="n">models</span><span class="o">.</span><span class="n">alexnet</span><span class="p">()</span>
    
    <span class="c1"># Set layers such as dropout and batchnorm in evaluation mode</span>
    <span class="n">alexnet</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>
    
    <span class="n">out</span> <span class="o">=</span> <span class="n">quantized_model_pretrained</span><span class="p">(</span><span class="n">image</span><span class="p">)</span>
    <span class="c1"># Find the predicted class</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out</span><span class="o">.</span><span class="n">argmax</span><span class="p">()]))</span>
    
    <span class="n">out</span> <span class="o">=</span> <span class="n">alexnet</span><span class="p">(</span><span class="n">image_2</span><span class="p">)</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Predicted class is: </span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">labels</span><span class="p">[</span><span class="n">out_2</span><span class="o">.</span><span class="n">argmax</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>Predicted class is: Golden Retriever
    Predicted class is: red king crab
    </pre>
    </div>
    </div>
    
    </div>
    
    </div>
    
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h2 id="Exercise-4:-Transfer-Learning">Exercise 4: Transfer Learning<a class="anchor-link" href="#Exercise-4:-Transfer-Learning">&#182;</a></h2><p>For this work, we will use a pre-trained model (ResNet18) as a descriptor extractor and will refine the classification by training only the last fully connected layer of the network. Thus, the output layer of the pre-trained network will be replaced by a layer adapted to the new classes to be recognized which will be in our case ants and bees.
    Download and unzip in your working directory the dataset available at the address :</p>
    <p><a href="https://download.pytorch.org/tutorial/hymenoptera_data.zip">https://download.pytorch.org/tutorial/hymenoptera_data.zip</a></p>
    <p>Execute the following code in order to display some images of the dataset.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">os</span>
    
    <span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
    <span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>
    <span class="kn">import</span> <span class="nn">torch</span>
    <span class="kn">import</span> <span class="nn">torchvision</span>
    <span class="kn">from</span> <span class="nn">torchvision</span> <span class="kn">import</span> <span class="n">datasets</span><span class="p">,</span> <span class="n">transforms</span>
    
    <span class="c1"># Data augmentation and normalization for training</span>
    <span class="c1"># Just normalization for validation</span>
    <span class="n">data_transforms</span> <span class="o">=</span> <span class="p">{</span>
        <span class="s2">&quot;train&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomResizedCrop</span><span class="p">(</span>
                    <span class="mi">224</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models were trained on 224x224 images</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomHorizontalFlip</span><span class="p">(),</span>  <span class="c1"># flip horizontally 50% of the time - increases train set variability</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>  <span class="c1"># convert it to a PyTorch tensor</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">(</span>
                    <span class="p">[</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models expect this norm</span>
            <span class="p">]</span>
        <span class="p">),</span>
        <span class="s2">&quot;val&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Resize</span><span class="p">(</span><span class="mi">256</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">CenterCrop</span><span class="p">(</span><span class="mi">224</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]),</span>
            <span class="p">]</span>
        <span class="p">),</span>
    <span class="p">}</span>
    
    <span class="n">data_dir</span> <span class="o">=</span> <span class="s2">&quot;hymenoptera_data&quot;</span>
    <span class="c1"># Create train and validation datasets and loaders</span>
    <span class="n">image_datasets</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">datasets</span><span class="o">.</span><span class="n">ImageFolder</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">data_dir</span><span class="p">,</span> <span class="n">x</span><span class="p">),</span> <span class="n">data_transforms</span><span class="p">[</span><span class="n">x</span><span class="p">])</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    <span class="n">dataloaders</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
            <span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">],</span> <span class="n">batch_size</span><span class="o">=</span><span class="mi">4</span><span class="p">,</span> <span class="n">shuffle</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="mi">0</span>
        <span class="p">)</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    <span class="n">dataset_sizes</span> <span class="o">=</span> <span class="p">{</span><span class="n">x</span><span class="p">:</span> <span class="nb">len</span><span class="p">(</span><span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">])</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]}</span>
    <span class="n">class_names</span> <span class="o">=</span> <span class="n">image_datasets</span><span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">]</span><span class="o">.</span><span class="n">classes</span>
    <span class="n">device</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">device</span><span class="p">(</span><span class="s2">&quot;cuda:0&quot;</span> <span class="k">if</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">()</span> <span class="k">else</span> <span class="s2">&quot;cpu&quot;</span><span class="p">)</span>
    
    <span class="c1"># Helper function for displaying images</span>
    <span class="k">def</span> <span class="nf">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="n">title</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Imshow for Tensor.&quot;&quot;&quot;</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">inp</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span><span class="o">.</span><span class="n">transpose</span><span class="p">((</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">0</span><span class="p">))</span>
        <span class="n">mean</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">])</span>
        <span class="n">std</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">])</span>
    
        <span class="c1"># Un-normalize the images</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">std</span> <span class="o">*</span> <span class="n">inp</span> <span class="o">+</span> <span class="n">mean</span>
        <span class="c1"># Clip just in case</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">clip</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="mi">0</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">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">title</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</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="n">title</span><span class="p">)</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">pause</span><span class="p">(</span><span class="mf">0.001</span><span class="p">)</span>  <span class="c1"># pause a bit so that plots are updated</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
    
    
    <span class="c1"># Get a batch of training data</span>
    <span class="n">inputs</span><span class="p">,</span> <span class="n">classes</span> <span class="o">=</span> <span class="nb">next</span><span class="p">(</span><span class="nb">iter</span><span class="p">(</span><span class="n">dataloaders</span><span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">]))</span>
    
    <span class="c1"># Make a grid from batch</span>
    <span class="n">out</span> <span class="o">=</span> <span class="n">torchvision</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">make_grid</span><span class="p">(</span><span class="n">inputs</span><span class="p">)</span>
    
    <span class="n">imshow</span><span class="p">(</span><span class="n">out</span><span class="p">,</span> <span class="n">title</span><span class="o">=</span><span class="p">[</span><span class="n">class_names</span><span class="p">[</span><span class="n">x</span><span class="p">]</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="n">classes</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>Now, execute the following code which uses a pre-trained model ResNet18 having replaced the output layer for the ants/bees classification and performs the model training by only changing the weights of this output layer.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">copy</span>
    <span class="kn">import</span> <span class="nn">os</span>
    <span class="kn">import</span> <span class="nn">time</span>
    
    <span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
    <span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>
    <span class="kn">import</span> <span class="nn">torch</span>
    <span class="kn">import</span> <span class="nn">torch.nn</span> <span class="k">as</span> <span class="nn">nn</span>
    <span class="kn">import</span> <span class="nn">torch.optim</span> <span class="k">as</span> <span class="nn">optim</span>
    <span class="kn">import</span> <span class="nn">torchvision</span>
    <span class="kn">from</span> <span class="nn">torch.optim</span> <span class="kn">import</span> <span class="n">lr_scheduler</span>
    <span class="kn">from</span> <span class="nn">torchvision</span> <span class="kn">import</span> <span class="n">datasets</span><span class="p">,</span> <span class="n">transforms</span>
    
    <span class="c1"># Data augmentation and normalization for training</span>
    <span class="c1"># Just normalization for validation</span>
    <span class="n">data_transforms</span> <span class="o">=</span> <span class="p">{</span>
        <span class="s2">&quot;train&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomResizedCrop</span><span class="p">(</span>
                    <span class="mi">224</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models were trained on 224x224 images</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomHorizontalFlip</span><span class="p">(),</span>  <span class="c1"># flip horizontally 50% of the time - increases train set variability</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>  <span class="c1"># convert it to a PyTorch tensor</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">(</span>
                    <span class="p">[</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models expect this norm</span>
            <span class="p">]</span>
        <span class="p">),</span>
        <span class="s2">&quot;val&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Resize</span><span class="p">(</span><span class="mi">256</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">CenterCrop</span><span class="p">(</span><span class="mi">224</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]),</span>
            <span class="p">]</span>
        <span class="p">),</span>
    <span class="p">}</span>
    
    <span class="n">data_dir</span> <span class="o">=</span> <span class="s2">&quot;hymenoptera_data&quot;</span>
    <span class="c1"># Create train and validation datasets and loaders</span>
    <span class="n">image_datasets</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">datasets</span><span class="o">.</span><span class="n">ImageFolder</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">data_dir</span><span class="p">,</span> <span class="n">x</span><span class="p">),</span> <span class="n">data_transforms</span><span class="p">[</span><span class="n">x</span><span class="p">])</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    <span class="n">dataloaders</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
            <span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">],</span> <span class="n">batch_size</span><span class="o">=</span><span class="mi">4</span><span class="p">,</span> <span class="n">shuffle</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="mi">4</span>
        <span class="p">)</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    <span class="n">dataset_sizes</span> <span class="o">=</span> <span class="p">{</span><span class="n">x</span><span class="p">:</span> <span class="nb">len</span><span class="p">(</span><span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">])</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]}</span>
    <span class="n">class_names</span> <span class="o">=</span> <span class="n">image_datasets</span><span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">]</span><span class="o">.</span><span class="n">classes</span>
    <span class="n">device</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">device</span><span class="p">(</span><span class="s2">&quot;cuda:0&quot;</span> <span class="k">if</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">()</span> <span class="k">else</span> <span class="s2">&quot;cpu&quot;</span><span class="p">)</span>
    
    <span class="c1"># Helper function for displaying images</span>
    <span class="k">def</span> <span class="nf">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="n">title</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Imshow for Tensor.&quot;&quot;&quot;</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">inp</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span><span class="o">.</span><span class="n">transpose</span><span class="p">((</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">0</span><span class="p">))</span>
        <span class="n">mean</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">])</span>
        <span class="n">std</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">])</span>
    
        <span class="c1"># Un-normalize the images</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">std</span> <span class="o">*</span> <span class="n">inp</span> <span class="o">+</span> <span class="n">mean</span>
        <span class="c1"># Clip just in case</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">clip</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="mi">0</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">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">title</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</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="n">title</span><span class="p">)</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">pause</span><span class="p">(</span><span class="mf">0.001</span><span class="p">)</span>  <span class="c1"># pause a bit so that plots are updated</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
    
    
    <span class="c1"># Get a batch of training data</span>
    <span class="c1"># inputs, classes = next(iter(dataloaders[&#39;train&#39;]))</span>
    
    <span class="c1"># Make a grid from batch</span>
    <span class="c1"># out = torchvision.utils.make_grid(inputs)</span>
    
    <span class="c1"># imshow(out, title=[class_names[x] for x in classes])</span>
    <span class="c1"># training</span>
    
    
    <span class="k">def</span> <span class="nf">train_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">criterion</span><span class="p">,</span> <span class="n">optimizer</span><span class="p">,</span> <span class="n">scheduler</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="mi">25</span><span class="p">):</span>
        <span class="n">since</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="n">best_model_wts</span> <span class="o">=</span> <span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">())</span>
        <span class="n">best_acc</span> <span class="o">=</span> <span class="mf">0.0</span>
    
        <span class="n">epoch_time</span> <span class="o">=</span> <span class="p">[]</span>  <span class="c1"># we&#39;ll keep track of the time needed for each epoch</span>
    
        <span class="k">for</span> <span class="n">epoch</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">num_epochs</span><span class="p">):</span>
            <span class="n">epoch_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="nb">print</span><span class="p">(</span><span class="s2">&quot;Epoch </span><span class="si">{}</span><span class="s2">/</span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">epoch</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">num_epochs</span><span class="p">))</span>
            <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;-&quot;</span> <span class="o">*</span> <span class="mi">10</span><span class="p">)</span>
    
            <span class="c1"># Each epoch has a training and validation phase</span>
            <span class="k">for</span> <span class="n">phase</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]:</span>
                <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">:</span>
                    <span class="n">scheduler</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
                    <span class="n">model</span><span class="o">.</span><span class="n">train</span><span class="p">()</span>  <span class="c1"># Set model to training mode</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">model</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>  <span class="c1"># Set model to evaluate mode</span>
    
                <span class="n">running_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
                <span class="n">running_corrects</span> <span class="o">=</span> <span class="mi">0</span>
    
                <span class="c1"># Iterate over data.</span>
                <span class="k">for</span> <span class="n">inputs</span><span class="p">,</span> <span class="n">labels</span> <span class="ow">in</span> <span class="n">dataloaders</span><span class="p">[</span><span class="n">phase</span><span class="p">]:</span>
                    <span class="n">inputs</span> <span class="o">=</span> <span class="n">inputs</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
                    <span class="n">labels</span> <span class="o">=</span> <span class="n">labels</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
    
                    <span class="c1"># zero the parameter gradients</span>
                    <span class="n">optimizer</span><span class="o">.</span><span class="n">zero_grad</span><span class="p">()</span>
    
                    <span class="c1"># Forward</span>
                    <span class="c1"># Track history if only in training phase</span>
                    <span class="k">with</span> <span class="n">torch</span><span class="o">.</span><span class="n">set_grad_enabled</span><span class="p">(</span><span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">):</span>
                        <span class="n">outputs</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">inputs</span><span class="p">)</span>
                        <span class="n">_</span><span class="p">,</span> <span class="n">preds</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">max</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
                        <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="n">labels</span><span class="p">)</span>
    
                        <span class="c1"># backward + optimize only if in training phase</span>
                        <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">:</span>
                            <span class="n">loss</span><span class="o">.</span><span class="n">backward</span><span class="p">()</span>
                            <span class="n">optimizer</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
    
                    <span class="c1"># Statistics</span>
                    <span class="n">running_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">inputs</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
                    <span class="n">running_corrects</span> <span class="o">+=</span> <span class="n">torch</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">preds</span> <span class="o">==</span> <span class="n">labels</span><span class="o">.</span><span class="n">data</span><span class="p">)</span>
    
                <span class="n">epoch_loss</span> <span class="o">=</span> <span class="n">running_loss</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="n">phase</span><span class="p">]</span>
                <span class="n">epoch_acc</span> <span class="o">=</span> <span class="n">running_corrects</span><span class="o">.</span><span class="n">double</span><span class="p">()</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="n">phase</span><span class="p">]</span>
    
                <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="si">{}</span><span class="s2"> Loss: </span><span class="si">{:.4f}</span><span class="s2"> Acc: </span><span class="si">{:.4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">phase</span><span class="p">,</span> <span class="n">epoch_loss</span><span class="p">,</span> <span class="n">epoch_acc</span><span class="p">))</span>
    
                <span class="c1"># Deep copy the model</span>
                <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;val&quot;</span> <span class="ow">and</span> <span class="n">epoch_acc</span> <span class="o">&gt;</span> <span class="n">best_acc</span><span class="p">:</span>
                    <span class="n">best_acc</span> <span class="o">=</span> <span class="n">epoch_acc</span>
                    <span class="n">best_model_wts</span> <span class="o">=</span> <span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">())</span>
    
            <span class="c1"># Add the epoch time</span>
            <span class="n">t_epoch</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="o">-</span> <span class="n">epoch_start</span>
            <span class="n">epoch_time</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">t_epoch</span><span class="p">)</span>
            <span class="nb">print</span><span class="p">()</span>
    
        <span class="n">time_elapsed</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="o">-</span> <span class="n">since</span>
        <span class="nb">print</span><span class="p">(</span>
            <span class="s2">&quot;Training complete in </span><span class="si">{:.0f}</span><span class="s2">m </span><span class="si">{:.0f}</span><span class="s2">s&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span>
                <span class="n">time_elapsed</span> <span class="o">//</span> <span class="mi">60</span><span class="p">,</span> <span class="n">time_elapsed</span> <span class="o">%</span> <span class="mi">60</span>
            <span class="p">)</span>
        <span class="p">)</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Best val Acc: </span><span class="si">{:4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">best_acc</span><span class="p">))</span>
    
        <span class="c1"># Load best model weights</span>
        <span class="n">model</span><span class="o">.</span><span class="n">load_state_dict</span><span class="p">(</span><span class="n">best_model_wts</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">model</span><span class="p">,</span> <span class="n">epoch_time</span>
    
    
    <span class="c1"># Download a pre-trained ResNet18 model and freeze its weights</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">torchvision</span><span class="o">.</span><span class="n">models</span><span class="o">.</span><span class="n">resnet18</span><span class="p">(</span><span class="n">pretrained</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
    <span class="k">for</span> <span class="n">param</span> <span class="ow">in</span> <span class="n">model</span><span class="o">.</span><span class="n">parameters</span><span class="p">():</span>
        <span class="n">param</span><span class="o">.</span><span class="n">requires_grad</span> <span class="o">=</span> <span class="kc">False</span>
    
    <span class="c1"># Replace the final fully connected layer</span>
    <span class="c1"># Parameters of newly constructed modules have requires_grad=True by default</span>
    <span class="n">num_ftrs</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">fc</span><span class="o">.</span><span class="n">in_features</span>
    <span class="n">model</span><span class="o">.</span><span class="n">fc</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="n">num_ftrs</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
    <span class="c1"># Send the model to the GPU</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
    <span class="c1"># Set the loss function</span>
    <span class="n">criterion</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">CrossEntropyLoss</span><span class="p">()</span>
    
    <span class="c1"># Observe that only the parameters of the final layer are being optimized</span>
    <span class="n">optimizer_conv</span> <span class="o">=</span> <span class="n">optim</span><span class="o">.</span><span class="n">SGD</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">fc</span><span class="o">.</span><span class="n">parameters</span><span class="p">(),</span> <span class="n">lr</span><span class="o">=</span><span class="mf">0.001</span><span class="p">,</span> <span class="n">momentum</span><span class="o">=</span><span class="mf">0.9</span><span class="p">)</span>
    <span class="n">exp_lr_scheduler</span> <span class="o">=</span> <span class="n">lr_scheduler</span><span class="o">.</span><span class="n">StepLR</span><span class="p">(</span><span class="n">optimizer_conv</span><span class="p">,</span> <span class="n">step_size</span><span class="o">=</span><span class="mi">7</span><span class="p">,</span> <span class="n">gamma</span><span class="o">=</span><span class="mf">0.1</span><span class="p">)</span>
    <span class="n">model</span><span class="p">,</span> <span class="n">epoch_time</span> <span class="o">=</span> <span class="n">train_model</span><span class="p">(</span>
        <span class="n">model</span><span class="p">,</span> <span class="n">criterion</span><span class="p">,</span> <span class="n">optimizer_conv</span><span class="p">,</span> <span class="n">exp_lr_scheduler</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="mi">10</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="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/torchvision/models/_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for &#39;weights&#39; are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=ResNet18_Weights.IMAGENET1K_V1`. You can also use `weights=ResNet18_Weights.DEFAULT` to get the most up-to-date weights.
      warnings.warn(msg)
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Epoch 1/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/torch/optim/lr_scheduler.py:136: UserWarning: Detected call of `lr_scheduler.step()` before `optimizer.step()`. In PyTorch 1.1.0 and later, you should call them in the opposite order: `optimizer.step()` before `lr_scheduler.step()`.  Failure to do this will result in PyTorch skipping the first value of the learning rate schedule. See more details at https://pytorch.org/docs/stable/optim.html#how-to-adjust-learning-rate
      warnings.warn(&#34;Detected call of `lr_scheduler.step()` before `optimizer.step()`. &#34;
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.7993 Acc: 0.5943
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.3701 Acc: 0.8696
    
    Epoch 2/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4917 Acc: 0.7951
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2116 Acc: 0.9348
    
    Epoch 3/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.5263 Acc: 0.7295
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2495 Acc: 0.9058
    
    Epoch 4/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.2608 Acc: 0.8893
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.3190 Acc: 0.8841
    
    Epoch 5/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4371 Acc: 0.8197
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2230 Acc: 0.9203
    
    Epoch 6/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.5459 Acc: 0.7828
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.4372 Acc: 0.8333
    
    Epoch 7/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4413 Acc: 0.8074
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.1740 Acc: 0.9493
    
    Epoch 8/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4181 Acc: 0.8238
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.1775 Acc: 0.9348
    
    Epoch 9/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.2983 Acc: 0.8852
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2060 Acc: 0.9203
    
    Epoch 10/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.3563 Acc: 0.8525
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.1771 Acc: 0.9420
    
    Training complete in 13m 36s
    Best val Acc: 0.949275
    </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>Experiments:
    Study the code and the results obtained.</p>
    <p>Modify the code and add an "eval_model" function to allow
    the evaluation of the model on a test set (different from the learning and validation sets used during the learning phase). Study the results obtained.</p>
    <p>Now modify the code to replace the current classification layer with a set of two layers using a "relu" activation function for the middle layer, and the "dropout" mechanism for both layers. Renew the experiments and study the results obtained.</p>
    <p>Apply ther quantization (post and quantization aware) and evaluate impact on model size and 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">
    <hr>
    <p>Dans cette partie, nous allons ajouter un dataset de test. On configure le data_transform pour qu'il prennent en compte les données test contenu dans le dossier test.</p>
    <p>On va aussi configurer la sortie avec la nouvelle structure de neurones.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="kn">import</span> <span class="nn">copy</span>
    <span class="kn">import</span> <span class="nn">os</span>
    <span class="kn">import</span> <span class="nn">time</span>
    
    <span class="kn">import</span> <span class="nn">matplotlib.pyplot</span> <span class="k">as</span> <span class="nn">plt</span>
    <span class="kn">import</span> <span class="nn">numpy</span> <span class="k">as</span> <span class="nn">np</span>
    <span class="kn">import</span> <span class="nn">torch</span>
    <span class="kn">import</span> <span class="nn">torch.nn</span> <span class="k">as</span> <span class="nn">nn</span>
    <span class="kn">import</span> <span class="nn">torch.optim</span> <span class="k">as</span> <span class="nn">optim</span>
    <span class="kn">import</span> <span class="nn">torchvision</span>
    <span class="kn">from</span> <span class="nn">torch.optim</span> <span class="kn">import</span> <span class="n">lr_scheduler</span>
    <span class="kn">from</span> <span class="nn">torchvision</span> <span class="kn">import</span> <span class="n">datasets</span><span class="p">,</span> <span class="n">transforms</span>
    
    <span class="c1"># Data augmentation and normalization for training</span>
    <span class="c1"># Just normalization for validation</span>
    
    <span class="c1"># on ajoute les data test</span>
    <span class="n">data_transforms</span> <span class="o">=</span> <span class="p">{</span>
        <span class="s2">&quot;train&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomResizedCrop</span><span class="p">(</span>
                    <span class="mi">224</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models were trained on 224x224 images</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">RandomHorizontalFlip</span><span class="p">(),</span>  <span class="c1"># flip horizontally 50% of the time - increases train set variability</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>  <span class="c1"># convert it to a PyTorch tensor</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">(</span>
                    <span class="p">[</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]</span>
                <span class="p">),</span>  <span class="c1"># ImageNet models expect this norm</span>
            <span class="p">]</span>
        <span class="p">),</span>
        <span class="s2">&quot;val&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Resize</span><span class="p">(</span><span class="mi">256</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">CenterCrop</span><span class="p">(</span><span class="mi">224</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]),</span>
            <span class="p">]</span>
        <span class="p">),</span>
        <span class="s2">&quot;test&quot;</span><span class="p">:</span> <span class="n">transforms</span><span class="o">.</span><span class="n">Compose</span><span class="p">(</span>
            <span class="p">[</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Resize</span><span class="p">(</span><span class="mi">256</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">CenterCrop</span><span class="p">(</span><span class="mi">224</span><span class="p">),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">ToTensor</span><span class="p">(),</span>
                <span class="n">transforms</span><span class="o">.</span><span class="n">Normalize</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">],</span> <span class="p">[</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">]),</span>
            <span class="p">]</span>
        <span class="p">),</span>
    <span class="p">}</span>
    
    <span class="n">data_dir</span> <span class="o">=</span> <span class="s2">&quot;hymenoptera_data&quot;</span>
    <span class="c1"># Create train and validation datasets and loaders</span>
    <span class="n">image_datasets</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">datasets</span><span class="o">.</span><span class="n">ImageFolder</span><span class="p">(</span><span class="n">os</span><span class="o">.</span><span class="n">path</span><span class="o">.</span><span class="n">join</span><span class="p">(</span><span class="n">data_dir</span><span class="p">,</span> <span class="n">x</span><span class="p">),</span> <span class="n">data_transforms</span><span class="p">[</span><span class="n">x</span><span class="p">])</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">,</span><span class="s2">&quot;test&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    
    <span class="n">dataloaders</span> <span class="o">=</span> <span class="p">{</span>
        <span class="n">x</span><span class="p">:</span> <span class="n">torch</span><span class="o">.</span><span class="n">utils</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">DataLoader</span><span class="p">(</span>
            <span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">],</span> <span class="n">batch_size</span><span class="o">=</span><span class="mi">4</span><span class="p">,</span> <span class="n">shuffle</span><span class="o">=</span><span class="kc">True</span><span class="p">,</span> <span class="n">num_workers</span><span class="o">=</span><span class="mi">4</span>
        <span class="p">)</span>
        <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">,</span><span class="s2">&quot;test&quot;</span><span class="p">]</span>
    <span class="p">}</span>
    <span class="n">dataset_sizes</span> <span class="o">=</span> <span class="p">{</span><span class="n">x</span><span class="p">:</span> <span class="nb">len</span><span class="p">(</span><span class="n">image_datasets</span><span class="p">[</span><span class="n">x</span><span class="p">])</span> <span class="k">for</span> <span class="n">x</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">,</span><span class="s2">&quot;test&quot;</span><span class="p">]}</span>
    <span class="n">class_names</span> <span class="o">=</span> <span class="n">image_datasets</span><span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">]</span><span class="o">.</span><span class="n">classes</span>
    <span class="n">device</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">device</span><span class="p">(</span><span class="s2">&quot;cuda:0&quot;</span> <span class="k">if</span> <span class="n">torch</span><span class="o">.</span><span class="n">cuda</span><span class="o">.</span><span class="n">is_available</span><span class="p">()</span> <span class="k">else</span> <span class="s2">&quot;cpu&quot;</span><span class="p">)</span>
    
    <span class="c1"># Helper function for displaying images</span>
    <span class="k">def</span> <span class="nf">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="n">title</span><span class="o">=</span><span class="kc">None</span><span class="p">):</span>
        <span class="sd">&quot;&quot;&quot;Imshow for Tensor.&quot;&quot;&quot;</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">inp</span><span class="o">.</span><span class="n">numpy</span><span class="p">()</span><span class="o">.</span><span class="n">transpose</span><span class="p">((</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">0</span><span class="p">))</span>
        <span class="n">mean</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.485</span><span class="p">,</span> <span class="mf">0.456</span><span class="p">,</span> <span class="mf">0.406</span><span class="p">])</span>
        <span class="n">std</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([</span><span class="mf">0.229</span><span class="p">,</span> <span class="mf">0.224</span><span class="p">,</span> <span class="mf">0.225</span><span class="p">])</span>
    
        <span class="c1"># Un-normalize the images</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">std</span> <span class="o">*</span> <span class="n">inp</span> <span class="o">+</span> <span class="n">mean</span>
        <span class="c1"># Clip just in case</span>
        <span class="n">inp</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">clip</span><span class="p">(</span><span class="n">inp</span><span class="p">,</span> <span class="mi">0</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">imshow</span><span class="p">(</span><span class="n">inp</span><span class="p">)</span>
        <span class="k">if</span> <span class="n">title</span> <span class="ow">is</span> <span class="ow">not</span> <span class="kc">None</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="n">title</span><span class="p">)</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">pause</span><span class="p">(</span><span class="mf">0.001</span><span class="p">)</span>  <span class="c1"># pause a bit so that plots are updated</span>
        <span class="n">plt</span><span class="o">.</span><span class="n">show</span><span class="p">()</span>
    
    
    <span class="c1"># Get a batch of training data</span>
    <span class="c1"># inputs, classes = next(iter(dataloaders[&#39;train&#39;]))</span>
    
    <span class="c1"># Make a grid from batch</span>
    <span class="c1"># out = torchvision.utils.make_grid(inputs)</span>
    
    <span class="c1"># imshow(out, title=[class_names[x] for x in classes])</span>
    <span class="c1"># training</span>
    
    
    <span class="k">def</span> <span class="nf">train_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">criterion</span><span class="p">,</span> <span class="n">optimizer</span><span class="p">,</span> <span class="n">scheduler</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="mi">25</span><span class="p">):</span>
        <span class="n">since</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="n">best_model_wts</span> <span class="o">=</span> <span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">())</span>
        <span class="n">best_acc</span> <span class="o">=</span> <span class="mf">0.0</span>
    
        <span class="n">epoch_time</span> <span class="o">=</span> <span class="p">[]</span>  <span class="c1"># we&#39;ll keep track of the time needed for each epoch</span>
    
        <span class="k">for</span> <span class="n">epoch</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">num_epochs</span><span class="p">):</span>
            <span class="n">epoch_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="nb">print</span><span class="p">(</span><span class="s2">&quot;Epoch </span><span class="si">{}</span><span class="s2">/</span><span class="si">{}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">epoch</span> <span class="o">+</span> <span class="mi">1</span><span class="p">,</span> <span class="n">num_epochs</span><span class="p">))</span>
            <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;-&quot;</span> <span class="o">*</span> <span class="mi">10</span><span class="p">)</span>
    
            <span class="c1"># Each epoch has a training and validation phase</span>
            <span class="k">for</span> <span class="n">phase</span> <span class="ow">in</span> <span class="p">[</span><span class="s2">&quot;train&quot;</span><span class="p">,</span> <span class="s2">&quot;val&quot;</span><span class="p">]:</span>
                <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">:</span>
                    <span class="n">scheduler</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
                    <span class="n">model</span><span class="o">.</span><span class="n">train</span><span class="p">()</span>  <span class="c1"># Set model to training mode</span>
                <span class="k">else</span><span class="p">:</span>
                    <span class="n">model</span><span class="o">.</span><span class="n">eval</span><span class="p">()</span>  <span class="c1"># Set model to evaluate mode</span>
    
                <span class="n">running_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
                <span class="n">running_corrects</span> <span class="o">=</span> <span class="mi">0</span>
    
                <span class="c1"># Iterate over data.</span>
                <span class="k">for</span> <span class="n">inputs</span><span class="p">,</span> <span class="n">labels</span> <span class="ow">in</span> <span class="n">dataloaders</span><span class="p">[</span><span class="n">phase</span><span class="p">]:</span>
                    <span class="n">inputs</span> <span class="o">=</span> <span class="n">inputs</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
                    <span class="n">labels</span> <span class="o">=</span> <span class="n">labels</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
    
                    <span class="c1"># zero the parameter gradients</span>
                    <span class="n">optimizer</span><span class="o">.</span><span class="n">zero_grad</span><span class="p">()</span>
    
                    <span class="c1"># Forward</span>
                    <span class="c1"># Track history if only in training phase</span>
                    <span class="k">with</span> <span class="n">torch</span><span class="o">.</span><span class="n">set_grad_enabled</span><span class="p">(</span><span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">):</span>
                        <span class="n">outputs</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">inputs</span><span class="p">)</span>
                        <span class="n">_</span><span class="p">,</span> <span class="n">preds</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">max</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
                        <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="n">labels</span><span class="p">)</span>
    
                        <span class="c1"># backward + optimize only if in training phase</span>
                        <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;train&quot;</span><span class="p">:</span>
                            <span class="n">loss</span><span class="o">.</span><span class="n">backward</span><span class="p">()</span>
                            <span class="n">optimizer</span><span class="o">.</span><span class="n">step</span><span class="p">()</span>
    
                    <span class="c1"># Statistics</span>
                    <span class="n">running_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">inputs</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
                    <span class="n">running_corrects</span> <span class="o">+=</span> <span class="n">torch</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">preds</span> <span class="o">==</span> <span class="n">labels</span><span class="o">.</span><span class="n">data</span><span class="p">)</span>
    
    
                <span class="n">epoch_loss</span> <span class="o">=</span> <span class="n">running_loss</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="n">phase</span><span class="p">]</span>
                <span class="n">epoch_acc</span> <span class="o">=</span> <span class="n">running_corrects</span><span class="o">.</span><span class="n">double</span><span class="p">()</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="n">phase</span><span class="p">]</span>
    
                <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;</span><span class="si">{}</span><span class="s2"> Loss: </span><span class="si">{:.4f}</span><span class="s2"> Acc: </span><span class="si">{:.4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">phase</span><span class="p">,</span> <span class="n">epoch_loss</span><span class="p">,</span> <span class="n">epoch_acc</span><span class="p">))</span>
    
                <span class="c1"># Deep copy the model</span>
                <span class="k">if</span> <span class="n">phase</span> <span class="o">==</span> <span class="s2">&quot;val&quot;</span> <span class="ow">and</span> <span class="n">epoch_acc</span> <span class="o">&gt;</span> <span class="n">best_acc</span><span class="p">:</span>
                    <span class="n">best_acc</span> <span class="o">=</span> <span class="n">epoch_acc</span>
                    <span class="n">best_model_wts</span> <span class="o">=</span> <span class="n">copy</span><span class="o">.</span><span class="n">deepcopy</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">state_dict</span><span class="p">())</span>
    
            <span class="c1"># Add the epoch time</span>
            <span class="n">t_epoch</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="o">-</span> <span class="n">epoch_start</span>
            <span class="n">epoch_time</span><span class="o">.</span><span class="n">append</span><span class="p">(</span><span class="n">t_epoch</span><span class="p">)</span>
    
    
        <span class="n">time_elapsed</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="o">-</span> <span class="n">since</span>
        <span class="nb">print</span><span class="p">(</span>
            <span class="s2">&quot;Training complete in </span><span class="si">{:.0f}</span><span class="s2">m </span><span class="si">{:.0f}</span><span class="s2">s&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span>
                <span class="n">time_elapsed</span> <span class="o">//</span> <span class="mi">60</span><span class="p">,</span> <span class="n">time_elapsed</span> <span class="o">%</span> <span class="mi">60</span>
            <span class="p">)</span>
        <span class="p">)</span>
        <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Best val Acc: </span><span class="si">{:4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">best_acc</span><span class="p">))</span>
    
        <span class="c1"># Load best model weights</span>
        <span class="n">model</span><span class="o">.</span><span class="n">load_state_dict</span><span class="p">(</span><span class="n">best_model_wts</span><span class="p">)</span>
        <span class="k">return</span> <span class="n">model</span><span class="p">,</span> <span class="n">epoch_time</span>
    
    
    
    <span class="c1"># Download a pre-trained ResNet18 model and freeze its weights</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">torchvision</span><span class="o">.</span><span class="n">models</span><span class="o">.</span><span class="n">resnet18</span><span class="p">(</span><span class="n">pretrained</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
    <span class="k">for</span> <span class="n">param</span> <span class="ow">in</span> <span class="n">model</span><span class="o">.</span><span class="n">parameters</span><span class="p">():</span>
        <span class="n">param</span><span class="o">.</span><span class="n">requires_grad</span> <span class="o">=</span> <span class="kc">False</span>
    
    <span class="c1"># Replace the final fully connected layer</span>
    <span class="c1"># Parameters of newly constructed modules have requires_grad=True by default</span>
    <span class="n">num_ftrs</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">fc</span><span class="o">.</span><span class="n">in_features</span>
    
    <span class="c1"># on ajoute les nouvelles couches</span>
    <span class="n">model</span><span class="o">.</span><span class="n">fc</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">Sequential</span><span class="p">(</span>
        <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="n">num_ftrs</span><span class="p">,</span> <span class="mi">256</span><span class="p">),</span>  <span class="c1"># Add a layer with 256 neurons</span>
        <span class="n">nn</span><span class="o">.</span><span class="n">ReLU</span><span class="p">(),</span>                 <span class="c1"># Apply ReLU activation function</span>
        <span class="n">nn</span><span class="o">.</span><span class="n">Dropout</span><span class="p">(</span><span class="mf">0.5</span><span class="p">),</span>           <span class="c1"># Apply dropout with a probability of 0.5</span>
        <span class="n">nn</span><span class="o">.</span><span class="n">Linear</span><span class="p">(</span><span class="mi">256</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>           <span class="c1"># Add the final layer with 2 output neurons</span>
    <span class="p">)</span>
    
    
    <span class="c1"># Send the model to the GPU</span>
    <span class="n">model</span> <span class="o">=</span> <span class="n">model</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
    <span class="c1"># Set the loss function</span>
    <span class="n">criterion</span> <span class="o">=</span> <span class="n">nn</span><span class="o">.</span><span class="n">CrossEntropyLoss</span><span class="p">()</span>
    
    <span class="c1"># Observe that only the parameters of the final layer are being optimized</span>
    <span class="n">optimizer_conv</span> <span class="o">=</span> <span class="n">optim</span><span class="o">.</span><span class="n">SGD</span><span class="p">(</span><span class="n">model</span><span class="o">.</span><span class="n">fc</span><span class="o">.</span><span class="n">parameters</span><span class="p">(),</span> <span class="n">lr</span><span class="o">=</span><span class="mf">0.001</span><span class="p">,</span> <span class="n">momentum</span><span class="o">=</span><span class="mf">0.9</span><span class="p">)</span>
    <span class="n">exp_lr_scheduler</span> <span class="o">=</span> <span class="n">lr_scheduler</span><span class="o">.</span><span class="n">StepLR</span><span class="p">(</span><span class="n">optimizer_conv</span><span class="p">,</span> <span class="n">step_size</span><span class="o">=</span><span class="mi">7</span><span class="p">,</span> <span class="n">gamma</span><span class="o">=</span><span class="mf">0.1</span><span class="p">)</span>
    <span class="n">model</span><span class="p">,</span> <span class="n">epoch_time</span> <span class="o">=</span> <span class="n">train_model</span><span class="p">(</span>
        <span class="n">model</span><span class="p">,</span> <span class="n">criterion</span><span class="p">,</span> <span class="n">optimizer_conv</span><span class="p">,</span> <span class="n">exp_lr_scheduler</span><span class="p">,</span> <span class="n">num_epochs</span><span class="o">=</span><span class="mi">10</span>
    <span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Epoch 1/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.6493 Acc: 0.6189
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.5245 Acc: 0.7174
    Epoch 2/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.5375 Acc: 0.7254
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.3046 Acc: 0.9203
    Epoch 3/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.5194 Acc: 0.7500
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2810 Acc: 0.8986
    Epoch 4/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4514 Acc: 0.7910
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2425 Acc: 0.9275
    Epoch 5/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4021 Acc: 0.7910
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2733 Acc: 0.8841
    Epoch 6/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4881 Acc: 0.7500
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2048 Acc: 0.9420
    Epoch 7/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4191 Acc: 0.7951
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2108 Acc: 0.9420
    Epoch 8/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.3865 Acc: 0.8484
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2127 Acc: 0.9348
    Epoch 9/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.4195 Acc: 0.8033
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2022 Acc: 0.9565
    Epoch 10/10
    ----------
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>train Loss: 0.3888 Acc: 0.8156
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>val Loss: 0.2033 Acc: 0.9493
    Training complete in 13m 34s
    Best val Acc: 0.956522
    </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>On a entraîné ce nouveau modèle. on définit maintenant la fonction eval_model(model), qui va évaluer les performances du modèle sur le data test.</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>On ajoute un test d'évaluation du modèle avec de nouvelles données</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="k">def</span> <span class="nf">eval_model</span><span class="p">(</span><span class="n">model</span><span class="p">):</span>
        <span class="c1"># initialisation des variables</span>
        <span class="n">running_loss</span> <span class="o">=</span> <span class="mf">0.0</span>
        <span class="n">running_corrects</span> <span class="o">=</span> <span class="mi">0</span>
        
        <span class="c1">#on teste sur les données test</span>
        <span class="k">for</span> <span class="n">inputs</span><span class="p">,</span> <span class="n">labels</span> <span class="ow">in</span> <span class="n">dataloaders</span><span class="p">[</span><span class="s2">&quot;test&quot;</span><span class="p">]:</span>
            <span class="n">inputs</span> <span class="o">=</span> <span class="n">inputs</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
            <span class="n">labels</span> <span class="o">=</span> <span class="n">labels</span><span class="o">.</span><span class="n">to</span><span class="p">(</span><span class="n">device</span><span class="p">)</span>
    
            <span class="n">outputs</span> <span class="o">=</span> <span class="n">model</span><span class="p">(</span><span class="n">inputs</span><span class="p">)</span>
            <span class="n">_</span><span class="p">,</span> <span class="n">preds</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">max</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="mi">1</span><span class="p">)</span>
            <span class="n">loss</span> <span class="o">=</span> <span class="n">criterion</span><span class="p">(</span><span class="n">outputs</span><span class="p">,</span> <span class="n">labels</span><span class="p">)</span>
    
            <span class="c1"># Statistics</span>
            <span class="n">running_loss</span> <span class="o">+=</span> <span class="n">loss</span><span class="o">.</span><span class="n">item</span><span class="p">()</span> <span class="o">*</span> <span class="n">inputs</span><span class="o">.</span><span class="n">size</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
            <span class="n">running_corrects</span> <span class="o">+=</span> <span class="n">torch</span><span class="o">.</span><span class="n">sum</span><span class="p">(</span><span class="n">preds</span> <span class="o">==</span> <span class="n">labels</span><span class="o">.</span><span class="n">data</span><span class="p">)</span>
    
        <span class="c1">#Calcul du loss et de l&#39;accuracy</span>
        <span class="n">loss</span> <span class="o">=</span> <span class="n">running_loss</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="s2">&quot;test&quot;</span><span class="p">]</span>
        <span class="n">acc</span> <span class="o">=</span> <span class="n">running_corrects</span><span class="o">.</span><span class="n">double</span><span class="p">()</span> <span class="o">/</span> <span class="n">dataset_sizes</span><span class="p">[</span><span class="s2">&quot;test&quot;</span><span class="p">]</span>
            
        <span class="k">return</span> <span class="n">loss</span><span class="p">,</span><span class="n">acc</span>
    
    <span class="n">loss</span><span class="p">,</span><span class="n">acc</span><span class="o">=</span><span class="n">eval_model</span><span class="p">(</span><span class="n">model</span><span class="p">)</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Loss: </span><span class="si">{:.4f}</span><span class="s2"> Acc: </span><span class="si">{:.4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">loss</span><span class="p">,</span> <span class="n">acc</span><span class="p">))</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Loss: 0.0623 Acc: 1.0000
    </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>On obtient une précision de 1 sur l'échantillon test. (il faudrait ajouter plus de photos)</p>
    <hr>
    <p>On va maintenant quantizer le modèle et comparer la taille des modèles.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">quantized_model</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">quantization</span><span class="o">.</span><span class="n">quantize_dynamic</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="n">dtype</span><span class="o">=</span><span class="n">torch</span><span class="o">.</span><span class="n">qint8</span><span class="p">)</span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">model</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    <span class="n">print_size_of_model</span><span class="p">(</span><span class="n">quantized_model</span><span class="p">,</span> <span class="s2">&quot;int8&quot;</span><span class="p">)</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>model:  int8  	 Size (KB): 45304.25
    model:  int8  	 Size (KB): 44911.014
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt">Out[&nbsp;]:</div>
    
    
    
    
    <div class="jp-RenderedText jp-OutputArea-output jp-OutputArea-executeResult" data-mime-type="text/plain">
    <pre>44911014</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>La quantization permet de passer de 45304.25 à 44911.014 KB.</p>
    <p>On étudie les performances du modèle.</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;[&nbsp;]:</div>
    <div class="jp-CodeMirrorEditor jp-Editor jp-InputArea-editor" data-type="inline">
         <div class="CodeMirror cm-s-jupyter">
    <div class=" highlight hl-ipython3"><pre><span></span><span class="n">loss</span><span class="p">,</span><span class="n">acc</span><span class="o">=</span><span class="n">eval_model</span><span class="p">(</span><span class="n">quantized_model</span><span class="p">)</span>
    <span class="nb">print</span><span class="p">(</span><span class="s2">&quot;Loss: </span><span class="si">{:.4f}</span><span class="s2"> Acc: </span><span class="si">{:.4f}</span><span class="s2">&quot;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="n">loss</span><span class="p">,</span> <span class="n">acc</span><span class="p">))</span>
    </pre></div>
    
         </div>
    </div>
    </div>
    </div>
    
    <div class="jp-Cell-outputWrapper">
    
    
    <div class="jp-OutputArea jp-Cell-outputArea">
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="application/vnd.jupyter.stderr">
    <pre>/Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    /Users/franck/Library/Python/3.8/lib/python/site-packages/urllib3/__init__.py:34: NotOpenSSLWarning: urllib3 v2.0 only supports OpenSSL 1.1.1+, currently the &#39;ssl&#39; module is compiled with &#39;LibreSSL 2.8.3&#39;. See: https://github.com/urllib3/urllib3/issues/3020
      warnings.warn(
    </pre>
    </div>
    </div>
    
    <div class="jp-OutputArea-child">
    
        
        <div class="jp-OutputPrompt jp-OutputArea-prompt"></div>
    
    
    <div class="jp-RenderedText jp-OutputArea-output" data-mime-type="text/plain">
    <pre>Loss: 0.2032 Acc: 1.0000
    </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>Le modèle quantizé permet aussi d'atteindre une précision de 1.</p>
    
    </div>
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h2 id="Optional">Optional<a class="anchor-link" href="#Optional">&#182;</a></h2><p>Try this at home!!</p>
    <p>Pytorch offers a framework to export a given CNN to your selfphone (either android or iOS). Have a look at the tutorial <a href="https://pytorch.org/mobile/home/">https://pytorch.org/mobile/home/</a></p>
    <p>The Exercise consists in deploying the CNN of Exercise 4 in your phone and then test it on live.</p>
    
    </div>
    </div>
    <div class="jp-Cell-inputWrapper"><div class="jp-InputPrompt jp-InputArea-prompt">
    </div><div class="jp-RenderedHTMLCommon jp-RenderedMarkdown jp-MarkdownOutput " data-mime-type="text/markdown">
    <h2 id="Author">Author<a class="anchor-link" href="#Author">&#182;</a></h2><p>Alberto BOSIO - Ph. D.</p>
    
    </div>
    </div>
    </body>
    
    
    
    
    
    
    
    </html>