.pickr {
  position: relative;
  overflow: visible;
  transform: translateY(0)
}

.pickr * {
  box-sizing: border-box;
  outline: none;
  border: none;
  -webkit-appearance: none
}

.pickr .pcr-button {
  position: relative;
  height: 2em;
  width: 2em;
  padding: .5em;
  cursor: pointer;
  font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
  border-radius: .15em;
  background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50" stroke="%2342445A" stroke-width="5px" stroke-linecap="round"><path d="M45,45L5,5"></path><path d="M45,5L5,45"></path></svg>') no-repeat center;
  background-size: 0;
  transition: all .3s
}

.pickr .pcr-button:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');
  background-size: .5em;
  border-radius: .15em;
  z-index: -1
}

.pickr .pcr-button:before {
  z-index: initial
}

.pickr .pcr-button:after {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  transition: background .3s;
  background: var(--pcr-color);
  border-radius: .15em
}

.pickr .pcr-button.clear {
  background-size: 70%
}

.pickr .pcr-button.clear:before {
  opacity: 0
}

.pickr .pcr-button.clear:focus {
  box-shadow: 0 0 0 1px #ffffffd9, 0 0 0 3px var(--pcr-color)
}

.pickr .pcr-button.disabled {
  cursor: not-allowed
}

.pickr *,
.pcr-app * {
  box-sizing: border-box;
  outline: none;
  border: none;
  -webkit-appearance: none
}

.pickr input:focus,
.pickr input.pcr-active,
.pickr button:focus,
.pickr button.pcr-active,
.pcr-app input:focus,
.pcr-app input.pcr-active,
.pcr-app button:focus,
.pcr-app button.pcr-active {
  box-shadow: 0 0 0 1px #ffffffd9, 0 0 0 3px var(--pcr-color)
}

.pickr .pcr-palette,
.pickr .pcr-slider,
.pcr-app .pcr-palette,
.pcr-app .pcr-slider {
  transition: box-shadow .3s
}

.pickr .pcr-palette:focus,
.pickr .pcr-slider:focus,
.pcr-app .pcr-palette:focus,
.pcr-app .pcr-slider:focus {
  box-shadow: 0 0 0 1px #ffffffd9, 0 0 0 3px #00000040
}

.pcr-app {
  position: fixed;
  display: flex;
  flex-direction: column;
  z-index: 10000;
  border-radius: .1em;
  background: #fff;
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s, visibility 0s .3s;
  font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
  box-shadow: 0 .15em 1.5em #0000001a, 0 0 1em #00000008;
  left: 0;
  top: 0
}

.pcr-app.visible {
  transition: opacity .3s;
  visibility: visible;
  opacity: 1
}

.pcr-app .pcr-swatches {
  display: flex;
  flex-wrap: wrap;
  margin-top: .75em
}

.pcr-app .pcr-swatches.pcr-last {
  margin: 0
}

@supports (display: grid) {
  .pcr-app .pcr-swatches {
    display: grid;
    align-items: center;
    grid-template-columns: repeat(auto-fit, 1.75em)
  }
}

.pcr-app .pcr-swatches>button {
  font-size: 1em;
  position: relative;
  width: calc(1.75em - 5px);
  height: calc(1.75em - 5px);
  border-radius: .15em;
  cursor: pointer;
  margin: 2.5px;
  flex-shrink: 0;
  justify-self: center;
  transition: all .15s;
  overflow: hidden;
  background: #0000;
  z-index: 1
}

.pcr-app .pcr-swatches>button:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');
  background-size: 6px;
  border-radius: .15em;
  z-index: -1
}

.pcr-app .pcr-swatches>button:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--pcr-color);
  border: 1px solid rgba(0, 0, 0, .05);
  border-radius: .15em;
  box-sizing: border-box
}

.pcr-app .pcr-swatches>button:hover {
  filter: brightness(1.05)
}

.pcr-app .pcr-swatches>button:not(.pcr-active) {
  box-shadow: none
}

.pcr-app .pcr-interaction {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0 -.2em
}

.pcr-app .pcr-interaction>* {
  margin: 0 .2em
}

.pcr-app .pcr-interaction input {
  letter-spacing: .07em;
  font-size: .75em;
  text-align: center;
  cursor: pointer;
  color: #75797e;
  background: #f1f3f4;
  border-radius: .15em;
  transition: all .15s;
  padding: .45em .5em;
  margin-top: .75em
}

.pcr-app .pcr-interaction input:hover {
  filter: brightness(.975)
}

.pcr-app .pcr-interaction input:focus {
  box-shadow: 0 0 0 1px #ffffffd9, 0 0 0 3px #4285f4bf
}

.pcr-app .pcr-interaction .pcr-result {
  color: #75797e;
  text-align: left;
  flex: 1 1 8em;
  min-width: 8em;
  transition: all .2s;
  border-radius: .15em;
  background: #f1f3f4;
  cursor: text
}

.pcr-app .pcr-interaction .pcr-result::-moz-selection {
  background: #4285f4;
  color: #fff
}

.pcr-app .pcr-interaction .pcr-result::selection {
  background: #4285f4;
  color: #fff
}

.pcr-app .pcr-interaction .pcr-type.active {
  color: #fff;
  background: #4285f4
}

.pcr-app .pcr-interaction .pcr-save,
.pcr-app .pcr-interaction .pcr-cancel,
.pcr-app .pcr-interaction .pcr-clear {
  color: #fff;
  width: auto
}

.pcr-app .pcr-interaction .pcr-save,
.pcr-app .pcr-interaction .pcr-cancel,
.pcr-app .pcr-interaction .pcr-clear {
  color: #fff
}

.pcr-app .pcr-interaction .pcr-save:hover,
.pcr-app .pcr-interaction .pcr-cancel:hover,
.pcr-app .pcr-interaction .pcr-clear:hover {
  filter: brightness(.925)
}

.pcr-app .pcr-interaction .pcr-save {
  background: #4285f4
}

.pcr-app .pcr-interaction .pcr-clear,
.pcr-app .pcr-interaction .pcr-cancel {
  background: #f44250
}

.pcr-app .pcr-interaction .pcr-clear:focus,
.pcr-app .pcr-interaction .pcr-cancel:focus {
  box-shadow: 0 0 0 1px #ffffffd9, 0 0 0 3px #f44250bf
}

.pcr-app .pcr-selection .pcr-picker {
  position: absolute;
  height: 18px;
  width: 18px;
  border: 2px solid #fff;
  border-radius: 100%;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none
}

.pcr-app .pcr-selection .pcr-color-palette,
.pcr-app .pcr-selection .pcr-color-chooser,
.pcr-app .pcr-selection .pcr-color-opacity {
  position: relative;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  display: flex;
  flex-direction: column;
  cursor: grab;
  cursor: -webkit-grab
}

.pcr-app .pcr-selection .pcr-color-palette:active,
.pcr-app .pcr-selection .pcr-color-chooser:active,
.pcr-app .pcr-selection .pcr-color-opacity:active {
  cursor: grabbing;
  cursor: -webkit-grabbing
}

.pcr-app[data-theme=monolith] {
  width: 14.25em;
  max-width: 95vw;
  padding: .8em
}

.pcr-app[data-theme=monolith] .pcr-selection {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex-grow: 1
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 1em;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  margin-bottom: .5em
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');
  background-size: .5em;
  border-radius: .15em;
  z-index: -1
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview .pcr-last-color {
  cursor: pointer;
  transition: background-color .3s, box-shadow .3s;
  border-radius: .15em 0 0 .15em;
  z-index: 2
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview .pcr-current-color {
  border-radius: 0 .15em .15em 0
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview .pcr-last-color,
.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-preview .pcr-current-color {
  background: var(--pcr-color);
  width: 50%;
  height: 100%
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-palette {
  width: 100%;
  height: 8em;
  z-index: 1
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-palette .pcr-palette {
  border-radius: .15em;
  width: 100%;
  height: 100%
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-palette .pcr-palette:before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');
  background-size: .5em;
  border-radius: .15em;
  z-index: -1
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-chooser,
.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-opacity {
  height: .5em;
  margin-top: .75em
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-chooser .pcr-picker,
.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-opacity .pcr-picker {
  top: 50%;
  transform: translateY(-50%)
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-chooser .pcr-slider,
.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-opacity .pcr-slider {
  flex-grow: 1;
  border-radius: 50em
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-chooser .pcr-slider {
  background: linear-gradient(to right, red, #ff0, #0f0, #0ff, #00f, #f0f, red)
}

.pcr-app[data-theme=monolith] .pcr-selection .pcr-color-opacity .pcr-slider {
  background: linear-gradient(to right, transparent, black), url('data:image/svg+xml;utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2 2"><path fill="white" d="M1,0H2V1H1V0ZM0,1H1V2H0V1Z"/><path fill="gray" d="M0,0H1V1H0V0ZM1,1H2V2H1V1Z"/></svg>');
  background-size: 100%, .25em
}

@font-face {
  font-family: O3DVIcons;
  src: url("/assets/fonts/O3DVIcons-2DDY3NID.woff?d27bdb5af135068ed4a9350e285e132e") format("woff")
}

i[class^=icon-]:before,
i[class*=" icon-"]:before {
  font-family: O3DVIcons !important;
  font-style: normal;
  font-weight: 400 !important;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale
}

.icon-arrow_down:before {
  content: "\f101"
}

.icon-arrow_left:before {
  content: "\f102"
}

.icon-arrow_right:before {
  content: "\f103"
}

.icon-arrow_up:before {
  content: "\f104"
}

.icon-camera_orthographic:before {
  content: "\f105"
}

.icon-camera_perspective:before {
  content: "\f106"
}

.icon-close:before {
  content: "\f107"
}

.icon-collapse:before {
  content: "\f108"
}

.icon-dark_mode:before {
  content: "\f109"
}

.icon-deisolate:before {
  content: "\f10a"
}

.icon-details:before {
  content: "\f10b"
}

.icon-donate:before {
  content: "\f10c"
}

.icon-download:before {
  content: "\f10d"
}

.icon-expand:before {
  content: "\f10e"
}

.icon-export:before {
  content: "\f10f"
}

.icon-feedback:before {
  content: "\f110"
}

.icon-file_download:before {
  content: "\f111"
}

.icon-files:before {
  content: "\f112"
}

.icon-fit:before {
  content: "\f113"
}

.icon-fix_up_off:before {
  content: "\f114"
}

.icon-fix_up_on:before {
  content: "\f115"
}

.icon-flat_list:before {
  content: "\f116"
}

.icon-flip:before {
  content: "\f117"
}

.icon-github:before {
  content: "\f118"
}

.icon-hidden:before {
  content: "\f119"
}

.icon-info:before {
  content: "\f11a"
}

.icon-isolate:before {
  content: "\f11b"
}

.icon-light_mode:before {
  content: "\f11c"
}

.icon-materials:before {
  content: "\f11d"
}

.icon-measure_angle:before {
  content: "\f11e"
}

.icon-measure_distance_parallel:before {
  content: "\f11f"
}

.icon-measure_distance:before {
  content: "\f120"
}

.icon-measure:before {
  content: "\f121"
}

.icon-meshes:before {
  content: "\f122"
}

.icon-missing_files:before {
  content: "\f123"
}

.icon-model:before {
  content: "\f124"
}

.icon-open_url:before {
  content: "\f125"
}

.icon-open:before {
  content: "\f126"
}

.icon-print3d:before {
  content: "\f127"
}

.icon-settings:before {
  content: "\f128"
}

.icon-share:before {
  content: "\f129"
}

.icon-snapshot:before {
  content: "\f12a"
}

.icon-tree_mesh:before {
  content: "\f12b"
}

.icon-tree_view:before {
  content: "\f12c"
}

.icon-twitter:before {
  content: "\f12d"
}

.icon-up_y:before {
  content: "\f12e"
}

.icon-up_z:before {
  content: "\f12f"
}

.icon-visible:before {
  content: "\f130"
}

.icon-warning:before {
  content: "\f131"
}

:root {
  --ov_foreground_color: #000000;
  --ov_background_color: #ffffff;
  --ov_disabled_foreground_color: #cccccc;
  --ov_button_color: #3393bd;
  --ov_button_hover_color: #146a8f;
  --ov_button_text_color: #ffffff;
  --ov_outline_button_color: #3393bd;
  --ov_outline_button_hover_color: #c9e5f8;
  --ov_outline_button_text_color: #3393bd;
  --ov_icon_color: #263238;
  --ov_light_icon_color: #838383;
  --ov_selected_icon_color: #3393bd;
  --ov_disabled_icon_color: #cccccc;
  --ov_hover_color: #c9e5f8;
  --ov_hover_text_color: #3393bd;
  --ov_logo_text_color: #15334a;
  --ov_logo_border_color: #000000;
  --ov_toolbar_background_color: #f5f5f5;
  --ov_toolbar_selected_color: #e1e1e1;
  --ov_toolbar_separator_color: #cccccc;
  --ov_treeview_selected_color: #eeeeee;
  --ov_dialog_foreground_color: #000000;
  --ov_dialog_background_color: #ffffff;
  --ov_dialog_control_border_color: #e1e1e1;
  --ov_border_color: #dddddd;
  --ov_shadow: 0px 0px 10px #cccccc;
  --ov_foreground_color_dark: #fafafa;
  --ov_background_color_dark: #2a2b2e;
  --ov_disabled_foreground_color_dark: #888888;
  --ov_button_color_dark: #3393bd;
  --ov_button_hover_color_dark: #146a8f;
  --ov_button_text_color_dark: #ffffff;
  --ov_outline_button_color_dark: #c9e5f8;
  --ov_outline_button_hover_color_dark: #2f6984;
  --ov_outline_button_text_color_dark: #c9e5f8;
  --ov_icon_color_dark: #fafafa;
  --ov_light_icon_color_dark: #bababa;
  --ov_selected_icon_color_dark: #3393bd;
  --ov_disabled_icon_color_dark: #888888;
  --ov_hover_color_dark: #667c86;
  --ov_hover_text_color_dark: #fafafa;
  --ov_logo_text_color_dark: #fafafa;
  --ov_logo_border_color_dark: #2a2b2e;
  --ov_toolbar_background_color_dark: #3d3e42;
  --ov_toolbar_selected_color_dark: #272727;
  --ov_toolbar_separator_color_dark: #888888;
  --ov_treeview_selected_color_dark: #38393d;
  --ov_dialog_foreground_color_dark: #fafafa;
  --ov_dialog_background_color_dark: #3c3c40;
  --ov_dialog_control_border_color_dark: #e1e1e1;
  --ov_border_color_dark: #444444;
  --ov_shadow_dark: 0px 0px 10px #222222
}

:root {
  --ov_only_on_model_display: inherit
}

@font-face {
  font-family: Quicksand;
  src: url("./Quicksand-Regular-K32YVORR.ttf")
}

html,
body {
  color: var(--ov_foreground_color);
  background: var(--ov_background_color);
  font-size: 16px;
  font-family: Quicksand, Helvetica, sans-serif;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  overflow: hidden
}

a {
  color: var(--ov_button_color);
  text-decoration: none
}

img {
  display: block
}

ol,
ul {
  padding: 0 25px;
  margin: 0
}

li {
  margin: 10px 0;
  line-height: 25px
}

.only_on_model {
  display: var(--ov_only_on_model_display)
}

input,
select,
textarea {
  font-family: Quicksand, Helvetica, sans-serif;
  font-size: 16px;
  outline: none
}

@media (hover) {
  a:hover {
    text-decoration: underline
  }
}

@media (max-width: 800px) {
  .only_full_width {
    display: none
  }
}

div.ov_svg_icon {
  color: var(--ov_icon_color);
  font-size: 18px;
  width: 18px;
  height: 18px
}

div.ov_svg_icon.left {
  margin-right: 10px;
  float: left
}

div.ov_svg_icon.left_inline {
  margin-right: 10px;
  margin-top: 2px;
  float: left
}

div.ov_svg_icon.light {
  color: var(--ov_light_icon_color)
}

div.ov_svg_icon.selected {
  color: var(--ov_selected_icon_color)
}

div.ov_svg_icon.disabled {
  color: var(--ov_disabled_icon_color)
}

div.ov_thin_scrollbar {
  scrollbar-color: var(--ov_border_color) transparent;
  scrollbar-width: thin
}

div.ov_thin_scrollbar::-webkit-scrollbar {
  width: 3px;
  height: 3px
}

div.ov_thin_scrollbar::-webkit-scrollbar-thumb {
  background: #ccc
}

div.ov_button {
  color: var(--ov_button_text_color);
  background: var(--ov_button_color);
  text-align: center;
  padding: 3px;
  border: 1px solid var(--ov_button_color);
  border-radius: 5px;
  cursor: pointer
}

div.ov_button.outline {
  color: var(--ov_outline_button_text_color);
  background: transparent;
  border: 1px solid var(--ov_outline_button_color)
}

div.ov_tooltip {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color);
  padding: 5px 10px;
  border-radius: 5px;
  position: absolute;
  box-shadow: var(--ov_shadow)
}

input[type=text] {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color)
}

input[type=text]:disabled {
  color: var(--ov_disabled_foreground_color)
}

textarea {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color)
}

input.ov_radio_button {
  position: relative;
  top: 2px;
  width: 14px;
  height: 14px;
  margin-right: 10px;
  border: 1px solid var(--ov_foreground_color);
  border-radius: 50%;
  transition: .2s all linear;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input.ov_radio_button:checked {
  border: 5px solid var(--ov_button_color)
}

input.ov_checkbox {
  position: relative;
  top: 4px;
  width: 14px;
  height: 14px;
  margin-right: 10px;
  border-radius: 2px;
  border: 1px solid var(--ov_foreground_color);
  transition: .2s all linear;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input.ov_checkbox:checked {
  background-color: var(--ov_button_color);
  background-image: url("/assets/fonts/checkmark-YRFBL6HJ.svg");
  background-position: center;
  border: 0px
}

div.ov_select_container {
  position: relative
}

div.ov_select_container:after {
  font-family: O3DVIcons;
  font-size: 18px;
  content: "\f101";
  position: absolute;
  right: 6px;
  top: 6px;
  pointer-events: none
}

select.ov_select {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color);
  font-size: 16px;
  margin: 0;
  padding: 5px;
  border: 1px solid var(--ov_border_color);
  border-radius: 5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input.ov_slider {
  height: 1px;
  background: var(--ov_border_color);
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

input.ov_slider::-webkit-slider-thumb {
  background: var(--ov_button_color);
  width: 14px;
  height: 14px;
  border-radius: 14px;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none
}

input.ov_slider::-moz-range-thumb {
  background: var(--ov_button_color);
  width: 14px;
  height: 14px;
  border: 0px;
  border-radius: 14px;
  cursor: pointer
}

span.ov_slider_label {
  margin-left: 10px;
  position: relative;
  bottom: -4px
}

div.ov_toggle {
  width: 24px;
  height: 8px;
  padding: 2px;
  transition: .4s;
  border: 1px solid var(--ov_foreground_color);
  border-radius: 10px;
  cursor: pointer
}

div.ov_toggle_slider {
  width: 6px;
  height: 6px;
  transition: .4s;
  border-radius: 8px;
  border: 1px solid var(--ov_foreground_color)
}

div.ov_toggle.on {
  background: var(--ov_foreground_color)
}

div.ov_toggle.on div.ov_toggle_slider {
  background: var(--ov_background_color);
  transform: translate(16px);
  border: 1px solid var(--ov_background_color)
}

@media (hover) {
  div.ov_svg_icon.selected:hover {
    color: var(--ov_hover_text_color)
  }

  div.ov_button:hover {
    background: var(--ov_button_hover_color);
    border: 1px solid var(--ov_button_hover_color)
  }

  div.ov_button.outline:hover {
    background: var(--ov_outline_button_hover_color);
    border: 1px solid var(--ov_outline_button_color)
  }
}

div.ov_modal {
  position: absolute
}

div.ov_modal_overlay {
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  position: absolute
}

div.ov_dialog {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color);
  width: 400px;
  padding: 20px;
  box-shadow: var(--ov_shadow);
  border-radius: 5px
}

div.ov_dialog div.ov_dialog_title {
  font-size: 19px;
  font-weight: 700
}

div.ov_dialog div.ov_dialog_inner_title {
  font-weight: 700;
  margin-bottom: 10px
}

div.ov_dialog div.ov_dialog_content {
  padding: 20px 0;
  overflow: auto
}

div.ov_dialog div.ov_dialog_section {
  margin: 10px 0;
  overflow: auto
}

div.ov_dialog div.ov_dialog_buttons {
  overflow: auto
}

div.ov_dialog div.ov_dialog_buttons_inner {
  float: right;
  overflow: auto
}

div.ov_dialog div.ov_dialog_buttons div.ov_dialog_button {
  margin-left: 10px;
  width: 80px;
  float: left
}

div.ov_dialog div.ov_dialog_message {
  overflow: auto
}

div.ov_dialog div.ov_dialog_submessage {
  font-size: 14px;
  font-style: italic;
  margin-top: 10px
}

div.ov_dialog input.ov_dialog_text {
  padding: 5px;
  border: 1px solid var(--ov_dialog_control_border_color);
  border-radius: 5px;
  overflow: auto
}

div.ov_dialog textarea.ov_dialog_textarea {
  margin: 10px 0;
  width: 100%;
  height: 120px;
  border: 1px solid var(--ov_dialog_control_border_color);
  box-sizing: border-box
}

div.ov_dialog div.ov_dialog_options {
  height: 50px
}

div.ov_dialog div.ov_dialog_import_file_list {
  max-height: 300px;
  overflow: auto
}

div.ov_dialog div.ov_dialog_file_link {
  color: var(--ov_button_color);
  padding: 5px;
  display: block;
  overflow: auto;
  border-radius: 5px;
  cursor: pointer
}

div.ov_dialog div.ov_dialog_file_link div.ov_file_link_img {
  color: var(--ov_button_color);
  margin-top: 2px;
  margin-right: 10px;
  float: left
}

div.ov_dialog div.ov_dialog_file_link div.ov_dialog_file_link_text {
  float: left
}

div.ov_dialog div.ov_dialog_copyable_input {
  padding: 3px;
  border: 1px solid var(--ov_dialog_control_border_color);
  border-radius: 5px;
  overflow: auto
}

div.ov_dialog div.ov_dialog_copyable_input input {
  width: 70%;
  margin-top: 3px;
  float: left;
  border: 0px;
  box-sizing: border-box
}

div.ov_dialog div.ov_dialog_copyable_input div.ov_dialog_copyable_input_button {
  width: 28%;
  margin-left: 0;
  box-sizing: border-box;
  cursor: pointer;
  float: right
}

div.ov_dialog div.ov_dialog_row {
  padding: 3px 0;
  overflow: auto
}

div.ov_dialog div.ov_dialog_row_name {
  width: 30%;
  margin-top: 6px;
  float: left
}

div.ov_dialog div.ov_dialog_row_value {
  width: 70%;
  float: left
}

div.ov_dialog select.ov_select {
  width: 100%;
  border: 1px solid var(--ov_dialog_control_border_color);
  box-sizing: border-box
}

div.ov_popup {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color);
  width: 200px;
  padding: 10px;
  box-shadow: var(--ov_shadow);
  border-radius: 5px
}

div.ov_popup div.ov_popup_list {
  max-height: 200px;
  overflow: auto
}

div.ov_popup div.ov_popup_list_item {
  padding: 10px;
  border-radius: 5px;
  cursor: pointer;
  overflow: auto
}

div.ov_popup div.ov_popup_list_item_icon {
  float: left
}

div.ov_popup div.ov_popup_list_item_name {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden
}

div.ov_progress {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color);
  padding: 20px;
  text-align: center;
  width: 400px;
  box-shadow: var(--ov_shadow);
  border-radius: 5px
}

@keyframes ov_progress_img_kf {
  0% {
    transform: rotate(0)
  }

  to {
    transform: rotate(360deg)
  }
}

div.ov_progress div.ov_progress_img svg {
  width: 80px;
  height: 80px;
  margin-top: 5px;
  margin-bottom: 15px;
  display: inline-block;
  animation: ov_progress_img_kf 5s linear infinite
}

div.ov_progress div.ov_progress_text {
  font-size: 19px;
  text-align: center
}

div.ov_snapshot_dialog {
  width: 480px;
  float: right
}

div.ov_snapshot_dialog_options {
  width: 230px;
  float: right
}

img.ov_snapshot_dialog_preview {
  background: var(--ov_border_color);
  border: 1px solid var(--ov_dialog_control_border_color);
  width: 230px;
  height: 230px;
  object-fit: contain;
  float: left;
  border-radius: 5px
}

div.ov_snapshot_dialog_param_name {
  width: 60px;
  margin-left: 30px;
  margin-top: 6px;
  float: left
}

input.ov_snapshot_dialog_param_value {
  width: 80px;
  text-align: right;
  float: left
}

div.ov_snapshot_dialog_separator {
  margin: 10px 0;
  border-bottom: 1px solid var(--ov_border_color)
}

@media (hover) {
  div.ov_dialog div.ov_dialog_file_link:hover {
    color: var(--ov_hover_text_color);
    background: var(--ov_hover_color)
  }

  div.ov_dialog div.ov_dialog_file_link:hover div.ov_file_link_img {
    color: var(--ov_hover_text_color)
  }

  div.ov_popup div.ov_popup_list_item:hover {
    background: var(--ov_hover_color)
  }
}

@media (max-width: 700px) {

  div.ov_dialog,
  div.ov_progress {
    max-width: 80%
  }
}

div.ov_tree_view {
  user-select: none
}

div.ov_tree_view div.ov_tree_item {
  overflow: auto;
  border-radius: 5px;
  padding-right: 5px
}

div.ov_tree_view div.ov_tree_item.selected {
  background: var(--ov_treeview_selected_color);
  font-weight: 700
}

div.ov_tree_view div.ov_tree_item.clickable {
  cursor: pointer;
  border-radius: 5px
}

div.ov_tree_view div.ov_tree_item_button_container {
  float: right
}

div.ov_tree_view div.ov_tree_item_button {
  color: var(--ov_light_icon_color);
  padding: 5px;
  float: left;
  cursor: pointer
}

div.ov_tree_view div.ov_tree_item_icon {
  padding: 5px;
  float: left
}

div.ov_tree_view div.ov_tree_item_name {
  padding: 4px 5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap
}

div.ov_tree_view div.ov_tree_view_children {
  margin-left: 28px
}

div.ov_tree_view.tight div.ov_tree_view_children {
  margin-left: 10px
}

@media (hover) {
  div.ov_tree_view div.ov_tree_item.clickable:hover {
    background: var(--ov_hover_color)
  }
}

div.ov_panel_set_container div.ov_panel_set_menu {
  float: left
}

div.ov_panel_set_right_container div.ov_panel_set_menu {
  float: right
}

div.ov_panel_set_menu div.ov_panel_set_menu_button {
  padding: 10px;
  cursor: pointer
}

div.ov_panel_set_container div.ov_panel_set_content {
  padding-left: 10px;
  border-left: 1px solid var(--ov_border_color);
  overflow: auto
}

div.ov_panel_set_right_container div.ov_panel_set_content {
  padding-right: 10px;
  border-right: 1px solid var(--ov_border_color);
  overflow: auto
}

div.ov_panel_button {
  cursor: pointer;
  margin-top: 10px;
  border: 1px solid var(--ov_border_color);
  border-radius: 5px;
  overflow: auto
}

div.ov_panel_button_text {
  padding: 5px;
  float: left
}

div.ov_panel_button_icon {
  color: var(--ov_light_icon_color);
  padding: 6px;
  float: right
}

div.ov_panel_button_left_icon {
  color: var(--ov_light_icon_color);
  padding: 6px;
  float: left
}

@media (hover) {

  div.ov_panel_button:hover,
  div.ov_panel_set_menu div.ov_panel_set_menu_button:hover {
    background: var(--ov_hover_color)
  }
}

div.ov_navigator_buttons {
  border-bottom: 1px solid var(--ov_border_color);
  margin-bottom: 10px;
  padding: 5px 5px 5px 0;
  overflow: auto
}

div.ov_navigator_button {
  float: left;
  cursor: pointer;
  padding: 5px
}

div.ov_navigator_button.right {
  float: right
}

div.ov_navigator_buttons div.ov_navigator_buttons_separator {
  background: var(--ov_border_color);
  width: 1px;
  height: 28px;
  margin: 0 2px;
  float: left
}

div.ov_navigator_tree_title {
  font-weight: 700;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid var(--ov_border_color)
}

div.ov_navigator_tree_title.withbuttons {
  padding-bottom: 6px
}

div.ov_navigator_tree_title.nomargin {
  margin-bottom: 0
}

div.ov_navigator_tree_title_buttons {
  float: right;
  margin-right: 5px;
  margin-top: -4px
}

div.ov_navigator_tree_panel {
  overflow: auto
}

div.ov_navigator_info_panel {
  margin-top: 10px;
  border-top: 1px solid var(--ov_border_color);
  overflow: auto
}

@media (hover) {

  div.ov_navigator_info_panel div.ov_navigator_info_panel_title:hover,
  div.ov_navigator_button:hover {
    background: var(--ov_hover_color)
  }
}

div.ov_sidebar_title {
  font-weight: 700;
  white-space: nowrap;
  text-overflow: ellipsis;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid var(--ov_border_color);
  overflow: hidden
}

div.ov_sidebar_title div.ov_sidebar_title_text {
  float: left
}

div.ov_sidebar_title div.ov_sidebar_title_img {
  color: var(--ov_light_icon_color);
  float: right;
  cursor: pointer
}

div.ov_sidebar_parameter {
  margin: 10px 0;
  overflow: hidden
}

div.ov_sidebar_parameter div.ov_sidebar_parameter_toggle {
  margin-right: 10px;
  margin-top: 3px;
  float: left
}

div.ov_sidebar_parameter div.ov_sidebar_parameter_text {
  float: left
}

div.ov_sidebar_image_picker {
  background-size: cover;
  background-position: center center;
  width: 28px;
  height: 13px;
  margin-top: 3px;
  margin-right: 10px;
  border: 1px solid var(--ov_border_color);
  border-radius: 3px;
  float: left;
  cursor: pointer
}

div.ov_sidebar_content,
div.ov_sidebar_section {
  overflow: auto
}

div.ov_sidebar_content div.ov_sidebar_settings_section {
  margin-bottom: 20px;
  overflow: auto
}

div.ov_sidebar_content div.ov_sidebar_settings_sections {
  margin-bottom: 10px;
  overflow: auto
}

div.ov_sidebar_content div.ov_sidebar_settings_row {
  margin: 5px 0;
  overflow: auto
}

div.ov_sidebar_content div.ov_sidebar_settings_row input.ov_slider {
  width: 80%
}

div.ov_sidebar_content div.ov_sidebar_settings_row.large {
  height: 25px
}

div.ov_sidebar_content div.ov_sidebar_settings_padded {
  margin: 10px 0 0 40px;
  overflow: hidden
}

div.ov_sidebar_content button.pcr-button {
  width: 30px;
  height: 15px;
  margin: 3px 10px 3px 0;
  border: 1px solid var(--ov_border_color);
  box-shadow: none;
  outline: none;
  float: left
}

div.ov_environment_map_checkbox {
  margin-bottom: 10px
}

img.ov_environment_map_preview {
  width: 160px;
  height: 88px;
  display: block;
  float: left;
  padding: 1px;
  border: 5px solid var(--ov_dialog_background_color);
  cursor: pointer
}

img.ov_environment_map_preview.selected {
  border: 5px solid var(--ov_button_color)
}

div.ov_environment_map_preview_no_color {
  background: linear-gradient(to top left, var(--ov_background_color) calc(50% - 1px), var(--ov_border_color), var(--ov_background_color) calc(50% + 1px))
}

div.ov_popup.sidebar {
  width: 344px
}

div.ov_color_circle {
  background: #fff;
  border: 1px solid #000000;
  width: 14px;
  height: 14px;
  display: inline-block;
  margin-right: 8px;
  margin-bottom: -2px;
  border-radius: 10px
}

div.header {
  overflow: auto;
  display: none
}

div.title {
  padding: 6px 10px;
  overflow: auto
}

div.title div.title_left {
  float: left
}

div.title svg.logo_image {
  width: 190px;
  height: 40px;
  float: left
}

div.title div.logo_text {
  color: var(--ov_foreground_color);
  font-size: 18px;
  font-weight: 700;
  padding: 9px;
  float: left
}

div.title div.title_right {
  float: right
}

div.title_right a {
  color: var(--ov_foreground_color);
  padding: 11px 5px;
  display: block;
  float: left;
  text-decoration: none
}

div.toolbar {
  background: var(--ov_toolbar_background_color)
}

div.intro {
  margin: 10px;
  padding: 10px;
  text-align: center;
  border: 2px dashed var(--ov_border_color);
  overflow: auto;
  display: none
}

div.intro_content {
  width: 500px;
  max-width: 90%;
  margin: 0 auto;
  position: relative
}

div.intro div.intro_logo {
  border-bottom: 1px solid var(--ov_border_color);
  padding-bottom: 30px;
  margin-bottom: 30px
}

div.intro svg.intro_logo {
  width: 381px;
  height: 80px;
  max-width: 90%;
  margin-bottom: 20px
}

div.intro div.intro_dragdrop_text {
  font-size: 30px
}

div.intro div.intro_formats_title {
  font-size: 25px;
  margin-bottom: 15px
}

div.intro div.intro_file_formats {
  margin: 0 auto
}

div.intro div.intro_file_formats a {
  color: var(--ov_outline_button_text_color);
  text-decoration: none;
  font-size: 17px;
  width: 50px;
  border-radius: 5px;
  padding: 4px 8px;
  margin: 6px 4px;
  border: 1px solid var(--ov_outline_button_color);
  display: inline-block;
  cursor: pointer
}

div.intro div.intro_file_formats a:hover {
  background: var(--ov_outline_button_hover_color)
}

div.noembed {
  text-align: center;
  padding: 10px
}

div.noembed a {
  padding: 10px 0;
  display: block
}

div.main {
  overflow: hidden;
  display: none
}

div.main_file_name {
  margin: 10px auto;
  white-space: nowrap;
  text-align: center;
  text-overflow: ellipsis;
  overflow: hidden
}

div.main_left_container {
  float: left;
  overflow: auto
}

div.main_navigator {
  width: 280px;
  margin: 10px 0;
  overflow: none;
  float: left
}

div.main_splitter {
  width: 10px;
  overflow: none;
  float: left;
  cursor: w-resize
}

div.main_viewer {
  float: left
}

div.main_right_container {
  float: left;
  overflow: auto
}

div.main_sidebar {
  width: 280px;
  margin: 10px 0;
  overflow: none;
  float: left
}

div.main_viewer canvas {
  margin: 10px 0;
  border: 1px solid var(--ov_border_color);
  outline: none;
  display: block
}

div.ov_toolbar {
  overflow: auto;
  user-select: none
}

div.ov_toolbar div.ov_toolbar_button {
  float: left;
  cursor: pointer;
  padding: 10px
}

div.ov_toolbar div.ov_toolbar_button.align_right {
  float: right
}

div.ov_toolbar div.ov_toolbar_button.selected {
  background: var(--ov_toolbar_selected_color)
}

div.ov_toolbar div.ov_toolbar_separator {
  background: var(--ov_toolbar_separator_color);
  width: 1px;
  height: 28px;
  margin: 5px 8px;
  float: left
}

div.pcr-app {
  color: var(--ov_dialog_foreground_color);
  background: var(--ov_dialog_background_color)
}

div.pcr-app input.pcr-result {
  color: var(--ov_foreground_color) !important;
  background: var(--ov_background_color) !important
}

div.ov_property_table {
  overflow: auto
}

div.ov_property_table_custom {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--ov_border_color)
}

div.ov_property_table div.ov_property_table_row {
  overflow: auto
}

div.ov_property_table div.ov_property_table_row.group {
  padding: 4px 0;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden
}

div.ov_property_table div.ov_property_table_row.ingroup {
  margin-left: 15px
}

div.ov_property_table div.ov_property_table_cell {
  padding: 4px 0;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  box-sizing: border-box
}

div.ov_property_table div.ov_property_table_name {
  width: 49%;
  padding-right: 2%;
  float: left
}

div.ov_property_table div.ov_property_table_value {
  width: 49%;
  text-align: left;
  float: left
}

div.ov_property_table div.ov_property_table_button {
  color: var(--ov_button_color);
  cursor: pointer
}

div.ov_bottom_floating_panel {
  background: var(--ov_background_color);
  border-top: 1px solid var(--ov_border_color);
  width: 100%;
  padding: 30px;
  box-sizing: border-box;
  position: absolute;
  bottom: 0
}

div.ov_bottom_floating_panel div.ov_floating_panel_text {
  padding: 3px;
  margin-bottom: 10px;
  float: left
}

div.ov_bottom_floating_panel div.ov_floating_panel_button {
  width: 120px;
  float: right
}

div.ov_measure_panel {
  padding: 6px 15px;
  position: absolute;
  border-radius: 30px;
  left: 0;
  top: 0
}

div.ov_measure_panel div.ov_svg_icon {
  color: inherit;
  margin-bottom: 2px
}

div.ov_measure_panel div.ov_measure_value {
  float: left;
  margin-right: 10px
}

@media (hover) {
  div.title_right div.header_button:hover {
    color: var(--ov_button_color)
  }

  div.ov_toolbar div.ov_toolbar_button:hover {
    background: var(--ov_hover_color)
  }
}

@media (max-width: 350px),
(max-height: 620px) {
  div.intro_content {
    margin: 0 auto
  }

  div.intro div.intro_logo {
    display: none
  }
}

@media (max-width: 800px) {
  div.intro_content {
    width: auto
  }

  div.main_viewer canvas {
    border: 0px;
    margin: 0
  }

  div.ov_dialog,
  div.ov_progress {
    max-width: 80%
  }

  div.ov_bottom_floating_panel {
    padding: 10px
  }
}

div.embed_viewer {
  overflow: auto
}

div.embed_viewer img.embed_logo {
  width: 40px;
  height: 40px;
  position: absolute;
  right: 10px;
  bottom: 10px;
  display: block
}

/*! Bundled license information:

@simonwep/pickr/dist/themes/monolith.min.css:
  (*! Pickr 1.9.0 MIT | https://github.com/Simonwep/pickr *)
*/
/*# sourceMappingURL=o3dv.website.min.css.map */