@charset "utf-8";

:root {
  --bounce: cubic-bezier(.33, 1.5, .68, 1);
  --theme-gradient: linear-gradient(132.27deg, #0053FC 14.84%, #00DEFF 85.67%);
  --theme-stroke: #1860D7;
  --text-gradient: linear-gradient(90deg, #0060FF 0%, #008AFF 27.88%, #00DCA0 100%);
}

/* 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(255, 255, 255, .5);
  backdrop-filter: blur(5px);
  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
}

.evt-section>.sect-cont {
  position: absolute;
  left: 0;
  top: var(--header-height);
  width: 100%;
  bottom: 0;
  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
}

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

.evt-navigation .evt-menu {
  background: rgba(255, 255, 255, .7);
}

.evt-navigation .circ {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  border-radius: 100%;
  transform: scale(.5);
  background: var(--theme-gradient);
  transition: all .25s var(--bounce);
}

.evt-navigation .on .circ {
  opacity: 1;
  transform: scale(1);
}

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

.evt-menu>li .icon {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-radius: 100%;
  background: transparent;
}

.evt-menu>li .icon::before,
.evt-menu>li .icon::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  background-repeat: no-repeat;
  background-position: center;
  transition: all .25s var(--easing)
}

.evt-menu>li .icon::before {
  opacity: 1;
}

.evt-menu>li .icon::after {
  opacity: 0;
}

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

.evt-menu>li>a::before {
  content: "";
  display: block;
  padding-top: 100%;
}

.evt-menu>li a.on .icon::before {
  opacity: 0;
}

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

.evt-menu>li a.on .icon::after {
  filter: grayscale(1) brightness(10);
}

.evt-menu>li .name {
  position: absolute;
  height: auto;
  background: #0045F3E5;
  color: #fff;
  font-weight: 600;
  font-size: .18rem;
  line-height: .21rem;
  text-align: center;
  height: auto;
  border-radius: .28rem;
  box-sizing: border-box;
  opacity: 0;
  transition: all .15s var(--easing)
}

.evt-menu>li a.on .name {
  background: linear-gradient(96.29deg, rgba(0, 83, 252, 0.9) 8.69%, rgba(0, 162, 255, 0.9) 91.31%);
}

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

.evt-navigation .btn-sound {
  border-radius: 100%;
  width: 100%;
  background-color: rgba(255, 255, 255, .7);
  box-sizing: border-box;
  padding: .04rem;
}

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

.evt-navigation .btn-sound .icon::before {
  content: "";
  display: block;
  padding-top: 100%;
}

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


.evt-menu>li a[data-scroll-to="main"] .icon::before,
.evt-menu>li a[data-scroll-to="main"] .icon::after {
  background-size: 61.54% auto;
  background-position-y: 48%;
}

.evt-menu>li a[data-scroll-to="main"] .icon::before {
  background-image: url(../img/nav-ic-main-gradient.svg)
}

.evt-menu>li a[data-scroll-to="main"] .icon::after {
  background-image: url(../img/nav-ic-main-filled.svg)
}

.evt-menu>li a[data-scroll-to="roadmap"] .icon::before,
.evt-menu>li a[data-scroll-to="roadmap"] .icon::after {
  background-size: 51.923% auto;
  background-position-y: 45%;
}

.evt-menu>li a[data-scroll-to="roadmap"] .icon::before {
  background-image: url(../img/nav-ic-roadmap-gradient.svg)
}

.evt-menu>li a[data-scroll-to="roadmap"] .icon::after {
  background-image: url(../img/nav-ic-roadmap-filled.svg)
}

.evt-menu>li a[data-scroll-to="character"] .icon::before,
.evt-menu>li a[data-scroll-to="character"] .icon::after {
  background-size: 67.31% auto;
}

.evt-menu>li a[data-scroll-to="character"] .icon::before {
  background-image: url(../img/nav-ic-character-gradient.svg)
}

.evt-menu>li a[data-scroll-to="character"] .icon::after {
  background-image: url(../img/nav-ic-character-filled.svg)
}

.evt-menu>li a[data-scroll-to="goodies"] .icon::before,
.evt-menu>li a[data-scroll-to="goodies"] .icon::after {
  background-size: 55.77% auto;
  background-position-y: 47.5%;
}

.evt-menu>li a[data-scroll-to="goodies"] .icon::before {
  background-image: url(../img/nav-ic-goodies-gradient.svg)
}

.evt-menu>li a[data-scroll-to="goodies"] .icon::after {
  background-image: url(../img/nav-ic-goodies-filled.svg)
}

.evt-menu>li a[data-scroll-to="minigame"] .icon::before,
.evt-menu>li a[data-scroll-to="minigame"] .icon::after {
  background-size: 55.77% auto;
  background-position-y: 47.5%;
  background-position-x: 47.5%;
}

.evt-menu>li a[data-scroll-to="minigame"] .icon::before {
  background-image: url(../img/nav-ic-minigame-gradient.svg)
}

.evt-menu>li a[data-scroll-to="minigame"] .icon::after {
  background-image: url(../img/nav-ic-minigame-filled.svg)
}

.ic-sound-bars {
  -webkit-mask-image: var(--theme-gradient);
  -webkit-mask-size: cover;
  mask-image: var(--theme-gradient);
  mask-size: cover;
}

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

.ic-sound-bars .bar {
  display: block;
  flex: none;
  width: .03rem;
  border-radius: .015rem;
  background-image: url(../img/gradient.jpg);
  background-repeat: no-repeat;
  background-size: .3rem auto;
  background-position-y: center;
  transition: transform .25s ease-out;
}

.ic-sound-bars .bar:nth-child(1) {
  height: .06rem;
  background-position-x: -.035rem
}

.ic-sound-bars .bar:nth-child(2) {
  height: .12rem;
  background-position-x: -.085rem
}

.ic-sound-bars .bar:nth-child(3) {
  height: .08rem;
  background-position-x: -.135rem
}

.ic-sound-bars .bar:nth-child(4) {
  height: .16rem;
  background-position-x: -.185rem
}

.ic-sound-bars .bar:nth-child(5) {
  height: .08rem;
  background-position-x: -.235rem
}

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

.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;
}

.gradient-txt {
  background: var(--text-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.icons-bg {
  background: var(--theme-gradient);
}

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

.common-btn>span {
  display: inline-block;
  width: auto;
  color: #fff;
  position: relative;
  z-index: 1;
  font-weight: 600;
  font-size: .26rem;
  line-height: .32rem;
  letter-spacing: -.025em;
  text-shadow: 0 .03rem 0 #00317A
}

a.common-btn>span {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}

.common-btn::before,
.common-btn::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
  background-repeat: no-repeat;
  background-position-x: center;
  background-size: 100% auto
}

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

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

.txt.has-stroke {
  position: relative;
  display: inline-block;
  z-index: 1;
  color: #fff
}

.txt.has-stroke::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: -1;
  color: transparent;
  -webkit-text-stroke: .03rem var(--theme-stroke);
  text-shadow:
    -.03rem 0 var(--theme-stroke),
    .03rem 0 var(--theme-stroke),
    0 -.03rem var(--theme-stroke),
    0 .03rem var(--theme-stroke),
    -.02rem -.02rem var(--theme-stroke),
    .02rem -.02rem var(--theme-stroke),
    -.02rem .02rem var(--theme-stroke),
    .02rem .02rem var(--theme-stroke);
}

.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;
  opacity: .6;
  background: #000528;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  border-radius: .6rem
}

.typo-words .bg::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  width: .2rem;
  height: .16rem;
  background: #000528;
}

.typo-words .bg::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: .044rem;
  height: .044rem;
  background: #000528;
  border-radius: 100%;
}

.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="top"] .bg::after {
  top: -.14rem;
}

.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[data-tail="bottom"] .bg::after {
  bottom: -.14rem;
}

.typo-words .text {
  display: block;
  position: relative;
  font-weight: 500;
  font-size: .24rem;
  line-height: .29rem;
  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%
}

.user-select .divider {
  display: inline-block;
  vertical-align: middle;
  position: relative;
  flex: none;
}

.user-select .divider::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: .01rem;
  height: .18rem;
  transform: translate(-50%, -50%);
  background: #94AFBE
}

.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);
  vertical-align: top;
  cursor: pointer;
}

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

.radio-btn>label::before {
  background: #C2EDFB;
}

.radio-btn>label::after {
  background: #0060FF;
  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;
}

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

input[type="checkbox"]+label .icon {
  display: inline-block;
  background: #7AD0ED;
  vertical-align: middle;
  position: relative;
  border-radius: .04rem;
  transition: background-color 0.2s;
}

input[type="checkbox"]:checked+label .icon {
  background: #28B2E0;
}

input[type="checkbox"]+label .icon::after {
  content: "";
  display: none;
  position: absolute;
  left: 52%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: url("../img/checkmark.svg") no-repeat center / contain;
}

input[type="checkbox"]:checked+label .icon::after {
  display: block;
}

.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-navigation {
    position: fixed;
    right: .5rem;
    top: 50%;
    transform: translateY(-50%);
  }

  .evt-navigation .evt-menu {
    width: .6rem;
    height: auto;
    border-radius: .3rem;
  }

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

  .evt-menu>li a:hover .icon::before {
    opacity: 0;
  }

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

  .evt-menu>li .name {
    right: 100%;
    top: 50%;
    transform: translateY(-50%) rotateX(90deg);
    width: 1.14rem;
    padding: .07rem;
    word-wrap: break-word;
    word-break: keep-all;
    margin-right: .05rem
  }

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

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

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

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

  .evt-section+.evt-section {
    margin-top: min(-.95rem, -4.948vw)
  }

  .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 {
    left: .13rem;
    top: .13rem;
  }

  .radio-btn>label::before {
    width: .26rem;
    height: .26rem;
  }

  .radio-btn>label::after {
    width: .12rem;
    height: .12rem;
  }

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

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

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

  input[type="checkbox"]+label:hover .icon {
    background: #28B2E0;
  }

  .btn-sound:hover .ic-sound-bars .bar {
    background: #0045F3
  }

  .btn-sound.on .ic-sound-bars .bar {
    background: #fff
  }

}

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

  .mo-only {
    display: block !important
  }

  .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: 1rem;
    padding: .15rem .4rem;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: space-evenly;
  }

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

  .evt-menu>li .name {
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(10%);
    width: auto;
    white-space: nowrap;
    padding: .07rem .2rem;
  }

  .evt-menu>li a.on .name {
    transform: translateX(-50%) translateY(-.06rem);
  }

  .evt-navigation .btn-sound {
    position: absolute;
    width: .6rem;
    bottom: 100%;
    left: 50%;
    margin-left: 2.8rem;
    margin-bottom: .2rem
  }

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

  .evt-section+.evt-section {
    margin-top: min(-.8rem, -12.12vw)
  }

  .radio-btn>label::before,
  .radio-btn>label::after {
    left: .17rem;
    top: .17rem;
  }

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

  .radio-btn>label::after {
    width: .16rem;
    height: .16rem;
  }

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

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

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


/* main */
.btn-camcorder {
  width: 4rem;
  display: block;
  cursor: pointer;
}

.btn-camcorder .object {
  display: block;
  width: 100%;
  position: relative;
}

.btn-camcorder .preview {
  display: block;
  position: absolute;
  width: 2.01rem;
  right: .45rem;
  bottom: .25rem
}

.btn-camcorder .preview::after {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  width: .58rem;
  height: .58rem;
  transform: translate(-50%, -50%);
  background: url(../img/ic-play.png) no-repeat center / contain
}

.btn-camcorder .txt {
  position: absolute;
  right: 0;
  top: .2rem;
  width: 2.92rem;
  height: auto;
  text-align: center;
  font-size: .2rem;
  line-height: .24rem;
  font-weight: 600;
  will-change: transform;
  transform: translateZ(0);
  transition: opacity .15s linear
}

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

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


#main .character {
  position: absolute;
}

#main .sect-title {
  display: block;
  margin: 0 auto;
  width: 6.24rem;
}

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

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

.ticket-container {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: stretch;
}

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

.ticket-container .entry-cont {
  flex: 1
}

.ticket-container .stub-cont {
  flex: none
}

.ticket-container .entry-cont .fieldset {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

.ticket-container .entry-cont .fieldset>* {
  flex: none;
}

.ticket-container .entry-cont .fieldset::before,
.ticket-container .entry-cont .fieldset::after {
  content: "";
  display: block;
  flex: 1
}

.ticket-container .stub-cont .item-name {
  position: absolute;
  transform: translateX(-50%);
  text-align: center;
  color: #fff;
  border-radius: .3rem;
  width: auto;
  white-space: nowrap;
  font-weight: 500;
}

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

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

.entry-cont .ticket-name {
  display: block;
  text-align: center
}

.entry-cont .ticket-name>span,
.entry-cont .ticket-name>small {
  font-weight: 800;
  letter-spacing: -.05em
}

.entry-cont .period {
  text-align: center;
  color: #31A7EE;
  font-weight: 600;
}

.user-field {
  position: relative;
  width: 100%;
  background: #C2EDFB;
  border-radius: .08rem;
  height: .7rem;
}

.user-agree {
  width: 100%
}

.user-agree li {
  display: block;
  text-align: left;
}

.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: translate(-50%, -50%);
  background: #28B2E0
}

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

.user-field {
  display: flex;
  align-items: stretch;
  position: relative;
}

.user-field input {
  display: block;
  width: 100%;
  height: .7rem;
  box-sizing: border-box;
  position: absolute;
  text-align: left;
  padding: .23rem .24rem .21rem;
  font-size: .22rem;
  font-weight: 500;
  line-height: .26rem;
}

.user-field input+label {
  position: absolute;
  left: .24rem;
  top: .23rem;
  font-size: .22rem;
  font-weight: 500;
  line-height: .26rem;
  pointer-events: none;
  color: #5894BA
}

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

.entry-cont .common-btn {
  position: relative;
  height: .7rem
}

.entry-cont .common-btn::before,
.entry-cont .common-btn::after {
  height: 100%;
  width: 100%;
}

.entry-cont .common-btn>span {
  letter-spacing: -.025em;
  color: #fff;
  text-shadow: 0px .01rem .02rem #1C47BE80;
}

.entry-cont .notice {
  color: #5894BA;
  width: 100%
}

.entry-cont .notice>p::before {
  content: "•";
  font: inherit;
  position: absolute;
  left: 0;
  top: 0;
}

.entry-cont .notice>p {
  color: #5894BA;
  letter-spacing: -.02em;
  display: block;
  position: relative;
}


#main .ticket-box.expired>img {
  opacity: 0
}

#main .expired-content {
  position: absolute
}

.entry-cont .expired-content {
  z-index: 1;
}

.stub-cont .expired-content {
  z-index: 0;
  transition: transform .25s var(--easing)
}

.expired-content .sales-note {
  position: absolute;
  height: auto
}

.expired-content .sales-note .item {
  text-align: center;
  margin: 0 auto;
  display: block;
  width: auto
}

.expired-content .sales-note .item>span {
  position: relative;
  color: #fff;
  background: linear-gradient(90deg, #0060FF 6.1%, #008AFF 30.58%, #00DCA0 93.9%);
  display: inline-block;
  letter-spacing: -.05em;
  text-transform:uppercase;
  font-weight: 700;
  box-sizing: border-box
}

.expired-content .sales-note .item>span::before,
.expired-content .sales-note .item>span::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  border-radius: 100%;
  background: #fff;
  transform: translate(-50%, -50%);
}

.expired-content .sales-note .item>span::before {
  left: 0
}

.expired-content .sales-note .item>span::after {
  left: 100%
}

.expired-content .sales-note .status {
  display: block;
  text-align: center;
}

.expired-content .sales-note .status>span {
  letter-spacing: -.05em;
  text-transform: uppercase;
  font-weight: 700;
}

.expired-content .sales-note .message {
  color: #03598D;
  font-weight: 600;
  letter-spacing: -.05em;
  display: block;
  text-align: center;
}

.expired-content .stamp {
  position: absolute;
  transform: scale(1.3);
  opacity: 0;
  transition: all .15s var(--bounce)
}

#main.activate .stub-cont .expired-content {
  transform: rotate(0deg) translateX(0) translateY(0);
}

#main.activate .expired-content .stamp {
  transform: scale(1);
  opacity: 1;
}

@media (min-width: 1081px) {

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

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

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

  #main .character.ch-l {
    width: 6.54rem;
    right: 50%;
    margin-right: 5.36rem;
    top: 62.376%;
  }

  #main .character.ch-r {
    width: 7.38rem;
    left: 50%;
    top: 58.91%;
    margin-left: 3.32rem;
  }

  #main .btn-camcorder {
    position: fixed;
    right: .22rem;
    bottom: .35rem;
    z-index: 10;
  }

  #main .btn-camcorder .object::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(../img/camcoder-hover.png) no-repeat center / 100% auto;
    opacity: 0
  }

  #main .btn-camcorder .object>img {
    opacity: 1
  }

  #main .btn-camcorder .object::before,
  #main .btn-camcorder .object>img {
    transition: opacity .15s linear
  }

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

  #main .btn-camcorder:hover>img {
    opacity: 0
  }

  #main .btn-camcorder .preview img {
    transition: filter .15s linear;
  }

  #main .btn-camcorder:hover .preview>img {
    filter: contrast(1.25) brightness(1.1)
  }

  .btn-camcorder:hover .txt {
    --theme-stroke: #0090FF
  }

  .ticket-box {
    margin-top: .16rem
  }

  .ticket-container {
    flex-direction: row
  }

  .ticket-container .stub-cont {
    width: 2.8rem
  }

  .ticket-container .rewards {
    position: absolute;
    width: 2.4rem;
    left: .06rem;
    top: .37rem
  }

  .ticket-container .stub-cont .item-name {
    left: 50%;
    top: 3.65rem;
    font-size: .18rem;
    line-height: .21rem;
    padding: .08rem .23rem .09rem;
    background: #1EA0F6B2;
  }

  .ticket-container .entry-cont .fieldset {
    width: 7.42rem;
    left: .31rem;
    top: .42rem;
    padding-left: .47rem;
    padding-right: .47rem;
    height: 4.49rem
  }

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


  .user-select .divider {
    width: .25rem;
    height: .26rem;
  }

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

  .user-field>.common-btn {
    flex: none;
    width: 2.2rem;
  }

  .user-field>.common-btn::before,
  .user-field>.common-btn::after {
    height: 100%;
    width: 100%;
    background-image: url(../img/main-apply-btn-pc.png)
  }

  .user-field>.input-field {
    flex: 1;
    position: relative;
  }


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

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

  .entry-cont .notice>p+p {
    margin-top: .04rem
  }

  #main .market-buttons {
    margin-top: .08rem;
    gap: .12rem
  }

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


  .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-camcorder {
    transform: translateX(15%) rotateY(45deg);
    transition: all .55s var(--bounce);
  }

  #main.activate .btn-camcorder {
    transform: translateX(0) rotateY(0);
    transition-delay: .15s
  }

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

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

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

  #main .character {
    opacity: 0;
  }

  #main .character.ch-l {
    transform: translateX(-15%) translateY(-50%)
  }

  #main .character.ch-r {
    transform: translateX(15%) translateY(-50%)
  }

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

  #main.activate .character.ch-l,
  #main.activate .character.ch-r {
    transform: translateX(0) translateY(-50%);
    opacity: 1;
    transition-delay: .7s;
  }

  #main.activate .sect-title {
    opacity: 1;
    transition-delay: .25s;
  }

  #main.activate .ticket-box,
  #main.activate .market-buttons {
    transform: translateY(0);
    opacity: 1;
  }

  #main.activate .ticket-box {
    transition-delay: .5s;
  }

  #main.activate .market-buttons {
    transition-delay: .65s;
  }
}

@media (max-width: 1080px) {

  #main .sect-cont::before {
    flex: .6;
    min-height: .6rem;
  }

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

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

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


  #main .character {
    left: 50%;
  }

  #main .character.ch-l {
    width: 5.73rem;
    margin-left: -2.54rem;
    top: 52.328%;
  }

  #main .character.ch-r {
    width: 6.52rem;
    margin-left: 1.18rem;
    top: 51.4285%
  }

  #main .aligner {
    display: block;
    height: 2.52rem
  }

  #main .btn-camcorder {
    position: relative;
    margin: .56rem auto 0;
  }

  #main .ticket-box {
    width: 6.86rem
  }

  .ticket-container {
    flex-direction: column
  }

  .ticket-container .stub-cont {
    height: 2.97rem;
  }

  .ticket-container .rewards {
    position: absolute;
    width: 5.96rem;
    left: .45rem;
    top: .11rem
  }

  .ticket-container .stub-cont .item-name {
    top: 1.78rem;
    font-size: .2rem;
    line-height: .22rem;
    left: 74.49%;
    padding: .09rem .26rem;
    background: #0680F7B2;
  }

  .ticket-container .entry-cont .fieldset {
    width: 5.86rem;
    left: .5rem;
    top: .3rem;
    height: 7.5rem;
    padding-left: .3rem;
    padding-right: .3rem;
  }

  .user-select {
    gap: .2rem;
    margin: .12rem 0;
    font-size: 0;
    line-height: 0;
    height: .34rem;
  }

  .user-select .divider {
    width: .01rem;
    height: .34rem;
  }

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

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

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

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

  .entry-cont .common-btn {
    display: block;
    margin: 0 auto;
    position: relative;
    width: 3.2rem;
  }

  .entry-cont .common-btn::before,
  .entry-cont .common-btn::after {
    height: 100%;
    width: 100%;
    background-image: url(../img/main-apply-btn-mo.png)
  }

  .entry-cont .notice {
    padding-top: .4rem
  }

  .entry-cont .notice>p+p {
    margin-top: .1rem
  }

  #main .market-buttons {
    margin-top: .16rem;
    gap: .2rem
  }
  #main .ticket-box.expired + .market-buttons{
    margin-top:.32rem
  }

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

  #main .main-words {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 46.56%;
    z-index: 1
  }

  .entry-cont .expired-content {
    left: 0;
    bottom: -.25rem;
    width: 6.72rem
  }

  .stub-cont .expired-content {
    left: .1rem;
    bottom: -.28rem;
    width: 6.62rem;
    transform-origin: -35% 5%;
    transform: rotate(-3.9deg) translateX(0) translateY(.24rem);
  }

  .expired-content .sales-note {
    left: .52rem;
    width: 5.88rem;
    top:.88rem
  }

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

  .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;
    right: 1.1rem;
    top: .8rem
  }

  /* Transition */

  #main .character,
  #main .character>img,
  #main .sect-title {
    transition: all .55s var(--easing)
  }

  #main .main-words,
  #main .main-words .typo-word {
    transition: all .3s var(--easing)
  }

  #main .sect-title>img,
  #main .ticket-box,
  #main .market-buttons,
  #main .btn-camcorder {
    transition: all .45s ease-out
  }

  #main .sect-title>img {
    opacity: 0;
  }

  #main.activate .sect-title>img {
    opacity: 1;
    transition-delay: .15s
  }

  #main .main-words {
    opacity: 0;
    transform: translate(-50%, .25rem);
  }

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

  #main .main-words .typo-words {
    opacity: 1;
    transform: translateY(0);
  }

  #main.activate .main-words .typo-words {
    opacity: 0;
    transform: translateY(.25rem);
  }

  #main .character {
    opacity: 0;
    transform: translate(-50%, -40%)
  }

  #main.activate .character {
    opacity: 1;
    transform: translate(-50%, -50%);
    transition-delay: .55s
  }

  #main .character>img {
    opacity: 1;
    transform: translate(0, 0)
  }

  #main.activate .character>img {
    opacity: 0;
    transform: translateX(0);
  }

  #main.activate .character.ch-l>img {
    transform: translateX(-30%)
  }

  #main.activate .character.ch-r>img {
    transform: translateX(30%)
  }

  #main .ticket-box,
  #main .market-buttons,
  #main .btn-camcorder {
    opacity: 0;
    transform: translateY(.4rem);
  }

  #main.activate .ticket-box,
  #main.activate .market-buttons,
  #main.activate .btn-camcorder {
    opacity: 1;
    transform: translateY(0);
  }

  #main.activate .sect-title {
    width: 4.36rem;
  }

  #main.activate.out .btn-camcorder {
    opacity: 1;
    transform: translateY(0);
  }

}



/* roadmap */

#roadmap .sect-title {
  margin: 0 auto;
  display: block;
  width: 5.04rem
}

#roadmap .roadmap-nav {
  margin: 0 auto;
  position: relative;
  box-sizing: border-box;
  background: #021E88B2;
}

#roadmap .roadmap-nav button {
  display: block;
  position: relative;
}

#roadmap .roadmap-nav button>span {
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
  transform: translateY(-50%);
  text-align: center;
  font-weight: 500;
  letter-spacing: -.025em;
  line-height: 1em;
  box-sizing: border-box;
  padding-left: 1em;
  padding-right: 1em;
  color: #879BE4;
  transition: color .1s var(--easing);
}

#roadmap .roadmap-nav button>img {
  opacity: 0;
  transition: opacity .1s var(--easing)
}

#roadmap .roadmap-nav button.on>img {
  opacity: 1
}

#roadmap .roadmap-nav button.on>span {
  color: #fff;
  text-shadow: 0 .01rem .02rem #0C2E604D
}

#roadmap .roadmap-content {
  display: block;
  position: relative;
  margin: 0 auto;
  overflow: visible
}

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

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

#roadmap .roadmap-content .swiper-slide.swiper-slide-active .common-btn {
  pointer-events: auto
}

#roadmap .roadmap-content .box {
  padding: .1rem;
  border-radius: .1rem;
  background: #fff;
  position: relative;
  z-index: 1;
}

#roadmap .roadmap-content .shadow {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
  z-index: -1
}


#roadmap .content-body {
  padding: .4rem .3rem .3rem;
}

#roadmap .content-body .title {
  color: #2A1F14;
  font-weight: 600;
  letter-spacing: -.025em;
  text-align: center;
  margin-bottom: .24rem;
  word-wrap: break-word;
  word-break: keep-all;
}

#roadmap .content-body .description {
  color: #615347;
  font-weight: 500;
  text-align: center;
  letter-spacing: -.025em;
  word-wrap: break-word;
  word-break: keep-all;
}

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

#roadmap .common-btn::before,
#roadmap .common-btn::after {
  background-image: url(../img/common-download-btn.png);
  width: 3.22rem;
  height: .82rem;
}

#roadmap .roadmap-content .swiper-slide {
  opacity: 0;
  position: relative;
  transition: all .8s var(--easing)
}

#roadmap .roadmap-content .swiper-slide.swiper-slide-active {
  opacity: 1;
  transition-delay: .4s;
}

#roadmap .roadmap-content .box {
  opacity: 0;
  transform: translateX(.1rem) translateY(0) rotate(3deg);
  transition: opacity .25s .15s var(--easing), transform .4s ease-out
}

#roadmap .roadmap-content .shadow {
  opacity: 0;
  transform: translateX(.1rem) translateY(.1rem) rotate(3deg);
  transition: opacity .35s 0s var(--easing), transform .4s ease-out
}

#roadmap .roadmap-content .swiper-slide.swiper-slide-active .box,
#roadmap .roadmap-content .swiper-slide.swiper-slide-active .shadow {
  opacity: 1;
  transform: translateX(0) translateY(0) rotate(0deg)
}

#roadmap .roadmap-content .swiper-slide.swiper-slide-active .shadow,
#roadmap .roadmap-content .swiper-slide.swiper-slide-active .box {
  transition-delay: .5s, .5s
}

#roadmap .sect-title,
#roadmap .roadmap-nav,
#roadmap .roadmap-content {
  opacity: 0;
  transform: translateY(.25rem);
  transition: all .45s var(--easing);
}

#roadmap.activate .sect-title,
#roadmap.activate .roadmap-nav,
#roadmap.activate .roadmap-content {
  opacity: 1;
  transform: translateY(0);
}

#roadmap.activate .sect-title {
  transition-delay: .2s;
}

#roadmap.activate .roadmap-nav {
  transition-delay: .35s;
}

#roadmap.activate .roadmap-content {
  transition-delay: .5s;
}

#roadmap .roadmap-content .thumbnail {
  opacity: 0;
  transition: opacity .25s 2s ease-in;
  animation: photo-frame-ani 1s 2s var(--bounce) forwards;
}

#roadmap .roadmap-content .swiper-slide-active .thumbnail {
  opacity: 1;
  transition-delay: .7s;
  animation-delay: 0s;
}


@media (min-width: 1081px) {

  #roadmap .sect-cont::before {
    min-height: .6rem;
    flex: .6
  }

  #roadmap .sect-cont::after {
    flex: 1.4;
  }

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

  #roadmap .masked-img {
    height: 14.95rem;
    background-image: url(../img/bg-roadmap-pc.jpg);
    background-position-y: 100%
  }


  #roadmap .roadmap-nav {
    width: 9.76rem;
    padding: 0 .36rem;
    border-radius: .58rem;
    margin: .45rem auto .1rem
  }

  #roadmap .roadmap-nav .swiper-wrapper {
    display: flex;
    width: 100%;
    height: .58rem;
    align-items: stretch;
  }

  #roadmap .roadmap-nav .swiper-slide {
    flex: 1;
  }

  #roadmap .roadmap-nav button:hover>span {
    color: #fff
  }

  #roadmap .roadmap-content {
    width: 9.6rem;
  }

  #roadmap .roadmap-content .swiper-slide {
    padding-top: .2rem;
  }

  #roadmap .roadmap-content .shadow {
    width: 9.94rem;
    background-image: url(../img/roadmap-content-bg-pc.png)
  }

  #roadmap .content-body .title {
    font-size: .2rem;
    line-height: .23rem
  }

  #roadmap .content-body .description {
    font-size: .18rem;
    line-height: .24rem
  }

}

@media (max-width: 1080px) {

  #roadmap .sect-cont::before {
    min-height: .7rem;
    flex:none
  }

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

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

  #roadmap .masked-img {
    height: 18.7rem;
    background-image: url(../img/bg-roadmap-mo.jpg);
    background-position-y: 40%
  }

  #roadmap .roadmap-nav {
    width: 6.63rem;
    border-radius: .66rem;
    margin: .42rem auto .22rem
  }

  #roadmap .roadmap-nav .swiper-slide {
    width: 2.44rem
  }

  #roadmap .roadmap-content {
    width: 6.15rem;
  }

  #roadmap .roadmap-content .swiper-slide {
    padding-top: .24rem;
  }

  #roadmap .roadmap-content .shadow {
    width: 6.38rem;
    background-image: url(../img/roadmap-content-bg-mo.png)
  }

  #roadmap .content-body .title {
    font-size: .22rem;
    line-height: .26rem
  }

  #roadmap .content-body .description {
    font-size: .22rem;
    line-height: .3rem
  }
}


/* character */
#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;
  color: #03598D
}

.character-nav button.on .name {
  color: #006CFF;
  font-weight: 600
}

.character-nav button .profile {
  display: block;
  width: 100%;
  padding-top: 100%;
  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: 50%
}

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

.character-nav button.on .profile::before {
  opacity: 0
}

.character-nav button.on .profile::after {
  opacity: 1
}

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

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

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

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

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

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

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

.card-head {
  color: #fff;
}

.card-head .fullname {
  width: 100%;
  position: absolute;
  left: 0;
  text-align: center;
  vertical-align: middle;
  font-weight: 600;
  font-size: .36rem;
  line-height: .44rem;
  letter-spacing: -.05em;
}


.card-body .quote-box {
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  min-height: .78rem;
}

.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;
  font-size: .2rem;
  line-height: .3rem;
  letter-spacing: -.025em;
  padding: .1rem .22rem;
}

.card-body .voice-sound {
  margin: 0 auto .21rem;
  background: #0033E5;
  gap: .18rem;
  display: flex;
  height: .4rem;
  border-radius: .4rem;
  align-items: stretch;
  justify-content: center;
}

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

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

.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: #85E9FF;
  transition: all .15s ease-in-out
}

.character-nav button .name,
.card-body .voice-sound .actor {
  text-transform: uppercase;
}



.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: translate(-50%, -50%);
  border-radius: 100%;
  width: .28rem;
  height: .28rem;
  background-color: #3FA7FF;
  transition: all .15s ease-in-out
}

.card-body .voice-sound button .icon .circ>i {
  opacity: 0;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  box-sizing: border-box;
  border-radius: 100%;
  border-style: solid;
  border-width: .015rem;
  border-color: #3FA7FF;
  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: .28rem
}

.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: translateX(-50%) translateY(.09rem);
  border-radius: .6rem;
  background: #51CDFE
}

.tooltip-box::before {
  content: "";
  display: block;
  position: absolute;
  left: 50%;
  width: .16rem;
  height: .12rem;
  background: #51CDFE;
  bottom: 100%;
  transform: translateX(-50%) translateY(.01rem);
  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: translateX(-50%);
  width: .02rem;
  height: .02rem;
  background: #51CDFE;
  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: #1DC7FF;
}

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

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

.card-body .bio-sheet {
  box-sizing: border-box;
  overflow: hidden;
}

.card-body .bio-sheet .sheet-main {
  padding-bottom: .18rem
}

.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(even) {
  background: #DBF6FF4D
}


.card-body .bio-sheet .sheet-main .item-label {
  flex: none;
  position: relative;
  font-weight: 600;
  color: #03598D;
  letter-spacing: -.025em;
  padding-left: .22rem;
}

.card-body .bio-sheet .sheet-main .item-label::before {
  content: "";
  display: block;
  position: absolute;
  width: .15rem;
  left: 0;
  top: 0;
  background: url(../img/txt_light.svg) no-repeat center /100% auto;
}

.card-body .bio-sheet .sheet-main .item-value {
  flex: 1;
  letter-spacing: -.025em;
  font-weight: 500;
  color: #002C40;
}


.card-body .bio-sheet .sheet-note>p {
  font-weight: 500;
  letter-spacing: -.025em;
  color: #5894BA;
  position: relative;
}

.card-body .bio-sheet .sheet-note>p::before {
  content: "•";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 1em;
  height: 1em;
  text-align: left;
}

.character-visual {
  position: relative;
}

.zoom-point {
  position: absolute;
  transform: translate(-50%, -50%);
  pointer-events: none;
  animation: zoom-point-blinking 2s ease-in-out infinite
}

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

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

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

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

.zoom-point::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  opacity: 1;
  pointer-events: none
}

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

.zoom-point.zoomin {
  animation: none;
}

.zoom-point.zoomin>img,
.zoom-point.zoomin::before {
  opacity: .2
}

.zoomin-box {
  position: absolute;
  transform: translate(-50%, -50%) scale(.5);
  opacity: 0;
  pointer-events: none;
  transition: all .15s var(--bounce);
}


.zoom-point.zoomin .zoomin-box {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  z-index: 25;
  pointer-events: fill
}

#character-mov {
  position: absolute;
  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 .2s .05s linear;
}

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

#character .character-content {
  opacity: 0;
  transform: translateY(.15rem);
  transition: all .25s var(--easing)
}

#character .back-img {
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  transition: all .35s var(--bounce)
}

#character .front-img {
  transform: translate(-50%, -45%);
  opacity: 0;
  transition: all .35s var(--bounce)
}

#character.activate .character-content.visible {
  opacity: 1;
  transform: translateY(0);
  transition-duration: .5s;
  transition-delay: .35s
}

#character.activate .character-content.visible .back-img {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  transition-duration: .35s;
  transition-delay: .35s
}

#character.activate .character-content.visible .front-img {
  transform: translate(-50%, -50%);
  opacity: 1;
  transition-duration: .45s;
  transition-delay: .4s
}


#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 .6s var(--bounce) 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: .5s
}

#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: .55s
}

#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: .6s
}

#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: .65s
}

#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: .7s
}

#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: .8s
}

#characterProfilePop.visible .sheet-main li:nth-child(1) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(2) .item-value {
  animation-delay: .15s
}

#characterProfilePop.visible .sheet-main li:nth-child(3) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(4) .item-value {
  animation-delay: .2s
}

#characterProfilePop.visible .sheet-main li:nth-child(5) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(6) .item-value {
  animation-delay: .25s
}

#characterProfilePop.visible .sheet-main li:nth-child(7) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(8) .item-value {
  animation-delay: .3s
}

#characterProfilePop.visible .sheet-main li:nth-child(9) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(10) .item-value {
  animation-delay: .35s
}

#characterProfilePop.visible .sheet-main li:nth-child(11) .item-value,
#characterProfilePop.visible .sheet-main li:nth-child(12) .item-value {
  animation-delay: .4s
}


@media (min-width: 1081px) {
  #character .sect-cont::before {
    min-height: .84rem;
    flex: .84
  }

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

  #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 .character-nav ul {
    gap: .14rem
  }

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

  .character-nav button .name {
    font-size: .18rem;
    line-height: .24rem;
    padding-top: .06rem;
  }

  .character-nav button:hover .name {
    color: #006CFF;
    font-weight: 600
  }

  #character .character-content {
    width: 12.8rem;
    height: 9.05rem;
    margin-top: .12rem;
    display: flex;
  }

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

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

  #character .front-img {
    position: absolute;
    width: 5.26rem;
    left: 43.75%;
    top: 47.624%;
  }

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

  #character .bio-card {
    width: 6.04rem;
    height: auto;
    margin-top: .27rem;
    float: right;
  }

  #character .card-head {
    display: block;
    width: 100%;
    height: auto;
    position: relative;
    z-index: 1;
    margin-bottom: -.03rem
  }

  #character .card-head .fullname {
    top: .28rem
  }

  #character .card-head .dolphin {
    position: absolute;
    left: 100%;
    width: 1.71rem;
    top: .06rem
  }

  #character .card-head .dolphin::before {
    content: "";
    display: block;
    width: 1.53rem;
    height: 1.21rem;
    background: url(../img/character-contents-box-pc-dolphin.png) no-repeat center / contain;
    position: absolute;
    left: .17rem;
    top: .99rem;
    transform-origin: 10% -5%;
    animation: dolphin-mov 2.4s ease-in-out infinite
  }

  #character .card-body {
    position: relative;
    width: 6.033rem;
    height: auto;
    padding: .11rem .21rem .21rem;
    box-sizing: border-box;
    border-radius: 0 0 .16rem .16rem;
    background: linear-gradient(48deg, #55c7ff 5%, #015bff 95%);
    border: .015rem solid rgba(0, 40, 120, 0.2);
    border-right: .012rem solid #015bffca;
    box-shadow:
      inset .038rem 0 .03rem -.022rem rgba(44, 200, 255, .8),
      inset -.025rem 0 .07rem -.035rem rgba(0, 0, 0, 0.25)
  }

  #character .card-body::before {
    content: "";
    display: block;
    position: absolute;
    width: 100%;
    left: 0;
    top: 0;
    height: 100%;
    background: url(../img/noise.gif) repeat center / 1.8rem auto;
    mix-blend-mode: screen;
    border-radius: 0 0 .17rem .17rem;
    opacity: .15
  }

  .card-body .bio-sheet {
    background: #fff;
    padding: .3rem .2rem .2rem;
    border-radius: .1rem
  }

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

  .card-body .voice-sound {
    width: 3.6rem;
    margin: 0 auto .21rem;
  }

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

  .card-body .bio-sheet .sheet-main li {
    gap: .02rem;
    min-height: .35rem;
    padding: .04rem .2rem .04rem .3rem;
  }

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

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

  .card-body .bio-sheet .sheet-main .item-label::before {
    height: .24rem;
  }

  .card-body .bio-sheet .sheet-note>p {
    padding-left: 1em;
    font-size: .14rem;
    line-height: .24rem;
    padding-bottom: .08rem;
  }


  .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 .actor {
    color: #DCF9FF
  }

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

  .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
  }

  .zoom-point:hover {
    animation: none;
    opacity: 1
  }

  .zoom-point:hover::before {
    animation: zoom-point-active 3s var(--easing) infinite
  }

  .character-content[data-name="justia"] #character-mov {
    width: 5.48rem;
    bottom: .6rem;
    left: 49.2%;
  }

  .character-content[data-name="wilhelmina"] #character-mov {
    bottom: 0;
    width: 7.43rem;
    left: 56.5%;
  }

  .character-content[data-name="zenith"] #character-mov {
    bottom: 0;
    width: 4.96rem;
    left: 49%;
  }

  .character-content[data-name="refithea"] #character-mov {
    width: 7.75rem;
    bottom: 13.1%;
    left: 42.5%;
  }

  .character-content[data-name="eclipse"] #character-mov {
    bottom: 0;
    width: 6.1rem;
    left: 51.5%;
  }

  #character .bio-card {
    transform: translateY(.15rem);
    opacity: 0;
    transition: all .25s var(--easing)
  }

  #character.activate .visible .bio-card {
    transform: translateY(0);
    opacity: 1;
    transition-delay: .35s
  }

}

@media (max-width: 1080px) {
  #character .sect-cont::before {
    min-height: .55rem;
    flex: .55
  }

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

  #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: 15.5rem;
    background-image: url(../img/bg-character-mo.jpg)
  }

  #character .character-nav {
    gap: .13rem
  }

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

  .character-nav button .name {
    font-size: .16rem;
    line-height: .21rem;
    padding-top: .03rem;
  }

  #character .character-content {
    width: 100%;
    padding: 1.32rem 0
  }

  #character .character-visual {
    height: 8.16rem;
    width: 100%;
    position: relative;
  }

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

  #character .front-img {
    position: absolute;
    width: 6.33rem;
    left: 50%;
    margin-left: -.39rem;
    top: 50%;
  }

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

  .character-content[data-name="justia"] #character-mov {
    width: 6.6rem;
    bottom: .7rem;
    left: 49.2%;
  }

  .character-content[data-name="wilhelmina"] #character-mov {
    bottom: 0;
    width: 8.94rem;
    left: 56.5%;
  }

  .character-content[data-name="zenith"] #character-mov {
    bottom: 0;
    width: 5.96rem;
    left: 49%;
  }

  .character-content[data-name="refithea"] #character-mov {
    width: 9.34rem;
    bottom: 13.1%;
    left: 42.5%;
  }

  .character-content[data-name="eclipse"] #character-mov {
    bottom: 0;
    width: 7.35rem;
    left: 51.5%;
  }

  .btn-open-card {
    width: 2.16rem;
    height: 2.16rem;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 1.5rem;
    margin-top: .77rem;
  }

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

  .inner-popup .bio-card {
    position: absolute;
    left: 50%;
    top: 0;
    height: calc(100% - .08rem);
    width: 5.6rem;
    padding: 0 .2rem;
    pointer-events: fill;
    margin-left: -3rem;
  }

  .inner-popup .character-info .dolphin {
    position: absolute;
    right: 0.04rem;
    width: .34rem;
    top: .18rem;
  }

  .inner-popup .character-info .dolphin::before {
    content: "";
    display: block;
    width: .86rem;
    height: .80rem;
    background: url(../img/character-contents-box-mo-dolphin.png) no-repeat center top / contain;
    position: absolute;
    left: -.02rem;
    top: 100%;
    margin-top: -.02rem;
    transform-origin: 10.5% -5%;
    animation: dolphin-mov 2.4s ease-in-out infinite
  }

  .bio-card .card-head {
    height: .9rem
  }

  .bio-card .card-head .fullname {
    top: .24rem;
  }

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

  .card-body .voice-sound {
    width: 4.8rem;
    margin: 0 auto .28rem;
  }

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

  .card-body .voice-sound .actor {
    font-size: .2rem;
    line-height: .28rem
  }

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

  .card-body .voice-sound .btn-tooltip .tooltip-box>span {
    font-size: .18rem;
    line-height: .22rem;
    padding-left: .27rem;
  }

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

  .card-body .bio-sheet {
    display: flex;
    flex-direction: column;
    padding: .3rem .2rem;
    width: 100%;
  }

  .card-body .bio-sheet .sheet-main {
    flex: 1;
    overflow-y: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch;
  }

  .card-body .bio-sheet .sheet-main::-webkit-scrollbar {
    display: none;
  }

  .card-body .bio-sheet .sheet-note {
    flex: none;
    padding: .06rem 0 0
  }

  .card-body .bio-sheet .sheet-note>p {
    top: .07rem;
    font-size: .16rem;
    line-height: .26rem;
    padding-left: .18rem
  }

  .card-body .bio-sheet .sheet-main li {
    min-height: .4rem;
    padding: .06rem .2rem;
    gap: .1rem
  }

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

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

  .card-body .bio-sheet .sheet-main .item-label::before {
    height: .28rem;
  }
}




@media (min-width: 1081px) {

  .zoomin-box {
    width: 2.98rem;
    height: 2.58rem;
  }

  .character-content[data-name="justia"] .zoom-point[value="01"] {
    left: 47.5%;
    top: 17%;
  }

  .character-content[data-name="justia"] .zoom-point[value="02"] {
    left: 57.5%;
    top: 30.2%;
  }

  .character-content[data-name="justia"] .zoom-point[value="03"] {
    left: 54.5%;
    top: 67.2%;
  }

  .character-content[data-name="justia"] .zoom-point[value="01"] .zoomin-box {
    left: 205%;
    top: 175%;
  }

  .character-content[data-name="justia"] .zoom-point[value="02"] .zoomin-box {
    left: -160%;
    top: 94%;
  }

  .character-content[data-name="justia"] .zoom-point[value="03"] .zoomin-box {
    top: -86%;
    left: 138%;
  }


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

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

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

  .character-content[data-name="wilhelmina"] .zoom-point[value="01"] .zoomin-box {
    left: 205%;
    top: 82%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="02"] .zoomin-box {
    left: -40%;
    top: 5.5%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="03"] .zoomin-box {
    left: 163%;
    top: 60%;

  }

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

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

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

  .character-content[data-name="zenith"] .zoom-point[value="01"] .zoomin-box {
    left: 80%;
    top: 65%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="02"] .zoomin-box {
    left: 154%;
    top: 171%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="03"] .zoomin-box {
    left: -24.5%;
    top: 97%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="01"] {
    left: 49.5%;
    top: 31.6%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="02"] {
    left: 55.4%;
    top: 42%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="03"] {
    left: 42.9%;
    top: 50.6%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="01"] .zoomin-box {
    left: 191%;
    top: 36%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="02"] .zoomin-box {
    left: 142.5%;
    top: 77%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="03"] .zoomin-box {
    left: -70%;
    top: 68%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="01"] {
    left: 47.5%;
    top: 24.3%;
  }

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

  .character-content[data-name="eclipse"] .zoom-point[value="03"] {
    left: 51.9%;
    top: 54.4%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="01"] .zoomin-box {
    left: 205.5%;
    top: 86%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="02"] .zoomin-box {
    left: -83%;
    top: -8%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="03"] .zoomin-box {
    left: 157%;
    top: 75%;
  }

}

@media (max-width: 1080px) {

  .zoomin-box {
    width: 3.58rem;
    height: 3.1rem;
  }

  .character-content[data-name="justia"] .zoom-point[value="01"] {
    left: 48.5%;
    top: 9.6%;
  }

  .character-content[data-name="justia"] .zoom-point[value="02"] {
    left: 57.5%;
    top: 26.5%;
  }

  .character-content[data-name="justia"] .zoom-point[value="03"] {
    left: 53.5%;
    top: 75.5%;
  }

  .character-content[data-name="justia"] .zoom-point[value="01"] .zoomin-box {
    left: 100%;
    top: 180%;
  }

  .character-content[data-name="justia"] .zoom-point[value="02"] .zoomin-box {
    left: -103%;
    top: 103%;
  }

  .character-content[data-name="justia"] .zoom-point[value="03"] .zoomin-box {
    top: -41%;
    left: 85%;
  }


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

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

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

  .character-content[data-name="wilhelmina"] .zoom-point[value="01"] .zoomin-box {
    left: 205%;
    top: 82%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="02"] .zoomin-box {
    left: 15%;
    top: 100%;
  }

  .character-content[data-name="wilhelmina"] .zoom-point[value="03"] .zoomin-box {
    left: 90%;
    top: 104%;

  }

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

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

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


  .character-content[data-name="zenith"] .zoom-point[value="01"] .zoomin-box {
    left: -1%;
    top: 120%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="02"] .zoomin-box {
    left: -2.5%;
    top: 102.5%;
  }

  .character-content[data-name="zenith"] .zoom-point[value="03"] .zoomin-box {
    left: 10%;
    top: 125%;
  }

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

  .character-content[data-name="refithea"] .zoom-point[value="02"] {
    left: 54.5%;
    top: 43%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="03"] {
    left: 45.5%;
    top: 53.5%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="01"] .zoomin-box {
    left: 110%;
    top: 125%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="02"] .zoomin-box {
    left: 77%;
    top: 122%;
  }

  .character-content[data-name="refithea"] .zoom-point[value="03"] .zoomin-box {
    left: -34%;
    top: 112%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="01"] {
    left: 49%;
    top: 18.5%;
  }

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

  .character-content[data-name="eclipse"] .zoom-point[value="03"] {
    left: 52%;
    top: 58.8%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="01"] .zoomin-box {
    left: 125%;
    top: 115%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="02"] .zoomin-box {
    left: -46%;
    top: 25%;
  }

  .character-content[data-name="eclipse"] .zoom-point[value="03"] .zoomin-box {
    left: 105%;
    top: 94%;
  }

}

/* goodies */
#goodies .sect-title {
  display: block;
  height: auto;
}

#goodies .common-btn::before,
#goodies .common-btn::after {
  background-image: url(../img/common-download-btn.png);
  width: 3.22rem;
  height: .82rem;
}

#goodies .common-btn.line-emoji::before,
#goodies .common-btn.line-emoji::after {
  background-image: url(../img/line-download-btn.png);
}

.common-btn.line-emoji>span {
  text-shadow: 0 .03rem 0 #00682A
}

.common-btn.line-emoji>span>i {
  display: inline-block;
  width: .34rem;
  margin-right: .06rem;
  vertical-align: middle;
}

.goodies-buttons .common-btn[data-target-slide] {
  visibility: hidden;
  display: none
}

.goodies-buttons .common-btn[data-target-slide].visible {
  visibility: visible;
  display: block
}

#goodies .tree,
#goodies .tree>span,
#goodies .tree::before,
#goodies .tree::after {
  position: absolute;
  transform: translate(-50%, -50%);
  z-index: 5;
}

#goodies .tree,
#goodies .tree>span {
  left: 50%;
  top: 50%;
  z-index: 0
}

#goodies .tree::before,
#goodies .tree::after {
  content: "";
  display: block;
  background: url(../img/goodie-light.svg) no-repeat center / contain
}

#goodies .goodies-nav {
  display: block;
  position: relative;
  margin: 0 auto;
  width: 100%;
  z-index: 2;
}

#goodies .goodies-nav button {
  display: block;
  position: relative;
  width: 2.36rem;
  height: .68rem;
}

#goodies .goodies-nav button::before,
#goodies .goodies-nav button::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity .15s var(--easing)
}

#goodies .goodies-nav button,
#goodies .goodies-nav button::before,
#goodies .goodies-nav button::after {
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position-x: center;
  background-image: url(../img/goodies-tab-btn.png);
}

#goodies .goodies-nav button {
  background-position-y: 0%
}

#goodies .goodies-nav button::before {
  background-position-y: 50%
}

#goodies .goodies-nav button::after {
  background-position-y: 100%
}

#goodies .goodies-nav button.on::after {
  opacity: 1
}

#goodies .goodies-nav button>span {
  font-size: .24rem;
  line-height: .32rem;
  color: #927B62;
  position: absolute;
  z-index: 1;
  left: 0;
  width: 100%;
  top: calc(50% - .015rem);
  transform: translateY(-50%);
}

#goodies .goodies-nav button.on>span {
  color: #FFFFFF;
  text-shadow: 0px .01rem .01rem #7C0000;
}

#goodies .goodies-nav button.on>span::before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: -1;
  color: transparent;
  -webkit-text-stroke: .01rem #7C0000;
  text-shadow:
    -.01rem 0 #7C0000,
    .01rem 0 #7C0000,
    0 -.01rem #7C0000,
    0 .01rem #7C0000,
    -.01rem -.01rem #7C0000,
    .01rem -.01rem #7C0000,
    -.01rem .01rem #7C0000,
    .01rem .01rem #7C0000;
}

#goodies .goodies-content {
  position: relative;
  z-index: 0;
  margin: 0 auto;
}

#goodies .goodies-content .swiper-container {
  position: absolute;
  overflow: hidden;
  left: 50%;
  transform: translateX(-50%);
}

#goodies .goodies-buttons {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: .4rem
}

#goodies .goodies-buttons>.common-btn {
  margin: 0;
  flex: none
}

/* motion */
#goodies .sect-title,
#goodies .goodies-nav,
#goodies .goodies-content,
#goodies .goodies-buttons {
  opacity: 0;
  transform: translateY(.2rem);
  transition: all .45s var(--easing)
}

#goodies.activate .sect-title,
#goodies.activate .goodies-nav,
#goodies.activate .goodies-content,
#goodies.activate .goodies-buttons {
  opacity: 1;
  transform: translateY(0);
}


#goodies.activate .sect-title {
  transition-delay: .25s;
}

#goodies.activate .goodies-nav {
  transition-delay: .35s;
}

#goodies.activate .goodies-content {
  transition-delay: .45s;
}

#goodies.activate .goodies-buttons {
  transition-delay: .6s;
}

#goodies .tree {
  opacity: 0;
  transform: translate(-50%, -40%);
  transition: all .55s var(--easing)
}

#goodies .tree .back {
  width: 100%;
  height: 100%
}

#goodies.activate .tree {
  opacity: 1;
  transform: translate(-50%, -50%);
  transition-delay: .7s;
}

#goodies .tree::before,
#goodies .tree::after {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0);
  transition: all .35s var(--bounce)
}

#goodies.activate .tree::before,
#goodies.activate .tree::after {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
  animation: twinkle-ani 2.5s var(--bounce) infinite
}

#goodies.activate .tree::before {
  transition-delay: .8s;
  animation-delay: 2s;
}

#goodies.activate .tree::after {
  transition-delay: .95s;
  animation-delay: 2.15s;
}

#goodies.activate .tree .back,
#goodies.activate .tree .front {
  opacity: 0;
}

#goodies.activate .sect-bg .tree .back,
#goodies.activate .sect-bg .tree .front {
  opacity: 1;
  transform: translate(-50%, -50%) rotate(0deg);
  transition: opacity .35s var(--easing), transform .75s var(--bounce);
}

#goodies.activate .sect-bg .tree .back {
  transition-delay: .8s, .9s;
}

#goodies.activate .sect-bg .tree .front {
  transition-delay: .8s, .9s;
}

#goodies.activate .tree .back img,
#goodies.activate .tree .front img {
  animation-timing-function: ease-in-out;
  animation-iteration-count: infinite;
  animation-duration: 3s
}

#goodies.activate .tree .back img {
  animation-delay: 1.1s;
}

#goodies.activate .tree .front img {
  animation-delay: .95s;
}


@media (min-width: 1081px) {
  #goodies .sect-cont::before {
    min-height: .84rem;
    flex: .84;
  }

  #goodies .sect-cont::after {
    flex: 1.9
  }

  #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: 13.89rem;
    background-image: url(../img/bg-goodies-pc.jpg)
  }

  #goodies .sect-title {
    width: 7.93rem;
    margin: 0 auto .33rem;
  }

  #goodies .goodies-nav {
    margin-bottom: -.37rem
  }

  #goodies .goodies-nav .swiper-wrapper {
    display: flex;
    width: 12.08rem;
    margin: 0 auto;
    height: .68rem;
    gap: .07rem;
  }

  #goodies .goodies-nav .swiper-wrapper .swiper-slide {
    display: block;
    flex: 1;
  }

  #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 {
    width: 11.64rem;
  }

  #goodies .goodies-content .swiper-container {
    top: 1rem;
    padding: .48rem 0;
    width: 9.6rem
  }

  #goodies .goodies-buttons {
    gap: .3rem
  }

  #goodies .tree.tree-l {
    width: 9.01rem;
    height: 8.21rem;
    margin-left: -4.86rem;
    margin-top: -.92rem
  }

  #goodies .tree.tree-r {
    width: 7.88rem;
    height: 7.88rem;
    margin-left: 5.82rem;
    margin-top: 1.08rem
  }

  #goodies .tree.tree-l .front {
    width: 7.52rem;
    height: 7.3rem
  }

  #goodies .tree.tree-l::before {
    width: .38rem;
    height: .38rem;
    left: 22.086%;
    top: 21.2%
  }

  #goodies .tree.tree-l::after {
    width: .75rem;
    height: .75rem;
    left: 13.874%;
    top: 37.03%
  }

  #goodies .tree.tree-r .front {
    width: 6.13rem;
    height: 6.12rem;
    margin-top: .68rem
  }

  #goodies .tree.tree-r::before {
    width: .24rem;
    height: .24rem;
    left: 67.132%;
    top: 18.655%
  }

  #goodies .tree.tree-r::after {
    width: .36rem;
    height: .36rem;
    left: 88.227%;
    top: 31.852%
  }

  #goodies .tree.tree-l .back,
  #goodies .tree.tree-l .front {
    transform: translate(-50%, -50%) rotate(15deg);
  }


  #goodies .tree.tree-r .back,
  #goodies .tree.tree-r .front {
    transform: translate(-50%, -50%) rotate(-15deg);
  }


  #goodies .tree.tree-l .back img,
  #goodies .tree.tree-l .front img {
    animation-name: tree-left-move;
  }

  #goodies .tree.tree-r .back img,
  #goodies .tree.tree-r .front img {
    animation-name: tree-right-move;
  }

}

@media (max-width: 1080px) {
  #goodies .sect-cont::before {
    min-height: .93rem;
    flex: .93;
  }

  #goodies .sect-cont::after {
    flex: 2.8
  }

  #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: 15.5rem;
    background-image: url(../img/bg-goodies-mo.jpg)
  }

  #goodies .sect-title {
    width: 6.75rem;
    margin: 0 auto .6rem;
  }

  #goodies .goodies-nav.swiper-container {
    width: 100%;
    max-width: 6.48rem;
    box-sizing: border-box;
    height: auto;
    overflow: visible;
    margin-bottom: -.25rem;
  }

  #goodies .goodies-nav .swiper-wrapper {
    height: .68rem;
  }


  #goodies .goodies-nav .swiper-slide {
    width: fit-content;
    box-sizing: content-box;
  }

  #goodies .goodies-nav .swiper-slide+.swiper-slide {
    padding-left: .07rem
  }

  #goodies .goodies-content {
    width: 6.9rem;
  }

  #goodies .goodies-content .swiper-container {
    top: 1rem;
    padding: .3rem 0;
    width: 5.42rem
  }

  #goodies .goodies-buttons {
    gap: .2rem
  }


  #goodies .tree.tree-l {
    width: 7.65rem;
    height: 6.97rem;
    margin-left: 3.9rem;
    margin-top: -4.61rem
  }

  #goodies .tree.tree-r {
    width: 6.7rem;
    height: 6.7rem;
    margin-left: -3.57rem;
    margin-top: -4.9rem
  }

  #goodies .tree.tree-r .front {
    width: 5.21rem;
    height: 5.2rem;
    margin-top: .36rem
  }

  #goodies .tree.tree-l .front {
    width: 6.39rem;
    height: 6.2rem
  }

  #goodies .tree.tree-r::before {
    width: .36rem;
    height: .36rem;
    left: 42.239%;
    top: 40%
  }

  #goodies .tree.tree-r::after {
    width: .75rem;
    height: .75rem;
    left: 55.671%;
    top: 20.597%
  }

  #goodies .tree.tree-l::before {
    width: .24rem;
    height: .24rem;
    left: 40.784%;
    top: 20.8%
  }

  #goodies .tree.tree-l::after {
    width: .38rem;
    height: .38rem;
    left: 52.16%;
    top: 31.564%
  }

  #goodies .tree.tree-l .back,
  #goodies .tree.tree-l .front {
    transform: translate(-50%, -50%) rotate(-15deg);
  }

  #goodies .tree.tree-r .back,
  #goodies .tree.tree-r .front {
    transform: translate(-50%, -50%) rotate(15deg);
  }


  #goodies .tree.tree-l .back img,
  #goodies .tree.tree-l .front img {
    animation-name: tree-right-move;
  }

  #goodies .tree.tree-r .back img,
  #goodies .tree.tree-r .front img {
    animation-name: tree-left-move;
  }
}



/* minigame */
#minigame .sect-cont::before,
#minigame .sect-cont::after {
  flex: none;
}

#minigame .sect-title {
  display: block;
  width: 4.7rem;
  height: auto;
  margin: 0 auto .3rem;
}

.minigame-words {
  position: relative;
  display: block;
  text-align: center;
}

#minigame .common-btn::before,
#minigame .common-btn::after {
  background-image: url(../img/minigame-btn.png);
  width: 3.6rem;
  height: 1.09rem;
}

#minigame .oil-area {
  display: block;
  flex: 1;
  position: relative
}

#minigame .oil-area .moving-icon {
  position: absolute;
  top: 75%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1.68rem;
  height: 2.52rem;
}

#minigame .oil-area .moving-icon>span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#minigame .oil-area .moving-icon .oil {
  width: 100%;
}

#minigame .oil-area .moving-icon .hand {
  width: 1.64rem;
}


#minigame .sect-title,
#minigame .minigame-words,
#minigame .common-btn {
  opacity: 0;
  transform: translateY(10%);
  transition: all .45s ease-out
}


#minigame.activate .sect-title,
#minigame.activate .minigame-words,
#minigame.activate .oil-area,
#minigame.activate .common-btn {
  opacity: 1;
  transform: translateY(0);
}

#minigame .oil-area {
  opacity: 0;
  transform: translateY(5%);
  transition: all .55s ease-out
}

#minigame .oil-area .hand {
  opacity: 0;
  transform: translate(-50%, -60%);
  transition: all .55s ease-out
}

#minigame.activate .sect-title {
  transition-delay: .25s
}

#minigame.activate .minigame-words {
  transition-delay: .5s
}


#minigame.activate .oil-area {
  transition-delay: .9s
}

#minigame.activate .oil-area .hand {
  opacity: 1;
  transform: translate(-50%, -50%);
  transition-delay: 1s
}

#minigame.activate .common-btn {
  transition-delay: 1s
}

#minigame.activate .oil-area .moving-icon .oil>img {
  animation: oil-blink-ani 2.5s 1.4s ease-out infinite;
}

#minigame.activate .oil-area .moving-icon .hand>img {
  animation: oil-hand-ani 2.5s 1.4s ease-out infinite;
}

@media (min-width: 1081px) {
  #minigame .sect-cont::before {
    height: .9rem;
  }

  #minigame .sect-cont::after {
    height: 1.78rem
  }

  #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: 13.12rem;
    background-image: url(../img/bg-minigame-pc.jpg);
    background-position-y: 20%
  }
}

@media (max-width: 1080px) {
  #minigame .sect-cont::before {
    height: 1rem;
  }

  #minigame .sect-cont::after {
    height: 3.6rem
  }

  #minigame .sect-bg {
    -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)
  }
}

@supports (-webkit-touch-callout: none) {
  .common-btn>span {
    transform: translateY(1%)
  }

  a.common-btn>span,
  #roadmap .roadmap-nav button>span {
    transform: translateY(-48.5%)
  }

  #goodies .goodies-nav button>span {
    top: calc(50%-.025rem)
  }
}


/* 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: .24rem;
  right: 0;
  margin-bottom: .1rem
}

.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: translate(-50%, -50%);
  width: 6.13rem;
  pointer-events: none;
}


.modal-popup {
  display: none;
  z-index: 10;
  position: absolute;
  left: 50%;
  top: calc(50% + .2rem);
  transform: translate(-50%, -50%);
  margin: 0 auto;
  height: auto;
  max-height: max(calc(100% - .8rem), 6.4rem);
  width: 6.4rem;
  background: #fff;
  transition: transform .25s var(--bounce);
  border-radius: .2rem;
  pointer-events: none;
  box-sizing: border-box;
  padding: .1rem;
  color: #1d1d1d
}

.inner-popup.visible {
  display: block;
}

.modal-popup.visible {
  display: block;
  pointer-events: auto;
}

.modal-popup::before {
  content: "";
  display: block;
  position: absolute;
  left: .06rem;
  right: .06rem;
  bottom: .06rem;
  top: .06rem;
  border-radius: .16rem;
  background: linear-gradient(248.54deg, #0089FE 1.18%, #00B2FC 50.96%, #32E0FF 98.86%);
}

.modal-popup .popup-content {
  width: 100%;
  display: block;
  position: relative;
  background: #fff;
  border-radius: .13rem;
  box-sizing: border-box;
  padding: .4rem .3rem;
}

.modal-popup.alert {
  width: 5rem;
}

.modal-popup.alert .face {
  display: block;
  width: 1.4rem;
  margin: .06rem auto .04rem
}

.alert-title {
  color: #0383FF;
  font-weight: 600;
  letter-spacing: -.05em;
  text-align: center;
}

.alert-title>span {
  display: inline-block;
  position: relative;
  padding: 0 .12rem
}

.alert-title>span::before,
.alert-title>span::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: .2rem;
  background: url(../img/ic-title-deco.svg) no-repeat center / 100% auto;
}


.alert-title>span::before {
  right: 100%;
  transform: rotateY(180deg)
}

.alert-title>span::after {
  left: 100%
}

.alert-words {
  text-align: center;
  letter-spacing: -.025em;
  font-weight: 500
}

.alert-msg {
  text-align: center;
  letter-spacing: -.025em;
  font-weight: 500;
  color: #0383FF
}

.popup-content .popup-title {
  display: block;
  font-weight: 600;
  letter-spacing: -.05em;
  color: #0383FF;
  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 .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: .3rem .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
}


@media (min-width: 1081px) {
  .popup-content .popup-title {
    font-size: .28rem;
    line-height: .33rem
  }

  .popup-content .alert-title {
    font-size: .32rem;
    line-height: .38rem
  }
  .alert-title>span::before,
  .alert-title>span::after{
    height: .38rem;
  }

  .modal-popup.alert .face {
    margin: .14rem auto .04rem
  }

  .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: .23rem;
    margin-top: .06rem
  }
  .face + .alert-msg{
    margin-top:0;
    padding-top:.02rem;
    padding-bottom:.1rem
  }
}

@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: .2rem auto .08rem
  }

  .popup-content .popup-title {
    padding-left: .14rem;
    padding-right: .14rem;
  }

  .popup-content .popup-title br {
    display: none
  }

  .popup-content .legal-notice {
    padding: .4rem .3rem 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: .3rem;
  }

  .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
  }
}


/* character shutter */
#character .flash-light {
  -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;
}

@media (min-width: 1081px) {
  #character .flash-light {
    -webkit-mask-image: url(../img/bg-character-pc-mask.png);
    mask-image: url(../img/bg-character-pc-mask.png);
    background: radial-gradient(circle at calc(50% - 3.6rem) center, rgba(255, 255, 255, .9), rgba(255, 255, 255, 0));
  }
}

@media (max-width: 1080px) {
  #character .flash-light {
    -webkit-mask-image: url(../img/bg-character-mo-mask.png);
    mask-image: url(../img/bg-character-mo-mask.png);
    background: radial-gradient(circle at center, rgba(255, 255, 255, .9), rgba(255, 255, 255, 0));
  }
}

#character .flash-light {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  mix-blend-mode: lighten;
}

#character.shutter .flash-light {
  animation: shutter-flash-ani .3s var(--bounce) forwards;
}

#character.shutter+.evt-section {
  z-index: 2
}

@keyframes shutter-flash-ani {
  0% {
    opacity: 0
  }

  65% {
    opacity: 1
  }

  100% {
    opacity: 0
  }
}

/* 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-2nd-logo.png);
  mask-image: url(../img/main-2nd-logo.png);
}

#main .sect-title .light::before {
  animation-duration: 10s;
}

#roadmap .sect-title .light {
  -webkit-mask-image: url(../img/roadmap-title.png);
  mask-image: url(../img/roadmap-title.png);
}

#roadmap .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)
  }

  50% {
    transform: scaleY(1.875)
  }
}

@keyframes floating-ani {

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

  50% {
    transform: translateY(-4%);
  }
}

@keyframes floating-ani-s {

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

  50% {
    transform: translateY(-2%);
  }
}

@keyframes oil-blink-ani {

  0%,
  100% {
    opacity: 1;
  }

  40%,
  65% {
    opacity: .6;
  }
}

@keyframes oil-hand-ani {

  0%,
  100% {
    transform: translateY(0);
    opacity: 1;
  }

  45%,
  65% {
    transform: translateY(35%);
    opacity: .5;
  }
}

@keyframes twinkle-ani {

  0%,
  10%,
  80%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
  }

  45%,
  55% {
    transform: translate(-50%, -50%) 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%,
  100% {
    opacity: .2
  }

  50% {
    opacity: .45
  }
}

@keyframes zoom-point-active {
  0% {
    transform: rotate(0deg)
  }

  50% {
    transform: rotate(180deg)
  }

  100% {
    transform: rotate(360deg)
  }
}

@keyframes photo-frame-ani {

  0%,
  70% {
    filter: brightness(2);
  }

  100% {
    filter: brightness(1);
  }
}

@keyframes tree-left-move {

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

  50% {
    transform: rotate(1.5deg);
  }
}

@keyframes tree-right-move {

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

  50% {
    transform: rotate(-1.5deg);
  }
}

@keyframes dolphin-mov {

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

  50% {
    transform: rotate(3.7deg);
  }
}



body.forced-color .radio-btn{
  background:#00f
}
body.forced-color .radio-btn label{
    color:#000 !important
}

@media (forced-colors: active) {
  .radio-btn{background:#f00}
  .radio-btn label{
    color:#000 !important
  }
}