@font-face {
  font-family: "AkFooterFont";
  src: url(assets/v2/AkFooterFont.08a27e0f.eot);
  src: url(assets/v2/AkFooterFont.08a27e0f.eot?#font-spider) format("embedded-opentype"), url(assets/v2/AkFooterFont.61ad1148.woff) format("woff"), url(assets/v2/AkFooterFont.63ec7d55.ttf) format("truetype"), url(assets/v2/AkFooterFont.afb65377.svg) format("svg");
  font-weight: normal;
  font-style: normal;
}
.footer {
  background-color: #1b1b1b;
  padding: 10% 0 5% 0;
  font-family: "AkFooterFont";
}
.footer .footer-content {
  max-width: 30rem;
  margin: auto;
}
.footer a {
  color: #868686;
}
.footer a a:visited {
  color: #868686;
}
.footer ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.footer .footer-links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  width: 90%;
  margin: auto;
  font-size: 0.6rem;
  line-height: 2em;
}
.footer .footer-links .footer-links-item {
  display: inline-block;
  text-align: center;
  white-space: nowrap;
}
.footer .footer-links .footer-links-item .footer-links-link {
  color: #fff;
  display: inline-block;
}
.footer .footer-links .footer-links-item:not(:last-of-type)::after {
  content: "|";
  display: inline-block;
  color: #494949;
  margin: 0 0.5em;
}
.footer .footer-claim {
  margin: 5% 0;
}
.footer .footer-claim .footer-claim-text {
  font-size: 0.6rem;
  margin: 0 auto;
}
.footer .footer-claim .footer-claim-text span {
  display: block;
  text-align: center;
  color: #535353;
}
.footer .footer-qualifications {
  border-top: 1px solid #868686;
  padding: 5% 5% 0;
  display: flex;
  flex-wrap: wrap;
  font-size: 0.6rem;
}
.footer .footer-qualifications .footer-qualifications-item {
  flex-basis: 50%;
  text-align: center;
  color: #868686;
  line-height: 1rem;
}
.footer .footer-qualifications .footer-qualifications-item.policy {
  flex-basis: 100%;
}
.footer .footer-qualifications .footer-qualifications-item.policy img {
  vertical-align: text-bottom;
}
.footer .footer-logo {
  width: 60%;
  display: block;
  margin: 5% auto 0;
}

html,
body {
  margin: 0;
  padding: 0;
}
@media only screen and (max-width: 428px) {
  html {
    font-size: 16px;
  }
}
@media only screen and (max-width: 414px) {
  html {
    font-size: 14px;
  }
}
@media only screen and (max-width: 320px) {
  html {
    font-size: 12px;
  }
}
body {
  margin: auto;
  padding: 0;
  overflow-x: hidden;
  width: 100%;
  max-width: 750px;
  font-family: "SourceHanSansCN", sans-serif;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
img.fill {
  display: block;
  width: 100%;
}
a {
  text-decoration: none;
}

body {
  max-width: unset;
}
.section {
  width: 100%;
  position: relative;
}
.section::before {
  content: "";
  display: block;
  padding-top: 56.25%;
  height: 0;
  background-size: 101% 100%;
}
@media screen and (max-width: 480px) {
  .section::before {
    padding-top: 90%;
    background-size: cover;
    background-position-x: center;
  }
}
.section > img {
  position: absolute;
  display: block;
  pointer-events: none;
}
.section > div {
  position: absolute;
}
.section .section-title {
  left: 25%;
  top: 10%;
  z-index: 25;
}
@media screen and (max-width: 480px) {
  .section .section-title {
    left: 12%;
    top: 15%;
  }
}
.section .tns-outer {
  width: 67.7%;
  overflow: hidden;
  transform: translateX(-50%);
  left: 50%;
  bottom: 0;
  pointer-events: none;
  z-index: 20;
}
.section .tns-outer::before {
  content: "";
  display: block;
  height: 0;
  width: 100%;
  padding-top: 81.2%;
}
.section .tns-outer .tns-ovh {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}
.section .tns-outer .tns-liveregion {
  display: none;
}
.section .slider .slider-item {
  display: inline-block;
  background-size: 100% 100%;
}
.section .slider .slider-item::before {
  content: "";
  display: block;
  height: 0;
  padding-top: 83.08%;
}
.section .slider-btn {
  top: 50%;
  width: 2.5%;
}
@media screen and (max-width: 480px) {
  .section .slider-btn {
    width: 4%;
  }
}
.section .slider-btn:focus {
  outline: none;
}
.section .slider-btn::before {
  content: "";
  display: block;
  height: 0;
  background-image: url(assets/v2/arrow.0ee4d15d.png);
  padding-top: 125%;
  background-size: 100% 100%;
}
.section .slider-btn.prev {
  transform: translate(-50%, -50%);
}
.section .slider-btn.next {
  transform: scaleX(-1) translate(-50%, -50%);
}
.section.home::before {
  background-image: url(assets/v2/background-home.02889881.jpg);
}
.section.home .home-logo {
  top: 5%;
  left: 25%;
  width: 14.6875%;
}
@media screen and (max-width: 480px) {
  .section.home .home-logo {
    top: 8%;
    left: 12%;
    width: 25%;
  }
}
.section.home .home-title {
  top: 35.5%;
  left: 9.5%;
  z-index: 15;
  width: 46.71875%;
}
@media screen and (max-width: 480px) {
  .section.home .home-title {
    top: 40%;
    left: -12%;
    z-index: 15;
    width: 70%;
  }
}
.section.home .home-char {
  top: 0%;
  right: 0;
  z-index: 10;
  width: 97.1875%;
  pointer-events: none;
}
.section.home .home-char::before {
  content: "";
  display: block;
  padding-top: 92.28%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
@media screen and (min-width: 480px) {
  .section.home .home-char::before {
    background-image: url(assets/v2/amiya-pc.3171e468.png);
  }
}
@media screen and (max-width: 480px) {
  .section.home .home-char {
    width: 100%;
    right: auto;
  }
  .section.home .home-char::before {
    background-image: url(assets/v2/amiya-sp.cc7c4472.png);
    padding-top: 137.87%;
  }
}
.section.home .home-download {
  display: flex;
  justify-content: space-between;
  top: 62%;
  z-index: 20;
}
.section.home .home-download .download-qr {
  flex-basis: 38.1%;
  position: relative;
}
.section.home .home-download .download-qr::before {
  content: "";
  display: block;
  height: 0;
  padding-top: 101.5%;
  background-size: 100% 100%;
}
.section.home .home-download .download-qr #gen-qrcode {
  position: absolute;
  width: 44%;
  bottom: 15%;
  left: 28%;
}
.section.home .home-download .download-btns {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.section.home .home-download .download-btns .download-btn {
  position: relative;
}
.section.char::before {
  background-image: url(assets/v2/background-char.b5499e2f.jpg);
}
.section.char .section-title {
  width: 13.22%;
}
.section.char .slider-btn.prev {
  left: 20%;
}
.section.char .slider-btn.next {
  right: 20%;
}
@media screen and (min-width: 480px) {
  .section.char .slider .char-item-5 {
    background-image: url(assets/v2/5.13b6038b.png);
  }
  .section.char .slider .char-item-4 {
    background-image: url(assets/v2/4.5b3aab4d.png);
  }
  .section.char .slider .char-item-3 {
    background-image: url(assets/v2/3.2a3f0ad4.png);
  }
  .section.char .slider .char-item-2 {
    background-image: url(assets/v2/2.5f26a811.png);
  }
  .section.char .slider .char-item-1 {
    background-image: url(assets/v2/1.1ed7f293.png);
  }
}
@media screen and (max-width: 480px) {
  .section.char::before {
    padding-top: 115%;
  }
  .section.char .section-title {
    width: 22%;
  }
  .section.char .tns-outer {
    width: 100%;
  }
  .section.char .tns-outer::before {
    padding-top: 111.47%;
  }
  .section.char .tns-outer .tns-inner .slider .slider-item::before {
    padding-top: 111.47%;
  }
  .section.char .tns-outer .tns-inner .slider .char-item-5 {
    background-image: url(assets/v2/5.8c258962.png);
  }
  .section.char .tns-outer .tns-inner .slider .char-item-4 {
    background-image: url(assets/v2/4.5ce353da.png);
  }
  .section.char .tns-outer .tns-inner .slider .char-item-3 {
    background-image: url(assets/v2/3.beb071cb.png);
  }
  .section.char .tns-outer .tns-inner .slider .char-item-2 {
    background-image: url(assets/v2/2.12ba282d.png);
  }
  .section.char .tns-outer .tns-inner .slider .char-item-1 {
    background-image: url(assets/v2/1.3a6aaa01.png);
  }
  .section.char .slider-btn {
    top: 56%;
  }
  .section.char .slider-btn.prev {
    left: 10%;
  }
  .section.char .slider-btn.next {
    right: 10%;
  }
}
.section.story::before {
  background-image: url(assets/v2/background-story.658f9a87.jpg);
  padding-top: 50.46875%;
}
.section.story .section-title {
  width: 7.5%;
}
.section.story .tns-outer::before {
  padding-top: 76.2%;
}
.section.story .slider .story-item-7 {
  background-image: url(assets/v2/7.18dc9273.png);
}
.section.story .slider .story-item-6 {
  background-image: url(assets/v2/6.6d92cb84.png);
}
.section.story .slider .story-item-5 {
  background-image: url(assets/v2/5.beb47cb9.png);
}
.section.story .slider .story-item-4 {
  background-image: url(assets/v2/4.98d74236.png);
}
.section.story .slider .story-item-3 {
  background-image: url(assets/v2/3.08c811ca.png);
}
.section.story .slider .story-item-2 {
  background-image: url(assets/v2/2.5c4c4f3e.png);
}
.section.story .slider .story-item-1 {
  background-image: url(assets/v2/1.8327f4ca.png);
}
.section.story .slider-btn.prev {
  left: 15%;
}
.section.story .slider-btn.next {
  right: 15%;
}
@media screen and (max-width: 480px) {
  .section.story::before {
    padding-top: 75%;
  }
  .section.story .section-title {
    width: 13%;
    top: 10%;
  }
  .section.story .tns-outer {
    width: 95%;
  }
  .section.story .slider-btn {
    top: 65%;
  }
  .section.story .slider-btn.prev {
    left: 8%;
  }
  .section.story .slider-btn.next {
    right: 8%;
  }
}
.section.footer::before {
  background-image: url(assets/v2/background-footer.bcb58d2f.jpg);
  padding-top: 12.24%;
}
.section.footer .footer-logo {
  transform: translate(-50%, -50%);
  left: 50%;
  top: 50%;
  width: 20.54%;
}
@media screen and (max-width: 480px) {
  .section.footer .footer-logo {
    width: 25%;
  }
}
.side-download-btn {
  width: 5%;
  position: fixed;
  right: 0;
  top: 20%;
  z-index: 50;
}
.side-download-btn::before {
  content: "";
  display: block;
  height: 0;
  background-image: url(assets/v2/side-btn.efea52c0.png);
  padding-top: 220.725%;
  background-size: 100% 100%;
}
.side-download-btn .side-download-ver {
  color: #ffffff;
  background-color: #fcca00;
  position: absolute;
  padding: 1.5rem 0.25rem 0.25rem;
  bottom: -1.25rem;
  z-index: -1;
  right: 0.5rem;
  font-size: 0.8rem;
  text-shadow: 0 0 1px #000, 0 0 2px #000, 0 0 3px #000;
}
@media screen and (max-width: 480px) {
  .side-download-btn {
    width: 10%;
    top: 8%;
  }
  .side-download-btn .side-download-ver {
    right: 0rem;
    bottom: -1rem;
    font-size: 0.5rem;
  }
}
.footer {
  padding: 3rem 0 1rem 0;
}
.footer .footer-content {
  max-width: 30rem;
  margin: auto;
}
.section.home .home-download {
  left: 21%;
}
@media screen and (max-width: 480px) {
  .section.home .home-download {
    width: 35%;
    top: 67%;
    left: 36px;
  }
}
.section.home .home-download .download-btns .download-btn img {
  width: 100%;
}

.nav-top {
  position: fixed;
  width: 100%;
  max-width: 750px;
  left: 50%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 100;
  transform: translate(-50%, -100%);
  animation: enter 0.5s forwards 0.5s;
}
@keyframes enter {
  from {
    transform: translate(-50%, -100%);
  }
  to {
    transform: translate(-50%, 0);
  }
}
.nav-top::before {
  content: "";
  display: block;
  height: 0;
  width: 100%;
  padding-top: 20%;
}
.nav-top .nav-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  padding: 3%;
  display: flex;
  justify-content: space-between;
}
.nav-top .nav-content .nav-icon,
.nav-top .nav-content .nav-download-link {
  height: 100%;
  display: inline-block;
}
.nav-top .nav-content .nav-download-btn {
  height: 100%;
  display: block;
}
.nav-top .nav-content .nav-title {
  flex-basis: 45%;
  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
.nav-top .nav-content .nav-title .nav-title-main {
  font-size: 1.2rem;
  color: #ffffff;
}
.nav-top .nav-content .nav-title .nav-title-ver {
  font-size: 0.8rem;
}
.nav-top .nav-content .nav-title .nav-title-sub {
  color: #bebebe;
  line-height: 1rem;
}
.nav-top .nav-content .nav-title.withRate .nav-title-main {
  font-size: 1rem;
}
.nav-top .nav-content .nav-title.withRate .nav-title-sub {
  font-size: 0.9rem;
}
.nav-top .nav-content .nav-title.withRate .nav-title-rate {
  color: #bebebe;
  line-height: 1em;
  font-size: 0.8rem;
}
.nav-top .nav-content .nav-title.withRate .nav-title-rate .nav-title-comment {
  margin-left: 1em;
  font-size: 0.4rem;
}
.nav-top .nav-content .nav-title-meta {
  color: #ffffff;
  font-size: 0.6rem;
  white-space: nowrap;
}
.nav-top .nav-content .nav-title-meta.name {
  font-size: 1.2rem;
}

