:root {
  --n770de0: Helvetica, arial, sans-serif;
  --n770de1: Source Code Pro, Firacode, Hasklig, Menlo, monospace;
  --n770de2: normal 10px Helvetica, arial, sans-serif;
  --n770de3: normal 12px Helvetica, arial, sans-serif;
  --n770de4: normal 14px Helvetica, arial, sans-serif;
  --n770de5: normal 16px/1.3em Helvetica, arial, sans-serif;
  --n770de6: 100;
  --n770de7: 700;
  --n770de8: 4px;
  --n770de9: 2px;
  --n770dea: 4px;
  --n770deb: 6px;
  --n770dec: 100%;
  --n770ded: 70px;
  --n770dee: 44px;
  --n770def: opacity 300ms ease, transform 300ms ease;
  --n770deg: opacity 200ms ease, transform 200ms ease;
  --n770deh: opacity 100ms ease, transform 100ms ease;
  --n770dei: 0;
  --n770dej: 2px;
  --n770dek: 4px;
  --n770del: 6px;
  --n770dem: 12px;
  --n770den: 16px;
  --n770deo: 20px;
  --n770dep: 40px;
}
:root {
  --n770deq: #000;
  --n770der: #040080;
  --n770des: #005ad2;
  --n770det: #00439c;
  --n770deu: #00439c;
  --n770dev: #0088ff;
  --n770dew: #75438a;
  --n770dex: #a7a7a7;
  --n770dey: #515151;
  --n770dez: #fff;
  --n770de10: #a7a7a7;
  --n770de11: #cd193d;
  --n770de12: #005ad2;
  --n770de13: #1da584;
  --n770de14: rgba(0, 0, 0, .05);
  --n770de15: #005ad2;
  --n770de16: #c5f5e9;
  --n770de17: #fee1e9;
  --n770de18: #1e1e1e;
  --n770de19: #fff;
  --n770de1a: #f4f4f4;
  --n770de1b: #e5f3ff;
  --n770de1c: #e8e8e8;
  --n770de1d: 0 2px 8px rgba(18, 21, 26, 0.3);
  --n770de1e: 0 0 0 5px #e5f3ff;
}
:root[data-playroom-dark] {
  --n770deq: #f6f8fa;
  --n770der: #c8e1f7;
  --n770des: #68aeea;
  --n770det: #97c8f1;
  --n770deu: #97c8f1;
  --n770dev: #3e8fe0;
  --n770dew: #aa83f2;
  --n770dex: #3d4b63;
  --n770dey: #f6f8fa;
  --n770dez: #000;
  --n770de10: #828ea4;
  --n770de11: #fa6b6c;
  --n770de12: #3e8fe0;
  --n770de13: #28b888;
  --n770de14: rgba(0, 0, 0, .15);
  --n770de15: #3e8fe0;
  --n770de16: #195546;
  --n770de17: #4c1a20;
  --n770de18: #1c2230;
  --n770de19: #0f131b;
  --n770de1a: #0a0c11;
  --n770de1b: rgba(41,111,192,0.15);
  --n770de1c: #1c2230;
  --n770de1d: 0 0 10px -2px #2d3648;
  --n770de1e: 0 0 0 5px rgba(104,174,234,0.4);
}
.n770de1f {
  position: absolute;
}
.n770de1g {
  position: relative;
}
.n770de1h {
  position: fixed;
}
.n770de1i {
  top: 0;
}
.n770de1j {
  bottom: 0;
}
.n770de1k {
  left: 0;
}
.n770de1l {
  right: 0;
}
.n770de1m {
  display: none;
}
.n770de1n {
  display: flex;
}
.n770de1o {
  display: block;
}
.n770de1p {
  display: inline;
}
.n770de1q {
  flex-direction: row;
}
.n770de1r {
  flex-direction: column;
}
.n770de1s {
  flex-direction: row-reverse;
}
.n770de1t {
  flex-wrap: wrap;
}
.n770de1u {
  justify-content: stretch;
}
.n770de1v {
  justify-content: flex-start;
}
.n770de1w {
  justify-content: center;
}
.n770de1x {
  justify-content: flex-end;
}
.n770de1y {
  justify-content: space-around;
}
.n770de1z {
  justify-content: space-between;
}
.n770de20 {
  align-items: stretch;
}
.n770de21 {
  align-items: flex-start;
}
.n770de22 {
  align-items: center;
}
.n770de23 {
  align-items: flex-end;
}
.n770de24 {
  padding-top: var(--n770dei);
}
.n770de25 {
  padding-top: var(--n770dej);
}
.n770de26 {
  padding-top: var(--n770dek);
}
.n770de27 {
  padding-top: var(--n770del);
}
.n770de28 {
  padding-top: var(--n770dem);
}
.n770de29 {
  padding-top: var(--n770den);
}
.n770de2a {
  padding-top: var(--n770deo);
}
.n770de2b {
  padding-top: var(--n770dep);
}
.n770de2c {
  padding-bottom: var(--n770dei);
}
.n770de2d {
  padding-bottom: var(--n770dej);
}
.n770de2e {
  padding-bottom: var(--n770dek);
}
.n770de2f {
  padding-bottom: var(--n770del);
}
.n770de2g {
  padding-bottom: var(--n770dem);
}
.n770de2h {
  padding-bottom: var(--n770den);
}
.n770de2i {
  padding-bottom: var(--n770deo);
}
.n770de2j {
  padding-bottom: var(--n770dep);
}
.n770de2k {
  padding-left: var(--n770dei);
}
.n770de2l {
  padding-left: var(--n770dej);
}
.n770de2m {
  padding-left: var(--n770dek);
}
.n770de2n {
  padding-left: var(--n770del);
}
.n770de2o {
  padding-left: var(--n770dem);
}
.n770de2p {
  padding-left: var(--n770den);
}
.n770de2q {
  padding-left: var(--n770deo);
}
.n770de2r {
  padding-left: var(--n770dep);
}
.n770de2s {
  padding-right: var(--n770dei);
}
.n770de2t {
  padding-right: var(--n770dej);
}
.n770de2u {
  padding-right: var(--n770dek);
}
.n770de2v {
  padding-right: var(--n770del);
}
.n770de2w {
  padding-right: var(--n770dem);
}
.n770de2x {
  padding-right: var(--n770den);
}
.n770de2y {
  padding-right: var(--n770deo);
}
.n770de2z {
  padding-right: var(--n770dep);
}
.n770de30 {
  margin-top: var(--n770dei);
}
.n770de31 {
  margin-top: var(--n770dej);
}
.n770de32 {
  margin-top: var(--n770dek);
}
.n770de33 {
  margin-top: var(--n770del);
}
.n770de34 {
  margin-top: var(--n770dem);
}
.n770de35 {
  margin-top: var(--n770den);
}
.n770de36 {
  margin-top: var(--n770deo);
}
.n770de37 {
  margin-top: var(--n770dep);
}
.n770de38 {
  margin-bottom: var(--n770dei);
}
.n770de39 {
  margin-bottom: var(--n770dej);
}
.n770de3a {
  margin-bottom: var(--n770dek);
}
.n770de3b {
  margin-bottom: var(--n770del);
}
.n770de3c {
  margin-bottom: var(--n770dem);
}
.n770de3d {
  margin-bottom: var(--n770den);
}
.n770de3e {
  margin-bottom: var(--n770deo);
}
.n770de3f {
  margin-bottom: var(--n770dep);
}
.n770de3g {
  margin-left: var(--n770dei);
}
.n770de3h {
  margin-left: var(--n770dej);
}
.n770de3i {
  margin-left: var(--n770dek);
}
.n770de3j {
  margin-left: var(--n770del);
}
.n770de3k {
  margin-left: var(--n770dem);
}
.n770de3l {
  margin-left: var(--n770den);
}
.n770de3m {
  margin-left: var(--n770deo);
}
.n770de3n {
  margin-left: var(--n770dep);
}
.n770de3o {
  margin-right: var(--n770dei);
}
.n770de3p {
  margin-right: var(--n770dej);
}
.n770de3q {
  margin-right: var(--n770dek);
}
.n770de3r {
  margin-right: var(--n770del);
}
.n770de3s {
  margin-right: var(--n770dem);
}
.n770de3t {
  margin-right: var(--n770den);
}
.n770de3u {
  margin-right: var(--n770deo);
}
.n770de3v {
  margin-right: var(--n770dep);
}
.n770de3w {
  overflow: hidden;
}
.n770de3x {
  overflow: auto;
}
.n770de3y {
  box-shadow: var(--n770de1d);
}
.n770de3z {
  box-shadow: var(--n770de1e);
}
.n770de40 {
  border-radius: var(--n770de9);
}
.n770de41 {
  border-radius: var(--n770dea);
}
.n770de42 {
  border-radius: var(--n770deb);
}
.n770de43 {
  border-radius: var(--n770dec);
}
.n770de44 {
  transition: var(--n770def);
}
.n770de45 {
  transition: var(--n770deg);
}
.n770de46 {
  transition: var(--n770deh);
}
.n770de47 {
  cursor: pointer;
}
.n770de48 {
  pointer-events: none;
}
.n770de49 {
  pointer-events: auto;
}
.n770de4a {
  user-select: none;
}
.n770de4b {
  appearance: none;
}
.n770de4c {
  opacity: 0;
}
.n770de4d {
  z-index: 0;
}
.n770de4e {
  z-index: 1;
}
.n770de4f {
  font: var(--n770de2);
}
.n770de4g {
  font: var(--n770de3);
}
.n770de4h {
  font: var(--n770de4);
}
.n770de4i {
  font: var(--n770de5);
}
.n770de4j {
  font-weight: var(--n770de6);
}
.n770de4k {
  font-weight: var(--n770de7);
}
.n770de4l {
  width: 100%;
}
.n770de4m {
  width: 100vw;
}
.n770de4n {
  height: 100%;
}
.n770de4o {
  height: 100vh;
}
.n770de4p {
  white-space: nowrap;
}
.n770de4q {
  box-sizing: border-box;
}
.n770de4r {
  text-align: center;
}
.n770de4s {
  text-align: left;
}
.n770de4t {
  text-align: right;
}
.n770de4u {
  border: 0;
}
._17lgqqk1 {
  color: var(--n770dey);
}
._17lgqqk2 {
  color: var(--n770de11);
}
._17lgqqk9 {
  text-overflow: ellipsis;
}
._8gb4ft1 {
  overflow-x: auto;
  overflow-y: hidden;
}
._8gb4ft1::before {
  content: "";
  flex: 1;
}
._8gb4ft1::after {
  content: "";
  flex: 1;
}
._8gb4ft5 {
  flex-grow: 1;
}
._8gb4ft7:not(:hover) {
  opacity: 0.8;
}
._8gb4ft9 {
  flex: 0 0 30px;
  height: 30px;
  margin-bottom: -10px;
}
._8gb4ft3:not(:hover) ._8gb4ft9 {
  opacity: 0.3;
}
._4kmewh1 {
  color: var(--n770dey);
  font-family: var(--n770de0);
}
._4kmewh2 {
  font-size: 36px;
}
._4kmewh3 {
  font-size: 24px;
}
._4kmewh4 {
  font-size: 16px;
}
._1jyxq182 {
  border-top: 1px solid var(--n770de1c);
}
._1v5m25a1:not(:last-child) {
  padding-bottom: var(--_1v5m25a0);
}
._1v5m25a2 {
  --_1v5m25a0: var(--n770de8);
}
._1v5m25a3 {
  --_1v5m25a0: calc(var(--n770de8) * 2);
}
._1v5m25a4 {
  --_1v5m25a0: calc(var(--n770de8) * 3);
}
._1v5m25a5 {
  --_1v5m25a0: calc(var(--n770de8) * 4);
}
._1v5m25a6 {
  --_1v5m25a0: calc(var(--n770de8) * 6);
}
._1v5m25a7 {
  --_1v5m25a0: calc(var(--n770de8) * 12);
}
._1ifsbf42 {
  color: currentColor;
  background-color: transparent;
  outline: none;
  text-decoration: underline;
  margin: calc(var(--n770del) * -1);
}
._1ifsbf42::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--n770deb);
  box-shadow: var(--n770de1e);
  cursor: pointer;
  opacity: 0;
  transform: scale(0.8);
  transition: var(--n770deg);
}
._1ifsbf42:focus::before, ._1ifsbf42:hover::before {
  opacity: 1;
  transform: scale(1);
}
._1ifsbf44 {
  height: calc(var(--n770de8) * 9);
}
._1ifsbf46 {
  height: 20px;
  width: 20px;
}
._1ifsbf48 {
  flex-grow: 0;
  flex-shrink: 0;
  height: calc(20px - (var(--n770dej) * 2));
  width: calc(20px - (var(--n770dej) * 2));
}
._1ifsbf48::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--n770dea);
  box-shadow: var(--n770de1e);
  transition: var(--n770deg);
  opacity: 0;
  transform: scale(0.5);
}
._1ifsbf48::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  border-radius: var(--n770dea);
  box-shadow: inset 0 0 0px 1px currentColor;
  background: var(--n770de19);
}
._1ifsbf46:hover:not(:focus) ~ ._1ifsbf48::before, ._1ifsbf46:focus ~ ._1ifsbf48::before {
  opacity: 1;
  transform: scale(1);
}
._1ifsbf48 > svg {
  height: 100%;
  width: 100%;
  opacity: 0;
  transform: scale(0.6);
  transition: var(--n770deh);
  transition-delay: 0.1s, 0.3s;
  z-index: 1;
}
._1ifsbf46:checked ~ ._1ifsbf48 > svg  {
  opacity: 1;
  transform: none;
  transition: var(--n770deh);
}
._1lybm870 {
  transition: var(--n770deg);
  transform-origin: 50% 50%;
}
._1lybm871 {
  transform: rotate(90deg);
}
._1lybm872 {
  transform: rotate(180deg);
}
._1lybm873 {
  transform: rotate(270deg);
}
._1xdrgkn4 {
  min-width: 0;
}
._1xdrgkn5 {
  flex-shrink: 0;
}
._1xdrgkn9 {
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
}
._1xdrgkn7:focus:not(:hover) ~ ._1xdrgkn9 {
  opacity: 1;
}
.ntid061 {
  background: transparent;
  outline: none;
  text-decoration: none;
  white-space: nowrap;
  text-overflow: ellipsis;
  height: var(--n770dee);
  -webkit-tap-highlight-color: transparent;
}
.ntid064 {
  --ntid062: currentColor;
  color: var(--ntid062);
  border: 1px solid var(--n770dex);
  height: calc(var(--n770de8) * 9);
}
.ntid064:hover {
  --ntid062: var(--n770de12);
  border-color: var(--ntid062);
}
.ntid064:active {
  transform: scale(0.98);
}
.ntid064::after {
  content: "";
  position: absolute;
  transform: translateY(-50%);
  min-height: var(--n770dee);
  min-width: var(--n770dee);
  left: calc((var(--n770de8) * 2) * -1);
  right: calc((var(--n770de8) * 2) * -1);
  height: 100%;
  top: 50%;
}
.ntid064:focus:not(:active):not(:hover):not([disabled]) {
  box-shadow: var(--n770de1e);
}
.ntid065 {
  --ntid062: var(--n770de13) !important;
  border-color: var(--ntid062);
}
.ntid067 {
  top: 1px;
}
._1kzebqj2 {
  margin-top: calc(var(--_1kzebqj0) * -1);
  margin-left: calc(var(--_1kzebqj0) * -1);
}
._1kzebqj3 {
  padding-top: var(--_1kzebqj0);
  padding-left: var(--_1kzebqj0);
}
._1kzebqj4 {
  --_1kzebqj0: var(--n770de8);
}
._1kzebqj5 {
  --_1kzebqj0: calc(var(--n770de8) * 2);
}
._1kzebqj6 {
  --_1kzebqj0: calc(var(--n770de8) * 3);
}
._1kzebqj7 {
  --_1kzebqj0: calc(var(--n770de8) * 4);
}
._1kzebqj8 {
  --_1kzebqj0: calc(var(--n770de8) * 5);
}
._1kzebqj9 {
  --_1kzebqj0: calc(var(--n770de8) * 6);
}
.n8cnl71 {
  color: var(--n770dey);
  height: var(--n770dee);
  background: var(--n770de19);
}
.n8cnl71:focus {
  outline: none;
}
.n8cnl71::placeholder {
  color: var(--n770dex);
}
.vridqq5 {
  outline: none;
  height: 60px;
  width: 60px;
  color: currentColor;
  background-color: var(--n770de19);
  -webkit-tap-highlight-color: transparent;
}
.vridqq5::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--n770de1b);
  opacity: 0;
  transition: var(--n770def);
  pointer-events: none;
}
.vridqq5::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  width: 5px;
  background-color: currentColor;
  transition: var(--n770def);
}
.vridqq5.vridqq0 {
  color: var(--n770de13);
}
.vridqq5:not(.vridqq1) {
  cursor: pointer;
}
.vridqq5.vridqq1 {
  color: var(--n770dex);
}
.vridqq5.vridqq2,.vridqq5.vridqq3:not(.vridqq0):not(.vridqq1),html:not([data-playroom-dark]) .vridqq5:hover:not(.vridqq0):not(.vridqq1) {
  color: var(--n770de12);
}
.vridqq5:not(.vridqq0):not(:hover):focus::before {
  color: var(--n770dey);
}
.vridqq5:not(.vridqq0):not(.vridqq1):focus::before,.vridqq5:not(.vridqq0):not(.vridqq1):hover::before {
  opacity: 1;
}
.vridqq5:not(.vridqq3)::after {
  transform: translateX(100%);
  opacity: 0;
}
.vridqq8 {
  top: 12px;
  right: 12px;
  height: 10px;
  width: 10px;
  background-color: var(--n770de15);
  border: 2px solid var(--n770de19);
}
.vridqq8:not(.vridqq6) {
  transform: scale(0);
  opacity: 0;
}
.vridqqa {
  top: 12px;
  right: 12px;
  height: 14px;
  width: 14px;
  background-color: var(--n770de13);
  border: 2px solid var(--n770de19);
}
.vridqqa:not(.vridqq6) {
  transform: translate3d(-15px, 9px, 0) scale(0);
  opacity: 0;
}
.vridqqa svg {
  color: var(--n770dez);
}
._7lnst2 {
  height: 60px;
  box-shadow: inset 0 -1px 0 0 var(--n770de1c);
}
._7lnst4 {
  top: 60px;
}
._7lnst6 {
  color: var(--n770dey);
  background-color: var(--n770de19);
}
._7lnst6::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--n770de1b);
  border-radius: var(--n770dea);
  opacity: 0;
  transition: var(--n770def);
  pointer-events: none;
}
._7lnst8 {
  color: var(--n770de10);
}
._7lnst9 {
  color: var(--n770de12);
}
._7lnst9::before {
  opacity: 1;
}
.b5ya4s2 {
  color: var(--n770dey);
  min-width: calc(60px + 1px);
}
.b5ya4s2.b5ya4s0 {
  width: 100vw;
}
.b5ya4s8 {
  bottom: 60px;
}
.b5ya4s8:not(.b5ya4s6) {
  opacity: 0;
  pointer-events: none;
  transform: translateY(20px);
}
.b5ya4sa {
  width: 60px;
  background-color: var(--n770de19);
  border-left: 1px solid var(--n770de1c);
}
.b5ya4sc {
  width: 300px;
  background-color: var(--n770de19);
  border-left: 1px solid var(--n770de1c);
}
.b5ya4s2:not(.b5ya4s0) .b5ya4sc {
  transform: translateX(calc(300px * 0.3));
  opacity: 0;
  pointer-events: none;
}
._1ggpj0i3 {
  height: var(--n770dee);
  width: var(--n770dee);
}
._1ggpj0i6 {
  height: var(--n770dee);
  width: var(--n770dee);
}
._1ggpj0i6::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--n770de1b);
  border-radius: var(--n770deb);
  transition: var(--n770deg);
  opacity: 0;
  transform: scale(0.8);
}
._1ggpj0i3:checked ~ ._1ggpj0i6,html:not([data-playroom-dark]) ._1ggpj0i3:hover ~ ._1ggpj0i6 {
  color: var(--n770de12);
}
._1ggpj0i3:focus ~ ._1ggpj0i6::before, ._1ggpj0i3:hover ~ ._1ggpj0i6::before {
  opacity: 1;
  transform: scale(1);
}
.ssf9ak5 {
  padding: 0 15px;
  left: 50%;
  transform: translateX(-50%);
  top: calc(var(--n770de8) * 5);
  height: calc(var(--n770de8) * 8);
  max-width: calc((100vw - 60px) - (var(--n770ded) * 2));
}
.ssf9ak5.ssf9ak0 {
  padding-right: calc((15px * 2) + 16px);
}
.ssf9ak5:not(.ssf9ak1) {
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, -10px, 0);
}
.ssf9ak5.ssf9ak2 {
  background-color: var(--n770de16);
}
.ssf9ak5.ssf9ak3 {
  background-color: var(--n770de17);
}
.ssf9ak7 {
  padding-left: 15px;
  right: 15px;
  height: 16px;
  width: 16px;
}
.ssf9ak7:not(:hover) {
  opacity: 0.4;
}
/* 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; }

/* 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;
}

@keyframes _7aabrb1 {
  90% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
._7aabrb0 {
  background-color: var(--n770de1b);
}
._7aabrb3 {
  background-color: var(--n770de17);
  color: var(--n770de11);
  min-width: 50px;
  margin-right: 4px;
  padding-right: 8px;
  animation-name: _7aabrb1;
  animation-duration: 1s;
  animation-timing-function: ease;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}
._7aabrb4 {
  width: 1em;
  padding: 0 8px;
}
._7aabrb6::after {
  content: "-";
}
._7aabrb8::after {
  content: "+";
  color: var(--n770de12);
}
.react-codemirror2 {
  height: 100%;
  background-color: var(--n770de19);
}
.CodeMirror {
  height: 100%;
  width: 100%;
  font-family: var(--n770de1);
  position: relative;
  z-index: 0;
}
.CodeMirror-gutters {
  min-width: var(--n770ded);
  box-sizing: border-box;
  padding-left: 8px;
}
.CodeMirror pre, .CodeMirror-linenumber {
  font-size: 16px;
}
.CodeMirror-lines {
  padding: 16px 0;
}
.CodeMirror-hints {
  position: absolute;
  z-index: 10;
  overflow: hidden;
  list-style: none;
  margin: 0;
  padding: 0;
  box-shadow: var(--n770de1d);
  border-radius: var(--n770dea);
  background-color: var(--n770de19);
  font-size: 90%;
  line-height: 150%;
  font-family: var(--n770de1);
  max-height: 20em;
  overflow-y: auto;
}
[data-playroom-dark] .CodeMirror-hints {
  background-color: var(--n770de18);
}
.CodeMirror-hint {
  margin: 0;
  padding: 4px 8px;
  border-radius: var(--n770de9);
  white-space: pre;
  color: var(--n770deq);
  cursor: pointer;
}
li.CodeMirror-hint-active {
  background-color: var(--n770de15);
  color: var(--n770dez);
}
.CodeMirror-linenumbers {
  min-width: 50px;
}
.CodeMirror-foldmarker {
  color: var(--n770de12);
  font-family: arial;
  cursor: pointer;
  padding: 0 var(--n770de8);
}
.cm-s-neo.CodeMirror {
  background-color: var(--n770de19);
  color: var(--n770deq);
}
.cm-s-neo .CodeMirror-cursor {
  background-color: var(--n770dey);
  width: 2px;
}
.cm-s-neo .CodeMirror-gutters {
  background-color: var(--n770de19);
  border: none;
}
.cm-s-neo .CodeMirror-gutters::after {
  content: "";
  background-color: var(--n770de19);
  position: absolute;
  right: 2px;
  height: 100%;
  box-shadow: 0 0 10px 5px var(--n770de19);
}
.cm-s-neo .CodeMirror-selected {
  background: var(--n770de1b);
}
.cm-s-neo .CodeMirror-activeline-background {
  background: transparent;
}
.cm-s-neo .CodeMirror-guttermarker-subtle {
  display: flex;
  justify-content: center;
  color: var(--n770dey);
  transition: var(--n770deh);
}
.cm-s-neo .CodeMirror-guttermarker-subtle:not(:hover):not(._7aabrb8) {
  color: var(--n770dex);
}
.cm-s-neo .CodeMirror-linenumber {
  min-width: 50px;
  color: var(--n770dey);
  transition: var(--n770deh);
}
.cm-s-neo .CodeMirror-linenumber:not(:hover):not(.cm-s-neo .CodeMirror-activeline .CodeMirror-linenumber) {
  color: var(--n770dex);
}
.cm-s-neo .cm-tag {
  color: var(--n770der);
}
.cm-s-neo .cm-attribute,.cm-s-neo .cm-keyword,.cm-s-neo .cm-property {
  color: var(--n770des);
}
.cm-s-neo .cm-string {
  color: var(--n770det);
}
.cm-s-neo .cm-atom {
  color: var(--n770deu);
}
.cm-s-neo .cm-variable {
  color: var(--n770dev);
}
.cm-s-neo .cm-number {
  color: var(--n770dew);
}
html {
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: var(--n770de1a);
}
html[data-playroom-dark] {
  color-scheme: dark;
}
body {
  margin: 0;
}
.ijqrva3 {
  position: absolute !important;
}
.ijqrva6 {
  max-width: 90vw;
}
.ijqrva6.ijqrva4 {
  transform: translateX(100%);
}
.ijqrva8 {
  max-height: 90vh;
}
.ijqrva8.ijqrva4 {
  transform: translateY(100%);
}
.ijqrvab.ijqrva9 {
  width: 60px;
}
.ijqrvad {
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  outline: none;
  min-width: var(--n770dee);
  height: var(--n770dee);
}
.ijqrvad::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: currentColor;
  opacity: 0;
  pointer-events: none;
  border-radius: var(--n770deb);
  transition: var(--n770def);
}
.ijqrvad:not(:hover):not(:focus) {
  opacity: 0.3;
}
.ijqrvad:hover::before, .ijqrvad:focus::before {
  opacity: 0.05;
}
.ijqrvaf {
  right: 60px;
}
