@font-face {
    font-family: Barlow;
    src: url(Barlow-Regular.ttf);
}
@font-face {
    font-family: BarlowLight;
    src: url(Barlow-Light.ttf);
}
/* width */
::-webkit-scrollbar {
    width: 4px;
}

/* Track */
::-webkit-scrollbar-track {
    background: rgba(0,0,0,0);
}

/* Handle */
::-webkit-scrollbar-thumb {
    background: #888;
}

/* Handle on hover */
::-webkit-scrollbar-thumb:hover {
    background: #555;
}

html, body {
    width: 100%;
    height: 100%;
    overflow: auto;
}
body {
    margin: 0;
    padding: 0;
    background: #000;
}
* {
    font-family: Barlow, sans-serif;
    margin: 0;
    padding: 0;
    -webkit-tap-highlight-color:  rgba(255, 255, 255, 0);
}
*:not(input,textarea) {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}
*:focus {
    outline: none;
}
.en, .cn, .jp {
    display: none;
}
.apply-en .en {
    display: inline-block;
}
.apply-cn .cn {
    display: inline-block;
}
.layer {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 1366px;
    height: 768px;
    overflow: hidden;
}
video {
    position: absolute;
}
.right-bottom-border-video {
    position: absolute;
    bottom: 0;
    right: 0;
}
.master-head {
    position: absolute;
    top: 228px;
    width: 1108px;
    left: 0;
    right: 0;
    margin: 0 auto;
    transition: 1s;
}
.master-logo {
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    height: 768px;
    width: 1366px;
    text-align: center;
    transition: 1s;
}
.master-logo .center-video {
    position: absolute;
    top: 0;
    left: 0;
    width: 1366px;
    height: 768px;
}
.master-text {
    position: absolute;
    top: 602px;
    font-size: 20px;
    color: #fff;
    right: 76px;
    margin: 0 auto;
    width: 204px;
    text-align: left;
}
.icon-wristband {
    position: absolute;
    top: 572px;
    width: 108px;
    right: 288px;
    margin: 0 auto;
    animation-name: breath;
    animation-duration: 2s;
    animation-iteration-count: infinite;
    transform: scale3d(1,1,1);
    animation-timing-function: linear;
}
.icon-arrowdown {
    position: absolute;
    top: 698px;
    width: 30px;
    right: 326px;
    margin: 0 auto;
    animation-name: updown;
    animation-duration: 3s;
    animation-iteration-count: infinite;
    transform: translate3d(0,0,0);
}
@keyframes breath {
    from {transform: scale3d(1,1,1);}
    25% {transform: scale3d(1.05,1.05,1.05);}
    75% {transform: scale3d(0.95,0.95,0.95);}
    to {transform: scale3d(1,1,1);}
}
@keyframes updown {
    from {transform: translate3d(0,0,0); opacity: 1;}
    15% {transform: translate3d(0,12px,0);}
    30% {transform: translate3d(0,0,0);}
    50% {opacity: 0;}
    to {transform: translate3d(0,0,0); opacity: 1;}
}
.icon-group {
    position: absolute;
    bottom: 0px;
    left: 0px;
    width: 100px;
    height: 100px;
}
.icon-fit {
    position: absolute;
    bottom: 0px;
    left: 0px;
    width: 100px;
    height: 100px;
}
.mode-fit .icon-group, .mode-fit .group-el {
    display: none !important;
}
.mode-group .icon-fit, .mode-group .fit-el {
    display: none !important;
}
.step2 .master-logo {
    transform: translate3d(0, -340px, 0) scale3d(0.1, 0.1, 1);
}
.step2 .master-head {
    top: 240px;
}
.btn {
    padding: 25px 35px;
    background: rgb(25, 26, 36);
    border-radius: 90px;
    font-size: 20px;
    color: #ED837B;
    float: left;
    margin: 8px 25px;
    transition: background 0.2s ease;
}
.btn:hover {
    background: rgba(25, 26, 36, 0.6);
}
.btn:active {
    background: #ED837B;
    color: #fff; /* optional for contrast */
    transition: background 0.05s ease; /* makes it snap fast when pressed */
}
.btn.btn-next {
    float: unset;
    width: fit-content;
    margin: 0 auto;
}
.btn.btn-round {
    padding: 40px 42px;
}
.master-text2, .master-text3, .master-text4, .master-text5 {
    position: absolute;
    top: 86px;
    font-size: 20px;
    text-align: center;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    max-width: 364px;
}
.master-text4 {
    top: 186px;
}
.master-text2 {
    max-width: 1024px;
}
.master-text2-small {
    top: 720px;
    font-size: 24px;
}
.master-text6 {
    font-size: 28px !important;
    top: 520px !important;
}
.master-text7 {
    top: 680px !important;
    font-size: 28px !important;
}
.master-smalltext4 {
    display: none;
    position: absolute;
    top: 400px;
    font-size: 16px;
    letter-spacing: 0.06em;
    text-align: center;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
}
.btn-group {
    position: absolute;
    top: 524px;
    width: fit-content;
    height: fit-content;
    left: 0;
    right: 0;
    margin: 0 auto;
}
.overwrite-block.btn-group {
    top: 200px;
}
.btn-group5 {
    top: 740px;
}
.input {
    display: none;
    position: absolute;
    top: 615px;
    width: fit-content;
    height: fit-content;
    left: 0;
    right: 0;
    margin: 0 auto;
}
.input input {
    border: 0;
    background: unset;
    color: rgba(255,255,255,0.5);
    font-size: 18px;
    border-bottom: 2px rgba(255,255,255,0.2) solid;
    padding: 0 0 16px 0;
}

.loading {
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 99999;
    background: black;
}
.loading p {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: 0 auto;
    color: #fff;
    text-align: center;
    font-size: 64px;
}
.layer1 {
    z-index: 900;
}
.layer2 {
    z-index: 800;
    background: linear-gradient(360deg, #012833 0%, #01070F 88.02%);
}
.world-canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 1366px;
    height: 768px;
    opacity: 0;
    transform: scale3d(0.5, 0.5, 0.5);
    transition: 2s;
    z-index: 9998;
}
.layer2.init .world-canvas {
    opacity: 1;
    transform: scale3d(1, 1, 1);
}
.score-board {
    width: 36px;
    overflow: hidden;
    height: 50px;
    text-align: center;
}
#score-board1, #score-board3, #score-board5 {
    margin-left: 70px;
}
.score-board p {
    font-family: BarlowLight, sans-serif;
    color: #fff;
    font-size: 60px;
    width: 36px;
    line-height: 50px;
    margin: 0;
}
.score-div {
    width: 156px;
    position: absolute;
    top: -150px;
    text-align: center;
    transition-timing-function: ease-out;
    overflow: hidden;
}
.score-div.explorer {
    right: 530px;
}
.score-div.mastermind {
    right: 288px;
}
.score-div.protector {
    right: 46px;
}
.init .score-div.explorer {
    transition-delay: 0s;
    transition-duration: 1.5s;
    top: 50px;
}
.init .score-div.mastermind {
    transition-delay: 0.3s;
    transition-duration: 1.5s;
    top: 50px;
}
.init .score-div.protector {
    transition-delay: 0.6s;
    transition-duration: 1.5s;
    top: 50px;
}
.score-div > p {
    font-weight: bold;
    margin: 0;
    color: #fff;
    font-size: 12px;
    margin-bottom: 24px;
}
.score-div > div {
    position: relative;
}
.score-div > div > canvas {
    /*margin-right: 18px;
    height: 51px;
    width: 51px;*/
    position: absolute;
    top: -28px;
    left: -24px;
}
.score-div > div > img, .score-div > div > div, .score-div > div > canvas {
    float: left;
}
.layer2 .left-top-border-video {
    transform-origin: left top;
    transform: scale(0.5);
    opacity: 0;
    transition: 3s;
}
.init .left-top-border-video {
    transform: scale(1);
    opacity: 0;
}
.avatar {
    position: absolute;
    top: 50px;
    left: 50px;
    transform: scale(0);
    opacity: 0;
    transition-delay: 2s;
    transition-duration: 2s;
    z-index: 9999;
}
.init .avatar {
    transform: scale(1);
    opacity: 1;
}
.hello {
    position: absolute;
    top: 48px;
    left: 170px;
    opacity: 0;
    transition-delay: 2.5s;
    transition-duration: 2s;
    z-index: 9999;
}
.hello p {
    font-size: 42px;
    color: #fff;
}
.init .hello {
    opacity: 1;
}
#nav-right {
    position: absolute;
    right: 22px;
    top: 48%;
}
#nav-left {
    position: absolute;
    left: 22px;
    top: 48%;
}
.nav {
    opacity: 0;
}
.init .nav {
    opacity: 1;
    transition-delay: 4s;
    transition-duration: 1s;
}
.menu {
    position: absolute;
    bottom: -70px;
    width: 400px;
    height: 70px;
    left: 0;
    right: 0;
    margin: 0 auto;
    border-radius: 90px;
    background-color: rgba(255,255,255,0.12);
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 90000;
}
.init .menu {
    opacity: 1;
    bottom: 20px;
    transition-delay: 2.5s;
    transition-duration: 2s;
}
.menu > canvas {
    margin: 0 16px;
    width: 64px;
    height: 64px;
    opacity: 0.5;
}
.exit {
    position: absolute;
    left: 396px;
    top: 58px;
    width: 70px;
    height: 70px;
    border-radius: 90px;
    backdrop-filter: blur(10px);
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(255,255,255,0.05);
    z-index: 9999;
}
.exit img {
    width: 22px;
    height: 22px;
}
.init .exit {
    opacity: 1;
    transition-delay: 3.5s;
    transition-duration: 2s;
}
.mobile {
    position: absolute;
    right: 50px;
    bottom: -90px;
    width: 70px;
    height: 70px;
    border-radius: 90px;
    backdrop-filter: blur(10px);
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background: rgba(255,255,255,0.05);
    z-index: 9999;
}
.mobile img {
    width: 22px;
    height: 36px;
}
.init .mobile {
    bottom: 20px;
    opacity: 1;
    transition-delay: 3.5s;
    transition-duration: 2s;
}
.orb, .orb-badge {
    position: absolute;
    width: 180px;
    height: 180px;
    z-index: 9999;
    opacity: 0;
}
.orb-badge {
    right: 200px;
    bottom: 100px;
}
.orb-badge.active {
    opacity: 1;
    transition: opacity 1s;
}
.init .orb1 {
    opacity: 1;
    transition-delay: 0.5s;
    transition-duration: 2s;
}
.init .orb2 {
    opacity: 1;
    transition-delay: 1.1s;
    transition-duration: 2s;
}
.init .orb3 {
    opacity: 1;
    transition-delay: 1.4s;
    transition-duration: 2s;
}
.init .orb4 {
    opacity: 1;
    transition-delay: 2.1s;
    transition-duration: 2s;
}
.init .orb5 {
    opacity: 1;
    transition-delay: 2.5s;
    transition-duration: 2s;
}
.init .orb1.floating {
    animation-name: floating;
    animation-delay: 0.2s;
    animation-duration: 2.8s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.init .orb2.floating {
    animation-name: floating;
    animation-delay: 1.1s;
    animation-duration: 2.4s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.init .orb3.floating {
    animation-name: floating;
    animation-delay: 1.9s;
    animation-duration: 2.1s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.init .orb4.floating {
    animation-name: floating;
    animation-delay: 2.4s;
    animation-duration: 2.9s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.init .orb5.floating {
    animation-name: floating;
    animation-delay: 3s;
    animation-duration: 2.4s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.orb-badge.floating {
    animation-name: floating;
    animation-duration: 2.8s;
    animation-iteration-count: infinite;
    animation-timing-function: ease-in-out;
}
.orb1 {
    left: 1056px;
    top: 600px;
}
.orb2 {
    left: 400px;
    top: 296px;
}
.orb3 {
    left: 860px;
    top: 182px;
}
.orb4 {
    left: 1154px;
    top: 230px;
}
.orb5 {
    left: 1400px;
    top: 462px;
}

.rotate0.orb1 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1056px;
    top: 600px;
}
.rotate0.orb2 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 400px;
    top: 296px;
}
.rotate0.orb3 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 860px;
    top: 182px;
}
.rotate0.orb4 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1154px;
    top: 230px;
}
.rotate0.orb5 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1400px;
    top: 462px;
}

.rotate1.orb1 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 400px;
    top: 296px;
}
.rotate1.orb2 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 860px;
    top: 182px;
}
.rotate1.orb3 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1154px;
    top: 230px;
}
.rotate1.orb4 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1400px;
    top: 462px;
}
.rotate1.orb5 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1056px;
    top: 600px;
}

.rotate2.orb5 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 400px;
    top: 296px;
}
.rotate2.orb1 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 860px;
    top: 182px;
}
.rotate2.orb2 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1154px;
    top: 230px;
}
.rotate2.orb3 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1400px;
    top: 462px;
}
.rotate2.orb4 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1056px;
    top: 600px;
}

.rotate3.orb4 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 400px;
    top: 296px;
}
.rotate3.orb5 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 860px;
    top: 182px;
}
.rotate3.orb1 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1154px;
    top: 230px;
}
.rotate3.orb2 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1400px;
    top: 462px;
}
.rotate3.orb3 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1056px;
    top: 600px;
}

.rotate4.orb3 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 400px;
    top: 296px;
}
.rotate4.orb4 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 860px;
    top: 182px;
}
.rotate4.orb5 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1154px;
    top: 230px;
}
.rotate4.orb1 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1400px;
    top: 462px;
}
.rotate4.orb2 {
    transition-delay: 0s;
    transition-duration: 2s;
    left: 1056px;
    top: 600px;
}

.orb p {
    position: absolute;
    font-size: 20px;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    top: 20px;
}
.orb-badge p {
    position: absolute;
    font-size: 12px;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    text-align: center;
    bottom: 0px;
}
.orb-badge p span {
    opacity: 0.5;
}
.orb-badge .orb-badge-count {
    opacity: 1;
}
.orb img, .orb-badge img {
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
    transform: translate3d(0, -50%, 0px);
}
@keyframes floating {
    0% { transform: translate(0,  0px); }
    50%  { transform: translate(0, 8px); }
    100%   { transform: translate(0, -0px); }
}
.new-badges {
    position: absolute;
    bottom: -660px;
    width: 588px;
    height: 660px;
    left: 50px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) -16.96%, rgba(255, 255, 255, 0.1) 94.12%);
    backdrop-filter: blur(7.5px);
    z-index: 9999;
    transition: 1s;
}

.init .new-badges {
    bottom: 0;
    transition-delay: 3s;
}

.init .new-badges.down {
    bottom: -570px;
    transition-delay: unset;
}

.init .new-badges.up {
    bottom: 0;
    transition-delay: unset;
}

.init .new-badges.down .panel-down {
    transform: rotate(180deg);
    transition: 1s;
}

.init .new-badges.down .panel-body {
    overflow: hidden;
}

.new-badges .panel-head {
    height: 70px;
    width: 100%;
    background: rgba(255,255,255,0.08);
    border-radius: 10px 10px 0 0;
}

.new-badges .panel-title {
    font-size: 30px;
    color: white;
    margin-left: 142px;
    line-height: 70px;
}

.new-badges .panel-down {
    position: absolute;
    top: 10px;
    right: 10px;
}

.new-badges .panel-scroll {
    position: relative;
    padding: 0 32px;
}

.new-badges .panel-top-bg {
    position: absolute;
    top: 0;
    left: 0;
}

.new-badges .panel-subtitle {
    position: relative;
    height: 130px;
    width: 126px;
}

.new-badges .panel-subtitle p {
    position: absolute;
    bottom: 20px;
    max-width: 126px;
    color: white;
    font-size: 20px;
}

.new-badges .divider {
    width: 100%;
    border-bottom: 1px solid rgba(255,255,255,0.2);
    margin-bottom: 32px;
}

.row {
    margin-bottom: 32px;
}

.col {
    width: 33%;
    text-align: center;
    float: left;
}

.col p {
    text-align: center;
    font-size: 17px;
    color: white;
}

.clear {
    clear: both;
}

.panel-body {
    overflow-y: scroll;
    height: 590px;
}

.alert {
    position: absolute;
    width: 62px;
    height: 62px;
    background: #ED837B;
    top: 0;
    left: 42px;
    transform: scale(0) rotate(0);
    border-radius: 5px;
}

.init .alert {
    animation-name: alerting;
    animation-duration: 1.5s;
    animation-timing-function: linear;
    animation-delay: 3s;
    animation-fill-mode: forwards;
}

@keyframes alerting {
    from {transform: scale(0) rotate(0);}
    65% {transform: scale(1) rotate(-45deg);}
    75% {transform: scale(1.1) rotate(-45deg);}
    to {transform: scale(1) rotate(-45deg);}
}

#acquisition-count {
    width: 30px;
    height: 24px;
    position: absolute;
    top: 18px;
    left: 58px;
    overflow: hidden;
    text-align: center;
}

#acquisition-count span {
    font-size: 30px;
    color: white;
    line-height: 24px;
    top: 24px;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    transition: 1s;
    transition-timing-function: ease-out;
}

.init #acquisition-count span {
    top: 0;
    transition-delay: 3.5s;
}

.col img {
    height: 140px;
    width: auto;
}

.menu-mask {
    background: rgba(255,255,255,0.2);
    width: 112px;
    position: absolute;
    height: 68px;
    border-radius: 90px;
    left: 94px;
    transition: transform 0.5s;
}

.step-quest .menu-mask {
    transform: translate(100px, 0px);
}

.step-badge .menu-mask {
    transform: translate(-94px, 0px);
}

.step-postcard .menu-mask {
    transform: translate(194px, 0px);
}

.hg-theme-default {
    position: absolute;
    z-index: 9999;
    background-color: rgba(5,1,13,0.82);
    backdrop-filter: blur(10px);
}

.hg-theme-default .hg-row:first-child .hg-button.hg-standardBtn[data-skbtn="@"] {
    max-width: unset;
}

.hg-theme-default .hg-button {
    border-bottom: unset;
    background: #2b2b30;
    height: 64px;
}

.hg-theme-default .hg-button span {
    color: #fff;
}

.hg-button-down {
    max-width: 60px;
}

.simple-keyboard {
    bottom: -360px;
    transition: 1.5s;
}

.down .simple-keyboard {
    bottom: 0;
}

.init.step-quest .new-badges, .init.step-badge .new-badges, .init.step-postcard .new-badges {
    transition: opacity 0.5s;
    opacity: 0;
    bottom: -660px;
}

.init.step-quest .orb, .init.step-badge .orb, .init.step-postcard .orb {
    transition: opacity 0.5s 0s !important;
    opacity: 0 !important;
}

.layer.step-quest .world-canvas canvas {
    transform: translate(-460px, 200px);
}

.layer.step-badge .world-canvas canvas {
    transform: translate(600px, 200px) scale(0.65);
}

.layer.step-postcard .world-canvas canvas {
    opacity: 0;
}

.layer #quests-header, .layer #quests-footer, .layer #quests-body {
    opacity: 0;
}

.layer #quests-header {
    transition: 0.8s;
    transition-delay: 1s;
}

.layer #quests-header p {
    transition: 0.8s;
    transform: translate(0, 32px);
}

.layer.step-quest #quests-header p {
    transform: translate(0, 0);
}

.layer #quests-footer {
    transition: 0.8s 2s;
    transform: translate(0, 32px);
}

.layer #quests-body {
    transition: 1s;
    transition-delay: 1s;
    transform: translate(0, 880px);
}

.layer.step-quest #quests-header {
    opacity: 1;
}

.layer.step-quest #quests-footer {
    opacity: 1;
    transform: translate(0, 0);
    z-index: 9998;
}

.layer.step-quest #quests-body {
    opacity: 1;
    transform: translate(0, 0);
}

.quest-marker {
    position: absolute;
    z-index: 10000;
    bottom: -100px;
    left: -100px;
    height: 54px;
    width: 35px;
    text-align: center;
    opacity: 0;
    transition: 0.5s;
}

.layer2.step-quest .quest-marker {
    opacity: 0;
}

.layer2.step-quest .quest-marker.active {
    opacity: 1;
}

@keyframes pulsing {
    0% { transform: scale(1); }
    50%  { transform: scale(1.2); }
    100%   { transform: scale(1); }
}

.btn-lang {
    font-size: 15px;
    color: #ED837B;
}

.input-box {
    position: relative;
    width: 944px;
    height: 176px;
    /*top: 296px;*/
    /*left: 0;*/
    /*right: 0;*/
    margin: 0 auto;
    background: rgba(25, 26, 36, 0.4);
    backdrop-filter: blur(7.5px);
    border-radius: 10px;
    transition: 1s;
    padding: 40px 72px;
}

.auth-layer .input-box {
    background: unset;
    backdrop-filter: unset;
}

.error-layer.active {
    display: block;
}

.error-layer >img {
    position: absolute;
    top: 214px;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.master-error-system-error {
    position: absolute;
    top: 338px;
    font-family: BarlowLight, sans-serif;
    font-size: 45px;
    text-align: center;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    max-width: 680px;
}

.down .input-block, .down .auth-block {
    transform: translate(0px, -122px);
}

.down .validate-block.kiosk-step2 {
    transform: translate(0px, -192px);
}

.down .btn-group-auth {
    transform: translate(0px, -192px);
}

.btn-group-auth {
    transition: 1s;
}

.input-label {
    font-weight: bold;
    font-size: 16px;
    color: #ED837B;
    text-transform: uppercase;
}

input, .input-text {
    background-color: rgba(0,0,0,0);
    border: 0;
    color: #fff;
    font-size: 30px;
}

.readonly input {
    color: rgba(255,255,255,1);
}

.input-center {
    width: 512px;
    margin: 0 auto;
}

.input-center .input-el, .input-center .input-error {
    width: 100%;
}

.input-center .input-error {
    display: none;
}

.auth-layer .input-center .input-error {
    display: block;
}

.input-half {
    float: left;
    margin-right: 32px;
    width: 512px;
}

.input-el {
    float: left;
    margin-right: 16px;
    min-height: 88px;
    width: 240px;
}

.input-email-block {
    width: 496px;
}

.input-el.radio {
    width: 366px;
}

#lang-en {
    margin-right: 16px;
}

.kiosk-step2, .kiosk-step3, .kiosk-step4 {
    opacity: 0;
    pointer-events: none;
    transition: 1s;
}

.step2 .kiosk-step2 {
    opacity: 1;
    pointer-events: auto;
}

.step3 .kiosk-step3 {
    opacity: 1;
    pointer-events: auto;
}

.step3 p.kiosk-step2, .step4 .kiosk-step2, .step4 .kiosk-step3 {
    opacity: 0;
    pointer-events: none;
}

.step4 .kiosk-step4 {

    opacity: 1;
    pointer-events: auto;
}

.input-body {
    border-bottom: 1.5px solid rgba(255,255,255,0.3);
    overflow: hidden;
}

.readonly .input-body {
    border: 0;
}

.btn-radio {
    width: 116px;
    float: left;
}

.btn-radio-outer {
    float: left;
    position: relative;
    width: 32px;
    height: 32px;
    border: 1px solid #fff;
    border-radius: 50%;
    margin-right: 8px;
}

.btn-radio-inner {
    opacity: 0;
    position: relative;
    width: 8px;
    height: 8px;
    background-color: #ED837B;
    margin: 0 auto;
    margin-top: 12px;
    transition: 0.5s;
    border-radius: 50%;
}

.active .btn-radio-inner {
    opacity: 1;
}

.btn-radio-label {
    float: left;
    color: #fff;
    font-size: 20px;
    line-height: 32px;
}

.btn-radio-group {
    height: 32px;
}

.btn-edit {
    position: absolute;
    top: 88px;
    right: 100px;
}

input:-webkit-autofill,
input:-webkit-autofill:focus {
    transition: background-color 600000s 0s, color 600000s 0s;
}
input[data-autocompleted] {
    background-color: transparent !important;
}

.btn-lang {
    position: absolute;
    top: 34px;
    padding: 12px 18px !important;
    z-index: 1000;
}

.btn-lang.active {
    background: rgb(25, 26, 36, 1);
}

.lang-en {
    right: 164px;
}

.lang-jp {
    right: 4px;
}

.lang-cn {
    right: 92px;
}

.kiosk-step4 > p {
    position: absolute;
    color: #fff;
}

.kiosk-step4 > p:nth-child(1) {
    display: none;
}

.kiosk-step4 > p:nth-child(2) {
    top: 228px;
    left: 166px;
    font-size: 45px;
    width: 440px;
}

.kiosk-step4 > p:nth-child(3) {
    bottom: 210px;
    left: 150px;
    font-size: 16px;
    width: 266px;
    color: #EC827B;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    text-align: center;
}

.kiosk-step4 > p:nth-child(4) {
    bottom: 210px;
    left: 150px;
    font-size: 16px;
    width: 266px;
    color: #EC827B;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    text-align: center;
}

.kiosk-step4 .icon-arrowdown {
    bottom: 154px;
    left: 268px;
    right: auto;
    top: auto;
}

.icon-warning {
    position: absolute;
    top: 480px;
    left: 166px;
}

.ill-1 {
    top: 250px;
    right: 540px;
    font-size: 20px;
    color: #fff;
    border: 1px solid #fff;
    padding: 50px;
    position: absolute;
}

.ill-2 {
    top: 410px;
    right: 540px;
    font-size: 20px;
    color: #fff;
    border: 1px solid #fff;
    padding: 50px;
    position: absolute;
}

.ill-3 {
    top: 570px;
    right: 540px;
    font-size: 20px;
    color: #fff;
    border: 1px solid #fff;
    padding: 50px;
    position: absolute;
}

#firstname, #lastname {
    width: 240px;
}

#email, #r-email {
    width: 496px;
}

.last-line {
    top: 606px;
    right: 148px;
    font-size: 20px;
    width: 360px;
}

.input-block {
    position: absolute;
    top: 196px;
    width: 1088px;
    height: 264px;
    overflow-y: auto;
    overflow-x: hidden;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.auth-block {
    position: absolute;
    top: 300px;
    width: 1088px;
    height: 160px;
    overflow: hidden;
    left: 0;
    right: 0;
    margin: 0 auto;
    transition: 1s;
}

.auth-form .input-label {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    text-align: center;
    height: 36px;
}

.auth-form.input-box {
    width: 344px;
}

.auth-form .input-el {
    min-height: 44px;
}

.auth-block .input-el {
    width: 100%;
}

.auth-block .input-label {
    float: left;
    width: 40%;
}

.auth-block .input-body {
    float: left;
    width: 60%;
}

.auth-layer .input-vid-error {
    display: none;
}

.input-box-template {
    display: none;
}

.input-block .input-box-template {
    display: block;
}

.visitor-count {
    position: sticky;
    width: 88px;
    height: 44px;
    left: 40px;
    top: 0;
    background: #EC827B;
    border-radius: 20px;
    font-family: 'Barlow', serif;
    font-style: normal;
    font-size: 30px;
    line-height: 44px;
    text-transform: uppercase;
    color: #000000;
    text-align: center;
    z-index: 10;
}

.form-mode-validate .input-body, .form-mode-validate .btn-radio-group {
    display: none;
}

.form-mode-validate .input-body-r {
    display: block;
}

.input-body-r {
    display: none;
}

.input-body-r p {
    background-color: rgba(0, 0, 0, 0);
    border: 0;
    color: #fff;
    font-size: 30px;
}

.input-error p, p.input-error {
    background-color: rgba(0, 0, 0, 0);
    border: 0;
    color: rgba(255, 0, 0, 1);
    font-size: 16px;
}

.btn-group .input-error p, .btn-group p.input-error{
    text-align: center;
}

.input-form {
    margin-top: 8px;
}

.input-form:nth-child(2) {
    margin-top: -20px;
}

.confirm-block {
    display: none;
}

.input-block {
    display: none;
}

.step2 .input-block {
    display: block;
}

.input-error > p {
    display: none;
}

input:-webkit-autofill {
    background-color: #fff !important;
    color: #000 !important;
    -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}

/* Chrome, Edge, Safari */
input:-webkit-autofill,
input:-webkit-autofill:focus,
input:-webkit-autofill:hover,
input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0px 1000px transparent inset !important; /* transparent overlay */
    -webkit-text-fill-color: inherit !important;  /* keep normal text color */
    background-color: transparent !important;      /* for good measure */
    caret-color: inherit;                          /* caret keeps same color */
    transition: background-color 9999s ease-in-out 0s; /* prevents yellow flash */
}

.info-block {
    position: absolute;
    top: 190px;
    left: 622px;
    width: 568px;
    height: 524px;
}

.info-box {
    float: left;
    margin-right: 28px;
    margin-bottom: 28px;
    width: 256px;
    height: 234px;
    position: relative;      /* so children can be positioned inside */
    text-align: center;      /* center contents horizontally */
    background: linear-gradient(180deg, rgba(25, 26, 36, 0.4) 0%, rgba(25, 26, 36, 0) 100%);
    backdrop-filter: blur(10px);
    border-radius: 13.5px;
}

.info-box .img-box {
    height: 148px;
    display: flex;
    flex-direction: column;
    align-items: center;        /* center horizontally */
    justify-content: center;    /* center vertically */
}

.info-box img {
    display: block;
    margin: 0 auto;          /* center image horizontally */
}

.info-box p {
    position: absolute;
    top: 148px;              /* lock text 148px from the top */
    text-align: center;
    left: 0;
    right: 0;
    margin: 0 auto;
    font-size: 16px;
    font-family: 'BarlowLight', serif;
    color: #fff;
}

.step4 .input-block, .step4 .btn-group {
    display: none !important;
}

.auth-layer, .success-layer, .error-layer, .overwrite-layer {
    display: none;
}

.step2 .success-layer {
    display: block;
}

.generic .success-layer {
    display: none;
}

.generic .auth-layer {
    display: block;
}

.unique .auth-layer {
    display: none;
}

.unique .success-layer {
    display: block;
}

.out {
    display: none;
}

.icon-out {
    width: 40px;
    height: 40px;
    position: absolute;
    bottom: 260px;
    left: 262px;
}

.auth-lastname-error {
    margin-left: 32px;
}

.input-90 {
    width: 84%;
}

.input-10 {
    width: 10%;
}

.mode-group .input-box {
    height: 86px;
}

.mode-group .input-form:nth-child(2) {
    margin-top: 8px;
}

.group-index {
    position: absolute;
    width: 148px;
    height: 44px;
    left: 8px;
    top: 0;
    font-family: 'Barlow', serif;
    font-style: normal;
    font-size: 30px;
    line-height: 44px;
    text-transform: uppercase;
    color: #EC827B;
    text-align: center;
    z-index: 10;
}

.btn-del-group {
    display: none;
    font-family: 'Barlow', serif;
    font-style: normal;
    font-size: 30px;
    color: #fff;
}

.input-10 .input-body {
    border-bottom: unset;
}

.group-template .btn-edit {
    top: 46px;
}

.digit-container {
    display: flex;
    justify-content: center;
    gap: 10px;
    border-bottom: 1px solid #2B2B30;
    width: 100%;
    margin: 50px auto;
}

.digit {
    font-family: BarlowLight, sans-serif;
    font-size: 60px;
    color: white;
    text-align: center;
}

.toggle {
    display: flex;
    justify-content: center;
    margin-top: 20px;
}

.mode-keypad {
    position: absolute;
    top: 0;
    left: 786px;
    z-index: 9999;
    width: 516px;
    height: 768px;
    background: #000;
    padding: 128px 32px;
}

.mode-keypad p {
    font-family: Barlow, sans-serif;
    font-size: 20px;
    color: white;
    text-align: center;
    width: 100%;
}

.keypad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    width: 100%;
}

.key {
    background: #2B2B30;
    color: white;
    font-size: 34px;
    font-family: Barlow, sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 64px;
    border-radius: 8px;
    cursor: pointer;
    user-select: none;
}

.key:active {
    background: #44444a;
}

.cover {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
}

.cover .left-top-border-video {
    left: 0;
    top: 0;
    width: 240px;
}

.cover .right-bottom-border-video {
    width: 240px;
}

.cover .master-logo {
    top: 135px;
    width: 100%;
    height: fit-content;
}

.cover .master-logo > div {
    position: relative;
    height: fit-content;
}

.cover .master-logo video {
    position: relative;
    width: 100%;
    height: auto;
}

.cover .master-head {
    width: 100%;
    position: relative;
    top: unset;
    left: unset;
    right: unset;
}

.cover p {
    color: #fff;
    font-size: 20px;
    margin-bottom: 20px;
}

.input-vid {
    width: 100%;
}

.overwrite .success-layer {
    display: none;
}

.overwrite .overwrite-layer {
    display: block;
}

.overwrite .overwrite-block .input-error {
    display: none;
}

.overwrite .overwrite-layer .master-text2 {
    opacity: 1;
}


.form-error {
    display: none;
}

.input-error .form-error p {
    color: rgba(255, 0, 0);
    font-size: 20px;
}

.hint-block {
    position: absolute;
    top: 464px;
    font-size: 20px;
    text-align: center;
    color: #fff;
    left: 0;
    right: 0;
    margin: 0 auto;
    max-width: 1024px;
}

.btn-close {
    position: absolute;
    bottom: 20px;
    margin: 0 auto;
    left: 0;
    right: 0;
    width: fit-content;
}

.master-quantity-error {
    display: none;
    font-size: 20px;
    color: red;
    font-family: 'Barlow', serif;
}


.scroll-down {
    opacity: 0;
    position: fixed;
    top: 500px;
    right: 15%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    border: 2px solid white;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    text-decoration: none;
    animation: float 2s ease-in-out infinite; /* Floating animation */
    z-index: 99;
}

.scroll-down::before {
    content: "";
    border: solid white;
    border-width: 0 3px 3px 0;
    display: inline-block;
    padding: 8px;
    transform: rotate(45deg);
}

.scroll-up.active, .scroll-down.active {
    opacity: 1;
}

.scroll-up {
    opacity: 0;
    position: fixed;
    top: 500px;
    right: 20%;
    transform: translateX(-50%);
    width: 40px;
    height: 40px;
    border: 2px solid white;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    text-decoration: none;
    animation: float 2s ease-in-out infinite; /* Floating animation */
    z-index: 99;
}

.scroll-up::before {
    content: "";
    border: solid white;
    border-width: 0 3px 3px 0;
    display: inline-block;
    padding: 8px;
    transform: rotate(225deg);
}

@keyframes float {
    0%, 100% {
        transform: translateX(-50%) translateY(0);
    }
    50% {
        transform: translateX(-50%) translateY(8px);
    }
}

body.mobile-mode > .layer {
    overflow-y: auto;
}

body.portrait {
    overflow: hidden !important;
}

.mobile-mode video {
    display: none !important;
}

.mobile-mode .mobile-on {
    display: block;
}

.mobile-on {
    display: none;
}

.mobile-mode video {
    display: none;
}

.wechat {
    display: none;
}

.in-wechat > div, .in-wechat > video, .in-wechat > img {
    /*display: none;*/
}

.in-wechat .wechat {
    display: block;
}

.in-wechat .wechat-off {
    /*display: none !important;*/
}

img.left-top-border-video, img.right-bottom-border-video {
    width: 1366px;
    height: 768px;
}

.app {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    overflow-x: hidden;
    display: none;
}

.app.appready {
    display: block;
}

@media (orientation: portrait) {
    html, body {
        position: fixed;
        margin: 0;
        padding: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
        overscroll-behavior: none;
    }

    .cover {
        display: block !important;
        z-index: 9999;
    }
}
