.tree-visualization {
    display: flex;
    flex-direction: column;
}

.tree-visualization > .toolbar {
    padding: 5px;
    flex-shrink: 0;
}

.tree-visualization > .toolbar label {
    cursor: pointer;
    margin-right: 5px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
            user-select: none;
    white-space: nowrap;
}

.tree-visualization ul {
    margin: 0;
    padding-left: 20px;
}

.tree-visualization > ul {
    cursor: default;
    box-sizing: border-box;
    font-family: monospace;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
            user-select: none;
    overflow-y: auto;
    height: 100%;
}

.tree-visualization .value-body {
    min-width: 300px;
    width: fit-content;
}

.highlight {
    background-color: #efefef;
    padding: 7px 7px 7px 10px;
    border: 1px solid #ddd;
    overflow: hidden;
}

.code {
    font-family: 'Bitstream Vera Sans Mono', 'Courier', monospace;
}

.highlight .c { color: #586e75; } /* Comment */
.highlight .err { color: #93a1a1; } /* Error */
.highlight .g { color: #93a1a1; } /* Generic */
.highlight .k { color: #859900; } /* Keyword */
.highlight .l { color: #93a1a1; } /* Literal */
.highlight .n { color: #93a1a1; } /* Name */
.highlight .o { color: #859900; } /* Operator */
.highlight .x { color: #cb4b16; } /* Other */
.highlight .p { color: #93a1a1; } /* Punctuation */
.highlight .cm { color: #586e75; } /* Comment.Multiline */
.highlight .cp { color: #859900; } /* Comment.Preproc */
.highlight .c1 { color: #586e75; } /* Comment.Single */
.highlight .cs { color: #859900; } /* Comment.Special */
.highlight .gd { color: #2aa198; } /* Generic.Deleted */
.highlight .ge { color: #93a1a1; font-style: italic; } /* Generic.Emph */
.highlight .gr { color: #dc322f; } /* Generic.Error */
.highlight .gh { color: #cb4b16; } /* Generic.Heading */
.highlight .gi { color: #859900; } /* Generic.Inserted */
.highlight .go { color: #93a1a1; } /* Generic.Output */
.highlight .gp { color: #93a1a1; } /* Generic.Prompt */
.highlight .gs { color: #93a1a1; font-weight: bold; } /* Generic.Strong */
.highlight .gu { color: #cb4b16; } /* Generic.Subheading */
.highlight .gt { color: #93a1a1; } /* Generic.Traceback */
.highlight .kc { color: #cb4b16; } /* Keyword.Constant */
.highlight .kd { color: #268bd2; } /* Keyword.Declaration */
.highlight .kn { color: #859900; } /* Keyword.Namespace */
.highlight .kp { color: #859900; } /* Keyword.Pseudo */
.highlight .kr { color: #268bd2; } /* Keyword.Reserved */
.highlight .kt { color: #dc322f; } /* Keyword.Type */
.highlight .ld { color: #93a1a1; } /* Literal.Date */
.highlight .m { color: #2aa198; } /* Literal.Number */
.highlight .s { color: #2aa198; } /* Literal.String */
.highlight .na { color: #93a1a1; } /* Name.Attribute */
.highlight .nb { color: #b58900; } /* Name.Builtin */
.highlight .nc { color: #268bd2; } /* Name.Class */
.highlight .no { color: #cb4b16; } /* Name.Constant */
.highlight .nd { color: #268bd2; } /* Name.Decorator */
.highlight .ni { color: #cb4b16; } /* Name.Entity */
.highlight .ne { color: #cb4b16; } /* Name.Exception */
.highlight .nf { color: #268bd2; } /* Name.Function */
.highlight .nl { color: #93a1a1; } /* Name.Label */
.highlight .nn { color: #93a1a1; } /* Name.Namespace */
.highlight .nx { color: #555; } /* Name.Other */
.highlight .py { color: #93a1a1; } /* Name.Property */
.highlight .nt { color: #268bd2; } /* Name.Tag */
.highlight .nv { color: #268bd2; } /* Name.Variable */
.highlight .ow { color: #859900; } /* Operator.Word */
.highlight .w { color: #93a1a1; } /* Text.Whitespace */
.highlight .mf { color: #2aa198; } /* Literal.Number.Float */
.highlight .mh { color: #2aa198; } /* Literal.Number.Hex */
.highlight .mi { color: #2aa198; } /* Literal.Number.Integer */
.highlight .mo { color: #2aa198; } /* Literal.Number.Oct */
.highlight .sb { color: #586e75; } /* Literal.String.Backtick */
.highlight .sc { color: #2aa198; } /* Literal.String.Char */
.highlight .sd { color: #93a1a1; } /* Literal.String.Doc */
.highlight .s2 { color: #2aa198; } /* Literal.String.Double */
.highlight .se { color: #cb4b16; } /* Literal.String.Escape */
.highlight .sh { color: #93a1a1; } /* Literal.String.Heredoc */
.highlight .si { color: #2aa198; } /* Literal.String.Interpol */
.highlight .sx { color: #2aa198; } /* Literal.String.Other */
.highlight .sr { color: #dc322f; } /* Literal.String.Regex */
.highlight .s1 { color: #2aa198; } /* Literal.String.Single */
.highlight .ss { color: #2aa198; } /* Literal.String.Symbol */
.highlight .bp { color: #268bd2; } /* Name.Builtin.Pseudo */
.highlight .vc { color: #268bd2; } /* Name.Variable.Class */
.highlight .vg { color: #268bd2; } /* Name.Variable.Global */
.highlight .vi { color: #268bd2; } /* Name.Variable.Instance */
.highlight .il { color: #2aa198; } /* Literal.Number.Integer.Long */

/*
  Icon Font: fontcustom
*/

@font-face {
    font-family: 'fontcustom';
    src: url(e5a6d0ca1f060e475806e6751e3f8537.eot);
    src:
        url(e5a6d0ca1f060e475806e6751e3f8537.eot?#iefix) format('embedded-opentype'),
        url(data:application/font-woff;base64,d09GMgABAAAAAAnAAA0AAAAAFNAAAAlsAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAP0ZGVE0cBmAAgkoIBBEICp4slk0LGAABNgIkAyAEIAWDUQdsG/UPIxF2c5PCQvxVAneY+OIOHggDeyIlo9CFIXQo5WLRur9TNNZ3/DddM28t5jWLVDxNBVrfBrFIN23RJFXwbOXEMLUUPByEEy2c2xfnFt2c4FMwFMdUDMpDzE/1DRBAoD3+f6brhf836G0PiLQeqagMC3epTPVlDWtY7b54TSU/CYB592sXtxORhg1LXjqhU8pt7P6JbeB33nCJ5AuFRIiEKOqVZq/z6JUSSQkStfMYzmHsUZxWX+kCAOyB99+7H947fn7y9b0PfoAbgQHA8dgNAKOmvN8gAZb2E2AowDqogc1d3c2dsBDSf2IxGosCkERuZx4IpivCFASTwQTAB3FhoiHbxAIdII1lYwAsgHmxr9T0Lo0syEYkICNen+8MAAXo1CIPSYydARI5NIESJSPRMQtgta0QSJcaEKjNAhqggaERyhZXygSrRZKiUMilNuXBKclUSP0L4Yq0ilOgGTeWySk58ckpWU+bdUobKqGuZNCLT5NJy2RUHDMfz9UdFHXgIC55sc08uDZ+/fHVMTglbCTdxPWHV0evPOKnp12OVtfUdX0VlX1zgQyuFi+vkEIvs2wkv5xeZNlVtnpOK7zjzoBhDjvhLzIb9JMrm6vMfcscr4iBC1/gyeZL0XA8LHyqmQUDnjsHpoH3nvvrl8X1btOsv4dVIZgt4YWsu7NUt8VEs3yYOyUE+/uOrGXd+7T7VbNgpj3yeNPDZQyAPyNV8qX4xuyqm5sutisEY3Cl7mFKESLkPDLJQ0RrX6nlQWyLpsfao7oVHqZthadeuJ5oGunFk5zQs2VdNVi17abKlFZ75ZYtNXz5hSdANbuIyqUWfSxXEB5jRamfzjMn4uFfksT4aMVa5k6KuJLqTotLZiEpURlSfAgpAeZkL+tDcF9CLMs9Cy9SnceepV6QynE3jIeJrAxqI0IHM6xQTVWX505j24zUXUbqrhA8i4kKiDjRRByCKuCSTIlCEwuJJgHIVClIAiXNgQBIEzIoVDGTpBoeAarJBeRNWdoWBVOYkQRnqE/aPx0LHRePMVEJYuOZoG3RdoO0H4BJn57+6VjouGIIxDiDdMwN4//K5WfB8QY7A3NO749gde0RIYhiuq5H9ZXLX8gdBBfERxcBea1dmskLl3jiR7AX3hNfLJEDtvGh0GPqquJyrEaEv6xl2qZY5fBtm/FLdRNHKijBWNOHPrmgZNglzh1DVvgI4xBDDBhDYIC1/ggSpDKZg4JTY/WadvTVq2jgQpOYD2AuAB+OlGqGKccaPVaHUkRUVFMrLkttLTaB6QO4mIWS5Blw4VLmOManJCI23LLl5qk1dK2wUhjUdNu7C00HhoM5dfPXp5h2m260Hx4ePPTk04eGBw4LbODQikdbzUNzrs/41vitiyzqC3cfGOo+t6Hq581FJLN4Q+c9yfjTkjTj5gPjOxf/XFW0GbDBf+DA0xbnI60Zp99t2WXdpZf6I6x0r36XZbdV9+PrIfJvasnOJx60ffRRW7edF3aKv51tVvOZC7PMlSdlqneOPjTrQoFNWZ+eeGbpOeadH43UT5eZ81s2VSx7Pcqy529nKNtbc61dFQ79xsxHpo6N3lXzvHrwMPxS3kyJ477fUu2vdZ4bHiYP75M2qIKN4+pGB90PdStcHtX4gvc/tlO3hnfnGLek8umj+exGq3fiiZMliTNuvznBOdpX9cjfNyKvntxgT/QFt7Qppvz40/u/N2iWrbg1PHh9XFzWtS69vot0wvab4kkPn2yj7E1+cnG91SVvFScxHpVb5WJCLtqt9qon0qFO9qW8DHV9wlwd/xuvSG0gf1ha1IcaVC9a+G2iCjWabXoe/p3dHAyuCQbWBALOgvwJ4/PvMz6pIBOkvobMgW7Uv3Rvk+rBBJPxYou9d4SEbK3/ScsRoqIZjlmzpHL4he4r45HulnbRVKOZon0E2CxrbqTUr0P4A8ZVLnlEwukbbK3RxFyDgrtKf5qQTtBGyHyfr3NTwphIasqZMQmb+oXWKvaWkRqFjVpfO93FUOZGihFkwoEBMWkXGTGhh58xY2VZi88fl5c3Vjb7qfb26cV2rvy/a3HFXedC7xbbQhMfHxJYTqxySDqT+22+H4bKnUM/+GydyZ3xlipRwgqheN60sGKJd4EzXCEK/+d1dObGpFgRdoY8Syqkrua4UAsj7au0xEX9BjbhhyFn+dAPgq0/uZNzVPZJmJZQXLNLatviWeS8W7G4M7a8s+Ndmczb9F2F23HH7reIxRzbVBZgjfFB1iz3GoOf8o5Nhxz8p0GjV25mPdk0FyhrYtn6xUZX0x2H2/Zdkzcx0cN/Z/WUXWx0mRYZXWxTmZ+jbB42S+41NaE+uBGYymaxwTgD6/8/5zeErP7Si2We8u94PAvaIfoP/q3z8zZk5JsK6xJbn7WXW55v2GXOSEnNMG/reHZvzizzVMieZu7JgdjG5sMINFTVo//UxjBaYMLKTFsCwee1C52n/MXfRSqOjWV89t8dhwu2Y4vd3p/e50KxmKAOGiZlNf/iCC26RqWPIK3AUiUkyOFiFhafRNyP9FTAqWT8IPDajmI6bNdYrIjiWI3dndm4oPLcTDkTEvRT9FVVWXD7dPHaJCHpSd3rSt1j/eO1oQX1d/1lxXBsJJEh2mG9nC5ikCMUAQp1qKBlP4Yzn9PjxgXQ5yZuPZ5jpIRQBiT5yVi8edM1V4ArTaFQf1vXTiBBa/YXv5pxeSjdWw/qz0EgJfYRv8JIDOYSCmkgqiGEw0XQawI7t4RaYPAWLgGIPYf/YpQ1/k9gszBCUfUQR8N3pWGW+XilokgMwpRFzHQOcSz+myUYQwDyqXu/2RSZoa7+TSIn8ErJF8PYc4TrJAES8OhEAIwaMgACayXAHICA5RiIgBaUp8H3EgACU/oJ9EJtMyNATsKgUUASRHWyHgpTWgXnmyZ7KiIEGSQgAhyUIQossBLRIIPnEAMa+KmLhRWy4p2TOGmmCSEDRYSKGVHGViOawUOMdP/ILEMEAKB7/rz+joG+/kVsLrw6py9n9wbwdPUMzAmI8C+6SQBnLGE7xB7HoekSEHxLZm+bGruKazI9URjyYyDRB8ServQEbW0EWI6V9zs1uc5ooc8vWoMzfePp2EcQLBlZWN7m7yQDxFyt2SYC6o09FJG/W3fcCFJII4MscihRjBIDC3rd42f8Yigke0uEvDfUQ83sGGD+t2B0gBYH+vrZ9ysYM1/ZOHcO) format('woff2'),
        url(data:application/font-woff;base64,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) format('woff'),
        url(815ffb83cfb9e9730c113c04999cdb1a.ttf) format('truetype'),
        url(05107745996bcbb3ab1368555f8aa079.svg#fontcustom) format('svg');
    font-weight: normal;
    font-style: normal;
}

@media screen and (min-device-pixel-ratio: 0) {
    @font-face {
        font-family: 'fontcustom';
        src: url(05107745996bcbb3ab1368555f8aa079.svg#fontcustom) format('svg');
    }
}

[data-icon]::before { content: attr(data-icon); }

[data-icon]::before,
.icon-GraphQL_Logo::before,
.icon-handlebars::before,
.icon-icu::before,
.icon-ocaml::before,
.icon-reason::before,
.icon-rust::before,
.icon-scala::before {
    display: inline-block;
    font-family: 'fontcustom';
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    line-height: 1;
    text-decoration: inherit;
    text-rendering: optimizelegibility;
    text-transform: none;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
}

.icon-GraphQL_Logo::before { content: '\f100'; }
.icon-handlebars::before { content: '\f101'; }
.icon-icu::before { content: '\f102'; }
.icon-ocaml::before { content: '\f106'; }
.icon-reason::before { content: '\f105'; }
.icon-rust::before { content: '\f104'; }
.icon-scala::before { content: '\f103'; }

html {
    font-size: 14px;
    box-sizing: border-box;
    font-family: 'Verdana', 'non-serif';
}

.cover {
    position: fixed;
    inset: 0;
    z-index: 200;
    background-color: rgb(255 255 255 / 70%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.hasError {
    filter: blur(3px);
}

.loadingIndicator {
    font-size: 200%;
    color: #555;
}

.dropTarget {
    position: absolute;
    inset: 0 0 26px;
}

.dropIndicator {
    position: fixed;
    inset: 0;
    z-index: 200;
    background-color: rgb(255 255 255 / 70%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    border: 3px dashed #888;
    border-radius: 10px;
}

.dropIndicator > div {
    max-width: 90%;
    color: #888;
    font-size: 32px;
}

.banner {
    background-color: #b8dff7;
    border-right: 1px solid #ddd;
    padding: 8px;
    text-align: center;
}


#root {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 26px);
}

#Toolbar {
    flex-shrink: 0;
    flex-grow: 0;
    font-family: monospace;
    height: 32px;
    line-height: 32px;
    border-bottom: 1px solid #ddd;
    color: #454545;
    padding-left: 10px;
    background-color: #efefef;
    z-index: 200;
}

#Toolbar,
#Toolbar .menuButton ul {
    background-color: #efefef;
}

#Toolbar > *,
#Toolbar > .menuButton > span,
#Toolbar button {
    background-color: transparent;
    box-sizing: border-box;
    color: inherit;
    display: inline-block;
    font-family: inherit;
    font-size: 16px;
    margin: 0;
    min-width: 90px;
    outline: none;
}

#Toolbar > .menuButton > span {
    cursor: default;
    line-height: 29px;
    padding: 2px 6px;
}

#Toolbar > * {
    height: 32px;
    border-right: 1px solid #ddd;
    vertical-align: top;
}

#Toolbar > * button {
    height: 100%;
    border: none;
    cursor: pointer;
}

#Toolbar > h1 {
    padding: 0;
    padding-right: 10px;
    margin: 0;
    font-size: 18px;
    display: inline-block;
    vertical-align: top;
}

#Toolbar > a {
    color: inherit;
    text-decoration: none;
}

#Toolbar .menuButton {
    position: relative;
}

#Toolbar .menuButton:hover > ul {
    display: block;
}

#Toolbar .menuButton ul {
    position: absolute;
    left: -1px;
    padding: 0;
    margin: 0;
    list-style: none;
    display: none;
    border: 1px solid #ddd;
    border-top: none;
    min-width: 100%;
}

#Toolbar .menuButton ul li {
    white-space: nowrap;
}

#Toolbar .menuButton ul button {
    line-height: 28px;
    padding-bottom: 2px;
    padding-top: 2px;
    text-align: left;
    width: 100%;
}

#Toolbar > *.disabled,
#Toolbar button:disabled,
#Toolbar button:disabled:hover,
#Toolbar button:disabled:active {
    background-color: transparent;
    color: #888;
    cursor: default;
}

#Toolbar .menuButton li.selected {
    background-color: rgb(0 0 0 / 5%);
}

#Toolbar > a:hover,
#Toolbar > .button:hover,
#Toolbar ul button:hover {
    background-color: rgb(0 0 0 / 10%);
}

#Toolbar > a:active,
#Toolbar button:active {
    background-color: rgb(0 0 0 / 30%);
}

#info {
    color: #898989;
    cursor: default;
    float: right;
    padding-right: 20px;
    border: none;
}

#info.small {
    font-size: 12px;
    line-height: 1.3em;
}

.errorMessage {
    font-family: 'Verdana', 'non-serif';
    font-size: 1.2em;
}

.errorMessage h3 {
    padding-top: 0;
    margin-top: 0;
    color: #c00;
}

#contribution {
    font-size: 0.9em;
    color: #555;
    position: absolute;
    height: 25px;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
    line-height: 25px;
    background-color: #efefef;
    border-top: 1px solid #ddd;
}

.splitpane-content {
    flex-grow: 2;
    position: relative;
}

.splitpane {
    position: absolute;
    inset: 0;
}

.splitpane-divider {
    background-color: #ddd;
}

.splitpane-divider:hover {
    background-color: #999;
    cursor: col-resize;
}

.splitpane-divider.vertical:hover {
    cursor: row-resize;
}

.output {
    box-sizing: border-box;
    position: absolute;
    inset: 0;
    padding: 0;
    border: none;
}

.output .toolbar {
    font-size: 14px;
    margin-left: -1px;
    border-bottom: 1px solid #ddd;
}

.output .toolbar > button {
    margin: 0;
    height: 100%;
    min-width: 90px;
    border: 1px solid transparent;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    font-size: 14px;
    background-color: transparent;
    display: inline-block;
    vertical-align: top;
    outline: none;
    cursor: pointer;
}

.output .toolbar > button.active {
    border-color: #999;
    background-color: #999;
    color: #f5f5f5;
}

.output .toolbar .time {
    float: right;
    margin-right: 10px;
    font-size: 10px;
    line-height: 25px;
}

.output > .container {
    overflow: auto;
    position: absolute;
    inset: 25px 0 0;
}

.output > .no-toolbar {
    top: 0;
}

#JSONEditor .CodeMirror {
    font-size: 0.9em;
}

#JSONEditor .CodeMirror,
#JSONEditor .CodeMirror-gutters {
    background-color: #efefef;
}

.editor {
    position: absolute;
    inset: 0;
}

li.entry {
    margin: 0;
    list-style: none;
    padding: 5px;
    position: relative;
}

.CodeMirror .marked,
.entry.focused {
    border-radius: 2px;
    background-color: rgb(255 240 6 / 40%);
}

.entry > .value .s {
    cursor: text;
    -webkit-user-select: text;
    user-select: text;
}

.entry.toggable::before {
    content: '+';
    color: green;
    position: absolute;
    left: -10px;
}

.entry.toggable.open::before {
    content: '-';
    color: red;
}

.entry .invokeable {
    cursor: pointer;
}

.entry .invokeable:hover {
    text-decoration: underline;
}

.placeholder {
    font-size: 0.9em;
}

.compact,
.tokenName,
.entry.toggable > .key {
    cursor: pointer;
}

.compact:hover,
.tokenName:hover,
.entry.toggable > .key:hover > .name {
    text-decoration: underline;
}

.CodeMirror {
    height: 100%;
}

.CodeMirror-scroll {
    overflow: auto;
}

.editor .CodeMirror-gutters {
    background-color: white;
    border: none;
}

.CodeMirror .ErrorGutter {
    width: .7em;
}

.CodeMirror pre.errorMarker {
    background-color: #eb9494;
}

/* Dialog */
.dialog {
    align-items: center;
    background-color: rgb(255 255 255 / 70%);
    inset: 0;
    color: #333;
    display: flex;
    justify-content: center;
    position: absolute;
    z-index: 1000;
}

.dialog .inner {
    max-height: 90vh;
    background-color: white;
    box-shadow: 0 0 10px #555;
    border-radius: 3px;
    min-width: 400px;
    display: flex;
    flex-direction: column;
}

.dialog .header {
    flex-shrink: 0;
    padding: 10px 10px 0;
}

.dialog .body {
    overflow: auto;
    padding: 10px;
}

.dialog .footer {
    flex-shrink: 0;
    padding: 0 10px 10px;
    text-align: right;
}

.dialog .inner h3 {
    margin: 0 0 10px;
    padding: 0;
}

#SettingsDialog ul.settings {
    margin: 0;
    padding: 0;
    list-style: none;
}

#SettingsDialog ul.settings li {
    padding: 3px 0;
}


body .CodeMirror-hints,
body .CodeMirror-Tern-tooltip {
    z-index: 1000;
}

.shareInfo dd {
    margin: 0;
    margin-top: 5px;
    margin-bottom: 10px;
}

.shareInfo input {
    font-size: 15px;
    padding: 5px;
    width: calc(100% - 10px);
}

.toggleBtn {
    position: absolute;
    right: 0;
    height: 20px;
    z-index: 10;
    cursor: pointer;
    outline: none;
}

.toggleBtn > .btnText {
    padding-left: 5px;
    font-size: 12px;
}

