      :root {
        --color-bg: #000;
        --color-fg: #f5e8c5; /*#f9e93f; */
        --color-text: var(--color-fg);
        --color-gradient1-top: #5098be;
        --color-gradient1-bottom: #414180;
        --color-ui-bg: #3e3514;
        --color-ui-fg: #e3e3e3;
        --vh: 1vh;

      }

      @font-face {
        font-family: 'Sansita Black';
        src: url('/00_Wuselhain/Sansita-Black.ttf') format('truetype');
      }


      html, body {
        font-size: 0.5vh;

      }
      html {
        background-color: black;
        height: 100%;
      }

      body {
        /* background-image: linear-gradient(#7D0658, #0F001D); */

        background-color: var(--color-bg);
        color: var(--color-text);
        min-height: 100%;
/*        font-family: "Univers LT Std 55 Roman"; */
        font-family: "Sansita Black";
      }

      .title, .subtitle {
        color: white;
      }

      form {
        display: unset;
      }
      .button {
        width: 100%;
      }
      .ct-draw-container {
        height: 350px; /* TODO: rather use flex or so */
      }
      .mainWrap {
        height: 100%;
        overflow-y: hidden;
        overflow-x: hidden;
        /* aspect-ratio: 0.56; */
        aspect-ratio: 0.4;
        margin: 0 auto;
        position: absolute;
        left: 50%;
        transform: translate(-50%);
      }
      .main {
        width: 100%;
        height: 100%;

      }
      .creative-tools {
        /* border: 1px dotted; */
        margin-top: 20px;
        color: white;
      }
      .ct-label {
        /* background-color: rgba(0,0,0,0.2); */
        background-color: rgba(0,0,0,0.0);
      }
      .ct-photo {
        width: 100%;
        /* background-color: rgba(255,255,255,0.6); */
        background-color: rgba(0,0,0,0.6);
      }
      .ct-draw {
        width: 100%;
        background-color: rgba(0,0,0,0.6);
        padding: 0;
      }
      input[type="text"] {
        margin-left: 10px;
      }
      .column, .columns {
        height: 100%;
      }
      .user-infos > div {
        margin-top: 15px;
        padding-top: 6px;
        padding-bottom: 6px;
      }
      .section {
        padding-top: 0;
				background-color: rgba(0,0,0,0);
		    border: 0px beige solid;
    		box-shadow: none;
      }

      #bgStars {
        position: absolute;
        z-index: 0;
        height: 100%;
        width: 100%;
        /* background-color: rgba(0.1,0.1,0.1,0.1); */
        background-image: url("https://res.cloudinary.com/fusion-robot-gmbh/image/upload/v1563358372/stars_fewer_q2cgyr.png"); /* /stars fewer.png"); */
        background-repeat: repeat, repeat;
        background-size: 300px;

      }
      #bgs {

		    pointer-events: none;
      }
      #bgs, #fgs {
        position: fixed;
        width: 100%;
        height: 100%;
        overflow:hidden;
      }

      .bg-pic {
        min-width: 100%;
        min-height: 100%;
        background-size: cover;
        background-image: url(/00_Wuselhain/BG.png);
        background-position: center center;
      }

	  #fgs {
		z-index: 1000;
		pointer-events: none;
	  }

      #bgStars2 {
        position: absolute;
        z-index: 0;
        height: 100%;
        width: 200%;
        /* background-color: rgba(0.1,0.1,0.1,0.1); */
        background-image: url("https://res.cloudinary.com/fusion-robot-gmbh/image/upload/v1563358372/stars_fewer_q2cgyr.png"); /* /stars fewer.png"); */
        background-repeat: repeat, repeat;
        background-size: 50%;

        -webkit-animation-name: MOVE-BG;
        -webkit-animation-duration: 10s;
        -webkit-animation-timing-function: linear;
        -webkit-animation-iteration-count: infinite;
      }

      #overlay_upload {
        background-color: rgba(0,0,0,0.5);
        position: absolute;
        height: 100%;
        width: 100%;
        pointer-events: all;
      }

      #header_img {

        width: 100%;
        /*
        position: absolute;
        left: 0;
        top: 0;
        */
      }

      #header_container {
        height: auto;
        padding-top: 20px;
        position: relative;
        /*margin-bottom: 25px; */ /* original paléo */
        margin-bottom: 10px; /* numerik games */
      }

/* original for paléo
      #header_img_planet {
        position: absolute;
        bottom: -5%;
        left: 1%;
        width: 19%;
      }
*/
/* version for numerik */
      #header_img_planet {
        position: absolute;
        top: 3%;
        right: 1%;
        width: 19%;
      }


    @-webkit-keyframes MOVE-BG {
             from {
                     -webkit-transform: translateX(0);
             }
             to {
                     -webkit-transform: translateX(-50%);
             }
    }

    #drawSvg {
      position: absolute;
      top: 0;
      left: 0;

    }

    .ct-draw-container, .ct-photo-container {

    }

    .title > a,.title > a:link,.title > a:hover,.title > a:visited,.title > a:active {
          color: white;
    }

    #btn_img_planet, #btn_img_star_sign {
          border: 1px solid rgba(255,255,255,0.5);
          border-radius: 4px;
          padding: 5px;
          width: 100%;
    }

    .center {
          position: absolute;
          display: block;

          left: 50%;
          top: 50%;
          width: 50%;
          transform: translate(-50%,-50%);
          -webkit-transform: translate(-50%,-50%);
    }

  .paleoBtn, #submit_button, a, a:link, a:visited {

  }

  #submit_button[disabled] {
    background-color: #dbdbdb;
    opacity: 0.5;
  }
  #submit_button.edi {
		position: absolute;
    bottom: 2%;
    width: 80%;
    margin-left: 10%;
  }

  .columns {
    margin: 0px;

  }

  #btnErase {
    z-index: 1000;
  }

  #drawTutorial {
    position: absolute;
    z-index: 2000;
    left: 0%;
    top: 45%;
    width: 100%;
    text-align: center;
    opacity: 0.95;
    pointer-events: none;
  }

  .inputfile {
    width: 0.1px;
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
  }

  .inputlabel {
    width: 100%;
    height: 50%;
    display: block;

  }
	.inputlabel.edi {
		width: 80%;
    margin-left: 10%;
    height: 5%;
    display: block;
	}

  #queueImageWrap {
    padding: 0px;
    position: relative;
    margin-bottom: 5px;
  }

  #queueImageWrap > img {
    width: 100%;
  }

  #queueShow {
    position: absolute;
    right: 1%;
    top: 0%;
    width: 26%;
    height: 13%;
    border: 4px solid #e53048;
  }

  #queueShowNr {
    position: absolute;
    right: 1%;
    top: 5%;
    width: 26%;
    height: 13%;
    text-align: center;
  }

  #imgPreviewWrap {
    margin-top: 15px;
    height: 250px;
    width: 100%;
    border: 1px solid rgba(255,255,255,0.5);
    background-color: rgba(0,0,0,0.5);
    /* position: relative; */
  }

  #imgPreview {
    display: block;
    margin: auto;
    max-height: 100%;
    /*
    position: absolute;
    top: 0;
    bottom: 0;
    */
  }

  .imhere {
    -moz-animation-duration: 1s;
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -moz-animation-name: imhere;
    -webkit-animation-name: imhere;
    animation-name: imhere;
    -moz-animation-iteration-count: infinite;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -moz-animation-direction: alternate;
    -webkit-animation-direction: alternate;
    animation-direction: alternate;
    -moz-animation-timing-function: ease-in-out;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }

  .imhere_slow {
    -moz-animation-duration: 4.123s;
    -webkit-animation-duration: 4.123s;
    animation-duration: 4.123s;
    -moz-animation-name: imhere;
    -webkit-animation-name: imhere;
    animation-name: imhere;
    -moz-animation-iteration-count: infinite;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -moz-animation-direction: alternate;
    -webkit-animation-direction: alternate;
    animation-direction: alternate;
    -moz-animation-timing-function: ease-in-out;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;

  }

  @-moz-keyframes imhere {
    from {
      -moz-transform: rotate(-3deg);
    }

    to {
      -moz-transform: rotate(3deg);
    }
  }

  @-webkit-keyframes imhere {
    from {
      -webkit-transform: rotate(-3deg);
    }

    to {
      -webkit-transform: rotate(3deg);
    }
  }

  @keyframes imhere {
    from {
      -webkit-transform: rotate(-3deg);
    }

    to {
      -webkit-transform: rotate(3deg);
    }
  }

  #btnBack {
    position: absolute;
    right: 0;
    top: 5px; /* bottom: -50px; */
    z-index: 10;
    padding-left: 10px;
    padding-right: 10px;


  }

  .queueNrInText {
    color: #e53048;
    background-color: #000;
    padding: 2px;
  }

  .svg-inline--fa {
    display: inline-block;
    font-size: inherit;
    height: 1em;
    overflow: visible;
    vertical-align: -.125em;
  }

#dbgConsole {
    z-index: 2000;
    background-color: rgba(0,0,0,0.5);

    position: absolute;
    width: 100%;
    height: 100%;
    display: none;
    pointer-events: none;
    top: 0px;
    left: 0px;
    overflow-y: scroll;
}
#dbgOverlay {
    z-index: 2000;
    background-color: rgba(0,0,0,0.0);

    position: fixed;
    width: 100%;
    height: 100%;
    display: none;
    pointer-events: none;
    top: 0px;
    left: 0px;
    overflow-y: scroll;
}

/* NOTE: lilu */

html, body {
  overflow: hidden;
}
body.liluBody {
  padding: 0;
  margin: 0;

  /* font-family: "europa", sans-serif; */
  /* font-family: "moret",serif; */
  box-sizing: border-box;
  overflow: hidden;
  height: 100vh;
  height: calc(var(--vh)*100);
  min-height: 100vh;
  min-height: calc(var(--vh)*100);
}

body.liluBody  * {
  /* font-family: "europa", sans-serif; */
  /* font-family: "moret",serif; */
  box-sizing: border-box;
  scrollbar-color: var(--color-fg) rgba(255,255,212,0.2);
  scrollbar-width: thin;
}

audio, img, video {
    height: auto;
    max-width: 100%;
}

.section {
  padding: 0;
}

.fullscreen-step {
  /*
  width: 100vw;
  height: 100vh;
  height: calc(var(--vh)*100);
  */
  width: 100%;
  height: 100%;

  position: relative;
  padding: 3rem;
  overflow: hidden;
}

.step-navigation {
  position: absolute;
  right: 0;
  bottom:0;
  width: 100%;
  margin: 0;
  padding: 3rem;

}

.btn-next {

}

button, .paleoBtn, #submit_button, a, a:link, a:visited {
  /* float: right; */
  background-color: var(--color-ui-bg);
  color: var(--color-text);
  border-radius: 1rem;
  border-width: 2rem;
  border-color: var(--color-ui-fg);
  border-style: solid;
  padding: 1rem 2rem;
  margin: 1rem;
  font-size: 3rem;
  width: auto;
  text-decoration: none;

  width: 100%;
  margin: 0;
  padding: 1rem;
  font-size: 10.5rem;
  font-family: "Sansita Black";
  height: 18rem;
}

#liluHeader {
/*  position: fixed; */
  top: 0;
  width: 100%;
  background-color: #333;

}

#liluStep1, #liluStep2 {
  /*
  width: 100%;
  height: 500px;
  */
}

#decorationArea, #decorationsWrap { /* #decorations { */
  display: inline-block;
  vertical-align: top;

  margin: 0;
  padding: 0;

  border-radius: 3rem;
}
#decorationArea {
  width: 80%;

  position: relative;
}
#decorationsWrap {
  height: 90%;
  max-height:90%;
  width: 19%;
  overflow-y: scroll;
  background-image: linear-gradient(var(--color-gradient1-top), var(--color-gradient1-bottom));
  border-radius: 0.5rem;
}
#decorations {


}
#decorationArea-content {
  z-index: -5;
}

.decoration {
  height: auto;
  width: 100%;
  display: inline-block;
  pointer-events:none;
}
.decoration-placed {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.decoration-dragging {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.decoration-content {
  pointer-events: none;
}

.colorPalette {
  width: auto;
  height: 93%;
  border: 1px solid rgba(0,0,0,0);
  margin: 4px 2px;
}

.colorPalette.selected {
  border: 1px solid var(--color-text);
  box-shadow: 0px 0px 2px 2px;
  border-radius: 2rem;
  background-color: var(--color-fg);
}

.palettesWrap {
  height: auto;
  overflow-x: scroll;
}

.palettes {
  white-space: nowrap;
  height: 100%;
}

.figure {
  /*
  mix-blend-mode: darken;
  */
}

#dance {
  position: relative;
  margin-top: 10rem;
}

#select-dance {
  height: 33rem;
  position: absolute;
  top: 83%;
  width: 91%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: auto 0;
}

#hat-mask-color {
  position: relative;
  width: 100%;
 /*  height: 60%; */
  aspect-ratio: 0.95;
}

#hat-mask-color-visual-container-wrap {
  width: 70%;
  margin: 50% auto;
  position: relative;
}

#hat-mask-color-visual-container {
  position: absolute;
  width: 100%;
  /* height: 100%; */
  aspect-ratio: 0.6761;
  top: 0;
  left: 0;
}

#hat-mask-color-visual-container > *
/*, #visual-dance-container > * */
{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;

}

#hat-mask-color-visual-container > * > *,
#hat-mask-color-visual-container > * > * > *,
#visual-dance-container > * > *,
#visual-dance-container > * > * > *
{
  width: 100%;

}

#visual-hat {
  /*
  width: 125.523%;
  left: -14.644%;
  top: -46.5%;
  */
  width: 132.523%;
  left: -18.1%;
  top: -45.5%;
}

#visual-mask {
  /*
  width: 125.523%;
  left: -12.552%;
  top: -10.749%;
  */
  width: 132.523%;
  left: -19.552%;
  top: -15.749%;
}

.selector-field {
  height: 30%;
  position: relative;
}


.select-left, .select-right {
  width: 15%;
  height: 65%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center center;
}
.select-left {
  background-image: url(/00_Wuselhain/ArrowLeft.png);
  float: left;
}
.select-right {
  background-image: url(/00_Wuselhain/ArrowRight.png);
  float: right;
}

.story-screen {
  position: relative;
}

.story-screen > .story-texts, .story-screen > form > .story-texts {
  /*
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 70%;
  height: auto;
  font-size: 5.5rem;
  line-height: 100%;
  padding-bottom: 5rem;
  */

  /*
  font-size: 5.5rem;
  line-height: 100%;
  padding-bottom: 5rem;
  text-align: center;
  */

  font-size: 8.5rem;
  line-height: 150%;
  padding-bottom: 0;
  padding-top: 3rem;
  text-align: center;
}

.step-title {
  font-size: 13rem;
}

.story-screen .stepNr {
  font-size: 2.5rem;
  /* font-family: "europa", sans-serif; */
  padding-left: 0.5rem;
}

.story-screen > .submitted-texts {
  /*
  font-size: 4.5rem;
  */
  padding-bottom: 1rem;
}

body.liluBody .german {
  /* font-family: "europa", sans-serif; */
  /* font-family: "moret",serif; */
}

body.liluBody .english {
  /* font-family: "europa", sans-serif; */
  /* font-family: "moret",serif; */
}

.paletteContainer {
  padding: 2rem 8rem;
  height: 45%;
}

.paletteContainer > * {
  display: inline-block;
  height: 100%;
}
.paletteDescription {
  font-size: 2rem;
  width: 20%;
  float: left;
}
.palettesWrap {
  width: 75%;
  overflow-y: hidden;
}

#CloudOutline {
  display: none;
}
#CloudLion_00000047756583903194143350000010485706947808040125_ {
  pointer-events: none !important;
}

/* custom scroll bar */

::-webkit-scrollbar,
::-webkit-scrollbar-thumb,
::-webkit-scrollbar-track {
    -webkit-appearance: none;
    width: 8px;
    border: none;
    background: transparent;
    -webkit-overflow-scrolling: auto;
}

::-webkit-scrollbar-button,
::-webkit-scrollbar-track-piece,
::-webkit-scrollbar-corner,
::-webkit-resizer {
    display: none;
}

::-webkit-scrollbar-thumb {
    border-radius: 6px;
    background-color: var(--color-fg);
    height: 3rem;
}

::-webkit-scrollbar-track {
    background-image: url("/lilu2022/scrollbar_bg.png");
    background-repeat: repeat-y;
    background-size: contain;
}
.palettesWrap::-webkit-scrollbar-track {
    background-image: url("/lilu2022/scrollbar_bg_horizontal.png");
    background-repeat: repeat-x;
    background-size: contain;
}

.square {
  position: relative;

}

.square:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}

.square-content {
  position: absolute;
  max-width: 100%;
  max-height: 100%;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
}

.decoration-list-item {
  background-color: var(--color-bg);
  border-radius: 0.5rem;
  display: inline-block;
  vertical-align: top;
  width: 45%;
  margin: 0.5rem 0 0 0.5rem;

}

.decoration-list-item .decoration-content {
  max-height: 5rem; /* TODO: 100%  does not seem to work :( 5rem is a workaround */
  max-width: 100%;
  width: unset;
  height: unset;
  /* border: 2px solid red; */
}

.waiting-wrap {
  font-size: 75%;
}

.waiting-wrap > * {
  display: inline-block;
}

.waiting-text {
  width: 70%;
}

.waiting-time {
  /* float: right; */
}

.wh_form_wrap {
  position: relative;
  top: 50%;
  transform: translate(0px,-50%);
}

.wh_schlussbild {
  width: 35%;
  margin: auto;
}

@media (orientation: landscape) {

}

@media (orientation: portrait) {
  #decorationArea {
    width: 100%;
  }

  #decorationsWrap {
    height: 60%;
    max-height: 60%;
    width: 100%;
  }

  .decoration-list-item {
    background-color: var(--color-bg);
    border-radius: 0.5rem;
    display: inline-block;
    vertical-align: top;
    width: 24%;
    margin: 0.5rem 0 0 0.5rem;

  }
  .paletteContainer {
    padding: 2rem 2rem;
  }

  .decoration-list-item .decoration-content {
    max-height: 15rem;
  }
}
