@charset "UTF-8";
/* -----------------------------------------------------------------
基本設定
-------------------------------------------------------------------*/
@import url('"https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;500;700;900&display=swap');
a,
ins {
  text-decoration: none; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
hr,
menu,
nav,
section {
  display: block; }

a,
hr {
  padding: 0; }

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0; }

ins,
mark {
  background-color: #ff9;
  color: #000; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 400; }

body {
  line-height: 1; }

nav ul {
  list-style: none; }

ul li {
  list-style-type: none; }

blockquote,
q {
  quotes: none; }

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: '';
  content: none; }

a {
  margin: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0; }

mark {
  font-style: italic;
  font-weight: 700; }

del {
  text-decoration: line-through; }

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

hr {
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0; }

input,
select {
  vertical-align: middle; }

html {
  font-size: 10px;
  font-size: 62.5%; }

body {
  font-family: Noto Serif JP,Hiragino Kaku Gothic ProN,'ヒラギノ角ゴ ProN W3',Meiryo,'メイリオ',sans-serif;
  line-height: 1.6;
  font-size: 2.2em;
  -webkit-text-size-adjust: 100%; }

#page {
  margin: 0 auto;
  overflow: hidden; }

img {
  display: block; }

.inner {
  max-width: 750pt;
  min-width: 750px; }

.btn, .inner {
  margin: 0 auto; }

.btn {
  width: 731px;
  -webkit-transition: all .5s;
  -o-transition: all .5s;
  transition: all .5s; }

.btn:hover {
  -webkit-filter: brightness(120%);
  filter: brightness(120%); }

.scrollFade {
  opacity: 0; }

#container {
  width: 170px;
  height: 4px;
  margin: 0 auto; }

.code_all_body {
  position: absolute; }

#conts_01 section, #conts_02 section, #conts_03 section {
  position: relative; }

h2 img {
  position: relative;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%); }

@-webkit-keyframes vertical {
  0% {
    -webkit-transform: translateY(-20px);
    transform: translateY(-20px); }
  to {
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

@keyframes vertical {
  0% {
    -webkit-transform: translateY(-20px);
    transform: translateY(-20px); }
  to {
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

@-webkit-keyframes b {
  0% {
    -webkit-transform: translateY(0);
    transform: translateY(0); }
  55% {
    -webkit-transform: translateY(5px);
    transform: translateY(5px); }
  to {
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

@keyframes b {
  0% {
    -webkit-transform: translateY(0);
    transform: translateY(0); }
  55% {
    -webkit-transform: translateY(5px);
    transform: translateY(5px); }
  to {
    -webkit-transform: translateY(0);
    transform: translateY(0); } }

@-webkit-keyframes ie-bar {
  0% {
    stroke-dashoffset: 100; }
  to {
    stroke-dashoffset: 0; } }

@keyframes ie-bar {
  0% {
    stroke-dashoffset: 100; }
  to {
    stroke-dashoffset: 0; } }

body {
  font-family: "Noto Sans TC", Arial, sans-serif; }

/* -----------------------------------------------------------------
組件設定
-------------------------------------------------------------------*/
#loader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 999; }

#loader {
  position: relative;
  width: 100%;
  height: 100%; }
  #loader .loader-wrap {
    position: relative;
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
  #loader .loader-container {
    text-align: center; }
  #loader img {
    margin: 0 auto;
    width: 418px; }
    @media screen and (max-width: 600px) {
      #loader img {
        width: 80vw;
        height: auto; } }
  #loader p span {
    display: inline-block;
    -webkit-animation: b ease 1s infinite;
    animation: b ease 1s infinite; }
    #loader p span:nth-of-type(1) {
      -webkit-animation-delay: -.6s;
      animation-delay: -.6s; }
    #loader p span:nth-of-type(2) {
      -webkit-animation-delay: -.55s;
      animation-delay: -.55s; }
    #loader p span:nth-of-type(3) {
      -webkit-animation-delay: -.5s;
      animation-delay: -.5s; }
    #loader p span:nth-of-type(4) {
      -webkit-animation-delay: -.45s;
      animation-delay: -.45s; }
    #loader p span:nth-of-type(5) {
      -webkit-animation-delay: -.4s;
      animation-delay: -.4s; }
    #loader p span:nth-of-type(6) {
      -webkit-animation-delay: -.35s;
      animation-delay: -.35s; }
    #loader p span:nth-of-type(7) {
      -webkit-animation-delay: -.3s;
      animation-delay: -.3s; }
    #loader p span:nth-of-type(8) {
      -webkit-animation-delay: -.25s;
      animation-delay: -.25s; }
    #loader p span:nth-of-type(9) {
      -webkit-animation-delay: -.2s;
      animation-delay: -.2s; }
    #loader p span:nth-of-type(10) {
      -webkit-animation-delay: -.15s;
      animation-delay: -.15s; }
    #loader p span:nth-of-type(11) {
      -webkit-animation-delay: -.1s;
      animation-delay: -.1s; }
    #loader p span:nth-of-type(12) {
      -webkit-animation-delay: -50ms;
      animation-delay: -50ms; }
    #loader p span:nth-of-type(13) {
      -webkit-animation-delay: 0;
      animation-delay: 0; }

#hum-menu {
  background-color: #e0d0be;
  -webkit-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 200; }
  #hum-menu nav {
    margin: 0 auto;
    position: relative;
    width: 750px; }
  #hum-menu .nav-list {
    margin: 0 auto;
    padding: 0px 20px 0;
    width: 750px; }
    #hum-menu .nav-list li {
      border-bottom: dotted 2px #fff;
      padding: 20px 0;
      position: relative; }
      #hum-menu .nav-list li a {
        color: #fff;
        display: block;
        font-size: 3rem;
        text-align: center; }
        #hum-menu .nav-list li a:hover {
          color: #f7eebd; }
  @media screen and (max-width: 820px) {
    #hum-menu .nav-list {
      width: auto; }
      #hum-menu .nav-list li a {
        font-size: 4vw; } }
  @media screen and (max-width: 480px) {
    #hum-menu .nav-list {
      width: auto; }
      #hum-menu .nav-list li a {
        font-size: 5vw; } }

#btn-hum {
  position: fixed;
  top: 0px;
  right: 0px;
  z-index: 24;
  width: 100px; }
  #btn-hum img {
    max-width: 100%; }
  @media screen and (max-width: 820px) {
    #btn-hum {
      width: 90px; } }
  @media screen and (max-width: 600px) {
    #btn-hum {
      width: 60px; } }

.btn-close {
  cursor: pointer;
  position: absolute;
  top: 0px;
  right: 30px;
  -webkit-transform: translate(0, -100%);
  -ms-transform: translate(0, -100%);
  transform: translate(0, -100%); }

.outside {
  opacity: 0;
  -webkit-transition: all .2s ease-out;
  -o-transition: all .2s ease-out;
  transition: all .2s ease-out;
  visibility: hidden; }

.open {
  opacity: 1;
  visibility: visible; }

.country {
  margin: 0;
  cursor: pointer;
  position: fixed;
  z-index: 20;
  right: 0px;
  top: 120px;
  width: 100px;
  color: #fff;
  text-align: center;
  background: #000; }
  .country dt {
    font-size: 16px;
    line-height: 31px; }
  .country dd {
    display: none;
    padding: 5px 0;
    margin: 0; }
    .country dd a {
      display: block;
      padding: 3px 0;
      font-size: 14px;
      color: #fff;
      text-align: center; }
      .country dd a:hover {
        color: #fff; }
    .country dd img {
      display: inline;
      margin: 0 5px 3px 0;
      vertical-align: middle; }
  .country.active dd {
    display: block; }
  @media screen and (max-width: 820px) {
    .country {
      top: 20px;
      right: 130px; } }
  @media screen and (max-width: 820px) {
    .country {
      top: 10px;
      right: 80px; } }

#conts_05 {
  background-color: #563126;
  padding: 50px 0; }
  #conts_05 .inner {
    max-width: none;
    min-width: 1px;
    width: 526px; }
  #conts_05 .btn-section {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    #conts_05 .btn-section a {
      position: relative;
      margin: 0 5px; }
      #conts_05 .btn-section a img {
        max-width: 100%; }
    #conts_05 .btn-section:nth-child(1) a {
      width: 100%; }
    #conts_05 .btn-section:nth-child(2) {
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: space-between; }
      #conts_05 .btn-section:nth-child(2) a {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 250px;
        flex: 0 0 250px; }
  @media screen and (max-width: 620px) {
    #conts_05 .inner {
      width: auto; }
    #conts_05 .btn-section {
      width: 90vw;
      margin-left: auto;
      margin-right: auto; }
      #conts_05 .btn-section:nth-child(1) a {
        width: 90vw; }
      #conts_05 .btn-section:nth-child(2) a {
        -webkit-box-flex: 0;
        -ms-flex: 0 0 44vw;
        flex: 0 0 44vw; } }

footer {
  padding-top: 2pc;
  padding-bottom: 2pc;
  background: #282828; }
  footer p {
    color: #fff;
    text-align: center; }

@media screen and (max-width: 820px) {
  footer .copyright {
    font-size: 12px; } }

#loader-bg {
  background-color: #ffefd5; }

body {
  background-color: #fcdcd1;
  margin: 0;
  padding: 0; }

img {
  display: inline-block; }

.copytext {
  position: absolute; }
  .copytext img {
    width: 175px; }

main {
  width: 100%;
  overflow: hidden;
  position: relative; }
  main:before {
    content: "";
    position: absolute;
    width: 1920px;
    height: 960px;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%); }

@media screen and (max-width: 820px) {
  .inner {
    max-width: auto;
    min-width: auto; } }

header {
  position: relative;
  height: 50vw;
  background-image: url("../images/kv-bg.jpg");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover; }
  header .inner {
    position: relative;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center; }
  header .logo {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 9;
    width: 230px; }
    header .logo img {
      max-width: 100%;
      height: auto; }
  header .slogan h2 {
    width: 42.395vw;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 0; }
    header .slogan h2 span {
      white-space: nowrap;
      text-indent: 100%;
      overflow: hidden;
      display: block;
      width: 100%;
      height: 0;
      padding-top: 31.57895%;
      background-image: url("../images/title.png");
      background-position: center top;
      background-repeat: no-repeat;
      background-size: cover; }
  header .slogan h3 {
    font-size: 30px;
    color: #fff;
    text-align: center;
    margin-bottom: .5em;
    text-shadow: 0 0 20px #000, 0 0 10px #000;
    width: 24em;
    margin-left: auto;
    margin-right: auto; }
  header .slogan .info {
    text-align: center;
    color: #fff;
    text-shadow: 0 0 10px #000,0 0 10px #000,0 0 10px #000,0 0 10px #000; }
  header .app {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding-top: 15px; }
    header .app a {
      margin: 0 5px; }
    header .app img {
      height: 60px; }
  @media screen and (max-width: 1280px) {
    header .logo {
      width: 15vw; }
    header .slogan h3 {
      font-size: 2.2vw; }
    header .slogan .info {
      font-size: 1.8vw; } }
  @media screen and (max-width: 820px) {
    header {
      height: 100vh;
      background-image: url("../images/kv-bg-m.jpg");
      background-size: cover; }
      header .inner {
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: start;
        padding-top: 9vw; }
      header .slogan h2 {
        width: 75vw; }
      header .slogan h3 {
        font-size: 3vw; }
      header .slogan .info {
        font-size: 2.4vw; }
      header .logo {
        width: 20vw; }
      header .store-icon {
        width: 100%;
        position: absolute;
        left: 0;
        bottom: 10vw; } }
  @media screen and (max-width: 820px) {
    header .store-icon img {
      height: 50px; }
    header .inner {
      padding-top: 20vw; }
    header .slogan h2 {
      width: 90vw; } }

.place-list {
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }

.place-item {
  width: 280px; }
  .place-item img {
    max-width: 100%;
    height: auto; }

@media screen and (max-width: 1180px) and (orientation: landscape) {
  .place-item {
    width: 200px; } }

@media screen and (max-width: 820px) {
  .place-item {
    width: 30vw; } }

.app {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  .app a {
    margin: 0 5px; }
  @media screen and (max-width: 820px) {
    .app {
      width: 100%;
      position: absolute;
      left: 0;
      bottom: 40vw; } }

.info {
  position: absolute;
  left: 0;
  bottom: 0;
  font-size: 0; }
  .info img {
    max-width: 100%;
    height: auto; }
  .info-main {
    width: 294px;
    position: relative;
    z-index: 1; }
  .info-hand {
    width: 34px;
    position: absolute;
    right: 10%;
    top: 12%;
    z-index: 3;
    -webkit-animation: pulse 1s infinite alternate;
    animation: pulse 1s infinite alternate; }
  .info-sound {
    width: 60px;
    position: absolute;
    top: 30%;
    right: -15%;
    z-index: 4;
    -webkit-animation: swing 1s infinite alternate;
    animation: swing 1s infinite alternate; }

@media screen and (max-width: 1180px) and (orientation: landscape) {
  .info-main {
    width: 21.48vw; }
  .info-hand {
    width: 2.4vw; }
  .info-sound {
    width: 4.386vw; } }
  @media screen and (max-width: 820px) {
    .info-main {
      width: 35.8vw; }
    .info-hand {
      width: 4vw; }
    .info-sound {
      width: 7.31vw; } }

@-webkit-keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1); }
  50% {
    -webkit-transform: scale3d(1.2, 1.2, 1.2);
    transform: scale3d(1.2, 1.2, 1.2); }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1); } }

@keyframes pulse {
  0% {
    -webkit-transform: scaleX(1);
    transform: scaleX(1); }
  50% {
    -webkit-transform: scale3d(1.2, 1.2, 1.2);
    transform: scale3d(1.2, 1.2, 1.2); }
  to {
    -webkit-transform: scaleX(1);
    transform: scaleX(1); } }

#conts-wrap {
  padding-top: 100px; }

.gotop {
  position: fixed;
  left: 10px;
  bottom: 5vw;
  z-index: 20;
  width: 200px; }
  .gotop img {
    max-width: 100%;
    height: auto; }
  @media screen and (max-width: 820px) {
    .gotop {
      width: 25vw; } }

.xpay {
  bottom: 70px; }
  @media screen and (max-width: 820px) {
    .xpay {
      bottom: 100px;
      right: 10px; }
      .xpay-main {
        width: 20vw; } }
  @media screen and (max-width: 480px) {
    .xpay {
      bottom: 20px; } }
