:root {
  --uitehr0: Helvetica, arial, sans-serif;
  --uitehr1: Source Code Pro, Firacode, Hasklig, Menlo, monospace;
  --uitehr2: normal 10px Helvetica, arial, sans-serif;
  --uitehr3: normal 12px Helvetica, arial, sans-serif;
  --uitehr4: normal 14px Helvetica, arial, sans-serif;
  --uitehr5: normal 16px/20px Helvetica, arial, sans-serif;
  --uitehr6: 700;
  --uitehr7: 4px;
  --uitehr8: 8px;
  --uitehr9: 16px;
  --uitehra: 100%;
  --uitehrb: 70px;
  --uitehrc: 44px;
  --uitehrd: opacity 300ms ease, transform 300ms ease;
  --uitehre: opacity 200ms ease, transform 200ms ease;
  --uitehrf: opacity 100ms ease, transform 100ms ease;
  --uitehrg: 0;
  --uitehrh: 2px;
  --uitehri: 4px;
  --uitehrj: 8px;
  --uitehrk: 12px;
  --uitehrl: 16px;
  --uitehrm: 20px;
  --uitehrn: 24px;
  --uitehro: 32px;
  --uitehrp: 40px;
}
:root {
  --y4nlu40: #000;
  --y4nlu41: #040080;
  --y4nlu42: #005ad2;
  --y4nlu43: #00439c;
  --y4nlu44: #00439c;
  --y4nlu45: #0088ff;
  --y4nlu46: #75438a;
  --y4nlu47: #a7a7a7;
  --y4nlu48: #515151;
  --y4nlu49: #fff;
  --y4nlu4a: #a7a7a7;
  --y4nlu4b: #cd193d;
  --y4nlu4c: #005ad2;
  --y4nlu4d: #1da584;
  --y4nlu4e: rgb(0, 0, 0, .05);
  --y4nlu4f: #005ad2;
  --y4nlu4g: #c5f5e9;
  --y4nlu4h: #fee1e9;
  --y4nlu4i: #eeeeee;
  --y4nlu4j: #fff;
  --y4nlu4k: #f4f4f4;
  --y4nlu4l: rgb(from #0088ff r g b / calc(alpha - 0.85));
  --y4nlu4m: hsl(from #e5f3ff h s calc(l - 15));
  --y4nlu4n: #eeeeee;
  --y4nlu4o: 0 2px 8px rgb(18, 21, 26, 0.3);
  --y4nlu4p: 0 0 0 5px #e5f3ff;
}
:root[data-playroom-dark] {
  --y4nlu40: #f6f8fa;
  --y4nlu41: #c8e1f7;
  --y4nlu42: #68aeea;
  --y4nlu43: #97c8f1;
  --y4nlu44: #97c8f1;
  --y4nlu45: #3e8fe0;
  --y4nlu46: #aa83f2;
  --y4nlu47: #3d4b63;
  --y4nlu48: #f6f8fa;
  --y4nlu49: #000;
  --y4nlu4a: #828ea4;
  --y4nlu4b: #fa6b6c;
  --y4nlu4c: #3e8fe0;
  --y4nlu4d: #28b888;
  --y4nlu4e: rgb(255, 255, 255, .07);
  --y4nlu4f: #3e8fe0;
  --y4nlu4g: color-mix(in srgb, #0f131b 60%, #28b888);
  --y4nlu4h: color-mix(in srgb, #0f131b 70%, #db2d2d);
  --y4nlu4i: #1c2230;
  --y4nlu4j: #0f131b;
  --y4nlu4k: hsl(from #0f131b h s calc(l - 3));
  --y4nlu4l: rgb(from #296fc0 r g b / calc(alpha - 0.75));
  --y4nlu4m: rgb(from #296fc0 r g b / calc(alpha - 0.25));
  --y4nlu4n: #1c2230;
  --y4nlu4o: 0 0 10px -2px hsl(from #0f131b h s calc(l - 5));
  --y4nlu4p: 0 0 0 5px rgb(from #68aeea r g b / calc(alpha - 0.6));
}
.y4nlu4q {
  position: absolute;
}
.y4nlu4r {
  position: relative;
}
.y4nlu4s {
  position: fixed;
}
.y4nlu4t {
  top: 0;
}
.y4nlu4u {
  bottom: 0;
}
.y4nlu4v {
  left: 0;
}
.y4nlu4w {
  right: 0;
}
.y4nlu4x {
  display: none;
}
.y4nlu4y {
  display: flex;
}
.y4nlu4z {
  display: block;
}
.y4nlu410 {
  display: inline;
}
.y4nlu411 {
  flex-direction: row;
}
.y4nlu412 {
  flex-direction: column;
}
.y4nlu413 {
  flex-direction: row-reverse;
}
.y4nlu414 {
  flex-wrap: wrap;
}
.y4nlu415 {
  flex-grow: 0;
}
.y4nlu416 {
  flex-grow: 1;
}
.y4nlu417 {
  justify-content: stretch;
}
.y4nlu418 {
  justify-content: flex-start;
}
.y4nlu419 {
  justify-content: center;
}
.y4nlu41a {
  justify-content: flex-end;
}
.y4nlu41b {
  justify-content: space-around;
}
.y4nlu41c {
  justify-content: space-between;
}
.y4nlu41d {
  align-items: stretch;
}
.y4nlu41e {
  align-items: flex-start;
}
.y4nlu41f {
  align-items: center;
}
.y4nlu41g {
  align-items: flex-end;
}
.y4nlu41h {
  gap: var(--uitehrg);
}
.y4nlu41i {
  gap: var(--uitehrh);
}
.y4nlu41j {
  gap: var(--uitehri);
}
.y4nlu41k {
  gap: var(--uitehrj);
}
.y4nlu41l {
  gap: var(--uitehrk);
}
.y4nlu41m {
  gap: var(--uitehrl);
}
.y4nlu41n {
  gap: var(--uitehrm);
}
.y4nlu41o {
  gap: var(--uitehrn);
}
.y4nlu41p {
  gap: var(--uitehro);
}
.y4nlu41q {
  gap: var(--uitehrp);
}
.y4nlu41r {
  padding-top: var(--uitehrg);
}
.y4nlu41s {
  padding-top: var(--uitehrh);
}
.y4nlu41t {
  padding-top: var(--uitehri);
}
.y4nlu41u {
  padding-top: var(--uitehrj);
}
.y4nlu41v {
  padding-top: var(--uitehrk);
}
.y4nlu41w {
  padding-top: var(--uitehrl);
}
.y4nlu41x {
  padding-top: var(--uitehrm);
}
.y4nlu41y {
  padding-top: var(--uitehrn);
}
.y4nlu41z {
  padding-top: var(--uitehro);
}
.y4nlu420 {
  padding-top: var(--uitehrp);
}
.y4nlu421 {
  padding-bottom: var(--uitehrg);
}
.y4nlu422 {
  padding-bottom: var(--uitehrh);
}
.y4nlu423 {
  padding-bottom: var(--uitehri);
}
.y4nlu424 {
  padding-bottom: var(--uitehrj);
}
.y4nlu425 {
  padding-bottom: var(--uitehrk);
}
.y4nlu426 {
  padding-bottom: var(--uitehrl);
}
.y4nlu427 {
  padding-bottom: var(--uitehrm);
}
.y4nlu428 {
  padding-bottom: var(--uitehrn);
}
.y4nlu429 {
  padding-bottom: var(--uitehro);
}
.y4nlu42a {
  padding-bottom: var(--uitehrp);
}
.y4nlu42b {
  padding-left: var(--uitehrg);
}
.y4nlu42c {
  padding-left: var(--uitehrh);
}
.y4nlu42d {
  padding-left: var(--uitehri);
}
.y4nlu42e {
  padding-left: var(--uitehrj);
}
.y4nlu42f {
  padding-left: var(--uitehrk);
}
.y4nlu42g {
  padding-left: var(--uitehrl);
}
.y4nlu42h {
  padding-left: var(--uitehrm);
}
.y4nlu42i {
  padding-left: var(--uitehrn);
}
.y4nlu42j {
  padding-left: var(--uitehro);
}
.y4nlu42k {
  padding-left: var(--uitehrp);
}
.y4nlu42l {
  padding-right: var(--uitehrg);
}
.y4nlu42m {
  padding-right: var(--uitehrh);
}
.y4nlu42n {
  padding-right: var(--uitehri);
}
.y4nlu42o {
  padding-right: var(--uitehrj);
}
.y4nlu42p {
  padding-right: var(--uitehrk);
}
.y4nlu42q {
  padding-right: var(--uitehrl);
}
.y4nlu42r {
  padding-right: var(--uitehrm);
}
.y4nlu42s {
  padding-right: var(--uitehrn);
}
.y4nlu42t {
  padding-right: var(--uitehro);
}
.y4nlu42u {
  padding-right: var(--uitehrp);
}
.y4nlu42v {
  margin-top: var(--uitehrg);
}
.y4nlu42w {
  margin-top: var(--uitehrh);
}
.y4nlu42x {
  margin-top: var(--uitehri);
}
.y4nlu42y {
  margin-top: var(--uitehrj);
}
.y4nlu42z {
  margin-top: var(--uitehrk);
}
.y4nlu430 {
  margin-top: var(--uitehrl);
}
.y4nlu431 {
  margin-top: var(--uitehrm);
}
.y4nlu432 {
  margin-top: var(--uitehrn);
}
.y4nlu433 {
  margin-top: var(--uitehro);
}
.y4nlu434 {
  margin-top: var(--uitehrp);
}
.y4nlu435 {
  margin-top: auto;
}
.y4nlu436 {
  margin-bottom: var(--uitehrg);
}
.y4nlu437 {
  margin-bottom: var(--uitehrh);
}
.y4nlu438 {
  margin-bottom: var(--uitehri);
}
.y4nlu439 {
  margin-bottom: var(--uitehrj);
}
.y4nlu43a {
  margin-bottom: var(--uitehrk);
}
.y4nlu43b {
  margin-bottom: var(--uitehrl);
}
.y4nlu43c {
  margin-bottom: var(--uitehrm);
}
.y4nlu43d {
  margin-bottom: var(--uitehrn);
}
.y4nlu43e {
  margin-bottom: var(--uitehro);
}
.y4nlu43f {
  margin-bottom: var(--uitehrp);
}
.y4nlu43g {
  margin-bottom: auto;
}
.y4nlu43h {
  margin-left: var(--uitehrg);
}
.y4nlu43i {
  margin-left: var(--uitehrh);
}
.y4nlu43j {
  margin-left: var(--uitehri);
}
.y4nlu43k {
  margin-left: var(--uitehrj);
}
.y4nlu43l {
  margin-left: var(--uitehrk);
}
.y4nlu43m {
  margin-left: var(--uitehrl);
}
.y4nlu43n {
  margin-left: var(--uitehrm);
}
.y4nlu43o {
  margin-left: var(--uitehrn);
}
.y4nlu43p {
  margin-left: var(--uitehro);
}
.y4nlu43q {
  margin-left: var(--uitehrp);
}
.y4nlu43r {
  margin-left: auto;
}
.y4nlu43s {
  margin-right: var(--uitehrg);
}
.y4nlu43t {
  margin-right: var(--uitehrh);
}
.y4nlu43u {
  margin-right: var(--uitehri);
}
.y4nlu43v {
  margin-right: var(--uitehrj);
}
.y4nlu43w {
  margin-right: var(--uitehrk);
}
.y4nlu43x {
  margin-right: var(--uitehrl);
}
.y4nlu43y {
  margin-right: var(--uitehrm);
}
.y4nlu43z {
  margin-right: var(--uitehrn);
}
.y4nlu440 {
  margin-right: var(--uitehro);
}
.y4nlu441 {
  margin-right: var(--uitehrp);
}
.y4nlu442 {
  margin-right: auto;
}
.y4nlu443 {
  overflow: hidden;
}
.y4nlu444 {
  overflow: auto;
}
.y4nlu445 {
  box-shadow: var(--y4nlu4o);
}
.y4nlu446 {
  box-shadow: var(--y4nlu4p);
}
.y4nlu447 {
  border-radius: var(--uitehr7);
}
.y4nlu448 {
  border-radius: var(--uitehr8);
}
.y4nlu449 {
  border-radius: var(--uitehr9);
}
.y4nlu44a {
  border-radius: var(--uitehra);
}
.y4nlu44b {
  transition: var(--uitehrd);
}
.y4nlu44c {
  transition: var(--uitehre);
}
.y4nlu44d {
  transition: var(--uitehrf);
}
.y4nlu44e {
  cursor: pointer;
}
.y4nlu44f {
  pointer-events: none;
}
.y4nlu44g {
  pointer-events: auto;
}
.y4nlu44h {
  user-select: none;
}
.y4nlu44i {
  appearance: none;
}
.y4nlu44j {
  opacity: 0;
}
.y4nlu44k {
  z-index: 0;
}
.y4nlu44l {
  z-index: 1;
}
.y4nlu44m {
  font: var(--uitehr2);
}
.y4nlu44n {
  font: var(--uitehr3);
}
.y4nlu44o {
  font: var(--uitehr4);
}
.y4nlu44p {
  font: var(--uitehr5);
}
.y4nlu44q {
  font-weight: var(--uitehr6);
}
.y4nlu44r {
  width: 100%;
}
.y4nlu44s {
  width: 100dvw;
}
.y4nlu44t {
  height: 100%;
}
.y4nlu44u {
  height: 100dvh;
}
.y4nlu44v {
  white-space: nowrap;
}
.y4nlu44w {
  box-sizing: border-box;
}
.y4nlu44x {
  text-align: center;
}
.y4nlu44y {
  text-align: left;
}
.y4nlu44z {
  text-align: right;
}
.y4nlu450 {
  border: 0;
}
/* BASICS */

.CodeMirror {
  /* Set height, width, borders, and global font properties here */
  font-family: monospace;
  height: 300px;
  color: black;
  direction: ltr;
}

/* PADDING */

.CodeMirror-lines {
  padding: 4px 0; /* Vertical padding around content */
}
.CodeMirror pre.CodeMirror-line,
.CodeMirror pre.CodeMirror-line-like {
  padding: 0 4px; /* Horizontal padding of content */
}

.CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
  background-color: white; /* The little square between H and V scrollbars */
}

/* GUTTER */

.CodeMirror-gutters {
  border-right: 1px solid #ddd;
  background-color: #f7f7f7;
  white-space: nowrap;
}
.CodeMirror-linenumbers {}
.CodeMirror-linenumber {
  padding: 0 3px 0 5px;
  min-width: 20px;
  text-align: right;
  color: #999;
  white-space: nowrap;
}

.CodeMirror-guttermarker { color: black; }
.CodeMirror-guttermarker-subtle { color: #999; }

/* CURSOR */

.CodeMirror-cursor {
  border-left: 1px solid black;
  border-right: none;
  width: 0;
}
/* Shown when moving in bi-directional text */
.CodeMirror div.CodeMirror-secondarycursor {
  border-left: 1px solid silver;
}
.cm-fat-cursor .CodeMirror-cursor {
  width: auto;
  border: 0 !important;
  background: #7e7;
}
.cm-fat-cursor div.CodeMirror-cursors {
  z-index: 1;
}
.cm-fat-cursor .CodeMirror-line::selection,
.cm-fat-cursor .CodeMirror-line > span::selection, 
.cm-fat-cursor .CodeMirror-line > span > span::selection { background: transparent; }
.cm-fat-cursor .CodeMirror-line::-moz-selection,
.cm-fat-cursor .CodeMirror-line > span::-moz-selection,
.cm-fat-cursor .CodeMirror-line > span > span::-moz-selection { background: transparent; }
.cm-fat-cursor { caret-color: transparent; }
@-moz-keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}
@-webkit-keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}
@keyframes blink {
  0% {}
  50% { background-color: transparent; }
  100% {}
}

/* Can style cursor different in overwrite (non-insert) mode */
.CodeMirror-overwrite .CodeMirror-cursor {}

.cm-tab { display: inline-block; text-decoration: inherit; }

.CodeMirror-rulers {
  position: absolute;
  left: 0; right: 0; top: -50px; bottom: 0;
  overflow: hidden;
}
.CodeMirror-ruler {
  border-left: 1px solid #ccc;
  top: 0; bottom: 0;
  position: absolute;
}

/* DEFAULT THEME */

.cm-s-default .cm-header {color: blue;}
.cm-s-default .cm-quote {color: #090;}
.cm-negative {color: #d44;}
.cm-positive {color: #292;}
.cm-header, .cm-strong {font-weight: bold;}
.cm-em {font-style: italic;}
.cm-link {text-decoration: underline;}
.cm-strikethrough {text-decoration: line-through;}

.cm-s-default .cm-keyword {color: #708;}
.cm-s-default .cm-atom {color: #219;}
.cm-s-default .cm-number {color: #164;}
.cm-s-default .cm-def {color: #00f;}
.cm-s-default .cm-variable,
.cm-s-default .cm-punctuation,
.cm-s-default .cm-property,
.cm-s-default .cm-operator {}
.cm-s-default .cm-variable-2 {color: #05a;}
.cm-s-default .cm-variable-3, .cm-s-default .cm-type {color: #085;}
.cm-s-default .cm-comment {color: #a50;}
.cm-s-default .cm-string {color: #a11;}
.cm-s-default .cm-string-2 {color: #f50;}
.cm-s-default .cm-meta {color: #555;}
.cm-s-default .cm-qualifier {color: #555;}
.cm-s-default .cm-builtin {color: #30a;}
.cm-s-default .cm-bracket {color: #997;}
.cm-s-default .cm-tag {color: #170;}
.cm-s-default .cm-attribute {color: #00c;}
.cm-s-default .cm-hr {color: #999;}
.cm-s-default .cm-link {color: #00c;}

.cm-s-default .cm-error {color: #f00;}
.cm-invalidchar {color: #f00;}

.CodeMirror-composing { border-bottom: 2px solid; }

/* Default styles for common addons */

div.CodeMirror span.CodeMirror-matchingbracket {color: #0b0;}
div.CodeMirror span.CodeMirror-nonmatchingbracket {color: #a22;}
.CodeMirror-matchingtag { background: rgba(255, 150, 0, .3); }
.CodeMirror-activeline-background {background: #e8f2ff;}

/* STOP */

/* The rest of this file contains styles related to the mechanics of
   the editor. You probably shouldn't touch them. */

.CodeMirror {
  position: relative;
  overflow: hidden;
  background: white;
}

.CodeMirror-scroll {
  overflow: scroll !important; /* Things will break if this is overridden */
  /* 50px is the magic margin used to hide the element's real scrollbars */
  /* See overflow: hidden in .CodeMirror */
  margin-bottom: -50px; margin-right: -50px;
  padding-bottom: 50px;
  height: 100%;
  outline: none; /* Prevent dragging from highlighting the element */
  position: relative;
  z-index: 0;
}
.CodeMirror-sizer {
  position: relative;
  border-right: 50px solid transparent;
}

/* The fake, visible scrollbars. Used to force redraw during scrolling
   before actual scrolling happens, thus preventing shaking and
   flickering artifacts. */
.CodeMirror-vscrollbar, .CodeMirror-hscrollbar, .CodeMirror-scrollbar-filler, .CodeMirror-gutter-filler {
  position: absolute;
  z-index: 6;
  display: none;
  outline: none;
}
.CodeMirror-vscrollbar {
  right: 0; top: 0;
  overflow-x: hidden;
  overflow-y: scroll;
}
.CodeMirror-hscrollbar {
  bottom: 0; left: 0;
  overflow-y: hidden;
  overflow-x: scroll;
}
.CodeMirror-scrollbar-filler {
  right: 0; bottom: 0;
}
.CodeMirror-gutter-filler {
  left: 0; bottom: 0;
}

.CodeMirror-gutters {
  position: absolute; left: 0; top: 0;
  min-height: 100%;
  z-index: 3;
}
.CodeMirror-gutter {
  white-space: normal;
  height: 100%;
  display: inline-block;
  vertical-align: top;
  margin-bottom: -50px;
}
.CodeMirror-gutter-wrapper {
  position: absolute;
  z-index: 4;
  background: none !important;
  border: none !important;
}
.CodeMirror-gutter-background {
  position: absolute;
  top: 0; bottom: 0;
  z-index: 4;
}
.CodeMirror-gutter-elt {
  position: absolute;
  cursor: default;
  z-index: 4;
}
.CodeMirror-gutter-wrapper ::selection { background-color: transparent }
.CodeMirror-gutter-wrapper ::-moz-selection { background-color: transparent }

.CodeMirror-lines {
  cursor: text;
  min-height: 1px; /* prevents collapsing before first draw */
}
.CodeMirror pre.CodeMirror-line,
.CodeMirror pre.CodeMirror-line-like {
  /* Reset some styles that the rest of the page might have set */
  -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0;
  border-width: 0;
  background: transparent;
  font-family: inherit;
  font-size: inherit;
  margin: 0;
  white-space: pre;
  word-wrap: normal;
  line-height: inherit;
  color: inherit;
  z-index: 2;
  position: relative;
  overflow: visible;
  -webkit-tap-highlight-color: transparent;
  -webkit-font-variant-ligatures: contextual;
  font-variant-ligatures: contextual;
}
.CodeMirror-wrap pre.CodeMirror-line,
.CodeMirror-wrap pre.CodeMirror-line-like {
  word-wrap: break-word;
  white-space: pre-wrap;
  word-break: normal;
}

.CodeMirror-linebackground {
  position: absolute;
  left: 0; right: 0; top: 0; bottom: 0;
  z-index: 0;
}

.CodeMirror-linewidget {
  position: relative;
  z-index: 2;
  padding: 0.1px; /* Force widget margins to stay inside of the container */
}

.CodeMirror-widget {}

.CodeMirror-rtl pre { direction: rtl; }

.CodeMirror-code {
  outline: none;
}

/* Force content-box sizing for the elements where we expect it */
.CodeMirror-scroll,
.CodeMirror-sizer,
.CodeMirror-gutter,
.CodeMirror-gutters,
.CodeMirror-linenumber {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
}

.CodeMirror-measure {
  position: absolute;
  width: 100%;
  height: 0;
  overflow: hidden;
  visibility: hidden;
}

.CodeMirror-cursor {
  position: absolute;
  pointer-events: none;
}
.CodeMirror-measure pre { position: static; }

div.CodeMirror-cursors {
  visibility: hidden;
  position: relative;
  z-index: 3;
}
div.CodeMirror-dragcursors {
  visibility: visible;
}

.CodeMirror-focused div.CodeMirror-cursors {
  visibility: visible;
}

.CodeMirror-selected { background: #d9d9d9; }
.CodeMirror-focused .CodeMirror-selected { background: #d7d4f0; }
.CodeMirror-crosshair { cursor: crosshair; }
.CodeMirror-line::selection, .CodeMirror-line > span::selection, .CodeMirror-line > span > span::selection { background: #d7d4f0; }
.CodeMirror-line::-moz-selection, .CodeMirror-line > span::-moz-selection, .CodeMirror-line > span > span::-moz-selection { background: #d7d4f0; }

.cm-searching {
  background-color: #ffa;
  background-color: rgba(255, 255, 0, .4);
}

/* Used to force a border model for a node */
.cm-force-border { padding-right: .1px; }

@media print {
  /* Hide the cursor when printing */
  .CodeMirror div.CodeMirror-cursors {
    visibility: hidden;
  }
}

/* See issue #2901 */
.cm-tab-wrap-hack:after { content: ''; }

/* Help users use markselection to safely style text background */
span.CodeMirror-selectedtext { background: none; }

.CodeMirror-dialog {
  position: absolute;
  left: 0; right: 0;
  background: inherit;
  z-index: 15;
  padding: .1em .8em;
  overflow: hidden;
  color: inherit;
}

.CodeMirror-dialog-top {
  border-bottom: 1px solid #eee;
  top: 0;
}

.CodeMirror-dialog-bottom {
  border-top: 1px solid #eee;
  bottom: 0;
}

.CodeMirror-dialog input {
  border: none;
  outline: none;
  background: transparent;
  width: 20em;
  color: inherit;
  font-family: monospace;
}

.CodeMirror-dialog button {
  font-size: 70%;
}

/* neo theme for codemirror */

/* Color scheme */

.cm-s-neo.CodeMirror {
  background-color:#ffffff;
  color:#2e383c;
  line-height:1.4375;
}
.cm-s-neo .cm-comment { color:#75787b; }
.cm-s-neo .cm-keyword, .cm-s-neo .cm-property { color:#1d75b3; }
.cm-s-neo .cm-atom,.cm-s-neo .cm-number { color:#75438a; }
.cm-s-neo .cm-node,.cm-s-neo .cm-tag { color:#9c3328; }
.cm-s-neo .cm-string { color:#b35e14; }
.cm-s-neo .cm-variable,.cm-s-neo .cm-qualifier { color:#047d65; }


/* Editor styling */

.cm-s-neo pre {
  padding:0;
}

.cm-s-neo .CodeMirror-gutters {
  border:none;
  border-right:10px solid transparent;
  background-color:transparent;
}

.cm-s-neo .CodeMirror-linenumber {
  padding:0;
  color:#e0e2e5;
}

.cm-s-neo .CodeMirror-guttermarker { color: #1d75b3; }
.cm-s-neo .CodeMirror-guttermarker-subtle { color: #e0e2e5; }

.cm-s-neo .CodeMirror-cursor {
  width: auto;
  border: 0;
  background: rgba(155,157,162,0.37);
  z-index: 1;
}

.i5rvnn5 {
  outline: none;
  height: 60px;
  width: 60px;
  color: currentColor;
  background-color: var(--y4nlu4j);
  -webkit-tap-highlight-color: transparent;
}
.i5rvnn5::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--y4nlu4l);
  opacity: 0;
  transition: var(--uitehrd);
  pointer-events: none;
}
.i5rvnn5::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 5px;
  background-color: currentColor;
  transition: var(--uitehrd);
}
.i5rvnn5.i5rvnn0 {
  color: var(--y4nlu4d);
}
.i5rvnn5:not(.i5rvnn1) {
  cursor: pointer;
}
.i5rvnn5.i5rvnn1 {
  color: var(--y4nlu47);
}
.i5rvnn5.i5rvnn2,.i5rvnn5.i5rvnn3:not(.i5rvnn0):not(.i5rvnn1),html:not([data-playroom-dark]) .i5rvnn5:hover:not(.i5rvnn0):not(.i5rvnn1) {
  color: var(--y4nlu4c);
}
.i5rvnn5:not(.i5rvnn0):not(:hover):focus::before {
  color: var(--y4nlu48);
}
.i5rvnn5:not(.i5rvnn0):not(.i5rvnn1):focus::before,.i5rvnn5:not(.i5rvnn0):not(.i5rvnn1):hover::before {
  opacity: 1;
}
.i5rvnn5:not(.i5rvnn3)::after {
  transform: translateX(100%);
  opacity: 0;
}
.i5rvnn8 {
  top: 12px;
  right: 12px;
  height: 10px;
  width: 10px;
  background-color: var(--y4nlu4f);
  border: 2px solid var(--y4nlu4j);
}
.i5rvnn8:not(.i5rvnn6) {
  transform: scale(0);
  opacity: 0;
}
.i5rvnna {
  top: 12px;
  right: 12px;
  height: 14px;
  width: 14px;
  background-color: var(--y4nlu4d);
  border: 2px solid var(--y4nlu4j);
}
.i5rvnna:not(.i5rvnn6) {
  transform: translate3d(-15px, 9px, 0) scale(0);
  opacity: 0;
}
.i5rvnna svg {
  color: var(--y4nlu49);
}
@keyframes _1w03agm1 {
  90% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
._1w03agm0 {
  background-color: var(--y4nlu4l);
}
._1w03agm3 {
  background-color: var(--y4nlu4h);
  color: var(--y4nlu4b);
  min-width: 50px;
  animation-name: _1w03agm1;
  animation-duration: 1s;
  animation-timing-function: ease;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
._1w03agm3:hover {
  cursor: help;
}
._1w03agm5 {
  width: 1em;
}
._1w03agm7::after {
  content: "-";
}
._1w03agm9::after {
  content: "+";
  color: var(--y4nlu4c);
}
.react-codemirror2 {
  height: 100%;
  background-color: var(--y4nlu4j);
}
.CodeMirror {
  height: 100%;
  width: 100%;
  font-family: var(--uitehr1);
  position: relative;
  z-index: 0;
}
.CodeMirror-gutters {
  min-width: var(--uitehrb);
  box-sizing: border-box;
  padding-left: var(--uitehrj);
}
.CodeMirror pre, .CodeMirror-linenumber {
  font-size: 16px;
}
.CodeMirror-lines {
  padding: var(--uitehrl) 0;
}
.CodeMirror-hints {
  position: absolute;
  z-index: 10;
  overflow: hidden;
  list-style: none;
  margin: 0;
  padding: 0;
  box-shadow: var(--y4nlu4o);
  border-radius: var(--uitehr7);
  background-color: var(--y4nlu4j);
  font-size: 90%;
  line-height: 150%;
  font-family: var(--uitehr1);
  max-height: 20em;
  overflow-y: auto;
}
[data-playroom-dark] .CodeMirror-hints {
  background-color: var(--y4nlu4i);
}
.CodeMirror-hint {
  margin: 0;
  padding: var(--uitehri) var(--uitehrj);
  border-radius: var(--uitehr7);
  white-space: pre;
  color: var(--y4nlu40);
  cursor: pointer;
}
li.CodeMirror-hint-active {
  background-color: var(--y4nlu4f);
  color: var(--y4nlu49);
}
.CodeMirror-linenumbers {
  min-width: 50px;
}
.CodeMirror-foldmarker {
  color: var(--y4nlu4c);
  font-family: arial;
  cursor: pointer;
  padding: 0 var(--uitehri);
}
.cm-s-neo.CodeMirror {
  background-color: var(--y4nlu4j);
  color: var(--y4nlu40);
}
.cm-s-neo .CodeMirror-cursor {
  background-color: var(--y4nlu48);
  width: 2px;
}
.cm-s-neo .CodeMirror-gutters {
  background-color: var(--y4nlu4j);
  border: none;
}
.cm-s-neo .CodeMirror-gutters::after {
  content: "";
  background-color: var(--y4nlu4j);
  position: absolute;
  right: var(--uitehrh);
  height: 100%;
  box-shadow: 0 0 10px 5px var(--y4nlu4j);
}
.cm-s-neo .CodeMirror-selected {
  background: var(--y4nlu4l);
}
.cm-s-neo .CodeMirror-activeline-background {
  background: transparent;
}
.cm-s-neo .CodeMirror-guttermarker-subtle {
  display: flex;
  justify-content: center;
  color: var(--y4nlu48);
  transition: var(--uitehrf);
}
.cm-s-neo .CodeMirror-guttermarker-subtle:not(:hover):not(._1w03agm9) {
  color: var(--y4nlu47);
}
.cm-s-neo .CodeMirror-linenumber {
  min-width: 50px;
  color: var(--y4nlu48);
  transition: var(--uitehrf);
}
.cm-s-neo .CodeMirror-linenumber:not(:hover):not(.cm-s-neo .CodeMirror-activeline .CodeMirror-linenumber) {
  color: var(--y4nlu47);
}
.cm-s-neo .cm-tag {
  color: var(--y4nlu41);
}
.cm-s-neo .cm-attribute,.cm-s-neo .cm-keyword,.cm-s-neo .cm-property {
  color: var(--y4nlu42);
}
.cm-s-neo .cm-string {
  color: var(--y4nlu43);
}
.cm-s-neo .cm-atom {
  color: var(--y4nlu44);
}
.cm-s-neo .cm-variable {
  color: var(--y4nlu45);
}
.cm-s-neo .cm-number {
  color: var(--y4nlu46);
}
.CodeMirror-dialog {
  padding-left: var(--uitehrl);
  padding-right: var(--uitehrl);
  min-height: 60px;
  border-bottom: 1px solid var(--y4nlu4n);
  display: flex;
  align-items: center;
}
.CodeMirror-scroll {
  transform: translateY(var(--_1w03agma));
  transition: var(--uitehrf);
}
.dialog-opened .CodeMirror-scroll {
  --_1w03agma: 60px;
}
.dialog-opened .CodeMirror-lines {
  padding-bottom: var(--_1w03agma);
}
.CodeMirror-dialog input {
  font: var(--uitehr5);
  font-family: var(--uitehr1);
  height: var(--uitehrc);
  flex-grow: 1;
}
.CodeMirror-search-hint {
  display: none;
}
.CodeMirror-search-label {
  display: flex;
  align-items: center;
  min-height: var(--uitehrc);
  font: var(--uitehr5);
  font-family: var(--uitehr1);
}
.CodeMirror-search-field {
  padding-left: var(--uitehrl);
}
label.CodeMirror-search-label {
  flex-grow: 1;
}
.dialog-opened.cm-s-neo .CodeMirror-selected {
  background: var(--y4nlu4m);
}
.cm-overlay.cm-searching {
  padding-top: var(--uitehrh);
  padding-bottom: var(--uitehrh);
  background: var(--y4nlu4l);
}
.CodeMirror-dialog button:first-of-type {
  margin-left: var(--uitehrl);
}
.CodeMirror-dialog button {
  appearance: none;
  font: var(--uitehr4);
  font-family: var(--uitehr0);
  margin-left: var(--uitehrj);
  padding-top: var(--uitehri);
  padding-bottom: var(--uitehri);
  padding-left: var(--uitehrk);
  padding-right: var(--uitehrk);
  align-self: center;
  display: block;
  background: none;
  border-radius: var(--uitehr8);
  cursor: pointer;
  border: 1px solid currentColor;
}
.CodeMirror-dialog button:focus {
  color: var(--y4nlu4c);
  box-shadow: var(--y4nlu4p);
  outline: none;
}
.CodeMirror-dialog button:focus:hover {
  background: var(--y4nlu4l);
}
.CodeMirror-dialog button:hover {
  background: var(--y4nlu4e);
}
._14zlk0u2 {
  top: var(--uitehrj);
  left: var(--uitehrj);
  right: var(--uitehrj);
  margin-inline: auto;
  width: fit-content;
  max-width: 80ex;
  color: #f6f8fa;
  background: #cd193d;
  box-shadow: 0 2px 10px -2px #cd193d;
  word-break: break-word;
  white-space: pre-line;
}
._14zlk0u2:not(._14zlk0u0) {
  transform: translateY(calc(var(--uitehrj) * -1));
  transition: none;
  opacity: 0;
}
._14zlk0u2 a {
  color: inherit;
}
._14zlk0u3 {
  transition-delay: 1000ms;
}
.y5cm4r1 {
  color: var(--y4nlu48);
}
.y5cm4r2 {
  color: var(--y4nlu4b);
}
.y5cm4r3 {
  color: var(--y4nlu4a);
}
.y5cm4ra {
  text-overflow: ellipsis;
}
._10ox27f1 {
  justify-content: safe center;
}
._10ox27f4 {
  flex-shrink: 0;
  width: var(--_10ox27f2);
}
._10ox27f4:not(:hover) ._10ox27f7 {
  opacity: 0.8;
}
._10ox27f9 {
  flex: 0 0 30px;
  height: 30px;
  margin-bottom: -10px;
}
._10ox27f4:not(:hover) ._10ox27f9 {
  opacity: 0.3;
}
.bwboom5 {
  padding: 0 15px;
  left: 50%;
  transform: translateX(-50%);
  top: var(--uitehrm);
  height: var(--uitehrn);
  max-width: calc((100dvw - 60px) - (var(--uitehrb) * 2));
}
.bwboom5.bwboom0 {
  padding-right: calc((15px * 2) + 16px);
}
.bwboom5:not(.bwboom1) {
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, -10px, 0);
}
.bwboom5.bwboom2 {
  background-color: var(--y4nlu4g);
}
.bwboom5.bwboom3 {
  background-color: var(--y4nlu4h);
}
.bwboom7 {
  padding-left: 15px;
  right: 15px;
  height: 16px;
  width: 16px;
}
.bwboom7:not(:hover) {
  opacity: 0.4;
}
._6uacaz1 {
  color: var(--y4nlu48);
  font-family: var(--uitehr0);
}
._6uacaz2 {
  font-size: 36px;
}
._6uacaz3 {
  font-size: 24px;
}
._6uacaz4 {
  font-size: 16px;
}
.qolz8c2 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--qolz8c0);
  align-items: var(--qolz8c1);
}
.qolz8c3 {
  --qolz8c0: var(--uitehrg);
}
.qolz8c4 {
  --qolz8c0: var(--uitehrh);
}
.qolz8c5 {
  --qolz8c0: var(--uitehri);
}
.qolz8c6 {
  --qolz8c0: var(--uitehrj);
}
.qolz8c7 {
  --qolz8c0: var(--uitehrk);
}
.qolz8c8 {
  --qolz8c0: var(--uitehrl);
}
.qolz8c9 {
  --qolz8c0: var(--uitehrm);
}
.qolz8ca {
  --qolz8c0: var(--uitehrn);
}
.qolz8cb {
  --qolz8c0: var(--uitehro);
}
.qolz8cc {
  --qolz8c0: var(--uitehrp);
}
.qolz8cd {
  align-items: flex-start;
}
.qolz8ce {
  align-items: center;
}
.qolz8cf {
  align-items: flex-end;
}
._1tnluad1 {
  display: flex;
  flex-direction: column;
  gap: var(--_1tnluad0);
}
._1tnluad2 {
  --_1tnluad0: var(--uitehrg);
}
._1tnluad3 {
  --_1tnluad0: var(--uitehrh);
}
._1tnluad4 {
  --_1tnluad0: var(--uitehri);
}
._1tnluad5 {
  --_1tnluad0: var(--uitehrj);
}
._1tnluad6 {
  --_1tnluad0: var(--uitehrk);
}
._1tnluad7 {
  --_1tnluad0: var(--uitehrl);
}
._1tnluad8 {
  --_1tnluad0: var(--uitehrm);
}
._1tnluad9 {
  --_1tnluad0: var(--uitehrn);
}
._1tnluada {
  --_1tnluad0: var(--uitehro);
}
._1tnluadb {
  --_1tnluad0: var(--uitehrp);
}
._1paxsvd1 {
  color: currentColor;
  background-color: transparent;
  outline: none;
  text-decoration: underline;
  margin: calc(var(--uitehri) * -1);
}
._1paxsvd1::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--uitehr7);
  box-shadow: var(--y4nlu4p);
  cursor: pointer;
  opacity: 0;
  transform: scale(0.8);
  transition: var(--uitehre);
}
._1paxsvd1:focus::before, ._1paxsvd1:hover::before {
  opacity: 1;
  transform: scale(1);
}
._1paxsvd4 {
  height: 20px;
  width: 20px;
}
._1paxsvd6 {
  flex-grow: 0;
  flex-shrink: 0;
  height: calc(20px - (var(--uitehrh) * 2));
  width: calc(20px - (var(--uitehrh) * 2));
}
._1paxsvd6::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--uitehr7);
  box-shadow: var(--y4nlu4p);
  transition: var(--uitehre);
  opacity: 0;
  transform: scale(0.5);
}
._1paxsvd6::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--uitehr7);
  box-shadow: inset 0 0 0px 1px currentColor;
  background: var(--y4nlu4j);
}
._1paxsvd4:hover:not(:focus) ~ ._1paxsvd6::before, ._1paxsvd4:focus ~ ._1paxsvd6::before {
  opacity: 1;
  transform: scale(1);
}
._1paxsvd6 > svg {
  height: 100%;
  width: 100%;
  opacity: 0;
  transform: scale(0.6);
  transition: var(--uitehrf);
  transition-delay: 0.1s, 0.3s;
  z-index: 1;
}
._1paxsvd4:checked ~ ._1paxsvd6 > svg  {
  opacity: 1;
  transform: none;
  transition: var(--uitehrf);
}
._1paxsvd8 {
  color: var(--y4nlu48);
  height: var(--uitehrc);
  background: var(--y4nlu4j);
  border: 1px solid var(--y4nlu4n);
}
._1paxsvd8::placeholder {
  color: var(--y4nlu47);
}
.z0nyr01 {
  background: transparent;
  outline: none;
  text-decoration: none;
  white-space: nowrap;
  text-overflow: ellipsis;
  -webkit-tap-highlight-color: transparent;
}
.z0nyr04 {
  --z0nyr02: currentColor;
  color: var(--z0nyr02);
  border: 1px solid var(--y4nlu47);
}
.z0nyr04:hover {
  --z0nyr02: var(--y4nlu4c);
  border-color: var(--z0nyr02);
}
.z0nyr04:active {
  transform: scale(0.98);
}
.z0nyr04::after {
  content: "";
  position: absolute;
  transform: translateY(-50%);
  min-height: var(--uitehrc);
  min-width: var(--uitehrc);
  width: 100%;
  height: 100%;
  top: 50%;
}
.z0nyr04:focus:not(:active):not(:hover):not([disabled]) {
  box-shadow: var(--y4nlu4p);
}
.z0nyr05 {
  --z0nyr02: var(--y4nlu4d) !important;
  border-color: var(--z0nyr02);
}
.z0nyr07 {
  top: 1px;
}
._1to029f0 {
  transition: var(--uitehre);
  transform-origin: 50% 50%;
}
._1to029f1 {
  transform: rotate(90deg);
}
._1to029f2 {
  transform: rotate(180deg);
}
._1to029f3 {
  transform: rotate(270deg);
}
.amqsaw4 {
  min-width: 0;
}
.amqsaw5 {
  flex-shrink: 0;
}
.amqsaw9 {
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
}
.amqsaw7:focus:not(:hover) ~ .amqsaw9 {
  opacity: 1;
}
.vba7k12 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.vba7k14 {
  display: inline-block;
  background: var(--y4nlu4i);
  font-family: system-ui;
  min-width: 16px;
}
.vba7k16 {
  height: var(--uitehrc);
  width: var(--uitehrc);
}
.vba7k18 {
  height: var(--uitehrc);
  width: var(--uitehrc);
}
.vba7k18::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--y4nlu4l);
  border-radius: var(--uitehr8);
  transition: var(--uitehre);
  opacity: 0;
  transform: scale(0.8);
}
.vba7k16:checked ~ .vba7k18,html:not([data-playroom-dark]) .vba7k16:hover ~ .vba7k18 {
  color: var(--y4nlu4c);
}
.vba7k16:focus ~ .vba7k18::before, .vba7k16:hover ~ .vba7k18::before {
  opacity: 1;
  transform: scale(1);
}
.u3ginz1 {
  color: var(--y4nlu48);
  height: var(--uitehrc);
  background: var(--y4nlu4j);
}
.u3ginz1:focus {
  outline: none;
}
.u3ginz1::placeholder {
  color: var(--y4nlu47);
}
._176503k2 {
  height: 60px;
  box-shadow: inset 0 -1px 0 0 var(--y4nlu4n);
}
._176503k4 {
  list-style: none;
  top: 60px;
}
._176503k4::before {
  content: "";
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  height: var(--uitehri);
  z-index: 1;
}
._176503k4::after {
  content: "";
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--uitehri);
  z-index: 1;
}
._176503k6 {
  scroll-margin-block: var(--uitehri);
  color: var(--y4nlu48);
  background-color: var(--y4nlu4j);
}
._176503k6::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--y4nlu4l);
  border-radius: var(--uitehr7);
  opacity: 0;
  pointer-events: none;
}
._176503k8 {
  color: var(--y4nlu4a);
}
._176503k9 {
  color: var(--y4nlu4c);
}
._176503k9::before {
  opacity: 1;
}
.lakcxt2 {
  color: var(--y4nlu48);
  min-width: calc(60px + 1px);
}
.lakcxt2.lakcxt0 {
  width: 100dvw;
}
.lakcxt6 {
  width: 60px;
  background-color: var(--y4nlu4j);
  border-left: 1px solid var(--y4nlu4n);
}
.lakcxt8 {
  width: 320px;
  background-color: var(--y4nlu4j);
  border-left: 1px solid var(--y4nlu4n);
}
.lakcxt9 {
  opacity: 0;
  transform: translateX(30%);
}
.lakcxtb {
  opacity: 1;
  transform: translateX(0);
}
.lakcxtc {
  opacity: 1;
  transform: translateX(0);
}
.lakcxtd {
  opacity: 1;
}
.lakcxtf {
  opacity: 0;
  transform: translateX(30%);
}
.lakcxtg {
  opacity: 0;
  transform: translateX(30%);
}
.mn2pju0 {
  cursor: row-resize;
}
.mn2pju1 {
  cursor: col-resize;
}
.mn2pjua {
  background: var(--y4nlu4i);
}
.mn2pjub {
  width: 70px;
  height: 4px;
}
.mn2pjuc {
  width: 4px;
  height: 70px;
}
html, body {
  margin: 0;
  padding: 0;
  overflow: hidden;
  background-color: var(--y4nlu4k);
}
html[data-playroom-dark] {
  color-scheme: dark;
}
._8jkuqz0 {
  pointer-events: none;
  user-select: none;
}
._8jkuqz6 {
  display: grid;
  grid-template-columns: 1fr var(--_8jkuqz2, 0px);
  grid-template-rows: auto var(--_8jkuqz1, 0px);
  will-change: grid-template-columns, grid-template-rows;
}
._8jkuqz7 {
  transition: grid-template-columns 300ms ease, grid-template-rows 300ms ease;
}
._8jkuqz8 {
  --_8jkuqz1: clamp(300px, var(--_8jkuqz3), 80vh);
  grid-template-areas: "frames frames"
"editor editor";
}
._8jkuqz9 {
  --_8jkuqz2: clamp(460px, var(--_8jkuqz3), 90vw);
  grid-template-areas: "frames editor"
"frames editor";
}
._8jkuqza {
  grid-area: frames;
}
._8jkuqzc {
  grid-area: editor;
}
._8jkuqz8 ._8jkuqze {
  width: 60px;
}
._8jkuqzg {
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  outline: none;
  min-width: var(--uitehrc);
  height: var(--uitehrc);
}
._8jkuqzg::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: currentColor;
  opacity: 0;
  pointer-events: none;
  border-radius: var(--uitehr8);
  transition: var(--uitehrd);
}
._8jkuqzg:not(:hover):not(:focus) {
  opacity: 0.3;
}
._8jkuqzg:hover::before, ._8jkuqzg:focus::before {
  opacity: 0.05;
}
