{ "cells": [ { "cell_type": "markdown", "metadata": { "colab_type": "text", "id": "kDM4XSGVFk8D" }, "source": [ "# Using Torchbearer with PyTorch DataParallel\n", "\n", "PyTorch offers a very simple way to take advantage of multiple GPUs when training large models on lots of data through [DataParallel](https://pytorch.org/docs/stable/nn.html?highlight=data%20parallel#torch.nn.DataParallel). They have a very good tutorial on how to use this for base PyTorch models [here](https://pytorch.org/tutorials/beginner/blitz/data_parallel_tutorial.html) and we recommend you familiarise yourself with it before moving on with this tutorial. \n", "\n", "**Note**: If your model doesn't require state then Torchbearer works immediately with DataParallel without needing any of the steps in this tutorial. \n", "\n", "Unfortunately, DataParallel cannot directly pass the main Torchbearer state dictionary to models running on multiple GPUs, which leads to problems with Torchbearer models needing to access and manipulate state on the forward pass. In this tutorial we demonstrate a callback that allows us to use such models across multiple devices without loss of functionality. \n", "\n", "\n", "**Note**: The easiest way to use this tutorial is as a colab notebook, which allows you to dive in with no setup. We recommend you enable a free GPU with\n", "\n", "> **Runtime**   →   **Change runtime type**   →   **Hardware Accelerator: GPU**\n", "\n", "## Install Torchbearer\n", "\n", "First we install torchbearer if needed. " ] }, { "cell_type": "code", "execution_count": 1, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 35 }, "colab_type": "code", "id": "X_GU5DwzJRqP", "outputId": "037ea2c5-c5ca-4953-94d6-2510ab2c1d85" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "0.4.0.dev\n" ] } ], "source": [ "try:\n", " import torchbearer\n", "except:\n", " !pip install -q torchbearer\n", " import torchbearer\n", " \n", " # If problems arise, try\n", "# !pip install git+https://github.com/pytorchbearer/torchbearer\n", "# import torchbearer\n", " \n", "print(torchbearer.__version__)\n", "\n", "\n", "# Create some state keys for this example\n", "A_KEY = torchbearer.state_key('a_key')\n", "NEW_KEY = torchbearer.state_key('new_key')" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## UnpackState Callback\n", "\n", "The callback that we will be using throughout this example to interface with state in DataParallel is called the [UnpackState callback](https://torchbearer.readthedocs.io/en/latest/code/callbacks.html#module-torchbearer.callbacks.unpack_state). This callback takes a list of keys which are the items in state that you wish to access and packs them as a dictionary (under the same keys) which gets passed to the model forward. \n", "\n", "For a quick example, we build a very simple model that just prints the input. Then we create an unpacker callback that asks for the keys torchbearer.X and a newly defined key A_KEY, which we populate before the run. We then run a Trial with this callback and model and observe that the model gets passed a dictionary with these two keys and their values. " ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 85, "resources": { "http://localhost:8080/nbextensions/google.colab/colabwidgets/controls.css": { "data": "/* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /* We import all of these together in a single css file because the Webpack
loader sees only one file at a time. This allows postcss to see the variable
definitions when they are used. */

 /*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

 /*
This file is copied from the JupyterLab project to define default styling for
when the widget styling is compiled down to eliminate CSS variables. We make one
change - we comment out the font import below.
*/

 /**
 * The material design colors are adapted from google-material-color v1.2.6
 * https://github.com/danlevan/google-material-color
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css
 *
 * The license for the material design color CSS variables is as follows (see
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)
 *
 * The MIT License (MIT)
 *
 * Copyright (c) 2014 Dan Le Van
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

 /*
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.
*/

 /*
 * Optional monospace font for input/output prompt.
 */

 /* Commented out in ipywidgets since we don't need it. */

 /* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */

 /*
 * Added for compabitility with output area
 */

 :root {

  /* Borders

  The following variables, specify the visual styling of borders in JupyterLab.
   */

  /* 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.
  */ /* Base font size */ /* Ensures px perfect FontAwesome icons */

  /* Use these font colors against the corresponding main layout colors.
     In a light theme, these go from dark to light.
  */

  /* Use these against the brand/accent/warn/error colors.
     These will typically go from light to darker, in both a dark and light theme
   */

  /* Content Fonts

  Content font variables are used for typography of user generated content.
  */ /* Base font size */


  /* Layout

  The following are the main layout colors use in JupyterLab. In a light
  theme these would go from light to dark.
  */

  /* Brand/accent */

  /* State colors (warn, error, success, info) */

  /* Cell specific styles */
  /* A custom blend of MD grey and blue 600
   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
  /* A custom blend of MD grey and orange 600
   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */

  /* Notebook specific styles */

  /* Console specific styles */

  /* Toolbar specific styles */
}

 /* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /*
 * We assume that the CSS variables in
 * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css
 * have been defined.
 */

 /* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:

Copyright (c) 2014-2017, PhosphorJS Contributors
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

* Neither the name of the copyright holder nor the names of its
  contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

*/

 /*
 * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css 
 * We've scoped the rules so that they are consistent with exactly our code.
 */

 .jupyter-widgets.widget-tab > .p-TabBar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  list-style-type: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
  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-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  overflow: hidden;
  white-space: nowrap;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {
  display: none !important;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {
  position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {
  left: 0;
  -webkit-transition: left 150ms ease;
  transition: left 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {
  top: 0;
  -webkit-transition: top 150ms ease;
  transition: top 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {
  -webkit-transition: none;
  transition: none;
}

 /* End tabbar.css */

 :root { /* margin between inline elements */

    /* From Material Design Lite */
}

 .jupyter-widgets {
    margin: 2px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    color: black;
    overflow: visible;
}

 .jupyter-widgets.jupyter-widgets-disconnected::before {
    line-height: 28px;
    height: 28px;
}

 .jp-Output-result > .jupyter-widgets {
    margin-left: 0;
    margin-right: 0;
}

 /* vbox and hbox */

 .widget-inline-hbox {
    /* Horizontal widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
}

 .widget-inline-vbox {
    /* Vertical Widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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;
}

 .widget-box {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    overflow: auto;
}

 .widget-gridbox {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: grid;
    margin: 0;
    overflow: auto;
}

 .widget-hbox {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
}

 .widget-vbox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 /* General Button Styling */

 .jupyter-button {
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 0px;
    padding-bottom: 0px;
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
    font-size: 13px;
    cursor: pointer;

    height: 28px;
    border: 0px solid;
    line-height: 28px;
    -webkit-box-shadow: none;
            box-shadow: none;

    color: rgba(0, 0, 0, .8);
    background-color: #EEEEEE;
    border-color: #E0E0E0;
    border: none;
}

 .jupyter-button i.fa {
    margin-right: 4px;
    pointer-events: none;
}

 .jupyter-button:empty:before {
    content: "\200b"; /* zero-width space */
}

 .jupyter-widgets.jupyter-button:disabled {
    opacity: 0.6;
}

 .jupyter-button i.fa.center {
    margin-right: 0;
}

 .jupyter-button:hover:enabled, .jupyter-button:focus:enabled {
    /* MD Lite 2dp shadow */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
            box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .jupyter-button:active, .jupyter-button.mod-active {
    /* MD Lite 4dp shadow */
    -webkit-box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
            box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
    color: rgba(0, 0, 0, .8);
    background-color: #BDBDBD;
}

 .jupyter-button:focus:enabled {
    outline: 1px solid #64B5F6;
}

 /* Button "Primary" Styling */

 .jupyter-button.mod-primary {
    color: rgba(255, 255, 255, 1.0);
    background-color: #2196F3;
}

 .jupyter-button.mod-primary.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 .jupyter-button.mod-primary:active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 /* Button "Success" Styling */

 .jupyter-button.mod-success {
    color: rgba(255, 255, 255, 1.0);
    background-color: #4CAF50;
}

 .jupyter-button.mod-success.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 .jupyter-button.mod-success:active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 /* Button "Info" Styling */

 .jupyter-button.mod-info {
    color: rgba(255, 255, 255, 1.0);
    background-color: #00BCD4;
}

 .jupyter-button.mod-info.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 .jupyter-button.mod-info:active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 /* Button "Warning" Styling */

 .jupyter-button.mod-warning {
    color: rgba(255, 255, 255, 1.0);
    background-color: #FF9800;
}

 .jupyter-button.mod-warning.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 .jupyter-button.mod-warning:active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 /* Button "Danger" Styling */

 .jupyter-button.mod-danger {
    color: rgba(255, 255, 255, 1.0);
    background-color: #F44336;
}

 .jupyter-button.mod-danger.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 .jupyter-button.mod-danger:active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 /* Widget Button*/

 .widget-button, .widget-toggle-button {
    width: 148px;
}

 /* Widget Label Styling */

 /* Override Bootstrap label css */

 .jupyter-widgets label {
    margin-bottom: 0;
    margin-bottom: initial;
}

 .widget-label-basic {
    /* Basic Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-label {
    /* Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-inline-hbox .widget-label {
    /* Horizontal Widget Label */
    color: black;
    text-align: right;
    margin-right: 8px;
    width: 80px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
}

 .widget-inline-vbox .widget-label {
    /* Vertical Widget Label */
    color: black;
    text-align: center;
    line-height: 28px;
}

 /* Widget Readout Styling */

 .widget-readout {
    color: black;
    font-size: 13px;
    height: 28px;
    line-height: 28px;
    overflow: hidden;
    white-space: nowrap;
    text-align: center;
}

 .widget-readout.overflow {
    /* Overflowing Readout */

    /* From Material Design Lite
        shadow-key-umbra-opacity: 0.2;
        shadow-key-penumbra-opacity: 0.14;
        shadow-ambient-shadow-opacity: 0.12;
     */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                        0 3px 1px -2px rgba(0, 0, 0, .14),
                        0 1px 5px 0 rgba(0, 0, 0, .12);

    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                0 3px 1px -2px rgba(0, 0, 0, .14),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .widget-inline-hbox .widget-readout {
    /* Horizontal Readout */
    text-align: center;
    max-width: 148px;
    min-width: 72px;
    margin-left: 4px;
}

 .widget-inline-vbox .widget-readout {
    /* Vertical Readout */
    margin-top: 4px;
    /* as wide as the widget */
    width: inherit;
}

 /* Widget Checkbox Styling */

 .widget-checkbox {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-checkbox input[type="checkbox"] {
    margin: 0px 8px 0px 0px;
    line-height: 28px;
    font-size: large;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-item-align: center;
        align-self: center;
}

 /* Widget Valid Styling */

 .widget-valid {
    height: 28px;
    line-height: 28px;
    width: 148px;
    font-size: 13px;
}

 .widget-valid i:before {
    line-height: 28px;
    margin-right: 4px;
    margin-left: 4px;

    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .widget-valid.mod-valid i:before {
    content: "\f00c";
    color: green;
}

 .widget-valid.mod-invalid i:before {
    content: "\f00d";
    color: red;
}

 .widget-valid.mod-valid .widget-valid-readout {
    display: none;
}

 /* Widget Text and TextArea Stying */

 .widget-textarea, .widget-text {
    width: 300px;
}

 .widget-text input[type="text"], .widget-text input[type="number"]{
    height: 28px;
    line-height: 28px;
}

 .widget-text input[type="text"]:disabled, .widget-text input[type="number"]:disabled, .widget-textarea textarea:disabled {
    opacity: 0.6;
}

 .widget-text input[type="text"], .widget-text input[type="number"], .widget-textarea textarea {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    outline: none !important;
}

 .widget-textarea textarea {
    height: inherit;
    width: inherit;
}

 .widget-text input:focus, .widget-textarea textarea:focus {
    border-color: #64B5F6;
}

 /* Widget Slider */

 .widget-slider .ui-slider {
    /* Slider Track */
    border: 1px solid #BDBDBD;
    background: #BDBDBD;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    border-radius: 0px;
}

 .widget-slider .ui-slider .ui-slider-handle {
    /* Slider Handle */
    outline: none !important; /* focused slider handles are colored - see below */
    position: absolute;
    background-color: white;
    border: 1px solid #9E9E9E;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    z-index: 1;
    background-image: none; /* Override jquery-ui */
}

 /* Override jquery-ui */

 .widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {
    background-color: #2196F3;
    border: 1px solid #2196F3;
}

 .widget-slider .ui-slider .ui-slider-handle:active {
    background-color: #2196F3;
    border-color: #2196F3;
    z-index: 2;
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
}

 .widget-slider  .ui-slider .ui-slider-range {
    /* Interval between the two specified value of a double slider */
    position: absolute;
    background: #2196F3;
    z-index: 0;
}

 /* Shapes of Slider Handles */

 .widget-hslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-top: -7px;
    margin-left: -7px;
    border-radius: 50%;
    top: 0;
}

 .widget-vslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-bottom: -7px;
    margin-left: -7px;
    border-radius: 50%;
    left: 0;
}

 .widget-hslider .ui-slider .ui-slider-range {
    height: 8px;
    margin-top: -3px;
}

 .widget-vslider .ui-slider .ui-slider-range {
    width: 8px;
    margin-left: -3px;
}

 /* Horizontal Slider */

 .widget-hslider {
    width: 300px;
    height: 28px;
    line-height: 28px;

    /* Override the align-items baseline. This way, the description and readout
    still seem to align their baseline properly, and we don't have to have
    align-self: stretch in the .slider-container. */
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

 .widgets-slider .slider-container {
    overflow: visible;
}

 .widget-hslider .slider-container {
    height: 28px;
    margin-left: 6px;
    margin-right: 6px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
}

 .widget-hslider .ui-slider {
    /* Inner, invisible slide div */
    height: 4px;
    margin-top: 12px;
    width: 100%;
}

 /* Vertical Slider */

 .widget-vbox .widget-label {
    height: 28px;
    line-height: 28px;
}

 .widget-vslider {
    /* Vertical Slider */
    height: 200px;
    width: 72px;
}

 .widget-vslider .slider-container {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 6px;
    margin-top: 6px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .widget-vslider .ui-slider-vertical {
    /* Inner, invisible slide div */
    width: 4px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-left: auto;
    margin-right: auto;
}

 /* Widget Progress Styling */

 .progress-bar {
    -webkit-transition: none;
    transition: none;
}

 .progress-bar {
    height: 28px;
}

 .progress-bar {
    background-color: #2196F3;
}

 .progress-bar-success {
    background-color: #4CAF50;
}

 .progress-bar-info {
    background-color: #00BCD4;
}

 .progress-bar-warning {
    background-color: #FF9800;
}

 .progress-bar-danger {
    background-color: #F44336;
}

 .progress {
    background-color: #EEEEEE;
    border: none;
    -webkit-box-shadow: none;
            box-shadow: none;
}

 /* Horisontal Progress */

 .widget-hprogress {
    /* Progress Bar */
    height: 28px;
    line-height: 28px;
    width: 300px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;

}

 .widget-hprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-top: 4px;
    margin-bottom: 4px;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    /* Override bootstrap style */
    height: auto;
    height: initial;
}

 /* Vertical Progress */

 .widget-vprogress {
    height: 200px;
    width: 72px;
}

 .widget-vprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    width: 20px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;
}

 /* Select Widget Styling */

 .widget-dropdown {
    height: 28px;
    width: 300px;
    line-height: 28px;
}

 .widget-dropdown > select {
    padding-right: 20px;
    border: 1px solid #9E9E9E;
    border-radius: 0;
    height: inherit;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    outline: none !important;
    -webkit-box-shadow: none;
            box-shadow: none;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    vertical-align: top;
    padding-left: 8px;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
    background-repeat: no-repeat;
	background-size: 20px;
	background-position: right center;
    background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg");
}

 .widget-dropdown > select:focus {
    border-color: #64B5F6;
}

 .widget-dropdown > select:disabled {
    opacity: 0.6;
}

 /* To disable the dotted border in Firefox around select controls.
   See http://stackoverflow.com/a/18853002 */

 .widget-dropdown > select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

 /* Select and SelectMultiple */

 .widget-select {
    width: 300px;
    line-height: 28px;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
}

 .widget-select > select {
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    outline: none !important;
    overflow: auto;
    height: inherit;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    padding-top: 5px;
}

 .widget-select > select:focus {
    border-color: #64B5F6;
}

 .wiget-select > select > option {
    padding-left: 4px;
    line-height: 28px;
    /* line-height doesn't work on some browsers for select options */
    padding-top: calc(28px - var(--jp-widgets-font-size) / 2);
    padding-bottom: calc(28px - var(--jp-widgets-font-size) / 2);
}

 /* Toggle Buttons Styling */

 .widget-toggle-buttons {
    line-height: 28px;
}

 .widget-toggle-buttons .widget-toggle-button {
    margin-left: 2px;
    margin-right: 2px;
}

 .widget-toggle-buttons .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Radio Buttons Styling */

 .widget-radio {
    width: 300px;
    line-height: 28px;
}

 .widget-radio-box {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-bottom: 8px;
}

 .widget-radio-box label {
    height: 20px;
    line-height: 20px;
    font-size: 13px;
}

 .widget-radio-box input {
    height: 20px;
    line-height: 20px;
    margin: 0 8px 0 1px;
    float: left;
}

 /* Color Picker Styling */

 .widget-colorpicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-colorpicker > .widget-colorpicker-input {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 72px;
}

 .widget-colorpicker input[type="color"] {
    width: 28px;
    height: 28px;
    padding: 0 2px; /* make the color square actually square on Chrome on OS X */
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    border-left: none;
    -webkit-box-flex: 0;
        -ms-flex-positive: 0;
            flex-grow: 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    outline: none !important;
}

 .widget-colorpicker.concise input[type="color"] {
    border-left: 1px solid #9E9E9E;
}

 .widget-colorpicker input[type="color"]:focus, .widget-colorpicker input[type="text"]:focus {
    border-color: #64B5F6;
}

 .widget-colorpicker input[type="text"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    outline: none !important;
    height: 28px;
    line-height: 28px;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    font-size: 13px;
    padding: 4px 8px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-colorpicker input[type="text"]:disabled {
    opacity: 0.6;
}

 /* Date Picker Styling */

 .widget-datepicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-datepicker input[type="date"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    outline: none !important;
    height: 28px;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-datepicker input[type="date"]:focus {
    border-color: #64B5F6;
}

 .widget-datepicker input[type="date"]:invalid {
    border-color: #FF9800;
}

 .widget-datepicker input[type="date"]:disabled {
    opacity: 0.6;
}

 /* Play Widget */

 .widget-play {
    width: 148px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .widget-play .jupyter-button {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    height: auto;
}

 .widget-play .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Tab Widget */

 .jupyter-widgets.widget-tab {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */
    overflow-x: visible;
    overflow-y: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
    /* Make sure that the tab grows from bottom up */
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    min-width: 0;
    min-height: 0;
}

 .jupyter-widgets.widget-tab > .widget-tab-contents {
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    margin: 0;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    padding: 15px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    overflow: auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    font: 13px Helvetica, Arial, sans-serif;
    min-height: 25px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 144px;
            flex: 0 1 144px;
    min-width: 35px;
    min-height: 25px;
    line-height: 24px;
    margin-left: -1px;
    padding: 0px 10px;
    background: #EEEEEE;
    color: rgba(0, 0, 0, .5);
    border: 1px solid #9E9E9E;
    border-bottom: none;
    position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {
    color: rgba(0, 0, 0, 1.0);
    /* We want the background to match the tab content background */
    background: white;
    min-height: 26px;
    -webkit-transform: translateY(1px);
            transform: translateY(1px);
    overflow: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {
    position: absolute;
    top: -1px;
    left: -1px;
    content: '';
    height: 2px;
    width: calc(100% + 2px);
    background: #2196F3;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {
    margin-left: 0;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {
    background: white;
    color: rgba(0, 0, 0, .8);
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {
    margin-left: 4px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {
    font-family: FontAwesome;
    content: '\f00d'; /* close */
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
    line-height: 24px;
}

 /* Accordion Widget */

 .p-Collapse {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Collapse-header {
    padding: 4px;
    cursor: pointer;
    color: rgba(0, 0, 0, .5);
    background-color: #EEEEEE;
    border: 1px solid #9E9E9E;
    padding: 10px 15px;
    font-weight: bold;
}

 .p-Collapse-header:hover {
    background-color: white;
    color: rgba(0, 0, 0, .8);
}

 .p-Collapse-open > .p-Collapse-header {
    background-color: white;
    color: rgba(0, 0, 0, 1.0);
    cursor: default;
    border-bottom: none;
}

 .p-Collapse .p-Collapse-header::before {
    content: '\f0da\00A0';  /* caret-right, non-breaking space */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .p-Collapse-open > .p-Collapse-header::before {
    content: '\f0d7\00A0'; /* caret-down, non-breaking space */
}

 .p-Collapse-contents {
    padding: 15px;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    border-left: 1px solid #9E9E9E;
    border-right: 1px solid #9E9E9E;
    border-bottom: 1px solid #9E9E9E;
    overflow: auto;
}

 .p-Accordion {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Accordion .p-Collapse {
    margin-bottom: 0;
}

 .p-Accordion .p-Collapse + .p-Collapse {
    margin-top: 4px;
}

 /* HTML widget */

 .widget-html, .widget-htmlmath {
    font-size: 13px;
}

 .widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {
    /* Fill out the area in the HTML widget */
    -ms-flex-item-align: stretch;
        align-self: stretch;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    /* Makes sure the baseline is still aligned with other elements */
    line-height: 28px;
    /* Make it possible to have absolutely-positioned elements in the html */
    position: relative;
}

/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../node_modules/@jupyter-widgets/controls/css/widgets.css","../node_modules/@jupyter-widgets/controls/css/labvariables.css","../node_modules/@jupyter-widgets/controls/css/materialcolors.css","../node_modules/@jupyter-widgets/controls/css/widgets-base.css","../node_modules/@jupyter-widgets/controls/css/phosphor.css"],"names":[],"mappings":"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","file":"controls.css","sourcesContent":["/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n /* We import all of these together in a single css file because the Webpack\nloader sees only one file at a time. This allows postcss to see the variable\ndefinitions when they are used. */\n\n@import \"./labvariables.css\";\n@import \"./widgets-base.css\";\n","/*-----------------------------------------------------------------------------\n| Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the Modified BSD License.\n|----------------------------------------------------------------------------*/\n\n/*\nThis file is copied from the JupyterLab project to define default styling for\nwhen the widget styling is compiled down to eliminate CSS variables. We make one\nchange - we comment out the font import below.\n*/\n\n@import \"./materialcolors.css\";\n\n/*\nThe following CSS variables define the main, public API for styling JupyterLab.\nThese variables should be used by all plugins wherever possible. In other\nwords, plugins should not define custom colors, sizes, etc unless absolutely\nnecessary. This enables users to change the visual theme of JupyterLab\nby changing these variables.\n\nMany variables appear in an ordered sequence (0,1,2,3). These sequences\nare designed to work well together, so for example, `--jp-border-color1` should\nbe used with `--jp-layout-color1`. The numbers have the following meanings:\n\n* 0: super-primary, reserved for special emphasis\n* 1: primary, most important under normal situations\n* 2: secondary, next most important under normal situations\n* 3: tertiary, next most important under normal situations\n\nThroughout JupyterLab, we are mostly following principles from Google's\nMaterial Design when selecting colors. We are not, however, following\nall of MD as it is not optimized for dense, information rich UIs.\n*/\n\n\n/*\n * Optional monospace font for input/output prompt.\n */\n /* Commented out in ipywidgets since we don't need it. */\n/* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */\n\n/*\n * Added for compabitility with output area\n */\n:root {\n  --jp-icon-search: none;\n  --jp-ui-select-caret: none;\n}\n\n\n:root {\n\n  /* Borders\n\n  The following variables, specify the visual styling of borders in JupyterLab.\n   */\n\n  --jp-border-width: 1px;\n  --jp-border-color0: var(--md-grey-700);\n  --jp-border-color1: var(--md-grey-500);\n  --jp-border-color2: var(--md-grey-300);\n  --jp-border-color3: var(--md-grey-100);\n\n  /* UI Fonts\n\n  The UI font CSS variables are used for the typography all of the JupyterLab\n  user interface elements that are not directly user generated content.\n  */\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n  --jp-ui-icon-font-size: 14px; /* Ensures px perfect FontAwesome icons */\n  --jp-ui-font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n\n  /* Use these font colors against the corresponding main layout colors.\n     In a light theme, these go from dark to light.\n  */\n\n  --jp-ui-font-color0: rgba(0,0,0,1.0);\n  --jp-ui-font-color1: rgba(0,0,0,0.8);\n  --jp-ui-font-color2: rgba(0,0,0,0.5);\n  --jp-ui-font-color3: rgba(0,0,0,0.3);\n\n  /* Use these against the brand/accent/warn/error colors.\n     These will typically go from light to darker, in both a dark and light theme\n   */\n\n  --jp-inverse-ui-font-color0: rgba(255,255,255,1);\n  --jp-inverse-ui-font-color1: rgba(255,255,255,1.0);\n  --jp-inverse-ui-font-color2: rgba(255,255,255,0.7);\n  --jp-inverse-ui-font-color3: rgba(255,255,255,0.5);\n\n  /* Content Fonts\n\n  Content font variables are used for typography of user generated content.\n  */\n\n  --jp-content-font-size: 13px;\n  --jp-content-line-height: 1.5;\n  --jp-content-font-color0: black;\n  --jp-content-font-color1: black;\n  --jp-content-font-color2: var(--md-grey-700);\n  --jp-content-font-color3: var(--md-grey-500);\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n\n  --jp-code-font-size: 13px;\n  --jp-code-line-height: 1.307;\n  --jp-code-padding: 5px;\n  --jp-code-font-family: monospace;\n\n\n  /* Layout\n\n  The following are the main layout colors use in JupyterLab. In a light\n  theme these would go from light to dark.\n  */\n\n  --jp-layout-color0: white;\n  --jp-layout-color1: white;\n  --jp-layout-color2: var(--md-grey-200);\n  --jp-layout-color3: var(--md-grey-400);\n\n  /* Brand/accent */\n\n  --jp-brand-color0: var(--md-blue-700);\n  --jp-brand-color1: var(--md-blue-500);\n  --jp-brand-color2: var(--md-blue-300);\n  --jp-brand-color3: var(--md-blue-100);\n\n  --jp-accent-color0: var(--md-green-700);\n  --jp-accent-color1: var(--md-green-500);\n  --jp-accent-color2: var(--md-green-300);\n  --jp-accent-color3: var(--md-green-100);\n\n  /* State colors (warn, error, success, info) */\n\n  --jp-warn-color0: var(--md-orange-700);\n  --jp-warn-color1: var(--md-orange-500);\n  --jp-warn-color2: var(--md-orange-300);\n  --jp-warn-color3: var(--md-orange-100);\n\n  --jp-error-color0: var(--md-red-700);\n  --jp-error-color1: var(--md-red-500);\n  --jp-error-color2: var(--md-red-300);\n  --jp-error-color3: var(--md-red-100);\n\n  --jp-success-color0: var(--md-green-700);\n  --jp-success-color1: var(--md-green-500);\n  --jp-success-color2: var(--md-green-300);\n  --jp-success-color3: var(--md-green-100);\n\n  --jp-info-color0: var(--md-cyan-700);\n  --jp-info-color1: var(--md-cyan-500);\n  --jp-info-color2: var(--md-cyan-300);\n  --jp-info-color3: var(--md-cyan-100);\n\n  /* Cell specific styles */\n\n  --jp-cell-padding: 5px;\n  --jp-cell-editor-background: #f7f7f7;\n  --jp-cell-editor-border-color: #cfcfcf;\n  --jp-cell-editor-background-edit: var(--jp-ui-layout-color1);\n  --jp-cell-editor-border-color-edit: var(--jp-brand-color1);\n  --jp-cell-prompt-width: 100px;\n  --jp-cell-prompt-font-family: 'Roboto Mono', monospace;\n  --jp-cell-prompt-letter-spacing: 0px;\n  --jp-cell-prompt-opacity: 1.0;\n  --jp-cell-prompt-opacity-not-active: 0.4;\n  --jp-cell-prompt-font-color-not-active: var(--md-grey-700);\n  /* A custom blend of MD grey and blue 600\n   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */\n  --jp-cell-inprompt-font-color: #307FC1;\n  /* A custom blend of MD grey and orange 600\n   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */\n  --jp-cell-outprompt-font-color: #BF5B3D;\n\n  /* Notebook specific styles */\n\n  --jp-notebook-padding: 10px;\n  --jp-notebook-scroll-padding: 100px;\n\n  /* Console specific styles */\n\n  --jp-console-background: var(--md-grey-100);\n\n  /* Toolbar specific styles */\n\n  --jp-toolbar-border-color: var(--md-grey-400);\n  --jp-toolbar-micro-height: 8px;\n  --jp-toolbar-background: var(--jp-layout-color0);\n  --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0,0,0,0.24);\n  --jp-toolbar-header-margin: 4px 4px 0px 4px;\n  --jp-toolbar-active-background: var(--md-grey-300);\n}\n","/**\n * The material design colors are adapted from google-material-color v1.2.6\n * https://github.com/danlevan/google-material-color\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css\n *\n * The license for the material design color CSS variables is as follows (see\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2014 Dan Le Van\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n:root {\n  --md-red-50: #FFEBEE;\n  --md-red-100: #FFCDD2;\n  --md-red-200: #EF9A9A;\n  --md-red-300: #E57373;\n  --md-red-400: #EF5350;\n  --md-red-500: #F44336;\n  --md-red-600: #E53935;\n  --md-red-700: #D32F2F;\n  --md-red-800: #C62828;\n  --md-red-900: #B71C1C;\n  --md-red-A100: #FF8A80;\n  --md-red-A200: #FF5252;\n  --md-red-A400: #FF1744;\n  --md-red-A700: #D50000;\n\n  --md-pink-50: #FCE4EC;\n  --md-pink-100: #F8BBD0;\n  --md-pink-200: #F48FB1;\n  --md-pink-300: #F06292;\n  --md-pink-400: #EC407A;\n  --md-pink-500: #E91E63;\n  --md-pink-600: #D81B60;\n  --md-pink-700: #C2185B;\n  --md-pink-800: #AD1457;\n  --md-pink-900: #880E4F;\n  --md-pink-A100: #FF80AB;\n  --md-pink-A200: #FF4081;\n  --md-pink-A400: #F50057;\n  --md-pink-A700: #C51162;\n\n  --md-purple-50: #F3E5F5;\n  --md-purple-100: #E1BEE7;\n  --md-purple-200: #CE93D8;\n  --md-purple-300: #BA68C8;\n  --md-purple-400: #AB47BC;\n  --md-purple-500: #9C27B0;\n  --md-purple-600: #8E24AA;\n  --md-purple-700: #7B1FA2;\n  --md-purple-800: #6A1B9A;\n  --md-purple-900: #4A148C;\n  --md-purple-A100: #EA80FC;\n  --md-purple-A200: #E040FB;\n  --md-purple-A400: #D500F9;\n  --md-purple-A700: #AA00FF;\n\n  --md-deep-purple-50: #EDE7F6;\n  --md-deep-purple-100: #D1C4E9;\n  --md-deep-purple-200: #B39DDB;\n  --md-deep-purple-300: #9575CD;\n  --md-deep-purple-400: #7E57C2;\n  --md-deep-purple-500: #673AB7;\n  --md-deep-purple-600: #5E35B1;\n  --md-deep-purple-700: #512DA8;\n  --md-deep-purple-800: #4527A0;\n  --md-deep-purple-900: #311B92;\n  --md-deep-purple-A100: #B388FF;\n  --md-deep-purple-A200: #7C4DFF;\n  --md-deep-purple-A400: #651FFF;\n  --md-deep-purple-A700: #6200EA;\n\n  --md-indigo-50: #E8EAF6;\n  --md-indigo-100: #C5CAE9;\n  --md-indigo-200: #9FA8DA;\n  --md-indigo-300: #7986CB;\n  --md-indigo-400: #5C6BC0;\n  --md-indigo-500: #3F51B5;\n  --md-indigo-600: #3949AB;\n  --md-indigo-700: #303F9F;\n  --md-indigo-800: #283593;\n  --md-indigo-900: #1A237E;\n  --md-indigo-A100: #8C9EFF;\n  --md-indigo-A200: #536DFE;\n  --md-indigo-A400: #3D5AFE;\n  --md-indigo-A700: #304FFE;\n\n  --md-blue-50: #E3F2FD;\n  --md-blue-100: #BBDEFB;\n  --md-blue-200: #90CAF9;\n  --md-blue-300: #64B5F6;\n  --md-blue-400: #42A5F5;\n  --md-blue-500: #2196F3;\n  --md-blue-600: #1E88E5;\n  --md-blue-700: #1976D2;\n  --md-blue-800: #1565C0;\n  --md-blue-900: #0D47A1;\n  --md-blue-A100: #82B1FF;\n  --md-blue-A200: #448AFF;\n  --md-blue-A400: #2979FF;\n  --md-blue-A700: #2962FF;\n\n  --md-light-blue-50: #E1F5FE;\n  --md-light-blue-100: #B3E5FC;\n  --md-light-blue-200: #81D4FA;\n  --md-light-blue-300: #4FC3F7;\n  --md-light-blue-400: #29B6F6;\n  --md-light-blue-500: #03A9F4;\n  --md-light-blue-600: #039BE5;\n  --md-light-blue-700: #0288D1;\n  --md-light-blue-800: #0277BD;\n  --md-light-blue-900: #01579B;\n  --md-light-blue-A100: #80D8FF;\n  --md-light-blue-A200: #40C4FF;\n  --md-light-blue-A400: #00B0FF;\n  --md-light-blue-A700: #0091EA;\n\n  --md-cyan-50: #E0F7FA;\n  --md-cyan-100: #B2EBF2;\n  --md-cyan-200: #80DEEA;\n  --md-cyan-300: #4DD0E1;\n  --md-cyan-400: #26C6DA;\n  --md-cyan-500: #00BCD4;\n  --md-cyan-600: #00ACC1;\n  --md-cyan-700: #0097A7;\n  --md-cyan-800: #00838F;\n  --md-cyan-900: #006064;\n  --md-cyan-A100: #84FFFF;\n  --md-cyan-A200: #18FFFF;\n  --md-cyan-A400: #00E5FF;\n  --md-cyan-A700: #00B8D4;\n\n  --md-teal-50: #E0F2F1;\n  --md-teal-100: #B2DFDB;\n  --md-teal-200: #80CBC4;\n  --md-teal-300: #4DB6AC;\n  --md-teal-400: #26A69A;\n  --md-teal-500: #009688;\n  --md-teal-600: #00897B;\n  --md-teal-700: #00796B;\n  --md-teal-800: #00695C;\n  --md-teal-900: #004D40;\n  --md-teal-A100: #A7FFEB;\n  --md-teal-A200: #64FFDA;\n  --md-teal-A400: #1DE9B6;\n  --md-teal-A700: #00BFA5;\n\n  --md-green-50: #E8F5E9;\n  --md-green-100: #C8E6C9;\n  --md-green-200: #A5D6A7;\n  --md-green-300: #81C784;\n  --md-green-400: #66BB6A;\n  --md-green-500: #4CAF50;\n  --md-green-600: #43A047;\n  --md-green-700: #388E3C;\n  --md-green-800: #2E7D32;\n  --md-green-900: #1B5E20;\n  --md-green-A100: #B9F6CA;\n  --md-green-A200: #69F0AE;\n  --md-green-A400: #00E676;\n  --md-green-A700: #00C853;\n\n  --md-light-green-50: #F1F8E9;\n  --md-light-green-100: #DCEDC8;\n  --md-light-green-200: #C5E1A5;\n  --md-light-green-300: #AED581;\n  --md-light-green-400: #9CCC65;\n  --md-light-green-500: #8BC34A;\n  --md-light-green-600: #7CB342;\n  --md-light-green-700: #689F38;\n  --md-light-green-800: #558B2F;\n  --md-light-green-900: #33691E;\n  --md-light-green-A100: #CCFF90;\n  --md-light-green-A200: #B2FF59;\n  --md-light-green-A400: #76FF03;\n  --md-light-green-A700: #64DD17;\n\n  --md-lime-50: #F9FBE7;\n  --md-lime-100: #F0F4C3;\n  --md-lime-200: #E6EE9C;\n  --md-lime-300: #DCE775;\n  --md-lime-400: #D4E157;\n  --md-lime-500: #CDDC39;\n  --md-lime-600: #C0CA33;\n  --md-lime-700: #AFB42B;\n  --md-lime-800: #9E9D24;\n  --md-lime-900: #827717;\n  --md-lime-A100: #F4FF81;\n  --md-lime-A200: #EEFF41;\n  --md-lime-A400: #C6FF00;\n  --md-lime-A700: #AEEA00;\n\n  --md-yellow-50: #FFFDE7;\n  --md-yellow-100: #FFF9C4;\n  --md-yellow-200: #FFF59D;\n  --md-yellow-300: #FFF176;\n  --md-yellow-400: #FFEE58;\n  --md-yellow-500: #FFEB3B;\n  --md-yellow-600: #FDD835;\n  --md-yellow-700: #FBC02D;\n  --md-yellow-800: #F9A825;\n  --md-yellow-900: #F57F17;\n  --md-yellow-A100: #FFFF8D;\n  --md-yellow-A200: #FFFF00;\n  --md-yellow-A400: #FFEA00;\n  --md-yellow-A700: #FFD600;\n\n  --md-amber-50: #FFF8E1;\n  --md-amber-100: #FFECB3;\n  --md-amber-200: #FFE082;\n  --md-amber-300: #FFD54F;\n  --md-amber-400: #FFCA28;\n  --md-amber-500: #FFC107;\n  --md-amber-600: #FFB300;\n  --md-amber-700: #FFA000;\n  --md-amber-800: #FF8F00;\n  --md-amber-900: #FF6F00;\n  --md-amber-A100: #FFE57F;\n  --md-amber-A200: #FFD740;\n  --md-amber-A400: #FFC400;\n  --md-amber-A700: #FFAB00;\n\n  --md-orange-50: #FFF3E0;\n  --md-orange-100: #FFE0B2;\n  --md-orange-200: #FFCC80;\n  --md-orange-300: #FFB74D;\n  --md-orange-400: #FFA726;\n  --md-orange-500: #FF9800;\n  --md-orange-600: #FB8C00;\n  --md-orange-700: #F57C00;\n  --md-orange-800: #EF6C00;\n  --md-orange-900: #E65100;\n  --md-orange-A100: #FFD180;\n  --md-orange-A200: #FFAB40;\n  --md-orange-A400: #FF9100;\n  --md-orange-A700: #FF6D00;\n\n  --md-deep-orange-50: #FBE9E7;\n  --md-deep-orange-100: #FFCCBC;\n  --md-deep-orange-200: #FFAB91;\n  --md-deep-orange-300: #FF8A65;\n  --md-deep-orange-400: #FF7043;\n  --md-deep-orange-500: #FF5722;\n  --md-deep-orange-600: #F4511E;\n  --md-deep-orange-700: #E64A19;\n  --md-deep-orange-800: #D84315;\n  --md-deep-orange-900: #BF360C;\n  --md-deep-orange-A100: #FF9E80;\n  --md-deep-orange-A200: #FF6E40;\n  --md-deep-orange-A400: #FF3D00;\n  --md-deep-orange-A700: #DD2C00;\n\n  --md-brown-50: #EFEBE9;\n  --md-brown-100: #D7CCC8;\n  --md-brown-200: #BCAAA4;\n  --md-brown-300: #A1887F;\n  --md-brown-400: #8D6E63;\n  --md-brown-500: #795548;\n  --md-brown-600: #6D4C41;\n  --md-brown-700: #5D4037;\n  --md-brown-800: #4E342E;\n  --md-brown-900: #3E2723;\n\n  --md-grey-50: #FAFAFA;\n  --md-grey-100: #F5F5F5;\n  --md-grey-200: #EEEEEE;\n  --md-grey-300: #E0E0E0;\n  --md-grey-400: #BDBDBD;\n  --md-grey-500: #9E9E9E;\n  --md-grey-600: #757575;\n  --md-grey-700: #616161;\n  --md-grey-800: #424242;\n  --md-grey-900: #212121;\n\n  --md-blue-grey-50: #ECEFF1;\n  --md-blue-grey-100: #CFD8DC;\n  --md-blue-grey-200: #B0BEC5;\n  --md-blue-grey-300: #90A4AE;\n  --md-blue-grey-400: #78909C;\n  --md-blue-grey-500: #607D8B;\n  --md-blue-grey-600: #546E7A;\n  --md-blue-grey-700: #455A64;\n  --md-blue-grey-800: #37474F;\n  --md-blue-grey-900: #263238;\n}","/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n/*\n * We assume that the CSS variables in\n * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css\n * have been defined.\n */\n\n@import \"./phosphor.css\";\n\n:root {\n    --jp-widgets-color: var(--jp-content-font-color1);\n    --jp-widgets-label-color: var(--jp-widgets-color);\n    --jp-widgets-readout-color: var(--jp-widgets-color);\n    --jp-widgets-font-size: var(--jp-ui-font-size1);\n    --jp-widgets-margin: 2px;\n    --jp-widgets-inline-height: 28px;\n    --jp-widgets-inline-width: 300px;\n    --jp-widgets-inline-width-short: calc(var(--jp-widgets-inline-width) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-width-tiny: calc(var(--jp-widgets-inline-width-short) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-margin: 4px; /* margin between inline elements */\n    --jp-widgets-inline-label-width: 80px;\n    --jp-widgets-border-width: var(--jp-border-width);\n    --jp-widgets-vertical-height: 200px;\n    --jp-widgets-horizontal-tab-height: 24px;\n    --jp-widgets-horizontal-tab-width: 144px;\n    --jp-widgets-horizontal-tab-top-border: 2px;\n    --jp-widgets-progress-thickness: 20px;\n    --jp-widgets-container-padding: 15px;\n    --jp-widgets-input-padding: 4px;\n    --jp-widgets-radio-item-height-adjustment: 8px;\n    --jp-widgets-radio-item-height: calc(var(--jp-widgets-inline-height) - var(--jp-widgets-radio-item-height-adjustment));\n    --jp-widgets-slider-track-thickness: 4px;\n    --jp-widgets-slider-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-slider-handle-size: 16px;\n    --jp-widgets-slider-handle-border-color: var(--jp-border-color1);\n    --jp-widgets-slider-handle-background-color: var(--jp-layout-color1);\n    --jp-widgets-slider-active-handle-color: var(--jp-brand-color1);\n    --jp-widgets-menu-item-height: 24px;\n    --jp-widgets-dropdown-arrow: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg\");\n    --jp-widgets-input-color: var(--jp-ui-font-color1);\n    --jp-widgets-input-background-color: var(--jp-layout-color1);\n    --jp-widgets-input-border-color: var(--jp-border-color1);\n    --jp-widgets-input-focus-border-color: var(--jp-brand-color2);\n    --jp-widgets-input-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-disabled-opacity: 0.6;\n\n    /* From Material Design Lite */\n    --md-shadow-key-umbra-opacity: 0.2;\n    --md-shadow-key-penumbra-opacity: 0.14;\n    --md-shadow-ambient-shadow-opacity: 0.12;\n}\n\n.jupyter-widgets {\n    margin: var(--jp-widgets-margin);\n    box-sizing: border-box;\n    color: var(--jp-widgets-color);\n    overflow: visible;\n}\n\n.jupyter-widgets.jupyter-widgets-disconnected::before {\n    line-height: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n}\n\n.jp-Output-result > .jupyter-widgets {\n    margin-left: 0;\n    margin-right: 0;\n}\n\n/* vbox and hbox */\n\n.widget-inline-hbox {\n    /* Horizontal widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: row;\n    align-items: baseline;\n}\n\n.widget-inline-vbox {\n    /* Vertical Widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n}\n\n.widget-box {\n    box-sizing: border-box;\n    display: flex;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-gridbox {\n    box-sizing: border-box;\n    display: grid;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-hbox {\n    flex-direction: row;\n}\n\n.widget-vbox {\n    flex-direction: column;\n}\n\n/* General Button Styling */\n\n.jupyter-button {\n    padding-left: 10px;\n    padding-right: 10px;\n    padding-top: 0px;\n    padding-bottom: 0px;\n    display: inline-block;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    text-align: center;\n    font-size: var(--jp-widgets-font-size);\n    cursor: pointer;\n\n    height: var(--jp-widgets-inline-height);\n    border: 0px solid;\n    line-height: var(--jp-widgets-inline-height);\n    box-shadow: none;\n\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color2);\n    border-color: var(--jp-border-color2);\n    border: none;\n}\n\n.jupyter-button i.fa {\n    margin-right: var(--jp-widgets-inline-margin);\n    pointer-events: none;\n}\n\n.jupyter-button:empty:before {\n    content: \"\\200b\"; /* zero-width space */\n}\n\n.jupyter-widgets.jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.jupyter-button i.fa.center {\n    margin-right: 0;\n}\n\n.jupyter-button:hover:enabled, .jupyter-button:focus:enabled {\n    /* MD Lite 2dp shadow */\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 3px 1px -2px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity)),\n                0 1px 5px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity));\n}\n\n.jupyter-button:active, .jupyter-button.mod-active {\n    /* MD Lite 4dp shadow */\n    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 1px 10px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity)),\n                0 2px 4px -1px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity));\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color3);\n}\n\n.jupyter-button:focus:enabled {\n    outline: 1px solid var(--jp-widgets-input-focus-border-color);\n}\n\n/* Button \"Primary\" Styling */\n\n.jupyter-button.mod-primary {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-brand-color1);\n}\n\n.jupyter-button.mod-primary.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n.jupyter-button.mod-primary:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n/* Button \"Success\" Styling */\n\n.jupyter-button.mod-success {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-success-color1);\n}\n\n.jupyter-button.mod-success.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n.jupyter-button.mod-success:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n /* Button \"Info\" Styling */\n\n.jupyter-button.mod-info {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-info-color1);\n}\n\n.jupyter-button.mod-info.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n.jupyter-button.mod-info:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n/* Button \"Warning\" Styling */\n\n.jupyter-button.mod-warning {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-warn-color1);\n}\n\n.jupyter-button.mod-warning.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n.jupyter-button.mod-warning:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n/* Button \"Danger\" Styling */\n\n.jupyter-button.mod-danger {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-error-color1);\n}\n\n.jupyter-button.mod-danger.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n.jupyter-button.mod-danger:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n/* Widget Button*/\n\n.widget-button, .widget-toggle-button {\n    width: var(--jp-widgets-inline-width-short);\n}\n\n/* Widget Label Styling */\n\n/* Override Bootstrap label css */\n.jupyter-widgets label {\n    margin-bottom: initial;\n}\n\n.widget-label-basic {\n    /* Basic Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-label {\n    /* Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-inline-hbox .widget-label {\n    /* Horizontal Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: right;\n    margin-right: calc( var(--jp-widgets-inline-margin) * 2 );\n    width: var(--jp-widgets-inline-label-width);\n    flex-shrink: 0;\n}\n\n.widget-inline-vbox .widget-label {\n    /* Vertical Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: center;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n/* Widget Readout Styling */\n\n.widget-readout {\n    color: var(--jp-widgets-readout-color);\n    font-size: var(--jp-widgets-font-size);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    overflow: hidden;\n    white-space: nowrap;\n    text-align: center;\n}\n\n.widget-readout.overflow {\n    /* Overflowing Readout */\n\n    /* From Material Design Lite\n        shadow-key-umbra-opacity: 0.2;\n        shadow-key-penumbra-opacity: 0.14;\n        shadow-ambient-shadow-opacity: 0.12;\n     */\n    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                        0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                        0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    -moz-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                     0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                     0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n\n.widget-inline-hbox .widget-readout {\n    /* Horizontal Readout */\n    text-align: center;\n    max-width: var(--jp-widgets-inline-width-short);\n    min-width: var(--jp-widgets-inline-width-tiny);\n    margin-left: var(--jp-widgets-inline-margin);\n}\n\n.widget-inline-vbox .widget-readout {\n    /* Vertical Readout */\n    margin-top: var(--jp-widgets-inline-margin);\n    /* as wide as the widget */\n    width: inherit;\n}\n\n/* Widget Checkbox Styling */\n\n.widget-checkbox {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-checkbox input[type=\"checkbox\"] {\n    margin: 0px calc( var(--jp-widgets-inline-margin) * 2 ) 0px 0px;\n    line-height: var(--jp-widgets-inline-height);\n    font-size: large;\n    flex-grow: 1;\n    flex-shrink: 0;\n    align-self: center;\n}\n\n/* Widget Valid Styling */\n\n.widget-valid {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width-short);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-valid i:before {\n    line-height: var(--jp-widgets-inline-height);\n    margin-right: var(--jp-widgets-inline-margin);\n    margin-left: var(--jp-widgets-inline-margin);\n\n    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.widget-valid.mod-valid i:before {\n    content: \"\\f00c\";\n    color: green;\n}\n\n.widget-valid.mod-invalid i:before {\n    content: \"\\f00d\";\n    color: red;\n}\n\n.widget-valid.mod-valid .widget-valid-readout {\n    display: none;\n}\n\n/* Widget Text and TextArea Stying */\n\n.widget-textarea, .widget-text {\n    width: var(--jp-widgets-inline-width);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"]{\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-text input[type=\"text\"]:disabled, .widget-text input[type=\"number\"]:disabled, .widget-textarea textarea:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"], .widget-textarea textarea {\n    box-sizing: border-box;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    flex-grow: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    outline: none !important;\n}\n\n.widget-textarea textarea {\n    height: inherit;\n    width: inherit;\n}\n\n.widget-text input:focus, .widget-textarea textarea:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n/* Widget Slider */\n\n.widget-slider .ui-slider {\n    /* Slider Track */\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-layout-color3);\n    background: var(--jp-layout-color3);\n    box-sizing: border-box;\n    position: relative;\n    border-radius: 0px;\n}\n\n.widget-slider .ui-slider .ui-slider-handle {\n    /* Slider Handle */\n    outline: none !important; /* focused slider handles are colored - see below */\n    position: absolute;\n    background-color: var(--jp-widgets-slider-handle-background-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-handle-border-color);\n    box-sizing: border-box;\n    z-index: 1;\n    background-image: none; /* Override jquery-ui */\n}\n\n/* Override jquery-ui */\n.widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-active-handle-color);\n}\n\n.widget-slider .ui-slider .ui-slider-handle:active {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border-color: var(--jp-widgets-slider-active-handle-color);\n    z-index: 2;\n    transform: scale(1.2);\n}\n\n.widget-slider  .ui-slider .ui-slider-range {\n    /* Interval between the two specified value of a double slider */\n    position: absolute;\n    background: var(--jp-widgets-slider-active-handle-color);\n    z-index: 0;\n}\n\n/* Shapes of Slider Handles */\n\n.widget-hslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    top: 0;\n}\n\n.widget-vslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    left: 0;\n}\n\n.widget-hslider .ui-slider .ui-slider-range {\n    height: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n.widget-vslider .ui-slider .ui-slider-range {\n    width: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n/* Horizontal Slider */\n\n.widget-hslider {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Override the align-items baseline. This way, the description and readout\n    still seem to align their baseline properly, and we don't have to have\n    align-self: stretch in the .slider-container. */\n    align-items: center;\n}\n\n.widgets-slider .slider-container {\n    overflow: visible;\n}\n\n.widget-hslider .slider-container {\n    height: var(--jp-widgets-inline-height);\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-right: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n}\n\n.widget-hslider .ui-slider {\n    /* Inner, invisible slide div */\n    height: var(--jp-widgets-slider-track-thickness);\n    margin-top: calc((var(--jp-widgets-inline-height) - var(--jp-widgets-slider-track-thickness)) / 2);\n    width: 100%;\n}\n\n/* Vertical Slider */\n\n.widget-vbox .widget-label {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-vslider {\n    /* Vertical Slider */\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vslider .slider-container {\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-top: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    display: flex;\n    flex-direction: column;\n}\n\n.widget-vslider .ui-slider-vertical {\n    /* Inner, invisible slide div */\n    width: var(--jp-widgets-slider-track-thickness);\n    flex-grow: 1;\n    margin-left: auto;\n    margin-right: auto;\n}\n\n/* Widget Progress Styling */\n\n.progress-bar {\n    -webkit-transition: none;\n    -moz-transition: none;\n    -ms-transition: none;\n    -o-transition: none;\n    transition: none;\n}\n\n.progress-bar {\n    height: var(--jp-widgets-inline-height);\n}\n\n.progress-bar {\n    background-color: var(--jp-brand-color1);\n}\n\n.progress-bar-success {\n    background-color: var(--jp-success-color1);\n}\n\n.progress-bar-info {\n    background-color: var(--jp-info-color1);\n}\n\n.progress-bar-warning {\n    background-color: var(--jp-warn-color1);\n}\n\n.progress-bar-danger {\n    background-color: var(--jp-error-color1);\n}\n\n.progress {\n    background-color: var(--jp-layout-color2);\n    border: none;\n    box-shadow: none;\n}\n\n/* Horisontal Progress */\n\n.widget-hprogress {\n    /* Progress Bar */\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    align-items: center;\n\n}\n\n.widget-hprogress .progress {\n    flex-grow: 1;\n    margin-top: var(--jp-widgets-input-padding);\n    margin-bottom: var(--jp-widgets-input-padding);\n    align-self: stretch;\n    /* Override bootstrap style */\n    height: initial;\n}\n\n/* Vertical Progress */\n\n.widget-vprogress {\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vprogress .progress {\n    flex-grow: 1;\n    width: var(--jp-widgets-progress-thickness);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: 0;\n}\n\n/* Select Widget Styling */\n\n.widget-dropdown {\n    height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-dropdown > select {\n    padding-right: 20px;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-radius: 0;\n    height: inherit;\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    box-sizing: border-box;\n    outline: none !important;\n    box-shadow: none;\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    vertical-align: top;\n    padding-left: calc( var(--jp-widgets-input-padding) * 2);\n\tappearance: none;\n\t-webkit-appearance: none;\n\t-moz-appearance: none;\n    background-repeat: no-repeat;\n\tbackground-size: 20px;\n\tbackground-position: right center;\n    background-image: var(--jp-widgets-dropdown-arrow);\n}\n.widget-dropdown > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-dropdown > select:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* To disable the dotted border in Firefox around select controls.\n   See http://stackoverflow.com/a/18853002 */\n.widget-dropdown > select:-moz-focusring {\n    color: transparent;\n    text-shadow: 0 0 0 #000;\n}\n\n/* Select and SelectMultiple */\n\n.widget-select {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    align-items: flex-start;\n}\n\n.widget-select > select {\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    outline: none !important;\n    overflow: auto;\n    height: inherit;\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    padding-top: 5px;\n}\n\n.widget-select > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.wiget-select > select > option {\n    padding-left: var(--jp-widgets-input-padding);\n    line-height: var(--jp-widgets-inline-height);\n    /* line-height doesn't work on some browsers for select options */\n    padding-top: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n    padding-bottom: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n}\n\n\n\n/* Toggle Buttons Styling */\n\n.widget-toggle-buttons {\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-toggle-buttons .widget-toggle-button {\n    margin-left: var(--jp-widgets-margin);\n    margin-right: var(--jp-widgets-margin);\n}\n\n.widget-toggle-buttons .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Radio Buttons Styling */\n\n.widget-radio {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-radio-box {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n    box-sizing: border-box;\n    flex-grow: 1;\n    margin-bottom: var(--jp-widgets-radio-item-height-adjustment);\n}\n\n.widget-radio-box label {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-radio-box input {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    margin: 0 calc( var(--jp-widgets-input-padding) * 2 ) 0 1px;\n    float: left;\n}\n\n/* Color Picker Styling */\n\n.widget-colorpicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-colorpicker > .widget-colorpicker-input {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-colorpicker input[type=\"color\"] {\n    width: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n    padding: 0 2px; /* make the color square actually square on Chrome on OS X */\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-left: none;\n    flex-grow: 0;\n    flex-shrink: 0;\n    box-sizing: border-box;\n    align-self: stretch;\n    outline: none !important;\n}\n\n.widget-colorpicker.concise input[type=\"color\"] {\n    border-left: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n}\n\n.widget-colorpicker input[type=\"color\"]:focus, .widget-colorpicker input[type=\"text\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-colorpicker input[type=\"text\"] {\n    flex-grow: 1;\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    box-sizing: border-box;\n}\n\n.widget-colorpicker input[type=\"text\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Date Picker Styling */\n\n.widget-datepicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-datepicker input[type=\"date\"] {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    box-sizing: border-box;\n}\n\n.widget-datepicker input[type=\"date\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-datepicker input[type=\"date\"]:invalid {\n    border-color: var(--jp-warn-color1);\n}\n\n.widget-datepicker input[type=\"date\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Play Widget */\n\n.widget-play {\n    width: var(--jp-widgets-inline-width-short);\n    display: flex;\n    align-items: stretch;\n}\n\n.widget-play .jupyter-button {\n    flex-grow: 1;\n    height: auto;\n}\n\n.widget-play .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Tab Widget */\n\n.jupyter-widgets.widget-tab {\n    display: flex;\n    flex-direction: column;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */\n    overflow-x: visible;\n    overflow-y: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n    /* Make sure that the tab grows from bottom up */\n    align-items: flex-end;\n    min-width: 0;\n    min-height: 0;\n}\n\n.jupyter-widgets.widget-tab > .widget-tab-contents {\n    width: 100%;\n    box-sizing: border-box;\n    margin: 0;\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    padding: var(--jp-widgets-container-padding);\n    flex-grow: 1;\n    overflow: auto;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    font: var(--jp-widgets-font-size) Helvetica, Arial, sans-serif;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n    flex: 0 1 var(--jp-widgets-horizontal-tab-width);\n    min-width: 35px;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n    line-height: var(--jp-widgets-horizontal-tab-height);\n    margin-left: calc(-1 * var(--jp-border-width));\n    padding: 0px 10px;\n    background: var(--jp-layout-color2);\n    color: var(--jp-ui-font-color2);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    border-bottom: none;\n    position: relative;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {\n    color: var(--jp-ui-font-color0);\n    /* We want the background to match the tab content background */\n    background: var(--jp-layout-color1);\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + 2 * var(--jp-border-width));\n    transform: translateY(var(--jp-border-width));\n    overflow: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {\n    position: absolute;\n    top: calc(-1 * var(--jp-border-width));\n    left: calc(-1 * var(--jp-border-width));\n    content: '';\n    height: var(--jp-widgets-horizontal-tab-top-border);\n    width: calc(100% + 2 * var(--jp-border-width));\n    background: var(--jp-brand-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {\n    margin-left: 0;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {\n    margin-left: 4px;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {\n    font-family: FontAwesome;\n    content: '\\f00d'; /* close */\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n    line-height: var(--jp-widgets-horizontal-tab-height);\n}\n\n/* Accordion Widget */\n\n.p-Collapse {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Collapse-header {\n    padding: var(--jp-widgets-input-padding);\n    cursor: pointer;\n    color: var(--jp-ui-font-color2);\n    background-color: var(--jp-layout-color2);\n    border: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    padding: calc(var(--jp-widgets-container-padding) * 2 / 3) var(--jp-widgets-container-padding);\n    font-weight: bold;\n}\n\n.p-Collapse-header:hover {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.p-Collapse-open > .p-Collapse-header {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color0);\n    cursor: default;\n    border-bottom: none;\n}\n\n.p-Collapse .p-Collapse-header::before {\n    content: '\\f0da\\00A0';  /* caret-right, non-breaking space */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.p-Collapse-open > .p-Collapse-header::before {\n    content: '\\f0d7\\00A0'; /* caret-down, non-breaking space */\n}\n\n.p-Collapse-contents {\n    padding: var(--jp-widgets-container-padding);\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border-left: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-right: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-bottom: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    overflow: auto;\n}\n\n.p-Accordion {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Accordion .p-Collapse {\n    margin-bottom: 0;\n}\n\n.p-Accordion .p-Collapse + .p-Collapse {\n    margin-top: 4px;\n}\n\n\n\n/* HTML widget */\n\n.widget-html, .widget-htmlmath {\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {\n    /* Fill out the area in the HTML widget */\n    align-self: stretch;\n    flex-grow: 1;\n    flex-shrink: 1;\n    /* Makes sure the baseline is still aligned with other elements */\n    line-height: var(--jp-widgets-inline-height);\n    /* Make it possible to have absolutely-positioned elements in the html */\n    position: relative;\n}\n","/* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:\n\nCopyright (c) 2014-2017, PhosphorJS Contributors\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n  list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n  this list of conditions and the following disclaimer in the documentation\n  and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n  contributors may be used to endorse or promote products derived from\n  this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n*/\n\n/*\n * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css \n * We've scoped the rules so that they are consistent with exactly our code.\n */\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n  display: flex;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex: 1 1 auto;\n  list-style-type: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n  flex: 0 0 auto;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {\n  flex: 1 1 auto;\n  overflow: hidden;\n  white-space: nowrap;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {\n  display: none !important;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {\n  position: relative;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {\n  left: 0;\n  transition: left 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {\n  top: 0;\n  transition: top 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {\n  transition: none;\n}\n\n/* End tabbar.css */\n"]} */", "headers": [ [ "content-type", "text/css" ] ], "ok": true, "status": 200, "status_text": "" } } }, "colab_type": "code", "id": "QY3pa2CNKFRb", "outputId": "63aa0602-de63-4376-f1d4-b204aff12d5f" }, "outputs": [ { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "6a2442a2e4344f059d0af9b471805be6", "version_major": 2, "version_minor": 0 }, "text/plain": [ "HBox(children=(IntProgress(value=0, description='0/1(t)', max=1, style=ProgressStyle(description_width='initia…" ] }, "metadata": {}, "output_type": "display_data" }, { "name": "stdout", "output_type": "stream", "text": [ "{x: tensor([[1.]]), a_key: 'test'}\n", "\n" ] } ], "source": [ "import torch\n", "import torch.nn as nn\n", "\n", "from torchbearer.callbacks import UnpackState\n", "from torchbearer import Trial\n", "\n", "class TestModel(nn.Module):\n", " def forward(self, x):\n", " print(str(x).replace('\\n', ''))\n", " return x\n", " \n", "unpacker = UnpackState(keys=[torchbearer.X, A_KEY])\n", "\n", "t = Trial(TestModel(), callbacks=[unpacker])\n", "t.state[A_KEY] = 'test'\n", "_ = t.with_train_data(torch.ones(10, 1), torch.ones(10, 1), batch_size=1, steps=1).run()" ] }, { "cell_type": "markdown", "metadata": { "colab_type": "text", "id": "YtbpgdbpLv62" }, "source": [ "Often when models interact with state they want to interact with it in some way, by adding values or modifying existing ones. The UnpackState callback allows this by updating the main state based on the model output. When a model returns a dictionary which includes a torchbearer.Y_PRED key, the the state dictionary will be automatically updated based on this output. \n", "\n", "We demonstrate this below by printing a previously unpopulated value in state after a model forward pass. " ] }, { "cell_type": "code", "execution_count": 3, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 85, "resources": { "http://localhost:8080/nbextensions/google.colab/colabwidgets/controls.css": { "data": "/* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /* We import all of these together in a single css file because the Webpack
loader sees only one file at a time. This allows postcss to see the variable
definitions when they are used. */

 /*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

 /*
This file is copied from the JupyterLab project to define default styling for
when the widget styling is compiled down to eliminate CSS variables. We make one
change - we comment out the font import below.
*/

 /**
 * The material design colors are adapted from google-material-color v1.2.6
 * https://github.com/danlevan/google-material-color
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css
 *
 * The license for the material design color CSS variables is as follows (see
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)
 *
 * The MIT License (MIT)
 *
 * Copyright (c) 2014 Dan Le Van
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

 /*
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.
*/

 /*
 * Optional monospace font for input/output prompt.
 */

 /* Commented out in ipywidgets since we don't need it. */

 /* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */

 /*
 * Added for compabitility with output area
 */

 :root {

  /* Borders

  The following variables, specify the visual styling of borders in JupyterLab.
   */

  /* 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.
  */ /* Base font size */ /* Ensures px perfect FontAwesome icons */

  /* Use these font colors against the corresponding main layout colors.
     In a light theme, these go from dark to light.
  */

  /* Use these against the brand/accent/warn/error colors.
     These will typically go from light to darker, in both a dark and light theme
   */

  /* Content Fonts

  Content font variables are used for typography of user generated content.
  */ /* Base font size */


  /* Layout

  The following are the main layout colors use in JupyterLab. In a light
  theme these would go from light to dark.
  */

  /* Brand/accent */

  /* State colors (warn, error, success, info) */

  /* Cell specific styles */
  /* A custom blend of MD grey and blue 600
   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
  /* A custom blend of MD grey and orange 600
   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */

  /* Notebook specific styles */

  /* Console specific styles */

  /* Toolbar specific styles */
}

 /* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /*
 * We assume that the CSS variables in
 * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css
 * have been defined.
 */

 /* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:

Copyright (c) 2014-2017, PhosphorJS Contributors
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

* Neither the name of the copyright holder nor the names of its
  contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

*/

 /*
 * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css 
 * We've scoped the rules so that they are consistent with exactly our code.
 */

 .jupyter-widgets.widget-tab > .p-TabBar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  list-style-type: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
  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-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  overflow: hidden;
  white-space: nowrap;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {
  display: none !important;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {
  position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {
  left: 0;
  -webkit-transition: left 150ms ease;
  transition: left 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {
  top: 0;
  -webkit-transition: top 150ms ease;
  transition: top 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {
  -webkit-transition: none;
  transition: none;
}

 /* End tabbar.css */

 :root { /* margin between inline elements */

    /* From Material Design Lite */
}

 .jupyter-widgets {
    margin: 2px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    color: black;
    overflow: visible;
}

 .jupyter-widgets.jupyter-widgets-disconnected::before {
    line-height: 28px;
    height: 28px;
}

 .jp-Output-result > .jupyter-widgets {
    margin-left: 0;
    margin-right: 0;
}

 /* vbox and hbox */

 .widget-inline-hbox {
    /* Horizontal widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
}

 .widget-inline-vbox {
    /* Vertical Widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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;
}

 .widget-box {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    overflow: auto;
}

 .widget-gridbox {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: grid;
    margin: 0;
    overflow: auto;
}

 .widget-hbox {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
}

 .widget-vbox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 /* General Button Styling */

 .jupyter-button {
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 0px;
    padding-bottom: 0px;
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
    font-size: 13px;
    cursor: pointer;

    height: 28px;
    border: 0px solid;
    line-height: 28px;
    -webkit-box-shadow: none;
            box-shadow: none;

    color: rgba(0, 0, 0, .8);
    background-color: #EEEEEE;
    border-color: #E0E0E0;
    border: none;
}

 .jupyter-button i.fa {
    margin-right: 4px;
    pointer-events: none;
}

 .jupyter-button:empty:before {
    content: "\200b"; /* zero-width space */
}

 .jupyter-widgets.jupyter-button:disabled {
    opacity: 0.6;
}

 .jupyter-button i.fa.center {
    margin-right: 0;
}

 .jupyter-button:hover:enabled, .jupyter-button:focus:enabled {
    /* MD Lite 2dp shadow */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
            box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .jupyter-button:active, .jupyter-button.mod-active {
    /* MD Lite 4dp shadow */
    -webkit-box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
            box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
    color: rgba(0, 0, 0, .8);
    background-color: #BDBDBD;
}

 .jupyter-button:focus:enabled {
    outline: 1px solid #64B5F6;
}

 /* Button "Primary" Styling */

 .jupyter-button.mod-primary {
    color: rgba(255, 255, 255, 1.0);
    background-color: #2196F3;
}

 .jupyter-button.mod-primary.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 .jupyter-button.mod-primary:active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 /* Button "Success" Styling */

 .jupyter-button.mod-success {
    color: rgba(255, 255, 255, 1.0);
    background-color: #4CAF50;
}

 .jupyter-button.mod-success.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 .jupyter-button.mod-success:active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 /* Button "Info" Styling */

 .jupyter-button.mod-info {
    color: rgba(255, 255, 255, 1.0);
    background-color: #00BCD4;
}

 .jupyter-button.mod-info.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 .jupyter-button.mod-info:active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 /* Button "Warning" Styling */

 .jupyter-button.mod-warning {
    color: rgba(255, 255, 255, 1.0);
    background-color: #FF9800;
}

 .jupyter-button.mod-warning.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 .jupyter-button.mod-warning:active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 /* Button "Danger" Styling */

 .jupyter-button.mod-danger {
    color: rgba(255, 255, 255, 1.0);
    background-color: #F44336;
}

 .jupyter-button.mod-danger.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 .jupyter-button.mod-danger:active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 /* Widget Button*/

 .widget-button, .widget-toggle-button {
    width: 148px;
}

 /* Widget Label Styling */

 /* Override Bootstrap label css */

 .jupyter-widgets label {
    margin-bottom: 0;
    margin-bottom: initial;
}

 .widget-label-basic {
    /* Basic Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-label {
    /* Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-inline-hbox .widget-label {
    /* Horizontal Widget Label */
    color: black;
    text-align: right;
    margin-right: 8px;
    width: 80px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
}

 .widget-inline-vbox .widget-label {
    /* Vertical Widget Label */
    color: black;
    text-align: center;
    line-height: 28px;
}

 /* Widget Readout Styling */

 .widget-readout {
    color: black;
    font-size: 13px;
    height: 28px;
    line-height: 28px;
    overflow: hidden;
    white-space: nowrap;
    text-align: center;
}

 .widget-readout.overflow {
    /* Overflowing Readout */

    /* From Material Design Lite
        shadow-key-umbra-opacity: 0.2;
        shadow-key-penumbra-opacity: 0.14;
        shadow-ambient-shadow-opacity: 0.12;
     */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                        0 3px 1px -2px rgba(0, 0, 0, .14),
                        0 1px 5px 0 rgba(0, 0, 0, .12);

    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                0 3px 1px -2px rgba(0, 0, 0, .14),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .widget-inline-hbox .widget-readout {
    /* Horizontal Readout */
    text-align: center;
    max-width: 148px;
    min-width: 72px;
    margin-left: 4px;
}

 .widget-inline-vbox .widget-readout {
    /* Vertical Readout */
    margin-top: 4px;
    /* as wide as the widget */
    width: inherit;
}

 /* Widget Checkbox Styling */

 .widget-checkbox {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-checkbox input[type="checkbox"] {
    margin: 0px 8px 0px 0px;
    line-height: 28px;
    font-size: large;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-item-align: center;
        align-self: center;
}

 /* Widget Valid Styling */

 .widget-valid {
    height: 28px;
    line-height: 28px;
    width: 148px;
    font-size: 13px;
}

 .widget-valid i:before {
    line-height: 28px;
    margin-right: 4px;
    margin-left: 4px;

    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .widget-valid.mod-valid i:before {
    content: "\f00c";
    color: green;
}

 .widget-valid.mod-invalid i:before {
    content: "\f00d";
    color: red;
}

 .widget-valid.mod-valid .widget-valid-readout {
    display: none;
}

 /* Widget Text and TextArea Stying */

 .widget-textarea, .widget-text {
    width: 300px;
}

 .widget-text input[type="text"], .widget-text input[type="number"]{
    height: 28px;
    line-height: 28px;
}

 .widget-text input[type="text"]:disabled, .widget-text input[type="number"]:disabled, .widget-textarea textarea:disabled {
    opacity: 0.6;
}

 .widget-text input[type="text"], .widget-text input[type="number"], .widget-textarea textarea {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    outline: none !important;
}

 .widget-textarea textarea {
    height: inherit;
    width: inherit;
}

 .widget-text input:focus, .widget-textarea textarea:focus {
    border-color: #64B5F6;
}

 /* Widget Slider */

 .widget-slider .ui-slider {
    /* Slider Track */
    border: 1px solid #BDBDBD;
    background: #BDBDBD;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    border-radius: 0px;
}

 .widget-slider .ui-slider .ui-slider-handle {
    /* Slider Handle */
    outline: none !important; /* focused slider handles are colored - see below */
    position: absolute;
    background-color: white;
    border: 1px solid #9E9E9E;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    z-index: 1;
    background-image: none; /* Override jquery-ui */
}

 /* Override jquery-ui */

 .widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {
    background-color: #2196F3;
    border: 1px solid #2196F3;
}

 .widget-slider .ui-slider .ui-slider-handle:active {
    background-color: #2196F3;
    border-color: #2196F3;
    z-index: 2;
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
}

 .widget-slider  .ui-slider .ui-slider-range {
    /* Interval between the two specified value of a double slider */
    position: absolute;
    background: #2196F3;
    z-index: 0;
}

 /* Shapes of Slider Handles */

 .widget-hslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-top: -7px;
    margin-left: -7px;
    border-radius: 50%;
    top: 0;
}

 .widget-vslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-bottom: -7px;
    margin-left: -7px;
    border-radius: 50%;
    left: 0;
}

 .widget-hslider .ui-slider .ui-slider-range {
    height: 8px;
    margin-top: -3px;
}

 .widget-vslider .ui-slider .ui-slider-range {
    width: 8px;
    margin-left: -3px;
}

 /* Horizontal Slider */

 .widget-hslider {
    width: 300px;
    height: 28px;
    line-height: 28px;

    /* Override the align-items baseline. This way, the description and readout
    still seem to align their baseline properly, and we don't have to have
    align-self: stretch in the .slider-container. */
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

 .widgets-slider .slider-container {
    overflow: visible;
}

 .widget-hslider .slider-container {
    height: 28px;
    margin-left: 6px;
    margin-right: 6px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
}

 .widget-hslider .ui-slider {
    /* Inner, invisible slide div */
    height: 4px;
    margin-top: 12px;
    width: 100%;
}

 /* Vertical Slider */

 .widget-vbox .widget-label {
    height: 28px;
    line-height: 28px;
}

 .widget-vslider {
    /* Vertical Slider */
    height: 200px;
    width: 72px;
}

 .widget-vslider .slider-container {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 6px;
    margin-top: 6px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .widget-vslider .ui-slider-vertical {
    /* Inner, invisible slide div */
    width: 4px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-left: auto;
    margin-right: auto;
}

 /* Widget Progress Styling */

 .progress-bar {
    -webkit-transition: none;
    transition: none;
}

 .progress-bar {
    height: 28px;
}

 .progress-bar {
    background-color: #2196F3;
}

 .progress-bar-success {
    background-color: #4CAF50;
}

 .progress-bar-info {
    background-color: #00BCD4;
}

 .progress-bar-warning {
    background-color: #FF9800;
}

 .progress-bar-danger {
    background-color: #F44336;
}

 .progress {
    background-color: #EEEEEE;
    border: none;
    -webkit-box-shadow: none;
            box-shadow: none;
}

 /* Horisontal Progress */

 .widget-hprogress {
    /* Progress Bar */
    height: 28px;
    line-height: 28px;
    width: 300px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;

}

 .widget-hprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-top: 4px;
    margin-bottom: 4px;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    /* Override bootstrap style */
    height: auto;
    height: initial;
}

 /* Vertical Progress */

 .widget-vprogress {
    height: 200px;
    width: 72px;
}

 .widget-vprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    width: 20px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;
}

 /* Select Widget Styling */

 .widget-dropdown {
    height: 28px;
    width: 300px;
    line-height: 28px;
}

 .widget-dropdown > select {
    padding-right: 20px;
    border: 1px solid #9E9E9E;
    border-radius: 0;
    height: inherit;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    outline: none !important;
    -webkit-box-shadow: none;
            box-shadow: none;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    vertical-align: top;
    padding-left: 8px;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
    background-repeat: no-repeat;
	background-size: 20px;
	background-position: right center;
    background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg");
}

 .widget-dropdown > select:focus {
    border-color: #64B5F6;
}

 .widget-dropdown > select:disabled {
    opacity: 0.6;
}

 /* To disable the dotted border in Firefox around select controls.
   See http://stackoverflow.com/a/18853002 */

 .widget-dropdown > select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

 /* Select and SelectMultiple */

 .widget-select {
    width: 300px;
    line-height: 28px;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
}

 .widget-select > select {
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    outline: none !important;
    overflow: auto;
    height: inherit;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    padding-top: 5px;
}

 .widget-select > select:focus {
    border-color: #64B5F6;
}

 .wiget-select > select > option {
    padding-left: 4px;
    line-height: 28px;
    /* line-height doesn't work on some browsers for select options */
    padding-top: calc(28px - var(--jp-widgets-font-size) / 2);
    padding-bottom: calc(28px - var(--jp-widgets-font-size) / 2);
}

 /* Toggle Buttons Styling */

 .widget-toggle-buttons {
    line-height: 28px;
}

 .widget-toggle-buttons .widget-toggle-button {
    margin-left: 2px;
    margin-right: 2px;
}

 .widget-toggle-buttons .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Radio Buttons Styling */

 .widget-radio {
    width: 300px;
    line-height: 28px;
}

 .widget-radio-box {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-bottom: 8px;
}

 .widget-radio-box label {
    height: 20px;
    line-height: 20px;
    font-size: 13px;
}

 .widget-radio-box input {
    height: 20px;
    line-height: 20px;
    margin: 0 8px 0 1px;
    float: left;
}

 /* Color Picker Styling */

 .widget-colorpicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-colorpicker > .widget-colorpicker-input {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 72px;
}

 .widget-colorpicker input[type="color"] {
    width: 28px;
    height: 28px;
    padding: 0 2px; /* make the color square actually square on Chrome on OS X */
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    border-left: none;
    -webkit-box-flex: 0;
        -ms-flex-positive: 0;
            flex-grow: 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    outline: none !important;
}

 .widget-colorpicker.concise input[type="color"] {
    border-left: 1px solid #9E9E9E;
}

 .widget-colorpicker input[type="color"]:focus, .widget-colorpicker input[type="text"]:focus {
    border-color: #64B5F6;
}

 .widget-colorpicker input[type="text"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    outline: none !important;
    height: 28px;
    line-height: 28px;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    font-size: 13px;
    padding: 4px 8px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-colorpicker input[type="text"]:disabled {
    opacity: 0.6;
}

 /* Date Picker Styling */

 .widget-datepicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-datepicker input[type="date"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    outline: none !important;
    height: 28px;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-datepicker input[type="date"]:focus {
    border-color: #64B5F6;
}

 .widget-datepicker input[type="date"]:invalid {
    border-color: #FF9800;
}

 .widget-datepicker input[type="date"]:disabled {
    opacity: 0.6;
}

 /* Play Widget */

 .widget-play {
    width: 148px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .widget-play .jupyter-button {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    height: auto;
}

 .widget-play .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Tab Widget */

 .jupyter-widgets.widget-tab {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */
    overflow-x: visible;
    overflow-y: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
    /* Make sure that the tab grows from bottom up */
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    min-width: 0;
    min-height: 0;
}

 .jupyter-widgets.widget-tab > .widget-tab-contents {
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    margin: 0;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    padding: 15px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    overflow: auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    font: 13px Helvetica, Arial, sans-serif;
    min-height: 25px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 144px;
            flex: 0 1 144px;
    min-width: 35px;
    min-height: 25px;
    line-height: 24px;
    margin-left: -1px;
    padding: 0px 10px;
    background: #EEEEEE;
    color: rgba(0, 0, 0, .5);
    border: 1px solid #9E9E9E;
    border-bottom: none;
    position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {
    color: rgba(0, 0, 0, 1.0);
    /* We want the background to match the tab content background */
    background: white;
    min-height: 26px;
    -webkit-transform: translateY(1px);
            transform: translateY(1px);
    overflow: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {
    position: absolute;
    top: -1px;
    left: -1px;
    content: '';
    height: 2px;
    width: calc(100% + 2px);
    background: #2196F3;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {
    margin-left: 0;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {
    background: white;
    color: rgba(0, 0, 0, .8);
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {
    margin-left: 4px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {
    font-family: FontAwesome;
    content: '\f00d'; /* close */
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
    line-height: 24px;
}

 /* Accordion Widget */

 .p-Collapse {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Collapse-header {
    padding: 4px;
    cursor: pointer;
    color: rgba(0, 0, 0, .5);
    background-color: #EEEEEE;
    border: 1px solid #9E9E9E;
    padding: 10px 15px;
    font-weight: bold;
}

 .p-Collapse-header:hover {
    background-color: white;
    color: rgba(0, 0, 0, .8);
}

 .p-Collapse-open > .p-Collapse-header {
    background-color: white;
    color: rgba(0, 0, 0, 1.0);
    cursor: default;
    border-bottom: none;
}

 .p-Collapse .p-Collapse-header::before {
    content: '\f0da\00A0';  /* caret-right, non-breaking space */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .p-Collapse-open > .p-Collapse-header::before {
    content: '\f0d7\00A0'; /* caret-down, non-breaking space */
}

 .p-Collapse-contents {
    padding: 15px;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    border-left: 1px solid #9E9E9E;
    border-right: 1px solid #9E9E9E;
    border-bottom: 1px solid #9E9E9E;
    overflow: auto;
}

 .p-Accordion {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Accordion .p-Collapse {
    margin-bottom: 0;
}

 .p-Accordion .p-Collapse + .p-Collapse {
    margin-top: 4px;
}

 /* HTML widget */

 .widget-html, .widget-htmlmath {
    font-size: 13px;
}

 .widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {
    /* Fill out the area in the HTML widget */
    -ms-flex-item-align: stretch;
        align-self: stretch;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    /* Makes sure the baseline is still aligned with other elements */
    line-height: 28px;
    /* Make it possible to have absolutely-positioned elements in the html */
    position: relative;
}

/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../node_modules/@jupyter-widgets/controls/css/widgets.css","../node_modules/@jupyter-widgets/controls/css/labvariables.css","../node_modules/@jupyter-widgets/controls/css/materialcolors.css","../node_modules/@jupyter-widgets/controls/css/widgets-base.css","../node_modules/@jupyter-widgets/controls/css/phosphor.css"],"names":[],"mappings":"AAAA;;GAEG;;CAEF;;kCAEiC;;CCNlC;;;+EAG+E;;CAE/E;;;;EAIE;;CCTF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;;CDhBH;;;;;;;;;;;;;;;;;;;EAmBE;;CAGF;;GAEG;;CACF,yDAAyD;;CAC1D,yEAAyE;;CAEzE;;GAEG;;CAOH;;EAEE;;;KAGG;;EAQH;;;;IAIE,CAIwB,oBAAoB,CAGhB,0CAA0C;;EAGxE;;IAEE;;EAOF;;KAEG;;EAOH;;;IAGE,CAWwB,oBAAoB;;;EAU9C;;;;IAIE;;EAOF,kBAAkB;;EAYlB,+CAA+C;;EAsB/C,0BAA0B;EAa1B;4EAC0E;EAE1E;wEACsE;;EAGtE,8BAA8B;;EAK9B,6BAA6B;;EAI7B,6BAA6B;CAQ9B;;CEzMD;;GAEG;;CAEH;;;;GAIG;;CCRH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8BE;;CAEF;;;GAGG;;CAEH;EACE,qBAAc;EAAd,qBAAc;EAAd,cAAc;EACd,0BAA0B;EAC1B,uBAAuB;EACvB,sBAAsB;EACtB,kBAAkB;CACnB;;CAGD;EACE,+BAAoB;EAApB,8BAAoB;MAApB,wBAAoB;UAApB,oBAAoB;CACrB;;CAGD;EACE,6BAAuB;EAAvB,8BAAuB;MAAvB,2BAAuB;UAAvB,uBAAuB;CACxB;;CAGD;EACE,UAAU;EACV,WAAW;EACX,qBAAc;EAAd,qBAAc;EAAd,cAAc;EACd,oBAAe;MAAf,mBAAe;UAAf,eAAe;EACf,sBAAsB;CACvB;;CAGD;EACE,+BAAoB;EAApB,8BAAoB;MAApB,wBAAoB;UAApB,oBAAoB;CACrB;;CAGD;EACE,6BAAuB;EAAvB,8BAAuB;MAAvB,2BAAuB;UAAvB,uBAAuB;CACxB;;CAGD;EACE,qBAAc;EAAd,qBAAc;EAAd,cAAc;EACd,+BAAoB;EAApB,8BAAoB;MAApB,wBAAoB;UAApB,oBAAoB;EACpB,+BAAuB;UAAvB,uBAAuB;EACvB,iBAAiB;CAClB;;CAGD;;EAEE,oBAAe;MAAf,mBAAe;UAAf,eAAe;CAChB;;CAGD;EACE,oBAAe;MAAf,mBAAe;UAAf,eAAe;EACf,iBAAiB;EACjB,oBAAoB;CACrB;;CAGD;EACE,yBAAyB;CAC1B;;CAGD;EACE,mBAAmB;CACpB;;CAGD;EACE,QAAQ;EACR,oCAA4B;EAA5B,4BAA4B;CAC7B;;CAGD;EACE,OAAO;EACP,mCAA2B;EAA3B,2BAA2B;CAC5B;;CAGD;EACE,yBAAiB;EAAjB,iBAAiB;CAClB;;CAED,oBAAoB;;CD9GpB,QAUqC,oCAAoC;;IA2BrE,+BAA+B;CAIlC;;CAED;IACI,YAAiC;IACjC,+BAAuB;YAAvB,uBAAuB;IACvB,aAA+B;IAC/B,kBAAkB;CACrB;;CAED;IACI,kBAA6C;IAC7C,aAAwC;CAC3C;;CAED;IACI,eAAe;IACf,gBAAgB;CACnB;;CAED,mBAAmB;;CAEnB;IACI,wBAAwB;IACxB,+BAAuB;YAAvB,uBAAuB;IACvB,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,+BAAoB;IAApB,8BAAoB;QAApB,wBAAoB;YAApB,oBAAoB;IACpB,4BAAsB;QAAtB,yBAAsB;YAAtB,sBAAsB;CACzB;;CAED;IACI,sBAAsB;IACtB,+BAAuB;YAAvB,uBAAuB;IACvB,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;IACvB,0BAAoB;QAApB,uBAAoB;YAApB,oBAAoB;CACvB;;CAED;IACI,+BAAuB;YAAvB,uBAAuB;IACvB,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,UAAU;IACV,eAAe;CAClB;;CAED;IACI,+BAAuB;YAAvB,uBAAuB;IACvB,cAAc;IACd,UAAU;IACV,eAAe;CAClB;;CAED;IACI,+BAAoB;IAApB,8BAAoB;QAApB,wBAAoB;YAApB,oBAAoB;CACvB;;CAED;IACI,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;CAC1B;;CAED,4BAA4B;;CAE5B;IACI,mBAAmB;IACnB,oBAAoB;IACpB,iBAAiB;IACjB,oBAAoB;IACpB,sBAAsB;IACtB,oBAAoB;IACpB,iBAAiB;IACjB,wBAAwB;IACxB,mBAAmB;IACnB,gBAAuC;IACvC,gBAAgB;;IAEhB,aAAwC;IACxC,kBAAkB;IAClB,kBAA6C;IAC7C,yBAAiB;YAAjB,iBAAiB;;IAEjB,yBAAgC;IAChC,0BAA0C;IAC1C,sBAAsC;IACtC,aAAa;CAChB;;CAED;IACI,kBAA8C;IAC9C,qBAAqB;CACxB;;CAED;IACI,iBAAiB,CAAC,sBAAsB;CAC3C;;CAED;IACI,aAA4C;CAC/C;;CAED;IACI,gBAAgB;CACnB;;CAED;IACI,wBAAwB;IACxB;;+CAE+E;YAF/E;;+CAE+E;CAClF;;CAED;IACI,wBAAwB;IACxB;;iDAE6E;YAF7E;;iDAE6E;IAC7E,yBAAgC;IAChC,0BAA0C;CAC7C;;CAED;IACI,2BAA8D;CACjE;;CAED,8BAA8B;;CAE9B;IACI,gCAAwC;IACxC,0BAAyC;CAC5C;;CAED;IACI,8BAAwC;IACxC,0BAAyC;CAC5C;;CAED;IACI,8BAAwC;IACxC,0BAAyC;CAC5C;;CAED,8BAA8B;;CAE9B;IACI,gCAAwC;IACxC,0BAA2C;CAC9C;;CAED;IACI,8BAAwC;IACxC,0BAA2C;EAC7C;;CAEF;IACI,8BAAwC;IACxC,0BAA2C;EAC7C;;CAED,2BAA2B;;CAE5B;IACI,gCAAwC;IACxC,0BAAwC;CAC3C;;CAED;IACI,8BAAwC;IACxC,0BAAwC;CAC3C;;CAED;IACI,8BAAwC;IACxC,0BAAwC;CAC3C;;CAED,8BAA8B;;CAE9B;IACI,gCAAwC;IACxC,0BAAwC;CAC3C;;CAED;IACI,8BAAwC;IACxC,0BAAwC;CAC3C;;CAED;IACI,8BAAwC;IACxC,0BAAwC;CAC3C;;CAED,6BAA6B;;CAE7B;IACI,gCAAwC;IACxC,0BAAyC;CAC5C;;CAED;IACI,8BAAwC;IACxC,0BAAyC;CAC5C;;CAED;IACI,8BAAwC;IACxC,0BAAyC;CAC5C;;CAED,kBAAkB;;CAElB;IACI,aAA4C;CAC/C;;CAED,0BAA0B;;CAE1B,kCAAkC;;CAClC;IACI,iBAAuB;IAAvB,uBAAuB;CAC1B;;CAED;IACI,iBAAiB;IACjB,aAAqC;IACrC,gBAAuC;IACvC,iBAAiB;IACjB,wBAAwB;IACxB,oBAAoB;IACpB,kBAA6C;CAChD;;CAED;IACI,WAAW;IACX,aAAqC;IACrC,gBAAuC;IACvC,iBAAiB;IACjB,wBAAwB;IACxB,oBAAoB;IACpB,kBAA6C;CAChD;;CAED;IACI,6BAA6B;IAC7B,aAAqC;IACrC,kBAAkB;IAClB,kBAA0D;IAC1D,YAA4C;IAC5C,qBAAe;QAAf,eAAe;CAClB;;CAED;IACI,2BAA2B;IAC3B,aAAqC;IACrC,mBAAmB;IACnB,kBAA6C;CAChD;;CAED,4BAA4B;;CAE5B;IACI,aAAuC;IACvC,gBAAuC;IACvC,aAAwC;IACxC,kBAA6C;IAC7C,iBAAiB;IACjB,oBAAoB;IACpB,mBAAmB;CACtB;;CAED;IACI,yBAAyB;;IAEzB;;;;OAIG;IACH;;uDAEoD;;IAMpD;;+CAE4C;CAC/C;;CAED;IACI,wBAAwB;IACxB,mBAAmB;IACnB,iBAAgD;IAChD,gBAA+C;IAC/C,iBAA6C;CAChD;;CAED;IACI,sBAAsB;IACtB,gBAA4C;IAC5C,2BAA2B;IAC3B,eAAe;CAClB;;CAED,6BAA6B;;CAE7B;IACI,aAAsC;IACtC,aAAwC;IACxC,kBAA6C;CAChD;;CAED;IACI,wBAAgE;IAChE,kBAA6C;IAC7C,iBAAiB;IACjB,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,qBAAe;QAAf,eAAe;IACf,4BAAmB;QAAnB,mBAAmB;CACtB;;CAED,0BAA0B;;CAE1B;IACI,aAAwC;IACxC,kBAA6C;IAC7C,aAA4C;IAC5C,gBAAuC;CAC1C;;CAED;IACI,kBAA6C;IAC7C,kBAA8C;IAC9C,iBAA6C;;IAE7C,0JAA0J;IAC1J,sBAAsB;IACtB,8CAA8C;IAC9C,mBAAmB;IACnB,qBAAqB;IACrB,oCAAoC;IACpC,mCAAmC;CACtC;;CAED;IACI,iBAAiB;IACjB,aAAa;CAChB;;CAED;IACI,iBAAiB;IACjB,WAAW;CACd;;CAED;IACI,cAAc;CACjB;;CAED,qCAAqC;;CAErC;IACI,aAAsC;CACzC;;CAED;IACI,aAAwC;IACxC,kBAA6C;CAChD;;CAED;IACI,aAA4C;CAC/C;;CAED;IACI,+BAAuB;YAAvB,uBAAuB;IACvB,0BAAwF;IACxF,wBAA2D;IAC3D,yBAAqC;IACrC,gBAAuC;IACvC,iBAAsF;IACtF,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,aAAa,CAAC,iEAAiE;IAC/E,qBAAe;QAAf,eAAe;IACf,yBAAyB;CAC5B;;CAED;IACI,gBAAgB;IAChB,eAAe;CAClB;;CAED;IACI,sBAAyD;CAC5D;;CAED,mBAAmB;;CAEnB;IACI,kBAAkB;IAClB,0BAA4E;IAC5E,oBAAoC;IACpC,+BAAuB;YAAvB,uBAAuB;IACvB,mBAAmB;IACnB,mBAAmB;CACtB;;CAED;IACI,mBAAmB;IACnB,yBAAyB,CAAC,oDAAoD;IAC9E,mBAAmB;IACnB,wBAAmE;IACnE,0BAAiG;IACjG,+BAAuB;YAAvB,uBAAuB;IACvB,WAAW;IACX,uBAAuB,CAAC,wBAAwB;CACnD;;CAED,wBAAwB;;CACxB;IACI,0BAA+D;IAC/D,0BAAiG;CACpG;;CAED;IACI,0BAA+D;IAC/D,sBAA2D;IAC3D,WAAW;IACX,8BAAsB;YAAtB,sBAAsB;CACzB;;CAED;IACI,iEAAiE;IACjE,mBAAmB;IACnB,oBAAyD;IACzD,WAAW;CACd;;CAED,8BAA8B;;CAE9B;IACI,YAA4C;IAC5C,aAA6C;IAC7C,iBAAgJ;IAChJ,kBAAqG;IACrG,mBAAmB;IACnB,OAAO;CACV;;CAED;IACI,YAA4C;IAC5C,aAA6C;IAC7C,oBAAuG;IACvG,kBAAiJ;IACjJ,mBAAmB;IACnB,QAAQ;CACX;;CAED;IACI,YAA6D;IAC7D,iBAAyJ;CAC5J;;CAED;IACI,WAA4D;IAC5D,kBAA0J;CAC7J;;CAED,uBAAuB;;CAEvB;IACI,aAAsC;IACtC,aAAwC;IACxC,kBAA6C;;IAE7C;;oDAEgD;IAChD,0BAAoB;QAApB,uBAAoB;YAApB,oBAAoB;CACvB;;CAED;IACI,kBAAkB;CACrB;;CAED;IACI,aAAwC;IACxC,iBAAwG;IACxG,kBAAyG;IACzG,oBAA+C;QAA/C,oBAA+C;YAA/C,gBAA+C;CAClD;;CAED;IACI,gCAAgC;IAChC,YAAiD;IACjD,iBAAmG;IACnG,YAAY;CACf;;CAED,qBAAqB;;CAErB;IACI,aAAwC;IACxC,kBAA6C;CAChD;;CAED;IACI,qBAAqB;IACrB,cAA0C;IAC1C,YAA2C;CAC9C;;CAED;IACI,oBAA+C;QAA/C,oBAA+C;YAA/C,gBAA+C;IAC/C,kBAAkB;IAClB,mBAAmB;IACnB,mBAA0G;IAC1G,gBAAuG;IACvG,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;CAC1B;;CAED;IACI,gCAAgC;IAChC,WAAgD;IAChD,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,kBAAkB;IAClB,mBAAmB;CACtB;;CAED,6BAA6B;;CAE7B;IACI,yBAAyB;IAIzB,iBAAiB;CACpB;;CAED;IACI,aAAwC;CAC3C;;CAED;IACI,0BAAyC;CAC5C;;CAED;IACI,0BAA2C;CAC9C;;CAED;IACI,0BAAwC;CAC3C;;CAED;IACI,0BAAwC;CAC3C;;CAED;IACI,0BAAyC;CAC5C;;CAED;IACI,0BAA0C;IAC1C,aAAa;IACb,yBAAiB;YAAjB,iBAAiB;CACpB;;CAED,yBAAyB;;CAEzB;IACI,kBAAkB;IAClB,aAAwC;IACxC,kBAA6C;IAC7C,aAAsC;IACtC,0BAAoB;QAApB,uBAAoB;YAApB,oBAAoB;;CAEvB;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,gBAA4C;IAC5C,mBAA+C;IAC/C,6BAAoB;QAApB,oBAAoB;IACpB,8BAA8B;IAC9B,aAAgB;IAAhB,gBAAgB;CACnB;;CAED,uBAAuB;;CAEvB;IACI,cAA0C;IAC1C,YAA2C;CAC9C;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,YAA4C;IAC5C,kBAAkB;IAClB,mBAAmB;IACnB,iBAAiB;CACpB;;CAED,2BAA2B;;CAE3B;IACI,aAAwC;IACxC,aAAsC;IACtC,kBAA6C;CAChD;;CAED;IACI,oBAAoB;IACpB,0BAAwF;IACxF,iBAAiB;IACjB,gBAAgB;IAChB,oBAA+C;QAA/C,oBAA+C;YAA/C,gBAA+C;IAC/C,aAAa,CAAC,iEAAiE;IAC/E,+BAAuB;YAAvB,uBAAuB;IACvB,yBAAyB;IACzB,yBAAiB;YAAjB,iBAAiB;IACjB,wBAA2D;IAC3D,yBAAqC;IACrC,gBAAuC;IACvC,oBAAoB;IACpB,kBAAyD;CAC5D,iBAAiB;CACjB,yBAAyB;CACzB,sBAAsB;IACnB,6BAA6B;CAChC,sBAAsB;CACtB,kCAAkC;IAC/B,kuBAAmD;CACtD;;CACD;IACI,sBAAyD;CAC5D;;CAED;IACI,aAA4C;CAC/C;;CAED;6CAC6C;;CAC7C;IACI,mBAAmB;IACnB,wBAAwB;CAC3B;;CAED,+BAA+B;;CAE/B;IACI,aAAsC;IACtC,kBAA6C;;IAE7C;;kEAE8D;IAC9D,yBAAwB;QAAxB,sBAAwB;YAAxB,wBAAwB;CAC3B;;CAED;IACI,0BAAwF;IACxF,wBAA2D;IAC3D,yBAAqC;IACrC,gBAAuC;IACvC,oBAA+C;QAA/C,oBAA+C;YAA/C,gBAA+C;IAC/C,yBAAyB;IACzB,eAAe;IACf,gBAAgB;;IAEhB;;kEAE8D;IAC9D,iBAAiB;CACpB;;CAED;IACI,sBAAyD;CAC5D;;CAED;IACI,kBAA8C;IAC9C,kBAA6C;IAC7C,kEAAkE;IAClE,0DAAiF;IACjF,6DAAoF;CACvF;;CAID,4BAA4B;;CAE5B;IACI,kBAA6C;CAChD;;CAED;IACI,iBAAsC;IACtC,kBAAuC;CAC1C;;CAED;IACI,aAA4C;CAC/C;;CAED,2BAA2B;;CAE3B;IACI,aAAsC;IACtC,kBAA6C;CAChD;;CAED;IACI,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;IACvB,2BAAqB;QAArB,wBAAqB;YAArB,qBAAqB;IACrB,+BAAuB;YAAvB,uBAAuB;IACvB,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,mBAA8D;CACjE;;CAED;IACI,aAA4C;IAC5C,kBAAiD;IACjD,gBAAuC;CAC1C;;CAED;IACI,aAA4C;IAC5C,kBAAiD;IACjD,oBAA4D;IAC5D,YAAY;CACf;;CAED,0BAA0B;;CAE1B;IACI,aAAsC;IACtC,aAAwC;IACxC,kBAA6C;CAChD;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,qBAAe;QAAf,eAAe;IACf,gBAA+C;CAClD;;CAED;IACI,YAAuC;IACvC,aAAwC;IACxC,eAAe,CAAC,6DAA6D;IAC7E,kBAAqD;IACrD,yBAAqC;IACrC,0BAAwF;IACxF,kBAAkB;IAClB,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,qBAAe;QAAf,eAAe;IACf,+BAAuB;YAAvB,uBAAuB;IACvB,6BAAoB;QAApB,oBAAoB;IACpB,yBAAyB;CAC5B;;CAED;IACI,+BAA6F;CAChG;;CAED;IACI,sBAAyD;CAC5D;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,yBAAyB;IACzB,aAAwC;IACxC,kBAA6C;IAC7C,kBAAqD;IACrD,yBAAqC;IACrC,0BAAwF;IACxF,gBAAuC;IACvC,iBAAsF;IACtF,aAAa,CAAC,iEAAiE;IAC/E,qBAAe;QAAf,eAAe;IACf,+BAAuB;YAAvB,uBAAuB;CAC1B;;CAED;IACI,aAA4C;CAC/C;;CAED,yBAAyB;;CAEzB;IACI,aAAsC;IACtC,aAAwC;IACxC,kBAA6C;CAChD;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,qBAAe;QAAf,eAAe;IACf,aAAa,CAAC,iEAAiE;IAC/E,yBAAyB;IACzB,aAAwC;IACxC,0BAAwF;IACxF,wBAA2D;IAC3D,yBAAqC;IACrC,gBAAuC;IACvC,iBAAsF;IACtF,+BAAuB;YAAvB,uBAAuB;CAC1B;;CAED;IACI,sBAAyD;CAC5D;;CAED;IACI,sBAAoC;CACvC;;CAED;IACI,aAA4C;CAC/C;;CAED,iBAAiB;;CAEjB;IACI,aAA4C;IAC5C,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,2BAAqB;QAArB,wBAAqB;YAArB,qBAAqB;CACxB;;CAED;IACI,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,aAAa;CAChB;;CAED;IACI,aAA4C;CAC/C;;CAED,gBAAgB;;CAEhB;IACI,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;CAC1B;;CAED;IACI,yFAAyF;IACzF,oBAAoB;IACpB,oBAAoB;CACvB;;CAED;IACI,iDAAiD;IACjD,uBAAsB;QAAtB,oBAAsB;YAAtB,sBAAsB;IACtB,aAAa;IACb,cAAc;CACjB;;CAED;IACI,YAAY;IACZ,+BAAuB;YAAvB,uBAAuB;IACvB,UAAU;IACV,kBAAoC;IACpC,yBAAgC;IAChC,0BAA6D;IAC7D,cAA6C;IAC7C,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,eAAe;CAClB;;CAED;IACI,wCAA+D;IAC/D,iBAAmF;CACtF;;CAED;IACI,oBAAiD;QAAjD,oBAAiD;YAAjD,gBAAiD;IACjD,gBAAgB;IAChB,iBAAmF;IACnF,kBAAqD;IACrD,kBAA+C;IAC/C,kBAAkB;IAClB,oBAAoC;IACpC,yBAAgC;IAChC,0BAA6D;IAC7D,oBAAoB;IACpB,mBAAmB;CACtB;;CAED;IACI,0BAAgC;IAChC,gEAAgE;IAChE,kBAAoC;IACpC,iBAAuF;IACvF,mCAA8C;YAA9C,2BAA8C;IAC9C,kBAAkB;CACrB;;CAED;IACI,mBAAmB;IACnB,UAAuC;IACvC,WAAwC;IACxC,YAAY;IACZ,YAAoD;IACpD,wBAA+C;IAC/C,oBAAmC;CACtC;;CAED;IACI,eAAe;CAClB;;CAED;IACI,kBAAoC;IACpC,yBAAgC;CACnC;;CAED;IACI,iBAAiB;CACpB;;CAED;IACI,yBAAyB;IACzB,iBAAiB,CAAC,WAAW;CAChC;;CAED;;;IAGI,kBAAqD;CACxD;;CAED,sBAAsB;;CAEtB;IACI,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;IACvB,2BAAqB;QAArB,wBAAqB;YAArB,qBAAqB;CACxB;;CAED;IACI,aAAyC;IACzC,gBAAgB;IAChB,yBAAgC;IAChC,0BAA0C;IAC1C,0BAAqE;IACrE,mBAA+F;IAC/F,kBAAkB;CACrB;;CAED;IACI,wBAA0C;IAC1C,yBAAgC;CACnC;;CAED;IACI,wBAA0C;IAC1C,0BAAgC;IAChC,gBAAgB;IAChB,oBAAoB;CACvB;;CAED;IACI,sBAAsB,EAAE,qCAAqC;IAC7D,sBAAsB;IACtB,8CAA8C;IAC9C,mBAAmB;IACnB,qBAAqB;IACrB,oCAAoC;IACpC,mCAAmC;CACtC;;CAED;IACI,sBAAsB,CAAC,oCAAoC;CAC9D;;CAED;IACI,cAA6C;IAC7C,wBAA0C;IAC1C,yBAAgC;IAChC,+BAA0E;IAC1E,gCAA2E;IAC3E,iCAA4E;IAC5E,eAAe;CAClB;;CAED;IACI,qBAAc;IAAd,qBAAc;IAAd,cAAc;IACd,6BAAuB;IAAvB,8BAAuB;QAAvB,2BAAuB;YAAvB,uBAAuB;IACvB,2BAAqB;QAArB,wBAAqB;YAArB,qBAAqB;CACxB;;CAED;IACI,iBAAiB;CACpB;;CAED;IACI,gBAAgB;CACnB;;CAID,iBAAiB;;CAEjB;IACI,gBAAuC;CAC1C;;CAED;IACI,0CAA0C;IAC1C,6BAAoB;QAApB,oBAAoB;IACpB,oBAAa;QAAb,qBAAa;YAAb,aAAa;IACb,qBAAe;QAAf,eAAe;IACf,kEAAkE;IAClE,kBAA6C;IAC7C,yEAAyE;IACzE,mBAAmB;CACtB","file":"controls.css","sourcesContent":["/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n /* We import all of these together in a single css file because the Webpack\nloader sees only one file at a time. This allows postcss to see the variable\ndefinitions when they are used. */\n\n@import \"./labvariables.css\";\n@import \"./widgets-base.css\";\n","/*-----------------------------------------------------------------------------\n| Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the Modified BSD License.\n|----------------------------------------------------------------------------*/\n\n/*\nThis file is copied from the JupyterLab project to define default styling for\nwhen the widget styling is compiled down to eliminate CSS variables. We make one\nchange - we comment out the font import below.\n*/\n\n@import \"./materialcolors.css\";\n\n/*\nThe following CSS variables define the main, public API for styling JupyterLab.\nThese variables should be used by all plugins wherever possible. In other\nwords, plugins should not define custom colors, sizes, etc unless absolutely\nnecessary. This enables users to change the visual theme of JupyterLab\nby changing these variables.\n\nMany variables appear in an ordered sequence (0,1,2,3). These sequences\nare designed to work well together, so for example, `--jp-border-color1` should\nbe used with `--jp-layout-color1`. The numbers have the following meanings:\n\n* 0: super-primary, reserved for special emphasis\n* 1: primary, most important under normal situations\n* 2: secondary, next most important under normal situations\n* 3: tertiary, next most important under normal situations\n\nThroughout JupyterLab, we are mostly following principles from Google's\nMaterial Design when selecting colors. We are not, however, following\nall of MD as it is not optimized for dense, information rich UIs.\n*/\n\n\n/*\n * Optional monospace font for input/output prompt.\n */\n /* Commented out in ipywidgets since we don't need it. */\n/* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */\n\n/*\n * Added for compabitility with output area\n */\n:root {\n  --jp-icon-search: none;\n  --jp-ui-select-caret: none;\n}\n\n\n:root {\n\n  /* Borders\n\n  The following variables, specify the visual styling of borders in JupyterLab.\n   */\n\n  --jp-border-width: 1px;\n  --jp-border-color0: var(--md-grey-700);\n  --jp-border-color1: var(--md-grey-500);\n  --jp-border-color2: var(--md-grey-300);\n  --jp-border-color3: var(--md-grey-100);\n\n  /* UI Fonts\n\n  The UI font CSS variables are used for the typography all of the JupyterLab\n  user interface elements that are not directly user generated content.\n  */\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n  --jp-ui-icon-font-size: 14px; /* Ensures px perfect FontAwesome icons */\n  --jp-ui-font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n\n  /* Use these font colors against the corresponding main layout colors.\n     In a light theme, these go from dark to light.\n  */\n\n  --jp-ui-font-color0: rgba(0,0,0,1.0);\n  --jp-ui-font-color1: rgba(0,0,0,0.8);\n  --jp-ui-font-color2: rgba(0,0,0,0.5);\n  --jp-ui-font-color3: rgba(0,0,0,0.3);\n\n  /* Use these against the brand/accent/warn/error colors.\n     These will typically go from light to darker, in both a dark and light theme\n   */\n\n  --jp-inverse-ui-font-color0: rgba(255,255,255,1);\n  --jp-inverse-ui-font-color1: rgba(255,255,255,1.0);\n  --jp-inverse-ui-font-color2: rgba(255,255,255,0.7);\n  --jp-inverse-ui-font-color3: rgba(255,255,255,0.5);\n\n  /* Content Fonts\n\n  Content font variables are used for typography of user generated content.\n  */\n\n  --jp-content-font-size: 13px;\n  --jp-content-line-height: 1.5;\n  --jp-content-font-color0: black;\n  --jp-content-font-color1: black;\n  --jp-content-font-color2: var(--md-grey-700);\n  --jp-content-font-color3: var(--md-grey-500);\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n\n  --jp-code-font-size: 13px;\n  --jp-code-line-height: 1.307;\n  --jp-code-padding: 5px;\n  --jp-code-font-family: monospace;\n\n\n  /* Layout\n\n  The following are the main layout colors use in JupyterLab. In a light\n  theme these would go from light to dark.\n  */\n\n  --jp-layout-color0: white;\n  --jp-layout-color1: white;\n  --jp-layout-color2: var(--md-grey-200);\n  --jp-layout-color3: var(--md-grey-400);\n\n  /* Brand/accent */\n\n  --jp-brand-color0: var(--md-blue-700);\n  --jp-brand-color1: var(--md-blue-500);\n  --jp-brand-color2: var(--md-blue-300);\n  --jp-brand-color3: var(--md-blue-100);\n\n  --jp-accent-color0: var(--md-green-700);\n  --jp-accent-color1: var(--md-green-500);\n  --jp-accent-color2: var(--md-green-300);\n  --jp-accent-color3: var(--md-green-100);\n\n  /* State colors (warn, error, success, info) */\n\n  --jp-warn-color0: var(--md-orange-700);\n  --jp-warn-color1: var(--md-orange-500);\n  --jp-warn-color2: var(--md-orange-300);\n  --jp-warn-color3: var(--md-orange-100);\n\n  --jp-error-color0: var(--md-red-700);\n  --jp-error-color1: var(--md-red-500);\n  --jp-error-color2: var(--md-red-300);\n  --jp-error-color3: var(--md-red-100);\n\n  --jp-success-color0: var(--md-green-700);\n  --jp-success-color1: var(--md-green-500);\n  --jp-success-color2: var(--md-green-300);\n  --jp-success-color3: var(--md-green-100);\n\n  --jp-info-color0: var(--md-cyan-700);\n  --jp-info-color1: var(--md-cyan-500);\n  --jp-info-color2: var(--md-cyan-300);\n  --jp-info-color3: var(--md-cyan-100);\n\n  /* Cell specific styles */\n\n  --jp-cell-padding: 5px;\n  --jp-cell-editor-background: #f7f7f7;\n  --jp-cell-editor-border-color: #cfcfcf;\n  --jp-cell-editor-background-edit: var(--jp-ui-layout-color1);\n  --jp-cell-editor-border-color-edit: var(--jp-brand-color1);\n  --jp-cell-prompt-width: 100px;\n  --jp-cell-prompt-font-family: 'Roboto Mono', monospace;\n  --jp-cell-prompt-letter-spacing: 0px;\n  --jp-cell-prompt-opacity: 1.0;\n  --jp-cell-prompt-opacity-not-active: 0.4;\n  --jp-cell-prompt-font-color-not-active: var(--md-grey-700);\n  /* A custom blend of MD grey and blue 600\n   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */\n  --jp-cell-inprompt-font-color: #307FC1;\n  /* A custom blend of MD grey and orange 600\n   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */\n  --jp-cell-outprompt-font-color: #BF5B3D;\n\n  /* Notebook specific styles */\n\n  --jp-notebook-padding: 10px;\n  --jp-notebook-scroll-padding: 100px;\n\n  /* Console specific styles */\n\n  --jp-console-background: var(--md-grey-100);\n\n  /* Toolbar specific styles */\n\n  --jp-toolbar-border-color: var(--md-grey-400);\n  --jp-toolbar-micro-height: 8px;\n  --jp-toolbar-background: var(--jp-layout-color0);\n  --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0,0,0,0.24);\n  --jp-toolbar-header-margin: 4px 4px 0px 4px;\n  --jp-toolbar-active-background: var(--md-grey-300);\n}\n","/**\n * The material design colors are adapted from google-material-color v1.2.6\n * https://github.com/danlevan/google-material-color\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css\n *\n * The license for the material design color CSS variables is as follows (see\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2014 Dan Le Van\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n:root {\n  --md-red-50: #FFEBEE;\n  --md-red-100: #FFCDD2;\n  --md-red-200: #EF9A9A;\n  --md-red-300: #E57373;\n  --md-red-400: #EF5350;\n  --md-red-500: #F44336;\n  --md-red-600: #E53935;\n  --md-red-700: #D32F2F;\n  --md-red-800: #C62828;\n  --md-red-900: #B71C1C;\n  --md-red-A100: #FF8A80;\n  --md-red-A200: #FF5252;\n  --md-red-A400: #FF1744;\n  --md-red-A700: #D50000;\n\n  --md-pink-50: #FCE4EC;\n  --md-pink-100: #F8BBD0;\n  --md-pink-200: #F48FB1;\n  --md-pink-300: #F06292;\n  --md-pink-400: #EC407A;\n  --md-pink-500: #E91E63;\n  --md-pink-600: #D81B60;\n  --md-pink-700: #C2185B;\n  --md-pink-800: #AD1457;\n  --md-pink-900: #880E4F;\n  --md-pink-A100: #FF80AB;\n  --md-pink-A200: #FF4081;\n  --md-pink-A400: #F50057;\n  --md-pink-A700: #C51162;\n\n  --md-purple-50: #F3E5F5;\n  --md-purple-100: #E1BEE7;\n  --md-purple-200: #CE93D8;\n  --md-purple-300: #BA68C8;\n  --md-purple-400: #AB47BC;\n  --md-purple-500: #9C27B0;\n  --md-purple-600: #8E24AA;\n  --md-purple-700: #7B1FA2;\n  --md-purple-800: #6A1B9A;\n  --md-purple-900: #4A148C;\n  --md-purple-A100: #EA80FC;\n  --md-purple-A200: #E040FB;\n  --md-purple-A400: #D500F9;\n  --md-purple-A700: #AA00FF;\n\n  --md-deep-purple-50: #EDE7F6;\n  --md-deep-purple-100: #D1C4E9;\n  --md-deep-purple-200: #B39DDB;\n  --md-deep-purple-300: #9575CD;\n  --md-deep-purple-400: #7E57C2;\n  --md-deep-purple-500: #673AB7;\n  --md-deep-purple-600: #5E35B1;\n  --md-deep-purple-700: #512DA8;\n  --md-deep-purple-800: #4527A0;\n  --md-deep-purple-900: #311B92;\n  --md-deep-purple-A100: #B388FF;\n  --md-deep-purple-A200: #7C4DFF;\n  --md-deep-purple-A400: #651FFF;\n  --md-deep-purple-A700: #6200EA;\n\n  --md-indigo-50: #E8EAF6;\n  --md-indigo-100: #C5CAE9;\n  --md-indigo-200: #9FA8DA;\n  --md-indigo-300: #7986CB;\n  --md-indigo-400: #5C6BC0;\n  --md-indigo-500: #3F51B5;\n  --md-indigo-600: #3949AB;\n  --md-indigo-700: #303F9F;\n  --md-indigo-800: #283593;\n  --md-indigo-900: #1A237E;\n  --md-indigo-A100: #8C9EFF;\n  --md-indigo-A200: #536DFE;\n  --md-indigo-A400: #3D5AFE;\n  --md-indigo-A700: #304FFE;\n\n  --md-blue-50: #E3F2FD;\n  --md-blue-100: #BBDEFB;\n  --md-blue-200: #90CAF9;\n  --md-blue-300: #64B5F6;\n  --md-blue-400: #42A5F5;\n  --md-blue-500: #2196F3;\n  --md-blue-600: #1E88E5;\n  --md-blue-700: #1976D2;\n  --md-blue-800: #1565C0;\n  --md-blue-900: #0D47A1;\n  --md-blue-A100: #82B1FF;\n  --md-blue-A200: #448AFF;\n  --md-blue-A400: #2979FF;\n  --md-blue-A700: #2962FF;\n\n  --md-light-blue-50: #E1F5FE;\n  --md-light-blue-100: #B3E5FC;\n  --md-light-blue-200: #81D4FA;\n  --md-light-blue-300: #4FC3F7;\n  --md-light-blue-400: #29B6F6;\n  --md-light-blue-500: #03A9F4;\n  --md-light-blue-600: #039BE5;\n  --md-light-blue-700: #0288D1;\n  --md-light-blue-800: #0277BD;\n  --md-light-blue-900: #01579B;\n  --md-light-blue-A100: #80D8FF;\n  --md-light-blue-A200: #40C4FF;\n  --md-light-blue-A400: #00B0FF;\n  --md-light-blue-A700: #0091EA;\n\n  --md-cyan-50: #E0F7FA;\n  --md-cyan-100: #B2EBF2;\n  --md-cyan-200: #80DEEA;\n  --md-cyan-300: #4DD0E1;\n  --md-cyan-400: #26C6DA;\n  --md-cyan-500: #00BCD4;\n  --md-cyan-600: #00ACC1;\n  --md-cyan-700: #0097A7;\n  --md-cyan-800: #00838F;\n  --md-cyan-900: #006064;\n  --md-cyan-A100: #84FFFF;\n  --md-cyan-A200: #18FFFF;\n  --md-cyan-A400: #00E5FF;\n  --md-cyan-A700: #00B8D4;\n\n  --md-teal-50: #E0F2F1;\n  --md-teal-100: #B2DFDB;\n  --md-teal-200: #80CBC4;\n  --md-teal-300: #4DB6AC;\n  --md-teal-400: #26A69A;\n  --md-teal-500: #009688;\n  --md-teal-600: #00897B;\n  --md-teal-700: #00796B;\n  --md-teal-800: #00695C;\n  --md-teal-900: #004D40;\n  --md-teal-A100: #A7FFEB;\n  --md-teal-A200: #64FFDA;\n  --md-teal-A400: #1DE9B6;\n  --md-teal-A700: #00BFA5;\n\n  --md-green-50: #E8F5E9;\n  --md-green-100: #C8E6C9;\n  --md-green-200: #A5D6A7;\n  --md-green-300: #81C784;\n  --md-green-400: #66BB6A;\n  --md-green-500: #4CAF50;\n  --md-green-600: #43A047;\n  --md-green-700: #388E3C;\n  --md-green-800: #2E7D32;\n  --md-green-900: #1B5E20;\n  --md-green-A100: #B9F6CA;\n  --md-green-A200: #69F0AE;\n  --md-green-A400: #00E676;\n  --md-green-A700: #00C853;\n\n  --md-light-green-50: #F1F8E9;\n  --md-light-green-100: #DCEDC8;\n  --md-light-green-200: #C5E1A5;\n  --md-light-green-300: #AED581;\n  --md-light-green-400: #9CCC65;\n  --md-light-green-500: #8BC34A;\n  --md-light-green-600: #7CB342;\n  --md-light-green-700: #689F38;\n  --md-light-green-800: #558B2F;\n  --md-light-green-900: #33691E;\n  --md-light-green-A100: #CCFF90;\n  --md-light-green-A200: #B2FF59;\n  --md-light-green-A400: #76FF03;\n  --md-light-green-A700: #64DD17;\n\n  --md-lime-50: #F9FBE7;\n  --md-lime-100: #F0F4C3;\n  --md-lime-200: #E6EE9C;\n  --md-lime-300: #DCE775;\n  --md-lime-400: #D4E157;\n  --md-lime-500: #CDDC39;\n  --md-lime-600: #C0CA33;\n  --md-lime-700: #AFB42B;\n  --md-lime-800: #9E9D24;\n  --md-lime-900: #827717;\n  --md-lime-A100: #F4FF81;\n  --md-lime-A200: #EEFF41;\n  --md-lime-A400: #C6FF00;\n  --md-lime-A700: #AEEA00;\n\n  --md-yellow-50: #FFFDE7;\n  --md-yellow-100: #FFF9C4;\n  --md-yellow-200: #FFF59D;\n  --md-yellow-300: #FFF176;\n  --md-yellow-400: #FFEE58;\n  --md-yellow-500: #FFEB3B;\n  --md-yellow-600: #FDD835;\n  --md-yellow-700: #FBC02D;\n  --md-yellow-800: #F9A825;\n  --md-yellow-900: #F57F17;\n  --md-yellow-A100: #FFFF8D;\n  --md-yellow-A200: #FFFF00;\n  --md-yellow-A400: #FFEA00;\n  --md-yellow-A700: #FFD600;\n\n  --md-amber-50: #FFF8E1;\n  --md-amber-100: #FFECB3;\n  --md-amber-200: #FFE082;\n  --md-amber-300: #FFD54F;\n  --md-amber-400: #FFCA28;\n  --md-amber-500: #FFC107;\n  --md-amber-600: #FFB300;\n  --md-amber-700: #FFA000;\n  --md-amber-800: #FF8F00;\n  --md-amber-900: #FF6F00;\n  --md-amber-A100: #FFE57F;\n  --md-amber-A200: #FFD740;\n  --md-amber-A400: #FFC400;\n  --md-amber-A700: #FFAB00;\n\n  --md-orange-50: #FFF3E0;\n  --md-orange-100: #FFE0B2;\n  --md-orange-200: #FFCC80;\n  --md-orange-300: #FFB74D;\n  --md-orange-400: #FFA726;\n  --md-orange-500: #FF9800;\n  --md-orange-600: #FB8C00;\n  --md-orange-700: #F57C00;\n  --md-orange-800: #EF6C00;\n  --md-orange-900: #E65100;\n  --md-orange-A100: #FFD180;\n  --md-orange-A200: #FFAB40;\n  --md-orange-A400: #FF9100;\n  --md-orange-A700: #FF6D00;\n\n  --md-deep-orange-50: #FBE9E7;\n  --md-deep-orange-100: #FFCCBC;\n  --md-deep-orange-200: #FFAB91;\n  --md-deep-orange-300: #FF8A65;\n  --md-deep-orange-400: #FF7043;\n  --md-deep-orange-500: #FF5722;\n  --md-deep-orange-600: #F4511E;\n  --md-deep-orange-700: #E64A19;\n  --md-deep-orange-800: #D84315;\n  --md-deep-orange-900: #BF360C;\n  --md-deep-orange-A100: #FF9E80;\n  --md-deep-orange-A200: #FF6E40;\n  --md-deep-orange-A400: #FF3D00;\n  --md-deep-orange-A700: #DD2C00;\n\n  --md-brown-50: #EFEBE9;\n  --md-brown-100: #D7CCC8;\n  --md-brown-200: #BCAAA4;\n  --md-brown-300: #A1887F;\n  --md-brown-400: #8D6E63;\n  --md-brown-500: #795548;\n  --md-brown-600: #6D4C41;\n  --md-brown-700: #5D4037;\n  --md-brown-800: #4E342E;\n  --md-brown-900: #3E2723;\n\n  --md-grey-50: #FAFAFA;\n  --md-grey-100: #F5F5F5;\n  --md-grey-200: #EEEEEE;\n  --md-grey-300: #E0E0E0;\n  --md-grey-400: #BDBDBD;\n  --md-grey-500: #9E9E9E;\n  --md-grey-600: #757575;\n  --md-grey-700: #616161;\n  --md-grey-800: #424242;\n  --md-grey-900: #212121;\n\n  --md-blue-grey-50: #ECEFF1;\n  --md-blue-grey-100: #CFD8DC;\n  --md-blue-grey-200: #B0BEC5;\n  --md-blue-grey-300: #90A4AE;\n  --md-blue-grey-400: #78909C;\n  --md-blue-grey-500: #607D8B;\n  --md-blue-grey-600: #546E7A;\n  --md-blue-grey-700: #455A64;\n  --md-blue-grey-800: #37474F;\n  --md-blue-grey-900: #263238;\n}","/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n/*\n * We assume that the CSS variables in\n * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css\n * have been defined.\n */\n\n@import \"./phosphor.css\";\n\n:root {\n    --jp-widgets-color: var(--jp-content-font-color1);\n    --jp-widgets-label-color: var(--jp-widgets-color);\n    --jp-widgets-readout-color: var(--jp-widgets-color);\n    --jp-widgets-font-size: var(--jp-ui-font-size1);\n    --jp-widgets-margin: 2px;\n    --jp-widgets-inline-height: 28px;\n    --jp-widgets-inline-width: 300px;\n    --jp-widgets-inline-width-short: calc(var(--jp-widgets-inline-width) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-width-tiny: calc(var(--jp-widgets-inline-width-short) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-margin: 4px; /* margin between inline elements */\n    --jp-widgets-inline-label-width: 80px;\n    --jp-widgets-border-width: var(--jp-border-width);\n    --jp-widgets-vertical-height: 200px;\n    --jp-widgets-horizontal-tab-height: 24px;\n    --jp-widgets-horizontal-tab-width: 144px;\n    --jp-widgets-horizontal-tab-top-border: 2px;\n    --jp-widgets-progress-thickness: 20px;\n    --jp-widgets-container-padding: 15px;\n    --jp-widgets-input-padding: 4px;\n    --jp-widgets-radio-item-height-adjustment: 8px;\n    --jp-widgets-radio-item-height: calc(var(--jp-widgets-inline-height) - var(--jp-widgets-radio-item-height-adjustment));\n    --jp-widgets-slider-track-thickness: 4px;\n    --jp-widgets-slider-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-slider-handle-size: 16px;\n    --jp-widgets-slider-handle-border-color: var(--jp-border-color1);\n    --jp-widgets-slider-handle-background-color: var(--jp-layout-color1);\n    --jp-widgets-slider-active-handle-color: var(--jp-brand-color1);\n    --jp-widgets-menu-item-height: 24px;\n    --jp-widgets-dropdown-arrow: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg\");\n    --jp-widgets-input-color: var(--jp-ui-font-color1);\n    --jp-widgets-input-background-color: var(--jp-layout-color1);\n    --jp-widgets-input-border-color: var(--jp-border-color1);\n    --jp-widgets-input-focus-border-color: var(--jp-brand-color2);\n    --jp-widgets-input-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-disabled-opacity: 0.6;\n\n    /* From Material Design Lite */\n    --md-shadow-key-umbra-opacity: 0.2;\n    --md-shadow-key-penumbra-opacity: 0.14;\n    --md-shadow-ambient-shadow-opacity: 0.12;\n}\n\n.jupyter-widgets {\n    margin: var(--jp-widgets-margin);\n    box-sizing: border-box;\n    color: var(--jp-widgets-color);\n    overflow: visible;\n}\n\n.jupyter-widgets.jupyter-widgets-disconnected::before {\n    line-height: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n}\n\n.jp-Output-result > .jupyter-widgets {\n    margin-left: 0;\n    margin-right: 0;\n}\n\n/* vbox and hbox */\n\n.widget-inline-hbox {\n    /* Horizontal widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: row;\n    align-items: baseline;\n}\n\n.widget-inline-vbox {\n    /* Vertical Widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n}\n\n.widget-box {\n    box-sizing: border-box;\n    display: flex;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-gridbox {\n    box-sizing: border-box;\n    display: grid;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-hbox {\n    flex-direction: row;\n}\n\n.widget-vbox {\n    flex-direction: column;\n}\n\n/* General Button Styling */\n\n.jupyter-button {\n    padding-left: 10px;\n    padding-right: 10px;\n    padding-top: 0px;\n    padding-bottom: 0px;\n    display: inline-block;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    text-align: center;\n    font-size: var(--jp-widgets-font-size);\n    cursor: pointer;\n\n    height: var(--jp-widgets-inline-height);\n    border: 0px solid;\n    line-height: var(--jp-widgets-inline-height);\n    box-shadow: none;\n\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color2);\n    border-color: var(--jp-border-color2);\n    border: none;\n}\n\n.jupyter-button i.fa {\n    margin-right: var(--jp-widgets-inline-margin);\n    pointer-events: none;\n}\n\n.jupyter-button:empty:before {\n    content: \"\\200b\"; /* zero-width space */\n}\n\n.jupyter-widgets.jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.jupyter-button i.fa.center {\n    margin-right: 0;\n}\n\n.jupyter-button:hover:enabled, .jupyter-button:focus:enabled {\n    /* MD Lite 2dp shadow */\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 3px 1px -2px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity)),\n                0 1px 5px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity));\n}\n\n.jupyter-button:active, .jupyter-button.mod-active {\n    /* MD Lite 4dp shadow */\n    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 1px 10px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity)),\n                0 2px 4px -1px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity));\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color3);\n}\n\n.jupyter-button:focus:enabled {\n    outline: 1px solid var(--jp-widgets-input-focus-border-color);\n}\n\n/* Button \"Primary\" Styling */\n\n.jupyter-button.mod-primary {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-brand-color1);\n}\n\n.jupyter-button.mod-primary.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n.jupyter-button.mod-primary:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n/* Button \"Success\" Styling */\n\n.jupyter-button.mod-success {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-success-color1);\n}\n\n.jupyter-button.mod-success.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n.jupyter-button.mod-success:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n /* Button \"Info\" Styling */\n\n.jupyter-button.mod-info {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-info-color1);\n}\n\n.jupyter-button.mod-info.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n.jupyter-button.mod-info:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n/* Button \"Warning\" Styling */\n\n.jupyter-button.mod-warning {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-warn-color1);\n}\n\n.jupyter-button.mod-warning.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n.jupyter-button.mod-warning:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n/* Button \"Danger\" Styling */\n\n.jupyter-button.mod-danger {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-error-color1);\n}\n\n.jupyter-button.mod-danger.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n.jupyter-button.mod-danger:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n/* Widget Button*/\n\n.widget-button, .widget-toggle-button {\n    width: var(--jp-widgets-inline-width-short);\n}\n\n/* Widget Label Styling */\n\n/* Override Bootstrap label css */\n.jupyter-widgets label {\n    margin-bottom: initial;\n}\n\n.widget-label-basic {\n    /* Basic Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-label {\n    /* Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-inline-hbox .widget-label {\n    /* Horizontal Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: right;\n    margin-right: calc( var(--jp-widgets-inline-margin) * 2 );\n    width: var(--jp-widgets-inline-label-width);\n    flex-shrink: 0;\n}\n\n.widget-inline-vbox .widget-label {\n    /* Vertical Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: center;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n/* Widget Readout Styling */\n\n.widget-readout {\n    color: var(--jp-widgets-readout-color);\n    font-size: var(--jp-widgets-font-size);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    overflow: hidden;\n    white-space: nowrap;\n    text-align: center;\n}\n\n.widget-readout.overflow {\n    /* Overflowing Readout */\n\n    /* From Material Design Lite\n        shadow-key-umbra-opacity: 0.2;\n        shadow-key-penumbra-opacity: 0.14;\n        shadow-ambient-shadow-opacity: 0.12;\n     */\n    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                        0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                        0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    -moz-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                     0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                     0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n\n.widget-inline-hbox .widget-readout {\n    /* Horizontal Readout */\n    text-align: center;\n    max-width: var(--jp-widgets-inline-width-short);\n    min-width: var(--jp-widgets-inline-width-tiny);\n    margin-left: var(--jp-widgets-inline-margin);\n}\n\n.widget-inline-vbox .widget-readout {\n    /* Vertical Readout */\n    margin-top: var(--jp-widgets-inline-margin);\n    /* as wide as the widget */\n    width: inherit;\n}\n\n/* Widget Checkbox Styling */\n\n.widget-checkbox {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-checkbox input[type=\"checkbox\"] {\n    margin: 0px calc( var(--jp-widgets-inline-margin) * 2 ) 0px 0px;\n    line-height: var(--jp-widgets-inline-height);\n    font-size: large;\n    flex-grow: 1;\n    flex-shrink: 0;\n    align-self: center;\n}\n\n/* Widget Valid Styling */\n\n.widget-valid {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width-short);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-valid i:before {\n    line-height: var(--jp-widgets-inline-height);\n    margin-right: var(--jp-widgets-inline-margin);\n    margin-left: var(--jp-widgets-inline-margin);\n\n    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.widget-valid.mod-valid i:before {\n    content: \"\\f00c\";\n    color: green;\n}\n\n.widget-valid.mod-invalid i:before {\n    content: \"\\f00d\";\n    color: red;\n}\n\n.widget-valid.mod-valid .widget-valid-readout {\n    display: none;\n}\n\n/* Widget Text and TextArea Stying */\n\n.widget-textarea, .widget-text {\n    width: var(--jp-widgets-inline-width);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"]{\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-text input[type=\"text\"]:disabled, .widget-text input[type=\"number\"]:disabled, .widget-textarea textarea:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"], .widget-textarea textarea {\n    box-sizing: border-box;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    flex-grow: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    outline: none !important;\n}\n\n.widget-textarea textarea {\n    height: inherit;\n    width: inherit;\n}\n\n.widget-text input:focus, .widget-textarea textarea:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n/* Widget Slider */\n\n.widget-slider .ui-slider {\n    /* Slider Track */\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-layout-color3);\n    background: var(--jp-layout-color3);\n    box-sizing: border-box;\n    position: relative;\n    border-radius: 0px;\n}\n\n.widget-slider .ui-slider .ui-slider-handle {\n    /* Slider Handle */\n    outline: none !important; /* focused slider handles are colored - see below */\n    position: absolute;\n    background-color: var(--jp-widgets-slider-handle-background-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-handle-border-color);\n    box-sizing: border-box;\n    z-index: 1;\n    background-image: none; /* Override jquery-ui */\n}\n\n/* Override jquery-ui */\n.widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-active-handle-color);\n}\n\n.widget-slider .ui-slider .ui-slider-handle:active {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border-color: var(--jp-widgets-slider-active-handle-color);\n    z-index: 2;\n    transform: scale(1.2);\n}\n\n.widget-slider  .ui-slider .ui-slider-range {\n    /* Interval between the two specified value of a double slider */\n    position: absolute;\n    background: var(--jp-widgets-slider-active-handle-color);\n    z-index: 0;\n}\n\n/* Shapes of Slider Handles */\n\n.widget-hslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    top: 0;\n}\n\n.widget-vslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    left: 0;\n}\n\n.widget-hslider .ui-slider .ui-slider-range {\n    height: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n.widget-vslider .ui-slider .ui-slider-range {\n    width: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n/* Horizontal Slider */\n\n.widget-hslider {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Override the align-items baseline. This way, the description and readout\n    still seem to align their baseline properly, and we don't have to have\n    align-self: stretch in the .slider-container. */\n    align-items: center;\n}\n\n.widgets-slider .slider-container {\n    overflow: visible;\n}\n\n.widget-hslider .slider-container {\n    height: var(--jp-widgets-inline-height);\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-right: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n}\n\n.widget-hslider .ui-slider {\n    /* Inner, invisible slide div */\n    height: var(--jp-widgets-slider-track-thickness);\n    margin-top: calc((var(--jp-widgets-inline-height) - var(--jp-widgets-slider-track-thickness)) / 2);\n    width: 100%;\n}\n\n/* Vertical Slider */\n\n.widget-vbox .widget-label {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-vslider {\n    /* Vertical Slider */\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vslider .slider-container {\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-top: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    display: flex;\n    flex-direction: column;\n}\n\n.widget-vslider .ui-slider-vertical {\n    /* Inner, invisible slide div */\n    width: var(--jp-widgets-slider-track-thickness);\n    flex-grow: 1;\n    margin-left: auto;\n    margin-right: auto;\n}\n\n/* Widget Progress Styling */\n\n.progress-bar {\n    -webkit-transition: none;\n    -moz-transition: none;\n    -ms-transition: none;\n    -o-transition: none;\n    transition: none;\n}\n\n.progress-bar {\n    height: var(--jp-widgets-inline-height);\n}\n\n.progress-bar {\n    background-color: var(--jp-brand-color1);\n}\n\n.progress-bar-success {\n    background-color: var(--jp-success-color1);\n}\n\n.progress-bar-info {\n    background-color: var(--jp-info-color1);\n}\n\n.progress-bar-warning {\n    background-color: var(--jp-warn-color1);\n}\n\n.progress-bar-danger {\n    background-color: var(--jp-error-color1);\n}\n\n.progress {\n    background-color: var(--jp-layout-color2);\n    border: none;\n    box-shadow: none;\n}\n\n/* Horisontal Progress */\n\n.widget-hprogress {\n    /* Progress Bar */\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    align-items: center;\n\n}\n\n.widget-hprogress .progress {\n    flex-grow: 1;\n    margin-top: var(--jp-widgets-input-padding);\n    margin-bottom: var(--jp-widgets-input-padding);\n    align-self: stretch;\n    /* Override bootstrap style */\n    height: initial;\n}\n\n/* Vertical Progress */\n\n.widget-vprogress {\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vprogress .progress {\n    flex-grow: 1;\n    width: var(--jp-widgets-progress-thickness);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: 0;\n}\n\n/* Select Widget Styling */\n\n.widget-dropdown {\n    height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-dropdown > select {\n    padding-right: 20px;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-radius: 0;\n    height: inherit;\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    box-sizing: border-box;\n    outline: none !important;\n    box-shadow: none;\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    vertical-align: top;\n    padding-left: calc( var(--jp-widgets-input-padding) * 2);\n\tappearance: none;\n\t-webkit-appearance: none;\n\t-moz-appearance: none;\n    background-repeat: no-repeat;\n\tbackground-size: 20px;\n\tbackground-position: right center;\n    background-image: var(--jp-widgets-dropdown-arrow);\n}\n.widget-dropdown > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-dropdown > select:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* To disable the dotted border in Firefox around select controls.\n   See http://stackoverflow.com/a/18853002 */\n.widget-dropdown > select:-moz-focusring {\n    color: transparent;\n    text-shadow: 0 0 0 #000;\n}\n\n/* Select and SelectMultiple */\n\n.widget-select {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    align-items: flex-start;\n}\n\n.widget-select > select {\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    outline: none !important;\n    overflow: auto;\n    height: inherit;\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    padding-top: 5px;\n}\n\n.widget-select > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.wiget-select > select > option {\n    padding-left: var(--jp-widgets-input-padding);\n    line-height: var(--jp-widgets-inline-height);\n    /* line-height doesn't work on some browsers for select options */\n    padding-top: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n    padding-bottom: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n}\n\n\n\n/* Toggle Buttons Styling */\n\n.widget-toggle-buttons {\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-toggle-buttons .widget-toggle-button {\n    margin-left: var(--jp-widgets-margin);\n    margin-right: var(--jp-widgets-margin);\n}\n\n.widget-toggle-buttons .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Radio Buttons Styling */\n\n.widget-radio {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-radio-box {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n    box-sizing: border-box;\n    flex-grow: 1;\n    margin-bottom: var(--jp-widgets-radio-item-height-adjustment);\n}\n\n.widget-radio-box label {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-radio-box input {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    margin: 0 calc( var(--jp-widgets-input-padding) * 2 ) 0 1px;\n    float: left;\n}\n\n/* Color Picker Styling */\n\n.widget-colorpicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-colorpicker > .widget-colorpicker-input {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-colorpicker input[type=\"color\"] {\n    width: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n    padding: 0 2px; /* make the color square actually square on Chrome on OS X */\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-left: none;\n    flex-grow: 0;\n    flex-shrink: 0;\n    box-sizing: border-box;\n    align-self: stretch;\n    outline: none !important;\n}\n\n.widget-colorpicker.concise input[type=\"color\"] {\n    border-left: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n}\n\n.widget-colorpicker input[type=\"color\"]:focus, .widget-colorpicker input[type=\"text\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-colorpicker input[type=\"text\"] {\n    flex-grow: 1;\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    box-sizing: border-box;\n}\n\n.widget-colorpicker input[type=\"text\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Date Picker Styling */\n\n.widget-datepicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-datepicker input[type=\"date\"] {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    box-sizing: border-box;\n}\n\n.widget-datepicker input[type=\"date\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-datepicker input[type=\"date\"]:invalid {\n    border-color: var(--jp-warn-color1);\n}\n\n.widget-datepicker input[type=\"date\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Play Widget */\n\n.widget-play {\n    width: var(--jp-widgets-inline-width-short);\n    display: flex;\n    align-items: stretch;\n}\n\n.widget-play .jupyter-button {\n    flex-grow: 1;\n    height: auto;\n}\n\n.widget-play .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Tab Widget */\n\n.jupyter-widgets.widget-tab {\n    display: flex;\n    flex-direction: column;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */\n    overflow-x: visible;\n    overflow-y: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n    /* Make sure that the tab grows from bottom up */\n    align-items: flex-end;\n    min-width: 0;\n    min-height: 0;\n}\n\n.jupyter-widgets.widget-tab > .widget-tab-contents {\n    width: 100%;\n    box-sizing: border-box;\n    margin: 0;\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    padding: var(--jp-widgets-container-padding);\n    flex-grow: 1;\n    overflow: auto;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    font: var(--jp-widgets-font-size) Helvetica, Arial, sans-serif;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n    flex: 0 1 var(--jp-widgets-horizontal-tab-width);\n    min-width: 35px;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n    line-height: var(--jp-widgets-horizontal-tab-height);\n    margin-left: calc(-1 * var(--jp-border-width));\n    padding: 0px 10px;\n    background: var(--jp-layout-color2);\n    color: var(--jp-ui-font-color2);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    border-bottom: none;\n    position: relative;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {\n    color: var(--jp-ui-font-color0);\n    /* We want the background to match the tab content background */\n    background: var(--jp-layout-color1);\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + 2 * var(--jp-border-width));\n    transform: translateY(var(--jp-border-width));\n    overflow: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {\n    position: absolute;\n    top: calc(-1 * var(--jp-border-width));\n    left: calc(-1 * var(--jp-border-width));\n    content: '';\n    height: var(--jp-widgets-horizontal-tab-top-border);\n    width: calc(100% + 2 * var(--jp-border-width));\n    background: var(--jp-brand-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {\n    margin-left: 0;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {\n    margin-left: 4px;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {\n    font-family: FontAwesome;\n    content: '\\f00d'; /* close */\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n    line-height: var(--jp-widgets-horizontal-tab-height);\n}\n\n/* Accordion Widget */\n\n.p-Collapse {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Collapse-header {\n    padding: var(--jp-widgets-input-padding);\n    cursor: pointer;\n    color: var(--jp-ui-font-color2);\n    background-color: var(--jp-layout-color2);\n    border: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    padding: calc(var(--jp-widgets-container-padding) * 2 / 3) var(--jp-widgets-container-padding);\n    font-weight: bold;\n}\n\n.p-Collapse-header:hover {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.p-Collapse-open > .p-Collapse-header {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color0);\n    cursor: default;\n    border-bottom: none;\n}\n\n.p-Collapse .p-Collapse-header::before {\n    content: '\\f0da\\00A0';  /* caret-right, non-breaking space */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.p-Collapse-open > .p-Collapse-header::before {\n    content: '\\f0d7\\00A0'; /* caret-down, non-breaking space */\n}\n\n.p-Collapse-contents {\n    padding: var(--jp-widgets-container-padding);\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border-left: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-right: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-bottom: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    overflow: auto;\n}\n\n.p-Accordion {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Accordion .p-Collapse {\n    margin-bottom: 0;\n}\n\n.p-Accordion .p-Collapse + .p-Collapse {\n    margin-top: 4px;\n}\n\n\n\n/* HTML widget */\n\n.widget-html, .widget-htmlmath {\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {\n    /* Fill out the area in the HTML widget */\n    align-self: stretch;\n    flex-grow: 1;\n    flex-shrink: 1;\n    /* Makes sure the baseline is still aligned with other elements */\n    line-height: var(--jp-widgets-inline-height);\n    /* Make it possible to have absolutely-positioned elements in the html */\n    position: relative;\n}\n","/* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:\n\nCopyright (c) 2014-2017, PhosphorJS Contributors\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n  list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n  this list of conditions and the following disclaimer in the documentation\n  and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n  contributors may be used to endorse or promote products derived from\n  this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n*/\n\n/*\n * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css \n * We've scoped the rules so that they are consistent with exactly our code.\n */\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n  display: flex;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex: 1 1 auto;\n  list-style-type: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n  flex: 0 0 auto;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {\n  flex: 1 1 auto;\n  overflow: hidden;\n  white-space: nowrap;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {\n  display: none !important;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {\n  position: relative;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {\n  left: 0;\n  transition: left 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {\n  top: 0;\n  transition: top 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {\n  transition: none;\n}\n\n/* End tabbar.css */\n"]} */", "headers": [ [ "content-type", "text/css" ] ], "ok": true, "status": 200, "status_text": "" } } }, "colab_type": "code", "id": "lu7MqCrmMJxS", "outputId": "7b4c589d-f232-4f24-aeca-d7e4966d4625" }, "outputs": [ { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "72b90aa00ed648a69ae2d575b17ed642", "version_major": 2, "version_minor": 0 }, "text/plain": [ "HBox(children=(IntProgress(value=0, description='0/1(t)', max=1, style=ProgressStyle(description_width='initia…" ] }, "metadata": {}, "output_type": "display_data" }, { "name": "stdout", "output_type": "stream", "text": [ "New Key is here\n", "\n" ] } ], "source": [ "class TestModel2(nn.Module):\n", " def forward(self, x):\n", " return {torchbearer.Y_PRED: x, NEW_KEY: 'New Key is here'}\n", " \n", "unpacker = UnpackState(output_to_state=True)\n", "\n", "@torchbearer.callbacks.on_step_training\n", "def print_state(state):\n", " print(state[NEW_KEY])\n", "\n", "t = Trial(TestModel2(), callbacks=[unpacker, print_state])\n", "_ = t.with_train_data(torch.ones(10, 1), torch.ones(10, 1), batch_size=1, steps=1).run()" ] }, { "cell_type": "markdown", "metadata": { "colab_type": "text", "id": "W6x8QWoqJSIB" }, "source": [ "## Building a more Advanced Model\n", "\n", "One type of model that often needs to access state is a VAE. In this example we will take the same model from the VAE example notebook [here](https://torchbearer.readthedocs.io/en/latest/examples/notebooks.html#deep-learning) and run it with DataParallel across all available GPUs. \n", "\n", "We define a very similar model, but modified to utilise the UnpackState callback method rather than the full state dictionary. " ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "colab": {}, "colab_type": "code", "id": "lEuq9_6tJwuD" }, "outputs": [], "source": [ "import torch.nn as nn\n", "import torch.nn.functional as F\n", "\n", "MU, LOGVAR = torchbearer.state_key('mu'), torchbearer.state_key('logvar')\n", "\n", "class VAE(nn.Module):\n", " def __init__(self):\n", " super(VAE, self).__init__()\n", "\n", " self.fc1 = nn.Linear(784, 400)\n", " self.fc21 = nn.Linear(400, 20)\n", " self.fc22 = nn.Linear(400, 20)\n", " self.fc3 = nn.Linear(20, 400)\n", " self.fc4 = nn.Linear(400, 784)\n", "\n", " def encode(self, x):\n", " h1 = F.relu(self.fc1(x))\n", " return self.fc21(h1), self.fc22(h1)\n", "\n", " def reparameterize(self, mu, logvar):\n", " if self.training:\n", " std = torch.exp(0.5*logvar)\n", " eps = torch.randn_like(std)\n", " return eps.mul(std).add_(mu)\n", " else:\n", " return mu\n", "\n", " def decode(self, z):\n", " h3 = F.relu(self.fc3(z))\n", " return torch.sigmoid(self.fc4(h3)).view(-1, 1, 28, 28)\n", "\n", " def forward(self, x):\n", " mu, logvar = self.encode(x.view(-1, 784))\n", " z = self.reparameterize(mu, logvar)\n", " return {torchbearer.Y_PRED: self.decode(z), MU: mu, LOGVAR: logvar}" ] }, { "cell_type": "markdown", "metadata": { "colab_type": "text", "id": "AgBCUcikJ_rz" }, "source": [ "We now copy the loss functions and data related methods from the VAE example. " ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "colab": {}, "colab_type": "code", "id": "eHkWe00VJ5eo" }, "outputs": [], "source": [ "# LOSSES \n", "\n", "def binary_cross_entropy(y_pred, y_true):\n", " BCE = F.binary_cross_entropy(y_pred.view(-1, 784), y_true.view(-1, 784), reduction='sum').view(1) # DataParallel doesnt like size([]) tensors\n", " return BCE\n", " \n", "def kld(mu, logvar):\n", " KLD = -0.5 * torch.sum(1 + logvar - mu.pow(2) - logvar.exp())\n", " return KLD\n", "\n", "main_loss = binary_cross_entropy\n", "\n", "@torchbearer.callbacks.add_to_loss\n", "def add_kld_loss_callback(state):\n", " KLD = kld(state[MU], state[LOGVAR])\n", " return KLD\n", " \n", "# DATA\n", "from torch.utils.data.dataset import Dataset\n", "import torchvision\n", "from torchvision import transforms\n", "from torchbearer.cv_utils import DatasetValidationSplitter\n", "\n", "class AutoEncoderMNIST(Dataset):\n", " def __init__(self, mnist_dataset):\n", " super().__init__()\n", " self.mnist_dataset = mnist_dataset\n", "\n", " def __getitem__(self, index):\n", " character, label = self.mnist_dataset.__getitem__(index)\n", " return character, character\n", "\n", " def __len__(self):\n", " return len(self.mnist_dataset)\n", "\n", "\n", "BATCH_SIZE = 128\n", "transform = transforms.Compose([transforms.ToTensor()])\n", "\n", "# Define standard classification mnist dataset with random validation set\n", "dataset = torchvision.datasets.MNIST('./data/mnist', train=True, download=True, transform=transform)\n", "splitter = DatasetValidationSplitter(len(dataset), 0.1)\n", "basetrainset = splitter.get_train_dataset(dataset)\n", "basevalset = splitter.get_val_dataset(dataset)\n", "basetestset = torchvision.datasets.MNIST('./data/mnist', train=False, download=True, transform=transform)\n", "\n", "# Wrap base classification mnist dataset to return the image as the target\n", "trainset = AutoEncoderMNIST(basetrainset)\n", "valset = AutoEncoderMNIST(basevalset)\n", "testset = AutoEncoderMNIST(basetestset)\n", "\n", "traingen = torch.utils.data.DataLoader(trainset, batch_size=BATCH_SIZE, shuffle=True, num_workers=8)\n", "valgen = torch.utils.data.DataLoader(valset, batch_size=BATCH_SIZE, shuffle=True, num_workers=8)\n", "testgen = torch.utils.data.DataLoader(testset, batch_size=BATCH_SIZE, shuffle=False, num_workers=8)\n", "\n", "# IMAGING\n", "\n", "from torchbearer.callbacks import imaging\n", "\n", "targets = imaging.MakeGrid(torchbearer.TARGET, num_images=64, nrow=8)\n", "targets = targets.on_test().to_pyplot().to_file('targets.png')\n", "\n", "predictions = imaging.MakeGrid(torchbearer.PREDICTION, num_images=64, nrow=8)\n", "predictions = predictions.on_test().to_pyplot().to_file('predictions.png')" ] }, { "cell_type": "markdown", "metadata": { "colab_type": "text", "id": "PT7X6DavPFPA" }, "source": [ "Finally we can create the UnpackState callback and the Trial. \n", "\n", "We run with DataParallel across all the GPUs, which for this particular model is slower than just running on a single GPU, but for a very large model, this might be the only feasible way to run. " ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "colab": { "base_uri": "https://localhost:8080/", "height": 657, "resources": { "http://localhost:8080/nbextensions/google.colab/colabwidgets/controls.css": { "data": "/* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /* We import all of these together in a single css file because the Webpack
loader sees only one file at a time. This allows postcss to see the variable
definitions when they are used. */

 /*-----------------------------------------------------------------------------
| Copyright (c) Jupyter Development Team.
| Distributed under the terms of the Modified BSD License.
|----------------------------------------------------------------------------*/

 /*
This file is copied from the JupyterLab project to define default styling for
when the widget styling is compiled down to eliminate CSS variables. We make one
change - we comment out the font import below.
*/

 /**
 * The material design colors are adapted from google-material-color v1.2.6
 * https://github.com/danlevan/google-material-color
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css
 *
 * The license for the material design color CSS variables is as follows (see
 * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)
 *
 * The MIT License (MIT)
 *
 * Copyright (c) 2014 Dan Le Van
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

 /*
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.
*/

 /*
 * Optional monospace font for input/output prompt.
 */

 /* Commented out in ipywidgets since we don't need it. */

 /* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */

 /*
 * Added for compabitility with output area
 */

 :root {

  /* Borders

  The following variables, specify the visual styling of borders in JupyterLab.
   */

  /* 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.
  */ /* Base font size */ /* Ensures px perfect FontAwesome icons */

  /* Use these font colors against the corresponding main layout colors.
     In a light theme, these go from dark to light.
  */

  /* Use these against the brand/accent/warn/error colors.
     These will typically go from light to darker, in both a dark and light theme
   */

  /* Content Fonts

  Content font variables are used for typography of user generated content.
  */ /* Base font size */


  /* Layout

  The following are the main layout colors use in JupyterLab. In a light
  theme these would go from light to dark.
  */

  /* Brand/accent */

  /* State colors (warn, error, success, info) */

  /* Cell specific styles */
  /* A custom blend of MD grey and blue 600
   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */
  /* A custom blend of MD grey and orange 600
   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */

  /* Notebook specific styles */

  /* Console specific styles */

  /* Toolbar specific styles */
}

 /* Copyright (c) Jupyter Development Team.
 * Distributed under the terms of the Modified BSD License.
 */

 /*
 * We assume that the CSS variables in
 * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css
 * have been defined.
 */

 /* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:

Copyright (c) 2014-2017, PhosphorJS Contributors
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright notice, this
  list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above copyright notice,
  this list of conditions and the following disclaimer in the documentation
  and/or other materials provided with the distribution.

* Neither the name of the copyright holder nor the names of its
  contributors may be used to endorse or promote products derived from
  this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

*/

 /*
 * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css 
 * We've scoped the rules so that they are consistent with exactly our code.
 */

 .jupyter-widgets.widget-tab > .p-TabBar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  list-style-type: none;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

 .jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
  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-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  overflow: hidden;
  white-space: nowrap;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {
  display: none !important;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {
  position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {
  left: 0;
  -webkit-transition: left 150ms ease;
  transition: left 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {
  top: 0;
  -webkit-transition: top 150ms ease;
  transition: top 150ms ease;
}

 .jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {
  -webkit-transition: none;
  transition: none;
}

 /* End tabbar.css */

 :root { /* margin between inline elements */

    /* From Material Design Lite */
}

 .jupyter-widgets {
    margin: 2px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    color: black;
    overflow: visible;
}

 .jupyter-widgets.jupyter-widgets-disconnected::before {
    line-height: 28px;
    height: 28px;
}

 .jp-Output-result > .jupyter-widgets {
    margin-left: 0;
    margin-right: 0;
}

 /* vbox and hbox */

 .widget-inline-hbox {
    /* Horizontal widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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: baseline;
        -ms-flex-align: baseline;
            align-items: baseline;
}

 .widget-inline-vbox {
    /* Vertical Widgets */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    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;
}

 .widget-box {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0;
    overflow: auto;
}

 .widget-gridbox {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    display: grid;
    margin: 0;
    overflow: auto;
}

 .widget-hbox {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
}

 .widget-vbox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 /* General Button Styling */

 .jupyter-button {
    padding-left: 10px;
    padding-right: 10px;
    padding-top: 0px;
    padding-bottom: 0px;
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
    font-size: 13px;
    cursor: pointer;

    height: 28px;
    border: 0px solid;
    line-height: 28px;
    -webkit-box-shadow: none;
            box-shadow: none;

    color: rgba(0, 0, 0, .8);
    background-color: #EEEEEE;
    border-color: #E0E0E0;
    border: none;
}

 .jupyter-button i.fa {
    margin-right: 4px;
    pointer-events: none;
}

 .jupyter-button:empty:before {
    content: "\200b"; /* zero-width space */
}

 .jupyter-widgets.jupyter-button:disabled {
    opacity: 0.6;
}

 .jupyter-button i.fa.center {
    margin-right: 0;
}

 .jupyter-button:hover:enabled, .jupyter-button:focus:enabled {
    /* MD Lite 2dp shadow */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
            box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .14),
                0 3px 1px -2px rgba(0, 0, 0, .2),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .jupyter-button:active, .jupyter-button.mod-active {
    /* MD Lite 4dp shadow */
    -webkit-box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
            box-shadow: 0 4px 5px 0 rgba(0, 0, 0, .14),
                0 1px 10px 0 rgba(0, 0, 0, .12),
                0 2px 4px -1px rgba(0, 0, 0, .2);
    color: rgba(0, 0, 0, .8);
    background-color: #BDBDBD;
}

 .jupyter-button:focus:enabled {
    outline: 1px solid #64B5F6;
}

 /* Button "Primary" Styling */

 .jupyter-button.mod-primary {
    color: rgba(255, 255, 255, 1.0);
    background-color: #2196F3;
}

 .jupyter-button.mod-primary.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 .jupyter-button.mod-primary:active {
    color: rgba(255, 255, 255, 1);
    background-color: #1976D2;
}

 /* Button "Success" Styling */

 .jupyter-button.mod-success {
    color: rgba(255, 255, 255, 1.0);
    background-color: #4CAF50;
}

 .jupyter-button.mod-success.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 .jupyter-button.mod-success:active {
    color: rgba(255, 255, 255, 1);
    background-color: #388E3C;
 }

 /* Button "Info" Styling */

 .jupyter-button.mod-info {
    color: rgba(255, 255, 255, 1.0);
    background-color: #00BCD4;
}

 .jupyter-button.mod-info.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 .jupyter-button.mod-info:active {
    color: rgba(255, 255, 255, 1);
    background-color: #0097A7;
}

 /* Button "Warning" Styling */

 .jupyter-button.mod-warning {
    color: rgba(255, 255, 255, 1.0);
    background-color: #FF9800;
}

 .jupyter-button.mod-warning.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 .jupyter-button.mod-warning:active {
    color: rgba(255, 255, 255, 1);
    background-color: #F57C00;
}

 /* Button "Danger" Styling */

 .jupyter-button.mod-danger {
    color: rgba(255, 255, 255, 1.0);
    background-color: #F44336;
}

 .jupyter-button.mod-danger.mod-active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 .jupyter-button.mod-danger:active {
    color: rgba(255, 255, 255, 1);
    background-color: #D32F2F;
}

 /* Widget Button*/

 .widget-button, .widget-toggle-button {
    width: 148px;
}

 /* Widget Label Styling */

 /* Override Bootstrap label css */

 .jupyter-widgets label {
    margin-bottom: 0;
    margin-bottom: initial;
}

 .widget-label-basic {
    /* Basic Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-label {
    /* Label */
    color: black;
    font-size: 13px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 28px;
}

 .widget-inline-hbox .widget-label {
    /* Horizontal Widget Label */
    color: black;
    text-align: right;
    margin-right: 8px;
    width: 80px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
}

 .widget-inline-vbox .widget-label {
    /* Vertical Widget Label */
    color: black;
    text-align: center;
    line-height: 28px;
}

 /* Widget Readout Styling */

 .widget-readout {
    color: black;
    font-size: 13px;
    height: 28px;
    line-height: 28px;
    overflow: hidden;
    white-space: nowrap;
    text-align: center;
}

 .widget-readout.overflow {
    /* Overflowing Readout */

    /* From Material Design Lite
        shadow-key-umbra-opacity: 0.2;
        shadow-key-penumbra-opacity: 0.14;
        shadow-ambient-shadow-opacity: 0.12;
     */
    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                        0 3px 1px -2px rgba(0, 0, 0, .14),
                        0 1px 5px 0 rgba(0, 0, 0, .12);

    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, .2),
                0 3px 1px -2px rgba(0, 0, 0, .14),
                0 1px 5px 0 rgba(0, 0, 0, .12);
}

 .widget-inline-hbox .widget-readout {
    /* Horizontal Readout */
    text-align: center;
    max-width: 148px;
    min-width: 72px;
    margin-left: 4px;
}

 .widget-inline-vbox .widget-readout {
    /* Vertical Readout */
    margin-top: 4px;
    /* as wide as the widget */
    width: inherit;
}

 /* Widget Checkbox Styling */

 .widget-checkbox {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-checkbox input[type="checkbox"] {
    margin: 0px 8px 0px 0px;
    line-height: 28px;
    font-size: large;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -ms-flex-item-align: center;
        align-self: center;
}

 /* Widget Valid Styling */

 .widget-valid {
    height: 28px;
    line-height: 28px;
    width: 148px;
    font-size: 13px;
}

 .widget-valid i:before {
    line-height: 28px;
    margin-right: 4px;
    margin-left: 4px;

    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .widget-valid.mod-valid i:before {
    content: "\f00c";
    color: green;
}

 .widget-valid.mod-invalid i:before {
    content: "\f00d";
    color: red;
}

 .widget-valid.mod-valid .widget-valid-readout {
    display: none;
}

 /* Widget Text and TextArea Stying */

 .widget-textarea, .widget-text {
    width: 300px;
}

 .widget-text input[type="text"], .widget-text input[type="number"]{
    height: 28px;
    line-height: 28px;
}

 .widget-text input[type="text"]:disabled, .widget-text input[type="number"]:disabled, .widget-textarea textarea:disabled {
    opacity: 0.6;
}

 .widget-text input[type="text"], .widget-text input[type="number"], .widget-textarea textarea {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    outline: none !important;
}

 .widget-textarea textarea {
    height: inherit;
    width: inherit;
}

 .widget-text input:focus, .widget-textarea textarea:focus {
    border-color: #64B5F6;
}

 /* Widget Slider */

 .widget-slider .ui-slider {
    /* Slider Track */
    border: 1px solid #BDBDBD;
    background: #BDBDBD;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    position: relative;
    border-radius: 0px;
}

 .widget-slider .ui-slider .ui-slider-handle {
    /* Slider Handle */
    outline: none !important; /* focused slider handles are colored - see below */
    position: absolute;
    background-color: white;
    border: 1px solid #9E9E9E;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    z-index: 1;
    background-image: none; /* Override jquery-ui */
}

 /* Override jquery-ui */

 .widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {
    background-color: #2196F3;
    border: 1px solid #2196F3;
}

 .widget-slider .ui-slider .ui-slider-handle:active {
    background-color: #2196F3;
    border-color: #2196F3;
    z-index: 2;
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
}

 .widget-slider  .ui-slider .ui-slider-range {
    /* Interval between the two specified value of a double slider */
    position: absolute;
    background: #2196F3;
    z-index: 0;
}

 /* Shapes of Slider Handles */

 .widget-hslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-top: -7px;
    margin-left: -7px;
    border-radius: 50%;
    top: 0;
}

 .widget-vslider .ui-slider .ui-slider-handle {
    width: 16px;
    height: 16px;
    margin-bottom: -7px;
    margin-left: -7px;
    border-radius: 50%;
    left: 0;
}

 .widget-hslider .ui-slider .ui-slider-range {
    height: 8px;
    margin-top: -3px;
}

 .widget-vslider .ui-slider .ui-slider-range {
    width: 8px;
    margin-left: -3px;
}

 /* Horizontal Slider */

 .widget-hslider {
    width: 300px;
    height: 28px;
    line-height: 28px;

    /* Override the align-items baseline. This way, the description and readout
    still seem to align their baseline properly, and we don't have to have
    align-self: stretch in the .slider-container. */
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
}

 .widgets-slider .slider-container {
    overflow: visible;
}

 .widget-hslider .slider-container {
    height: 28px;
    margin-left: 6px;
    margin-right: 6px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
}

 .widget-hslider .ui-slider {
    /* Inner, invisible slide div */
    height: 4px;
    margin-top: 12px;
    width: 100%;
}

 /* Vertical Slider */

 .widget-vbox .widget-label {
    height: 28px;
    line-height: 28px;
}

 .widget-vslider {
    /* Vertical Slider */
    height: 200px;
    width: 72px;
}

 .widget-vslider .slider-container {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 6px;
    margin-top: 6px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .widget-vslider .ui-slider-vertical {
    /* Inner, invisible slide div */
    width: 4px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-left: auto;
    margin-right: auto;
}

 /* Widget Progress Styling */

 .progress-bar {
    -webkit-transition: none;
    transition: none;
}

 .progress-bar {
    height: 28px;
}

 .progress-bar {
    background-color: #2196F3;
}

 .progress-bar-success {
    background-color: #4CAF50;
}

 .progress-bar-info {
    background-color: #00BCD4;
}

 .progress-bar-warning {
    background-color: #FF9800;
}

 .progress-bar-danger {
    background-color: #F44336;
}

 .progress {
    background-color: #EEEEEE;
    border: none;
    -webkit-box-shadow: none;
            box-shadow: none;
}

 /* Horisontal Progress */

 .widget-hprogress {
    /* Progress Bar */
    height: 28px;
    line-height: 28px;
    width: 300px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;

}

 .widget-hprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-top: 4px;
    margin-bottom: 4px;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    /* Override bootstrap style */
    height: auto;
    height: initial;
}

 /* Vertical Progress */

 .widget-vprogress {
    height: 200px;
    width: 72px;
}

 .widget-vprogress .progress {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    width: 20px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0;
}

 /* Select Widget Styling */

 .widget-dropdown {
    height: 28px;
    width: 300px;
    line-height: 28px;
}

 .widget-dropdown > select {
    padding-right: 20px;
    border: 1px solid #9E9E9E;
    border-radius: 0;
    height: inherit;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    outline: none !important;
    -webkit-box-shadow: none;
            box-shadow: none;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    vertical-align: top;
    padding-left: 8px;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
    background-repeat: no-repeat;
	background-size: 20px;
	background-position: right center;
    background-image: url("data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg");
}

 .widget-dropdown > select:focus {
    border-color: #64B5F6;
}

 .widget-dropdown > select:disabled {
    opacity: 0.6;
}

 /* To disable the dotted border in Firefox around select controls.
   See http://stackoverflow.com/a/18853002 */

 .widget-dropdown > select:-moz-focusring {
    color: transparent;
    text-shadow: 0 0 0 #000;
}

 /* Select and SelectMultiple */

 .widget-select {
    width: 300px;
    line-height: 28px;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
}

 .widget-select > select {
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    -webkit-box-flex: 1;
        -ms-flex: 1 1 148px;
            flex: 1 1 148px;
    outline: none !important;
    overflow: auto;
    height: inherit;

    /* Because Firefox defines the baseline of a select as the bottom of the
    control, we align the entire control to the top and add padding to the
    select to get an approximate first line baseline alignment. */
    padding-top: 5px;
}

 .widget-select > select:focus {
    border-color: #64B5F6;
}

 .wiget-select > select > option {
    padding-left: 4px;
    line-height: 28px;
    /* line-height doesn't work on some browsers for select options */
    padding-top: calc(28px - var(--jp-widgets-font-size) / 2);
    padding-bottom: calc(28px - var(--jp-widgets-font-size) / 2);
}

 /* Toggle Buttons Styling */

 .widget-toggle-buttons {
    line-height: 28px;
}

 .widget-toggle-buttons .widget-toggle-button {
    margin-left: 2px;
    margin-right: 2px;
}

 .widget-toggle-buttons .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Radio Buttons Styling */

 .widget-radio {
    width: 300px;
    line-height: 28px;
}

 .widget-radio-box {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    margin-bottom: 8px;
}

 .widget-radio-box label {
    height: 20px;
    line-height: 20px;
    font-size: 13px;
}

 .widget-radio-box input {
    height: 20px;
    line-height: 20px;
    margin: 0 8px 0 1px;
    float: left;
}

 /* Color Picker Styling */

 .widget-colorpicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-colorpicker > .widget-colorpicker-input {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 72px;
}

 .widget-colorpicker input[type="color"] {
    width: 28px;
    height: 28px;
    padding: 0 2px; /* make the color square actually square on Chrome on OS X */
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    border-left: none;
    -webkit-box-flex: 0;
        -ms-flex-positive: 0;
            flex-grow: 0;
    -ms-flex-negative: 0;
        flex-shrink: 0;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    -ms-flex-item-align: stretch;
        align-self: stretch;
    outline: none !important;
}

 .widget-colorpicker.concise input[type="color"] {
    border-left: 1px solid #9E9E9E;
}

 .widget-colorpicker input[type="color"]:focus, .widget-colorpicker input[type="text"]:focus {
    border-color: #64B5F6;
}

 .widget-colorpicker input[type="text"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    outline: none !important;
    height: 28px;
    line-height: 28px;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    font-size: 13px;
    padding: 4px 8px;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    -ms-flex-negative: 1;
        flex-shrink: 1;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-colorpicker input[type="text"]:disabled {
    opacity: 0.6;
}

 /* Date Picker Styling */

 .widget-datepicker {
    width: 300px;
    height: 28px;
    line-height: 28px;
}

 .widget-datepicker input[type="date"] {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    min-width: 0; /* This makes it possible for the flexbox to shrink this input */
    outline: none !important;
    height: 28px;
    border: 1px solid #9E9E9E;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    font-size: 13px;
    padding: 4px 8px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
}

 .widget-datepicker input[type="date"]:focus {
    border-color: #64B5F6;
}

 .widget-datepicker input[type="date"]:invalid {
    border-color: #FF9800;
}

 .widget-datepicker input[type="date"]:disabled {
    opacity: 0.6;
}

 /* Play Widget */

 .widget-play {
    width: 148px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .widget-play .jupyter-button {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    height: auto;
}

 .widget-play .jupyter-button:disabled {
    opacity: 0.6;
}

 /* Tab Widget */

 .jupyter-widgets.widget-tab {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */
    overflow-x: visible;
    overflow-y: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {
    /* Make sure that the tab grows from bottom up */
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    min-width: 0;
    min-height: 0;
}

 .jupyter-widgets.widget-tab > .widget-tab-contents {
    width: 100%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    margin: 0;
    background: white;
    color: rgba(0, 0, 0, .8);
    border: 1px solid #9E9E9E;
    padding: 15px;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    overflow: auto;
}

 .jupyter-widgets.widget-tab > .p-TabBar {
    font: 13px Helvetica, Arial, sans-serif;
    min-height: 25px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 144px;
            flex: 0 1 144px;
    min-width: 35px;
    min-height: 25px;
    line-height: 24px;
    margin-left: -1px;
    padding: 0px 10px;
    background: #EEEEEE;
    color: rgba(0, 0, 0, .5);
    border: 1px solid #9E9E9E;
    border-bottom: none;
    position: relative;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {
    color: rgba(0, 0, 0, 1.0);
    /* We want the background to match the tab content background */
    background: white;
    min-height: 26px;
    -webkit-transform: translateY(1px);
            transform: translateY(1px);
    overflow: visible;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {
    position: absolute;
    top: -1px;
    left: -1px;
    content: '';
    height: 2px;
    width: calc(100% + 2px);
    background: #2196F3;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {
    margin-left: 0;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {
    background: white;
    color: rgba(0, 0, 0, .8);
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {
    margin-left: 4px;
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {
    font-family: FontAwesome;
    content: '\f00d'; /* close */
}

 .jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,
.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {
    line-height: 24px;
}

 /* Accordion Widget */

 .p-Collapse {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Collapse-header {
    padding: 4px;
    cursor: pointer;
    color: rgba(0, 0, 0, .5);
    background-color: #EEEEEE;
    border: 1px solid #9E9E9E;
    padding: 10px 15px;
    font-weight: bold;
}

 .p-Collapse-header:hover {
    background-color: white;
    color: rgba(0, 0, 0, .8);
}

 .p-Collapse-open > .p-Collapse-header {
    background-color: white;
    color: rgba(0, 0, 0, 1.0);
    cursor: default;
    border-bottom: none;
}

 .p-Collapse .p-Collapse-header::before {
    content: '\f0da\00A0';  /* caret-right, non-breaking space */
    display: inline-block;
    font: normal normal normal 14px/1 FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

 .p-Collapse-open > .p-Collapse-header::before {
    content: '\f0d7\00A0'; /* caret-down, non-breaking space */
}

 .p-Collapse-contents {
    padding: 15px;
    background-color: white;
    color: rgba(0, 0, 0, .8);
    border-left: 1px solid #9E9E9E;
    border-right: 1px solid #9E9E9E;
    border-bottom: 1px solid #9E9E9E;
    overflow: auto;
}

 .p-Accordion {
    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: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
}

 .p-Accordion .p-Collapse {
    margin-bottom: 0;
}

 .p-Accordion .p-Collapse + .p-Collapse {
    margin-top: 4px;
}

 /* HTML widget */

 .widget-html, .widget-htmlmath {
    font-size: 13px;
}

 .widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {
    /* Fill out the area in the HTML widget */
    -ms-flex-item-align: stretch;
        align-self: stretch;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    -ms-flex-negative: 1;
        flex-shrink: 1;
    /* Makes sure the baseline is still aligned with other elements */
    line-height: 28px;
    /* Make it possible to have absolutely-positioned elements in the html */
    position: relative;
}

/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../node_modules/@jupyter-widgets/controls/css/widgets.css","../node_modules/@jupyter-widgets/controls/css/labvariables.css","../node_modules/@jupyter-widgets/controls/css/materialcolors.css","../node_modules/@jupyter-widgets/controls/css/widgets-base.css","../node_modules/@jupyter-widgets/controls/css/phosphor.css"],"names":[],"mappings":"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","file":"controls.css","sourcesContent":["/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n /* We import all of these together in a single css file because the Webpack\nloader sees only one file at a time. This allows postcss to see the variable\ndefinitions when they are used. */\n\n@import \"./labvariables.css\";\n@import \"./widgets-base.css\";\n","/*-----------------------------------------------------------------------------\n| Copyright (c) Jupyter Development Team.\n| Distributed under the terms of the Modified BSD License.\n|----------------------------------------------------------------------------*/\n\n/*\nThis file is copied from the JupyterLab project to define default styling for\nwhen the widget styling is compiled down to eliminate CSS variables. We make one\nchange - we comment out the font import below.\n*/\n\n@import \"./materialcolors.css\";\n\n/*\nThe following CSS variables define the main, public API for styling JupyterLab.\nThese variables should be used by all plugins wherever possible. In other\nwords, plugins should not define custom colors, sizes, etc unless absolutely\nnecessary. This enables users to change the visual theme of JupyterLab\nby changing these variables.\n\nMany variables appear in an ordered sequence (0,1,2,3). These sequences\nare designed to work well together, so for example, `--jp-border-color1` should\nbe used with `--jp-layout-color1`. The numbers have the following meanings:\n\n* 0: super-primary, reserved for special emphasis\n* 1: primary, most important under normal situations\n* 2: secondary, next most important under normal situations\n* 3: tertiary, next most important under normal situations\n\nThroughout JupyterLab, we are mostly following principles from Google's\nMaterial Design when selecting colors. We are not, however, following\nall of MD as it is not optimized for dense, information rich UIs.\n*/\n\n\n/*\n * Optional monospace font for input/output prompt.\n */\n /* Commented out in ipywidgets since we don't need it. */\n/* @import url('https://fonts.googleapis.com/css?family=Roboto+Mono'); */\n\n/*\n * Added for compabitility with output area\n */\n:root {\n  --jp-icon-search: none;\n  --jp-ui-select-caret: none;\n}\n\n\n:root {\n\n  /* Borders\n\n  The following variables, specify the visual styling of borders in JupyterLab.\n   */\n\n  --jp-border-width: 1px;\n  --jp-border-color0: var(--md-grey-700);\n  --jp-border-color1: var(--md-grey-500);\n  --jp-border-color2: var(--md-grey-300);\n  --jp-border-color3: var(--md-grey-100);\n\n  /* UI Fonts\n\n  The UI font CSS variables are used for the typography all of the JupyterLab\n  user interface elements that are not directly user generated content.\n  */\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n  --jp-ui-icon-font-size: 14px; /* Ensures px perfect FontAwesome icons */\n  --jp-ui-font-family: \"Helvetica Neue\", Helvetica, Arial, sans-serif;\n\n  /* Use these font colors against the corresponding main layout colors.\n     In a light theme, these go from dark to light.\n  */\n\n  --jp-ui-font-color0: rgba(0,0,0,1.0);\n  --jp-ui-font-color1: rgba(0,0,0,0.8);\n  --jp-ui-font-color2: rgba(0,0,0,0.5);\n  --jp-ui-font-color3: rgba(0,0,0,0.3);\n\n  /* Use these against the brand/accent/warn/error colors.\n     These will typically go from light to darker, in both a dark and light theme\n   */\n\n  --jp-inverse-ui-font-color0: rgba(255,255,255,1);\n  --jp-inverse-ui-font-color1: rgba(255,255,255,1.0);\n  --jp-inverse-ui-font-color2: rgba(255,255,255,0.7);\n  --jp-inverse-ui-font-color3: rgba(255,255,255,0.5);\n\n  /* Content Fonts\n\n  Content font variables are used for typography of user generated content.\n  */\n\n  --jp-content-font-size: 13px;\n  --jp-content-line-height: 1.5;\n  --jp-content-font-color0: black;\n  --jp-content-font-color1: black;\n  --jp-content-font-color2: var(--md-grey-700);\n  --jp-content-font-color3: var(--md-grey-500);\n\n  --jp-ui-font-scale-factor: 1.2;\n  --jp-ui-font-size0: calc(var(--jp-ui-font-size1)/var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size1: 13px; /* Base font size */\n  --jp-ui-font-size2: calc(var(--jp-ui-font-size1)*var(--jp-ui-font-scale-factor));\n  --jp-ui-font-size3: calc(var(--jp-ui-font-size2)*var(--jp-ui-font-scale-factor));\n\n  --jp-code-font-size: 13px;\n  --jp-code-line-height: 1.307;\n  --jp-code-padding: 5px;\n  --jp-code-font-family: monospace;\n\n\n  /* Layout\n\n  The following are the main layout colors use in JupyterLab. In a light\n  theme these would go from light to dark.\n  */\n\n  --jp-layout-color0: white;\n  --jp-layout-color1: white;\n  --jp-layout-color2: var(--md-grey-200);\n  --jp-layout-color3: var(--md-grey-400);\n\n  /* Brand/accent */\n\n  --jp-brand-color0: var(--md-blue-700);\n  --jp-brand-color1: var(--md-blue-500);\n  --jp-brand-color2: var(--md-blue-300);\n  --jp-brand-color3: var(--md-blue-100);\n\n  --jp-accent-color0: var(--md-green-700);\n  --jp-accent-color1: var(--md-green-500);\n  --jp-accent-color2: var(--md-green-300);\n  --jp-accent-color3: var(--md-green-100);\n\n  /* State colors (warn, error, success, info) */\n\n  --jp-warn-color0: var(--md-orange-700);\n  --jp-warn-color1: var(--md-orange-500);\n  --jp-warn-color2: var(--md-orange-300);\n  --jp-warn-color3: var(--md-orange-100);\n\n  --jp-error-color0: var(--md-red-700);\n  --jp-error-color1: var(--md-red-500);\n  --jp-error-color2: var(--md-red-300);\n  --jp-error-color3: var(--md-red-100);\n\n  --jp-success-color0: var(--md-green-700);\n  --jp-success-color1: var(--md-green-500);\n  --jp-success-color2: var(--md-green-300);\n  --jp-success-color3: var(--md-green-100);\n\n  --jp-info-color0: var(--md-cyan-700);\n  --jp-info-color1: var(--md-cyan-500);\n  --jp-info-color2: var(--md-cyan-300);\n  --jp-info-color3: var(--md-cyan-100);\n\n  /* Cell specific styles */\n\n  --jp-cell-padding: 5px;\n  --jp-cell-editor-background: #f7f7f7;\n  --jp-cell-editor-border-color: #cfcfcf;\n  --jp-cell-editor-background-edit: var(--jp-ui-layout-color1);\n  --jp-cell-editor-border-color-edit: var(--jp-brand-color1);\n  --jp-cell-prompt-width: 100px;\n  --jp-cell-prompt-font-family: 'Roboto Mono', monospace;\n  --jp-cell-prompt-letter-spacing: 0px;\n  --jp-cell-prompt-opacity: 1.0;\n  --jp-cell-prompt-opacity-not-active: 0.4;\n  --jp-cell-prompt-font-color-not-active: var(--md-grey-700);\n  /* A custom blend of MD grey and blue 600\n   * See https://meyerweb.com/eric/tools/color-blend/#546E7A:1E88E5:5:hex */\n  --jp-cell-inprompt-font-color: #307FC1;\n  /* A custom blend of MD grey and orange 600\n   * https://meyerweb.com/eric/tools/color-blend/#546E7A:F4511E:5:hex */\n  --jp-cell-outprompt-font-color: #BF5B3D;\n\n  /* Notebook specific styles */\n\n  --jp-notebook-padding: 10px;\n  --jp-notebook-scroll-padding: 100px;\n\n  /* Console specific styles */\n\n  --jp-console-background: var(--md-grey-100);\n\n  /* Toolbar specific styles */\n\n  --jp-toolbar-border-color: var(--md-grey-400);\n  --jp-toolbar-micro-height: 8px;\n  --jp-toolbar-background: var(--jp-layout-color0);\n  --jp-toolbar-box-shadow: 0px 0px 2px 0px rgba(0,0,0,0.24);\n  --jp-toolbar-header-margin: 4px 4px 0px 4px;\n  --jp-toolbar-active-background: var(--md-grey-300);\n}\n","/**\n * The material design colors are adapted from google-material-color v1.2.6\n * https://github.com/danlevan/google-material-color\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/dist/palette.var.css\n *\n * The license for the material design color CSS variables is as follows (see\n * https://github.com/danlevan/google-material-color/blob/f67ca5f4028b2f1b34862f64b0ca67323f91b088/LICENSE)\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2014 Dan Le Van\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\n:root {\n  --md-red-50: #FFEBEE;\n  --md-red-100: #FFCDD2;\n  --md-red-200: #EF9A9A;\n  --md-red-300: #E57373;\n  --md-red-400: #EF5350;\n  --md-red-500: #F44336;\n  --md-red-600: #E53935;\n  --md-red-700: #D32F2F;\n  --md-red-800: #C62828;\n  --md-red-900: #B71C1C;\n  --md-red-A100: #FF8A80;\n  --md-red-A200: #FF5252;\n  --md-red-A400: #FF1744;\n  --md-red-A700: #D50000;\n\n  --md-pink-50: #FCE4EC;\n  --md-pink-100: #F8BBD0;\n  --md-pink-200: #F48FB1;\n  --md-pink-300: #F06292;\n  --md-pink-400: #EC407A;\n  --md-pink-500: #E91E63;\n  --md-pink-600: #D81B60;\n  --md-pink-700: #C2185B;\n  --md-pink-800: #AD1457;\n  --md-pink-900: #880E4F;\n  --md-pink-A100: #FF80AB;\n  --md-pink-A200: #FF4081;\n  --md-pink-A400: #F50057;\n  --md-pink-A700: #C51162;\n\n  --md-purple-50: #F3E5F5;\n  --md-purple-100: #E1BEE7;\n  --md-purple-200: #CE93D8;\n  --md-purple-300: #BA68C8;\n  --md-purple-400: #AB47BC;\n  --md-purple-500: #9C27B0;\n  --md-purple-600: #8E24AA;\n  --md-purple-700: #7B1FA2;\n  --md-purple-800: #6A1B9A;\n  --md-purple-900: #4A148C;\n  --md-purple-A100: #EA80FC;\n  --md-purple-A200: #E040FB;\n  --md-purple-A400: #D500F9;\n  --md-purple-A700: #AA00FF;\n\n  --md-deep-purple-50: #EDE7F6;\n  --md-deep-purple-100: #D1C4E9;\n  --md-deep-purple-200: #B39DDB;\n  --md-deep-purple-300: #9575CD;\n  --md-deep-purple-400: #7E57C2;\n  --md-deep-purple-500: #673AB7;\n  --md-deep-purple-600: #5E35B1;\n  --md-deep-purple-700: #512DA8;\n  --md-deep-purple-800: #4527A0;\n  --md-deep-purple-900: #311B92;\n  --md-deep-purple-A100: #B388FF;\n  --md-deep-purple-A200: #7C4DFF;\n  --md-deep-purple-A400: #651FFF;\n  --md-deep-purple-A700: #6200EA;\n\n  --md-indigo-50: #E8EAF6;\n  --md-indigo-100: #C5CAE9;\n  --md-indigo-200: #9FA8DA;\n  --md-indigo-300: #7986CB;\n  --md-indigo-400: #5C6BC0;\n  --md-indigo-500: #3F51B5;\n  --md-indigo-600: #3949AB;\n  --md-indigo-700: #303F9F;\n  --md-indigo-800: #283593;\n  --md-indigo-900: #1A237E;\n  --md-indigo-A100: #8C9EFF;\n  --md-indigo-A200: #536DFE;\n  --md-indigo-A400: #3D5AFE;\n  --md-indigo-A700: #304FFE;\n\n  --md-blue-50: #E3F2FD;\n  --md-blue-100: #BBDEFB;\n  --md-blue-200: #90CAF9;\n  --md-blue-300: #64B5F6;\n  --md-blue-400: #42A5F5;\n  --md-blue-500: #2196F3;\n  --md-blue-600: #1E88E5;\n  --md-blue-700: #1976D2;\n  --md-blue-800: #1565C0;\n  --md-blue-900: #0D47A1;\n  --md-blue-A100: #82B1FF;\n  --md-blue-A200: #448AFF;\n  --md-blue-A400: #2979FF;\n  --md-blue-A700: #2962FF;\n\n  --md-light-blue-50: #E1F5FE;\n  --md-light-blue-100: #B3E5FC;\n  --md-light-blue-200: #81D4FA;\n  --md-light-blue-300: #4FC3F7;\n  --md-light-blue-400: #29B6F6;\n  --md-light-blue-500: #03A9F4;\n  --md-light-blue-600: #039BE5;\n  --md-light-blue-700: #0288D1;\n  --md-light-blue-800: #0277BD;\n  --md-light-blue-900: #01579B;\n  --md-light-blue-A100: #80D8FF;\n  --md-light-blue-A200: #40C4FF;\n  --md-light-blue-A400: #00B0FF;\n  --md-light-blue-A700: #0091EA;\n\n  --md-cyan-50: #E0F7FA;\n  --md-cyan-100: #B2EBF2;\n  --md-cyan-200: #80DEEA;\n  --md-cyan-300: #4DD0E1;\n  --md-cyan-400: #26C6DA;\n  --md-cyan-500: #00BCD4;\n  --md-cyan-600: #00ACC1;\n  --md-cyan-700: #0097A7;\n  --md-cyan-800: #00838F;\n  --md-cyan-900: #006064;\n  --md-cyan-A100: #84FFFF;\n  --md-cyan-A200: #18FFFF;\n  --md-cyan-A400: #00E5FF;\n  --md-cyan-A700: #00B8D4;\n\n  --md-teal-50: #E0F2F1;\n  --md-teal-100: #B2DFDB;\n  --md-teal-200: #80CBC4;\n  --md-teal-300: #4DB6AC;\n  --md-teal-400: #26A69A;\n  --md-teal-500: #009688;\n  --md-teal-600: #00897B;\n  --md-teal-700: #00796B;\n  --md-teal-800: #00695C;\n  --md-teal-900: #004D40;\n  --md-teal-A100: #A7FFEB;\n  --md-teal-A200: #64FFDA;\n  --md-teal-A400: #1DE9B6;\n  --md-teal-A700: #00BFA5;\n\n  --md-green-50: #E8F5E9;\n  --md-green-100: #C8E6C9;\n  --md-green-200: #A5D6A7;\n  --md-green-300: #81C784;\n  --md-green-400: #66BB6A;\n  --md-green-500: #4CAF50;\n  --md-green-600: #43A047;\n  --md-green-700: #388E3C;\n  --md-green-800: #2E7D32;\n  --md-green-900: #1B5E20;\n  --md-green-A100: #B9F6CA;\n  --md-green-A200: #69F0AE;\n  --md-green-A400: #00E676;\n  --md-green-A700: #00C853;\n\n  --md-light-green-50: #F1F8E9;\n  --md-light-green-100: #DCEDC8;\n  --md-light-green-200: #C5E1A5;\n  --md-light-green-300: #AED581;\n  --md-light-green-400: #9CCC65;\n  --md-light-green-500: #8BC34A;\n  --md-light-green-600: #7CB342;\n  --md-light-green-700: #689F38;\n  --md-light-green-800: #558B2F;\n  --md-light-green-900: #33691E;\n  --md-light-green-A100: #CCFF90;\n  --md-light-green-A200: #B2FF59;\n  --md-light-green-A400: #76FF03;\n  --md-light-green-A700: #64DD17;\n\n  --md-lime-50: #F9FBE7;\n  --md-lime-100: #F0F4C3;\n  --md-lime-200: #E6EE9C;\n  --md-lime-300: #DCE775;\n  --md-lime-400: #D4E157;\n  --md-lime-500: #CDDC39;\n  --md-lime-600: #C0CA33;\n  --md-lime-700: #AFB42B;\n  --md-lime-800: #9E9D24;\n  --md-lime-900: #827717;\n  --md-lime-A100: #F4FF81;\n  --md-lime-A200: #EEFF41;\n  --md-lime-A400: #C6FF00;\n  --md-lime-A700: #AEEA00;\n\n  --md-yellow-50: #FFFDE7;\n  --md-yellow-100: #FFF9C4;\n  --md-yellow-200: #FFF59D;\n  --md-yellow-300: #FFF176;\n  --md-yellow-400: #FFEE58;\n  --md-yellow-500: #FFEB3B;\n  --md-yellow-600: #FDD835;\n  --md-yellow-700: #FBC02D;\n  --md-yellow-800: #F9A825;\n  --md-yellow-900: #F57F17;\n  --md-yellow-A100: #FFFF8D;\n  --md-yellow-A200: #FFFF00;\n  --md-yellow-A400: #FFEA00;\n  --md-yellow-A700: #FFD600;\n\n  --md-amber-50: #FFF8E1;\n  --md-amber-100: #FFECB3;\n  --md-amber-200: #FFE082;\n  --md-amber-300: #FFD54F;\n  --md-amber-400: #FFCA28;\n  --md-amber-500: #FFC107;\n  --md-amber-600: #FFB300;\n  --md-amber-700: #FFA000;\n  --md-amber-800: #FF8F00;\n  --md-amber-900: #FF6F00;\n  --md-amber-A100: #FFE57F;\n  --md-amber-A200: #FFD740;\n  --md-amber-A400: #FFC400;\n  --md-amber-A700: #FFAB00;\n\n  --md-orange-50: #FFF3E0;\n  --md-orange-100: #FFE0B2;\n  --md-orange-200: #FFCC80;\n  --md-orange-300: #FFB74D;\n  --md-orange-400: #FFA726;\n  --md-orange-500: #FF9800;\n  --md-orange-600: #FB8C00;\n  --md-orange-700: #F57C00;\n  --md-orange-800: #EF6C00;\n  --md-orange-900: #E65100;\n  --md-orange-A100: #FFD180;\n  --md-orange-A200: #FFAB40;\n  --md-orange-A400: #FF9100;\n  --md-orange-A700: #FF6D00;\n\n  --md-deep-orange-50: #FBE9E7;\n  --md-deep-orange-100: #FFCCBC;\n  --md-deep-orange-200: #FFAB91;\n  --md-deep-orange-300: #FF8A65;\n  --md-deep-orange-400: #FF7043;\n  --md-deep-orange-500: #FF5722;\n  --md-deep-orange-600: #F4511E;\n  --md-deep-orange-700: #E64A19;\n  --md-deep-orange-800: #D84315;\n  --md-deep-orange-900: #BF360C;\n  --md-deep-orange-A100: #FF9E80;\n  --md-deep-orange-A200: #FF6E40;\n  --md-deep-orange-A400: #FF3D00;\n  --md-deep-orange-A700: #DD2C00;\n\n  --md-brown-50: #EFEBE9;\n  --md-brown-100: #D7CCC8;\n  --md-brown-200: #BCAAA4;\n  --md-brown-300: #A1887F;\n  --md-brown-400: #8D6E63;\n  --md-brown-500: #795548;\n  --md-brown-600: #6D4C41;\n  --md-brown-700: #5D4037;\n  --md-brown-800: #4E342E;\n  --md-brown-900: #3E2723;\n\n  --md-grey-50: #FAFAFA;\n  --md-grey-100: #F5F5F5;\n  --md-grey-200: #EEEEEE;\n  --md-grey-300: #E0E0E0;\n  --md-grey-400: #BDBDBD;\n  --md-grey-500: #9E9E9E;\n  --md-grey-600: #757575;\n  --md-grey-700: #616161;\n  --md-grey-800: #424242;\n  --md-grey-900: #212121;\n\n  --md-blue-grey-50: #ECEFF1;\n  --md-blue-grey-100: #CFD8DC;\n  --md-blue-grey-200: #B0BEC5;\n  --md-blue-grey-300: #90A4AE;\n  --md-blue-grey-400: #78909C;\n  --md-blue-grey-500: #607D8B;\n  --md-blue-grey-600: #546E7A;\n  --md-blue-grey-700: #455A64;\n  --md-blue-grey-800: #37474F;\n  --md-blue-grey-900: #263238;\n}","/* Copyright (c) Jupyter Development Team.\n * Distributed under the terms of the Modified BSD License.\n */\n\n/*\n * We assume that the CSS variables in\n * https://github.com/jupyterlab/jupyterlab/blob/master/src/default-theme/variables.css\n * have been defined.\n */\n\n@import \"./phosphor.css\";\n\n:root {\n    --jp-widgets-color: var(--jp-content-font-color1);\n    --jp-widgets-label-color: var(--jp-widgets-color);\n    --jp-widgets-readout-color: var(--jp-widgets-color);\n    --jp-widgets-font-size: var(--jp-ui-font-size1);\n    --jp-widgets-margin: 2px;\n    --jp-widgets-inline-height: 28px;\n    --jp-widgets-inline-width: 300px;\n    --jp-widgets-inline-width-short: calc(var(--jp-widgets-inline-width) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-width-tiny: calc(var(--jp-widgets-inline-width-short) / 2 - var(--jp-widgets-margin));\n    --jp-widgets-inline-margin: 4px; /* margin between inline elements */\n    --jp-widgets-inline-label-width: 80px;\n    --jp-widgets-border-width: var(--jp-border-width);\n    --jp-widgets-vertical-height: 200px;\n    --jp-widgets-horizontal-tab-height: 24px;\n    --jp-widgets-horizontal-tab-width: 144px;\n    --jp-widgets-horizontal-tab-top-border: 2px;\n    --jp-widgets-progress-thickness: 20px;\n    --jp-widgets-container-padding: 15px;\n    --jp-widgets-input-padding: 4px;\n    --jp-widgets-radio-item-height-adjustment: 8px;\n    --jp-widgets-radio-item-height: calc(var(--jp-widgets-inline-height) - var(--jp-widgets-radio-item-height-adjustment));\n    --jp-widgets-slider-track-thickness: 4px;\n    --jp-widgets-slider-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-slider-handle-size: 16px;\n    --jp-widgets-slider-handle-border-color: var(--jp-border-color1);\n    --jp-widgets-slider-handle-background-color: var(--jp-layout-color1);\n    --jp-widgets-slider-active-handle-color: var(--jp-brand-color1);\n    --jp-widgets-menu-item-height: 24px;\n    --jp-widgets-dropdown-arrow: url(\"data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE5LjIuMSwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHZpZXdCb3g9IjAgMCAxOCAxOCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMTggMTg7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDpub25lO30KPC9zdHlsZT4KPHBhdGggZD0iTTUuMiw1LjlMOSw5LjdsMy44LTMuOGwxLjIsMS4ybC00LjksNWwtNC45LTVMNS4yLDUuOXoiLz4KPHBhdGggY2xhc3M9InN0MCIgZD0iTTAtMC42aDE4djE4SDBWLTAuNnoiLz4KPC9zdmc+Cg\");\n    --jp-widgets-input-color: var(--jp-ui-font-color1);\n    --jp-widgets-input-background-color: var(--jp-layout-color1);\n    --jp-widgets-input-border-color: var(--jp-border-color1);\n    --jp-widgets-input-focus-border-color: var(--jp-brand-color2);\n    --jp-widgets-input-border-width: var(--jp-widgets-border-width);\n    --jp-widgets-disabled-opacity: 0.6;\n\n    /* From Material Design Lite */\n    --md-shadow-key-umbra-opacity: 0.2;\n    --md-shadow-key-penumbra-opacity: 0.14;\n    --md-shadow-ambient-shadow-opacity: 0.12;\n}\n\n.jupyter-widgets {\n    margin: var(--jp-widgets-margin);\n    box-sizing: border-box;\n    color: var(--jp-widgets-color);\n    overflow: visible;\n}\n\n.jupyter-widgets.jupyter-widgets-disconnected::before {\n    line-height: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n}\n\n.jp-Output-result > .jupyter-widgets {\n    margin-left: 0;\n    margin-right: 0;\n}\n\n/* vbox and hbox */\n\n.widget-inline-hbox {\n    /* Horizontal widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: row;\n    align-items: baseline;\n}\n\n.widget-inline-vbox {\n    /* Vertical Widgets */\n    box-sizing: border-box;\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n}\n\n.widget-box {\n    box-sizing: border-box;\n    display: flex;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-gridbox {\n    box-sizing: border-box;\n    display: grid;\n    margin: 0;\n    overflow: auto;\n}\n\n.widget-hbox {\n    flex-direction: row;\n}\n\n.widget-vbox {\n    flex-direction: column;\n}\n\n/* General Button Styling */\n\n.jupyter-button {\n    padding-left: 10px;\n    padding-right: 10px;\n    padding-top: 0px;\n    padding-bottom: 0px;\n    display: inline-block;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    text-align: center;\n    font-size: var(--jp-widgets-font-size);\n    cursor: pointer;\n\n    height: var(--jp-widgets-inline-height);\n    border: 0px solid;\n    line-height: var(--jp-widgets-inline-height);\n    box-shadow: none;\n\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color2);\n    border-color: var(--jp-border-color2);\n    border: none;\n}\n\n.jupyter-button i.fa {\n    margin-right: var(--jp-widgets-inline-margin);\n    pointer-events: none;\n}\n\n.jupyter-button:empty:before {\n    content: \"\\200b\"; /* zero-width space */\n}\n\n.jupyter-widgets.jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.jupyter-button i.fa.center {\n    margin-right: 0;\n}\n\n.jupyter-button:hover:enabled, .jupyter-button:focus:enabled {\n    /* MD Lite 2dp shadow */\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 3px 1px -2px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity)),\n                0 1px 5px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity));\n}\n\n.jupyter-button:active, .jupyter-button.mod-active {\n    /* MD Lite 4dp shadow */\n    box-shadow: 0 4px 5px 0 rgba(0, 0, 0, var(--md-shadow-key-penumbra-opacity)),\n                0 1px 10px 0 rgba(0, 0, 0, var(--md-shadow-ambient-shadow-opacity)),\n                0 2px 4px -1px rgba(0, 0, 0, var(--md-shadow-key-umbra-opacity));\n    color: var(--jp-ui-font-color1);\n    background-color: var(--jp-layout-color3);\n}\n\n.jupyter-button:focus:enabled {\n    outline: 1px solid var(--jp-widgets-input-focus-border-color);\n}\n\n/* Button \"Primary\" Styling */\n\n.jupyter-button.mod-primary {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-brand-color1);\n}\n\n.jupyter-button.mod-primary.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n.jupyter-button.mod-primary:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-brand-color0);\n}\n\n/* Button \"Success\" Styling */\n\n.jupyter-button.mod-success {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-success-color1);\n}\n\n.jupyter-button.mod-success.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n.jupyter-button.mod-success:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-success-color0);\n }\n\n /* Button \"Info\" Styling */\n\n.jupyter-button.mod-info {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-info-color1);\n}\n\n.jupyter-button.mod-info.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n.jupyter-button.mod-info:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-info-color0);\n}\n\n/* Button \"Warning\" Styling */\n\n.jupyter-button.mod-warning {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-warn-color1);\n}\n\n.jupyter-button.mod-warning.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n.jupyter-button.mod-warning:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-warn-color0);\n}\n\n/* Button \"Danger\" Styling */\n\n.jupyter-button.mod-danger {\n    color: var(--jp-inverse-ui-font-color1);\n    background-color: var(--jp-error-color1);\n}\n\n.jupyter-button.mod-danger.mod-active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n.jupyter-button.mod-danger:active {\n    color: var(--jp-inverse-ui-font-color0);\n    background-color: var(--jp-error-color0);\n}\n\n/* Widget Button*/\n\n.widget-button, .widget-toggle-button {\n    width: var(--jp-widgets-inline-width-short);\n}\n\n/* Widget Label Styling */\n\n/* Override Bootstrap label css */\n.jupyter-widgets label {\n    margin-bottom: initial;\n}\n\n.widget-label-basic {\n    /* Basic Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-label {\n    /* Label */\n    color: var(--jp-widgets-label-color);\n    font-size: var(--jp-widgets-font-size);\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-inline-hbox .widget-label {\n    /* Horizontal Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: right;\n    margin-right: calc( var(--jp-widgets-inline-margin) * 2 );\n    width: var(--jp-widgets-inline-label-width);\n    flex-shrink: 0;\n}\n\n.widget-inline-vbox .widget-label {\n    /* Vertical Widget Label */\n    color: var(--jp-widgets-label-color);\n    text-align: center;\n    line-height: var(--jp-widgets-inline-height);\n}\n\n/* Widget Readout Styling */\n\n.widget-readout {\n    color: var(--jp-widgets-readout-color);\n    font-size: var(--jp-widgets-font-size);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    overflow: hidden;\n    white-space: nowrap;\n    text-align: center;\n}\n\n.widget-readout.overflow {\n    /* Overflowing Readout */\n\n    /* From Material Design Lite\n        shadow-key-umbra-opacity: 0.2;\n        shadow-key-penumbra-opacity: 0.14;\n        shadow-ambient-shadow-opacity: 0.12;\n     */\n    -webkit-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                        0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                        0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    -moz-box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                     0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                     0 1px 5px 0 rgba(0, 0, 0, 0.12);\n\n    box-shadow: 0 2px 2px 0 rgba(0, 0, 0, 0.2),\n                0 3px 1px -2px rgba(0, 0, 0, 0.14),\n                0 1px 5px 0 rgba(0, 0, 0, 0.12);\n}\n\n.widget-inline-hbox .widget-readout {\n    /* Horizontal Readout */\n    text-align: center;\n    max-width: var(--jp-widgets-inline-width-short);\n    min-width: var(--jp-widgets-inline-width-tiny);\n    margin-left: var(--jp-widgets-inline-margin);\n}\n\n.widget-inline-vbox .widget-readout {\n    /* Vertical Readout */\n    margin-top: var(--jp-widgets-inline-margin);\n    /* as wide as the widget */\n    width: inherit;\n}\n\n/* Widget Checkbox Styling */\n\n.widget-checkbox {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-checkbox input[type=\"checkbox\"] {\n    margin: 0px calc( var(--jp-widgets-inline-margin) * 2 ) 0px 0px;\n    line-height: var(--jp-widgets-inline-height);\n    font-size: large;\n    flex-grow: 1;\n    flex-shrink: 0;\n    align-self: center;\n}\n\n/* Widget Valid Styling */\n\n.widget-valid {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width-short);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-valid i:before {\n    line-height: var(--jp-widgets-inline-height);\n    margin-right: var(--jp-widgets-inline-margin);\n    margin-left: var(--jp-widgets-inline-margin);\n\n    /* from the fa class in FontAwesome: https://github.com/FortAwesome/Font-Awesome/blob/49100c7c3a7b58d50baa71efef11af41a66b03d3/css/font-awesome.css#L14 */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.widget-valid.mod-valid i:before {\n    content: \"\\f00c\";\n    color: green;\n}\n\n.widget-valid.mod-invalid i:before {\n    content: \"\\f00d\";\n    color: red;\n}\n\n.widget-valid.mod-valid .widget-valid-readout {\n    display: none;\n}\n\n/* Widget Text and TextArea Stying */\n\n.widget-textarea, .widget-text {\n    width: var(--jp-widgets-inline-width);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"]{\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-text input[type=\"text\"]:disabled, .widget-text input[type=\"number\"]:disabled, .widget-textarea textarea:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n.widget-text input[type=\"text\"], .widget-text input[type=\"number\"], .widget-textarea textarea {\n    box-sizing: border-box;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    flex-grow: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    outline: none !important;\n}\n\n.widget-textarea textarea {\n    height: inherit;\n    width: inherit;\n}\n\n.widget-text input:focus, .widget-textarea textarea:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n/* Widget Slider */\n\n.widget-slider .ui-slider {\n    /* Slider Track */\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-layout-color3);\n    background: var(--jp-layout-color3);\n    box-sizing: border-box;\n    position: relative;\n    border-radius: 0px;\n}\n\n.widget-slider .ui-slider .ui-slider-handle {\n    /* Slider Handle */\n    outline: none !important; /* focused slider handles are colored - see below */\n    position: absolute;\n    background-color: var(--jp-widgets-slider-handle-background-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-handle-border-color);\n    box-sizing: border-box;\n    z-index: 1;\n    background-image: none; /* Override jquery-ui */\n}\n\n/* Override jquery-ui */\n.widget-slider .ui-slider .ui-slider-handle:hover, .widget-slider .ui-slider .ui-slider-handle:focus {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border: var(--jp-widgets-slider-border-width) solid var(--jp-widgets-slider-active-handle-color);\n}\n\n.widget-slider .ui-slider .ui-slider-handle:active {\n    background-color: var(--jp-widgets-slider-active-handle-color);\n    border-color: var(--jp-widgets-slider-active-handle-color);\n    z-index: 2;\n    transform: scale(1.2);\n}\n\n.widget-slider  .ui-slider .ui-slider-range {\n    /* Interval between the two specified value of a double slider */\n    position: absolute;\n    background: var(--jp-widgets-slider-active-handle-color);\n    z-index: 0;\n}\n\n/* Shapes of Slider Handles */\n\n.widget-hslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    top: 0;\n}\n\n.widget-vslider .ui-slider .ui-slider-handle {\n    width: var(--jp-widgets-slider-handle-size);\n    height: var(--jp-widgets-slider-handle-size);\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / -2 + var(--jp-widgets-slider-border-width));\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-handle-size)) / 2 - var(--jp-widgets-slider-border-width));\n    border-radius: 50%;\n    left: 0;\n}\n\n.widget-hslider .ui-slider .ui-slider-range {\n    height: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-top: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n.widget-vslider .ui-slider .ui-slider-range {\n    width: calc( var(--jp-widgets-slider-track-thickness) * 2 );\n    margin-left: calc((var(--jp-widgets-slider-track-thickness) - var(--jp-widgets-slider-track-thickness) * 2 ) / 2 - var(--jp-widgets-slider-border-width));\n}\n\n/* Horizontal Slider */\n\n.widget-hslider {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Override the align-items baseline. This way, the description and readout\n    still seem to align their baseline properly, and we don't have to have\n    align-self: stretch in the .slider-container. */\n    align-items: center;\n}\n\n.widgets-slider .slider-container {\n    overflow: visible;\n}\n\n.widget-hslider .slider-container {\n    height: var(--jp-widgets-inline-height);\n    margin-left: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-right: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n}\n\n.widget-hslider .ui-slider {\n    /* Inner, invisible slide div */\n    height: var(--jp-widgets-slider-track-thickness);\n    margin-top: calc((var(--jp-widgets-inline-height) - var(--jp-widgets-slider-track-thickness)) / 2);\n    width: 100%;\n}\n\n/* Vertical Slider */\n\n.widget-vbox .widget-label {\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-vslider {\n    /* Vertical Slider */\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vslider .slider-container {\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    margin-top: calc(var(--jp-widgets-slider-handle-size) / 2 - 2 * var(--jp-widgets-slider-border-width));\n    display: flex;\n    flex-direction: column;\n}\n\n.widget-vslider .ui-slider-vertical {\n    /* Inner, invisible slide div */\n    width: var(--jp-widgets-slider-track-thickness);\n    flex-grow: 1;\n    margin-left: auto;\n    margin-right: auto;\n}\n\n/* Widget Progress Styling */\n\n.progress-bar {\n    -webkit-transition: none;\n    -moz-transition: none;\n    -ms-transition: none;\n    -o-transition: none;\n    transition: none;\n}\n\n.progress-bar {\n    height: var(--jp-widgets-inline-height);\n}\n\n.progress-bar {\n    background-color: var(--jp-brand-color1);\n}\n\n.progress-bar-success {\n    background-color: var(--jp-success-color1);\n}\n\n.progress-bar-info {\n    background-color: var(--jp-info-color1);\n}\n\n.progress-bar-warning {\n    background-color: var(--jp-warn-color1);\n}\n\n.progress-bar-danger {\n    background-color: var(--jp-error-color1);\n}\n\n.progress {\n    background-color: var(--jp-layout-color2);\n    border: none;\n    box-shadow: none;\n}\n\n/* Horisontal Progress */\n\n.widget-hprogress {\n    /* Progress Bar */\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    align-items: center;\n\n}\n\n.widget-hprogress .progress {\n    flex-grow: 1;\n    margin-top: var(--jp-widgets-input-padding);\n    margin-bottom: var(--jp-widgets-input-padding);\n    align-self: stretch;\n    /* Override bootstrap style */\n    height: initial;\n}\n\n/* Vertical Progress */\n\n.widget-vprogress {\n    height: var(--jp-widgets-vertical-height);\n    width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-vprogress .progress {\n    flex-grow: 1;\n    width: var(--jp-widgets-progress-thickness);\n    margin-left: auto;\n    margin-right: auto;\n    margin-bottom: 0;\n}\n\n/* Select Widget Styling */\n\n.widget-dropdown {\n    height: var(--jp-widgets-inline-height);\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-dropdown > select {\n    padding-right: 20px;\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-radius: 0;\n    height: inherit;\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    box-sizing: border-box;\n    outline: none !important;\n    box-shadow: none;\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    vertical-align: top;\n    padding-left: calc( var(--jp-widgets-input-padding) * 2);\n\tappearance: none;\n\t-webkit-appearance: none;\n\t-moz-appearance: none;\n    background-repeat: no-repeat;\n\tbackground-size: 20px;\n\tbackground-position: right center;\n    background-image: var(--jp-widgets-dropdown-arrow);\n}\n.widget-dropdown > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-dropdown > select:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* To disable the dotted border in Firefox around select controls.\n   See http://stackoverflow.com/a/18853002 */\n.widget-dropdown > select:-moz-focusring {\n    color: transparent;\n    text-shadow: 0 0 0 #000;\n}\n\n/* Select and SelectMultiple */\n\n.widget-select {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    align-items: flex-start;\n}\n\n.widget-select > select {\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    flex: 1 1 var(--jp-widgets-inline-width-short);\n    outline: none !important;\n    overflow: auto;\n    height: inherit;\n\n    /* Because Firefox defines the baseline of a select as the bottom of the\n    control, we align the entire control to the top and add padding to the\n    select to get an approximate first line baseline alignment. */\n    padding-top: 5px;\n}\n\n.widget-select > select:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.wiget-select > select > option {\n    padding-left: var(--jp-widgets-input-padding);\n    line-height: var(--jp-widgets-inline-height);\n    /* line-height doesn't work on some browsers for select options */\n    padding-top: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n    padding-bottom: calc(var(--jp-widgets-inline-height)-var(--jp-widgets-font-size)/2);\n}\n\n\n\n/* Toggle Buttons Styling */\n\n.widget-toggle-buttons {\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-toggle-buttons .widget-toggle-button {\n    margin-left: var(--jp-widgets-margin);\n    margin-right: var(--jp-widgets-margin);\n}\n\n.widget-toggle-buttons .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Radio Buttons Styling */\n\n.widget-radio {\n    width: var(--jp-widgets-inline-width);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-radio-box {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n    box-sizing: border-box;\n    flex-grow: 1;\n    margin-bottom: var(--jp-widgets-radio-item-height-adjustment);\n}\n\n.widget-radio-box label {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-radio-box input {\n    height: var(--jp-widgets-radio-item-height);\n    line-height: var(--jp-widgets-radio-item-height);\n    margin: 0 calc( var(--jp-widgets-input-padding) * 2 ) 0 1px;\n    float: left;\n}\n\n/* Color Picker Styling */\n\n.widget-colorpicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-colorpicker > .widget-colorpicker-input {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: var(--jp-widgets-inline-width-tiny);\n}\n\n.widget-colorpicker input[type=\"color\"] {\n    width: var(--jp-widgets-inline-height);\n    height: var(--jp-widgets-inline-height);\n    padding: 0 2px; /* make the color square actually square on Chrome on OS X */\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    border-left: none;\n    flex-grow: 0;\n    flex-shrink: 0;\n    box-sizing: border-box;\n    align-self: stretch;\n    outline: none !important;\n}\n\n.widget-colorpicker.concise input[type=\"color\"] {\n    border-left: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n}\n\n.widget-colorpicker input[type=\"color\"]:focus, .widget-colorpicker input[type=\"text\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-colorpicker input[type=\"text\"] {\n    flex-grow: 1;\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n    background: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    flex-shrink: 1;\n    box-sizing: border-box;\n}\n\n.widget-colorpicker input[type=\"text\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Date Picker Styling */\n\n.widget-datepicker {\n    width: var(--jp-widgets-inline-width);\n    height: var(--jp-widgets-inline-height);\n    line-height: var(--jp-widgets-inline-height);\n}\n\n.widget-datepicker input[type=\"date\"] {\n    flex-grow: 1;\n    flex-shrink: 1;\n    min-width: 0; /* This makes it possible for the flexbox to shrink this input */\n    outline: none !important;\n    height: var(--jp-widgets-inline-height);\n    border: var(--jp-widgets-input-border-width) solid var(--jp-widgets-input-border-color);\n    background-color: var(--jp-widgets-input-background-color);\n    color: var(--jp-widgets-input-color);\n    font-size: var(--jp-widgets-font-size);\n    padding: var(--jp-widgets-input-padding) calc( var(--jp-widgets-input-padding) *  2 );\n    box-sizing: border-box;\n}\n\n.widget-datepicker input[type=\"date\"]:focus {\n    border-color: var(--jp-widgets-input-focus-border-color);\n}\n\n.widget-datepicker input[type=\"date\"]:invalid {\n    border-color: var(--jp-warn-color1);\n}\n\n.widget-datepicker input[type=\"date\"]:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Play Widget */\n\n.widget-play {\n    width: var(--jp-widgets-inline-width-short);\n    display: flex;\n    align-items: stretch;\n}\n\n.widget-play .jupyter-button {\n    flex-grow: 1;\n    height: auto;\n}\n\n.widget-play .jupyter-button:disabled {\n    opacity: var(--jp-widgets-disabled-opacity);\n}\n\n/* Tab Widget */\n\n.jupyter-widgets.widget-tab {\n    display: flex;\n    flex-direction: column;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    /* Necessary so that a tab can be shifted down to overlay the border of the box below. */\n    overflow-x: visible;\n    overflow-y: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n    /* Make sure that the tab grows from bottom up */\n    align-items: flex-end;\n    min-width: 0;\n    min-height: 0;\n}\n\n.jupyter-widgets.widget-tab > .widget-tab-contents {\n    width: 100%;\n    box-sizing: border-box;\n    margin: 0;\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    padding: var(--jp-widgets-container-padding);\n    flex-grow: 1;\n    overflow: auto;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n    font: var(--jp-widgets-font-size) Helvetica, Arial, sans-serif;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n    flex: 0 1 var(--jp-widgets-horizontal-tab-width);\n    min-width: 35px;\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + var(--jp-border-width));\n    line-height: var(--jp-widgets-horizontal-tab-height);\n    margin-left: calc(-1 * var(--jp-border-width));\n    padding: 0px 10px;\n    background: var(--jp-layout-color2);\n    color: var(--jp-ui-font-color2);\n    border: var(--jp-border-width) solid var(--jp-border-color1);\n    border-bottom: none;\n    position: relative;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current {\n    color: var(--jp-ui-font-color0);\n    /* We want the background to match the tab content background */\n    background: var(--jp-layout-color1);\n    min-height: calc(var(--jp-widgets-horizontal-tab-height) + 2 * var(--jp-border-width));\n    transform: translateY(var(--jp-border-width));\n    overflow: visible;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-current:before {\n    position: absolute;\n    top: calc(-1 * var(--jp-border-width));\n    left: calc(-1 * var(--jp-border-width));\n    content: '';\n    height: var(--jp-widgets-horizontal-tab-top-border);\n    width: calc(100% + 2 * var(--jp-border-width));\n    background: var(--jp-brand-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:first-child {\n    margin-left: 0;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab:hover:not(.p-mod-current) {\n    background: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon {\n    margin-left: 4px;\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-mod-closable > .p-TabBar-tabCloseIcon:before {\n    font-family: FontAwesome;\n    content: '\\f00d'; /* close */\n}\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n    line-height: var(--jp-widgets-horizontal-tab-height);\n}\n\n/* Accordion Widget */\n\n.p-Collapse {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Collapse-header {\n    padding: var(--jp-widgets-input-padding);\n    cursor: pointer;\n    color: var(--jp-ui-font-color2);\n    background-color: var(--jp-layout-color2);\n    border: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    padding: calc(var(--jp-widgets-container-padding) * 2 / 3) var(--jp-widgets-container-padding);\n    font-weight: bold;\n}\n\n.p-Collapse-header:hover {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n}\n\n.p-Collapse-open > .p-Collapse-header {\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color0);\n    cursor: default;\n    border-bottom: none;\n}\n\n.p-Collapse .p-Collapse-header::before {\n    content: '\\f0da\\00A0';  /* caret-right, non-breaking space */\n    display: inline-block;\n    font: normal normal normal 14px/1 FontAwesome;\n    font-size: inherit;\n    text-rendering: auto;\n    -webkit-font-smoothing: antialiased;\n    -moz-osx-font-smoothing: grayscale;\n}\n\n.p-Collapse-open > .p-Collapse-header::before {\n    content: '\\f0d7\\00A0'; /* caret-down, non-breaking space */\n}\n\n.p-Collapse-contents {\n    padding: var(--jp-widgets-container-padding);\n    background-color: var(--jp-layout-color1);\n    color: var(--jp-ui-font-color1);\n    border-left: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-right: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    border-bottom: var(--jp-widgets-border-width) solid var(--jp-border-color1);\n    overflow: auto;\n}\n\n.p-Accordion {\n    display: flex;\n    flex-direction: column;\n    align-items: stretch;\n}\n\n.p-Accordion .p-Collapse {\n    margin-bottom: 0;\n}\n\n.p-Accordion .p-Collapse + .p-Collapse {\n    margin-top: 4px;\n}\n\n\n\n/* HTML widget */\n\n.widget-html, .widget-htmlmath {\n    font-size: var(--jp-widgets-font-size);\n}\n\n.widget-html > .widget-html-content, .widget-htmlmath > .widget-html-content {\n    /* Fill out the area in the HTML widget */\n    align-self: stretch;\n    flex-grow: 1;\n    flex-shrink: 1;\n    /* Makes sure the baseline is still aligned with other elements */\n    line-height: var(--jp-widgets-inline-height);\n    /* Make it possible to have absolutely-positioned elements in the html */\n    position: relative;\n}\n","/* This file has code derived from PhosphorJS CSS files, as noted below. The license for this PhosphorJS code is:\n\nCopyright (c) 2014-2017, PhosphorJS Contributors\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n* Redistributions of source code must retain the above copyright notice, this\n  list of conditions and the following disclaimer.\n\n* Redistributions in binary form must reproduce the above copyright notice,\n  this list of conditions and the following disclaimer in the documentation\n  and/or other materials provided with the distribution.\n\n* Neither the name of the copyright holder nor the names of its\n  contributors may be used to endorse or promote products derived from\n  this software without specific prior written permission.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\nAND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\nIMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n\n*/\n\n/*\n * The following section is derived from https://github.com/phosphorjs/phosphor/blob/23b9d075ebc5b73ab148b6ebfc20af97f85714c4/packages/widgets/style/tabbar.css \n * We've scoped the rules so that they are consistent with exactly our code.\n */\n\n.jupyter-widgets.widget-tab > .p-TabBar {\n  display: flex;\n  -webkit-user-select: none;\n  -moz-user-select: none;\n  -ms-user-select: none;\n  user-select: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar > .p-TabBar-content {\n  margin: 0;\n  padding: 0;\n  display: flex;\n  flex: 1 1 auto;\n  list-style-type: none;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='horizontal'] > .p-TabBar-content {\n  flex-direction: row;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar[data-orientation='vertical'] > .p-TabBar-content {\n  flex-direction: column;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab {\n  display: flex;\n  flex-direction: row;\n  box-sizing: border-box;\n  overflow: hidden;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabIcon,\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabCloseIcon {\n  flex: 0 0 auto;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tabLabel {\n  flex: 1 1 auto;\n  overflow: hidden;\n  white-space: nowrap;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar .p-TabBar-tab.p-mod-hidden {\n  display: none !important;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab {\n  position: relative;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='horizontal'] .p-TabBar-tab {\n  left: 0;\n  transition: left 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging[data-orientation='vertical'] .p-TabBar-tab {\n  top: 0;\n  transition: top 150ms ease;\n}\n\n\n.jupyter-widgets.widget-tab > .p-TabBar.p-mod-dragging .p-TabBar-tab.p-mod-dragging {\n  transition: none;\n}\n\n/* End tabbar.css */\n"]} */", "headers": [ [ "content-type", "text/css" ] ], "ok": true, "status": 200, "status_text": "" } } }, "colab_type": "code", "id": "TKwMgQbdPNEh", "outputId": "6ac2f6a3-1385-4e35-e1c0-aa247ec434be" }, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "Running on devices: [0, 1]\n" ] }, { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "62e168c400c144979f22e6bff1387a5b", "version_major": 2, "version_minor": 0 }, "text/plain": [ "HBox(children=(IntProgress(value=0, max=10), HTML(value='')))" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "application/vnd.jupyter.widget-view+json": { "model_id": "609922190a6a40e299e4426b27ba47ee", "version_major": 2, "version_minor": 0 }, "text/plain": [ "HBox(children=(IntProgress(value=0, description='0/1(e)', max=79, style=ProgressStyle(description_width='initi…" ] }, "metadata": {}, "output_type": "display_data" }, { "data": { "image/png": "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\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" }, { "data": { "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQEAAAD8CAYAAAB3lxGOAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjAsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+17YcXAAAgAElEQVR4nOxdd1gU19c+i6AiUlSwoYJdbFFRo0bUaDTErrFFNCZR+Vli7MYWJcESa4wxgi3GWMBe0NhFY4mKXQFREQVUiiJNQNh73+8PnPl2YSm7OwMB5zzP+7DM3Dln5s7MO7ece44KACmiiCLvr5gU9gkooogihSsKCSiiyHsuCgkoosh7LgoJKKLIey4KCSiiyHsuCgkoosh7LrKRgEqlclWpVCEqleqRSqWaKZcdRRRRxDhRyeEnoFKpShDRAyLqSkSRRBRARF8ACJLcmCKKKGKUyNUSaE1EjwA8BpBORL5E1EcmW4oooogRYiqTXnsiitD4P5KIPsypsEqlUtwWFVFEfnkJwC7rRrlIIE9RqVTuROReWPYVUeQ9lKe6NspFAs+IqLrG/9XebRMFwHoiWk+ktAQUUaQwRa4xgQAiqqtSqWqqVKqSRDSEiA7JZEsRRRQxQmRpCQBQq1Sqb4noOBGVIKI/AATKYUsRRRQxTmTzEwDwN4B6AGoDWCiXHblk586dxBjLhgcPHlCNGjUK5Bzq1atHnHOaMGGCLPotLCyIMUZXr14lBwcHWWwo8t8XxWNQh+zcuZMGDBgg/n///n3y8/MjIqLatWvTsGHDCuQ8mjdvTpxzevbsWd6FDZCqVasS55ycnZ2pZ8+estho0aIFPXnyJMf93bp1o+rVq+e431jp1asXcc5p/PjxVKJECUl0VqxYkc6ePUuLFi0iR0fHXMtaW1tTr169yMzMTBLbsgiAQgcR4b+Cli1bIj09HYwx3LlzB46OjihbtixKliyJGzdugDGG5cuXF8i5LF68GAkJCbLotrOzw8WLF5GRkQHGGMaPHy+LnVmzZuHFixc57l+zZg18fX1lsV2hQgVERESAcw7OOczNzY3WWa5cOcTGxiI9PR07d+7Mtay1tTUePXqEhIQE1K1b1yi7VlZW+P3333Hu3Dlj9FzT+f4VNgHkRQIDBgzA8ePHsXnzZnh5eaF9+/aoU6eOLA8NEaFXr17IyMjAnTt3UKVKFXH77NmzkZaWBsYYPv74Y9nsC2jSpAmSk5Oxdu1ayXV/9913OHPmDDIyMkQS2LlzJyZMmIAOHTpIZsfU1BTnz5/PlQS++uor3LlzBxYWFpJfZ79+/UQC2L59O97NQhkMW1tbnD59Gowx/Pbbb3mWX7ZsGRhjGDVqlFF23dzc8OTJEzDGwBgzRlfRJIHHjx+LN1JAQkICLl26lCN27dqFli1bGlxZDg4OKF++vNa227dvizehIEhgwIAB4JyjY8eOkutmjIkEIJCA8PvRo0dwdnaWxE7Xrl2hVquxaNGiHMtMmTIFarUadnZ2kl9nQECA+Mx89tlnRuvr1q2b+Azkdb6NGjUC5xx79+6FpaWlwTarVauG2NhYcM5F21mfTT1QNEmgS5cumDJlClxdXTFlyhRs3bpVq4knID09Hc+ePRP/l7rJnpqaCsYYLl26hDJlykj+wGbF1atXERYWJvkX8u+//wYA8YFijCEmJgaPHz/W2masnSZNmuDly5cICQlB2bJlcyx39uxZ2UhA89kwVlfFihWxbt06MMbw1Vdf5Vq2UaNGePHiBTjnGDZsmFF2V61aBcaYFgnExcVh6tSpKFmypL76iiYJ6EK5cuXQuXNndOnSRcRHH30EOzs7vHz5EpxzjBs3TrKHqWfPnmCM4cWLF7J8mbPC0dERnHPcv39fUr0dO3ZEaGio1pf/t99+Q69evdChQwd4eHiI28eOHWuULV9fX6SmpqJVq1Y5lilfvrxISHKSwOHDh43WtXXrVgDAtWvX8iTmMWPGgHOOP/74wyibDg4OSEhIAGMMt27dwvHjx0UiePHiBSpXrqyvzuJDAjnh888/B2MMt2/fNqbJlA0eHh5gjGHVqlWSP6i6MGLECHDOcf78ecl0Ojo64sWLF1rN/0ePHmm1ahwcHPD8+XNkZGQgKSkJkydPhpmZmd62BgwYgMTERNy9ezfXcitWrABjDKdPnzbITl7gnCMtLQ3NmjUzWtdff/0FxhgOHTqU47mam5vD09MTr169kqQ11adPH3DOxcHA0qVL45tvvgHnHABw5coVfZ/z4k0CFStWRHR0NADg888/l+xBOnDgAFJSUrB58+Zcm7VSYvny5eCco1evXpLprFu3rtYYwKlTp2Bra5ut3IQJE7SIonbt2nrb2rlzJ9Rqda6tMUdHR0RFRSE9PR2dO3eWvA7btWsHzjlevXoliT6BBBhj8Pf3x/79+9GtWzcRCxcuxMWLF8Uyec0c5AeDBg0CYwx9+/bV2i50D/z9/fV9JosvCXz00Ud4+/YtOOeSjm5funRJsj6yPgCA7du3S6qzbt26+boWR0dHXL16FUBmM33btm162alYsSLUanWexwlE4ePjI0sdbt26FXFxcahWrZpkOsuVK4ePP/4YS5YsAeccUVFRWLJkCZYsWYLGjRuL9btlyxZJ7AkkcOvWLTRo0AADBw7Ejh078OrVK3DO8fLlSzRs2FAfncWXBBYuXAjOOU6ePClZs7J3797ilODp06dleVBzAucc/fr1k1Tn8uXLxZZAbuWMbQmYm5vj2rVruXbJKlasKL4wcvgntG/fHmq1GmFhYQV2z2rVqgXOOW7cuCHZ+Eb58uURFxeXbWCwTp06uH//Phhj8Pb21kdn8SQBc3NzXL9+HWlpaWjXrp0klV+hQgVcvnxZrPQVK1YU2MNUuXJlBAcHS643JCQkVxKws7NDx44dtcYNnj9/jho1auhtS/jK//vvvxg4cKAWtm3bhvPnz0OtVufZZTAUQl96/fr1BXbf/vzzTzDG0LVrV0n1fvLJJ4iPjwcAcM7x66+/goiwaNEicM4RFhamD1EXTxKYN28eOOf4+++/Jav4RYsWiQSwd+/eAhsLICLMnDkTmzdvllxvXiSwatUqLd+B0NBQuLi4GGTLyckJu3btwps3b8SXXYBAMsL/UnjxZcXWrVvBOc91ZkJqCP4rLVq0kFz3J598gj/++AMrV64Un0Vzc3Ps379f3+5H8SOBHj16ICMjA/Hx8Wjbtq1klS50AxhjWl6DBQEvLy+sXLlScr25kcDff/+N0NBQLRKQYlqtefPmGDBggBaICFu2bBFJQOrrrFatGtRqNTjnBXrfBK/EgrQ5ZMgQMMYQHh6e31mC4kcCoaGh4Jxjx44dklauJgk0atQItra2IoQxBzMzM3Fb3bp1sXbtWqxduxa//fabUc5EkZGRsoyWP3jwQLymzz77DJ999hkiIyPBGAOg7Twk90Do/PnzRRJo0qSJpLoHDRok+gfIeQ1ZkZycLEsrIDeYmJhgx44dYIxh3rx5+TmmeJFAiRIlwDnHw4cPDZrGyg2aJJAVvr6++OWXX8TK14U5c+YYZNfFxQUZGRmykMDkyZN1ugnr+j8/fvHGQPC7kINsxo4dC845YmJiZL0GTYwZMwZRUVEFZk8TzZo1w5s3b8AYQ7169fIqX7xIoF69epLPpQvYt29fji94Vrx9+xapqalITU3F9OnTMX36dIO7JitWrADnHCVKlJD8mjQdgXSRwPPnz3H69GnUrl1bdrdozZaA1Lr3798PzjmuXbsm6zVo4tatW9i0aROICJaWlgYNphqDqVOngnOOPXv25DXGUnxIwMHBAU+ePMHUqVONXhmWE2bMmIE5c+aI0HzxN2zYIG53cnKSxF6ZMmUQHBwsazO2Q4cOWLlypU4SkGspsS4sXrwYarUaycnJkuo1MzPD3bt3wTnHhQsXCux6bt26hfXr18PNzQ3Xrl2TzE8gv7Czs8ODBw/AOUfTpk1zK1s8SMDFxQWJiYngnBu1UlBB4cHPz0+WLg8RoWrVqti0aVOBkpqLiws8PDxQqVIlQxb1SIYTJ04gOTk5Nwei4kECs2bNEgd+GjRoUOgPtAIF/xVYWVkhLCwMvXv3zqmMThIotLwDxsrt27fp/v37hX0aiijyn5HExESqWbOm3sfJkotQ75NQ8g4ookhByHUALbNuVAKNKqLIey4KCSiiyHsuCgkoosh7LgoJKKLIey4KCSiiyHsuxYYEypUrRx988IEIGxsb+vHHH+mDDz4o7FPLt7i4uFCJEiVoxowZdO7cOZoxYwbNmDGDXFxcJLNRqlQpWrt2LanValKr1ZLpfZ/Fw8OD/P39Zbfj7OxMCxYsIMYYcc6JMUYBAQH0119/kZOTk+GKC9tRyBC3YU306NED69atQ0hIiJZrb3BwMFJSUgo8NJghsLKygp+fH968eSNGS9bEmzdvEBsbKy7FNQbTp0+HWq3GiRMn0KZNm0K/djkgRKMGIMb7W7p0KSpVqiSLPX9/fwBAp06dJNXr7u6OlStXIiAgAAEBAWCMiWsuvLy80K1bN311Fg+PQQG1a9dGcnIy1Gp1not8CvuhzAteXl5aL/3Zs2dx6NAhHDp0CIcPH9ZKupKHb3ieWLFiBdRqNWbMmFHo1y01zMzMMHPmTERGRorPhWZAE2NDgOcEQTw8PCTVK4QUS05ORkBAAFauXAl3d3djdBYvEujYsWOOL31gYCB27dolQoob0qZNGyxZsgRXrlzBv//+ixEjRhidX44oM1GFkGEmPDwcnTp10opkZGJiAg8PD6jVagDA3r17Ua5cOYPtrV+/HqmpqQW+9r158+Y4fPiw1te5Tp06sLCwQM+ePSWJMPTtt99qvfRnzpzJFtlIjmsTRGq9e/bsgVqtRkBAgFQ6izYJ2NraYsGCBXB1dQURoW3btoiIiEBcXBx8fX0xd+5cdO3aFba2tpJm7WnSpAm8vb2zNdGFzDZ3796Fl5eXwQtH2rRpIzJ+boteFi1ahPT0dHDO0aNHD4NsVa1aFYyxAl1hZ2Zmhk8++UTn1/nPP/8Uc/sZm6mnUaNGiI6O1nrhzczMxBWLRZEE7OzsEBYWhpiYGKmWJxddErCwsBAzAmddHFGjRg2YmJhIfgOaNm2KdevWIT4+HpxzREREYMeOHVi4cCEyMjJw+fJlcM7x7NkzPH36FGPGjDHITseOHfOdrUaIpCSsXdcXa9euzZME2rZtKwYFzUeQijzx4Ycfii9gREQEunbtiq5du2LUqFEYOnQoXr58idTUVHTp0sVgG40aNcKhQ4dEggkNDUWjRo1AlElCrVu3RlRUFNRqNe7cuSP5s+Lh4QFA+u4AUWYiXMaYVC23okkCJUuWxMGDB8EYw4IFCwokD+C6desQExMjfvFPnjyJ0qVLi/v9/f3RoEEDXLp0CSkpKQgLCzN47OGff/4B5xz/+9//8iy7du1acM4RGBhokK2nT5/mmEvPy8sL4eHhSEpKEl/auLg4/PDDDwbXo+bX+fjx41oPctWqVREQEAC1Wo3Fixcbdb+GDx8uhkl7+/Ytpk6dmq3Mzz//jIyMDACQPAqxIHKQwJw5c8A5h5ubG5ydneHs7GzMO1D0SKBs2bJYuHAhGGOIjo6GtbW15JWsidKlS2PevHlinPfo6Gh4eHhk617cuXMHjRo1Qrdu3bS6B/raq1WrFh49eoTXr1/nK1y6kKnYEBIoU6YMnj17hvDwcK3trVu3xrNnz8SXKCYmBvv378fTp08BAJGRkQbXp6+vr5i6K+v4Sbdu3USyMTa/444dO8SuxvHjx3MsJ2SWvnHjhqTPjVwkIHQHhBaO8HfPnj3o37+/ITqLHgkMGzYMjDGEhYVJmkkmJ7i6uiIpKQmcc0RGRqJ169Za+0uUKAFHR0dMmzYNT58+FYObAMBff/2ltz0hXPru3bvzVd4YEvjuu++gVquxdu1acVvVqlW1muqLFi3SqudDhw4Z3I/esGEDGGNITEzMFuTCzMwM/v7+YIzhzJkzRt2zChUq4NGjR+JLktvYwrRp04oMCdjZ2SEoKAiMMQQEBOCvv/6Cu7s73N3dERYWJo4j6dkyKHokEBMTA8YYUlJSMH/+fDRv3lzSm5cVQiz35ORk8cuoa0BQgFqtxu7duw0OSx4UFIR///033+WNIYHjx49DrVZj8uTJIMqM0fjq1atcBzVXrFiBq1evGnRtN2/ehFqtxvPnz7W2L126VIt4bGxsjLpns2fPzneLQiABtVotaZIQQeR8NnOCu7s7AgICEBMTA2dn57zKSx9URKVSPSGiJCJiRKQG0FKlUpUnop1E5EhET4hoEIDXhui3s7MjzjmVKlWK5s2bR3PnziVvb2+6fPky1ahRgw4ePEhERI0aNaJ///2XIiMjjbkcSk1NpX79+pGNjQ3NnDmTPvroI3r16hWFh4dT69atqXXr1lrl169fT7Nnz6b4+Hi9bVlYWJCZmZlR56uPWFpakkqlIpVKRUREEyZMIBsbGxo7dmyux2RkZBhkLygoiJo0aUIVKlSgmzdvitubNm0qED+dPn3aoLrTlDJlyojXdO7cuTzLm5iYEOfcKJv/JVm/fj3t27ePzp07R0eOHKFx48bRvn379FNi5Bf8CRHZZtm2lIhmvvs9k4iWGNoSWLZsWb6j/kZFRcHX11c2xv3rr7+0nHZGjhxpVFRgIcW0Pi0B4Rxu376tt72LFy9qtQSEOeicygvTifntqmSFubk5/Pz8sjns9OjRQ0xTJoXH4rFjx/I9/VccWwICOnToILYIJk2alFM56bsDpJsEQoioyrvfVYgoxFASKFGiBFq1aoUHDx7g8ePHYmTcnKBWqzF37lxZKlmYo+ecY+jQoUbr05cEnJ2dERcXZ7CfQFYSqFChAl68eIHZs2ejQoUK2cpfvnwZycnJRr+onTp1wrRp0zBt2jR0794dv//+u+jWLUXiTkNIID4+XlJnqf8CCRBl+tIEBgbmVheykEAYEd0goutE5P5uW7zGfpXm//qSQFZ06dIFrq6uWslCs2L//v2SV+6oUaNEArh79y5KlSpltE59SMDZ2Rnbt28H5xznz5+HqampXraqVq2Kx48fa5EAEaFKlSpQq9U4d+4cLC0tQUTo2bMnLl++jLdv3xo1PZgTBLI2ZCBVF/QhgTt37oAxltuX0iAIawfkmCLUF+vWrcttuloWErB/97ciEd0mog6U5aUnotc5HOtORNfeQa8LnTlzJhjLTMvs7OyMbdu2yUYCrVu3RkJCAjjnSExMxEcffSSJ3s6dOyMhISFPEihRogR8fHxEh6UPP/zQIHvHjx8HYwx+fn5ao8k9e/ZE7dq1Ub16daxfv170VZeDAIhI8i9xs2bNREegvByunj9/jqioKC2fDynwXyEBJycnREdH4969ezmVkXd2gIg8iGgaSdgdyAktWrQQX/pTp05pLSJas2aNpBXr6ekJzjmSk5MlXyUWFBSEwMBA2NraZtvXtGlTeHt74+rVq2IrxJj59GrVqonz5BcuXED//v3Rtm1beHp6il0FxhiCgoLQr18/2R5Uxhi2bdsmqU7BWSi3fIDClKXU40adOnUSuwNSk8DkyZPz7U7t4OCAvXv3Ijk5ObdQ/NKSABFZEJGlxu9LRORKRMtIe2BwqdQkYG5uDh8fH61uQHp6Ovbv3y/pugFLS0u8ffsWnHN4e3tLeoOJMklASJl1+PBhLQiLioS8ehs3bjTaW7JKlSq4f/9+tkU1AjZu3KhzfEAqNGrUSJJ1AllRq1YtsTWo2d0R0LlzZ7x8+RIvXrzILTGHQRBaAVKTQP/+/cEYg5eXl879dnZ2ot/A0aNHxRZAHgQuOQnUoswuwG0iCiSiOe+2VyCi00T0kIhOEVF5qUmAiFCpUiW8ePECjDGEhoZKzsJly5ZFZGSk+CJK3YQkIvTr1w/Xr1/P1Q8hJiYGM2fOlMymjY0N/ve//2HZsmWIj4/HsmXLsGzZsgJJ5DJ8+HCo1WpJ4iJkhaOjIx4/foz4+HgsWrQIRJm+EG5uboiJiYFarcaSJUsktanZCpC6ldi/f38AmSsuY2Ji4O3tjXXr1uHcuXOiR6vwNzAwECtXrtTZosyCoucsVJi4ffu2+DJK/fC8r7h58yamTZsmqw1ra2u0bt0afn5+WLJkCZYsWYLWrVvrPZhaTFG8MhDJLeXLlyeVSkUxMTG0atWqwj6dYiFBQUGy20hISKCrV69Sr169ZLdVXKTYxBiUWlauXElERJ6envTixYtCPpviIceOHaOAgIDCPg1FsoiShkwRRd4fUdKQKaKIItlFIQFFFHnPRSEBRRR5z0UhAUUUec9FIQFFFHnPRSGBQpKyZcuSk5MTrV69mlavXk3NmjUr7FMqNnLs2DFSq9UUFRVF27Ztk1x/eHg4AaC2bdtKrrtQpLC9Bf+rHoNyomzZsvjxxx+zrX3YunUrypcvX6jn5uvrCzc3t0KvI0PRuXNn0U24Xr16kqdaq169OgBgypQphXqdXbt2hbe3N169eiV6tgIQ3c1zOK74uA136tQJq1evBgBcv35dUt/6goAQQVkXnj17VmjnZWJigpiYGMybN082Gw4ODli+fDnOnTuHxo0bS6q7QoUKePnyJdRqNQ4cOCDL+U+ZMgUAMGjQoEK5R4MHD8arV6/EdQMPHjzA0qVL8fnnn6N+/fpYv359bpGviz4JVK5cGZcuXRKXvd6/fx+xsbFQq9X44osvDK7Y7t27i6sFNZOA+vj4wMfHBz///DP69u2L9u3bS3IjR48eLQbX+PXXX+Hu7o7x48eLN9fDw6NA8itkhbOzMzjnspFAvXr1xGQuQkTnZs2aoVevXkbnWCTKjI0grIiUK9nqpUuXAADVq1cv0HuzdOlSMcHu/fv34ePjg9atW8PMzEyr3KhRo+Dv75+TnqJNAra2trh+/boYglzIyFq9enXcuHED+/btg4mJCQYPHox69erhnRdivjBmzJhcowprruq7ePEiJk+ejE8//RT169c36IYeOXIEjDH4+PhobXdxcUFsbCwYY9i6dWu2GywF6tWrh0OHDsHBwSHbPoEEpI4nYGJigkaNGuH58+fZ6lQI2HLx4kWjM0kJMSn37t0ry4sodAWy5m4oCERHR4Nzjp07d+aa8q527dq5rXgt2iSwZMkSMMYQERGRrRJq166NatWqoWfPnmKzWp8El2ZmZhg5ciQWL16MsWPHYuzYsZgyZQrOnj0rQhcppKSk4Mcff9T7hgKZS0SFVFmaaNeunXgN27Ztk3z125dffgnOOT7//PNs+wYPHgzOebZ8C8bAzs4OP/30k1hnr1+/hlqtzlaXr169MupaK1asiHv37kkeRFQTK1asAACsWLFC5/62bdti0KBBGDRoEFasWIG2bdtKZnvfvn3gnOPLL780Rk/RJYEhQ4YgIyMDsbGxWhl7NdGwYUPExcWBMYZ9+/bp1RLID6ZMmYIpU6YgICBA6+GNj4/XOzPSyZMnwRiDo6Ojzv0vX74UiUDqvueff/4JzrnO5vLp06cRFxcnKfEIfVTOOd6+fYtPP/0Uly5d0qrDmJgYo18YuYKIamLXrl0AdI8HtG3bFuHh4cgqUhBBvXr18ObNG4SGhoqxIA2EThIoElOETZs2JRMTEwoMDKTk5GSdZTRzDiQlJQnkIpmsXLmSVq5cSS4uLlS3bl3atGkTERFZWVnR1KlT9dIVHBys9f+oUaPozJkzNHjwYBo8eDD5+PiI++rWrWv8yb8TS0tL6tKlC+3atYuuXr2abb+ZmRlxzkmtVhtty8TEhPbu3UvffPMNcc7p1q1b1K5dO1q1ahW1adNGq+yNGzfo33//Ncqek5MTERE9fvyYbty4YZQuQ2Ty5MlUvXp1IiKaOnUqtWvXjiIiImjFihVG6x4zZgyZm5vTsWPHKCkpyWh92aSwWwH5aQns3LkTjDF07949xzIDBw5EamoqGGMGp+7WB3Xq1BH7tLVq1dLr2C+//FLMsNygQQOkpaXlOFsQFhaGAQMGSJKH8cMPPwTnXOf0lo2NDWJjY7ONUxiKSZMmiV/64OBgDB48GKmpqdm6ASEhITrHJ/TF8+fPwRiDu7u7bPc8t5aAIJr7hPLG2vXy8gLnXIooyUWzO1CmTBnxhfjggw+y7TczM4Orq6tY5pdffpHtIRBQq1YtMWdhfHw8ypUrZ5S+Hj16YMuWLWKyjtxw+/ZtnWMJeaFUqVIIDQ3Fy5cv0aNHD2zcuBGHDx8WR9OFKScp5r9LlCiBixcvas20xMXFwdPTE02bNhXJ4N9//4WVlZUk90QgAc2YiXfv3tX6f/r06UbZEMYEstZR9erVcenSpWzlcyON/KJs2bKIj49HQEAAGjduLMLAcHdFkwRKliyJ0NBQMMay3cQqVapgxowZWi+JLqKQGhMnThQf8GXLlkmmt0SJErCxsUH9+vVRr1492NjYwMbGBr/++iuSkpLEa8wt825OsLa2zjbTcffuXfj5+cHPzw8pKSngnCM1NdXYwScQZbYshg0bhiFDhmjFL9y7d68Yvr1evXqS1Z1AAvHx8Th69Ci++OILlCpVCl27dsXu3btFIhg4cKDBNoTZgaxf9127dukkz0uXLhk9k5A187WA69evY+DAgfqSQdEkAaLMcNlCBuCTJ09izJgxWL16NR49eoTk5GS8fv0anHM8efJEdo+7unXriq2APMI75xu2trZ5piZv166dGDI8l+QSOaJ06dIICQnB69evMX36dFSsWFFrf3h4uPhyXrx4Ubb6Ex7iDRs2SKp38eLFYIxh3bp12fZZWloiODgYarXa6BiHgp+A5ku/a9eubF/7QYMG6Ww1GPK8HTt2DDt37sTChQuxcOFC3Lt3T6zHHTt26EMERZcEiAi9e/fGlStXxJcgLS0NGzduRJcuXcSxgE2bNsn28BJlvqwHDhwQb4Cu8Nb6olevXggNDUVqair69OmTa1lLS0s8fPgQjDG4urrqbcvKykonSdrb2yMpKQk3b95E06ZNUbduXVnqr3z58uCc4+nTp7nOdRuCvNKOb9iwQRISEF5uANi1axfatm0LQNt5aNCgQQgPD0d4eLgsTkXm5uZwdnbGwYMHwTnXJ1FM0SYBosz+f5s2bdCmTSBZNHoAACAASURBVBtxGqhevXoiMeQ2cCgFli9fLhLAo0ePjHZuISIMHTpUJDG1Wp3nlFKrVq2QkZGRm1eY3hg5ciQ451iwYIGs9SeME4wcOVJy3ePGjQMAnWnimjdvjujoaDDGJIl2PGXKlGzTgYJ/gDAOAEgzPZgT7O3txYjYY8aMye9xRZ8EdKFz584iCcjZFRgyZIg4eJaUlIQmTZpIplv4ijHG8kxzNnLkSNHdWEr7nHN06dJFtvqrVasWEhMT4efnZ1Q259ywefNmqNVqrF+/XnQWq1GjhphhSa1WY8SIEZLYql69ujhQmFUuXbokq1txx44dRQL4559/9PEdKJ4kIGS5lZsEBPfWnLztjIGVlRVOnTolJlLRNWA2ceJE3L17V/Qfl4MEXFxcZKk7e3t7hIWFgXOOGjVqyHaPypUrh4iICJEI+vXrh8jISKjVakREROCnn36Sxa7QKlixYoVsC4uE7lOZMmWQnJwMzjkuXbqEli1b6qOn+JFAjRo1RC9Bf39/2RJM2NjYiATw22+/yeLTX7ZsWYSGhiIlJQUZGRl4+/atFrJOFUqZLkxuEujVq5e41FUO/Zpo0aKFSARCF+v48eOyeRES/f/U4a5du8RxAql0W1paYvDgwZg9ezZ+++03hIWFITU1FfPnzzfEe7D4kYBmV0DqdNMCTExMxCnBgIAAWQhAEyNGjEBkZGSOfgLnz5/H3LlzJbW5b98+AMCoUaMkv57WrVsjLi4OnHOkpaXJWncCmjVrBj8/P5w5cwbTp0+XfBBSF8LDw8WpQim6AiVKlMCMGTOQnp6OO3fuIC0tTZzabd68uaF6ix8J7Nq1C4wxnY4aUsDKykoM2vDPP/8U21RWU6dOxYEDByRfvjx58mSxBfX8+XM0a9as0K+1qKBPnz7w8fHBxYsXMXjw4GyDnQai+JGAkJTx999/l+VG9O/fX3yI7e3tC/3BKGr47rvv8Pr1a8ybNw9VqlQp9PNRoJsElAxEuUj9+vXJ39+fHj58SB07dizs01FEEWNFZwYihQQUUeT9ESUNmSKKKJJdFBJQRJH3XBQSUESR91wUElBEkfdcFBJQRJH3XEwL+wSKivTt25emTp1Kq1evpoyMDHH7mTNnKDExsRDPTBFNefDgAdWuXZusrKzozZs3hX06RUPy4cjzBxHFENE9jW3liegkET1897fcu+0qIlpNRI+I6A4RtZDDWejixYuSJQLJL3Jy4/X29i5sBxCDERoaKqt+R0dHANBKkcU5x6ZNm/DTTz9hyJAhkkeFDgkJgVqtxrBhwwq9fqVGQEAAzp07Z4wOwzwGiagDEbUgbRJYSkQz3/2eSURL3v3uTkRHKZMM2hDRFalJoEWLFkhKSkLDhg1lrXALCwt06NBBDM2dEwlkZGTg1atXsq4dlwNCopGs2ytWrIjnz59j0aJFRttwdHTMM2bit99+K0lcBgGXL18Wlw1LXWd2dnaYPHkyzp07J3qrCn/37NmD/v37y3rPAgICDIoqpQHD3YaJyJG0SSCEiKq8+12FiELe/V5HRF/oKicFCZiYmODEiRN4+fIl7OzsxO2LFi2SfHnvihUrwBhDQkICPv/8c2zZsiXXh7mgWybGwtfXVycJVK5cGYwxHDt2zGgbVlZW+PHHH8WVnjlByuXFffr0wbVr15Ceni55nR09elRcmZj1r1qtRlJSkiTh5nKCu7t7bnkG8wNJ8w5UAvDi3e8oIqr07rc9EUVolIt8t00SGTRoENnb21PTpk0pNjZW3J6RkUGDBw+WxIaFhQWtWLGCxo8fT0SZKcQ7depEvr6+dO/ePYG0som3t7deduzs7LLZHTZsGO3du5c458QYE/926NDBsIvJQZydnalz584693Xp0kUyO4mJiTR//nzq3r07EWXep7i4uGzlhP1SyMGDB8nT0zPH+2SM2NrakomJCb169YpOnDhB48aNoxs3btDNmzdJpVKRhYUFTZw4UXK7miKLh6+BLYH4LPtfv/t7mIjaa2w/TUQtc9DpTkTX3iFfTObh4aEzA7Gbmxtu374tCdv+9ttv2b5U//77r7j/zz//BGMMK1euxD///COWSU5O1svOypUrQZTZxHR3d0dgYCDUajWio6Ph6ekJT09P8SsjlJUClpaWCA0NBeccf/75Z7b9K1asAOcc8+fPl8SemZkZDh06BMYY/v77b9jb22PRokViSDXGGIKDgyXJqyBgwoQJsnQH+vXrBy8vr2yxCZycnMRWwcSJEyW3q2lHjpZAkekOODo6IiYmRmfcADc3NyQmJhrVrDQ3N8fPP/+M9PR0nU1WoZy1tTVatmwJMzMz2NvbawU/za+trVu3wtvbG97e3ggKCkJ0dDSOHj2aLXHGggULwBgDAMmCYkyZMkU83549e2bbf/PmTTDGMHz4cKNtmZmZ4aeffgJjDI8fP9ZaiXnixAmt+q1cubJkL8vNmzdlIQFdsLCwQGBgIBhjCAgIkN0eY8yYsQdJSWAZaQ8MLn33uwdpDwxelWpgcNq0aXj8+LHWWICAXbt2ITk5Oc+w3bmhb9++uSb8yOm4OnXqiOVq1qyZp53+/fuLOQTUajU8PT1zJK8yZcrg3r17YIzB09PT6AfI2toaUVFRYCznTD0CCRibUIVIe2Bw9uzZWvu6dOkihkpjjGHcuHGSvSjz5s0rEBKYM2eO2IJTq9WSZ3PWBW9vb2PIxuDZAR8iekFEGZTZxx9JRBUos6n/kIhOEVH5d2VVRPQ7EYUS0V3KoSugLwnUqFED8fHxOiPqNGjQAG/fvsXSpUuNqtxBgwbpJICYmBg4OTnleFzDhg3Fsr17987XgxMQEAB3d3fY2trmWT4gIAAA4OXlZfQD9OzZMzDGcPXqVZ3hyWrVqoX4+HhjR6BFTJ8+XexO6YonICRmZYxhzZo1kr0of/75p+wk4OzsrDU74OXlpfMDJTUKhQQKArmduBDfz8/PL8cy27dvN3pKS7iZmtizZ0+ewUvv3r2rFwnoC2FE2BgSEEb8hWuMiYnB1q1b8cEHH6Bq1apiOaHpLgUJCAFgc8uWJERwlpoEWrVqhWPHjmH37t2S34+smDNnDsLCwrTql3OOTz/9VBZ7Qlo+A7uHRZMEzM3N4e/vj+joaPz8888YPXp0ti/o5MmTERwcDAcHBxH6zj1nJYE7d+7kGE6sYcOGePbsGVJSUsQBIcaYLKG03d3dxS+NoTrs7OzENGOa18g5R1RUFPbt24dbt26JXYWDBw8adc7W1tZinMTcxhbkIgEiwqxZsxAZGSn5/dAFW1tbeHp6il0DxhjOnj0rmz0jkpPqJIH/vNtwamoqffbZZ9SvXz+qX78+DR8+nKZPn05paWmkUqkIANnY2FC1atUoLCyMbty4QXv27KFffvmF3r59a7BdANlSdI8cOZJatGhBLi4uVLlyZa19b968IcaYwfZyEhcXF1KpVHThwgWDdcTGxtKXX35JvXr1ohYtWlDp0qWJiKh27dpkZ2dHffr0EesyNTWV1qxZY9Q5m5qaUpUqVYzSUZTk5cuX9MMPP9Dq1atpxYoVNGzYMHJxcSF3d3dav3695PYAUP369SXT958nASKitLQ08vHxISIiDw8PKlOmDJmZmVGPHj2IiGjcuHFkbW1NzZs3p4iICC3f/vyK8BIIYm5uTq1atRL/379/P9nY2JC5ubnO493c3PS2mR9p0KABAaDg4GCj9OzZs4f27NmjtW348OHUvHlzunnzJvXq1YsGDBhAiYmJdPLkSaNsGSIhISEFblMOcXJyEr+wxt6znESlUkmrsLC7AvkZGMwL27dvR3R0NGxsbAzWsXXr1jxdXHPCuXPnZMs4ExAQUCBTT+vWrQNjDIGBgUbrqlChglg3uY3VCN2Bhw8fGnXvdKEguwMChCldzjnc3Nxks2NEd0NSj8H/nOzYsYPi4+MNPn7v3r16H/Pq1Su6cOECDR48mCIiIvI+QE+xs7MjW1tb2r9/v+S6s0q5cuWIiOjw4cOS6v3qq6/I0dFR577GjRsTEZG/v79R906XDBs2jEqVKkXVqlWTVG9OsnLlSpo1axYBoNjYWDp//rxstlQqFbm4uEinsLBbAVK0BNzc3HDq1CmjdDRu3Bh37tzJ99f/2bNnsubuIyK4urrmOqcvJR49egTGGJYsWWK0Ls2WAGMM0dHRoqfnqFGjMGrUKFy+fBlpaWkICQnJl3+Fvrhy5QrUajW++uor2evOyclJbAFI0ZLKC4KPiQHHFs3ZgfzAzc0N0dHRqFWrllF66tWrl2v2H8YyU6LHxsbi448/lv1mR0dHQ61Wy04C7du3B5C51Ldv375G6zMxMcHmzZu16u3t27d4/vx5tvqcMGGCLNc0a9asAiGBrVu3IikpCWq1Gnv27JE8gYsuADB0Grf4koCtra1kufTq16+fY4vg9OnTmDJliuw3WQDnHNHR0bLbGT58uDh92LRpU0l0jhgxIs/W1IwZM2TLUCwXCVhYWGDv3r3Yu3cvGGPiC1kQ3oIClJZADhg/fjx27NhRYDdCbsyZMwecc1kTaWrixIkTkrruEmU6ejk7O2PIkCEICgrC9u3bYWZmBjMzM8mDiRQUhAHU5ORkBAQEyB5DQBecnZ0NbSEWbxIoTrCzs0NYWBiio6NlTeWtQH8MGzYMZ8+ezbYWoohAIYGiAsEv/ejRo4V+LgqKFYr3FGFxEwA0fPjwwj4NRd4DUXIRKqLI+yNKLkJFFFEkuygkoIgi77koJKCIIu+5KCSgiCLvuSgkoIgi77kUGRIYOXIkcc61MGPGDHJycpLN5smTJ+nAgQPUs2fPfJU3NS0S4RmIiOjatWv09u1bYozpRHp6ulZuh6IilpaW9ODBA7p9+7bsturUqUP+/v705s0b4pwXyGpPBwcH4pzT/Pnzc4xtobcUtqNQfpyFDh06pBWnXhPLly+XzbliyZIl4Jxj8uTJ+Sq/bNkyvfRHRkbi7t27+OKLL3Tud3Z2xqxZszBr1iyEh4eDMYaoqCg0btzY4GsaMmQIEhISkJGRAcYy8yc0b94cZcuWFTF27FixfuWMoy8HSpYsidOnT8saaLREiRLo1q0bEhMTwTlHbGwsOOf4+++/Zb++zp07izkd9+7dq+/xRdNjsFOnTkhOTgZjDLdu3cLBgwdx8OBBfPjhh+LqNLmST3777bf5JoGuXbvqnRjCxcUFsbGxePv2LeLj47WQkJCAN2/eiOGsNWFoToARI0bg6dOnYIzBx8cnx+uysbERA6hOnz5d72vauHEj1qxZgy+++AL9+vXDxo0bAfx/QtL79++LZXKL5Gwodu7cCbVajZIlS0quu1KlSjh27Bg450hKSsLIkSNhb29fYCRw5MiR948EKlSogO3bt8PPzy9b2Gq5l6MGBgbmmwQWLlyIa9eu6W2jU6dOOHr0aLYXXVgpJhUJuLm5iTkBd+3ahWrVquVafu3atXqTQNWqVXHz5s1sAU3fvHmDmJgYnD9/HtHR0YiOjhZzDiQkJEiaeITo/0mgY8eOkuq1tbXF9evXkZqaim+++UYrUjPnHL///rssz6EmNEngjz/+0Pf4ohlo9NWrV7nG71Or1ZSYmCi53caNG5O9ff7TKHbt2pV++uknve2cPXuWAgICxAg4VlZW2a7n8OHDVLNmTSIiunLlCoWHh+tl45tvvqF169ZRWFgYde7cmQIDAw2Kw5iXLF++nJo2baq1zdPTkw4cOEC3bt3S2t6sWTM6dOgQ2dvbU8eOHWnnzp2Sn4/UYmtrSxs2bKA9e/bQy5cvs+1fvnx5gZ3LmzdvpLNX2K2A/IwJ6IKlpSUYY/jll19kYdzRo0eLjJvXks1SpUrh5s2bksfJIyL06NEDycnJUKvVuH37tkGZgSZNmgTGWL7DVJubm+PYsWNITEzMM++CAFNTU3GcITk5GXPnzkWFChVyDf0eFBQExpjORCjGYMKECWCMwdfXV5ZnQxdiYmJkt1GrVi08f/48zzwcuaBodgd0oW3btmKmnJwG1YxB2bJlcf/+/Xz3uwYNGmRsosgcMXv2bLEbcOnSJYN02NraokmTJjAzM8tX+S5duoAxhvj4+HzbEIJsHjx4EE2aNMmzfNOmTcWxHqlJoFOnTlCr1QVGAo6OjgXSFVi8eLH4YdqwYYMhOoo+CZQsWRITJ04UZwoiIiJkGVjasGGDWNkffPBBnuWFgSKpz2PEiBFiK0CtVhudFCQ/sLe3R0xMDNLS0jB27Nh8H+fh4YGhQ4fmu7yfnx845/D29pb8Gj766CO8ffsWd+7cgYWFhex1tmjRIllagZooU6YMzp49Kz6XH374oSF6ijYJODg46Iz/FxoaiiFDhkhW2b1790Z8fDw453j8+DFKly6da3lra2vcuHFDchKwtLREQkKCSADz5s2TfAAtKxo3boxNmzaBMYYFCxbIZqd06dLgnCMjIwOurq6y2Lh79y7UarXs+QFtbW3x4sULWW0I90YggPeWBKpVq4br16+L6N+/Pz755BOcOnVKJITw8HA4OzsbXNF16tTRmn7JT/y7Zs2aicdIdcMvXLigNTsgd6BRCwsLbNy4EYwxpKSkoFevXrLZqlu3LtLS0sA5lyyeoS4I2ZzlJAEbGxtcuXJFVsIUoEkCJ06cMFRP0SaBnNCuXTv4+PiIRPDkyRPUqVNHbz2ffvoprl27Bs45Hjx4IE5HqlQq0YmmVKlS4m8hRp5AAgbM2eqEMOAJZAaw3Lx5s6wPlyYBXL16FZ988oms9nr16gXGGHbv3g1zc3PZ7BRES2Dbtm0IDw+Hg4NDrvU7e/ZsXL9+3ShbmiQwaNAgQ/UUTxIgyvTgOnDggEgE7dq101vH2rVrxUp++vQp1qxZgzVr1sDLywuccwDA9evXxTJDhw6FpaUlZsyYAc45Nm3aZPRDVa5cOcyZM0fLT+B///ufbA8xEYkEEB4eLlsmXU28fv1atkFUTchNAn369AEAeHh46NxvbW2NAQMG4P79+0hPT8eqVauMsqdJAkaMcxRfEhAghIEODQ1F3bp19To2Ojpaq8+lCw8ePMDTp09x9+5dcM4REBCAJ0+egHOOVq1aGX3+Q4cO1XIWqlu3rqQhuWvUqIGaNWuiZs2aWL58uZh6LTw8HPXq1ZPlZdGEiYmJSNTBwcEICgpCUFAQjhw5IrktHx8f2UhAmBKOjIzM9pzZ2tri559/RlxcHDjniIyMlMRpqVKlSggODgbnHCNHjjRUT/EngTFjxogPWY8ePfQ6dvz48eLL/uTJE1y5cgWnT5/G6dOnMWfOHHz66acoV64c7O3tUapUKXTt2hWHDh0C5xw3b96EtbW1Uederlw5XLp0SfQH+O677/ROr54TypYti379+olTcrpw4sQJdOvWDZUqVRKPq1ixIjZu3CjJOVSoUEGr26bpVShH1h45WwLCVF3nzp3Fba1atcKZM2fEZ+jixYt6u1znBnt7e4SFhSljArnByckJERERBpOAqakpWrVqhVatWqFatWr5yiSzZs0acM6xdu1ao869fPnyOHDggNgKkHK2o2/fvjh//nyO2ZR27NiBtLQ0cVt8fDzWrl2Lzz77DKtWrcKYMWMkOY8rV66INo4fP47p06ejVq1aqFChgizTa3INDNrZ2eHFixfiOgFHR0eMHj0ab9++xevXr+Hn54evvvoKpqamktqtUKECbt26pZBAVpQtWxYdO3bE8uXLxVV2jDHExcWhbdu2kj9Yuh6I2rVrG5V6qly5chg/frzW2gCpzq9UqVJaL7gmEhMTRT+A8ePHIzExMZu//59//inZuXz//ff47LPP8OrVK4MGbvWFp6enLC0BDw8PsUnu4eGBqKgocM5x/PhxfPTRR7Jdj2Z3QCEByvzqN2zYEOfOncv2cIeEhBgzelrg2L17txYBSJl2rG3btkhPT9eqn9TUVCxevDjby2FnZ4fp06fj6NGjOHr0KJo1ayb5tfbt2xdBQUEFUq/jxo2TnARMTU0RGhqabazIwDTheqFy5coICQl5v0mgRIkSqF69Ov744w/RR10TUVFRcHd3h6WlZYE8ZFKgTJkyCAkJ0SIBqeMjzJo1C3PmzMGBAwewePFi2T3bcsOMGTMKzJVXDhL48MMPxRf/1KlTGDt2LFxdXQvEK5GIMGXKFADADz/8YKgOw0iAiP4gohgiuqexzYOInhHRrXforrFvFhE9IqIQIvpUzu5AcUBgYCBCQkIQEhKCPn36FPr5yIkZM2ZIOlimQG8YvJT4TyJaQ0R/Zdn+CwCttYwqlaohEQ0hokZEVJWITqlUqnoAWD7svJfSqFGjwj6FApM7d+7QgwcPCvs0FMkieZIAgH9UKpVjPvX1ISJfAG+JKEylUj0iotZE9K/BZ6hIsZFjx44V9ikookOMCTT6rUqluqNSqf5QqVTl3m2zJ6IIjTKR77Ypoogi/1ExlAS8iKg2ETUjohdEtEJfBSqVyl2lUl1TqVTXDDwHRRRRRAIxiAQARANgADgRbaDMJj9R5mBhdY2i1d5t06VjPYCW0JEgURFFFCk4MYgEVCpVFY1/+xHRvXe/DxHREJVKVUqlUtUkorpEdNW4U1REEUXklDxJQKVS+VDmwF59lUoVqVKpRhLRUpVKdVelUt0hoo+JaDIREYBAItpFREFEdIyIxiszA4ooYrj07NmT9u3bR+Hh4QSAjh8/LrkN1bt5+kKVd2vzFVFEkSzy+PFjmj59OiUkJFDJkiVp0qRJdPbsWVq0aJEh6q7r7H4XtregMc5CXl5ehe18UeTRv39/Merv1q1bJdNbqVIlMYGJJgrimrZu3Ypz585h2LBhcHZ21kJuAUDyiypVquDx48eil6fmasKCwJQpU/D48WNDws0VbbdhXSiI2G5yY9asWQCA7du369zfrVs3Y0JM5wsODg6IiopCWFgYbG1tJdG5YcMGJCQkwNvbG4sXLxYXMsldn3Z2dggLCxNJRzNAC2MMZ8+eRf/+/Y22Iyz7VqvVOHnyZIE+M5UrV8bDhw/h4+Oj77E6SaDIJCQtLKlYsSJ9/fXXxDknABQaGkrjxo2jEiVKSKK/TJkyBICSk5N17q9Tpw4REXXr1o1atGghic2s8vTpU4qIiCA7OzuytbWVRGdCQgKNHDmSxowZQ7NmzaJdu3ZReno6lSxZUhL9OUmNGjWoRo0aNHbsWKpcuTKNGzeOPv74Yxo3bhyNHTuWfvjhBxo9ejQ1aNDAKDuXLl0Sf3/88cfGnrZeEhUVRd9++y21adOGTEwkeIULuxVgTEsgJiZGljh11apVg4eHBwIDA/HmzRtwzpGSkiKGxuKc48svv5TElpDfIKfw3suXLwfnHPHx8XpHS8ovnJyckJSUhL/++ku2r1epUqXwzz//GBolN99wdnbOMziri4uL0Xa6deuGtLQ0yZd/5xeNGzfG27dvMWDAAH2OK37dAc45WrduLVnF2tvbw8vLS+tlf/z4Ma5du4Zu3brB3t5eXNP9zTffGG3PysoKT58+Bedc580cOHCgGPYsODhYtgfK1dUVjDFZcjgIaNOmDRhjBUICjDHZIzQTEc6dOyeSQP369WW3lxV///13jt3IHKB0B/ISGxsb+vrrr8na2ppiY2OpYcOG1Lx5c2rZsiWdOHGCnj17RkuWLCEiIktLS6PtNW7cmKpXz/StyrqwpnTp0jR69Giys7MjIqLU1FSj7ekSJycn2rJlCwUHB1NwcLAsNogyu1VERI8ePZLNBlHm9bz7sMguCxYsEH/v2bOnQGxqitBVNFYUEtCQwMBA+vHHH6l79+7Upk0bun//PiUkJGiVERJR9uzZU1LbDx8+1Pp/6dKl9Mknn4j/79q1S1J7gixYsIBSU1OpU6dOsugXxN3dnYgyE8zKKf369SOVSiWrDUEuXrxIr1+/JiIia2trsrKyKhC7REQWFhZUqVIlaZQVdlfA2O6AIWm6jcGXX34pWRpqzTDnmmMb8+fPR0ZGhrjv9evXqFixoizXo1arZR0LIMpM6hIVFQXGGNq0aSNrEA5hJiAsLAwBAQEICAiQZDYgJ8yaNUuceZAzaUtWfPzxx+Cc4+uvv9bnuOI5JqDnwIjRmDt3LjjnaNCggdG61q1bp5MEUlJStMJXyRGSmyhzOq0gQmO1aNFCy1dg8+bNsow/zJkzR4xi/OTJEwQEBIgReuXKqVCyZEkxkOuVK1ckT66aEwQS0DNUfPEkASkHBvOCu7s7OOeYPXu2ZDq3bNkCzjl27tyJUaNGITk5WYsA1Go1unXrJvm1CFmEiTL9BDQdaiZPnoxJkyZh8uTJ8Pb2NiqQqiacnJy0og7fuHFDsvyK3t7eYIzh6NGjOV6rXIOFf/zxh9gCmTVrlmR6bW1tsXnzZiQmJiIlJQUpKSlITEzERx99BMYYRowYoa/O4kcC0dHRKFWqlCw3NivCwsLEDERTp05FzZo1JdH7ySefiNmThBffx8dH/H316lXJr6V///7iQxsQEIDo6OhsTjWaf93c3CSzbW1tLXooMsZQo0YNSfQ6OzvDy8tLp7NTfqYNjUHv3r3Fujp79qxk4cZPnjyJsLAw1K5dG0QEMzMzTJs2Tcx1kd9U8xoofiRQkB6DQhJNAYmJifD395esmTly5EgcPHgQq1evxnfffSfaWbNmjST6LSws4OzsLGZpEprNgYGBcHd3z/UFCQgIkLQur1+/LjkJ5BZQdPLkybK2BExNTbUSyE6bNs1ondWqVUNSUpLONHRCNqzy5cvrq1chAWMgOO1wzpGWlobbt2+Dcy5L9hwh1TnnHJ6enkbrmzNnDgIDA7W+7mfPnsXEiRPz1dSXYvxDwI8//oiUlBQwxvDw4UNJ+tD9+/fX2Q0QIMzny+k7oEkCUoyzdOzYEZxzODo6am3v3bs3goKCEB4ejsuXL+sbPbr4kcC9e/dku6lZceLECdy6dQuffvopmjdvju7du8Pf3x+LFi2S3NZPP/0ESiYT+QAAHCRJREFUzjkePnxo9Ei68OUHIA6YSflS64Pu3buLLYCHDx9K5gEZEBCQIwnY2dmJrR45naE0SSAuLs7ohUp169YF5xwtWrQAUaaz1fDhw/HmzRvUqFEDDRs2REREBK5evapPAt7iRwIFuYqQc47vv/++QGzt27cPnHPcuXNHsoeTMYaffvpJsgVC+uDrr7/G8+fPkZqaCsYYfH19JSMAYcGQrq+8nZ0dAgICxGuX8xovX74saf4IU1NTnD17FgkJCXj+/LnYhdNcNNSgQQMsWrQIycnJOHbsGLp27Zqt5ZAFxYsESpUqhd69exfIQ2xjYwNfX1/JEoTmhQ0bNoBzjrlz5xqtS+jvy/kVzA1fffWVViq0H3/8UfI8fdeuXcOcOXOybRdaQQEBAbKT3w8//KBFAhcvXjRaZ8WKFbFkyRLs3bsXX375JcqWLZstS7VKpYK7uztu376N+Pj4vGbLihcJtG7dukDSaRNljgc0atSoQGwREY4fPy7OQhSUTbmgmYmYMSZpqnUBf/31l9gasLOzg7u7u5h2fffu3QXS+qlVq5YWCUgxOCgDihcJjB49ukAqztnZWdL8gPmBMDBYHEhg/PjxYIwhPDxcNtJ2cnJCTEyM1tgHAFk9BbPCzMwM3333HaKjo5GUlCT25f9jKF4kUFCIjIyUpFmuD+zt7XH27NliQQIK/lNQSMAQ+Pr6omTJkoV+HgoUSACdJKAEGlVEkfdHdAYaVZYSK6LIey4KCSiiyHsuCgkoosh7LgoJKKLIey4KCSiiyHsuCgn8h6V27dq0ceNGSklJoXbt2hX26SjyTmxsbOjGjRsUEhJS2KcijRS2j8B/zU9g8uTJeS4PFtbmy3ke8+fPF11t161bV+j1UlAwNzeXxNuuX79+OHjwILp164ZKlSpJcm7lypUTYyFkZGRg2bJlBVYvZcqUQfXq1WFqaopnz56J6zD0jPpU9J2FTE1NMXHiRCxcuDCbS2iJEiUwatQo+Pr6IigoyOB16kKUndzKCJFq5HJLbdWqlbjm/vz58wYnWKlSpQrat2+P9u3bw9PTE7dv386Gu3fvYt++fWjfvn1eK9Akh4mJCTp27Ijvv/8eu3fvRmJiIpKSkvTO6dCyZUusXr0aq1evxu+//46DBw/iyZMnkp/vzz//LBKzFIFm9cHAgQOhVqvh5+cnrk9gjGH27NmwtLTMr56iTwIDBw7UmdzS1NRU68vJGEOdOnUMqmwAeebMExJcSJnAUxOLFy8G5xyXL182JHqMiKtXr2ZLCJoVwlp7xhju3r2LatWqyfYgN2/eHESZufS+//57XLt2DZxzAEBERAQ8PDwwfvx4vfWGhobi5s2b2LJlC44dO4Zx48ZJvuDL1tYWt27dAmMMcXFxBZ5sZM6cOeKLv2bNGjGZi1qtxi+//JJfPUWbBNq0aYMXL16ID2xcXJy4r27dutke7okTJxpU2ULF5rb0VmgJSJnAUxOccyQkJBgdekvzBc8PCTDGcOjQIcmvp0aNGjh58qSYSSkmJka8xs2bN6N79+4Gk52FhQXS0tLQoUMHyc9bE7dv3y60VoCzszNSUlJEEhDc2NetWwe1Wg1fX9/86iraJPD3339rPayrVq0S9+kigYULFxpU4UJLILdQVEJLQDPyi1QoVaoUGGM55ibUB25ubjh06FA2jBw5EtWrV0f16tXh5uaG+Ph42UigfPnyCAkJEcOlZWRkIDQ0FGPHjkWtWrWM1t+qVSuo1WrZSUAgy4SEBINbmYZi165d4v1B5gsDIoKlpSVu3rwJxlh+g8HqJAFTKgLSqVMncnZ21tqWV0aezZs3G2RLyD6cl+SnjCHi6upKp06dIi8vL6N1bd++nbZv355rmaxZbePi4oy2K0j58uXpyJEjVLduXSIiysjIoM8++4zOnDkjmQ1ra+sCyTikUqkIAKWnp+eYSq1evXpUtmzZbNvv3r1LGRkZBtvW+FhSWlqauD0pKYkePHhATZo0oblz5+Z5r/M08F9tCVhYWOCff/7J9qWvXLkyTE1NMXDgQJ19X0PZWmB8fVoCLVu2lCQgqBCzUIovZH5QuXLlbN2B6tWrS6Zf6AJwznHhwgWj4+7pwurVq8E512oJmJqawsHBAY6Ojvjwww/h4OCAd4vUDIZQT7GxsTr3Hz58GC9fvtTZ5Tp58iTmzZtnsO2dO3eKg4GjRo3S2te/f399MiMXze6ArqY+YwyjR4/W6qdp4tixYwbnIxDGBHJLXz1s2DCo1WoEBgbC2dkZ586dMzreYdOmTZGcnJznoKQxsLe3x9ChQzF06FBERUUhMTExGwlMmDABffv2NdpW27ZtER8fD845tm7dKltotvHjx4skYGVlhc8//xxBQUFa4eGFLE4ff/yxwXZyIwFLS0ux/q5duwZ/f3+sWbMGHh4eOHDggBhb0RAiqFq1KpKSknJ80du2bVv8SWDFihX5HtQSIMXNzq0lIGS7EcpKEcNO6DdnjZrr5OQEe3t7o1+W4cOH4969e/mqw5SUFEybNg1NmzY1ONrx48ePwTnHli1bDEmSkW9069YNnHOsX78eT58+RUZGBnx8fDBgwABUqlQJlSpVgpubG/z8/JCenm7wWItQT7oCiK5atQqMZQZQtbKyyrb/22+/RXBwsEEE7+TkpHNGTEDbtm1z3KcDhpEAEVUnIn8iCiKiQCKa+G57eSI6SUQP3/0t9267iohWE9EjIrpDRC3kaAnk9AAfPnzYqIfq3Llzom5PT08xNdeCBQvEzDmCXakGBl1cXMA5R2pqKlq3bo3FixfD29sbO3bsEK8rLCzMKBuzZs3S+jJu2LAhW8QkV1dX/P7773jy5Ik4dcc519vW9OnTxfwMCQkJSEpKAuccsbGxYuvg5cuXsuYB0AVzc3PcuXMHz58/1/vY3FoC+/btA2Ms19bjpEmTEBQUpLfdZ8+eQa1W48mTJzpnAQqkJUBEVejdi0xElkT0gIgaEtFSIpr5bvtMIlry7nd3IjpKmWTQhoiuGEMCtWvXRlpaGhITE/H777/j0aNHSExMRGJiolbePuGB3b9/v1EPirOzs5hBVzNZh670XIGBgZLk6Tt//jw459kIrGzZsggLCxOJoGfPngbbsLOzQ+PGjUXkFvCzefPmePr0qT5fGC1cunRJvC9XrlzBqlWr0K5dO1SsWBEODg5YuXIl0tPTER0djTFjxhhdf/pgxIgRSE9P1zv3Qm6zAwIJbNu2LcfjJ02ahMGDB+t9vsKzltM0YKF0B4joIBF1JaIQIqqiQRQh736vI6IvNMqL5QwhAaJMjzBd20uWLAl/f3+tlkD79u2NflD69+8vBq7UbPKvXLlSTErKmO7kl4ZAIIGRI0dqbbe1tRWvKzg4uEBflmbNmhk8RlG+fHl4eXlh4MCBsLa21llmwYIFImkbO2inDzp06ADOObp27arXcf/73//EexEVFYWBAweK+6pUqYJnz54hOTkZR44cQadOnbIdv2nTJkyaNEnv8xWetZxIYObMmWCM4cyZM/nRZzwJEJEjEYUTkRURxWtsVwn/E9FhImqvse80EbU0hgRyw6+//qpFAlLliK9RowZatGghQnOfwM5SNWcvXLgAAPj555+1ttva2opfVEP9HrLC1dU1X+U6deokui5LYTcrvv32W51p2eVG9+7dkZaWhnLlyul1nKmpqTgnzxjDrVu3tPZPmTJF9OlPTk7W+uo3bNgQSUlJ6Nevn97nKzxrw4cP17lfmDnI5ziYcSRARGWJ6DoR9X/3f3yW/a/1IQEicieia+9g0A01NzfHgwcPJB0TyA+EgUGpEnUKLYEzZ85gyJAhIMoMYd2zZ08wxpCeni5JCvYuXbogISEBv/76a64JQFxdXbUciKSuv5o1a4q5HA8cOFCgLYEjR44gJSXFoGOrVKki1kl6ejrWrl2r1TVo2bIl1qxZgyNHjuDNmzeiC3NkZCQYYwZdp0ACbdq0ybavTJkyuHjxItRqdX7dvQ0nASIyI6LjRDRFVzOfZO4O5ISGDRtmGxgsiNRkwiKj2bNnS6LPw8NDq+/fp08fbNy4Ufx/9erVktjp0aOHqPPo0aPw8/PD999/j86dO8PPz0+EMCaSmJiICxcuSFp3nTp1QmRkJDjniI6ORpMmTYzWqVKp8vRBUKlUKF++PJ49e2ZwwlCVSoUhQ4ZotQgSExNx9+5dTJo0ScSMGTOwZ88esczNmzdRtWpVg2wKJLBx48Zs+4TFRAcPHsxvUheDBwZVRPQXEa3Ksn0ZaQ8MLn33uwdpDwxezYcNgyooPDw8GwlIMSaQF4BM12JdaaMNQenSpeHq6qrl9CT0BZ8+fSrZUtg6deqIMxx5TbMyJu0CKSsrK3zzzTf/197VxkR1retnIT2IAmnRai3SUvSYRlM9l5gLVFPQEC+QWmpCq6lfVGKNKdqbQtOPUwW0qS1+JEWp0aYikHpJ23vrVevV9jRA0XqtnkOhAtHiJwhXig2oIOLs/dwfM3uf4WP4mNnDnpH1JE9mZs+etd9Zs/cz73r3Wu/Lrq4uqqrKpqYmJiUlGdZ2S0sLX3jhhT7nIwQHB7OgoIA3btzg8ePHXR5+vPjii9yyZQurqqoc9l11dTW3bNnCxYsXOz1nBbBe6Ipinc6tVSCeP38+S0pKqKoqKysrOWnSpMG257QIzLU1UAXgFxsTAYyD1dX/DcDfAATbiUYegIsAfsUA8QBXRKCvE3g4RMDomIDGhx56iM8++yxra2tZVlbGhIQEl1YR9sUxY8ZwxYoVLCoq4uHDh3VB03jt2jUWFRWxqKhoyONmAJw8eTJDQkIYEhLCNWvW8K233uLu3bv1eQOtra3csWOH4asV33zzTaqqyldeeYVhYWEMCAjgSy+9xOLiYjY3N7O5uZnZ2dkuXZA96evry5CQEGZnZ/fiEC7MfjlhwgQ2NzfTYrGwtra22+zBysrKofajd04W6o89RaCxsdGwarf9USt0aZQnYBbHjh3LOXPmcOXKlXzjjTc4Z84cTp8+3aU2b926xXv37rGrq4uKovDu3btsb29nW1sbjx075vLKSEf09fXlpk2beO3aNd65c4ctLS28e/cuDx48yHXr1plWjt0Ibt68uddt6pqaGmeE5sEVgf3793Ps2LGGV7uVlHzA6L2rCB2h5wo4CQmJoUNeRRISIxxSBCQkRjikCEhIjHBIEZCQGOGQIiAhMcIhRUBCYoRDioCEhBcgMjISpaWlWLx4seFte40ILFu2DIqiYPv27abZsHDhQqiqijVr1phmg8TgMGPGDMyaNctsMwxDVFQUoqOjceDAAdy4cQOrV6+Gr69B03zMni04mBmD48aN44kTJ2ixWNjW1sbHHnus3/137tzJq1ev8tVXXzV0xtWZM2eoKArPnz9v9syvYePo0aNZWFhouh2Dpb+/P9PS0njv3j193X9FRYXOvLw8zps3byilu/rkjh07qKoqz549y6+//prbtm3j0qVLGRIS4rakqunp6ayvr9enEOfk5Aw1/6T3Thu2T6GkKEq/XzwsLEyfX11eXm7oj6BNUz516pRbT+SEhAR+/vnnLCoqYnl5OYuKigxJNjoUJicnc82aNfz555+7ZdHpi7GxsSwpKWFWVpbOvrLruJv+/v48duxYtzUlPdeXaK+rq6udXuQTFxfHS5cucdGiRUxMTOSePXt48+ZN3rx5k11dXfzxxx8NTd1uz8WLF3Pnzp369fDpp58O5fMPhggcOnSo36Wg27Ztc9sqP+0ESklJccsPPHfu3F4nscZ9+/a5dW1EcHAwn376aX711Ve8fPkyW1tb2dLSwsTExAE/m5WVxcHAneIQGRnJM2fO6NmKTp06xczMTM6dO5fLly9ncnIy4+Liuq1oLCgocOpYBw4ccJhnIT09nYsWLXI6S/Ng6O/vzw8++IB3794lSW7YsGGwn30wRKCvlM8aH374Yd1lt1gsjIyMNLTztYzACQkJhrYbERHBw4cPs7OzUx9unDx5kpmZmfziiy/0+gAxMTGGn1CxsbH88MMP2draStK6rLigoIDR0dEMCgoaVBGX2NjYQYmAhpKSEsPFICcnRxfMU6dO9VuV+rPPPqOiWAuwOnOs6upq5ufnG/5bDJUHDx6koig8ceLEYJdIe68IaMkUFUXh9u3bHe4XGhpKRbHWa6utrTW04s2UKVOoqiqvX79uWJs+Pj7MyMjQk5p2dXX1mcjj22+/paqqTEtLM+S4q1at4rlz51hdXd3N2ygtLWVcXBwfffRRp9qNjY3tNiQYyEPIysoyrC/tRaC/PAiJiYlsa2tzWgT8/PxYV1fH9PR0w2x3lv7+/vof3iB/M+8VAS2P2kCeQGhoqB43cHVdfE8WFhZSVVVu2rTJsDYzMjL0cWpNTY3DopqaCOzfv9/lgBYA7t+/n42NjWxqamJ+fr4hFYcGQ0cegxFewdq1a3URcDQMDA8P15OBakvQh3qc8PBwdnR0GHoeOMtVq1aNTBFw9O8eGBjIpKSkQQUPnaHmkq9bt86Q9lauXKmPX48ePerQnZs2bRobGhpIWusqZGZmunTcqVOnMjk5me++++6wBxuBvoXAKI8gLy9P99bsk4hMmzaNe/bs6VZ85ciRI04HBouLi9nR0dHrwsvJyRlyKnNnqMUEtGzQR48eHWy8yDtFIDo6Wk+v1NLS0u9+gw0eOkOLxcLbt28bUmwEsAbTFEXh6dOn+xQArZimlrBSCxa64uHMmDGDGzdu5IoVKxgdHe32k9URewqBUSIwbtw4vfBJRUUFw8PDGR8fz99//13/979y5Qq3bt3qkke1efPmPutE/PDDD9y6dauhfZWbm0tFUVhfX89du3Zx8+bNPH36tP59zp07NxQx904RePnll7uNW0n2+3qguIGzdKYc10DfS7uXrV3g7e3teuS653dSVdXlux1BQUG8efMmb9++zSlTphjeR0Nhz3iBUYHC1157rZvL39DQwIULFxoyjNLo4+PDEydOsKGhQb8LsHfvXqqqari4+vn5MTExkRs3bmRNTQ1bWlposVj4ySefONOed4pAdHS0nuK7Z1mwmpoa1tbWdqvaOlDcwBmOGTOGimJ8/v2UlBTW19f3uug/+ugjxsfHc+3atXp24IaGBgYEBLh0vKlTp/LIkSMkyaqqKpaVlRn+nQbLniLgijewYMECfvnll70qEauqyrffftst9q9fv56qqjI7O5tCCFZUVJCk2z2soKAgWiwWNjU1OZOs1TtFALDmyy8vL2d5eTmjoqIYGRmp151/8sknGRERwcrKSlosFtbV1Rl6VwCwBmD6G4q4yjlz5nDp0qWcOXNmt+0xMTH6ybxs2TJDjhUWFsaYmBjGxMQYVkbNGfYUgaF+/vHHH+emTZvY2NjYTUSPHz/O9PR0xsbGUlEUdnZ2On23YyCWlZXplaS/+eYbt3gCffHOnTu0WCzODA29VwQGYkJCgh43cKbe20A8dOgQ169f7/Yftye1nPOO4gauMi8vb1hLgNnTXgRKSkqG/HmtQIqW0biwsJAzZ85kYGAg/fz8uHTpUn0Y1Vf1HiP4yCOPMCMjgzt37mRubq6hIvD+++87vFvU3t7ubHzowRWBq1ev6kMBd4jAhQsX3DoDrC9OnjxZD2gNNG3XWaqqyqCgoGH9XhpLSkp0EXBmKGA/fKqqquLy5cuZmZnJ/Px8nj17tltMwFFRVCOZmppqmAgkJyfz1q1bvQJ+U6dOZW5urn6uGyUCXp1tWIMQAkIItx6js7PTre33RGpqKoKDg9HW1obvv//ebcfp6OhwW9uOkJWVhdjYWP11aWnpkNv4+OOP8frrryMwMBDPPPMMCgoKeu3T2NiI5557Dm1tbS5YO7zw8fHBsmXLMGbMGNy/fx8TJkyAv78/UlJSkJKSgieeeALt7e3YtWsXLly4YMgxvV4EVq9ejYkTJ4IkOjo6DOsYDaGhoQgICICiKIa2OxCCg4MBAHV1dWhtbXXLMS5dugSLxeKWtvtDZmam/ry0tNQpEXjvvfeQl5eHJUuWYNKkSZg/f77+nhACJDFv3rxhE4C4uDhD2hk/fjyef/55AEBTU5PmKesoKytDWloaampqDDke8ACIQEBAAEaNGgUA8PX1RVBQkKHtR0VFYeLEiYa2ORBmzZqFlJQUCCHw008/Gd7+hAkTsHv3boSHhxve9lCRnZ3t9GevX79uan4Je1y5cgXNzc2oqKhwqZ0//vgD3333HRYsWKBvy8/PR2dnJ4qLi3Hy5ElXTe0Ns+MBrsYEpk2bpgcF9+7d22sCh6scPXo0L168OCzjZI1Hjx7V5w04U9O+P/r4+HDDhg36xJnh/F5A91gAOfS7Ap7K1NRU3r9/n7Nnzzbdln744AYGHzSqqsrLly8zPj7e8La1mn3uuNswGGpw5o6AJ3Pjxo2GLi5zE6UIeAvLy8u5YMEC0+1wBzWYkXREsm8REOwReDADQgjzjZCQePDxd5Kze270mkSjEhIS7oEUAQmJEQ5PuUXYAqDd9uhNGA9ps7vhbfYCnmvzk31t9IiYAAAIIc72NV7xZEib3Q9vsxfwPpvlcEBCYoRDioCExAiHJ4nAXrMNcALSZvfD2+wFvMxmj4kJSEhImANP8gQkJCRMgOkiIISIF0KcF0LUCSHeMdseRxBCXBFC/CqE+EUIcda2LVgI8b0Q4jfb4yMm27hPCNEshDhnt61PG4UVubZ+rxJCRHiQzVlCiOu2vv5FCJFo9967NpvPCyH+zSSbQ4UQJUKIGiFEtRDiDdt2j+5rhzB5zcAoABcBhAP4E4BKANPNXsvgwNYrAMb32JYD4B3b83cAfGyyjc8BiABwbiAbASQC+B8AAkAUgNMeZHMWgIw+9p1uO0f8ADxlO3dGmWDzJAARtueBAC7YbPPovnZEsz2BfwVQR/ISyS4AxQCSTLZpKEgCoKW0KQDwoom2gOSPAP7osdmRjUkACmnF/wJ4WAgxaXgs/Scc2OwISQCKSd4jeRlAHazn0LCCZBPJf9ie3wZQCyAEHt7XjmC2CIQAqLd73WDb5okggO+EEH8XQrxm2zaRZJPt+f8BGN7sI4ODIxs9ve/TbK7zPrthlsfZLIQIA/AvAE7DS/vabBHwJswlGQEgAcDrQojn7N+k1e/z6Fst3mCjDbsBTAHwFwBNADwjfVAPCCECAPwngH8necv+PS/qa9NF4DqAULvXk23bPA4kr9semwF8A6sbekNz62yPzeZZ6BCObPTYvid5g6RCUgXwGf7p8nuMzUKIh2AVgC9I/pdts9f1NWC+CJwB8GchxFNCiD8BWALgkMk29YIQYqwQIlB7DmABgHOw2rrStttKAP9tjoX9wpGNhwCssEWuowC02bmypqLHeHkRrH0NWG1eIoTwE0I8BeDPAH42wT4B4HMAtSR32L3ldX0NwNy7A3aR0wuwRnr/arY9DmwMhzUqXQmgWrMTwDgAPwD4DcDfAASbbOd/wOo+34d13JnqyEZYI9V5tn7/FcBsD7K5yGZTFawX0CS7/f9qs/k8gASTbJ4Lq6tfBeAXGxM9va8dUc4YlJAY4TB7OCAhIWEypAhISIxwSBGQkBjhkCIgITHCIUVAQmKEQ4qAhMQIhxQBCYkRDikCEhIjHP8P/NuIl42LhP4AAAAASUVORK5CYII=\n", "text/plain": [ "
" ] }, "metadata": { "needs_background": "light" }, "output_type": "display_data" }, { "data": { "text/plain": [ "{'test_binary_acc': 0.9712415933609009, 'test_loss': 12247.904296875}" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "import torch.optim as optim\n", "\n", "device = 'cuda' if torch.cuda.is_available() else 'cpu'\n", "num_devices = torch.cuda.device_count()\n", "\n", "model = VAE()\n", "\n", "try: \n", " model = nn.DataParallel(model.to('cuda'), device_ids=list(range(num_devices)))\n", " print(\"Running on devices: {}\".format(list(range(num_devices))))\n", "except Exception as e:\n", " print(\"Cannot initialise DataParallel model.\")\n", " \n", " \n", "optimizer = optim.Adam(model.parameters(), lr=0.001)\n", "loss = binary_cross_entropy\n", "\n", "trial = Trial(model, optimizer, main_loss, metrics=['acc', 'loss'],\n", " callbacks=[UnpackState(output_to_state=True), add_kld_loss_callback, predictions, targets]).to(device)\n", "trial.with_generators(train_generator=traingen, val_generator=valgen, test_generator=testgen)\n", "_ = trial.run(epochs=10, verbose=1)\n", "trial.evaluate(data_key=torchbearer.TEST_DATA)" ] } ], "metadata": { "accelerator": "GPU", "colab": { "name": "dataparallel.ipynb", "provenance": [], "version": "0.3.2" }, "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.6.8" }, "pycharm": { "stem_cell": { "cell_type": "raw", "metadata": { "collapsed": false }, "source": [] } } }, "nbformat": 4, "nbformat_minor": 1 }