body {
  padding: 0;
  margin: 0;
  background: #1e1e1e; }

*, :before, :after {
  box-sizing: border-box;
  outline: none; }

 {
  /* 24 frames / sec; the initial sequence is 80 frames */
  /* Automated loader timeout */ }
  #loader-overlay {
    position: absolute;
    overflow: hidden;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #1e1e1e;
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    z-index: 10000000;
    display: flex;
    flex-direction: column;
    justify-content: center;
    -webkit-app-region: drag; }
    #loader-overlay .container {
      flex-shrink: 0;
      display: block;
      position: relative;
      width: 1000px;
      height: 1000px;
      align-self: center;
      margin-bottom: 10vh;
      transition-duration: .5s; }
      #loader-overlay .container img {
        -webkit-user-select: none;
           -moz-user-select: none;
            -ms-user-select: none;
                user-select: none; }
    #loader-overlay .setup, #loader-overlay .idle {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      display: none; }
      #loader-overlay .setup.visible, #loader-overlay .idle.visible {
        display: block; }
    #loader-overlay .setup.visible.normal {
      -webkit-animation: loader-initial-sequence 0s cubic-bezier(0.81, 0.01, 0.65, 1.16) 3.33333s forwards;
              animation: loader-initial-sequence 0s cubic-bezier(0.81, 0.01, 0.65, 1.16) 3.33333s forwards; }
    #loader-overlay .setup.visible.halloween {
      -webkit-animation: loader-initial-sequence 0s cubic-bezier(0.81, 0.01, 0.65, 1.16) 13.45833s forwards;
              animation: loader-initial-sequence 0s cubic-bezier(0.81, 0.01, 0.65, 1.16) 13.45833s forwards; }
    #loader-overlay .idle.animation-normal img {
      position: absolute; }
    #loader-overlay .idle.animation-normal .steam {
      position: absolute;
      top: 282px;
      left: 380px;
      width: 249px;
      height: 125px;
      background: url(/img/334bdd1ccd19209a8179.png) 0 0;
      -webkit-animation: sprite-steam 2.5s steps(50) forwards infinite;
              animation: sprite-steam 2.5s steps(50) forwards infinite; }
    #loader-overlay.finishing {
      pointer-events: none;
      -webkit-animation: overlay-fade .3s .2s both;
              animation: overlay-fade .3s .2s both; }
      #loader-overlay.finishing .idle .steam {
        display: none; }
      #loader-overlay.finishing .idle .bowl {
        -webkit-animation: swipe-out-bowl .5s both;
                animation: swipe-out-bowl .5s both; }
      #loader-overlay.finishing .idle .text {
        -webkit-animation: swipe-out-text .5s .12s both;
                animation: swipe-out-text .5s .12s both; }
    #loader-overlay .loader-stage {
      position: absolute;
      left: 5px;
      bottom: 5px;
      font-size: 12px;
      font-family: monospace;
      color: #999; }
  #loader-overlay:not(.initialized) + #critical-load:not(.shown) {
    display: block !important;
    opacity: 0;
    -webkit-animation: loader-setup-timeout 0s ease-in 3.33333s forwards;
            animation: loader-setup-timeout 0s ease-in 3.33333s forwards; }
    #loader-overlay:not(.initialized) + #critical-load:not(.shown) .error::before {
      content: 'Failed to startup loader!'; }
    #loader-overlay:not(.initialized) + #critical-load:not(.shown) .detail::before {
      content: 'Lookup the console for more details'; }

@media all and (max-width: 850px) {
  #loader-overlay .container {
    transform: scale(0.5); } }

@media all and (max-height: 700px) {
  #loader-overlay .container {
    transform: scale(0.5); } }

@media all and (max-width: 400px) {
  #loader-overlay .container {
    transform: scale(0.3); } }

@-webkit-keyframes loader-initial-sequence {
  to {
    display: none; } }

@keyframes loader-initial-sequence {
  to {
    display: none; } }

@-webkit-keyframes sprite-steam {
  to {
    background-position: 0 -6250px; } }

@keyframes sprite-steam {
  to {
    background-position: 0 -6250px; } }

@-webkit-keyframes swipe-out-bowl {
  from {
    transform: translate3d(0, 0, 0); }
  40% {
    opacity: 1;
    transform: translate3d(-60px, 0, 0) skew(-5deg, 0) rotateY(-6deg); }
  to {
    opacity: 0;
    transform: translate3d(700px, 0, 0) skew(30deg, 0) rotateZ(-6deg); } }

@keyframes swipe-out-bowl {
  from {
    transform: translate3d(0, 0, 0); }
  40% {
    opacity: 1;
    transform: translate3d(-60px, 0, 0) skew(-5deg, 0) rotateY(-6deg); }
  to {
    opacity: 0;
    transform: translate3d(700px, 0, 0) skew(30deg, 0) rotateZ(-6deg); } }

@-webkit-keyframes swipe-out-text {
  from {
    transform: translate3d(0, 0, 0); }
  40% {
    opacity: 1;
    transform: translate3d(-30px, 20px, 0) skew(-5deg, 0); }
  to {
    opacity: 0;
    transform: translate3d(550px, 0, 0) skew(30deg, 0) scale(0.96, 1.25) rotateZ(6deg); } }

@keyframes swipe-out-text {
  from {
    transform: translate3d(0, 0, 0); }
  40% {
    opacity: 1;
    transform: translate3d(-30px, 20px, 0) skew(-5deg, 0); }
  to {
    opacity: 0;
    transform: translate3d(550px, 0, 0) skew(30deg, 0) scale(0.96, 1.25) rotateZ(6deg); } }

@-webkit-keyframes animation-nothing {
  to {
    background-position: 0 -6250px; } }

@keyframes animation-nothing {
  to {
    background-position: 0 -6250px; } }

@-webkit-keyframes overlay-fade {
  to {
    opacity: 0; } }

@keyframes overlay-fade {
  to {
    opacity: 0; } }

@-webkit-keyframes loader-setup-timeout {
  to {
    opacity: 1; } }

@keyframes loader-setup-timeout {
  to {
    opacity: 1; } }

#overlay-no-js, #critical-load {
  z-index: 100000000;
  display: none;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: #1e1e1e;
  text-align: center;
  -webkit-app-region: drag; }
  #overlay-no-js h1, #overlay-no-js h3, #overlay-no-js a, #critical-load h1, #critical-load h3, #critical-load a {
    -webkit-app-region: no-drag; }
  #overlay-no-js .container, #critical-load .container {
    position: relative;
    display: inline-block;
    top: 20%; }
  #overlay-no-js.shown, #critical-load.shown {
    display: block; }

#overlay-no-js {
  display: block;
  color: #999; }
  #overlay-no-js svg {
    fill: #999; }

#critical-load .img {
  height: 12em; }

#critical-load .error {
  color: #bd1515;
  margin-bottom: 0; }

#critical-load .detail {
  color: #696363;
  margin-top: .5em; }

svg {
  max-height: 100%;
  max-width: 100%; }

@media (max-height: 750px) {
  #critical-load .container {
    top: unset; }
  #critical-load {
    font-size: .8rem;
    flex-direction: column;
    justify-content: center; }
  #critical-load.shown {
    display: flex; } }


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://teaspeak-web/./loader/app/css/index.scss","webpack://teaspeak-web/./loader/app/css/loader.scss","webpack://teaspeak-web/./loader/app/css/overlay.scss"],"names":[],"mappings":"AAAA;EACI,UAAU;EACV,SAAS;EAET,mBAAmB;;AAGvB;EACI,sBAAsB;EACtB,aAAa;;ACTjB;EAC+B;EAwH9B,+BAA8B;EAzH/B;IAME,kBAAkB;IAClB,gBAAgB;IAEhB,MAAM;IACN,OAAO;IACP,QAAQ;IACR,SAAS;IAET,mBAAmB;IAEnB,yBAAiB;OAAjB,sBAAiB;QAAjB,qBAAiB;YAAjB,iBAAiB;IAEjB,iBAAiB;IAEjB,aAAa;IACb,sBAAsB;IACtB,uBAAuB;IAEvB,wBAAwB;IAxB1B;MA2BG,cAAc;MAEd,cAAc;MACd,kBAAkB;MAElB,aAAa;MACb,cAAc;MAEd,kBAAkB;MAClB,mBAAmB;MAEnB,wBAAwB;MAtC3B;QAyCI,yBAAiB;WAAjB,sBAAiB;YAAjB,qBAAiB;gBAAjB,iBAAiB;IAzCrB;MA8CG,kBAAkB;MAElB,MAAM;MACN,OAAO;MACP,QAAQ;MACR,SAAS;MAET,aAAa;MArDhB;QAwDI,cAAc;IAxDlB;MA8DI,oGAAgG;cAAhG,4FAAgG;IA9DpG;MAkEI,qGAAmG;cAAnG,6FAAmG;IAlEvG;MAwEI,kBAAkB;IAxEtB;MA4EI,kBAAkB;MAElB,UAAU;MACV,WAAW;MAEX,YAAY;MACZ,aAAa;MACb,mDAA6C;MAE7C,gEAAwD;cAAxD,wDAAwD;IArF5D;MAwGG,oBAAoB;MACpB,4CAAoC;cAApC,oCAAoC;MAzGvC;QA4FK,aAAa;MA5FlB;QAgGK,0CAAkC;gBAAlC,kCAAkC;MAhGvC;QAoGK,+CAAuC;gBAAvC,uCAAuC;IApG5C;MA6GG,kBAAkB;MAElB,SAAS;MACT,WAAW;MAEX,eAAe;MACf,sBAAsB;MAEtB,WAAW;EArHd;IA2HE,yBAAyB;IACzB,UAAU;IAEV,oEAAsE;YAAtE,4DAAsE;IA9HxE;MAiIG,oCAAoC;IAjIvC;MAqIG,8CAA8C;;AAKjD;EACC;IAEE,qBAAoB,IACpB;;AAIH;EACC;IAEE,qBAAoB,IACpB;;AAIH;EACC;IAEE,qBAAoB,IACpB;;AAIH;EACC;IACC,aAAa;;AAFf;EACC;IACC,aAAa;;AAIf;EACC;IACC,8BAA8B;;AAFhC;EACC;IACC,8BAA8B;;AAIhC;EACC;IACC,+BAA+B;EAGhC;IACC,UAAU;IACV,iEAAiE;EAGlE;IACC,UAAU;IACV,iEAAiE;;AAZnE;EACC;IACC,+BAA+B;EAGhC;IACC,UAAU;IACV,iEAAiE;EAGlE;IACC,UAAU;IACV,iEAAiE;;AAInE;EACC;IACC,+BAA+B;EAGhC;IACC,UAAU;IACV,qDAAqD;EAGtD;IACC,UAAU;IACV,kFAAiF;;AAZnF;EACC;IACC,+BAA+B;EAGhC;IACC,UAAU;IACV,qDAAqD;EAGtD;IACC,UAAU;IACV,kFAAiF;;AAInF;EACC;IACC,8BAA8B;;AAFhC;EACC;IACC,8BAA8B;;AAIhC;EACC;IACC,UAAU;;AAFZ;EACC;IACC,UAAU;;AAIZ;EACC;IACC,UAAU;;AAFZ;EACC;IACC,UAAU;;AC5NZ;EAEQ,kBAAkB;EAClB,aAAa;EACb,eAAe;EAEf,MAAM;EACN,SAAS;EACT,OAAO;EACP,QAAQ;EAER,mBAAmB;EACnB,kBAAkB;EAElB,wBAAwB;EAdhC;IAiBY,2BAA2B;EAjBvC;IAqBY,kBAAkB;IAClB,qBAAqB;IAErB,QAAQ;EAxBpB;IA4BY,cAAc;;AA5B1B;EAiCQ,cAAc;EACd,WAAW;EAlCnB;IAqCY,UAAU;;AArCtB;EA2CY,YACJ;;AA5CR;EA+CY,cAAc;EACd,gBACJ;;AAjDR;EAoDY,cAAc;EACd,gBACJ;;AAtDR;EA0DQ,gBAAgB;EAChB,eAAe;;AAKvB;EACI;IAEQ,UAAU;EAFlB;IAMQ,gBAAgB;IAEhB,sBAAsB;IACtB,uBAAuB;EAT/B;IAaQ,aAAa,IAChB","file":"css/loader.18d7b5647f7bc83f9d62.css","sourcesContent":["body {\n    padding: 0;\n    margin: 0;\n\n    background: #1e1e1e;\n}\n\n*, :before, :after {\n    box-sizing: border-box;\n    outline: none;\n}",":global {\n\t$setup-time-normal: 80s / 24; /* 24 frames / sec; the initial sequence is 80 frames */\n\t$setup-time-halloween: 323s / 24;\n\t$loop-time-halloween: 25s / 24;\n\n\t#loader-overlay {\n\t\tposition: absolute;\n\t\toverflow: hidden;\n\n\t\ttop: 0;\n\t\tleft: 0;\n\t\tright: 0;\n\t\tbottom: 0;\n\n\t\tbackground: #1e1e1e;\n\n\t\tuser-select: none;\n\n\t\tz-index: 10000000;\n\n\t\tdisplay: flex;\n\t\tflex-direction: column;\n\t\tjustify-content: center;\n\n\t\t-webkit-app-region: drag;\n\n\t\t.container {\n\t\t\tflex-shrink: 0;\n\n\t\t\tdisplay: block;\n\t\t\tposition: relative;\n\n\t\t\twidth: 1000px;\n\t\t\theight: 1000px;\n\n\t\t\talign-self: center;\n\t\t\tmargin-bottom: 10vh;\n\n\t\t\ttransition-duration: .5s;\n\n\t\t\timg {\n\t\t\t\tuser-select: none;\n\t\t\t}\n\t\t}\n\n\t\t.setup, .idle {\n\t\t\tposition: absolute;\n\n\t\t\ttop: 0;\n\t\t\tleft: 0;\n\t\t\tright: 0;\n\t\t\tbottom: 0;\n\n\t\t\tdisplay: none;\n\n\t\t\t&.visible {\n\t\t\t\tdisplay: block;\n\t\t\t}\n\t\t}\n\n\t\t.setup.visible {\n\t\t\t&.normal {\n\t\t\t\tanimation: loader-initial-sequence 0s cubic-bezier(.81,.01,.65,1.16) $setup-time-normal forwards;\n\t\t\t}\n\n\t\t\t&.halloween {\n\t\t\t\tanimation: loader-initial-sequence 0s cubic-bezier(.81,.01,.65,1.16) $setup-time-halloween forwards;\n\t\t\t}\n\t\t}\n\n\t\t.idle.animation-normal {\n\t\t\timg {\n\t\t\t\tposition: absolute;\n\t\t\t}\n\n\t\t\t.steam {\n\t\t\t\tposition: absolute;\n\n\t\t\t\ttop: 282px;\n\t\t\t\tleft: 380px;\n\n\t\t\t\twidth: 249px;\n\t\t\t\theight: 125px;\n\t\t\t\tbackground: url(\"../../images/steam.png\") 0 0;\n\n\t\t\t\tanimation: sprite-steam 2.5s steps(50) forwards infinite;\n\t\t\t}\n\t\t}\n\n\t\t&.finishing {\n\t\t\t.idle {\n\t\t\t\t.steam {\n\t\t\t\t\tdisplay: none;\n\t\t\t\t}\n\n\t\t\t\t.bowl {\n\t\t\t\t\tanimation: swipe-out-bowl .5s both;\n\t\t\t\t}\n\n\t\t\t\t.text {\n\t\t\t\t\tanimation: swipe-out-text .5s .12s both;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tpointer-events: none;\n\t\t\tanimation: overlay-fade .3s .2s both;\n\t\t}\n\n\t\t.loader-stage {\n\t\t\tposition: absolute;\n\n\t\t\tleft: 5px;\n\t\t\tbottom: 5px;\n\n\t\t\tfont-size: 12px;\n\t\t\tfont-family: monospace;\n\n\t\t\tcolor: #999;\n\t\t}\n\t}\n\n\t/* Automated loader timeout */\n\t#loader-overlay:not(.initialized) + #critical-load:not(.shown) {\n\t\tdisplay: block !important;\n\t\topacity: 0;\n\n\t\tanimation: loader-setup-timeout 0s ease-in $setup-time-normal forwards;\n\n\t\t.error::before {\n\t\t\tcontent: 'Failed to startup loader!';\n\t\t}\n\n\t\t.detail::before {\n\t\t\tcontent: 'Lookup the console for more details';\n\t\t}\n\t}\n}\n\n@media all and (max-width: 850px) {\n\t:global {\n\t\t#loader-overlay .container {\n\t\t\ttransform: scale(.5);\n\t\t}\n\t}\n}\n\n@media all and (max-height: 700px) {\n\t:global {\n\t\t#loader-overlay .container {\n\t\t\ttransform: scale(.5);\n\t\t}\n\t}\n}\n\n@media all and (max-width: 400px) {\n\t:global {\n\t\t#loader-overlay .container {\n\t\t\ttransform: scale(.3);\n\t\t}\n\t}\n}\n\n@keyframes :global(loader-initial-sequence) {\n\tto {\n\t\tdisplay: none;\n\t}\n}\n\n@keyframes :global(sprite-steam) {\n\tto {\n\t\tbackground-position: 0 -6250px;\n\t}\n}\n\n@keyframes :global(swipe-out-bowl) {\n\tfrom {\n\t\ttransform: translate3d(0, 0, 0);\n\t}\n\n\t40% {\n\t\topacity: 1;\n\t\ttransform: translate3d(-60px, 0, 0) skew(-5deg, 0) rotateY(-6deg);\n\t}\n\n\tto {\n\t\topacity: 0;\n\t\ttransform: translate3d(700px, 0, 0) skew(30deg, 0) rotateZ(-6deg);\n\t}\n}\n\n@keyframes :global(swipe-out-text) {\n\tfrom {\n\t\ttransform: translate3d(0, 0, 0);\n\t}\n\n\t40% {\n\t\topacity: 1;\n\t\ttransform: translate3d(-30px, 20px, 0) skew(-5deg, 0);\n\t}\n\n\tto {\n\t\topacity: 0;\n\t\ttransform: translate3d(550px, 0, 0) skew(30deg, 0) scale(.96, 1.25) rotateZ(6deg);\n\t}\n}\n\n@keyframes :global(animation-nothing) {\n\tto {\n\t\tbackground-position: 0 -6250px;\n\t}\n}\n\n@keyframes :global(overlay-fade) {\n\tto {\n\t\topacity: 0;\n\t}\n}\n\n@keyframes :global(loader-setup-timeout) {\n\tto {\n\t\topacity: 1;\n\t}\n}",":global {\n    #overlay-no-js, #critical-load {\n        z-index: 100000000;\n        display: none;\n        position: fixed;\n\n        top: 0;\n        bottom: 0;\n        left: 0;\n        right: 0;\n\n        background: #1e1e1e;\n        text-align: center;\n\n        -webkit-app-region: drag;\n\n        h1, h3, a {\n            -webkit-app-region: no-drag;\n        }\n\n        .container {\n            position: relative;\n            display: inline-block;\n\n            top: 20%;\n        }\n\n        &.shown {\n            display: block;\n        }\n    }\n\n    #overlay-no-js {\n        display: block;\n        color: #999;\n\n        svg {\n            fill: #999;\n        }\n    }\n\n    #critical-load {\n        .img {\n            height: 12em\n        }\n\n        .error {\n            color: #bd1515;\n            margin-bottom: 0\n        }\n\n        .detail {\n            color: #696363;\n            margin-top: .5em\n        }\n    }\n\n    svg {\n        max-height: 100%;\n        max-width: 100%;\n    }\n}\n\n\n@media (max-height: 750px) {\n    :global {\n        #critical-load .container {\n            top: unset;\n        }\n\n        #critical-load {\n            font-size: .8rem;\n\n            flex-direction: column;\n            justify-content: center;\n        }\n\n        #critical-load.shown {\n            display: flex;\n        }\n    }\n}"],"sourceRoot":""}*/