html {
    line-height: 1.15; /* 1 */
    -ms-text-size-adjust: 100%; /* 2 */
    -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
    margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
    display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main { /* 1 */
    display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
    margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
    box-sizing: content-box; /* 1 */
    height: 0; /* 1 */
    overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
    font-family: monospace, monospace; /* 1 */
    font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
    background-color: transparent; /* 1 */
    -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
    border-bottom: none; /* 1 */
    text-decoration: underline; /* 2 */
    text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
    font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
    font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
    font-family: monospace, monospace; /* 1 */
    font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
    font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

mark {
    background-color: #ff0;
    color: #000;
}

/**
 * Add the correct font size in all browsers.
 */

small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
    display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
    display: none;
    height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
    border-style: none;
}

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
    overflow: hidden;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
    font-family: sans-serif; /* 1 */
    font-size: 100%; /* 1 */
    line-height: 1.15; /* 1 */
    margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
    overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
    text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */

button,
html [type="button"], /* 1 */
[type="reset"],
[type="submit"] {
    -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    border-style: none;
    padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
    outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
    padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */

legend {
    box-sizing: border-box; /* 1 */
    color: inherit; /* 2 */
    display: table; /* 1 */
    max-width: 100%; /* 1 */
    padding: 0; /* 3 */
    white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
    display: inline-block; /* 1 */
    vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
    overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

[type="checkbox"],
[type="radio"] {
    box-sizing: border-box; /* 1 */
    padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
    -webkit-appearance: textfield; /* 1 */
    outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
    -webkit-appearance: button; /* 1 */
    font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details, /* 1 */
menu {
    display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
    display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
    display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
    display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
    display: none;
}
/* line 1, app/assets/stylesheets/globals.scss */
html {
  overflow-y: auto;
}

/* line 5, app/assets/stylesheets/globals.scss */
body,
button,
input,
select,
textarea {
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft Yahei", "WenQuanYi Micro Hei", "sans-serif";
}

/* line 13, app/assets/stylesheets/globals.scss */
body {
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

/* line 18, app/assets/stylesheets/globals.scss */
.hero-body {
  padding: 40px 0;
}

/* line 22, app/assets/stylesheets/globals.scss */
.content a:not(.button):visited {
  color: #1fc8db;
}

/* line 26, app/assets/stylesheets/globals.scss */
.content a:not(.button) {
  border-bottom: none;
}

/* line 30, app/assets/stylesheets/globals.scss */
code {
  font-size: inherit;
  cursor: pointer;
}

/* line 35, app/assets/stylesheets/globals.scss */
.input.is-flat,
.is-flat.textarea {
  border: none;
  box-shadow: none;
}

/* line 41, app/assets/stylesheets/globals.scss */
.content a:visited {
  color: #1fc8db;
}

@media screen and (min-width: 768px) {
  /* line 46, app/assets/stylesheets/globals.scss */
  .columns.is-tablet {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}

/* line 54, app/assets/stylesheets/globals.scss */
.content a {
  border-bottom: none;
}

@media screen and (min-width: 980px) {
  /* line 59, app/assets/stylesheets/globals.scss */
  a.nav-item.is-tab.logo {
    padding-left: 0;
  }
}

@media screen and (max-device-width: 640px) {
  /* line 72, app/assets/stylesheets/globals.scss */
  .box {
    overflow-x: hidden;
  }
}

/* line 77, app/assets/stylesheets/globals.scss */
.subheader.tabs:not(:last-child) {
  margin-bottom: 0;
}

/* line 81, app/assets/stylesheets/globals.scss */
.footer {
  padding: 40px 20px 40px;
}

/* line 85, app/assets/stylesheets/globals.scss */
.pagination {
  width: 100%;
}

/* line 88, app/assets/stylesheets/globals.scss */
.pagination span.active {
  background: #00d1b2;
  border: none;
  color: #fff;
  display: block;
  margin: 0 4px;
  display: block;
  min-width: 32px;
  padding: 5px 8px;
  border-radius: 4px;
}

/* line 101, app/assets/stylesheets/globals.scss */
.katex {
  font-size: 1em !important;
}

/* line 106, app/assets/stylesheets/globals.scss */
.tgl {
  display: none;
}

/* line 110, app/assets/stylesheets/globals.scss */
.tgl + .tgl-btn {
  outline: 0;
  display: block;
  width: 44px;
  height: 24px;
  position: relative;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

/* line 123, app/assets/stylesheets/globals.scss */
.tgl + .tgl-btn:after,
.tgl + .tgl-btn:before {
  position: relative;
  display: block;
  content: "";
  width: 50%;
  height: 100%;
}

/* line 132, app/assets/stylesheets/globals.scss */
.tgl + .tgl-btn:after {
  left: 0;
}

/* line 136, app/assets/stylesheets/globals.scss */
.tgl + .tgl-btn:before {
  display: none;
}

/* line 140, app/assets/stylesheets/globals.scss */
.tgl:checked + .tgl-btn:after {
  left: 50%;
}

/* line 144, app/assets/stylesheets/globals.scss */
.tgl-light + .tgl-btn {
  background: #f0f0f0;
  border-radius: 2em;
  padding: 2px;
  -webkit-transition: all .4s ease;
  transition: all .4s ease;
}

/* line 152, app/assets/stylesheets/globals.scss */
.tgl-light + .tgl-btn:after {
  border-radius: 50%;
  background: #fff;
  -webkit-transition: all .2s ease;
  transition: all .2s ease;
}

/* line 159, app/assets/stylesheets/globals.scss */
.tgl-light:checked + .tgl-btn {
  background: #97cd76;
}

/* line 164, app/assets/stylesheets/globals.scss */
.button.is-primary.is-outlined.graphPlay {
  color: #738e9c;
  border-color: #738e9c;
}

/* line 169, app/assets/stylesheets/globals.scss */
.graphToolbar {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 40px;
  text-align: center;
}

/* line 176, app/assets/stylesheets/globals.scss */
.graphToolbar .graphPlay {
  position: absolute;
  left: 2px;
  top: 5px;
  cursor: pointer;
  border-radius: 16px;
  padding: 1px 8px 0 12px;
  width: 30px;
  height: 30px;
}

/* line 187, app/assets/stylesheets/globals.scss */
.graphToolbar .graphSwitch {
  position: absolute;
  right: 5px;
  top: 10px;
}

/* line 193, app/assets/stylesheets/globals.scss */
.graphToolbar .graphButton {
  margin: 0 5px;
  line-height: 2;
}

/* line 199, app/assets/stylesheets/globals.scss */
.logintips {
  text-align: center;
  padding: 10px;
  font-size: 1.2em;
}

/* line 206, app/assets/stylesheets/globals.scss */
.katex span.accent-body.accent-vec {
  display: inline;
}

/* line 212, app/assets/stylesheets/globals.scss */
.scroller {
  overflow: auto;
  height: 100%;
}

/* line 217, app/assets/stylesheets/globals.scss */
.scroller::-webkit-scrollbar {
  width: 6px;
  background-color: #F5F5F5;
}

/* line 222, app/assets/stylesheets/globals.scss */
.scroller::-webkit-scrollbar-track {
  -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
  background-color: #F5F5F5;
  -webkit-border-radius: 0;
}

/* line 228, app/assets/stylesheets/globals.scss */
.scroller::-webkit-scrollbar-thumb {
  background-color: #c1c1c1;
  -webkit-border-radius: 0;
}

/* line 234, app/assets/stylesheets/globals.scss */
.panel-block form {
  width: 80%;
}
/* line 5, app/assets/stylesheets/scenes.scss */
.scenes .cursor-default {
  cursor: default;
}

/* line 9, app/assets/stylesheets/scenes.scss */
.scenes .cursor-pointer {
  cursor: pointer;
}

/* line 13, app/assets/stylesheets/scenes.scss */
.scenes .cursor-move {
  cursor: move;
}

/* line 17, app/assets/stylesheets/scenes.scss */
.scenes #container {
  z-index: 9000;
  pointer-events: none;
}

/* line 19, app/assets/stylesheets/scenes.scss */
.scenes #container input,
.scenes #container textarea,
.scenes #container button,
.scenes #container select,
.scenes #container a,
.scenes #container div,
.scenes #container path {
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

/* line 31, app/assets/stylesheets/scenes.scss */
.scenes #container input:focus {
  outline: none;
}

/* line 38, app/assets/stylesheets/scenes.scss */
.scenes #container #hjcheck_done,
.scenes #container .ctlbutton {
  pointer-events: auto;
}

/* line 44, app/assets/stylesheets/scenes.scss */
.scenes .rotscl {
  position: absolute;
}

/* line 48, app/assets/stylesheets/scenes.scss */
.scenes .content {
  width: 1200px;
  height: 600px;
  overflow: hidden;
}

/* line 53, app/assets/stylesheets/scenes.scss */
.scenes .content .page > div > svg {
  z-index: 5000;
  position: absolute;
  transform: translateZ(0px);
}

/* line 61, app/assets/stylesheets/scenes.scss */
.scenes text {
  -webkit-user-select: none;
  user-select: none;
}

/* line 66, app/assets/stylesheets/scenes.scss */
.scenes .leftBox {
  padding: 0;
  height: 100%;
}

/* line 71, app/assets/stylesheets/scenes.scss */
.scenes .rightBox {
  -webkit-box-orient: vertical;
  display: -webkit-box;
  height: 100%;
  overflow: hidden;
  padding: 0;
}

/* line 79, app/assets/stylesheets/scenes.scss */
.scenes .subtitleBox {
  text-align: center;
  position: absolute;
  width: 100%;
  bottom: 60px;
  background: transparent;
}

/* line 86, app/assets/stylesheets/scenes.scss */
.scenes .subtitleBox .subtitleDiv {
  color: white;
  background: rgba(0, 0, 0, 0.6);
  display: inline-block;
  padding: 5px;
  font-size: 1.8em;
  border-radius: 5px;
}

/* line 95, app/assets/stylesheets/scenes.scss */
.scenes .subtitleBox mark {
  color: #e91e63;
}

/* line 100, app/assets/stylesheets/scenes.scss */
.scenes .toolbar {
  height: 55px;
  text-align: center;
  margin: 0 0 0 0;
  padding: 16px 0 8px 0;
  background: #263539;
  position: relative;
}

/* line 108, app/assets/stylesheets/scenes.scss */
.scenes .toolbar #fullButton {
  margin-right: 6px;
}

/* line 112, app/assets/stylesheets/scenes.scss */
.scenes .toolbar .slider {
  position: absolute;
  top: 0;
  left: 0;
}

/* line 119, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarl {
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100px;
  pointer-events: none;
}

/* line 127, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarl a {
  pointer-events: auto;
}

/* line 132, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarm {
  pointer-events: auto;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(0, 0, 0, 0.3);
}

/* line 141, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarm #playButton {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 120px;
  height: 120px;
  margin-top: -60px;
  margin-left: -60px;
}

/* line 152, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarr {
  width: 82px;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  z-index: 9000;
  transform: translateZ(3px);
  pointer-events: none;
}

/* line 165, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarr .mitem {
  width: 100%;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

/* line 173, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarr .mitem a {
  pointer-events: auto;
}

/* line 178, app/assets/stylesheets/scenes.scss */
.scenes #minitoolbarr .mitem.last {
  align-items: flex-end;
}

/* line 183, app/assets/stylesheets/scenes.scss */
.scenes .page_num {
  position: absolute;
  bottom: 5px;
  left: 85px;
  background: transparent;
  color: #fff;
  padding: 3px 5px;
  text-shadow: 0 0 0.2em #484848;
  z-index: 9333;
  font-size: 0.8em;
  user-select: none;
  opacity: 0.8;
  -webkit-user-select: none;
}

/* line 198, app/assets/stylesheets/scenes.scss */
.scenes .page_num #debug_message {
  background: #e25041;
  border-radius: 4px;
  text-shadow: none;
}

/* line 203, app/assets/stylesheets/scenes.scss */
.scenes .page_num #debug_message span {
  padding: 10px;
}

/* line 209, app/assets/stylesheets/scenes.scss */
.scenes #prevButton {
  left: 0;
  bottom: 0;
  opacity: 0.8;
  transform-origin: 0% 100%;
  display: none;
  padding: 16px;
}

/* line 218, app/assets/stylesheets/scenes.scss */
.scenes #nextButton {
  right: 0;
  bottom: 0;
  transform-origin: 100% 100%;
  opacity: 0;
  padding: 16px;
  display: none;
}

/* line 227, app/assets/stylesheets/scenes.scss */
.scenes .ctrlbtnsize {
  width: 50px;
  height: 50px;
}

@media (min-width: 961px) {
  /* line 1, app/assets/stylesheets/scenes.scss */
  .scenes {
    /* tablet, landscape iPad, lo-res laptops ands desktops */
  }
  /* line 235, app/assets/stylesheets/scenes.scss */
  .scenes .ctrlbtnsize {
    width: 60px;
    height: 60px;
  }
}

/* line 241, app/assets/stylesheets/scenes.scss */
.scenes #popaButton {
  right: 15px;
  top: 120px;
  opacity: 0.8;
  transform-origin: 100% 100%;
  display: none;
}

@media only screen and (min-device-width: 320px) and (max-device-width: 568px) {
  /* line 257, app/assets/stylesheets/scenes.scss */
  .scenes #popaButton {
    top: 70px;
  }
}

/* line 266, app/assets/stylesheets/scenes.scss */
.scenes .ctlbutton {
  width: 50px;
  height: 50px;
  position: absolute;
  z-index: 8000;
  cursor: pointer;
  transform: translateZ(3px);
}

@media screen and (max-width: 768px) {
  /* line 276, app/assets/stylesheets/scenes.scss */
  .scenes .is-3 {
    display: none;
  }
  /* line 280, app/assets/stylesheets/scenes.scss */
  .scenes .rightContainer {
    padding-left: 10px;
  }
}

/* line 285, app/assets/stylesheets/scenes.scss */
.scenes .system_animation {
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}

/* line 292, app/assets/stylesheets/scenes.scss */
.scenes .lesson {
  background: #37454b;
  color: #fefefe;
  padding: 10px;
}

/* line 297, app/assets/stylesheets/scenes.scss */
.scenes .lesson .title {
  color: #fefefe;
  margin: 10px 0 15px 0;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* line 304, app/assets/stylesheets/scenes.scss */
.scenes .lesson blockquote {
  padding: 10px 20px 10px 10px;
  margin-bottom: 20px;
}

/* line 308, app/assets/stylesheets/scenes.scss */
.scenes .lesson blockquote:before {
  content: '';
}

/* line 319, app/assets/stylesheets/scenes.scss */
.scenes #contentWrapper {
  -moz-box-flex: 1;
  -webkit-box-flex: 1;
  box-flex: 1;
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
}

/* line 335, app/assets/stylesheets/scenes.scss */
.scenes .gadget .graphBox {
  border: none;
}

/* line 340, app/assets/stylesheets/scenes.scss */
.scenes .gridbackground {
  position: absolute;
  width: 801px;
  height: 600px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center center;
  z-index: 9000;
  background-size: 100px 100px;
  background-image: linear-gradient(to right, #ff3860 1px, transparent 1px), linear-gradient(to bottom, #ff3860 1px, transparent 1px);
}

/* line 353, app/assets/stylesheets/scenes.scss */
.scenes .quizContainer {
  position: absolute;
  width: 95%;
  height: 95%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  border: 1px solid #ccc;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 5px;
  padding: 10px;
}

/* line 367, app/assets/stylesheets/scenes.scss */
.scenes .quizContainer .question {
  background: #fff;
}

/* line 371, app/assets/stylesheets/scenes.scss */
.scenes .quizContainer .choice {
  background: #fff;
}

/* line 377, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range] {
  border: none;
  display: block;
  height: 8px;
  padding: 0;
  margin: 0;
  cursor: pointer;
  outline: none;
  background: #d3d6db;
  -webkit-tap-highlight-color: transparent;
  --low: 0%;
  --high: 15%;
  width: 100%;
  position: absolute;
  bottom: 0;
  opacity: 0.8;
}

/* line 395, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]:focus {
  outline: none;
}

/* line 399, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-focus-outer {
  border: none;
}

/* line 403, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-webkit-slider-runnable-track,
.scenes input.slider[type=range]::-webkit-slider-thumb,
.scenes input.slider[type=range] {
  -webkit-appearance: none;
  appearance: none;
}

/* line 410, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-webkit-slider-thumb {
  border-radius: 50%;
  height: 18px;
  width: 18px;
  background-color: #fff;
  border: 4px solid #69707a;
  box-shadow: 0 2px 3px rgba(17, 17, 17, 0.1);
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  box-sizing: border-box;
}

/* line 423, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-webkit-slider-thumb:hover {
  -webkit-transform: scale(1.25);
  transform: scale(1.25);
}

/* line 428, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-webkit-slider-thumb:active {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

/* line 433, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-webkit-slider-runnable-track {
  display: -webkit-box;
  display: flex;
  -webkit-box-align: center;
  align-items: center;
  height: 8px;
  border-radius: 0;
  --track-background: linear-gradient(to right, transparent var(--low), #69707a calc(0%), #69707a var(--high), transparent calc(0%)) no-repeat 0 100%;
  background: var(--track-background);
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

/* line 447, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-thumb {
  border-radius: 50%;
  height: 18px;
  width: 18px;
  background-color: #fff;
  border: 4px solid #69707a;
  box-shadow: 0 2px 3px rgba(17, 17, 17, 0.1);
  transform: translateZ(0);
  box-sizing: border-box;
}

/* line 459, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-thumb:hover {
  transform: scale(1.25);
}

/* line 463, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-thumb:active {
  cursor: grabbing;
}

/* line 467, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-progress:focus {
  outline: 0;
  border: 0;
}

/* line 472, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-track {
  background: transparent;
}

/* line 476, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-moz-range-progress {
  display: flex;
  align-items: center;
  width: 100%;
  height: 8px;
  border-radius: 290486px;
  background-color: #69707a;
}

/* line 485, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-ms-thumb {
  border-radius: 50%;
  height: 18px;
  width: 18px;
  background-color: #fff;
  border: 4px solid #69707a;
  box-shadow: 0 2px 3px rgba(17, 17, 17, 0.1);
  transform: translateZ(0);
  box-sizing: border-box;
}

/* line 497, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-ms-thumb:hover {
  transform: scale(1.25);
}

/* line 501, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-ms-thumb:active {
  cursor: grabbing;
}

/* line 505, app/assets/stylesheets/scenes.scss */
.scenes input.slider[type=range]::-ms-tooltip {
  display: none;
}

/* line 510, app/assets/stylesheets/scenes.scss */
.scenes .button svg {
  height: 60%;
  fill: #00d1b2;
}

/* line 515, app/assets/stylesheets/scenes.scss */
.scenes .button:hover svg {
  fill: #fff;
}

/* line 519, app/assets/stylesheets/scenes.scss */
.scenes .panel-block {
  width: 100%;
}

/* line 523, app/assets/stylesheets/scenes.scss */
.scenes #sidetreefield {
  position: absolute;
  right: 10px;
  bottom: 10px;
}

/* line 530, app/assets/stylesheets/scenes.scss */
.scenes .loaderer {
  width: 100%;
  height: 100%;
}

/* line 535, app/assets/stylesheets/scenes.scss */
.scenes #clickback {
  position: absolute;
  z-index: 9900;
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0);
  pointer-events: auto;
}

/* line 545, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-inner {
  bottom: 0;
  height: 60px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 100px;
}

/* line 556, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap {
  animation: spin 2000ms cubic-bezier(0.175, 0.885, 0.32, 1.275) infinite;
  box-sizing: border-box;
  height: 50px;
  left: 0;
  overflow: hidden;
  position: absolute;
  top: 0;
  transform-origin: 50% 100%;
  width: 100px;
}

/* line 568, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line {
  border: 4px solid transparent;
  border-radius: 100%;
  box-sizing: border-box;
  height: 100px;
  left: 0;
  margin: 0 auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 100px;
}

/* line 581, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(1) {
  animation-delay: -50ms;
}

/* line 585, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(2) {
  animation-delay: -100ms;
}

/* line 589, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(3) {
  animation-delay: -150ms;
}

/* line 593, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(4) {
  animation-delay: -200ms;
}

/* line 597, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(5) {
  animation-delay: -250ms;
}

/* line 601, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(1) .loader-line {
  border-color: #eb4747;
  height: 90px;
  width: 90px;
  top: 7px;
}

/* line 608, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(2) .loader-line {
  border-color: #ebeb47;
  height: 76px;
  width: 76px;
  top: 14px;
}

/* line 615, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(3) .loader-line {
  border-color: #47eb47;
  height: 62px;
  width: 62px;
  top: 21px;
}

/* line 622, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(4) .loader-line {
  border-color: #47ebeb;
  height: 48px;
  width: 48px;
  top: 28px;
}

/* line 629, app/assets/stylesheets/scenes.scss */
.scenes .loader0 .loader-line-wrap:nth-child(5) .loader-line {
  border-color: #4747eb;
  height: 34px;
  width: 34px;
  top: 35px;
}

@keyframes spin {
  0%,
15% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* line 649, app/assets/stylesheets/scenes.scss */
.scenes .loader1 {
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: center;
}

/* line 660, app/assets/stylesheets/scenes.scss */
.scenes .loader1 *,
.scenes .loader1 *:before,
.scenes .loader1 *:after {
  box-sizing: border-box;
  position: relative;
}

/* line 667, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .loader-content {
  margin-top: 100px;
}

/* line 671, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .ball {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  margin: 4rem 0 0 2rem;
  z-index: 0;
}

/* line 678, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .ball:after {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  border-radius: 50%;
  box-shadow: inset 0 -8px 0 0 rgba(0, 0, 0, 0.2);
  background: #6E64F0;
  z-index: 1;
}

/* line 692, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .ball:focus {
  outline: none;
}

/* line 695, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .ball:focus:after {
  animation: bounce 400ms infinite alternate;
}

@keyframes bounce {
  from {
    transform: scale(2);
    animation-timing-function: ease-in;
  }
  to {
    transform: scale(0.8);
    animation-timing-function: cubic-bezier(0, 0, 0, 1);
  }
}

@keyframes bounce-shadow {
  from {
    transform: scale(2.5, 2.6) translateY(-50%);
    animation-timing-function: ease-in;
  }
  to {
    transform: scale(0.5) translateY(0);
    animation-timing-function: cubic-bezier(0, 0, 0, 1);
  }
}

/* line 723, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .ball:focus:before {
  content: '';
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.05);
  animation: bounce-shadow 400ms infinite alternate;
  z-index: -10;
}

/* line 739, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog {
  width: 100px;
  height: 100px;
  z-index: 1;
}

/* line 744, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog:before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.03);
  transform: translateY(-30%) scale(1.5);
}

/* line 755, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog * {
  position: absolute;
}

/* line 760, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-body {
  top: -50%;
  animation: dog-body 200ms ease-in-out infinite alternate;
}

/* line 764, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-body:before {
  content: '';
  position: absolute;
  bottom: 90%;
  right: 50%;
  width: 90%;
  height: 90%;
  border-top-left-radius: 100%;
  border-bottom-left-radius: 10%;
  border-top-right-radius: 10%;
  background: rgba(255, 255, 255, 0.4);
  transform-origin: right bottom;
  animation: dog-tail-blur 200ms 33.3333333333ms ease-in-out infinite alternate both;
}

@keyframes dog-tail-blur {
  from {
    transform: rotate(0);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  to {
    transform: rotate(90deg);
    opacity: 0;
  }
}

@keyframes dog-body {
  from {
    transform: translateX(-10%);
  }
  to {
    transform: translateX(10%);
  }
}

/* line 808, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-head {
  animation: dog-head 1800ms cubic-bezier(0.11, 0.79, 0, 0.99) infinite;
}

@keyframes dog-head {
  from,
to {
    transform: rotate(45deg);
  }
  33.3% {
    transform: rotate(-45deg);
  }
  66.6% {
    transform: rotate(0);
  }
}

/* line 828, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-torso {
  top: -20%;
  animation: dog-torso 200ms ease-in-out infinite alternate-reverse;
}

@keyframes dog-torso {
  from {
    transform: translateX(-5%);
  }
  to {
    transform: translateX(5%);
  }
}

/* line 843, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-eyes {
  width: 60%;
  top: 55%;
  left: 20%;
  z-index: 1;
}

/* line 849, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-eyes:before {
  content: '';
  display: block;
  height: 40px;
  width: 40px;
  border-radius: 40px;
  position: absolute;
  background: orange;
  top: -10px;
  left: -10px;
  z-index: 0;
  border: 4px solid white;
  border-left-width: 0;
  border-bottom-width: 0;
  border-top-width: 0;
  transform: rotate(-45deg);
}

/* line 868, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-eye {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #000;
  z-index: 1;
  animation: dog-eye 1800ms infinite;
}

@keyframes dog-eye {
  from,
to {
    animation-timing-function: step-end;
    opacity: 1;
  }
  50%,
55% {
    animation-timing-function: step-start;
    opacity: 0;
  }
}

/* line 891, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-eye:first-child {
  left: 0;
}

/* line 895, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-eye:last-child {
  right: 0;
}

/* line 900, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-muzzle {
  width: 60%;
  left: 20%;
  height: 50%;
  border-bottom-left-radius: 100%;
  border-bottom-right-radius: 100%;
  background: white;
  bottom: -15%;
}

/* line 909, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-muzzle:before, .scenes .loader1 .dog-muzzle:after {
  content: '';
  display: block;
  position: absolute;
}

/* line 916, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-muzzle:before {
  width: 6px;
  height: 20px;
  bottom: 0;
  left: calc(50% - 3px);
  background: #EAEBEC;
}

/* line 924, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-muzzle:after {
  background: black;
  width: 20px;
  height: 15px;
  bottom: 12px;
  left: calc(50% - 10px);
  border-bottom-left-radius: 60% 60%;
  border-bottom-right-radius: 60% 60%;
  border-top-left-radius: 50% 40%;
  border-top-right-radius: 50% 40%;
}

/* line 941, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-tongue {
  width: 40px;
  height: 100%;
  left: calc(50% - 20px);
  z-index: -1;
  transform-origin: center top;
  animation: dog-tongue 1800ms -50ms ease-in-out infinite;
}

@keyframes dog-tongue {
  from,
to {
    transform: rotate(0);
  }
  16.6666666667% {
    transform: rotate(30deg);
  }
  33.3333333333%,
66.6666666667% {
    transform: rotate(0);
  }
  50%,
83.3333333333% {
    transform: rotate(-20deg);
  }
}

/* line 969, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-tongue:before {
  content: '';
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 40px;
  background: #FD3163;
  animation: dog-tongue-inner 100ms ease-in-out infinite alternate;
}

@keyframes dog-tongue-inner {
  from {
    transform: translateY(5%);
  }
  to {
    transform: translateY(22%);
  }
}

/* line 992, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-ears {
  width: 40%;
  top: 25%;
  left: 30%;
  animation: dog-ears 1800ms 100ms ease infinite;
}

@keyframes dog-ears {
  42.3%,
71.6% {
    transform: rotate(-5deg);
  }
  50.3%,
79.6% {
    transform: rotate(5deg);
  }
  5% {
    transform: rotate(5deg);
  }
  12% {
    transform: rotate(-5%);
  }
  from,
33.3%,
66%,
to {
    transform: rotate(0);
  }
}

/* line 1027, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-ear {
  bottom: -10px;
  height: 50px;
  width: 50px;
  background: #EAEBEC;
  animation-duration: 400ms;
  animation-direction: alternate;
  animation-timing-function: ease-in-out;
  animation-fill-mode: both;
  animation-iteration-count: infinite;
}

/* line 1038, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-ear:first-child {
  border-bottom-left-radius: 80%;
  border-top-right-radius: 80%;
  right: 100%;
  box-shadow: inset -15px 15px 0 1px white;
  transform-origin: right bottom;
  transform: rotate(10deg);
}

/* line 1047, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-ear:last-child {
  border-top-left-radius: 80%;
  border-bottom-right-radius: 80%;
  left: 100%;
  box-shadow: inset 15px 15px 0 0 white;
  transform-origin: left bottom;
  transform: rotate(-10deg);
}

/* line 1057, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-tail {
  width: 22px;
  height: 24.2px;
  background: white;
  bottom: 40%;
  border-radius: 11px;
  left: calc(50% - 11px);
  transform-origin: center bottom;
}

/* line 1067, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-tail .dog-tail {
  animation: dog-tail-segment 200ms ease-in-out infinite alternate;
}

@keyframes dog-tail-segment {
  from {
    transform: rotate(-10deg);
  }
  to {
    transform: rotate(10deg);
  }
}

/* line 1082, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-body > .dog-tail {
  bottom: 90%;
  animation: dog-tail 200ms ease-in-out infinite alternate;
}

@keyframes dog-tail {
  from {
    transform: rotate(-45deg);
  }
  to {
    transform: rotate(45deg);
  }
}

/* line 1097, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-body,
.scenes .loader1 .dog-torso,
.scenes .loader1 .dog-head {
  border-radius: 50%;
  background: white;
  position: absolute;
  height: 100%;
  width: 100%;
}

/* line 1107, app/assets/stylesheets/scenes.scss */
.scenes .loader1 .dog-body,
.scenes .loader1 .dog-torso {
  box-shadow: inset 0 -15px 0 0 #EAEBEC;
}

/* line 1114, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .loader-content {
  height: 100%;
  display: flex;
  justify-content: center;
  width: 100%;
  position: absolute;
  transform: scale(0.6);
}

/* line 1123, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .wall {
  background-color: #d6d6d6;
  width: 500px;
  height: 70px;
  bottom: 30%;
  position: absolute;
  border-radius: 10px;
  z-index: 1;
}

/* line 1133, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .wall::before,
.scenes .loader2 .wall::after {
  width: 20px;
  height: 40px;
  left: 20%;
  bottom: -40px;
  background-color: #737373;
  position: absolute;
  content: '';
  border-radius: 0px 0px 20px 20px;
}

/* line 1145, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .wall::after {
  left: 75%;
}

/* line 1149, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .cat {
  width: 200px;
  height: 250px;
  background-color: #e4a547;
  border-radius: 100%;
  position: absolute;
  bottom: calc(30% + 20px);
  box-shadow: inset 0px -20px 0px rgba(0, 0, 0, 0.2);
}

/* line 1159, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .cat::after {
  width: 60%;
  height: 60%;
  left: 20%;
  top: 45%;
  background-color: white;
  position: absolute;
  content: '';
  border-radius: 100%;
  opacity: 0.2;
}

/* line 1171, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .ears {
  position: relative;
  z-index: -1;
}

/* line 1176, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .ears span {
  width: 60px;
  height: 60px;
  background-color: #d47151;
  position: absolute;
  top: -5px;
  border: solid 8px #e4a547;
  border-radius: 10px;
}

/* line 1186, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .ears span:nth-child(1) {
  left: 30px;
  box-shadow: inset 0px 5px 0px rgba(0, 0, 0, 0.1);
  animation: ear1 8s ease infinite;
}

@keyframes ear1 {
  0%,
80%,
100% {
    transform: rotate(20deg);
  }
  90% {
    transform: rotate(8deg);
  }
}

/* line 1205, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .ears span:nth-child(2) {
  right: 30px;
  box-shadow: inset 0px 5px 0px rgba(0, 0, 0, 0.1);
  animation: ear2 8s ease infinite;
}

@keyframes ear2 {
  0%,
80%,
100% {
    transform: rotate(-20deg);
  }
  90% {
    transform: rotate(-8deg);
  }
}

/* line 1224, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span {
  width: 30px;
  height: 30px;
  position: absolute;
  top: 30px;
  border-radius: 100%;
  background-color: white;
}

/* line 1233, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(1) {
  left: 50px;
}

/* line 1237, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(2) {
  right: 50px;
}

/* line 1241, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(1)::after,
.scenes .loader2 .eyes span:nth-child(2)::after {
  width: inherit;
  height: inherit;
  left: 0;
  position: absolute;
  content: '';
  z-index: 1;
  border-radius: 100%;
  animation: blink 8s ease-in-out infinite;
}

@keyframes blink {
  0%,
70% {
    box-shadow: inset 0px 5px 0px #ce8314;
  }
  85% {
    box-shadow: inset 0px 40px 0px #ce8314;
  }
  100% {
    box-shadow: inset 0px 5px 0px #ce8314;
  }
}

/* line 1269, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(3),
.scenes .loader2 .eyes span:nth-child(4) {
  width: 10px;
  height: 10px;
  background-color: black;
  position: absolute;
  box-shadow: none;
  top: 45px;
  left: 65px;
  border-radius: 100%;
}

/* line 1281, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(4) {
  left: 125px;
}

/* line 1285, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(1)::before {
  left: 35%;
}

/* line 1289, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .eyes span:nth-child(2)::before {
  right: 35%;
}

/* line 1293, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose {
  width: 0px;
  height: 0px;
  position: absolute;
  top: 70px;
  left: calc(50% - 12px);
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top: 12px solid #d47151;
  z-index: 1;
  animation: nose 6s ease infinite;
}

@keyframes nose {
  0%,
80%,
100% {
    transform: rotate(0deg);
  }
  85%,
95% {
    transform: rotate(-2deg);
  }
  90% {
    transform: rotate(2deg);
  }
}

/* line 1324, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span {
  width: 120px;
  height: 2px;
  background-color: white;
  position: absolute;
  top: -6px;
  left: -125px;
  border-radius: 5px;
  opacity: 0.2;
  z-index: 0;
}

/* line 1336, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span:nth-child(2) {
  left: 5px;
}

/* line 1340, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span::after,
.scenes .loader2 .nose span::before {
  width: inherit;
  height: inherit;
  content: '';
  position: absolute;
  background-color: inherit;
  top: -10px;
  width: 110px;
  left: 10px;
  border-radius: inherit;
  transform: rotate(10deg);
}

/* line 1354, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span:nth-child(1)::before {
  transform: rotate(-10deg);
  top: 10px;
  left: 10px;
}

/* line 1360, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span:nth-child(2)::after {
  top: -10px;
  transform: rotate(-10deg);
  left: 0px;
}

/* line 1366, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .nose span:nth-child(2)::before {
  top: 10px;
  left: 0px;
}

/* line 1371, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .mouth {
  font-family: 'Nunito', sans-serif;
  color: #d28422;
  font-size: 30px;
  transform: rotate(90deg);
  top: 72px;
  position: absolute;
  left: calc(50% - 10px);
  letter-spacing: 1px;
  font-weight: 100;
  animation: mouth 6s ease infinite;
}

@keyframes mouth {
  0%,
80%,
90%,
100% {
    top: 75px;
  }
  85%,
95% {
    top: 73px;
  }
}

/* line 1399, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .mouth::after {
  width: 2px;
  height: 15px;
  content: '';
  position: absolute;
  background-color: #d28422;
  top: 12px;
  left: -1px;
  transform: rotate(90deg);
}

/* line 1410, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .paws {
  width: 30px;
  height: 30px;
  position: absolute;
  top: 30px;
  border-radius: 100%;
  z-index: 1;
}

/* line 1419, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .paws span {
  width: 30px;
  height: 30px;
  background-color: brown;
  position: absolute;
  bottom: -160px;
  border-radius: 100%;
  opacity: 0.3;
  box-shadow: inset 5px 0px 0px rgba(0, 0, 0, 0.5);
}

/* line 1430, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .paws span:nth-child(1) {
  left: 50px;
}

/* line 1434, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .paws span:nth-child(2) {
  left: 120px;
}

/* line 1438, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .tail {
  width: 100px;
  height: 15px;
  position: absolute;
  bottom: 50px;
  border-radius: 30px;
  z-index: 1;
  right: -65px;
  background-color: #e4a547;
  z-index: -1;
  animation: tail 3s ease-in-out infinite alternate;
}

@keyframes tail {
  0% {
    right: -65px;
  }
  50% {
    transform: rotate(0deg);
  }
  60% {
    transform: rotate(-180deg);
  }
  100% {
    right: 145px;
    transform: rotate(-180deg);
  }
}

/* line 1470, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .tail::after {
  width: 25%;
  height: inherit;
  content: '';
  position: absolute;
  border-top-right-radius: 30px;
  border-bottom-right-radius: 30px;
  background-color: white;
  right: 0px;
  opacity: 0.2;
}

/* line 1482, app/assets/stylesheets/scenes.scss */
.scenes .loader2 .tail::before {
  width: 10%;
  height: inherit;
  content: '';
  position: absolute;
  border-radius: 0px;
  background-color: black;
  right: 25%;
  opacity: 0.1;
}

/* line 1503, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .loader-content {
  width: 100%;
  height: 100%;
  transform: scale(0.8);
}

/* line 1509, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog {
  height: 182px;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}

/* line 1515, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ears2 {
  height: 0;
  width: 0;
  position: relative;
  left: 30px;
  border-bottom: 27px solid #F07E42;
  border-left: 23px solid transparent;
  border-right: 10px solid transparent;
}

/* line 1524, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ears2::before {
  display: block;
  content: "";
  height: 0;
  width: 0;
  position: relative;
  left: 33px;
  border-bottom: 27px solid #F07E42;
  border-left: 10px solid transparent;
  border-right: 23px solid transparent;
}

/* line 1537, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .head2 {
  height: 74px;
  width: 140px;
  position: relative;
  z-index: 2;
  box-shadow: 8px 0 0 #F07E42;
  border-radius: 35px;
  background: #FFA852;
}

/* line 1546, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .head2 .eyes2 {
  height: 12px;
  width: 12px;
  position: relative;
  top: 37px;
  left: 50px;
  border-radius: 100%;
  animation: 9s dogRead infinite;
  background: black;
}

/* line 1556, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .head2 .eyes2::before {
  display: block;
  content: "";
  height: 12px;
  width: 12px;
  position: relative;
  left: 18px;
  border-radius: 100%;
  background: black;
}

/* line 1568, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .head2 .nose2 {
  height: 30px;
  width: 45px;
  position: relative;
  top: 40px;
  left: 37px;
  border-radius: 20px;
  background: #FBF1D8;
}

/* line 1577, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .head2 .nose2::before {
  display: block;
  content: "";
  height: 0;
  width: 0;
  position: relative;
  top: 3px;
  left: 9px;
  border-radius: 10px;
  border-top: 10px solid black;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
}

/* line 1593, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .body2 {
  height: 110px;
  width: 200px;
  position: relative;
  top: -30px;
  z-index: 1;
  border-radius: 55px;
  background: #FFA852;
}

/* line 1602, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .body2 .left-paw2 {
  height: 25px;
  width: 37px;
  position: relative;
  top: 70px;
  left: 15px;
  border-radius: 12px;
  animation: 9s dogLeftType infinite;
  background: #FBF1D8;
}

/* line 1613, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .body2 .right-paw2 {
  height: 25px;
  width: 37px;
  position: relative;
  top: 45px;
  left: 60px;
  border-radius: 12px;
  animation: 9s dogRightType infinite;
  background: #FBF1D8;
}

/* line 1625, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .tail2 {
  height: 34px;
  width: 70px;
  position: relative;
  top: -64px;
  left: 150px;
  z-index: 0;
  border-radius: 0 17px 17px 0;
  background: #F07E42;
}

/* line 1636, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop {
  position: relative;
  top: -161px;
  left: -103px;
  z-index: 2;
}

/* line 1642, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop .ORscreen {
  height: 85px;
  width: 130px;
  border-radius: 8px;
  transform: skew(18deg);
  background: #FFCA95;
}

/* line 1649, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop .ORscreen::before {
  display: block;
  content: "";
  height: 17px;
  width: 10px;
  position: relative;
  top: 38px;
  left: 50px;
  border-radius: 6px;
  background: #F07E42;
}

/* line 1661, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop .ORscreen::after {
  display: block;
  content: "";
  height: 17px;
  width: 10px;
  position: relative;
  top: 21px;
  left: 64px;
  border-radius: 6px;
  background: #F07E42;
}

/* line 1674, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop .ORkeyboard {
  height: 12px;
  width: 132px;
  position: relative;
  left: 14px;
  border-radius: 6px 0 0 6px;
  background: #F07E42;
}

/* line 1682, app/assets/stylesheets/scenes.scss */
.scenes .loader3 .dog .ORlaptop .ORkeyboard::before {
  display: block;
  content: "";
  height: 12px;
  width: 72px;
  position: relative;
  left: 128px;
  border-radius: 6px;
  background: #FFCA95;
}

@keyframes catLeftType {
  2% {
    transform: translateY(-8px);
  }
  6% {
    transform: none;
  }
  8% {
    transform: translateY(-8px);
  }
  10% {
    transform: none;
  }
  14% {
    transform: translateY(-8px);
  }
  16% {
    transform: none;
  }
  18% {
    transform: translateY(-8px);
  }
  20% {
    transform: none;
  }
  22% {
    transform: translateY(-8px);
  }
  26% {
    transform: none;
  }
}

@keyframes catRightType {
  6% {
    transform: translateY(-8px);
  }
  8% {
    transform: none;
  }
  10% {
    transform: translateY(-8px);
  }
  12% {
    transform: none;
  }
  16% {
    transform: translateY(-8px);
  }
  18% {
    transform: none;
  }
  20% {
    transform: translateY(-8px);
  }
  22% {
    transform: none;
  }
  24% {
    transform: translateY(-8px);
  }
  28% {
    transform: none;
  }
}

@keyframes catRead {
  55% {
    transform: none;
  }
  62% {
    transform: translateX(-2px);
  }
  70% {
    transition-timing-function: ease-out;
    transform: translateX(3px);
  }
  82% {
    transform: translateX(-2px);
  }
  90% {
    transition-timing-function: ease-out;
    transform: translateX(3px);
  }
  100% {
    transform: none;
  }
}

@keyframes dogLeftType {
  50% {
    transform: none;
  }
  52% {
    transform: translateY(-8px);
  }
  56% {
    transform: none;
  }
  58% {
    transform: translateY(-8px);
  }
  60% {
    transform: none;
  }
  64% {
    transform: translateY(-8px);
  }
  66% {
    transform: none;
  }
  68% {
    transform: translateY(-8px);
  }
  70% {
    transform: none;
  }
  72% {
    transform: translateY(-8px);
  }
  76% {
    transform: none;
  }
}

@keyframes dogRightType {
  54% {
    transform: none;
  }
  56% {
    transform: translateY(-8px);
  }
  58% {
    transform: none;
  }
  60% {
    transform: translateY(-8px);
  }
  62% {
    transform: none;
  }
  66% {
    transform: translateY(-8px);
  }
  68% {
    transform: none;
  }
  70% {
    transform: translateY(-8px);
  }
  72% {
    transform: none;
  }
  74% {
    transform: translateY(-8px);
  }
  78% {
    transform: none;
  }
}

@keyframes dogRead {
  5% {
    transform: none;
  }
  17% {
    transition-timing-function: ease-out;
    transform: translateX(-5px);
  }
  25% {
    transform: none;
  }
  37% {
    transition-timing-function: ease-out;
    transform: translateX(-5px);
  }
  45% {
    transform: none;
  }
}

@keyframes tail {
  6.6666666667% {
    transform: rotate(0);
  }
  10% {
    transform: rotate(10deg);
  }
  16.6666666667% {
    transform: rotate(-5deg);
  }
  20% {
    transform: rotate(30deg);
  }
  26.6666666667% {
    transform: rotate(-2deg);
  }
  46.6666666667% {
    transform: rotate(10deg);
  }
  53.3333333333% {
    transform: rotate(-5deg);
  }
  56.6666666667% {
    transform: rotate(10deg);
  }
}

@keyframes body {
  6.6666666667% {
    transform: scaleY(1);
  }
  10% {
    transform: scaleY(1.15);
  }
  16.6666666667% {
    transform: scaleY(1);
  }
  20% {
    transform: scaleY(1.25);
  }
  26.6666666667% {
    transform: scaleY(1);
  }
  46.6666666667% {
    transform: scaleY(1.15);
  }
  53.3333333333% {
    transform: scaleY(1);
  }
  56.6666666667% {
    transform: scaleY(1.15);
  }
}

@keyframes left-whisker {
  6.6666666667% {
    transform: rotate(0);
  }
  10% {
    transform: rotate(0deg);
  }
  16.6666666667% {
    transform: rotate(-5deg);
  }
  20% {
    transform: rotate(0deg);
  }
  26.6666666667% {
    transform: rotate(0deg);
  }
  46.6666666667% {
    transform: rotate(10deg);
  }
  53.3333333333% {
    transform: rotate(-5deg);
  }
  56.6666666667% {
    transform: rotate(10deg);
  }
}

@keyframes right-whisker {
  6.6666666667% {
    transform: rotate(180deg);
  }
  10% {
    transform: rotate(190deg);
  }
  16.6666666667% {
    transform: rotate(180deg);
  }
  20% {
    transform: rotate(175deg);
  }
  26.6666666667% {
    transform: rotate(190deg);
  }
  46.6666666667% {
    transform: rotate(180deg);
  }
  53.3333333333% {
    transform: rotate(185deg);
  }
  56.6666666667% {
    transform: rotate(175deg);
  }
}

@keyframes left-ear {
  0% {
    transform: rotate(-20deg);
  }
  6.6666666667% {
    transform: rotate(-7deg);
  }
  13.3333333333% {
    transform: rotate(-15deg);
  }
  26.6666666667% {
    transform: rotate(-15deg);
  }
  33.3333333333% {
    transform: rotate(-30deg);
  }
  40% {
    transform: rotate(-30deg);
  }
  46.6666666667% {
    transform: rotate(-7deg);
  }
  53.3333333333% {
    transform: rotate(-7deg);
  }
  60% {
    transform: rotate(-15deg);
  }
  80% {
    transform: rotate(-15deg);
  }
  93.3333333333% {
    transform: rotate(-7deg);
  }
  100% {
    transform: rotateZ(-6deg);
  }
}

@keyframes right-ear {
  0% {
    transform: rotateZ(-16deg);
  }
  6.6666666667% {
    transform: rotateZ(-16deg);
  }
  13.3333333333% {
    transform: rotateZ(-19deg);
  }
  26.6666666667% {
    transform: rotateZ(-19deg);
  }
  33.3333333333% {
    transform: rotateZ(-30deg);
  }
  36.6666666667% {
    transform: rotateZ(-19deg);
  }
  37.3333333333% {
    transform: rotateZ(-30deg);
  }
  38% {
    transform: rotateZ(-19deg);
  }
  40% {
    transform: rotateZ(-19deg);
  }
  40.6666666667% {
    transform: rotateZ(-30deg);
  }
  41.3333333333% {
    transform: rotateZ(-19deg);
  }
  46.6666666667% {
    transform: rotateZ(-9deg);
  }
  53.3333333333% {
    transform: rotateZ(-9deg);
  }
  60% {
    transform: rotateZ(-19deg);
  }
  60.6666666667% {
    transform: rotateZ(-30deg);
  }
  61.3333333333% {
    transform: rotateZ(-19deg);
  }
  62.6666666667% {
    transform: rotateZ(-19deg);
  }
  63.3333333333% {
    transform: rotateZ(-30deg);
  }
  64% {
    transform: rotateZ(-19deg);
  }
  80% {
    transform: rotateZ(-19deg);
  }
  93.3333333333% {
    transform: rotateZ(-16deg);
  }
  100% {
    transform: rotateZ(-16deg);
  }
}

@keyframes nose {
  6.6666666667% {
    transform: rotate(0deg);
  }
  10% {
    transform: rotate(-8deg);
  }
  16.6666666667% {
    transform: translateY(1px);
  }
  20% {
    transform: rotate(10deg);
  }
  26.6666666667% {
    transform: rotate(-7deg);
  }
  46.6666666667% {
    transform: rotate(0deg);
  }
  53.3333333333% {
    transform: translateY(-1px);
  }
  56.6666666667% {
    transform: translateY(1px);
  }
}

/* line 2236, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .loader-content {
  height: 100%;
}

/* line 2240, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main {
  height: 400px;
  width: 400px;
  position: relative;
}

/* line 2246, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main .stand {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%);
  height: 20px;
  width: 200px;
  border-radius: 7px;
  background-color: #fd6e72;
  z-index: 2;
}

/* line 2258, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main .stand:after {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translate(-50%);
  height: 10px;
  width: 50px;
  border-radius: 20px;
  background-color: #fdf9de;
  box-shadow: 0 10px 0 #fdf9de, 0 20px 0 #fdf9de, 0 30px 0 #fdf9de, 0 40px 0 #fdf9de, 0 50px 0 #fdf9de, 0 60px 0 #fdf9de, 0 70px 0 #fdf9de, 0 80px 0 #fdf9de, 0 90px 0 #fdf9de, 0 100px 0 #fdf9de, 0 110px 0 #fdf9de, 0 120px 0 #fdf9de, 0 130px 0 #fdf9de, 0 140px 0 #fdf9de, 0 150px 0 #fdf9de, 0 160px 0 #fdf9de, 0 170px 0 #fdf9de;
}

/* line 2271, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main .cat {
  width: 110px;
  height: 50px;
  position: absolute;
  top: calc(50% - 50px);
  right: 130px;
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
}

/* line 2281, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main .cat .body {
  width: 110px;
  height: 50px;
  background-color: #745260;
  position: absolute;
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
  animation: body 12s none infinite;
  box-shadow: inset -1px 4px 15px #8f6576;
}

/* line 2292, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .main .cat .head {
  content: "";
  width: 70px;
  height: 35px;
  background-color: #745260;
  position: absolute;
  top: calc(50% - 10px);
  left: -40px;
  border-top-left-radius: 80px;
  border-top-right-radius: 80px;
  box-shadow: 3px 0 3px #654754;
}

/* line 2305, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .tail-container {
  position: absolute;
  right: 0;
  bottom: -13px;
  z-index: 3;
}

/* line 2312, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .tail {
  position: absolute;
  height: 30px;
  width: 14px;
  bottom: -10px;
  right: 0;
  border-bottom-right-radius: 5px;
  border-top-right-radius: 10px;
  background-color: #745260;
  z-index: 0;
}

/* line 2324, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .tail > .tail {
  animation: tail 12s none infinite;
  height: 100%;
  width: 14px;
  border-bottom-left-radius: 20px 20px;
  border-bottom-right-radius: 20px 20px;
  border-top-right-radius: 40px;
}

/* line 2333, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .ear {
  position: absolute;
  left: 2px;
  top: -2px;
  width: 0;
  height: 0;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-bottom: 20px solid #745260;
  transform: rotate(-30deg);
  animation: left-ear 12s both infinite;
}

/* line 2346, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .ear + .ear {
  animation: right-ear 12s both infinite;
  top: -12px;
  left: 30px;
}

/* line 2352, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .nose {
  position: absolute;
  bottom: 10px;
  left: -10px;
  background-color: #fd6e72;
  height: 5px;
  width: 7px;
  border-radius: 45%;
  transform: rotate(-5deg);
  animation: nose 12s both infinite;
  box-shadow: 1px 1px 3px #563d47;
}

/* line 2365, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .whisker-container {
  position: absolute;
  bottom: 3px;
  left: -36px;
  width: 20px;
  height: 10px;
  transform-origin: right;
  animation: left-whisker 12s both infinite;
}

/* line 2375, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .whisker-container:nth-child(2) {
  left: -16px;
  bottom: 10px;
  transform-origin: right;
  transform: rotate(180deg);
  animation: right-whisker 12s both infinite;
}

/* line 2383, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .whisker {
  position: absolute;
  top: 0;
  width: 100%;
  border: 1px solid #fdf9de;
  background-color: #fdf9de;
  transform-origin: 100% 0;
  transform: rotate(10deg);
  box-shadow: 0 1px 2px #563d47;
}

/* line 2394, app/assets/stylesheets/scenes.scss */
.scenes .loader4 .whisker:last-child {
  top: 0;
  transform: rotate(-20deg);
}

/* line 2407, app/assets/stylesheets/scenes.scss */
.scenes .loader5 * {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

/* line 2413, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .loader-content {
  height: 100%;
}

/* line 2417, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .container {
  margin: auto;
  width: 200px;
  height: 200px;
  position: relative;
  background: #EAEBE1;
  border-radius: 50%;
  overflow: hidden;
  z-index: 100;
}

/* line 2427, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .container div {
  position: absolute;
}

/* line 2432, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .cat {
  width: 70%;
  height: 70%;
  bottom: 0;
  right: 0;
}

/* line 2439, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face {
  width: 60%;
  height: 60%;
  background: #7c95a9;
  border-radius: 50%;
  z-index: 10;
}

/* line 2446, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .ears:before,
.scenes .loader5 .face .ears:after {
  content: "";
  position: absolute;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-bottom: 40px solid #7c95a9;
}

/* line 2455, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .ears:before {
  transform: translate(40px, -20px) rotate(10deg);
}

/* line 2459, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .ears:after {
  transform: translate(60px, -15px) rotate(10deg);
}

/* line 2463, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyes:before,
.scenes .loader5 .face .eyes:after {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: linear-gradient(to right, #000000, #000000 50%, #FFFFFF 50%, #FFFFFF 100%);
  transform: rotate(15deg);
}

/* line 2474, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyes:before {
  top: 20px;
  left: 10px;
}

/* line 2479, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyes:after {
  top: 30px;
  left: 40px;
}

/* line 2484, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyelids:before,
.scenes .loader5 .face .eyelids:after {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(to bottom, #607C92, #607C92 50%, transparent 50%, transparent 100%);
}

/* line 2495, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyelids:before {
  top: 17px;
  left: 10px;
  transform: rotate(25deg);
  animation: blink 2s linear infinite;
}

/* line 2502, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .eyelids:after {
  top: 28px;
  left: 40px;
  transform: rotate(25deg);
  animation: blink 2s linear infinite;
}

/* line 2509, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .nose {
  border-top: 5px solid #607C92;
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  top: 52%;
  left: 30%;
  transform: rotate(15deg);
}

/* line 2518, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face .whiskers:before,
.scenes .loader5 .face .whiskers:after {
  content: "";
  position: absolute;
  width: 3px;
  height: 14px;
  background: #607C92;
}

/* line 2527, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w1 {
  top: 40px;
}

/* line 2530, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w1:before {
  transform: translate(-6px, -15px) rotate(-50deg);
}

/* line 2534, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w1:after {
  transform: translate(-8px, -7px) rotate(-80deg);
}

/* line 2539, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w2 {
  top: 60px;
  left: 65px;
}

/* line 2543, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w2:before {
  transform: translate(2px, -15px) rotate(60deg);
}

/* line 2547, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .face #w2:after {
  transform: translate(2px, -7px) rotate(110deg);
}

/* line 2553, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .body {
  width: 110px;
  border-bottom: 150px solid #7c95a9;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  transform: translate(24px, 20px) rotate(-35deg);
}

/* line 2561, app/assets/stylesheets/scenes.scss */
.scenes .loader5 .tail {
  background: #7c95a9;
  top: 70%;
  left: -10px;
  width: 10px;
  height: 60px;
  border-radius: 50% 60%;
  animation: wag 3s ease-out infinite;
}

@keyframes blink {
  0% {
    background: linear-gradient(to bottom, #607C92, #607C92 50%, transparent 50%, transparent 100%);
  }
  50% {
    background: linear-gradient(to bottom, #607C92, #607C92 20%, transparent 20%, transparent 100%);
  }
  100% {
    background: linear-gradient(to bottom, #607C92, #607C92 50%, transparent 50%, transparent 100%);
  }
}

@keyframes wag {
  0% {
    transform: rotate(-20deg);
  }
  25% {
    transform: rotate(0deg);
  }
  50% {
    transform: rotate(30deg);
  }
  75% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(-20deg);
  }
}

/* line 2612, app/assets/stylesheets/scenes.scss */
.scenes #tips_container {
  width: 100%;
  height: 100%;
}

/* line 2617, app/assets/stylesheets/scenes.scss */
.scenes .ring-container {
  position: relative;
  pointer-events: none;
  width: 26px;
  height: 26px;
}

/* line 2624, app/assets/stylesheets/scenes.scss */
.scenes .circle {
  width: 15px;
  height: 15px;
  background-color: #ffde57;
  border-radius: 50%;
  position: absolute;
  top: 5px;
  left: 5px;
  border: 1px solid rgba(255, 255, 255, 0.6);
}

/* line 2635, app/assets/stylesheets/scenes.scss */
.scenes .ringring {
  border: 3px solid rgba(251, 219, 86, 0.6);
  -webkit-border-radius: 30px;
  height: 25px;
  width: 25px;
  position: absolute;
  left: -2px;
  top: -2px;
  -webkit-animation: pulsate 1.4s ease-out;
  -webkit-animation-iteration-count: infinite;
  opacity: 0.0;
  pointer-events: none;
}

@-webkit-keyframes pulsate {
  0% {
    -webkit-transform: scale(0.1, 0.1);
    opacity: 0.0;
  }
  50% {
    opacity: 1.0;
  }
  100% {
    -webkit-transform: scale(1.2, 1.2);
    opacity: 0.0;
  }
}

/* line 2667, app/assets/stylesheets/scenes.scss */
.scenes .safe_area {
  width: 800px;
  height: 600px;
  z-index: 5001;
  position: absolute;
  overflow: hidden;
  pointer-events: none;
  border-left: 1px dashed rgba(255, 0, 0, 0.3);
  border-right: 1px dashed rgba(255, 0, 0, 0.3);
  left: 200px;
  top: 0;
  transform: translateZ(2px);
}

/* line 2681, app/assets/stylesheets/scenes.scss */
.scenes .fakeDragNode {
  opacity: 0;
}

/* line 2685, app/assets/stylesheets/scenes.scss */
.scenes .ctrlhzbtn {
  cursor: pointer;
}

/* line 2691, app/assets/stylesheets/scenes.scss */
.scene_attachments .panel-block {
  width: 100%;
}

/* line 2696, app/assets/stylesheets/scenes.scss */
.sceneCanvasView {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  z-index: 6000;
  transform: translateZ(1px);
}

/* line 2706, app/assets/stylesheets/scenes.scss */
.sceneCanvasView.under_svg {
  z-index: 4000;
  transform: translateZ(-1px);
}

/* line 2711, app/assets/stylesheets/scenes.scss */
#hjgamecanvas-c {
  z-index: 6000;
  text-align: center;
  transform: translateZ(-1px);
}

/* line 2716, app/assets/stylesheets/scenes.scss */
#hjgamecanvas-c canvas {
  position: absolute;
}

/* line 2720, app/assets/stylesheets/scenes.scss */
#hjgamecanvas-c #hjgamecanvas-div {
  position: absolute;
  top: 0;
  left: 0;
  width: 1200px;
  height: 600px;
  z-index: 6500;
  pointer-events: none;
  transform: translateZ(2px);
}

/* line 2733, app/assets/stylesheets/scenes.scss */
#hjgamecanvas,
.hjgamecanvas {
  z-index: 6000;
  transform: translateZ(2px);
  touch-action: none;
  width: 1200px;
  height: 600px;
  cursor: inherit;
}

/* line 2744, app/assets/stylesheets/scenes.scss */
.scene-table td {
  vertical-align: middle;
}

@font-face {
  font-family: "fpinyin";
  src: url(/fonts/fpinyin.woff2) format("woff2"), url(/fonts/fpinyin.woff) format("woff2");
}

@font-face {
  font-family: "fmono";
  src: url(/fonts/fmono.woff2) format("woff2"), url(/fonts/fmono.woff) format("woff2");
}

@font-face {
  font-family: "fgaegu";
  src: url(/fonts/fgaegu.woff2) format("woff2"), url(/fonts/fgaegu.woff) format("woff2");
}

@font-face {
  font-family: "fnunito";
  src: url(/fonts/fnunito.woff2) format("woff2"), url(/fonts/fnunito.woff) format("woff2");
}

@font-face {
  font-family: "flondrina";
  src: url(/fonts/flondrina.woff2) format("woff2"), url(/fonts/flondrina.woff) format("woff2");
}

@font-face {
  font-family: "ffredoka";
  src: url(/fonts/ffredoka.woff2) format("woff2"), url(/fonts/ffredoka.woff) format("woff2");
}

@font-face {
  font-family: "fwriting";
  src: url(/fonts/fwriting.woff2) format("woff2"), url(/fonts/fwriting.woff) format("woff2");
}

@font-face {
  font-family: "fcute";
  src: url(/fonts/fcute.woff2) format("woff2"), url(/fonts/fcute.woff) format("woff2");
}

/* line 2807, app/assets/stylesheets/scenes.scss */
.fyuanti {
  font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif;
}

/* line 2812, app/assets/stylesheets/scenes.scss */
.fkai {
  font-family: "fkai";
}

/* line 2816, app/assets/stylesheets/scenes.scss */
.fdefaultp {
  font-family: "fpinyin", "Helvetica Neue", Helvetica, STHeiTi, sans-serif;
  padding: 10px;
}

/* line 2821, app/assets/stylesheets/scenes.scss */
.fyuantip {
  font-family: "fpinyin", "Helvetica Neue", Helvetica, STHeiTi, sans-serif;
  padding: 10px;
}

/* line 2826, app/assets/stylesheets/scenes.scss */
.fkaip {
  font-family: "fpinyin", "fkai";
  padding: 10px;
}

/* line 2832, app/assets/stylesheets/scenes.scss */
.fdefault {
  font-family: "Helvetica Neue", Helvetica, STHeiTi, sans-serif;
}

/* line 2836, app/assets/stylesheets/scenes.scss */
.fmono {
  font-family: "fmono";
}

/* line 2840, app/assets/stylesheets/scenes.scss */
.fgaegu {
  font-family: "fgaegu";
}

/* line 2844, app/assets/stylesheets/scenes.scss */
.fnunito {
  font-family: "fnunito";
}

/* line 2848, app/assets/stylesheets/scenes.scss */
.flondrina {
  font-family: "flondrina";
}

/* line 2852, app/assets/stylesheets/scenes.scss */
.ffredoka {
  font-family: "ffredoka";
}

/* line 2856, app/assets/stylesheets/scenes.scss */
.fwriting {
  font-family: "fwriting";
  font-weight: bold;
}

/* line 2861, app/assets/stylesheets/scenes.scss */
.fcute {
  font-family: "fcute";
}

/* line 2871, app/assets/stylesheets/scenes.scss */
.center {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* line 2877, app/assets/stylesheets/scenes.scss */
#gamedone {
  width: 100%;
  height: 100%;
  z-index: 9100;
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* line 2888, app/assets/stylesheets/scenes.scss */
#gamedone .done-background {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.65);
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: auto;
}

/* line 2898, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup {
  width: 800px;
  height: 500px;
  z-index: 9120;
  display: flex;
  flex-direction: column;
}

/* line 2905, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top {
  height: 360px;
  width: auto;
  background-image: url(/assets/donePop-46630fee0314124ca48c291f82cc678b4bb4256358a8d9862ef6c4adfa07eef6.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}

/* line 2919, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top .done-pop {
  height: 300px;
}

/* line 2923, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top .done-input-ping {
  position: relative;
  margin: 40px 0 30px 0;
}

/* line 2928, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top .done-input-url {
  position: relative;
}

/* line 2932, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top .done-url {
  background: #fff;
  font-size: 1.5em;
  border-radius: 20px;
  border: none;
  padding: 16px 10px;
  color: #181b18;
  pointer-events: auto;
  width: 300px;
}

/* line 2943, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top .done-copy {
  position: absolute;
  right: -10px;
  top: -6px;
  width: 136px;
  height: 71px;
  cursor: pointer;
  pointer-events: auto;
  -webkit-tap-highlight-color: transparent;
}

/* line 2954, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-top #copyTips {
  font-size: 1.3em;
  position: absolute;
  bottom: 50px;
}

/* line 2963, app/assets/stylesheets/scenes.scss */
#gamedone .done-popup .done-bottom .done-icon {
  height: 80px;
  margin: 0 20px;
  cursor: pointer;
  pointer-events: auto;
  -webkit-tap-highlight-color: transparent;
}
/* line 1, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard {
  display: none;
  background: #eee;
  position: absolute;
  top: 80px;
  left: 210px;
  width: 300px;
  border-radius: 6px;
  z-index: 9000;
  box-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
  z-index: 8000;
  transform: translateZ(85px);
}

/* line 15, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .close {
  position: absolute;
  right: -20px;
  top: -20px;
  cursor: pointer;
  font-family: sans-serif;
  font-size: 2em;
  background: #eee;
  width: 40px;
  height: 40px;
  text-align: center;
  line-height: 36px;
  border-radius: 20px;
  color: #777;
  box-shadow: 1px -1px 1px 0px rgba(0, 0, 0, 0.2);
}

/* line 32, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .keys {
  display: flex;
  flex-wrap: wrap;
  padding: 5px;
}

/* line 37, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .keys .grid-item {
  width: 20%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* line 43, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .keys .grid-item .key {
  cursor: pointer;
  background: white;
  color: #333;
  width: 80%;
  height: 80%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 5px;
  box-shadow: 0px 1px 0px 2px #DDD;
  font-size: 1.1em;
}

/* line 58, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .keys .grid-item .key.active {
  background: #ffb82b;
}

/* line 64, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard .keys .grid-item:before {
  content: '';
  float: left;
  padding-top: 100%;
}

/* line 72, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.open {
  display: block;
}

/* line 76, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard:after,
.hjnumkeyboard:before {
  top: 68%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}

/* line 87, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-right:after,
.hjnumkeyboard.bottom-right:before {
  right: 100%;
  margin-right: -1px;
}

/* line 93, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-right:before,
.hjnumkeyboard.bottom-left:before {
  border-color: rgba(238, 238, 238, 0);
  border-width: 12px;
  margin-top: -12px;
}

/* line 100, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-left:after,
.hjnumkeyboard.bottom-right:after {
  border-color: rgba(255, 255, 255, 0);
  border-width: 11px;
  margin-top: -11px;
}

/* line 107, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-right:before {
  border-right-color: #ddd;
}

/* line 111, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-right:after {
  border-right-color: #eee;
}

/* line 115, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-left:before,
.hjnumkeyboard.bottom-left:after {
  left: 100%;
  margin-left: -1px;
}

/* line 121, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-left:before {
  border-left-color: #ddd;
}

/* line 125, app/assets/stylesheets/libs/hjnumkeyboard.scss */
.hjnumkeyboard.bottom-left:after {
  border-left-color: #eee;
}
/* line 7, app/assets/stylesheets/gameweb.scss */
html,
body {
  position: relative;
  overflow: hidden;
  height: 101%;
}

/* line 18, app/assets/stylesheets/gameweb.scss */
body {
  position: fixed;
  height: 100%;
  overflow: hidden;
  width: 100%;
  background-color: #f4f4f4;
}

@media screen and (orientation: portrait) {
  /* line 27, app/assets/stylesheets/gameweb.scss */
  #container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}

@media screen and (orientation: landscape) {
  /* line 37, app/assets/stylesheets/gameweb.scss */
  #container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}
