@charset "utf-8";

:root {
  --bounce: cubic-bezier(.1, 1.4, .75, 1);
  --zoom-bounce: cubic-bezier(0.3, -3, 0.5, 1);
  --easing: cubic-bezier(.1, .7, .48, 1);
  --rgb-theme: 0, 51, 90;
  --rgb-nav: 0, 24, 42;
  --rgb-white: 255, 255, 255;
  --rgb-black: 0, 0, 0;
  --card-cutter: .5rem;
  --hex-text: #181818;
}

/* layout */
body.resizing * {
  transition: none !important;
  animation-duration: 0s !important;
  animation-delay: 0s !important;
  animation-iteration-count: 1 !important;
  animation-fill-mode: forwards !important;
}

body.nav-open {
  overflow: hidden;
  touch-action: none;
}

.header {
  transition: all .5s ease-out
}

.header.hide {
  background-color: rgba(var(--rgb-white), .5);
  transform: translateY(-300%);
}

.evt-wrapper {
  position: relative;
  width: 100%;
  overflow-x: hidden;
  height: auto;
}

.evt-wrapper img {
  display: block
}

.evt-container,
.evt-section {
  position: relative;
  width: 100%;
  height: auto;
}


.sect-bg {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: auto;
  -webkit-mask-image: none;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center top;
  -webkit-mask-size: cover;
  mask-image: none;
  mask-repeat: no-repeat;
  mask-position: center top;
  mask-size: cover;
}

.sect-bg .masked-img {
  display: block;
  width: 100%;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center
}

.effect-layer {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.effect-layer canvas {
  display: block;
  width: 100%;
  height: 100%;
}

.evt-section>.sect-cont {
  position: absolute;
  left: 0;
  top: var(--header-height);
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.evt-section>.sect-cont::before,
.evt-section>.sect-cont::after {
  content: "";
  display: block;
}

.evt-section>.sect-cont>* {
  margin: 0 auto;
  flex: none
}

.bg-cont {
  position: absolute;
  left: 0;
  top: var(--header-height);
  width: 100%;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.bg-cont::before,
.bg-cont::after {
  content: "";
  display: block;
}

.bg-cont-box {
  display: block;
  position: relative;
  width: 100%;
  flex: none
}

.evt-navigation {
  user-select: none;
  z-index: 10;
}

.evt-navigation .icon {
  opacity: .5;
  transition: opacity .25s var(--easing)
}

.evt-navigation a:hover .icon,
.evt-navigation button:hover .icon,
.evt-navigation .on .icon {
  opacity: 1
}


.evt-menu>li>a {
  position: relative;
  display: block;
  width: 100%;
}

.evt-menu>li .icon {
  display: block;
  position: relative;
  z-index: 1;
}

.evt-navigation .btn-sound .icon::before,
.evt-menu>li .icon::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  opacity: 0;
  transform: scale(.75);
  background: url(../img/nav-on.png) no-repeat center / contain;
  transition: all .25s var(--easing)
}

.evt-navigation .btn-sound .icon::before {
  z-index: 0
}

.evt-menu>li a.on {
  cursor: default;
  pointer-events: none;
}

.evt-navigation .btn-sound.on .icon::before,
.evt-menu>li a.on .icon::before {
  opacity: 1;
  transform: scale(1);
}

.evt-menu>li .name {
  position: absolute;
  height: auto;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
  padding: 0;
  opacity: 0;
  transition: all .15s var(--easing)
}

.evt-menu>li .name::before,
.evt-menu>li .name::after {
  content: "";
  flex: none;
  display: block;
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  width: 50%;
  background-image: url(../img/nav-name.svg);
  background-repeat: no-repeat;
  background-size: auto calc(100% + .01rem);
}

.evt-menu>li .name::before {
  background-position: left center;
  left: 0;
}

.evt-menu>li .name::after {
  background-position: right center;
  right: 0;
}

.evt-menu>li .name>em {
  display: block;
  flex: none;
  font: inherit;
  text-align: center;
  width: 100%;
  word-wrap: break-word;
  word-break: keep-all;
  font-weight: 500;
  color: rgb(var(--rgb-white));
  letter-spacing: -.025em;
}


.evt-menu>li a.on .name {
  opacity: 1;
}

.evt-navigation .btn-sound {
  width: 100%;
  background: url(../img/nav-off.png) no-repeat center / contain;
  box-sizing: border-box;
}

.evt-navigation .btn-sound .icon {
  position: relative;
  width: 100%;
  display: block;
}


:lang(zh-CN) .evt-menu>li .name,
:lang(zh-TW) .evt-menu>li .name,
:lang(ja) .evt-menu>li .name {
  font-weight: 700
}


.ic-sound-bars {
  position: absolute;
  top: 50%;
  transform: translateY(-50%) translateX(-50%);
  left: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ic-sound-bars .bar {
  display: block;
  flex: none;
  background: rgb(var(--rgb-white));
  transition: transform .25s ease-out;
}

.btn-sound.on .ic-sound-bars .bar {
  animation: sound-move .8s infinite ease-out;
  transition: none;
}

.btn-sound.on .ic-sound-bars .bar:nth-child(1) {
  animation-delay: 0s;
}

.btn-sound.on .ic-sound-bars .bar:nth-child(2) {
  animation-delay: 0.1s;
}

.btn-sound.on .ic-sound-bars .bar:nth-child(3) {
  animation-delay: 0.2s;
}

.btn-sound.on .ic-sound-bars .bar:nth-child(4) {
  animation-delay: 0.3s;
}

.btn-sound.on .ic-sound-bars .bar:nth-child(5) {
  animation-delay: 0.4s;
}


.common-btn {
  display: block;
  margin: 0 auto;
  position: relative;
  text-align: center;
  pointer-events: fill;
  width: 3.22rem;
  height: .82rem;
}

.common-btn>span {
  display: block;
  color: rgb(var(--rgb-white));
  z-index: 1;
  font-weight: 600;
  font-size: .26rem;
  line-height: .32rem;
  letter-spacing: -.025em;
  text-shadow: 0 0 .04rem #00000040;
}

.common-btn>span {
  position: absolute;
  left: 0;
  width: 100%;
  top: 50%;
  padding-bottom: .04rem;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}

.common-btn::before,
.common-btn::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 3.22rem;
  height: .82rem;
  pointer-events: none;
  background-repeat: no-repeat;
  background-position-x: center;
  background-size: 100% auto;
  background-image: url(../img/btn.png);
}

.common-btn::before {
  opacity: 1;
  background-position-y: top
}

.common-btn::after {
  opacity: 0;
  background-position-y: bottom
}

.minigame-words {
  width: 100%;
}

.typo-words {
  display: inline-block;
  position: relative;
  width: max-content;
  max-width: 90%;
  padding: .15rem .3rem;
}

.typo-words .bg {
  display: block;
  background: rgba(var(--rgb-theme), .75);
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  border-radius: .72rem
}

.typo-words[data-tail="top"] .bg::before {
  bottom: 100%;
  transform: translateX(-50%) translateY(.01rem);
  clip-path: polygon(calc(50% - .02rem) .02rem, calc(50% + .02rem) .02rem, 100% 100%, 0 100%);
}

.typo-words[data-tail="bottom"] .bg::before {
  top: 100%;
  transform: translateX(-50%) translateY(-.01rem);
  clip-path: polygon(0 0, 100% 0, calc(50% + .02rem) calc(100% - .02rem), calc(50% - .02rem) calc(100% - .02rem));
}

.typo-words .text {
  display: block;
  position: relative;
  font-weight: 500;
  letter-spacing: -.025em;
  word-wrap: break-word;
  word-break: keep-all;
}

.typo-words .text::before {
  content: attr(data-text);
  display: inline-block;
  font: inherit;
  color: transparent;
  opacity: 0;
}

.typo-words .text>i {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: auto;
  text-align: center;
  word-wrap: break-word;
  word-break: keep-all;
  font: inherit;
  color: #fff
}

.user-select {
  display: flex;
  align-items: flex-start;
  width: 100%
}

.radio-btn {
  display: block;
  flex: none;
  font-size: 0;
  line-height: 0;
  transform: translateY(0);
  position: relative
}

.radio-btn>label {
  position: relative;
  display: inline-block;
  transform: translateY(0);
  color: #5B3B3B;
  font-weight: 500;
  letter-spacing: -.05em;
  vertical-align: top;
  cursor: pointer;
}

.radio-btn>label::before,
.radio-btn>label::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  border-radius: 100%;
  transform: translate3d(0, -50%, 0);
}

.radio-btn>label::before {
  background: url(../img/radio-off.png) no-repeat center / contain;
}

.radio-btn>label::after {
  background: url(../img/radio-on.png) no-repeat center / contain;
  display: none;
}

.radio-btn>input {
  position: absolute;
  right: 100%;
  bottom: 100%;
  font-size: 1px;
  line-height: 1px;
  visibility: hidden;
  opacity: 0
}

.radio-btn>input:checked+label::after {
  display: block;
}

input[type="checkbox"]+label {
  display: inline;
  cursor: pointer;
  color: #5B3B3B;
  font-weight: 500;
  letter-spacing: -.05em;
}

input[type="checkbox"]+label>span {
  vertical-align: middle;
}

input[type="checkbox"]+label .icon {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  background: url(../img/checkbox-off.png) no-repeat center / contain;
}

input[type="checkbox"]:checked+label .icon {
  background-image: url(../img/checkbox-on.png)
}

.no-ui {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: textfield;
  background: transparent;
  border: none;
  outline: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  width: 100%;
  caret-color: auto;
}

.no-ui::-webkit-outer-spin-button,
.no-ui::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.no-ui[type="number"] {
  -moz-appearance: textfield;
  appearance: textfield;
}

@media (min-width: 1081px) {
  .pc-only {
    display: block !important
  }

  .mo-only {
    display: none !important
  }

  .evt-section>.sect-cont {
    bottom: 0;
  }

  .evt-navigation {
    position: fixed;
    right: .6rem;
    top: 50%;
    transform: translateY(-50%);
  }

  .evt-navigation .evt-menu,
  .evt-navigation .btn-sound {
    width: .62rem;
    height: auto;
    position: relative;
  }

  .evt-navigation .evt-menu::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: .18rem;
    bottom: .18rem;
    width: 100%;
    z-index: -1;
    background: rgb(var(--rgb-nav), .6)
  }

  .evt-navigation .evt-menu>li:first-child::before,
  .evt-navigation .evt-menu>li:last-child::before {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    left: 0;
    height: .18rem;
    z-index: -1;
    background: url(../img/nav-off.png) no-repeat center / 100% auto;
  }

  .evt-navigation .evt-menu>li:first-child::before {
    top: 0;
    background-position-y: 0
  }

  .evt-navigation .evt-menu>li:last-child::before {
    bottom: 0;
    background-position-y: 100%
  }

  .evt-menu>li {
    width: 100%;
    box-sizing: border-box;
  }

  .evt-navigation .btn-sound .icon,
  .evt-menu .icon {
    padding: .15rem .11rem .16rem
  }


  .evt-menu>li .name {
    right: 100%;
    top: 50%;
    transform: translate3d(0, -50%, 0) rotateX(90deg);
    margin-right: .06rem;
    padding: .03rem 0 .05rem;
    min-height: .34rem;
  }

  .evt-menu>li .name em {
    width: 1.14rem;
    font-size: .18rem;
    line-height: .21rem;
    min-height: .24rem;
    box-sizing: border-box;
    padding-top: .02rem
  }

  .evt-menu>li .name::before,
  .evt-menu>li .name::after {
    opacity: 0.64
  }

  .evt-menu>li a:hover .name {
    opacity: 1;
  }

  .evt-menu>li a.on .name,
  .evt-menu>li a:hover .name {
    transform: translate3d(0, -50%, 0) rotateX(0deg);
  }

  .evt-navigation .btn-sound {
    margin-top: .15rem
  }

  .evt-navigation .btn-sound .icon {
    width: .4rem;
    height: .4rem
  }

  .ic-sound-bars {
    width: .4rem;
    height: .4rem;
    gap: .03rem;
  }

  .ic-sound-bars .bar {
    width: .03rem;
    border-radius: .015rem;
  }

  .ic-sound-bars .bar:nth-child(1) {
    height: .0825rem;
  }

  .ic-sound-bars .bar:nth-child(2) {
    height: .165rem;
  }

  .ic-sound-bars .bar:nth-child(3) {
    height: .11rem;
  }

  .ic-sound-bars .bar:nth-child(4) {
    height: .22rem;
  }

  .ic-sound-bars .bar:nth-child(5) {
    height: .11rem;
  }

  .evt-section .masked-img {
    min-height: 100vh;
  }

  .common-btn::before,
  .common-btn::after {
    transition: opacity .05s linear
  }

  .common-btn::before {
    transition-delay: 0s;
  }

  .common-btn::after {
    transition-delay: .05s;
  }

  .common-btn:hover::after {
    transition-delay: 0s;
    opacity: 1
  }

  .common-btn:hover::before {
    transition-delay: .05s;
    opacity: 0
  }

  .radio-btn>label::before,
  .radio-btn>label::after {
    width: .34rem;
    height: .34rem;
  }

  .radio-btn>label {
    padding-left: .42rem;
    line-height: .26rem;
    font-size: .22rem;
    padding-top: .04rem;
    padding-bottom: .04rem
  }

  input[type="checkbox"]+label .icon {
    width: .22rem;
    height: .22rem;
    margin-right: .08rem;
  }

}

@media (max-width: 1080px) {
  .pc-only {
    display: none !important
  }

  .mo-only {
    display: block !important
  }

  .evt-section .bg-cont,
  .evt-section>.sect-cont {
    bottom: var(--header-height)
  }

  .evt-navigation {
    position: fixed;
    width: 100%;
    height: auto;
    left: 0;
    bottom: 0;
  }

  .evt-navigation.sticky {
    position: absolute;
  }

  .evt-navigation .evt-menu {
    width: 6.8rem;
    border-radius: .5rem .5rem 0 0;
    margin: 0 auto;
    height: .94rem;
    padding: 0 .42rem;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
    background: rgba(var(--rgb-nav), .5);
  }

  .evt-navigation .evt-menu,
  .evt-navigation .btn-sound {
    transform: translate3d(0, 300%, 0);
  }

  .init .evt-navigation .evt-menu,
  .init .evt-navigation .btn-sound {
    transform: translate3d(0, 0, 0);
    transition: transform .35s 3s var(--easing);
  }

  .evt-menu>li {
    width: .83rem;
    flex: none
  }

  .evt-menu>li .icon {
    padding: .22rem .17rem .22rem .16rem
  }

  .evt-menu>li .name {
    bottom: min(.94rem, 94px);
    left: 50%;
    transform: translate3d(-50%, 50%, 0);
    width: auto;
    padding: .06rem 0;
    min-height: .4rem;
  }

  .evt-menu>li .name::before,
  .evt-menu>li .name::after {
    opacity: 0.8
  }

  .evt-menu>li .name em {
    width: 1.28rem;
    font-size: .2rem;
    line-height: .22rem;
  }

  .evt-menu>li a.on .name {
    transform: translate3d(-50%, 0, 0);
  }

  .evt-navigation .btn-sound {
    position: absolute;
    width: .83rem;
    bottom: 100%;
    left: 50%;
    margin-left: 2.55rem;
    margin-bottom: .3rem
  }

  .evt-navigation .btn-sound .icon {
    width: .83rem;
    height: .94rem
  }

  .ic-sound-bars {
    width: .5rem;
    height: .5rem;
    gap: .035rem;
  }

  .ic-sound-bars .bar {
    width: .035rem;
    border-radius: .018rem;
  }

  .ic-sound-bars .bar:nth-child(1) {
    height: .103rem;
  }

  .ic-sound-bars .bar:nth-child(2) {
    height: .206rem;
  }

  .ic-sound-bars .bar:nth-child(3) {
    height: .137rem;
  }

  .ic-sound-bars .bar:nth-child(4) {
    height: .275rem;
  }

  .ic-sound-bars .bar:nth-child(5) {
    height: .137rem;
  }

  .sect-bg {
    background-size: auto 100%
  }

  .radio-btn>label::before,
  .radio-btn>label::after {
    width: .34rem;
    height: .34rem;
  }

  .radio-btn>label {
    padding-left: .42rem;
    line-height: .34rem;
    font-size: .22rem;
  }

  input[type="checkbox"]+label .icon {
    width: .3rem;
    height: .3rem;
    margin-right: .08rem;
  }

  input[type="checkbox"]+label .icon::after {
    width: .15rem;
    height: .15rem
  }
}



/* main */
#mainBgEffect {
  mix-blend-mode: plus-lighter;
}

.btn-float {
  display: block;
  cursor: pointer;
}

.btn-float .object {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
}

.btn-float .object.default {
  opacity: 1
}

.btn-float .object.hover {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  pointer-events: none
}

#main.activate .btn-float {
  opacity: 1;
  pointer-events: auto;
  animation: floating-ani 2s .55s ease-in-out infinite;
}

#main .character {
  position: absolute;
}

#main .main-words {
  position: absolute;
  z-index: 1;
}

.register-box-wrap {
  position: relative;
  flex: none;
  width: 100%;
  margin: 0 auto
}

#main .sect-title {
  display: block;
  left: 0;
  width: 100%;
}

#main .sect-title>span {
  position: absolute;
  left: 50%;
  transform: translate3d(-50%, 0, 0);
}

#main .sect-title .top {
  top: 0;
  z-index: 2;
}

#main .sect-title .btm {
  bottom: 0;
  z-index: 1;
}

#main .register-box {
  display: block;
  margin: 0 auto;
  position: relative;
}

#main .register-box::before {
  z-index: -1;
  content: "";
  display: block;
  position: absolute;
  background: url(../img/main-envelope-opened.png) no-repeat center bottom / contain;
  transform-origin: center bottom;
}

#main.expired .register-box::before {
  display: none;
}

#main .register-box>img {
  z-index: 1
}

#main .register-box.trans * {
  cursor: default;
  pointer-events: none !important;
  user-select: none !important;
}

.register-container {
  position: absolute;
}

.register-container>div {
  display: block;
  position: relative;
  box-sizing: border-box
}

.register-container .register-name {
  display: block;
  width: 100%;
  text-align: center;
  font-weight: 700;
  letter-spacing: -.025em;
  color: #5B3B3B
}

.register-container .register-name>span {
  display: inline-block;
  position: relative;
  font: inherit;
  letter-spacing: -.025em;
}

.register-container .register-name>span::before,
.register-container .register-name>span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
  width: .48rem;
  background: url(../img/main-title-deco.png) no-repeat center / contain
}

.register-container .register-name>span::before {
  left: 0
}

.register-container .register-name>span::after {
  right: 0;
  transform: rotateY(180deg);
}

.register-container .period {
  display: block;
  margin: 0 auto;
  width: fit-content;
  text-align: center;
  background: #E8E2DF;
  color: #5B3B3B;
  font-weight: 500;
  letter-spacing: -.025em;
}

.market-buttons {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.market-buttons>button {
  display: block;
  flex: none;
}


.user-field {
  position: relative;
  width: 100%;
}

.user-agree {
  width: 100%
}

.user-agree li {
  display: block;
  overflow: hidden;
  position: relative;
  color: #5B3B3B;
  text-align: left;
}

.user-agree li input {
  outline: none
}

.user-agree li label {
  font-weight: 500;
  letter-spacing: -.025em;
}

.user-agree .btn-docs {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  cursor: pointer;
}

.user-agree .btn-docs::before,
.user-agree .btn-docs::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%, -50%, 0);
  background: #d1a6a5
}

.user-agree .btn-docs::after {
  transform: translate3d(-50%, -50%, 0) rotate(90deg);
}

.input-field {
  display: block;
  width: 100%;
  height: .54rem;
  position: relative;
  box-sizing: border-box;
  border-radius: .06rem;
  background: rgb(var(--rgb-white));
  border: max(.01rem, 1px) solid #C2B299
}

.input-field input {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  position: absolute;
  text-align: left;
  padding: .15rem .25rem .13rem;
  font-size: .22rem;
  font-weight: 500;
  letter-spacing: -.06em;
  line-height: .26rem;
}

.input-field input+label {
  position: absolute;
  left: .25rem;
  top: .15rem;
  font-size: .22rem;
  font-weight: 500;
  line-height: .26rem;
  letter-spacing: -.06em;
  pointer-events: none;
  color: #A97654
}

.input-field input:focus+label,
.input-field input:valid+label,
.input-field input.has-value+label {
  display: none
}

.register-box-wrap .common-btn {
  position: relative;
}

.register-box-wrap .common-btn::before,
.register-box-wrap .common-btn::after {
  height: 100%;
  width: 100%;
  background-image: url(../img/btn-register.png)
}

.register-box-wrap .notice {
  width: 100%
}

.register-box-wrap .notice>p::before {
  content: "";
  font: inherit;
  position: absolute;
  left: 0;
  height: .09rem;
  width: .09rem;
  background: url(../img/bu-notice.svg) no-repeat center / contain;
}


.register-box-wrap .notice>p {
  color: #5B3B3B;
  font-weight: 500;
  letter-spacing: -.05em;
  display: block;
  position: relative;
}


#main.expired .expired-box .stamp {
  position: absolute;
}

#main.expired .expired-box {
  cursor: pointer;
  opacity: 0;
  transition: opacity .15s, transform .45s var(--easing)
}

#main.expired.activate .expired-box {
  transform: translate3d(0, 0, 0) rotate(0deg);
  opacity: 1;
  transform-origin: right bottom;
}

#main.expired .expired-box .stamp {
  transform: scale(1.3);
  opacity: 0;
  transition: opacity .15s, transform .45s var(--bounce)
}

#main.expired.activate .expired-box .stamp {
  transform: scale(1);
  opacity: 1;
  transition-delay: 1.95s, 1.85s;
}

#main.expired.activate .expired-box.play {
  animation: envelope-play-ani 1s 0s ease-in-out forwards;
}

#main.expired.activate .expired-box:not(.play) {
  animation: envelope-ani 10s 0s ease-in-out infinite;
}

@keyframes envelope-ani {

  0%,
  5%,
  100% {
    transform: rotate(0deg)
  }

  7%,
  11.5% {
    transform: rotate(-4deg)
  }

  9.5%,
  14% {
    transform: rotate(0deg)
  }
}

@keyframes envelope-play-ani {

  0%,
  20%,
  60%,
  100% {
    transform: rotate(0deg)
  }

  38%,
  78% {
    transform: rotate(-4deg)
  }
}


@media (min-width: 1081px) {

  #main .sect-cont::before {
    flex: .7
  }

  #main .sect-cont::after {
    flex: 1.3
  }

  #main .sect-cont {
    padding-top: 3.06rem
  }

  #main .masked-img {
    height: 17rem;
    background-image: url(../img/bg-main-pc.jpg)
  }

  #mainBgEffect canvas {
    -webkit-mask-image: linear-gradient(to bottom,
        rgba(0, 0, 0, 1) 50%,
        rgba(0, 0, 0, 0) 80%);
    mask-image: linear-gradient(to bottom,
        rgba(0, 0, 0, 1) 50%,
        rgba(0, 0, 0, 0) 80%);
  }

  #main .character {
    width: 7.53rem;
    right: 50%;
    margin-right: .75rem;
    top: 55.4375%;
  }

  #main .btn-float {
    position: fixed;
    right: .4rem;
    bottom: .4rem;
    width: 1.52rem;
    z-index: 10;
  }

  #main .btn-float .object.hover {
    transition: opacity .2s var(--easing)
  }

  #main .btn-float:hover .object.default {
    opacity: 0;
    transition-delay: .2s;
    transition-duration: 0s;
  }

  #main .btn-float:hover .object.hover {
    opacity: 1
  }

  #main .btn-float,
  #main.activate.out .btn-float {
    opacity: 0;
    pointer-events: none
  }


  #main .sect-title {
    top: 45vh;
    opacity: 0;
    transform: translate3d(0, -50%, 0) scale(1.5);
    position: absolute;
  }

  #main .sect-title .top {
    width: 1.2rem;
  }

  #main .sect-title .btm {
    width: 4.81rem;
  }

  #main .main-words {
    left: 50%;
    margin-left: -5.91rem;
    top: 50.8126%
  }

  .typo-words .text {
    font-size: .18rem;
    line-height: .24rem
  }

  #main .market-buttons {
    gap: .1rem
  }

  #main .market-buttons>button {
    width: 1.76rem
  }

  .register-box-wrap {
    width: 12.8rem;
    height: 10.28rem;
    display: flex;
    align-items: start;
    justify-content: end;
  }

  .register-box-wrap::before {
    content: "";
    display: block;
    flex: 1
  }

  .register-box {
    flex: none;
    position: relative;
    width: 6.7rem;
    margin-left: -.1rem;
  }

  .register-container {
    left: .2rem;
    top: .44rem;
    right: .6rem;
    bottom: .94rem
  }

  .register-container .register-name>span {
    padding: 0 .58rem
  }

  .register-container .period {
    margin-top: .08rem;
    margin-bottom: .48rem;
    font-size: .16rem;
    line-height: .2rem;
    padding: .08rem .2rem .06rem;
    border-radius: .16rem
  }

  .register-container .fieldset {
    width: 5rem;
    margin: 0 auto
  }

  .user-select {
    gap: .15rem;
    margin: 0 0
  }

  .input-field {
    margin: .08rem 0
  }

  .user-agree {
    padding: .08rem 0
  }

  .user-agree li {
    padding-left: .3rem;
    text-indent: -.3rem;
  }

  .user-agree li+li {
    margin-top: .1rem
  }

  .user-agree li label span {
    font-size: .15rem;
    line-height: .18rem;
    letter-spacing: -.05em
  }

  .user-agree .btn-docs {
    width: .22rem;
    height: .22rem;
    margin-left: .02rem;
  }

  .register-box-wrap .common-btn {
    width: 3.88rem;
    height: .8rem;
    margin-top: .12rem;
    box-sizing: border-box;
    padding-bottom: .04rem;
    margin-bottom: .12rem
  }

  .register-box-wrap .common-btn>span {
    font-size: .28rem;
    line-height: .34rem;
  }

  .user-agree .btn-docs::before,
  .user-agree .btn-docs::after {
    width: .15rem;
    height: .04rem
  }

  .register-box-wrap .common-btn {
    width: 3.88rem;
  }

  .register-box-wrap .notice>p {
    font-size: .15rem;
    line-height: .18rem;
    padding-left: .18rem;
  }

  .register-box-wrap .notice>p+p {
    margin-top: .1rem
  }

  .register-box-wrap .notice>p::before {
    top: 50%;
    margin-top: -.045rem;
  }

  #main.expired .character {
    width: 6.48rem;
    margin-right: 1.84rem;
    top: 58.295%
  }

  #main.expired .typo-words {
    padding-top: .31rem;
    padding-bottom: .31rem
  }

  #main.expired .expired-box {
    width: 6.98rem;
    margin-top: .96rem;
    flex: none;
    position: relative;
    left: .24rem
  }

  #main.expired .expired-box .stamp {
    right: .31rem;
    top: 2.1rem;
    width: 1.75rem
  }

  /* Transition */
  #main .btn-float {
    transform: translate3d(15%, 0, 0);
    transition: all .55s var(--bounce);
  }

  #main.activate .btn-float {
    transform: translate3d(0, 0, 0);
    transition-delay: .15s
  }

  #main.activate.out .btn-float {
    opacity: 0;
    transform: translateX(15%);
    transition: all .25s var(--easing);
  }

  #main .main-words {
    transform: translate3d(-50%, -40%, 0);
    opacity: 0;
    transition: all .35s var(--easing)
  }

  #main .sect-title {
    opacity: 0;
    height: 1.44rem;
  }

  #main.activate .sect-title {
    transform: translate3d(0, -50%, 0) scale(1);
    top: 2.18rem;
    transition: all 1s 1s var(--bounce);
    animation: main-title-ani .65s .15s ease-out forwards;
  }

  @keyframes main-title-ani {
    0% {
      opacity: 0;
      height: 1.44rem;
    }

    30% {
      opacity: 0;
    }

    100% {
      opacity: 1;
      height: 2.88rem;
    }
  }

  #main .character {
    transition: all .45s var(--easing)
  }


  #main .register-box::before {
    width: 7.1rem;
    height: 6.92rem;
    right: -.6rem;
    transform: rotate(-5deg) translate3d(0, -5%, 0);
    opacity: 0;
    transition: opacity .3s, transform .45s var(--easing)
  }

  #main .register-box,
  #main .market-buttons {
    transform: translateY(.2rem);
    opacity: 0;
    transition: all .45s var(--easing)
  }

  #main .character {
    opacity: 0;
    transform: translateX(-7%) translateY(-50%)
  }

  #main.activate .character {
    transform: translateX(0) translateY(-50%);
    opacity: 1;
    transition-delay: 1.45s;
  }

  #main.activate .main-words {
    transform: translate3d(-50%, -50%, 0);
    opacity: 1;
    transition-delay: 1.6s
  }

  #main.activate .register-box::before {
    transform: rotate(0deg) translate3d(0, 0, 0);
    opacity: 1;
    transition-delay: 1.8s, 1.8s
  }

  #main.activate .register-box,
  #main.activate .market-buttons {
    transform: translateY(0);
    opacity: 1;
    transition-delay: 1.45s;
  }

  #main.expired .expired-box {
    transform: translate3d(0, .4rem, 0) rotate(-4deg);
  }

  #main.expired.activate .expired-box {
    transition-delay: 1.45s, 1.5s;
  }

  #main.expired.activate .expired-box:not(.play) {
    animation-delay: 3.5s;
  }


  .lake-effect-layer {
    position: absolute;
    width: 100%;
    height: max(50%, 50vh);
    bottom: 0;
    -webkit-mask-image: radial-gradient(circle at 50% 200%, rgba(0, 0, 0, 1), rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 90%);
    mask-image: radial-gradient(circle at 50% 200%, rgba(0, 0, 0, 1), rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 90%);
    pointer-events: none;
  }

  .lake-sparkles {
    position: absolute;
    left: 50%;
    width: 10rem;
    height: 5rem;
    transform: translate3d(-50%, 0, 0);
    bottom: 0
  }

  .lake-sparkles .sparkle {
    position: absolute;
    opacity: 0;
    transform: translate3d(-50%, -50%, 0) scale(0);
    transition: transform .15s var(--easing);
  }

  .sparkle::before {
    content: "";
    display: block;
    padding-top: 100%;
    background: url(../img/main-sparkle.png) no-repeat center / contain;
    animation-name: twinkle-ani;
    animation-timing-function: ease-in-out;
    animation-iteration-count: infinite;
  }

  #main.activate .sparkle {
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1);
    transition-delay: .75s;
  }

  .sparkle.eff-1 {
    width: 1.09rem;
    left: 120.02%;
    top: 69.6%
  }

  .sparkle.eff-1::before {
    animation-duration: 3.3s;
    animation-delay: .2s
  }

  .sparkle.eff-2 {
    width: .4rem;
    left: 135%;
    top: 70.8%
  }

  .sparkle.eff-2::before {
    animation-duration: 2.1s;
    animation-delay: .5s
  }

  .sparkle.eff-3 {
    width: .65rem;
    left: 154.2%;
    top: 54.6%
  }

  .sparkle.eff-3::before {
    animation-duration: 2.9s;
    animation-delay: .4s
  }

  .sparkle.eff-4 {
    width: .36rem;
    left: 143%;
    top: 35.6%
  }

  .sparkle.eff-4::before {
    animation-duration: 2.4s;
    animation-delay: .65s
  }

  .sparkle.eff-5 {
    width: .24rem;
    left: 133.2%;
    top: 40.6%
  }

  .sparkle.eff-5::before {
    animation-duration: 1.8s;
    animation-delay: .35s
  }

  .sparkle.eff-6 {
    width: .5rem;
    left: 100%;
    top: 61.2%
  }

  .sparkle.eff-6::before {
    animation-duration: 2.7s;
    animation-delay: .5s
  }

  .sparkle.eff-7 {
    width: .36rem;
    left: 101.3%;
    top: 37.4%
  }

  .sparkle.eff-7::before {
    animation-duration: 2s;
    animation-delay: .55s
  }

  .sparkle.eff-8 {
    width: .32rem;
    left: 85.2%;
    top: 22%
  }

  .sparkle.eff-8::before {
    animation-duration: 1.6s;
    animation-delay: .7s
  }

  .sparkle.eff-9 {
    width: .38rem;
    left: 71.6%;
    top: 75.2%
  }

  .sparkle.eff-9::before {
    animation-duration: 1.9s;
    animation-delay: .45s
  }

  .sparkle.eff-10 {
    width: .6rem;
    left: 61.6%;
    top: 83%
  }

  .sparkle.eff-10::before {
    animation-duration: 3.1s;
    animation-delay: .6s
  }

  .sparkle.eff-11 {
    width: .38rem;
    left: 52%;
    top: 7.6%
  }

  .sparkle.eff-11::before {
    animation-duration: 2s;
    animation-delay: .5s
  }

  .sparkle.eff-12 {
    width: .32rem;
    left: 43.2%;
    top: 22.2%
  }

  .sparkle.eff-12::before {
    animation-duration: 1.8s;
    animation-delay: .3s
  }

  .sparkle.eff-13 {
    width: .32rem;
    left: 42%;
    top: 59.8%
  }

  .sparkle.eff-13::before {
    animation-duration: 1.75s;
    animation-delay: .7s
  }

  .sparkle.eff-14 {
    width: .65rem;
    left: 30.6%;
    top: 47.5%
  }

  .sparkle.eff-14::before {
    animation-duration: 2.9s;
    animation-delay: .5s
  }

  .sparkle.eff-15 {
    width: .65rem;
    left: 17.5%;
    top: 76.6%
  }

  .sparkle.eff-15::before {
    animation-duration: 3.05s;
    animation-delay: .1s
  }

  .sparkle.eff-16 {
    width: .43rem;
    left: 22.2%;
    top: 13.6%
  }

  .sparkle.eff-16::before {
    animation-duration: 2.2s;
    animation-delay: .4s
  }

  .sparkle.eff-17 {
    width: .87rem;
    left: -3.8%;
    top: 58.4%
  }

  .sparkle.eff-17::before {
    animation-duration: 3.15s;
    animation-delay: .6s
  }

  .sparkle.eff-18 {
    width: .43rem;
    left: -22.3%;
    top: 24.4%
  }

  .sparkle.eff-18::before {
    animation-duration: 2.5s;
    animation-delay: .15s
  }

  .sparkle.eff-19 {
    width: .32rem;
    left: -33.7%;
    top: 41.4%
  }

  .sparkle.eff-19::before {
    animation-duration: 2.1s;
    animation-delay: .3s
  }

  .sparkle.eff-20 {
    width: .33rem;
    left: -35.4%;
    top: 18.2%
  }

  .sparkle.eff-20::before {
    animation-duration: 2.7s;
    animation-delay: .6s
  }
}

@media (max-width: 1080px) {

  #main .sect-cont::before {
    flex: .7;
  }

  #main .sect-cont::after {
    flex: .8;
  }

  #main.activate .sect-bg {
    pointer-events: none;
  }

  #main .masked-img {
    height: 20.9rem;
    background-image: url(../img/bg-main-mo.jpg)
  }

  #mainBgEffect canvas {
    -webkit-mask-image: linear-gradient(to bottom,
        rgba(0, 0, 0, 1) 30%,
        rgba(0, 0, 0, 0) 55%);
    mask-image: linear-gradient(to bottom,
        rgba(0, 0, 0, 1) 30%,
        rgba(0, 0, 0, 0) 55%);
  }

  #main .character {
    width: 8rem;
    top: 56.364%;
    left: 50%;
    margin-left: -.47rem
  }

  #main .btn-float {
    position: relative;
    width: 4.15rem;
    margin-top: .6rem
  }

  #main .market-buttons {
    gap: .2rem;
    margin-top: .48rem
  }

  #main .market-buttons>button {
    width: 2rem
  }

  #main .sect-title {
    position: relative;
    height: 2.44rem;
  }

  #main .sect-title .top {
    width: 1.08rem;
    padding-bottom: .18rem
  }

  #main .sect-title .btm {
    width: 3.64rem;
  }

  #main .main-words {
    left: 50%;
    z-index: 0;
    top: 50%
  }

  #main.expired .character {
    width: 6.83rem;
    top: 54.5%;
    margin-left: -1.07rem;
  }

  #main.expired .typo-words {
    padding: .31rem 0;
  }

  #main.expired .expired-box {
    width: 6.98rem;
    margin-top: 4.8rem;
  }

  #main.expired .expired-box .stamp {
    right: .24rem;
    top: 2.05rem;
    width: 1.62rem
  }

  #main.expired .expired-box {
    transform: translate3d(25%, 0, 0) rotate(-2deg);
  }

  #main.expired.activate .sect-title {
    transition-delay: .5s;
    animation-delay: .15s;
  }

  #main.expired.activate .character {
    animation: none;
    transition-delay: .65s
  }

  #main.expired.activate .main-words {
    transition-delay: .65s;
    animation-delay: 3s
  }

  #main.expired.activate .expired-box {
    transform: translate3d(0, 0, 0) rotate(0deg);
    transition-delay: 3.05s, 3.1s;
  }

  #main.expired.activate .expired-box:not(.play) {
    animation-delay: 5s;
  }

  #main.expired.activate .expired-box .stamp {
    transition-delay: 3.5s, 3.6s;
  }


  #main.expired.fin .main-words {
    animation-delay: 0s;
    animation-duration: 0s;
  }

  #main .main-words .typo-words {
    width: 100%;
    box-sizing: border-box;
    text-align: center;
    max-width: 100%;
  }

  .typo-words .text {
    font-size: .22rem;
    line-height: .32rem
  }

  .register-box-wrap {
    width: 7.12rem;
    margin-top: .13rem;
    display: flex;
    align-items: start;
    justify-content: end;
  }

  .register-box-wrap::before {
    content: "";
    display: block;
    flex: 1
  }

  .register-box {
    flex: none;
    position: relative;
    width: 6.7rem;
    margin-left: -.1rem;
  }

  .register-container {
    left: .2rem;
    top: .44rem;
    right: .6rem;
    bottom: .24rem
  }

  .register-container .register-name>span {
    font-size: .4rem;
    line-height: .48rem;
    padding-left: .6rem;
    padding-right: .6rem
  }

  .register-container .period {
    margin-top: .18rem;
    margin-bottom: .48rem;
    font-size: .2rem;
    line-height: .24rem;
    padding: .05rem .2rem .03rem;
    border-radius: .16rem
  }

  .register-container .fieldset {
    width: 5rem;
    margin: 0 auto
  }

  .user-select {
    gap: .2rem;
    margin: 0 0
  }

  .input-field {
    margin: .1rem 0
  }

  .user-agree {
    padding: .08rem 0
  }

  .user-agree li {
    padding-left: .38rem;
    text-indent: -.38rem;
  }

  .user-agree li+li {
    margin-top: .1rem
  }

  .user-agree li label span {
    font-size: .18rem;
    line-height: .26rem;
    word-wrap: break-word;
    word-break: keep-all;
    letter-spacing: -.05em
  }

  .user-agree .btn-docs {
    width: .15rem;
    height: .15rem;
    margin-left: .04rem;
  }

  .register-box-wrap .common-btn {
    width: 3.88rem;
    height: .8rem;
    margin-top: .25rem;
    box-sizing: border-box;
    margin-bottom: .25rem
  }

  .register-box-wrap .common-btn>span {
    font-size: .28rem;
    line-height: .34rem;
    padding-bottom: .04rem;
  }

  .user-agree .btn-docs::before,
  .user-agree .btn-docs::after {
    width: .15rem;
    height: .04rem
  }

  .register-box-wrap .common-btn {
    width: 3.88rem;
  }

  .register-box-wrap .notice>p {
    font-size: .16rem;
    line-height: .19rem;
    padding-left: .19rem;
    word-wrap: break-word;
    word-break: keep-all;
  }

  .register-box-wrap .notice>p+p {
    margin-top: .11rem
  }

  .register-box-wrap .notice>p::before {
    top: .45em;
  }

  .entry-cont .expired-content {
    right: -.15rem;
    top: .04rem;
    width: 8.02rem
  }

  .stub-cont .expired-content {
    left: -.36rem;
    top: .24rem;
    width: 3.84rem;
    transform-origin: 0 100%;
    transform: rotate(-7.6deg) translateX(.285rem) translateY(-.02rem)
  }


  .expired-content .sales-note {
    right: 0;
    width: 4.52rem;
    top: 1.4rem
  }

  .expired-content .sales-note .item>span {
    font-size: .24rem;
    line-height: .28rem;
    padding: .04rem .15rem;
    min-width: 1.64rem
  }

  .expired-content .sales-note .item>span::before,
  .expired-content .sales-note .item>span::after {
    width: .08rem;
    height: .08rem
  }

  .expired-content .sales-note .status {
    margin-top: .1rem
  }

  .expired-content .sales-note .status>span {
    font-size: .56rem;
    line-height: .67rem;
  }

  .expired-content .sales-note .message {
    margin-top: .1rem;
    font-size: .2rem;
    line-height: .3rem
  }

  .expired-content .stamp {
    width: 1.57rem;
    left: 1rem;
    bottom: 1.38rem
  }

  #main.activate .stub-cont .expired-content {
    transition-delay: 1.1s
  }

  #main.activate .expired-content .stamp {
    transition-delay: 1.45s
  }

  /* Transition */
  #main .btn-float {
    opacity: 0;
    transform: translate3d(15%, 0, 0);
    transition: all .35s var(--bounce);
  }

  #main.activate .btn-float {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    transition-delay: 3.85s
  }

  #main .sect-title {
    transform: translate3d(0, 30%, 0) scale(1.4);
    transition: all .5s var(--easing);
  }

  #main.activate .sect-title {
    transform: translate3d(0, 0, 0) scale(1);
    transition-delay: 3.75s;
  }

  #main .sect-title>span {
    opacity: 0;
    transform: translate3d(-50%, 5%, 0) scale(1.1);
    transition: all .3s var(--easing)
  }

  #main.activate .sect-title>span {
    opacity: 1;
    transform: translate3d(-50%, 0, 0) scale(1);
    transition-delay: .2s
  }

  #main .character {
    opacity: 0;
    transform: translate3d(-50%, -40%, 0);
    transition: all .35s var(--bounce);
  }

  #main.activate .character {
    transform: translate3d(-50%, -50%, 0);
    opacity: 1;
    transition-delay: .15s;
    animation: main-disapper-ani .65s 3.75s var(--easing) forwards;
  }

  #main .main-words {
    transform: translate3d(-50%, -40%, 0);
    opacity: 0;
    transition: all .35s var(--bounce)
  }

  #main.activate .main-words {
    transform: translate3d(-50%, -50%, 0);
    opacity: 1;
    transition-delay: .15s;
    animation: main-disapper-ani .55s 3.85s var(--easing) forwards;
  }

  #main .register-box::before {
    width: 6.4rem;
    height: 6.25rem;
    right: .06rem;
    bottom: -.3rem;
    transform: rotate(-5deg) translate3d(0, -5%, 0);
    opacity: 0;
    transition: opacity .3s, transform .45s var(--easing)
  }

  #main.activate .register-box::before {
    transform: rotate(0deg) translate3d(0, 0, 0);
    opacity: 1;
    transition-delay: 4.3s, 4.3s
  }

  #main .register-box,
  #main .market-buttons {
    transform: translateY(.2rem);
    opacity: 0;
    transition: all .45s var(--easing)
  }


  #main.activate .register-box,
  #main.activate .market-buttons {
    transform: translateY(0);
    opacity: 1;
    transition-delay: 4s;
  }

  @keyframes main-disapper-ani {
    0% {
      transform: translate3d(-50%, -50%, 0);
      opacity: 1;
    }

    100% {
      transform: translate3d(-50%, -35%, 0);
      opacity: 0;
      pointer-events: none;
    }
  }

}


/* category-tab */
.category-tab {
  display: block;
  position: relative;
  height: .6rem;
  z-index: 1;
}

.category-tab .bg-box {
  content: "";
  display: block;
  position: absolute;
  pointer-events: none;
  z-index: -1;
  left: .3rem;
  top: 0;
  bottom: 0;
  right: .3rem;
  background-repeat: repeat-x;
  background-size: auto 100%;
  background-position: left center;
}


.category-tab .bg-box::before,
.category-tab .bg-box::after {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: .3rem;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

.category-tab .bg-box::before {
  right: 100%;
  background-position: right center;
}

.category-tab .bg-box::after {
  left: 100%;
  background-position: left center;
}

.category-tab .fade-area {
  position: absolute;
  left: .05rem;
  right: .05rem;
  top: 0;
  height: 100%;
  padding: 0 .2rem;
  box-sizing: border-box;
  clip-path: polygon(0 50%, .15rem 0, calc(100% - .15rem) 0, 100% 50%, calc(100% - .15rem) 100%, .15rem 100%);
  mask-image: linear-gradient(to right, transparent, rgb(var(--rgb-black)) .2rem, rgb(var(--rgb-black)) calc(100% - .2rem), transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, rgb(var(--rgb-black)) .2rem, rgb(var(--rgb-black)) calc(100% - .2rem), transparent);
}

.category-tab .swiper-container {
  display: block;
  width: 100%;
  position: relative;
  height: 100%;
  overflow: visible;
}

.category-tab .swiper-wrapper {
  justify-content: start;
}

.category-tab .swiper-wrapper::before,
.category-tab .swiper-wrapper::after {
  content: "";
  display: block;
  flex: 1;
}

.category-tab .line-box {
  position: absolute;
  top: 0;
  pointer-events: none;
  height: 100%;
  left: .25rem;
  z-index: -1;
  right: .25rem;
  background-repeat: repeat-x;
  background-size: auto 100%;
  background-position: left center;
}

.category-tab .line-box::before,
.category-tab .line-box::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
  width: .2rem;
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: left center;
}

.category-tab .line-box::before {
  right: 100%;
}

.category-tab .line-box::after {
  left: 100%;
  transform: rotateY(180deg);
}

.category-tab .swiper-container .swiper-slide {
  width: auto;
  flex: none;
  box-sizing: border-box;
  padding: 0 .3rem;
}

.category-tab .swiper-container .swiper-slide>button {
  display: block;
  text-align: center;
  position: relative;
  box-sizing: border-box;
  font-weight: 600;
  letter-spacing: -.025em;
  width: auto;
  height: 100%;
}

.category-tab .swiper-container .swiper-slide>button.on::before,
.category-tab .swiper-container .swiper-slide>button.on::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  height: 100%;
  width: .31rem;
  background-image: url(../img/category-btn-start.png);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: auto 100%;
}

.category-tab .swiper-container .swiper-slide>button.on::before {
  right: 100%;
  margin-right: -.02rem;
}

.category-tab .swiper-container .swiper-slide>button.on::after {
  left: 100%;
  margin-left: -.02rem;
  transform: rotateY(180deg);
}

.category-tab .swiper-container .swiper-slide>button.on {
  background: url(../img/category-btn-bg.png) repeat-x center / auto 100%;
}

.category-tab .swiper-container .swiper-slide>button>span {
  padding-left: .07rem;
  padding-right: .07rem;
}


@media (min-width: 1081px) {
  .category-tab {
    width: 11.9rem;
  }

  .category-tab .swiper-container .swiper-slide>button {
    min-width: 1.5rem
  }
}

@media (max-width: 1080px) {
  .category-tab {
    width: 6.76rem;
  }

  .category-tab .swiper-container .swiper-slide>button {
    min-width: 1.8rem
  }
}


/** whatsnew */
#whatsnew .sect-title {
  margin: 0 auto .5rem;
  display: block;
  width: 4.12rem
}

#whatsnew .category-tab .bg-box {
  background-image: url(../img/whatsnew-category-bg.png);
}

#whatsnew .category-tab .bg-box::before {
  background-image: url(../img/whatsnew-category-bg-start.png);
}

#whatsnew .category-tab .bg-box::after {
  background-image: url(../img/whatsnew-category-bg-end.png);
}

#whatsnew .category-tab .line-box {
  background-image: url(../img/whatsnew-category-line.png)
}

#whatsnew .category-tab .line-box::before,
#whatsnew .category-tab .line-box::after {
  background-image: url(../img/whatsnew-category-line-start.png);
}

#whatsnew .category-tab button {
  color: #ABC6D8;
}

#whatsnew .category-tab button.on,
#whatsnew .category-tab button.on:hover {
  color: #11508D;
}

#whatsnew .whatsnew-content {
  display: block;
  position: relative;
  margin: 0 auto;
  overflow: visible;
  opacity: 0;
  transition: all .55s var(--bounce);
}

#whatsnew .whatsnew-content .swiper-container {
  opacity: 0;
  transition: opacity .6s ease-out;
}

#whatsnew.activate .whatsnew-content {
  opacity: 1;
  z-index: 2;
  transition-delay: .4s
}

#whatsnew.activate .whatsnew-content .swiper-container {
  opacity: 1;
  transition-delay: .5s
}

#whatsnew .whatsnew-content .swiper-container {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%
}

#whatsnew .whatsnew-content .swiper-slide {
  position: relative;
  height: auto;
  overflow: visible;
}

#whatsnew .whatsnew-content .page {
  position: absolute;
  opacity: 1;
  transform-style: preserve-3d;
}

#whatsnew .whatsnew-content .page::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-size: 100% 100%;
  background-repeat: no-repeat;
  transform: rotateY(180deg);
  backface-visibility: hidden;
  pointer-events: none;
}

#whatsnew .whatsnew-content .swiper-slide {
  opacity: 0;
  transition: opacity .8s 0s !important;
}

#whatsnew .whatsnew-content .swiper-slide-active {
  transition: opacity 0s .8s !important;
}

#whatsnew .whatsnew-content .page {
  opacity: 0;
  animation: book-page-inactive-ani .9s 0s forwards var(--easing);
}

#whatsnew .whatsnew-content .swiper-slide-active .page {
  opacity: 1;
  animation: book-page-active-ani .9s 0s forwards var(--easing);
}

#whatsnew .whatsnew-content .content-body {
  opacity: 0;
  transition: opacity .15s var(--easing)
}

#whatsnew .whatsnew-content .swiper-slide-active .content-body {
  opacity: 1;
  transition-delay: .15s
}


#whatsnew .whatsnew-content .box {
  position: absolute;
}

#whatsnew .whatsnew-content .inner-box {
  display: flex;
  align-items: center;
  justify-content: center;
}

#whatsnew .whatsnew-content .thumbnail {
  flex: 1;
  transform-origin: right center;
}

#whatsnew .whatsnew-content .swiper-slide-active .thumbnail {
  z-index: 2;
  animation: book-thumb-active-ani .9s 0s forwards var(--easing);
}

#whatsnew .whatsnew-content .content-body {
  position: relative;
  flex: 1;
  z-index: 1;
}

#whatsnew .whatsnew-content .swiper-slide .common-btn {
  pointer-events: none;
}

#whatsnew .whatsnew-content .swiper-slide.swiper-slide-active .common-btn {
  pointer-events: fill
}


#whatsnew .content-body {
  padding: .4rem .3rem .3rem;
  opacity: 0;
  transition: transform .55s 0s var(--easing);
}

#whatsnew .swiper-slide-active .content-body {
  opacity: 1;
  transition-delay: .5s
}

#whatsnew .content-body p {
  display: block;
  position: relative;
  letter-spacing: -.025em;
  color: #18272E;
  margin: 0 auto;
  word-wrap: break-word;
  text-align: center;
  word-break: keep-all;
}

#whatsnew .content-body .title {
  position: relative;
  font-weight: 600;
}

#whatsnew .content-body .title::before,
#whatsnew .content-body .title::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translate3d(-50%, 0, 0);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}

#whatsnew .content-body .description {
  font-weight: 500;
}

#whatsnew .common-btn {
  margin-top: .4rem
}

.whatsnew-content button[name="whatsnew-bookmark"] {
  position: absolute;
  pointer-events: auto;
  cursor: pointer;
  z-index: 25;
}

.whatsnew-content button[name="whatsnew-bookmark"]>img {
  object-fit: fill;
  height: 100%;
}

.whatsnew-content button[name="whatsnew-bookmark"]::before,
.whatsnew-content button[name="whatsnew-bookmark"]::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 0 0;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, -75%, 0) rotate(30deg);
  transition: opacity .1s .1s linear, transform .3s 0s var(--easing)
}

.whatsnew-content button[name="whatsnew-bookmark"]::before {
  background-image: url(../img/whatsnew-clip-01.png)
}

.whatsnew-content button[name="whatsnew-bookmark"]::after {
  background-image: url(../img/whatsnew-clip-02.png);
}

.whatsnew-content button[name="whatsnew-bookmark"][data-type="1"]::before,
.whatsnew-content button[name="whatsnew-bookmark"][data-type="1"]::after {
  transform: translate3d(-50%, -50%, 0) rotate(20deg);
  pointer-events: auto;
}

.whatsnew-content button[name="whatsnew-bookmark"][data-type="1"]::before {
  opacity: 1;
}

.whatsnew-content button[name="whatsnew-bookmark"][data-type="2"]::after {
  opacity: 1;
  transition-delay: 0s, .3s;
}

.whatsnew-content button[name="whatsnew-bookmark"][data-type="2"]::before {
  transition-delay: .1s, .3s;
}

#whatsnewBgEffect canvas {
  -webkit-mask-image: linear-gradient(to bottom,
      rgba(0, 0, 0, 1) 50%,
      rgba(0, 0, 0, 0) 80%);
  mask-image: linear-gradient(to bottom,
      rgba(0, 0, 0, 1) 50%,
      rgba(0, 0, 0, 0) 80%);
}


@media (min-width: 1081px) {

  #whatsnew {
    margin-top: min(-1rem, -3.90625vw, -6.945vh)
  }

  #whatsnew .sect-cont::before {
    flex: .55
  }

  #whatsnew .sect-cont::after {
    flex: 1.8;
  }

  #whatsnew .sect-bg {
    -webkit-mask-image: url(../img/bg-whatsnew-pc-mask.png);
    mask-image: url(../img/bg-whatsnew-pc-mask.png);
  }

  #whatsnew .masked-img {
    height: 14.4rem;
    background-image: url(../img/bg-whatsnew-pc.jpg);
  }

  #whatsnew .whatsnew-content {
    width: 12.02rem;
    margin-top: .3rem
  }

  #whatsnew .whatsnew-content {
    transform: scaleX(.7);
  }

  #whatsnew.activate .whatsnew-content {
    transform: scaleX(1);
  }

  #whatsnew .whatsnew-content .page {
    width: 5.48rem;
    z-index: 10;
    top: .24rem;
    right: .54rem;
    transform-origin: left center;
  }

  #whatsnew .whatsnew-content .box {
    width: 10.33rem;
    height: 7.53rem;
    left: .84rem;
    top: .54rem;
    opacity: 0;
    transition: opacity .3s .35s var(--easing);
  }

  #whatsnew .whatsnew-content .inner-box {
    gap: .56rem;
  }

  #whatsnew .whatsnew-content .swiper-slide-active .box {
    opacity: 1;
    transition-delay: .35s
  }

  #whatsnew .whatsnew-content .thumbnail {
    width: 4.84rem;
    flex: none
  }

  #whatsnew .whatsnew-content .page::before {
    background-image: url(../img/minigame-kv-mo.png)
  }

  #whatsnew .category-tab button:hover {
    color: #fff;
  }

  @keyframes book-page-active-ani {
    0% {
      opacity: .1;
      transform: rotateY(0deg);
      z-index: 2;
    }

    50% {
      opacity: 1;
      z-index: 1;
    }

    100% {
      opacity: 0;
      z-index: 0;
      transform: rotateY(-180deg);
    }
  }

  @keyframes book-page-inactive-ani {
    0% {
      opacity: 0;
      transform: rotateY(0deg);
    }

    50% {
      opacity: 1;
      z-index: 2;
    }

    100% {
      opacity: 0;
      z-index: 0;
      transform: rotateY(-180deg);
    }
  }

  @keyframes book-thumb-active-ani {
    0% {
      opacity: 0;
    }

    70% {
      opacity: 0;
    }

    95% {
      opacity: 1;
    }

  }

  #whatsnew .content-body {
    transform-origin: left center;
  }

  #whatsnew .content-body {
    transform: rotateY(30deg);
  }

  #whatsnew .swiper-slide-active .content-body {
    transform: rotateY(0deg);
  }

  #whatsnew .content-body p {
    width: 4.2rem;
  }

  #whatsnew .content-body .title {
    font-size: .36rem;
    line-height: .44rem;
    padding-top: 1rem;
    padding-bottom: .45rem
  }

  #whatsnew .content-body .title::before {
    background-image: url(../img/whatsnew-snow.png);
    width: .69rem;
    height: .81rem;
    top: 0;
  }

  #whatsnew .content-body .title::after {
    background-image: url(../img/whatsnew-divider.png);
    width: 2.95rem;
    height: .25rem;
    bottom: 0;
  }

  #whatsnew .content-body .description {
    font-size: .18rem;
    line-height: .24rem;
    padding-top: .2rem
  }

  .whatsnew-content button[name="whatsnew-bookmark"] {
    height: .6rem;
    width: 5.45rem;
    left: 50%;
    top: .25rem
  }

  .whatsnew-content button[name="whatsnew-bookmark"]::before,
  .whatsnew-content button[name="whatsnew-bookmark"]::after {
    width: .81rem;
    height: 1.32rem;
    left: 83.12%;
    top: 3.35%
  }
}

@media (max-width: 1080px) {

  #whatsnew {
    margin-top: min(-1.05rem, -9.723vw, -6.25vh);
  }

  #whatsnew .sect-cont::before {
    flex: .55
  }

  #whatsnew .sect-cont::after {
    flex: 1.8;
  }

  #whatsnew .sect-bg {
    -webkit-mask-image: url(../img/bg-whatsnew-pc-mask.png);
    mask-image: url(../img/bg-whatsnew-pc-mask.png);
  }

  #whatsnew .masked-img {
    height: 16.1rem;
    background-image: url(../img/bg-whatsnew-pc.jpg);
  }

  #whatsnew .whatsnew-content {
    width: 6.85rem;
    margin-top: .2rem
  }

  #whatsnew .whatsnew-content {
    transform: scaleY(.5);
  }

  #whatsnew.activate .whatsnew-content {
    transform: scaleY(1);
  }

  #whatsnew .whatsnew-content .page {
    width: 6.46rem;
    z-index: 10;
    top: .18rem;
    right: .2rem;
    transform-origin: center bottom;
  }

  #whatsnew .whatsnew-content .box {
    width: 5.75rem;
    left: .54rem;
    top: .52rem;
    opacity: 0;
    transition: opacity .3s .35s var(--easing);
  }

  #whatsnew .whatsnew-content .inner-box {
    gap: .66rem;
    flex-direction: column;
    height: 8.94rem
  }

  #whatsnew .whatsnew-content .swiper-slide-active .box {
    opacity: 1;
    transition-delay: .35s
  }

  #whatsnew .whatsnew-content .thumbnail {
    width: 100%;
    flex: none
  }

  #whatsnew .whatsnew-content .page::before {
    background-image: url(../img/minigame-kv-mo.png)
  }

  @keyframes book-page-active-ani {
    0% {
      opacity: .1;
      transform: rotateX(-180deg) scaleY(1.46);
      z-index: 2;
    }

    50% {
      opacity: 1;
      z-index: 1;
    }

    100% {
      opacity: 0;
      z-index: 0;
      transform: rotateX(0deg) scaleY(1);
    }
  }

  @keyframes book-page-inactive-ani {
    0% {
      opacity: 0;
      transform: rotateX(-180deg) scaleY(1.46);
    }

    50% {
      opacity: 1;
      z-index: 2;
    }

    100% {
      opacity: 0;
      z-index: 0;
      transform: rotateX(0deg);
    }
  }

  @keyframes book-thumb-active-ani {
    0% {
      opacity: 0;
    }

    70% {
      opacity: 0;
    }

    95% {
      opacity: 1;
    }

  }

  #whatsnew .content-body {
    transform-origin: center top;
    transform: rotateX(30deg);
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
  }

  #whatsnew .swiper-slide-active .content-body {
    transform: rotateX(0deg);
  }

  #whatsnew .content-body p {
    width: 4.8rem;
  }

  #whatsnew .content-body .title {
    font-size: .32rem;
    line-height: .38rem;
    padding-bottom: .38rem
  }

  #whatsnew .content-body .title::after {
    background-image: url(../img/whatsnew-divider.png);
    width: 2.6rem;
    height: .22rem;
    bottom: 0;
  }

  #whatsnew .content-body .description {
    font-size: .2rem;
    line-height: .26rem;
    padding-top: .16rem
  }

  .whatsnew-content button[name="whatsnew-bookmark"] {
    height: .6rem;
    width: 6.46rem;
    left: .2rem;
    top: .18rem;
  }

  .whatsnew-content button[name="whatsnew-bookmark"]::before,
  .whatsnew-content button[name="whatsnew-bookmark"]::after {
    width: .81rem;
    height: 1.32rem;
    left: 88.5%;
    top: 30%;
  }
}

#whatsnew .sect-title,
#whatsnew .category-tab {
  opacity: 0;
  transform: translate3d(0, .25rem, 0);
  transition: all .25s var(--easing)
}

#whatsnew.activate .sect-title,
#whatsnew.activate .category-tab {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}


#whatsnew.activate .sect-title {
  transition-delay: .15s;
}

#whatsnew.activate .category-tab {
  transition-delay: .25s;
}


/* character */
.character-container {
  flex: none;
  width: 100%;
  height: fit-content;
  position: relative;
}

#character .bg-objects {
  z-index: 0;
  position: absolute;
}

#character .snowball-glass {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}

#character .snowball-glass::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  left: 0;
  top: 100%;
  z-index: -1;
  background: url(../img/character-snowball-shadow.png) no-repeat center top / auto 100%
}

#character .snowball-glass {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}

.glass-view {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.glass-view::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 40%;
  z-index: 1;
  background: url(../img/character-snowball-effect.png) no-repeat center / contain;
  pointer-events: none;
}

.glass-view>img {
  position: absolute;
  left: 1.04%;
  top: .4%;
  width: 97.92%;
  height: auto;
  opacity: 0;
  transform: rotate(360deg) scale(0.3);
  transition: opacity .65s 0s var(--easing), transform 3s var(--easing);
}

#snowball[data-name="zenith"] .glass-view>img.zenith,
#snowball[data-name="darian"] .glass-view>img.darian,
#snowball[data-name="tyr"] .glass-view>img.tyr,
#snowball[data-name="eleaneer"] .glass-view>img.eleaneer,
#snowball[data-name="wilhelmina"] .glass-view>img.wilhelmina {
  opacity: 1;
  transform: rotate(0deg) scale(1);
  transition-delay: .2s, .1s;
  transition-duration: .35s, .5s;
}

#character .back-img {
  transform: translate3d(-50%, -50%, 0);
  z-index: 1
}

#character .front-img {
  position: absolute;
  z-index: 2;
}

#character .front-img::before {
  content: "";
  display: block;
  padding-top: 155%
}

#character .character-nav {
  position: relative;
  z-index: 10;
}

.character-nav ul {
  width: 100%;
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
}

.character-nav li {
  display: block;
  flex: none
}

.character-nav button {
  display: block;
  width: 100%;
}

.character-nav button .name {
  font-weight: 500;
  letter-spacing: -.025em;
  text-align: center;
  display: block;
  text-transform: uppercase;
  color: #005A93
}

.character-nav button.on .name {
  font-weight: 600
}

.character-nav button .profile {
  display: block;
  width: 100%;
  padding-top: 117.39%;
  position: relative
}

.character-nav button .profile::before,
.character-nav button .profile::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity .1s linear
}

.character-nav button .profile,
.character-nav button .profile::before,
.character-nav button .profile::after {
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position-x: center
}

.character-nav button .profile {
  background-position-y: 0%
}

.character-nav button .profile::before {
  background-position-y: 100%
}

.character-nav button:hover .profile::before,
.character-nav button.on .profile::before {
  opacity: 1
}

.character-nav button[value="wilhelmina"] .profile,
.character-nav button[value="wilhelmina"] .profile::before {
  background-image: url(../characters/wilhelmina/thumbnail.png)
}

.character-nav button[value="zenith"] .profile,
.character-nav button[value="zenith"] .profile::before {
  background-image: url(../characters/zenith/thumbnail.png)
}

.character-nav button[value="darian"] .profile,
.character-nav button[value="darian"] .profile::before {
  background-image: url(../characters/darian/thumbnail.png)
}

.character-nav button[value="tyr"] .profile,
.character-nav button[value="tyr"] .profile::before {
  background-image: url(../characters/tyr/thumbnail.png)
}

.character-nav button[value="eleaneer"] .profile,
.character-nav button[value="eleaneer"] .profile::before {
  background-image: url(../characters/eleaneer/thumbnail.png)
}

.character-content {
  position: relative;
  margin: 0 auto;
  display: block;
}

.character-visual {
  position: relative;
}


#character-mov {
  position: absolute;
  pointer-events: none;
  /*left: 50%;
  transform: translateX(-50%);*/
}

#character-mov video {
  background: none;
  display: block;
  width: 100%;
  object-fit: contain;
  height: auto;
  opacity: 0;
}

#character-mov video.active {
  opacity: 1;
}

#character-mov video.hide {
  opacity: 0;
  transition: opacity .1s .05s;
}

#motion-video {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 9;
  pointer-events: none;
}

.zoom-point {
  position: absolute;
  transform: translate3d(-50%, -50%, 0);
  pointer-events: none;
  z-index: 15;
}

.zoom-point::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 1;
  pointer-events: none
}

.zoom-point::before {
  background-image: url(../img/character-pointer-light.png)
}


.character-content.visible .zoom-point {
  pointer-events: fill;
}

.zoomin-box {
  position: absolute;
  pointer-events: none;
}

.zoomin-box::before,
.zoomin-box::after {
  content: "";
  display: block;
  box-sizing: border-box;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}

.zoomin-box::before {
  width: 74.8%;
  left: 12.6%;
  top: 12.6%;
  height: 74.8%;
  background-image: url(../img/character-closeup-deco.png);
}

.zoomin-box::after {
  width: 83.5%;
  left: 8.25%;
  top: 8.25%;
  height: 83.5%;
  background-image: url(../img/character-closeup-line.png);
}

.zoomin .zoomin-box::before {
  animation: zoomin-box-deco 5s .2s linear infinite;
}

.zoomin .zoomin-box::after {
  animation: zoomin-box-deco 5s .2s linear infinite reverse;
}

.zoom-point {
  animation: zoom-point-blinking 2s var(--easing) infinite alternate;
}

.zoom-point[value="01"] {
  animation-duration: 2.3s;
  animation-delay: 0s
}

.zoom-point[value="02"] {
  animation-duration: 2.5s;
  animation-delay: .25s
}

.zoom-point[value="03"] {
  animation-duration: 2.1s;
  animation-delay: .5s
}

.zoom-point.zoomin {
  animation-delay: 0s;
  animation-duration: .1s;
  animation-iteration-count: 1;
  animation-fill-mode: forwards;
}

.zoomin-box {
  transform: translate3d(-50%, -50%, 0);
  opacity: 0;
  left: 50%;
  top: 50%;
  transition: all .15s var(--bounce);
}

.zoom-point.zoomin .zoomin-box {
  opacity: 1;
  z-index: 25;
  animation-delay: .15s;
  animation-duration: .25s;
  pointer-events: fill
}


#characterContent.focused .zoom-point>img,
#characterContent.focused .zoom-point::before {
  pointer-events: none;
  opacity: 0;
  transition: all .25s .5s ease-out;
}

#characterContent.focused .zoom-point.zoomin>img {
  animation: zoom-point-active .15s 0s var(--easing) forwards;
}

#characterContent.focused .zoom-point {
  pointer-events: none;
  cursor: default;
}

.character-content .front-img::before {
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center top;
}

.character-content[data-name="zenith"] #character-mov {
  width: 100%;
  bottom: -3%;
  left: -.05%;
}

.character-content[data-name="darian"] #character-mov {
  width: 100%;
  bottom: 0;
  left: 0;
}

.character-content[data-name="tyr"] #character-mov {
  width: 100.4%;
  bottom: -15%;
  left: -.05%;
}

.character-content[data-name="eleaneer"] #character-mov {
  width: 100%;
  bottom: .05%;
  left: 0;
}

.character-content[data-name="wilhelmina"] #character-mov {
  width: 219%;
  bottom: -31%;
  left: -59.5%;
}


@media (min-width: 1081px) {
  #character {
    margin-top: min(-1rem, -3.90625vw, -6.945vh)
  }

  #character .sect-cont::before {
    flex: 1.3
  }

  #character .sect-cont::after {
    flex: 1;
  }

  #character .sect-bg {
    -webkit-mask-image: url(../img/bg-character-pc-mask.png);
    mask-image: url(../img/bg-character-pc-mask.png);
  }

  #character .masked-img {
    height: 15.5rem;
    background-image: url(../img/bg-character-pc.jpg)
  }

  #character .bg-objects {
    width: 12.8rem;
    height: 10.8rem;
    bottom: 0;
    left: 50%;
    margin-left: -6.4rem;
  }

  #character .snowball-glass {
    width: 6.73rem;
    left: -.57rem;
    top: 1.5rem
  }

  #character .snowball-glass::before {
    margin-top: -.78rem;
    height: 2.62rem
  }

  #character .back-img {
    position: absolute;
    width: 6.59rem;
    width: 6.26rem;
    left: 43.90625%;
    top: 43.333%;
  }

  #character .back-img::before,
  #character .glass-view::before {
    width: 12rem;
    height: 12rem
  }

  #character .front-img {
    width: 7.2rem;
    left: 43.75%;
    top: 49.1666%;
  }

  #character .character-nav ul {
    gap: .28rem
  }

  #character .character-nav li {
    width: 1.38rem
  }

  .character-nav button .name {
    font-size: .18rem;
    line-height: .24rem;
    margin-top: -.06rem;
    color: #005A93
  }

  .character-nav button:hover .name {
    font-weight: 600
  }

  #character .character-content {
    width: 12.8rem;
    height: 10.8rem;
    display: flex;
  }

  #character .character-visual,
  #character .character-info {
    flex: 1;
    position: relative;
  }

  .zoom-point {
    width: 1.14rem;
    height: 1.14rem;
  }

  .zoom-point::before {
    width: .39rem;
    height: .39rem;
  }

  .zoom-point:hover {
    transform: translate3d(-50%, -50%, 0) scale(1);
    transition-delay: 0s, 0s;
  }

  .zoom-point>img {
    opacity: .5;
    transform: scale(1);
    transition: opacity .15s .15s ease-out, transform .2s 0s ease-out;
  }

  .zoom-point:hover>img {
    transform: scale(1.2);
    opacity: 1;
    transition-delay: 0s, 0s;
  }

  .zoom-point::before {
    opacity: 0.5;
    transition: transform .15s .1s ease-out;
    mix-blend-mode: screen;
  }

  .zoom-point:hover::before {
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1.8);
  }

  .zoomin-box {
    width: 3.06rem;
  }

  .character-content[data-name="zenith"] #character-mov {
    width: 7.2rem;
  }

  .character-content[data-name="darian"] #character-mov {
    width: 7.2rem;
  }

  .character-content[data-name="tyr"] #character-mov {
    width: 7.22rem;
  }

  .character-content[data-name="eleaneer"] #character-mov {
    width: 7.2rem;
  }

  .character-content[data-name="wilhelmina"] #character-mov {
    width: 15.75rem;
  }

  .character-content[data-name="zenith"] .zoom-point[value="01"] {
    left: 56.2%;
    top: 29%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="02"] {
    left: 44.6%;
    top: 37.2%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="03"] {
    left: 42.4%;
    top: 48.5%;
  }

  .character-content[data-name="darian"] .zoom-point[value="01"] {
    left: 38.8%;
    top: 31.7%;
  }

  .character-content[data-name="darian"] .zoom-point[value="02"] {
    left: 38.1%;
    top: 45.2%;
  }

  .character-content[data-name="darian"] .zoom-point[value="03"] {
    left: 38.2%;
    top: 70%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="01"] {
    left: 50.6%;
    top: 36.6%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="02"] {
    left: 40.2%;
    top: 49%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="03"] {
    left: 33.3%;
    top: 58.6%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="01"] {
    left: 31.4%;
    top: 28.9%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="02"] {
    left: 45.2%;
    top: 35.5%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="03"] {
    left: 52.4%;
    top: 49.9%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="01"] {
    left: 40.4%;
    top: 30.7%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="02"] {
    left: 54.8%;
    top: 36.4%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="03"] {
    left: 54.1%;
    top: 47%;
  }
}

@media (max-width: 1080px) {
  #character {
    margin-top: min(-.96rem, -8.889vw, -5.053vh)
  }

  #character .sect-cont::before {
    flex: 1.3
  }

  #character .sect-cont::after {
    flex: 1;
  }

  #character .sect-bg {
    -webkit-mask-image: url(../img/bg-character-mo-mask.png);
    mask-image: url(../img/bg-character-mo-mask.png);
  }

  #character .masked-img {
    height: 19rem;
    background-image: url(../img/bg-character-mo.jpg)
  }

  #character .bg-objects {
    width: 8.65rem;
    height: 13.42rem;
    bottom: 0;
    left: 50%;
    margin-left: -4.325rem;
  }

  #character .snowball-glass {
    width: 6.73rem;
    left: .96rem;
    top: 3.3rem
  }

  #character .snowball-glass::before {
    margin-top: -.78rem;
    height: 2.62rem
  }

  #character .back-img {
    position: absolute;
    width: 6.59rem;
    left: 50%;
    top: 48.3%;
  }

  #character .back-img::before,
  #character .glass-view::before {
    width: 12rem;
    height: 12rem
  }

  #character .front-img {
    width: 100%;
    left: 50%;
    top: 50%;
  }

  #character .character-nav ul {
    gap: .22rem
  }

  #character .character-nav li {
    width: 1.15rem
  }

  .character-nav button .name {
    font-size: .2rem;
    line-height: .28rem;
    margin-top: -.06rem;
    color: #005A93
  }

  #character .character-content {
    margin: 0 auto;
    height: 13.42rem;
    position: relative;
    margin-top: .4rem;
  }

  #character .character-visual {
    width: 8.65rem;
    left: 50%;
    margin-left: -4.325rem;
    top: 0;
    position: absolute;
    height: 100%;
  }

  .zoom-point {
    width: 15.84%;
  }

  .zoom-point::before {
    width: .48rem;
    height: .48rem;
  }

  .zoom-point:active {
    transform: translate3d(-50%, -50%, 0) scale(1);
    transition-delay: 0s, 0s;
  }

  .zoom-point>img {
    opacity: .5;
    transform: scale(1);
    transition: opacity .15s .15s ease-out, transform .2s 0s ease-out;
  }

  .zoom-point:active>img {
    transform: scale(1.2);
    opacity: 1;
    transition-delay: 0s, 0s;
    transition-timing-function: ease-out, var(--zoom-bounce);
  }

  .zoom-point::before {
    opacity: 0.5;
    transition: transform .15s .15s ease-out;
    mix-blend-mode: screen;
  }

  .zoom-point:active::before {
    opacity: 1;
    transform: translate3d(-50%, -50%, 0) scale(1.8);
  }


  .zoomin-box {
    width: 3.69rem;
  }

  .character-content[data-name="zenith"] .zoom-point[value="01"] {
    left: 61.2%;
    top: 30.5%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="02"] {
    left: 50.8%;
    top: 38.4%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="03"] {
    left: 48.8%;
    top: 49.4%;
  }

  .character-content[data-name="darian"] .zoom-point[value="01"] {
    left: 45.6%;
    top: 33.1%;
  }

  .character-content[data-name="darian"] .zoom-point[value="02"] {
    left: 45.2%;
    top: 46.3%;
  }

  .character-content[data-name="darian"] .zoom-point[value="03"] {
    left: 45.2%;
    top: 70.2%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="01"] {
    left: 56%;
    top: 37.9%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="02"] {
    left: 47%;
    top: 49.9%;
  }

  .character-content[data-name="tyr"] .zoom-point[value="03"] {
    left: 40.9%;
    top: 59.2%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="01"] {
    left: 39%;
    top: 30.5%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="02"] {
    left: 51.1%;
    top: 36.8%;
  }

  .character-content[data-name="eleaneer"] .zoom-point[value="03"] {
    left: 57.5%;
    top: 50.8%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="01"] {
    left: 47.1%;
    top: 32.1%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="02"] {
    left: 59.7%;
    top: 37.6%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="03"] {
    left: 59.1%;
    top: 47.9%;
  }

  .btn-open-card {
    width: 1.34rem;
    height: 1.94rem;
    z-index: 25;
    position: fixed;
    left: 50%;
    margin-left: 1.76rem;
    opacity: 0;
    bottom: 2.55rem;
    pointer-events: none;
    transition: opacity .15s;
  }

  .btn-open-card>img {
    transform: rotate(1.5deg);
    position: relative;
    z-index: 3;
    transition: transform .35s var(--easing);
    transform-origin: left bottom;
  }

  .btn-open-card .card-back-layer::before {
    width: 1.21rem;
    height: 1.61rem;
    right: -.09rem;
    top: .24rem;
    transform: translate3d(0, -3%, 0) rotate(-3deg) scale(1);
    transform-origin: left bottom;
  }

  .btn-open-card .card-back-layer::after {
    width: 1.2rem;
    height: 1.7rem;
    right: -.03rem;
    top: .15rem;
    transform: translate3d(0, -2%, 0) rotate(-1.5deg) scale(1);
    transform-origin: left bottom;
  }

  #character .btn-open-card.visible {
    opacity: 1;
    left: 50%;
    pointer-events: fill;
  }

  .btn-open-card.visible>img {
    transform: rotate(0deg);
  }

  #character.activate .btn-open-card {
    animation: floating-ani-s 2s .25s ease-in-out infinite;
  }

  @keyframes floating-ani-s {

    0%,
    100% {
      transform: translate3d(0, 0, 0);
    }

    50% {
      transform: translate3d(0, -3%, 0);
    }
  }

  .btn-open-card .star {
    position: absolute;
    transform: translate3d(-50%, -50%, 0) scale(0);
    opacity: 0;
    transition: all .25s ease-out;
    z-index: 5;
  }

  #character.activate .btn-open-card .star {
    transform: translate3d(-50%, -50%, 0) scale(1);
    opacity: 1;
    transition-delay: .8s;
  }

  .btn-open-card .star::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .btn-open-card .star::before {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    width: 100%;
    top: 50%;
    height: 100%;
    transform: translate3d(-50%, -50%, 0) scale(1);
    background: url(../img/character-pointer-light.png) no-repeat center / contain;
    animation: twinkle-ani 2s ease-out infinite;
  }

  .btn-open-card .star.light-1 {
    width: .37rem;
    left: .4rem;
    top: .11rem
  }

  .btn-open-card .star.light-1::before {
    animation-duration: 2.5s;
    animation-delay: 1.2s
  }

  .btn-open-card .star.light-2 {
    width: .23rem;
    left: 1.21rem;
    top: .39rem
  }

  .btn-open-card .star.light-2::before {
    animation-duration: 1.95s;
    animation-delay: .8s
  }

  .btn-open-card .star.light-3 {
    width: .37rem;
    left: 1.09rem;
    top: 1.43rem
  }

  .btn-open-card .star.light-3::before {
    animation-duration: 2.3s;
    animation-delay: 1.3s
  }

  .btn-open-card .star.light-4 {
    width: .23rem;
    left: .9rem;
    top: 1.6rem
  }

  .btn-open-card .star.light-4::before {
    animation-duration: 2s;
    animation-delay: 1s
  }

  .btn-open-card .star.light-5 {
    width: .14rem;
    left: 1rem;
    top: 1.72rem
  }

  .btn-open-card .star.light-5::before {
    animation-duration: 1.7s;
    animation-delay: .5s
  }

  .btn-open-card .star.light-6 {
    width: .23rem;
    left: .13rem;
    top: 1.86rem
  }

  .btn-open-card .star.light-6::before {
    animation-duration: 1.9s;
    animation-delay: .75s
  }

  .btn-open-card .star.light-7 {
    width: .18rem;
    left: 1.38rem;
    top: 1.14rem
  }

  .btn-open-card .star.light-7::before {
    animation-duration: 2.1s;
    animation-delay: 1s
  }

  .btn-open-card .star.light-8 {
    width: .28rem;
    left: -.05rem;
    top: 1.24rem
  }

  .btn-open-card .star.light-8::before {
    animation-duration: 2.3s;
    animation-delay: .6s
  }

  .btn-open-card .star.light-9 {
    width: .09rem;
    left: 1.46rem;
    top: 1.02rem
  }

  .btn-open-card .star.light-9::before {
    animation-duration: 1.8s;
    animation-delay: .85s
  }

  .btn-open-card .star.light-10 {
    width: .56rem;
    left: -.12rem;
    top: 1.7rem
  }

  .btn-open-card .star.light-10::before {
    animation-duration: 2.65s;
    animation-delay: .9s
  }

  .btn-open-card .star.light-11 {
    width: .37rem;
    left: 1.46rem;
    top: .69rem
  }

  .btn-open-card .star.light-11::before {
    animation-duration: 2.4s;
    animation-delay: 1.1s
  }

}


/* Bio card */
.card-back-layer {
  position: absolute;
  z-index: -1;
  left: 0;
  width: 100%;
  height: 100%;
  top: 0;
  pointer-events: none;
}

.card-back-layer::before,
.card-back-layer::after {
  content: "";
  display: block;
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: right bottom;
  transform-origin: left bottom;
}

.card-back-layer::before {
  background-image: url(../img/character-cntbox-back-02.png);
}

.card-back-layer::after {
  background-image: url(../img/character-cntbox-back-01.png);
}

#character .back-img::before {
  content: "";
  display: block;
  pointer-events: none;
  z-index: -1;
  position: absolute;
  left: 50%;
  top: 50%;
  background: url(../img/character-snowball-effect.png) no-repeat center / contain;
}

.bio-card {
  height: auto;
  transform-origin: left bottom;
  border-radius: calc(var(--card-cutter)*0.225);
  background: linear-gradient(0deg, #0ecfff 0%, #1b4ee2 100%);
  box-shadow: inset -.01rem 0 0 .01rem rgba(0, 41, 151, .5)
}

.bio-card::before,
.bio-card::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  left: 0;
  top: 0;
  pointer-events: none;
  height: 100%;
  border-radius: calc(var(--card-cutter)*0.225);
}

.bio-card::before {
  background: url(../img/character-cntbox-texture.jpg) repeat center top / 100% auto;
  mix-blend-mode: color-burn;
  opacity: .6
}

.bio-card::after {
  mix-blend-mode: overlay;
  box-shadow:
    inset -.02rem -.02rem .02rem .03rem rgba(0, 0, 0, .5),
    inset 0 .01rem .01rem .02rem rgba(255, 255, 255, 1)
}

.bio-card .card-deco {
  position: absolute;
  pointer-events: none;
  left: 50%;
  top: 0;
  width: 100%;
  ;
}

.bio-card .card-deco::before {
  content: "";
  display: block;
  padding-top: 33.3%;
  background: url(../img/character-cntbox-deco.png) no-repeat center top / 100% auto;
  mix-blend-mode: overlay;
}

.bio-card .card-deco::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(../img/character-cntbox-light.png) no-repeat center top / 100% auto;
  mix-blend-mode: overlay;
}

.card-head {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
  color: #fff;
}

.card-head .fullname {
  width: 100%;
  text-align: center;
  vertical-align: middle;
  font-weight: 600;
  letter-spacing: -.025em;
}

.card-body {
  position: relative;
  height: auto;
  margin: 0 auto calc(var(--card-cutter)*.4);
  box-sizing: border-box;
}

.corner-deco {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0;
  pointer-events: none;
}

.card-body::before,
.card-body::after,
.corner-deco::before,
.corner-deco::after {
  content: "";
  width: var(--card-cutter);
  height: var(--card-cutter);
  display: block;
  position: absolute;
  pointer-events: none;
  background: url(../img/character-cntbox-starline.png) no-repeat center / contain
}

.corner-deco::before {
  top: 0;
  left: 0;
  transform: rotateY(180deg);
}

.corner-deco::after {
  top: 0;
  right: 0
}

.card-body::before {
  bottom: 0;
  left: 0;
  transform: rotateX(180deg) rotateY(180deg);
}

.card-body::after {
  bottom: 0;
  right: 0;
  transform: rotateX(180deg);
}

.card-body-content {
  position: relative;
  margin: 0 auto;
  height: auto;
  box-sizing: border-box;
  background: #fff url(../img/character-cntbox-sun.jpg) no-repeat center top / 74.275% auto;
  padding: calc(var(--card-cutter)*.24) calc(var(--card-cutter)*.55);
  clip-path: polygon(0 var(--card-cutter), var(--card-cutter) 0, calc(100% - var(--card-cutter)) 0, 100% var(--card-cutter), 100% calc(100% - var(--card-cutter)), calc(100% - var(--card-cutter)) calc(100% + 1px), var(--card-cutter) calc(100% + 1px), 0 calc(100% - var(--card-cutter)));
}

.card-body-content::before {
  content: "";
  display: block;
  position: absolute;
  pointer-events: none;
  box-sizing: border-box;
  height: 100%;
  display: flex;
  overflow: hidden;
  flex-direction: column;
  z-index: -1;
}

.card-body-content::before {
  left: calc(var(--card-cutter) * 0.1);
  top: calc(var(--card-cutter) * 0.1);
  right: calc(var(--card-cutter) * 0.1);
  bottom: -.015rem;
  border-width: .015rem;
  border-style: solid;
  border-image: linear-gradient(to bottom, #1b4ee2 0%, #0ecfff 100%) 1;
  opacity: .5;
}

.card-body .quote-box {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: var(--hex-text);
}

.card-body .quote-box::before,
.card-body .quote-box::after {
  content: "";
  display: block;
  flex: 1
}

.card-body .quote {
  flex: none;
  text-align: center;
  font-weight: 500;
  letter-spacing: -.025em;
}

.card-body .voice-sound {
  margin: 0 auto;
  position: relative;
  gap: .2rem;
  display: flex;
  height: .45rem;
  z-index: 2;
  align-items: stretch;
  justify-content: center;
}

.card-body .voice-sound::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #88C8FF80;
  z-index: 0;
  pointer-events: none;
  clip-path: polygon(0 .225rem, .2rem 0, calc(100% - .2rem) 0, 100% .225rem, 100% calc(100% - .225rem), calc(100% - .2rem) 100%, .2rem 100%, 0 calc(100% - .225rem));
}

.card-body .voice-sound li {
  display: block;
  flex: none;
  width: fit-content
}

.card-body .voice-sound li:first-child {
  padding-left: .18rem
}

.card-body .voice-sound li>button {
  display: block;
  position: relative;
  padding-right: .48rem;
}

.card-body .voice-sound .actor {
  display: inline-block;
  font-weight: 500;
  letter-spacing: -.025em;
  color: var(--hex-text);
  transition: all .15s ease-in-out
}

.card-body .voice-sound button .icon {
  position: absolute;
  right: 0;
  width: .48rem;
  top: 50%;
  height: .48rem;
  transform: translateY(-50%);
}

.card-body .voice-sound button .icon .circ {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  border-radius: 100%;
  width: .28rem;
  height: .28rem;
  background-color: #008AFF;
  transition: all .15s ease-in-out
}

.card-body .voice-sound button .icon .circ>i {
  opacity: 0;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  box-sizing: border-box;
  border-radius: 100%;
  border-style: solid;
  border-color: #0060ffaa;
  border-width: .015rem;
  transition: opacity .15s var(--easing);
}

.card-body .voice-sound button.on .icon .circ>i {
  animation: sound-wave-ani 1.5s linear infinite;
}

.card-body .voice-sound button.on .icon .circ>i:nth-child(1) {
  animation-delay: .25s;
}

.card-body .voice-sound button.on .icon .circ>i:nth-child(2) {
  animation-delay: .95s;
}

.card-body .voice-sound button .ic-sound-bars {
  gap: .02rem;
  width: .16rem;
  height: .16rem;
  transform-origin: 0 0;
}

.card-body .voice-sound button .ic-sound-bars .bar {
  background: #fff;
  width: .02rem;
}

.card-body .voice-sound .btn-tooltip .ic-sound-bars .bar {
  height: .02rem;
}

.card-body .voice-sound .btn-tooltip .tooltip-box {
  display: none;
  position: absolute;
  top: 100%;
  width: fit-content;
  left: 50%;
  transform: translate3d(-50%, .09rem, 0);
  border-radius: .6rem;
  background: #5B6D87
}

.tooltip-box::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  width: .16rem;
  height: .12rem;
  background: #5B6D87;
  bottom: 100%;
  transform: translate3d(-50%, .01rem, 0);
  clip-path: polygon(calc(50% - .01rem) .01rem, calc(50% + .01rem) .01rem, 100% 100%, 0 100%);
}

.tooltip-box::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translate3d(-50%, 0, 0);
  width: .02rem;
  height: .02rem;
  background: #5B6D87;
  border-radius: 100%;
  top: -.05rem;
}

.card-body .voice-sound .btn-tooltip .tooltip-box>span {
  display: inline-block;
  letter-spacing: -.025em;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
  position: relative
}

.card-body .voice-sound .btn-tooltip .tooltip-box>span::before {
  content: "";
  display: block;
  background: url(../img/ic-warning.png) no-repeat center / contain;
  left: 0;
  top: 0;
  position: absolute;
}

.card-body .voice-sound .btn-tooltip.on .tooltip-box {
  display: block
}

.card-body .voice-sound button.on {
  color: #DCF9FF
}

.card-body .voice-sound button.on .ic-sound-bars .bar {
  animation-name: sound-move-2;
}

.card-body .voice-sound button.on .icon .circ {
  background-color: #0060FF;
}

.card-body .voice-sound button.on .icon .circ>i {
  opacity: 1;
}

.card-body .bio-sheet {
  box-sizing: border-box;
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding-bottom: calc(var(--card-cutter)*.24)
}

.card-body .bio-sheet .bio-sheet-wrap {
  position: relative;
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  padding: calc(var(--card-cutter)*.2);
  border-radius: calc(var(--card-cutter)*.2);
  background: rgb(var(--rgb-white));
}

.card-body .bio-sheet .bio-sheet-wrap::before,
.card-body .bio-sheet .bio-sheet-wrap::after {
  content: "";
  display: block;
  position: absolute;
  pointer-events: none;
  border-color: #e4f0fa;
  border-width: .02rem;
  box-sizing: border-box;
}

.card-body .bio-sheet .bio-sheet-wrap::before {
  left: 0;
  width: 100%;
  height: 100%;
  top: 0;
  border-style: dotted;
  border-radius: calc(var(--card-cutter)*.3);
}

.card-body .bio-sheet .bio-sheet-wrap::after {
  left: .04rem;
  width: calc(100% - .08rem);
  height: calc(100% - .08rem);
  top: .04rem;
  border-style: solid;
  border-radius: calc(var(--card-cutter)*.25);
}

.card-body .bio-sheet .sheet-main {
  position: relative;
  flex: 1;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  box-sizing: border-box;
  background: #F8FCFF;
  border-radius: calc(var(--card-cutter)*.2);
}

.card-body .bio-sheet .sheet-main li {
  display: flex;
  box-sizing: border-box;
  width: 100%;
  align-items: start;
}

.card-body .bio-sheet .sheet-main>li:nth-child(odd) {
  background: #EAF6FF
}

.card-body .bio-sheet .sheet-main>li:first-child {
  border-radius: calc(var(--card-cutter)*.2) calc(var(--card-cutter)*.2) 0 0;
}

.card-body .bio-sheet .sheet-main>li:last-child {
  border-radius: 0 0 calc(var(--card-cutter)*.2) calc(var(--card-cutter)*.2);
}

.card-body .bio-sheet .sheet-main .item-label {
  flex: none;
  position: relative;
  font-weight: 600;
  color: #33559A;
  letter-spacing: -.025em;
}

.card-body .bio-sheet .sheet-main .item-value {
  flex: 1;
  letter-spacing: -.025em;
  font-weight: 500;
  color: var(--hex-text);
}


.card-body .sheet-note {
  flex: none;
}

.card-body .sheet-note>p {
  font-weight: 500;
  letter-spacing: -.025em;
  text-align: center;
  color: #80BBE1;
  position: relative;
}


@media (min-width: 1081px) {
  :root {
    --card-cutter: .5rem;
  }

  #character .character-info {
    display: flex !important;
    flex-direction: column;
    justify-content: start;
  }

  #character .character-info::before,
  #character .character-info::after {
    content: "";
    display: block;
  }

  #character .character-info::before {
    flex: none;
    height: 1rem
  }

  #character .character-info::after {
    flex: 1
  }

  #character .bio-card {
    width: 5.8rem;
    margin-left: .08rem;
  }

  #character .bio-card .card-deco {
    width: 5.66rem;
    margin-left: -2.83rem;
  }

  .card-body {
    width: 5.42rem;
  }

  .card-back-layer::before {
    width: 6.03rem;
    height: 8.06rem;
    right: -.46rem;
    top: 1.52rem;
  }

  .card-back-layer::after {
    width: 6.01rem;
    height: 8.49rem;
    right: -.1rem;
    top: 1.15rem;
  }

  .card-body::before,
  .card-body::after,
  .corner-deco::before,
  .corner-deco::after {
    width: .5rem;
    height: .5rem
  }

  .card-head {
    padding: .36rem 0 .3rem
  }

  .card-body .quote-box {
    min-height: .84rem;
    margin-bottom: .06rem;
  }

  .card-body .quote {
    font-size: .2rem;
    line-height: .3rem;
  }


  .card-body .quote {
    font-size: .2rem;
    line-height: .3rem;
  }

  .card-body .voice-sound {
    width: 4rem;
    margin: 0 auto .22rem;
  }

  .card-body .voice-sound button .ic-sound-bars {
    transform: scaleY(0.75) translate3d(-50%, -50%, 0)
  }

  .card-body .voice-sound .actor {
    font-size: .18rem;
    line-height: .25rem;
    padding: .1rem 0;
  }

  .card-body .bio-sheet .sheet-main li {
    gap: .16rem;
    min-height: .35rem;
    padding: .06rem .16rem;
  }

  .card-body .bio-sheet .sheet-main>li:last-child {
    min-height: 1.1rem
  }

  .card-body .bio-sheet .sheet-main .item-label {
    width: 1.1rem
  }

  .card-body .bio-sheet .sheet-main .item-label,
  .card-body .bio-sheet .sheet-main .item-value {
    font-size: .16rem;
    line-height: .24rem;
  }

  .card-body .sheet-note>p {
    font-size: .15rem;
    line-height: .2rem;
    padding-bottom: .04rem;
    margin-top: -.04rem
  }


  .card-body .voice-sound .btn-tooltip .tooltip-box {
    padding: .12rem .3rem;
  }

  .card-body .voice-sound .btn-tooltip .tooltip-box>span {
    font-size: .14rem;
    line-height: .16rem;
    padding-left: .24rem;
  }

  .card-body .voice-sound .btn-tooltip .tooltip-box>span::before {
    width: .18rem;
    height: .16rem;
  }

  .card-body .voice-sound button:hover .icon .circ {
    background-color: #0060FF;
  }

  .card-body .voice-sound button:hover .icon .circ>i {
    opacity: 1
  }

  .card-body .voice-sound button:hover .icon .circ>i:nth-child(1) {
    width: .38rem;
    height: .38rem
  }

  .card-body .voice-sound button:hover .icon .circ>i:nth-child(2) {
    width: .48rem;
    height: .48rem
  }

  .card-body .voice-sound button.on .icon .circ>i {
    width: .28rem;
    height: .28rem;
    opacity: 0
  }
}


@media (max-width: 1080px) {
  :root {
    --card-cutter: .6rem;
  }

  .inner-popup .bio-card {
    height: 11.05rem;
    max-height: calc(100vh - .96rem);
    width: 100%;
    pointer-events: fill;
    position: relative;
    display: flex;
    overflow: hidden;
    flex-direction: column;
  }

  .inner-popup .bio-card .card-deco {
    width: 6.66rem;
    margin-left: -3.33rem;
  }

  .inner-popup .bio-card .card-head {
    height: 1.3rem;
    flex: none;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .inner-popup .bio-card .card-head::before,
  .inner-popup .bio-card .card-head::after {
    content: "";
    display: block;
  }

  .inner-popup .bio-card .card-head::before {
    flex: 1.6
  }

  .inner-popup .bio-card .card-head::after {
    flex: 0.9
  }

  .inner-popup .card-head .fullname {
    flex: none;
    display: block;
  }

  .inner-popup .bio-card .card-body {
    flex: 1;
    overflow: hidden;
    width: 6.38rem;
  }

  .inner-popup .bio-card .card-body-content {
    height: 100%;
    display: flex;
    flex-direction: column;
  }

  .card-body .quote-box {
    min-height: 1.24rem;
    margin-top: -.08rem
  }

  .card-body .quote {
    font-size: .24rem;
    line-height: .32rem;
  }

  .card-body .voice-sound {
    margin: 0 auto .25rem;
  }

  .card-body .voice-sound button .ic-sound-bars {
    transform: scaleY(0.55) translate3d(-50%, -50%, 0)
  }

  .card-body .voice-sound .actor {
    font-size: .2rem;
    line-height: .25rem;
    padding: .1rem 0;
  }

  .card-body .bio-sheet .sheet-main li {
    gap: .12rem;
    min-height: .3rem;
    padding: .07rem .28rem;
  }

  .card-body .bio-sheet .sheet-main>li:last-child {
    min-height: 1.144rem
  }

  .card-body .bio-sheet .sheet-main .item-label {
    width: 1.1rem
  }

  .card-body .bio-sheet .sheet-main .item-label,
  .card-body .bio-sheet .sheet-main .item-value {
    font-size: .2rem;
    line-height: .3rem;
  }

  .card-body .sheet-note>p {
    font-size: .18rem;
    line-height: .22rem;
    padding-bottom: .06rem;
    margin-top: 0
  }

  .card-body .voice-sound .btn-tooltip .tooltip-box {
    padding: .12rem .3rem;
  }

  .card-body .voice-sound .btn-tooltip .tooltip-box>span {
    font-size: .14rem;
    line-height: .16rem;
    padding-left: .24rem;
  }

  .card-body .voice-sound .btn-tooltip .tooltip-box>span::before {
    width: .18rem;
    height: .16rem;
  }

  .card-body .voice-sound button.on .icon .circ>i {
    width: .28rem;
    height: .28rem;
    opacity: 0
  }
}


.card-back-layer::before,
.card-back-layer::after {
  opacity: 0;
  transition: all .2s 0s var(--easing), opacity .1s .1s var(--easing);
}

.card-back-layer::before {
  transform: translate3d(0, -4%, 0) rotate(1.5deg) scale(.8);
}

.card-back-layer::after {
  transform: translate3d(0, -2%, 0) rotate(4deg) scale(.85);
}

#openBiocardBtn.visible .card-back-layer::before,
#openBiocardBtn.visible .card-back-layer::after,
#character.activate .character-content.visible .card-back-layer::before,
#character.activate .character-content.visible .card-back-layer::after {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  transition-duration: .2s, .15s;
  transition-delay: .1s, .1s;
}

#character .bio-card {
  transform: translate3d(0, -3%, 0) rotate(7.5deg) scale(.9);
  transition: all .2s 0s var(--easing);
}

#character.activate .character-content.visible .bio-card {
  transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
  opacity: 1;
  transition-duration: .25s;
  transition-delay: .1s;
}

#character .character-content {
  opacity: 0;
  transform: translate3d(0, 0, 0);
  transition: all .25s ease-out
}

#character.activate .character-content.visible {
  opacity: 1;
  transition-delay: .25s;
}

#character .snowball-glass {
  transform: translate3d(-7.5%, 0, 0) scale(.85);
  opacity: 0;
  transition: all .45s 0s var(--easing)
}

#character.activate .snowball-glass {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  transition-delay: .1s
}


#character.activate .front-img {
  transform: translate3d(-50%, -42%, 0) scale(.85);
  opacity: 0;
  transition: opacity 0s .15s, transform .25s ease-out
}

#character.activate #character-mov {
  transform: scale(.85);
  opacity: 0;
  animation: character-in-ani .35s .35s var(--bounce) forwards;
}

#character.activate .glass-view::before {
  transform: translate3d(-50%, -50%, 0) rotate(0deg) scale(1);
  opacity: 0;
  mix-blend-mode: overlay;
}

#character .snowball-glass.playing .glass-view::before {
  animation: snowball-effect-ani .7s 0s var(--easing);
}

#character.activate .character-content.visible .front-img {
  transform: translate3d(-50%, -50%, 0) scale(1);
  opacity: 1;
  transition-delay: .15s, .1s;
  transition-duration: .15s, .3s;
}

@keyframes character-in-ani {
  0% {
    opacity: 0;
    transform: scale(.85);
  }

  50% {
    opacity: 1;
  }

  100% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes snowball-effect-ani {
  0% {
    transform: translate3d(-50%, -50%, 0) rotate(0deg) scale(0.85);
    opacity: 0;
  }

  50% {
    transform: translate3d(-50%, -50%, 0) rotate(360deg) scale(1.05);
    opacity: 0.8
  }

  100% {
    transform: translate3d(-50%, -50%, 0) rotate(0deg) scale(1);
    opacity: 0;
  }
}

.character-content .bio-card .card-head,
.character-content .bio-card .card-body {
  opacity: 0;
  transition: opacity .15s ease-out
}

.character-content.visible .bio-card .card-head,
.character-content.visible .bio-card .card-body {
  opacity: 1;
  transition-delay: .55s;
  transition-duration: .35s
}



#character .character-content .sheet-main .item-value,
#characterProfilePop .sheet-main .item-value {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
}

#character.activate .character-content.visible .sheet-main .item-value,
#characterProfilePop.visible .sheet-main .item-value {
  animation: text-appear-ani .55s ease-out forwards
}


#character.activate .character-content.visible .sheet-main li:nth-child(1) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(2) .item-value {
  animation-delay: .8s
}

#character.activate .character-content.visible .sheet-main li:nth-child(3) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(4) .item-value {
  animation-delay: .85s
}

#character.activate .character-content.visible .sheet-main li:nth-child(5) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(6) .item-value {
  animation-delay: .9s
}

#character.activate .character-content.visible .sheet-main li:nth-child(7) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(8) .item-value {
  animation-delay: .95s
}

#character.activate .character-content.visible .sheet-main li:nth-child(9) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(10) .item-value {
  animation-delay: 1s
}

#character.activate .character-content.visible .sheet-main li:nth-child(11) .item-value,
#character.activate .character-content.visible .sheet-main li:nth-child(12) .item-value {
  animation-delay: 1.1s
}

#characterProfilePop.visible .sheet-main li:nth-child(1) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(2) .item-value {
  animation-delay: .45s
}

#characterProfilePop.visible .sheet-main li:nth-child(3) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(4) .item-value {
  animation-delay: .5s
}

#characterProfilePop.visible .sheet-main li:nth-child(5) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(6) .item-value {
  animation-delay: .55s
}

#characterProfilePop.visible .sheet-main li:nth-child(7) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(8) .item-value {
  animation-delay: .6s
}

#characterProfilePop.visible .sheet-main li:nth-child(9) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(10) .item-value {
  animation-delay: .65s
}

#characterProfilePop.visible .sheet-main li:nth-child(11) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(12) .item-value {
  animation-delay: .7s
}


/* goodies */
#goodies .sect-title {
  display: block;
  height: auto;
}

#goodies .common-btn::before,
#goodies .common-btn::after {
  background-image: url(../img/btn-goodies.png);
}

.goodies-buttons .common-btn[data-target-slide] {
  visibility: hidden;
  display: none
}

.goodies-buttons .common-btn[data-target-slide].visible {
  visibility: visible;
  display: block
}

#goodies .category-tab .bg-box {
  background-image: url(../img/goodies-category-bg.png);
}

#goodies .category-tab .bg-box::before {
  background-image: url(../img/goodies-category-bg-start.png);
}

#goodies .category-tab .bg-box::after {
  background-image: url(../img/goodies-category-bg-end.png);
}

#goodies .category-tab .line-box {
  background-image: url(../img/goodies-category-line.png)
}

#goodies .category-tab .line-box::before,
#goodies .category-tab .line-box::after {
  background-image: url(../img/goodies-category-line-start.png);
}

#goodies .category-tab button {
  color: #ABA6DE;
}

#goodies .category-tab button.on,
#goodies .category-tab button.on:hover {
  color: #3234CE;
}


#goodies .goodies-content {
  position: relative;
  z-index: 0;
  margin: 0 auto;
}

#goodies .goodies-content .swiper-container {
  margin: 0 auto;
  overflow: hidden;
}

#goodies .goodies-buttons {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

#goodies .goodies-buttons>.common-btn {
  margin: 0;
  opacity: 0;
  pointer-events: none;
  flex: none
}

#goodies .goodies-buttons>.common-btn.visible {
  opacity: 1;
  pointer-events: auto;
}

#goodies .hill {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 100%;
  pointer-events: none;
}

#goodies .particles {
  position: absolute;
  transform: translate3d(-50%, -50%, 0);
  pointer-events: none;
}

#goodies .particles>img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%
}


#goodies .store {
  position: absolute;
  pointer-events: none;
  left: 50%;
  height: auto;
  transform: translate3d(-50%, -50%, 0)
}

#goodies button[name="goodies-icecream"] {
  position: absolute;
  left: 100%;
  transform-origin: center bottom;
  width: .56rem;
}


#goodies button[name="goodies-icecream"]>span {
  display: block;
  position: relative;
  width: 100%;
  transform-origin: center bottom;
}

#goodies button[name="goodies-icecream"]>span.pink {
  width: 94.64%;
  margin-left: 4%;
  margin-bottom: -28.5%;
  z-index: 3;
}

#goodies button[name="goodies-icecream"]>span.vanilla {
  margin-bottom: -41.935%;
  z-index: 2;
}

#goodies button[name="goodies-icecream"]>span.blue {
  z-index: 1;
}

#goodies button[name="goodies-icecream"]:not(.playing)>span {
  animation: icecream-idle-ani 10s ease-out infinite;
}

#goodies button[name="goodies-icecream"]:not(.playing) .blue {
  animation-delay: 3.45s;
}

#goodies button[name="goodies-icecream"]:not(.playing) .vanilla {
  animation-delay: 3.55s;
}

#goodies button[name="goodies-icecream"]:not(.playing) .pink {
  animation-delay: 3.65s;
}

#goodies button[name="goodies-icecream"].playing>span {
  animation: icecream-move-ani 1s ease-out forwards;
}

#goodies button[name="goodies-icecream"].playing .blue {
  animation-duration: 1.25s;
}

#goodies button[name="goodies-icecream"].playing .vanilla {
  animation-duration: 1.7s;
}

#goodies button[name="goodies-icecream"].playing .pink {
  animation-duration: 2.1s;
}

@keyframes icecream-idle-ani {

  16%,
  21.5%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  18%,
  18.5% {
    transform: translate3d(0, -12.5%, 0) rotate(.5deg);
  }

  19.5% {
    transform: translate3d(0, 5%, 0) rotate(0deg);
  }

  20%,
  20.5% {
    transform: translate3d(0, -7%, 0) rotate(-0.5deg);
  }
}

@keyframes icecream-move-ani {
  0% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }

  2.5%,
  24% {
    transform: translate3d(0, 3.5%, 0) rotate(0deg);
  }

  11.5%,
  13.5% {
    transform: translate3d(0, -200%, 0) rotate(10deg);
  }

  26.5%,
  100% {
    transform: translate3d(0, 0, 0) rotate(0deg);
  }
}


#goodies .swiper-slide {
  position: relative;
}

#goodies .swiper-slide .note {
  position: absolute;
  width: 100%;
  left: 0;
  text-align: center;
  font-weight: 500;
  letter-spacing: -.025em;
  color: #8C7662;
}

#goodies.activate.opened *[data-parallax="true"] {
  transition-duration: .1s !important;
  transition-delay: 0s !important;
  transition-timing-function: ease-out !important;
}

#goodies .macaron {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -35%, 0) scale(.3);
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s var(--easing), transform .5s var(--bounce);
}

#goodies.activate .macaron {
  opacity: 1;
  transform: translate3d(-50%, -50%, 0) scale(1);
  transition-delay: 1s, 1s
}

#goodies.activate .macaron>img {
  animation: floating-ani 2s .35s ease-in-out infinite;
}

#goodies.activate .macaron.violet {
  transition-delay: 1.3s;
  animation-duration: 5.2s
}

#goodies.activate .macaron.pink {
  transition-delay: 1.5s;
  animation-duration: 4.5s;
  animation-direction: reverse;
}

#goodies.activate .macaron.blue {
  transition-delay: 1.65s;
  animation-delay: 3.3s
}

#goodies.activate .macaron.mint {
  transition-delay: 1.8s;
  animation-delay: 2.9s;
  animation-direction: reverse
}

.bubble-group {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0;
  /*transform: translate3d(0, 1rem, 0) scale(.9);*/
  transition: all .4s ease-in-out;
}

#goodies.activate .bubble-group {
  opacity: 1;
  top: 0;
  /*transform: translate3d(0, 0, 0) scaleX(1);*/
  transition-delay: 2.3s
}

#goodies .particles {
  opacity: 0;
  transform: translate3d(-50%, -50%, 0) scale(1.35);
  transition: all 2s var(--easing);
}

#goodies.activate .particles {
  opacity: 1;
  transform: translate3d(-50%, -50%, 0) scale(1);
  transition-delay: 1s
}

.bubble {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0);
  pointer-events: none;
  border-radius: 100%;
}

.bubble::before {
  content: "";
  display: block;
  width: 100%;
  padding-top: 100%;
}

.bubble>i {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  display: block;
  width: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}

.bubble>i:first-child {
  background-image: url(../img/goodies-bubble-multiply.png);
  mix-blend-mode: color-burn;
  opacity: .6
}

.bubble>i:last-child {
  background-image: url(../img/goodies-bubble-overlay.png);
  mix-blend-mode: overlay;
}

.bubble.bb-1 {
  background: radial-gradient(circle at 50% 35%, #ffdab9 30%, #ffc789 95%);
}

.bubble.bb-2 {
  background: radial-gradient(circle at 50% 35%, #faabdd 30%, #f371bd 95%);
}

.bubble.bb-3 {
  background: radial-gradient(circle at 50% 35%, #e1bafb 30%, #d38ef6 95%);
}

.bubble.bb-4 {
  background: radial-gradient(circle at 50% 35%, #f9b9eb 30%, #f48fdc 95%);
}

.bubble.bb-5 {
  background: radial-gradient(circle at 50% 35%, #e4c9fd 30%, #d5a4fa 95%);
}

.bubble.bb-6 {
  background: radial-gradient(circle at 50% 35%, #dfb5fa 30%, #cd7ef5 95%);
}

.bubble.bb-7 {
  background: radial-gradient(circle at 50% 35%, #acd2fa 30%, #72a7f3 95%);
}

.bubble.bb-8 {
  background: radial-gradient(circle at 50% 35%, #a3d8fc 30%, #66b2f9 95%);
}


#goodies .swiper-slide-active .goodies-play-btn {
  pointer-events: auto
}

.buttons-in-slide {
  position: absolute;
  pointer-events: none
}

.goodies-play-btn {
  position: relative;
  pointer-events: none
}

.goodies-play-btn>img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate3d(-50%, -50%, 0)
}

@media (min-width: 1081px) {
  #goodies {
    margin-top: min(-.75rem, -2.923vw, -5.208vh);
  }

  #goodies .bg-cont::before,
  #goodies .sect-cont::before {
    flex: 1.4;
  }

  #goodies .bg-cont::after,
  #goodies .sect-cont::after {
    flex: 1.76
  }

  #goodies .bg-cont-box {
    height: 10.96rem
  }

  #goodies .sect-bg {
    -webkit-mask-image: url(../img/bg-goodies-pc-mask.png);
    mask-image: url(../img/bg-goodies-pc-mask.png);
  }

  #goodies .masked-img {
    height: 14.12rem;
    background-image: url(../img/bg-goodies-pc.jpg)
  }

  #goodies .hill {
    min-width: 25.6rem;
    transform: translate3d(-50%, 0, 0)
  }

  #goodies .store {
    top: 30.383%;
    width: 13.18rem
  }

  #goodies button[name="goodies-icecream"] {
    margin-left: .22rem;
    bottom: -.34rem;
  }

  #goodies .particles {
    width: 19.89rem;
    height: 10.38rem;
    left: 50.273%;
    top: 57.664%
  }

  #goodies .macaron.violet {
    width: 2.92rem;
    margin-left: -6.82rem;
    margin-top: 3.32rem;
  }

  #goodies .macaron.pink {
    width: 1.83rem;
    margin-left: 6.31rem;
    margin-top: -.72rem;
  }

  #goodies .macaron.blue {
    width: 1.26rem;
    margin-left: 7.27rem;
    margin-top: 1.52rem;
  }

  #goodies .macaron.mint {
    width: .92rem;
    margin-left: -7.1rem;
    margin-top: .59rem;
  }

  #goodies .bubble {
    width: .28rem
  }

  #goodies .bubble.bb-1 {
    margin-left: 6.32rem;
    margin-top: 2.64rem;
  }

  #goodies .bubble.bb-2 {
    margin-left: -6.93rem;
    margin-top: -.29rem;
  }

  #goodies .bubble.bb-3 {
    margin-left: -8.92rem;
    margin-top: .72rem;
  }

  #goodies .bubble.bb-4 {
    margin-left: 9.86rem;
    margin-top: .82rem;
  }

  #goodies .bubble.bb-5 {
    width: .2rem;
    margin-left: -7.34rem;
    margin-top: -2.03rem;
  }

  #goodies .bubble.bb-6 {
    width: .2rem;
    margin-left: 7.9rem;
    margin-top: -.74rem;
  }

  #goodies .bubble.bb-7 {
    width: .2rem;
    margin-left: -8.27rem;
    margin-top: 1.95rem;
  }

  #goodies .bubble.bb-8 {
    width: .2rem;
    margin-left: 8.98rem;
    margin-top: 3.14rem;
  }

  #goodies .goodies-content {
    width: 9.24rem;
    margin-top: 1.8rem
  }

  #goodies .sect-title {
    width: 6.13rem;
    margin: 0 auto .45rem;
  }

  #goodies .category-tab button:hover {
    color: #fff;
  }
  #goodies .goodies-nav .swiper-wrapper .swiper-slide {
    display: block;
    flex: 1;
  }

  #goodies .swiper-slide .note {
    bottom: .22rem;
    line-height: .24rem;
    font-size: .18rem
  }

  #goodies .goodies-nav button:hover::before {
    opacity: 1
  }

  #goodies .goodies-nav button:hover>span {
    color: #7D6750
  }

  #goodies .goodies-nav button.on>span {
    color: #fff
  }

  #goodies .goodies-content .swiper-container {
    width: 100%;
    height: 4.8rem;
  }

  #goodies .goodies-buttons {
    padding-top: .92rem;
    padding-bottom: .4rem;
    gap: .3rem
  }

  #goodies .swiper-slide-active .goodies-play-btn:hover>img {
    transform: translate3d(-50%, -50%, 0) scale(1.15)
  }

  #goodies .buttons-in-slide {
    left: .2rem;
    right: .18rem;
    top: .17rem;
    bottom: 1.13rem;
    display: grid;
    grid-template-rows: repeat(2, 1fr);
    grid-template-columns: repeat(6, 1fr)
  }

  .goodies-play-btn>img {
    width: .65rem
  }


  .goodies-play-btn[name="zenith"] {
    grid-column: 1 / 5;
    grid-row: 1 / 3
  }

  .goodies-play-btn[name="tyr"] {
    grid-column: 5/7;
    grid-row: 1 / 2
  }

  .goodies-play-btn[name="darian"] {
    grid-column: 5/7;
    grid-row: 2 / 2
  }

}

@media (max-width: 1080px) {
  #goodies {
    margin-top: min(-.8rem, -7.41vw, -4.79vh);
  }

  #goodies .bg-cont::before,
  #goodies .sect-cont::before {
    flex: 1;
  }

  #goodies .bg-cont::after,
  #goodies .sect-cont::after {
    flex: 1.38
  }

  #goodies .bg-cont-box {
    height: 11.55rem
  }

  #goodies .sect-bg {
    -webkit-mask-image: url(../img/bg-goodies-mo-mask.png);
    mask-image: url(../img/bg-goodies-mo-mask.png);
  }

  #goodies .masked-img {
    height: 16.7rem;
    background-image: url(../img/bg-goodies-mo.jpg)
  }

  #goodies .hill {
    width: 100%;
    transform: translate3d(-50%, 0, 0)
  }

  #goodies .store {
    top: 43.3%;
    width: 9.94rem
  }

  #goodies button[name="goodies-icecream"] {
    margin-left: -.11rem;
    bottom: -.51rem;
  }

  #goodies .particles {
    width: 10.05rem;
    left: 48.98%;
    top: 18%
  }

  #goodies.activate .macaron {
    transform: translate3d(-50%, -50%, 0) scale(1) !important;
  }

  #goodies .macaron.violet {
    width: 2.22rem;
    margin-left: -2.94rem;
    margin-top: 4.45rem;
  }

  #goodies .macaron.pink {
    width: 1.45rem;
    margin-left: 3.22rem;
    margin-top: -.98rem;
  }

  #goodies .macaron.blue {
    width: 1.02rem;
    margin-left: 3.57rem;
    margin-top: 1.69rem;
  }

  #goodies .macaron.mint {
    width: .75rem;
    margin-left: -3.18rem;
    margin-top: .59rem;
  }

  #goodies .bubble {
    width: .27rem
  }

  #goodies .bubble.bb-1 {
    margin-left: 3.31rem;
    margin-top: 4.64rem;
  }

  #goodies .bubble.bb-2 {
    margin-left: -3.05rem;
    margin-top: 2.32rem;
  }

  #goodies .bubble.bb-5 {
    width: .2rem;
    margin-left: -4.1rem;
    margin-top: -1.8rem;
  }

  #goodies .bubble.bb-6 {
    width: .2rem;
    margin-left: 3.15rem;
    margin-top: .32rem;
  }

  #goodies .bubble.bb-7 {
    width: .2rem;
    margin-left: -2.02rem;
    margin-top: 6.12rem;
  }

  #goodies .goodies-content {
    width: 5rem;
    margin-top: 1.52rem
  }

  #goodies .sect-title {
    width: 6.13rem;
    margin: 0 auto .3rem;
  }

  #goodies .goodies-nav .swiper-wrapper .swiper-slide {
    display: block;
    flex: 1;
  }

  #goodies .swiper-slide .note {
    line-height: .24rem;
    font-size: .18rem;
    width: 100%;
    box-sizing: border-box;
  }

  #goodies .swiper-slide[data-name="wallpaper"] .note {
    top: 4.72rem;
  }

  #goodies .swiper-slide[data-name="live-wallpaper"] .note {
    top: 5.36rem;
  }

  #goodies .swiper-slide[data-name="emoticon"] .note {
    top: 5.05rem;
  }

  #goodies .swiper-slide[data-name="profile"] .note {
    top: 5.36rem;
  }
  #goodies .swiper-slide[data-name="voice-message"] .note {
    top: 5.36rem;
  }

  #goodies .goodies-nav button:hover::before {
    opacity: 1
  }

  #goodies .goodies-nav button:hover>span {
    color: #7D6750
  }

  #goodies .goodies-nav button.on>span {
    color: #fff
  }

  #goodies .goodies-content .swiper-container {
    width: 100%;
    height: 5.64rem;
  }

  #goodies .goodies-buttons {
    padding-top: 1.12rem;
    padding-bottom: .34rem;
    gap: .3rem
  }

  #goodies .goodies-play-btn:active>img {
    transform: translate3d(-50%, -50%, 0) scale(.95)
  }

  #goodies .buttons-in-slide {
    left: .18rem;
    right: .2rem;
    top: .17rem;
    bottom: .9rem;
    display: flex;
    flex-direction: column;
  }

  .goodies-play-btn>img {
    width: .65rem
  }

  .goodies-play-btn {
    flex: 1
  }
}

#goodies .masked-img {
  transform: scale(1.5);
  transition: transform 1.5s ease-out;
}

#goodies.activate .masked-img {
  transform: scale(1.1);
  transition-delay: .15s
}

#goodies .hill {
  transform: translate3d(-50%, 20%, 0);
  opacity: 0;
  transition: all .85s var(--easing);
}

#goodies .hill img {
  transform: scale(1.05)
}

#goodies.activate .hill {
  transform: translate3d(-50%, 0, 0);
  opacity: 1;
  transition-delay: .85s
}

#goodies .store {
  transform: translate3d(-50%, -55%, 0);
  opacity: 0;
  transition: all .35s var(--easing);
}

#goodies.activate .store {
  transform: translate3d(-50%, -50%, 0);
  opacity: 1;
  transition-delay: .35s
}


#goodies .sect-title,
#goodies .category-tab {
  opacity: 0;
  transform: translate3d(0, .25rem, 0);
  transition: all .35s var(--easing)
}

#goodies .goodies-content,
#goodies .goodies-buttons {
  opacity: 0;
  transition: all .35s var(--easing)
}

#goodies.activate .sect-title,
#goodies.activate .category-tab,
#goodies.activate .goodies-content,
#goodies.activate .goodies-buttons {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}


#goodies.activate .sect-title {
  transition-delay: .65s;
}

#goodies.activate .category-tab {
  transition-delay: .75s;
}

#goodies.activate .goodies-content,
#goodies.activate .goodies-buttons {
  transition-delay: .9s;
}


/* minigame */

#minigame .sect-title,
#minigame .game-logo,
#minigame .common-btn {
  display: block;
  margin: 0 auto;
  position: relative;
}

#minigame .game-visual {
  position: absolute;
  left: 50%;
  transform: translate3d(-50%, -50%, 0)
}

#minigame .game-visual .kv,
#minigame .game-visual .cursor {
  position: absolute;
}

#minigame.activate .game-visual .cursor {
  animation: minigame-cursor-move 3s .85s var(--easing) forwards;
}

#minigame.activate .game-visual .cursor>img {
  animation: minigame-cursor-ani 5s 5s ease-out infinite;
}

#minigame .game-visual::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain
}

#minigame.activate .game-visual::before {
  animation: game-shadow-ani 4s linear infinite alternate-reverse;
}

@keyframes game-shadow-ani {
  0% {
    opacity: 0
  }

  33% {
    opacity: 0
  }

  66% {
    opacity: 1
  }

  100% {
    opacity: 1
  }
}


#minigame .cloud {
  position: absolute;
  transform: translate3d(0, -40%, 0);
  opacity: 0;
  transition: opacity .4s ease-out, transform .4s ease-out;
}

#minigame.activate .cloud {
  opacity: 1;
  transform: translate3d(0, -50%, 0);
}

#minigame.activate .cloud-1 {
  transition-delay: .3s, .3s
}

#minigame.activate .cloud-1::before {
  animation-direction: reverse;
  animation-duration: 5.5s;
  animation-delay: .4s
}

#minigame.activate .cloud-2 {
  transition-delay: .25s, .25s
}

#minigame.activate .cloud-2::before {
  animation-duration: 4s;
  animation-delay: .35s
}

#minigame.activate .cloud-3 {
  transition-delay: .4s, .4s
}

#minigame.activate .cloud-3::before {
  animation-direction: reverse;
  animation-duration: 4.5s;
  animation-delay: .5s
}

#minigame.activate .cloud-4 {
  transition-delay: .25s, .25s
}

#minigame.activate .cloud-4::before {
  animation-duration: 5s;
  animation-delay: .35s
}

#minigame .star {
  position: absolute;
  opacity: 0;
  transition: opacity .25s ease-out;
}

#minigame.activate .star {
  opacity: 1;
  transition-delay: .5s
}

#minigame .cloud::before,
#minigame .star::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  background-repeat: no-repeat;
}

#minigame .cloud::before {
  height: 100%;
  background-size: contain;
  background-position: center;
}

#minigame.activate .cloud::before {
  animation-name: pixel-cloud-ani;
  animation-timing-function: steps(2);
  animation-iteration-count: infinite;
}

#minigame .star::before {
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding-top: 100%;
  background-position: center top;
}

#minigame.activate .star::before {
  animation-name: pixel-star-twinkle-ani;
  animation-timing-function: steps(1);
  animation-iteration-count: infinite;
}

#minigame .light-1::before {
  background-image: url(../img/minigame-star-01.png);
}

#minigame.activate .light-1::before {
  animation-duration: 1.8s;
  animation-delay: .4s;
}

#minigame .light-2::before {
  background-image: url(../img/minigame-star-02.png)
}

#minigame.activate .light-2::before {
  padding-top: 140%;
  animation-duration: 1.5s;
  animation-delay: .8s;
}

#minigame .light-3::before {
  background-image: url(../img/minigame-star-03.png)
}

#minigame.activate .light-3::before {
  animation-duration: 2.2s;
  animation-delay: .75s;
}

#minigame .light-4::before {
  background-image: url(../img/minigame-star-04.png)
}

#minigame.activate .light-4::before {
  animation-name: pixel-dot-twinkle-ani;
  animation-duration: 1.3s;
  animation-delay: .3s;
}

#minigame .light-5::before {
  background-image: url(../img/minigame-star-05.png)
}

#minigame.activate .light-5::before {
  animation-duration: 1.9s;
  animation-delay: .85s;
}

#minigame .light-6::before {
  background-image: url(../img/minigame-star-06.png)
}

#minigame.activate .light-5::before {
  animation-duration: 1.5s;
  animation-delay: .45s;
}

#minigame .light-7::before {
  background-image: url(../img/minigame-star-01.png)
}

#minigame.activate .light-7::before {
  animation-duration: 2.25s;
  animation-delay: .9s;
}

#minigame .light-8::before {
  background-image: url(../img/minigame-star-03.png)
}

#minigame.activate .light-8::before {
  animation-duration: 2.05s;
  animation-delay: .6s;
}

#minigame .light-9::before {
  background-image: url(../img/minigame-star-04.png)
}

#minigame.activate .light-9::before {
  animation-name: pixel-dot-twinkle-ani;
  animation-duration: 1.1s;
  animation-delay: .4s;
}

#minigame .light-10::before {
  background-image: url(../img/minigame-star-04.png)
}

#minigame.activate .light-10::before {
  animation-name: pixel-dot-twinkle-ani;
  animation-duration: 1.1s;
  animation-delay: .8s;
}

#minigame .light-11::before {
  background-image: url(../img/minigame-star-06.png)
}

#minigame.activate .light-11::before {
  animation-duration: 1.4s;
  animation-delay: .65s;
}

#minigame .light-12::before {
  background-image: url(../img/minigame-star-06.png)
}

#minigame.activate .light-12::before {
  animation-duration: 1.25s;
  animation-delay: .5s;
}

#minigame .light-13::before {
  background-image: url(../img/minigame-star-06.png)
}

#minigame.activate .light-13::before {
  animation-duration: 1.35s;
  animation-delay: .9s;
}


@keyframes pixel-dot-twinkle-ani {
  0% {
    background-position-y: 0
  }

  50%,
  100% {
    background-position-y: 100%
  }
}

@keyframes pixel-star-twinkle-ani {
  0% {
    background-position-y: 0
  }

  35% {
    background-position-y: 50%
  }

  70%,
  100% {
    background-position-y: 100%
  }
}



@media (min-width: 1081px) {
  #minigame {
    margin-top: min(-.7rem, -2.734375vw, -4.8612vh)
  }

  #minigame .bg-cont::before,
  #minigame .sect-cont::before {
    flex: 1.5
  }

  #minigame .bg-cont::after,
  #minigame .sect-cont::after {
    flex: 2.4
  }

  #minigame .sect-bg {
    -webkit-mask-image: url(../img/bg-minigame-pc-mask.png);
    mask-image: url(../img/bg-minigame-pc-mask.png);
  }

  #minigame .masked-img {
    height: 14.5rem;
    background-image: url(../img/bg-minigame-pc.jpg);
    background-position-y: 20%
  }

  #minigame .bg-cont-box {
    height: max(10.03rem, 64.71vh);
    width: max(12.64rem, 81.548vh);
    margin: 0 auto;
    position: relative;
  }

  #minigame .sect-title {
    width: 4.81rem;
  }

  #minigame .game-logo {
    width: 9.8rem;
    margin-top: max(6.34rem, 40.9vh);
    margin-bottom: .46rem
  }

  #minigame .game-visual {
    width: max(12.64rem, 81.548vh);
    left: 51.367%;
    top: 69.691%
  }

  #minigame .game-visual::before {
    background-image: url(../img/minigame-shadow-pc-2.png);
  }

  #minigame .game-visual .kv {
    width: max(10.26rem, 66.193vh);
    left: max(.71rem, 4.581vh);
    top: max(.43rem, 2.7742vh)
  }

  #minigame .game-visual .cursor {
    width: max(.6rem, 3.871vh);
    right: min(-.23rem, -1.484vh);
    top: max(2.7rem, 17.42vh);
  }

  #minigame .cloud-1::before {
    background-image: url(../img/minigame-cloud-pc-01.png)
  }

  #minigame .cloud-2::before {
    background-image: url(../img/minigame-cloud-pc-02.png)
  }

  #minigame .cloud-3::before {
    background-image: url(../img/minigame-cloud-pc-03.png)
  }

  #minigame .cloud-4::before {
    background-image: url(../img/minigame-cloud-pc-04.png)
  }

  #minigame .cloud-1 {
    width: 4.13rem;
    height: 2.57rem;
    right: 0;
    top: 28.4%
  }

  #minigame .cloud-2 {
    width: 3.16rem;
    height: .89rem;
    left: 50%;
    margin-left: 7.6rem;
    top: 47.5%;
  }

  #minigame .cloud-3 {
    width: 4.39rem;
    height: 1.16rem;
    left: 50%;
    margin-left: -12.3rem;
    top: 34.7%
  }

  #minigame .cloud-4 {
    width: 2.49rem;
    height: .6rem;
    left: .45rem;
    top: 19.7%
  }

  #minigame .light-1 {
    width: .54rem;
    left: 82.2785%;
    top: 12%
  }

  #minigame .light-2 {
    width: .3rem;
    left: 3.328%;
    top: 32.9%
  }

  #minigame .light-3 {
    width: .78rem;
    left: 14.715%;
    top: 13.9%
  }

  #minigame .light-4 {
    left: 61.87%;
    top: 25%
  }

  #minigame .light-5 {
    width: .54rem;
    left: 7.912%;
    top: .94%
  }

  #minigame .light-6 {
    left: 50%;
    top: 13.4%
  }

  #minigame .light-7 {
    width: .27rem;
    left: -.08%;
    top: 37.4%
  }

  #minigame .light-8 {
    width: .55rem;
    left: 94.065%;
    top: 40.5%
  }

  #minigame .light-9 {
    left: 26.582%;
    top: 17.8%
  }

  #minigame .light-10 {
    left: 69.62%;
    top: 13.1%
  }

  #minigame .light-11 {
    left: 10.05%;
    top: 18%
  }

  #minigame .light-12 {
    left: 97.15%;
    top: 23.4%
  }

  #minigame .light-13 {
    left: 101.11%;
    top: 46%
  }

  #minigame .light-4,
  #minigame .light-9,
  #minigame .light-10 {
    width: .18rem
  }

  #minigame .light-6,
  #minigame .light-11,
  #minigame .light-12,
  #minigame .light-13 {
    width: .14rem
  }


  @media (min-height: 1550px) {

    #minigame .bg-cont::before,
    #minigame .sect-cont::before,
    #minigame .bg-cont::after,
    #minigame .sect-cont::after {
      flex: 1
    }
  }


  @keyframes minigame-cursor-move {
    0% {
      opacity: 0;
      margin-right: max(1.55rem, 10vh);
      margin-top: min(-2.4rem, -15.484vh);
      transform: translate3d(0, 0, 0) rotate(-360deg);
    }

    25% {
      margin-right: 0;
      margin-top: min(-2.4rem, -15.484vh);
      transform: translate3d(0, 0, 0) rotate(-720deg);
      opacity: 1;
    }

    100% {
      margin-right: 0;
      margin-top: 0;
      transform: translate3d(0, 0, 0) rotate(0deg);
    }
  }

  @keyframes minigame-cursor-ani {

    0%,
    20% {
      transform: translate3d(0, 0, 0) rotate(0deg);
    }

    40%,
    60% {
      transform: translate3d(0, -250%, 0) rotate(-720deg);
    }

    100% {
      transform: translate3d(0, 0, 0) rotate(0deg);
    }
  }

  @keyframes pixel-cloud-ani {
    0% {
      transform: translate3d(0, 0, 0)
    }

    25% {
      transform: translate3d(0, -.2rem, 0)
    }

    50% {
      transform: translate3d(0, 0, 0)
    }

    75% {
      transform: translate3d(0, .2rem, 0)
    }

    90%,
    100% {
      transform: translate3d(0, 0, 0)
    }
  }

}

@media (max-width: 1080px) {
  #minigame {
    margin-top: min(-.55rem, -5.0926vw, -3.5484vh)
  }


  #minigame .bg-cont::before,
  #minigame .sect-cont::before {
    flex: 1.9
  }

  #minigame .bg-cont::after,
  #minigame .sect-cont::after {
    flex: 2.5
  }

  #minigame .sect-bg {
    pointer-events: auto;
    -webkit-mask-image: url(../img/bg-minigame-mo-mask.png);
    mask-image: url(../img/bg-minigame-mo-mask.png);
  }

  #minigame .masked-img {
    height: 15.5rem;
    background-image: url(../img/bg-minigame-mo.jpg);
    background-position-y: 20%
  }

  #minigame .bg-cont-box {
    height: 11.04rem
  }

  #minigame .sect-title {
    width: 4.81rem;
  }

  #minigame .game-logo {
    width: 5.97rem;
    margin-top: 6.5rem;
    margin-bottom: .76rem
  }

  #minigame .game-visual {
    width: 10.8rem;
    left: 50%;
    top: 70.925%;
  }

  #minigame .game-visual>img {
    width: 9.76rem;
    margin-left: .89rem;
    display: block
  }

  #minigame .game-visual::before {
    pointer-events: none;
    width: 9.76rem;
    margin-left: .89rem;
    background-image: url(../img/minigame-shadow-mo-2.png);
  }

  #minigame .game-visual::after {
    pointer-events: none;
    content: "";
    display: block;
    bottom: 0;
    width: 100%;
    left: 0;
    height: 100%;
    background: url(../img/minigame-shadow-mo-cloud.png) no-repeat center bottom;
    background-size: contain;
    position: absolute;
  }

  #minigame .game-visual .kv {
    width: 7.14rem;
    left: 50%;
    margin-left: -3.6rem;
    top: .17rem
  }

  #minigame .game-visual .cursor {
    width: .71rem;
    right: .26rem;
    top: 2.15rem;
  }

  #minigame .cloud-1::before {
    background-image: url(../img/minigame-cloud-mo-01.png)
  }

  #minigame .cloud-2::before {
    background-image: url(../img/minigame-cloud-mo-02.png)
  }

  #minigame .cloud-3::before {
    background-image: url(../img/minigame-cloud-mo-03.png)
  }

  #minigame .cloud-4::before {
    background-image: url(../img/minigame-cloud-mo-04.png)
  }

  #minigame .cloud-1 {
    width: .84rem;
    height: .32rem;
    right: 0;
    top: 33.2%
  }

  #minigame .cloud-2 {
    width: 1.92rem;
    height: .54rem;
    left: 50%;
    margin-left: 2.83rem;
    top: 17.375%
  }

  #minigame .cloud-3 {
    width: .87rem;
    height: .22rem;
    left: 50%;
    margin-left: -3.34rem;
    top: 11.86%
  }

  #minigame .cloud-4 {
    width: 1.42rem;
    height: .55rem;
    left: 0;
    top: 27.87%
  }

  #minigame .star {
    left: 50%
  }

  #minigame .light-1 {
    width: .43rem;
    margin-left: 2.3rem;
    top: 11.946%
  }

  #minigame .light-2 {
    width: .3rem;
    margin-left: -4.78rem;
    top: 16.28%
  }

  #minigame .light-3 {
    width: .62rem;
    margin-left: -2rem;
    top: 14.57%
  }

  #minigame .light-4 {
    margin-left: 1.76rem;
    top: 21.8%
  }

  #minigame .light-5 {
    width: .43rem;
    margin-left: -3.34rem;
    top: -2.353%
  }

  #minigame .light-6 {
    margin-left: .34rem;
    top: 11.674%
  }

  #minigame .light-7 {
    width: .27rem;
    margin-left: -4.29rem;
    top: 34.3%
  }

  #minigame .light-8 {
    width: .39rem;
    margin-left: 4.12rem;
    top: 22.534%
  }

  #minigame .light-9 {
    margin-left: 3.25rem;
    top: 2.715%
  }

  #minigame .light-10 {
    margin-left: -3.2rem;
    top: 22.172%
  }

  #minigame .light-11 {
    margin-left: -2.96rem;
    top: 2.986%
  }

  #minigame .light-12 {
    margin-left: 4.94rem;
    top: 12.67%
  }

  #minigame .light-13 {
    margin-left: 4.06rem;
    top: 41.448%
  }

  #minigame .light-4,
  #minigame .light-9,
  #minigame .light-10 {
    width: .18rem
  }

  #minigame .light-6,
  #minigame .light-11,
  #minigame .light-12,
  #minigame .light-13 {
    width: .14rem
  }

  @keyframes minigame-cursor-move {
    0% {
      opacity: 0;
      transform: translate3d(80%, 0, 0) rotate(-360deg);
    }

    35% {
      transform: translate3d(0, 0, 0) rotate(-720deg);
      opacity: 1;
    }

    100% {
      transform: translate3d(0, 150%, 0) rotate(0deg);
    }
  }

  @keyframes minigame-cursor-ani {

    0%,
    20% {
      transform: translate3d(0, 0, 0) rotate(0deg);
    }

    40%,
    60% {
      transform: translate3d(0, -150%, 0) rotate(-720deg);
    }

    100% {
      transform: translate3d(0, 0, 0) rotate(0deg);
    }
  }

  @keyframes pixel-cloud-ani {
    0% {
      transform: translate3d(0, 0, 0)
    }

    25% {
      transform: translate3d(0, -.1rem, 0)
    }

    50% {
      transform: translate3d(0, 0, 0)
    }

    75% {
      transform: translate3d(0, .1rem, 0)
    }

    90%,
    100% {
      transform: translate3d(0, 0, 0)
    }
  }
}



#minigame .sect-bg {
  pointer-events: auto;
}

#minigame .sect-cont {
  pointer-events: none;
}

#minigame .sect-title,
#minigame .common-btn {
  opacity: 0;
  transform: translate3d(0, .25rem, 0);
  transition: all .35s var(--easing)
}

#minigame .kv,
#minigame .game-logo {
  opacity: 0;
  transform: scale(1.05);
  transition: all .35s var(--easing)
}

#minigame.activate .kv,
#minigame.activate .game-logo {
  transition-duration: .45s;
}

#minigame .kv .cursor {
  opacity: 0;
  z-index: 10;
  transition: opacity .15s var(--easing)
}

#minigame .kv .cursor>img {
  pointer-events: fill;
  cursor: pointer;
}

#minigame.activate .sect-title,
#minigame.activate .kv,
#minigame.activate .game-logo,
#minigame.activate .common-btn {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

#minigame.activate .sect-title {
  transition-delay: .35s;
}

#minigame.activate .kv {
  transition-delay: .5s;
}

#minigame.shutter .kv>img {
  animation: minigame-shutter .3s var(--easing) forwards;
  animation-delay: 0s;
}

#minigame.shutter .game-logo>img {
  animation: minigame-shutter .35s .2s var(--easing) forwards;
}

#minigame.activate .game-logo {
  transition-delay: .6s;
}

#minigame.activate .common-btn {
  transition-delay: .8s;
}

#minigame.activate .kv .cursor {
  opacity: 1;
  transition-delay: 1s
}

@keyframes minigame-shutter {
  0% {
    filter: brightness(1) blur(0);
  }

  50% {
    filter: brightness(1.2) blur(.03rem)
  }

  100% {
    filter: brightness(1) blur(0);
  }
}


/* layer */
.inner-layer,
.modal-layer {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  flex-direction: column;
  align-items: center;
  z-index: 3000;
}

.modal-layer.visible {
  display: flex
}

@media (max-width: 1080px) {
  .inner-layer.visible {
    display: block
  }
}

.inner-dim,
.modal-dim {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 5;
  pointer-events: none;
  background: rgba(0, 0, 0, .7);
  transition: opacity .25s ease-out
}

.inner-layer.visible .inner-dim,
.modal-layer.visible .modal-dim {
  pointer-events: fill;
  opacity: 1
}

.inner-layer .btn-close,
.modal-layer .btn-close {
  position: absolute;
  bottom: 100%;
  width: .34rem;
  right: 0;
  margin-bottom: .18rem
}

.inner-layer .btn-close {
  right: .1rem;
  pointer-events: fill
}

.inner-popup {
  display: none;
  z-index: 10;
  position: absolute;
  left: 50%;
  top: calc(50% + .2rem);
  transform: translate3d(-50%, -50%, 0);
  width: 6.84rem;
  pointer-events: none;
}


.modal-popup {
  display: none;
  z-index: 10;
  position: absolute;
  left: 50%;
  top: calc(50% + .2rem);
  transform: translate3d(-50%, -50%, 0);
  margin: 0 auto;
  height: auto;
  max-height: max(calc(100% - .8rem), 6.4rem);
  width: 6.4rem;
  border-radius: .16rem;
  padding: .04rem;
  pointer-events: none;
  box-sizing: border-box;
  color: #1d1d1d;
}

.inner-popup.visible {
  display: block;
}

.modal-popup.visible {
  display: block;
  pointer-events: auto;
}

.modal-popup::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  background: #fff;
  border-radius: .16rem;
  background: linear-gradient(180deg, #BFE6FF 0%, #91D9FF 100%);
}

.modal-popup .popup-content {
  width: 100%;
  display: block;
  position: relative;
  border-radius: .13rem;
  box-sizing: border-box;
  padding: .5rem .3rem;
  background: url(../img/popup-deco-left.png) no-repeat left bottom / 2.5rem 1.6rem, url(../img/popup-deco-right.png) no-repeat right bottom / 2.5rem 1.6rem, #fff;
}


.modal-popup.no-frame {
  width: 12.8rem;
  max-width: 94%;
  max-height: none;
  border-radius: 0;
  padding: 0;
}

.modal-popup.no-frame::before {
  display: none
}

.modal-popup.no-frame .popup-content {
  background: none;
  padding: 56.25% 0 0;
  width: 100%;
  overflow: hidden;
  border-radius: 0;
}

.modal-popup.no-frame .popup-content>iframe,
.modal-popup.no-frame .popup-content>div {
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  top: 0;
}


.modal-popup.alert {
  width: 5rem;
}

.modal-popup.alert .face {
  display: block;
  width: 1.4rem;
  margin: .06rem auto .04rem
}


.alert-title {
  color: #0070BE;
  font-weight: 600;
  letter-spacing: -.05em;
  text-align: center;
}

.alert-title>span {
  display: inline-block;
  position: relative;
  padding: 0 .08rem
}

.alert-title>span::before,
.alert-title>span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: .23rem;
  background: url(../img/popup-title-deco.png) no-repeat center / 100% auto;
}


.alert-title>span::before {
  right: 100%
}

.alert-title>span::after {
  left: 100%;
  transform: rotateY(180deg)
}

.alert-words {
  text-align: center;
  letter-spacing: -.025em;
  font-weight: 500;
  color: #18272E
}

.alert-msg {
  text-align: center;
  letter-spacing: -.025em;
  font-weight: 500;
  color: #3DA0D3
}

.popup-content .popup-title {
  display: block;
  font-weight: 600;
  letter-spacing: -.05em;
  color: #0070BE;
  text-align: center
}

.popup-content .popup-desc {
  display: block;
  font-weight: 500;
  letter-spacing: -.05em;
  text-align: center
}

.popup-content .legal-notice li,
.popup-content .legal-notice dt,
.popup-content .legal-notice dd {
  color: #1d1d1d;
  letter-spacing: -.025em;
  font-weight: 500;
}

.popup-content .legal-notice dt {
  font-weight: 600
}



.popup-content .has-bullet li::before {
  content: "•";
  font: inherit;
  position: absolute;
  left: -.25em;
  top: 0;
}

.popup-content .has-bullet li[data-bullet]::before {
  content: attr(data-bullet)
}

.popup-content .has-bullet li {
  padding-left: 1em;
  position: relative;
}

.popup-content.for-launcher {
  max-height: min(9.4rem, calc(100vh - 1rem));
  display: flex;
  flex-direction: column;
}

.scroll-box-wrapper {
  background: #E5F6FD;
  border-radius: .12rem;
  box-sizing: border-box;
  padding: .16rem .1rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.scroll-box {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  padding: .14rem .2rem
}

.scroll-box::-webkit-scrollbar {
  width: .06rem;
  height: .06rem;
}

.scroll-box::-webkit-scrollbar-track {
  background: #CBDFED;
  border-radius: .06rem;
}

.scroll-box::-webkit-scrollbar-thumb {
  background-color: #A6CAE3;
  /* 은은한 회색 블루톤 */
  border-radius: .06rem;
  border: .03rem solid #A6CAE3;
}

.scroll-box::-webkit-scrollbar-thumb:hover {
  background-color: #7b97b1;
}


/* 런처 팝업*/
.popup-content.for-launcher {
  display: flex;
  width: 100%;
  overflow: hidden;
  flex-direction: column;
  align-items: center;
}

.popup-content.for-launcher .popup-title,
.popup-content.for-launcher .popup-desc,
.popup-content.for-launcher .info-notice {
  flex: none;
}

.popup-content .scroll-box-wrapper {
  flex: 1;
}

.popup-content .install-guide>p {
  font-size: .16rem;
  line-height: .19rem;
  font-weight: 500;
  color: #000;
  padding-bottom: .06rem
}

.popup-content .install-guide>ul {
  padding: .04rem .05rem .2rem
}

.popup-content .install-guide>ul:last-child {
  padding-bottom: 0
}

.popup-content .install-guide>ul li {
  font-size: .16rem;
  line-height: .22rem;
  font-weight: 500;
  color: #31A7EE
}

.popup-content .install-guide>ul li+li {
  margin-top: .08rem
}

.popup-content .popup-desc {
  font-size: .18rem;
  line-height: .24rem;
  padding: .2rem 0 .24rem
}

.popup-content .info-notice {
  padding: .24rem .1rem .3rem 0
}

.popup-content .info-notice>li {
  color: #5894BA;
  font-size: .14rem;
  line-height: .2rem;
  font-weight: 500
}

.popup-content .info-notice>li+li {
  margin-top: .1rem
}

.popup-content .btn-launcher {
  display: block;
  width: 2.44rem;
  margin: 0 auto
}

.inner-layer .btn-close>img,
.modal-layer .btn-close>img {
  transform: rotate(0deg);
  transition: transform .35s ease-in-out
}

.msg-block button {
  display: block;
  margin: .3rem auto .12rem
}

.msg-block button+.alert-msg {
  margin: 0;
  padding: 0
}

@media (min-width: 1081px) {

  .inner-layer .btn-close:hover>img,
  .modal-layer .btn-close:hover>img {
    transform: rotate(180deg)
  }

  .popup-content .popup-title {
    font-size: .26rem;
    line-height: .3rem;
    padding-bottom: .04rem
  }

  .popup-content .alert-title {
    font-size: .32rem;
    line-height: .36rem;
    padding-bottom: .02rem
  }

  .alert-title>span::before,
  .alert-title>span::after {
    height: .38rem;
  }

  .modal-popup.alert .face {
    margin: .1rem auto .08rem
  }

  .popup-content .legal-notice {
    padding: .3rem .2rem 0 .1rem;
  }

  .popup-content .legal-notice li+li,
  .popup-content .legal-notice dd+dt {
    margin-top: .2rem
  }

  .popup-content .legal-notice>li,
  .popup-content .legal-notice>dt,
  .popup-content .legal-notice>dd {
    font-size: .16rem;
    line-height: .24rem;
  }

  .popup-content .legal-notice dt {
    font-weight: 600
  }

  .alert-words {
    font-size: .2rem;
    line-height: .24rem;
  }

  .alert-msg {
    font-size: .16rem;
    line-height: .19rem;
    padding-top: .02rem;
    margin-top: .1rem
  }

  .face+.alert-msg {
    margin-top: 0;
    padding-top: .02rem;
    padding-bottom: .1rem
  }

  .msg-block button {
    width: 1.76rem;
  }
}

@media (max-width: 1080px) {

  .popup-content .popup-title,
  .popup-content .alert-title {
    font-size: .36rem;
    line-height: .42rem
  }

  .alert-title>span::before,
  .alert-title>span::after {
    height: .42rem;
  }

  .modal-popup.alert .face {
    margin: .1rem auto .08rem
  }


  .popup-content .popup-title br {
    display: none
  }

  .popup-content .legal-notice {
    padding: .4rem .2rem 0 .2rem;
  }

  .popup-content .legal-notice li+li {
    margin-top: .3rem
  }

  .popup-content .legal-notice dd+dt {
    margin-top: .2rem
  }

  .popup-content ul.legal-notice {
    padding-left: .2rem;
  }

  .popup-content .legal-notice>li,
  .popup-content .legal-notice>dt,
  .popup-content .legal-notice>dd {
    font-size: .2rem;
    line-height: .28rem;
  }

  .alert-words {
    font-size: .22rem;
    line-height: .26rem;
  }

  .alert-msg {
    font-size: .2rem;
    line-height: .24rem;
    margin-top: .09rem
  }

  .face+.alert-msg {
    margin-top: 0;
    padding-top: 0;
    padding-bottom: .1rem
  }

  .msg-block button {
    width: 2rem;
  }
}


/* title light */
.sect-title {
  position: relative;
  overflow: hidden
}

.sect-title .light {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  mix-blend-mode: plus-lighter;
}

.evt-section.activate .sect-title .light::before {
  content: "";
  display: block;
  position: absolute;
  height: 200%;
  width: 200%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, .35) 50%, rgba(255, 255, 255, 0) 80%);
  transform: rotate(-30deg);
  top: -200%;
  left: -200%;
  animation: title-light-move 9s ease-in infinite;
}

#main .sect-title .light {
  -webkit-mask-image: url(../img/main-title-02.png);
  mask-image: url(../img/main-title-02.png);
}

#main .sect-title .light::before {
  animation-duration: 10s;
}

#whatsnew .sect-title .light {
  -webkit-mask-image: url(../img/whatsnew-title.png);
  mask-image: url(../img/whatsnew-title.png);
}

#whatsnew .sect-title .light::before {
  animation-duration: 9s;
}

#goodies .sect-title .light {
  -webkit-mask-image: url(../img/goodies-title.png);
  mask-image: url(../img/goodies-title.png);
}

#goodies .sect-title .light::before {
  animation-duration: 11s;
}

#minigame .sect-title .light {
  -webkit-mask-image: url(../img/minigame-title.png);
  mask-image: url(../img/minigame-title.png);
}

#minigame .sect-title .light::before {
  animation-duration: 9.5s;
}

@keyframes title-light-move {

  0% {
    top: -200%;
    left: -200%;
    opacity: 0
  }

  40% {
    top: -200%;
    left: -200%;
    opacity: 1
  }

  75% {
    top: 200%;
    left: 200%;
    opacity: 1
  }

  100% {
    top: 200%;
    left: 200%;
    opacity: 0
  }
}


/* animation */
@keyframes sound-wave-ani {
  0% {
    opacity: 1;
    width: .28rem;
    height: .28rem;
  }

  75% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    width: .48rem;
    height: .48rem
  }
}


@keyframes sound-move-2 {

  0%,
  100% {
    transform: scaleY(1)
  }

  50% {
    transform: scaleY(0.5)
  }
}

@keyframes sound-move {

  0%,
  100% {
    transform: scaleY(1)
  }

  20% {
    transform: scaleY(0.7)
  }

  80% {
    transform: scaleY(1.3)
  }
}

@keyframes floating-ani {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-4%);
  }
}


@keyframes twinkle-ani {

  0%,
  10%,
  80%,
  100% {
    transform: translate3d(-50%, -50%, 0) scale(1);
    opacity: 1;
  }

  45%,
  55% {
    transform: translate3d(-50%, -50%, 0) scale(.3);
    opacity: .1;
  }
}

@keyframes text-appear-ani {
  0% {
    clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }

  100% {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}


@keyframes zoom-point-blinking {

  0%,
  20% {
    opacity: .4;
  }

  100% {
    opacity: 1;
  }
}

@keyframes zoom-point-active {
  0% {
    transform: scale(1);
    opacity: .5;
  }

  30% {
    transform: scale(.7);
    opacity: 1;
  }

  100% {
    opacity: 1;
    transform: scale(1.3);
  }
}

@keyframes zoomin-box-deco {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}


/* 삼성 브라우저 텍스트 투명 처리 */
.is-samsung-brw .radio-btn>label,
.is-samsung-brw #main .register-box label>span {
  background: #000;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}