/*! destyle.css v2.0.2 | MIT License | https://github.com/nicolas-cusan/destyle.css */

*, ::before, ::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-style: solid;
  border-width: 0
}

html {
  line-height: 1.15;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%
}

body {
  margin: 0
}

main {
  display: block
}

p, table, blockquote, address, pre, iframe, form, figure, dl {
  margin: 0
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit
}

ul, ol {
  padding: 0;
  margin: 0;
  list-style: none
}

dt {
  font-weight: bold
}

dd {
  margin-left: 0
}

hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
  margin: 0;
  overflow: visible;
  clear: both;
  color: inherit;
  border-top-width: 1px
}

pre {
  font-family: monospace;
  font-size: inherit
}

address {
  font-style: inherit
}

a {
  color: inherit;
  text-decoration: none;
  background-color: rgba(0, 0, 0, 0)
}

abbr[title] {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted
}

b, strong {
  font-weight: bolder
}

code, kbd, samp {
  font-family: monospace;
  font-size: inherit
}

small {
  font-size: 80%
}

sub, sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline
}

sub {
  bottom: -0.25em
}

sup {
  top: -0.5em
}

img, embed, object, iframe {
  vertical-align: bottom
}

button, input, optgroup, select, textarea {
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  text-align: inherit;
  vertical-align: middle;
  background: rgba(0, 0, 0, 0);
  border-radius: 0;
  outline: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none
}

[type=checkbox] {
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox
}

[type=radio] {
  -webkit-appearance: radio;
  -moz-appearance: radio;
  appearance: radio
}

button, input {
  overflow: visible
}

button, select {
  text-transform: none
}

button, [type=button], [type=reset], [type=submit] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer
}

button[disabled], [type=button][disabled], [type=reset][disabled], [type=submit][disabled] {
  cursor: default
}

button::-moz-focus-inner, [type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner {
  padding: 0;
  border-style: none
}

button:-moz-focusring, [type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText
}

select::-ms-expand {
  display: none
}

option {
  padding: 0
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0
}

legend {
  display: table;
  max-width: 100%;
  padding: 0;
  color: inherit;
  white-space: normal
}

progress {
  vertical-align: baseline
}

textarea {
  overflow: auto
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto
}

[type=search] {
  outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  appearance: button;
  font: inherit
}

label[for] {
  cursor: pointer
}

details {
  display: block
}

summary {
  display: list-item
}

[contenteditable] {
  outline: none
}

table {
  border-spacing: 0;
  border-collapse: collapse
}

caption {
  text-align: left
}

td, th {
  padding: 0;
  vertical-align: top
}

th {
  font-weight: bold;
  text-align: left
}

template {
  display: none
}

[hidden] {
  display: none
}

html {
  height: -webkit-fill-available;
  height: -moz-available;
  height: fill-available;
  font-size: 625%
}

@media(min-width: 769px)and (max-width: 1200px) {
  html {
    font-size: 8.3333333333vw
  }
}

@media(max-width: 768px) {
  html {
    font-size: 13.0208333333vw
  }
}

br.sp {
  display: none
}

@media(max-width: 768px) {
  br.sp {
    display: block
  }
}

br.pc {
  display: block
}

@media(max-width: 768px) {
  br.pc {
    display: none
  }
}

body {
  height: 100vh;
  min-height: -webkit-fill-available;
  min-height: -moz-available;
  min-height: fill-available;
  margin: 0 auto;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: .18rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
  line-height: 1.8;
  color: #000;
  letter-spacing: .1em;
  word-break: break-word;
  overflow-wrap: break-word;
  counter-reset: number 0;
  background: #000;
  hanging-punctuation: first allow-end last
}

header {
  position: fixed;
  top: 0;
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  height: 50px;
  background: rgba(0, 0, 0, .7);
  border-bottom: 1px solid #fff;
  -o-border-image: linear-gradient(to right, transparent 170px, #fff 170px) 1;
  border-image: linear-gradient(to right, transparent 170px, #fff 170px) 1
}

header .logo {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 150px
}

header .navBtn {
  display: none
}

header .gNavWrap .closeBtn {
  display: none
}

header .gNavWrap #gNav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}

header .gNavWrap #gNav ul li a {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  height: 50px;
  padding: 0 .3rem;
  font-family: "Barlow Condensed", sans-serif;
  font-size: .26rem;
  line-height: 1;
  color: #fff
}

header .gNavWrap #gNav ul li a::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  background-image: url("../img/bg_gnav.png");
  background-repeat: no-repeat;
  background-position: top center;
  opacity: 0;
  -webkit-transition: opacity .3s ease;
  transition: opacity .3s ease
}

header .gNavWrap #gNav ul li a:hover::before {
  opacity: 1
}

header .gNavWrap .lang {
  position: absolute;
  top: 5px;
  right: 0;
  display: block;
  width: 1.41rem;
  height: 38px;
  padding: .1rem .31rem .1rem .1rem;
  line-height: 1;
  border-left: .01rem solid #fff
}

header .gNavWrap .lang:hover {
  opacity: .6
}

header .gNavWrap .lang::after {
  position: absolute;
  top: 0;
  right: .12rem;
  bottom: 0;
  display: inline-block;
  width: .1rem;
  height: .11rem;
  margin: auto 0;
  content: "";
  background: url("../img/lang_arrow.png");
  background-size: cover;
  -webkit-transition-duration: .5s;
  transition-duration: .5s
}

header .gNavWrap .lang.on::after {
  -webkit-transform: rotate(-180deg);
  transform: rotate(-180deg)
}

header .gNavWrap ul.langList {
  position: absolute;
  top: 50px;
  right: 0;
  display: none
}

header .gNavWrap ul.langList li {
  position: relative;
  display: grid;
  place-items: center;
  height: .38rem;
  background: #fff
}

header .gNavWrap ul.langList li:first-child::after {
  position: absolute;
  right: 0;
  bottom: -0.02rem;
  left: 0;
  z-index: 1;
  display: inline-block;
  width: 90%;
  margin: 0 auto;
  content: "";
  border-bottom: .02rem solid #000
}

header .gNavWrap ul.langList li:first-child img {
  width: .74rem
}

header .gNavWrap ul.langList li img {
  width: .54rem;
  vertical-align: middle
}

header .gNavWrap ul.langList li a {
  display: block;
  width: 1.41rem;
  padding-left: .4rem
}

header .gNavWrap ul.langList li a.active {
  pointer-events: none
}

header .gNavWrap ul.langList li a.active::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: .16rem;
  display: inline-block;
  width: .16rem;
  height: .16rem;
  margin: auto 0;
  content: "";
  background: url("../img/lang_icon.png");
  background-size: cover
}

header .gNavWrap ul.langList li a:hover {
  background: #ccc;
  opacity: .8
}

header .gNavWrap .gNavLogo {
  display: none
}

@media(max-width: 768px) {
  header {
    height: 70px;
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.75)), to(rgba(0, 0, 0, 0)));
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0) 100%);
    border: none
  }
  header .logo {
    position: absolute;
    top: 14px;
    width: 95px
  }
  header .navBtn {
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 54px;
    padding: 15px
  }
  header .gNavWrap {
    position: fixed;
    top: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 0 .6rem .6rem;
    -webkit-clip-path: inset(0 0 100% 0);
    clip-path: inset(0 0 100% 0);
    background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(37, 88, 25, 0.95)), to(rgba(0, 0, 0, 0.95)));
    background-image: linear-gradient(to bottom, rgba(37, 88, 25, 0.95) 0%, rgba(0, 0, 0, 0.95) 100%);
    border: 1px solid #3cc51c;
    -webkit-transition: .4s;
    transition: .4s
  }
  header .gNavWrap.is-open {
    -webkit-clip-path: inset(0);
    clip-path: inset(0)
  }
  header .gNavWrap::before {
    position: absolute;
    top: .32rem;
    left: .32rem;
    font-family: "Barlow Condensed", sans-serif;
    font-size: .24rem;
    font-weight: 300;
    color: #fff;
    content: "THE KING OF FIGHTERS XIII GLOBAL MATCH"
  }
  header .gNavWrap .closeBtn {
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 1.08rem
  }
  header .gNavWrap #gNav {
    margin-top: -0.6rem
  }
  header .gNavWrap #gNav ul {
    display: block
  }
  header .gNavWrap #gNav ul li a {
    height: auto;
    padding: 0;
    margin-bottom: 2.5vh;
    font-size: 1rem
  }
  header .gNavWrap #gNav ul li a::before {
    display: none
  }
  header .gNavWrap .langWrap {
    position: relative
  }
  header .gNavWrap .langWrap .lang {
    position: relative;
    right: 0;
    z-index: 1;
    width: 1.98rem;
    height: .6rem;
    padding: .2rem .3rem .4rem 0;
    border-bottom: 1px solid #fff;
    border-left: none
  }
  header .gNavWrap .langWrap .lang::after {
    right: 0;
    width: .15rem;
    height: .16rem
  }
  header .gNavWrap .langWrap .lang:hover {
    opacity: 1
  }
  header .gNavWrap .langWrap ul.langList {
    top: .7rem;
    right: auto;
    left: 0;
    z-index: 1;
    width: 1.98rem
  }
  header .gNavWrap .langWrap ul.langList li {
    height: .6rem
  }
  header .gNavWrap .langWrap ul.langList li:first-child img {
    width: 1.14rem
  }
  header .gNavWrap .langWrap ul.langList li img {
    width: .82rem
  }
  header .gNavWrap .langWrap ul.langList li a {
    width: 2.22rem;
    padding-left: .6rem
  }
  header .gNavWrap .langWrap ul.langList li a.active::before {
    width: .24rem;
    height: .24rem
  }
  header .gNavWrap .langWrap ul.langList li a:hover {
    background: #ccc;
    opacity: .8
  }
  header .gNavWrap .gNavLogo {
    position: absolute;
    bottom: .6rem;
    left: 0;
    display: block;
    width: 100%;
    text-align: center
  }
  header .gNavWrap .gNavLogo img {
    width: 4.5rem
  }
}

img, canvas {
  width: 100%;
  height: auto
}

svg {
  display: block
}

footer {
  padding-top: .65rem;
  color: #fff;
  text-align: center;
  background: #000
}

@media(max-width: 768px) {
  footer {
    padding-top: 1rem;
    margin: 0 auto
  }
}

@media(max-width: 768px) {
  footer .inner {
    width: 7.68rem;
    padding: 0 .3rem;
    margin: 0 auto
  }
}

footer .inner .logo {
  display: block;
  width: 2.98rem;
  margin: 0 auto .4rem
}

@media(max-width: 768px) {
  footer .inner .logo {
    width: 7.08rem;
    padding: 0 1.705rem;
    margin: 0 auto .5rem
  }
}

footer .inner .txt {
  font-size: .12rem;
  line-height: 1.5
}

@media(max-width: 768px) {
  footer .inner .txt {
    padding-left: 1em;
    font-size: .2rem;
    text-align: left;
    text-indent: -1em
  }
}

footer .inner .txt.txt_inline {
  display: inline
}

@media(max-width: 768px) {
  footer .inner .txt.txt_inline {
    display: block;
    margin: 0 auto
  }
}

footer .inner .txt.txt_bottom {
  margin: 0 auto .7rem
}

@media(max-width: 768px) {
  footer .inner .txt.txt_bottom {
    margin: 0 auto .7rem
  }
}

footer .inner .txtbottom {
  margin-bottom: .6rem;
  font-size: .12rem
}

@media(max-width: 768px) {
  footer .inner .txtbottom {
    margin-bottom: .7rem;
    font-size: .2rem
  }
}

footer .inner .txtbottom span {
  display: inline-block
}

footer .inner .txtbottom span.ps_logo {
  width: .14rem
}

@media(max-width: 768px) {
  footer .inner .txtbottom span.ps_logo {
    width: .22rem
  }
}

footer .inner .txtbottom span.ps4 {
  width: .4rem
}

@media(max-width: 768px) {
  footer .inner .txtbottom span.ps4 {
    width: .6rem
  }
}

footer .inner .txtbottom span img {
  vertical-align: middle
}

footer .inner ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  place-content: center;
  place-items: center;
  width: 5.8rem;
  padding: 0;
  margin: 0 auto .2rem
}

@media(max-width: 768px) {
  footer .inner ul {
    -webkit-column-gap: .2rem;
    -moz-column-gap: .2rem;
    column-gap: .2rem;
    width: 6.8rem
  }
}

footer .inner ul li {
  list-style: none
}

footer .inner ul li.ps4_logo {
  width: 2.37rem
}

@media(max-width: 768px) {
  footer .inner ul li.ps4_logo {
    width: 3.1rem
  }
}

footer .inner ul li.switch_logo {
  width: 1.98rem
}

@media(max-width: 768px) {
  footer .inner ul li.switch_logo {
    width: 2.59rem
  }
}

footer .inner ul.link {
  grid-template-columns: 1.5rem 2.5rem;
  place-items: start;
  width: 4rem;
  margin: 0 auto .2rem;
  font-size: .2rem
}

@media(max-width: 768px) {
  footer .inner ul.link {
    display: block;
    width: 100%;
    margin: 0 auto .5rem;
    font-size: .34rem
  }
}

footer .inner ul.link li {
  display: grid;
  place-content: center
}

@media(max-width: 768px) {
  footer .inner ul.link li {
    line-height: 2
  }
}

footer .inner ul.link li a {
  display: block;
  width: 2.5rem
}

@media(max-width: 768px) {
  footer .inner ul.link li a {
    width: 100%
  }
}

footer .inner ul.link li a:hover {
  opacity: .8
}

footer .inner ul.link li:first-child {
  border-right: .02rem solid #fff
}

@media(max-width: 768px) {
  footer .inner ul.link li:first-child {
    border: none
  }
}

footer .inner ul.link li:first-child a {
  width: 1.48rem
}

@media(max-width: 768px) {
  footer .inner ul.link li:first-child a {
    width: 7.68rem
  }
}

footer .copy {
  display: grid;
  place-content: center;
  height: .4rem;
  margin: 0 auto;
  border-top: solid #fff .01rem
}

@media(max-width: 768px) {
  footer .copy {
    height: .7rem;
    border-top: solid #fff .02rem
  }
}

footer .copy img {
  width: 2.34rem;
  vertical-align: middle
}

@media(max-width: 768px) {
  footer .copy img {
    width: 4.02rem
  }
}

.pageTitle {
  position: relative;
  margin: 2.1rem 0 2rem;
  text-align: center
}

.pageTitle img {
  position: relative;
  z-index: 1;
  width: auto;
  height: .77rem
}

.pageTitle::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 7rem;
  height: 3rem;
  content: "";
  background: no-repeat center/contain url("../img/bg_ttl.png");
  -webkit-transform: translate(-48%, -40%);
  transform: translate(-48%, -40%)
}

@media(max-width: 768px) {
  .pageTitle {
    margin: 2.3rem 0 2.1rem
  }
  .pageTitle img {
    height: 1rem
  }
  .pageTitle::after {
    width: 100%;
    height: 40vw;
    -webkit-transform: translate(-50%, -40%);
    transform: translate(-50%, -40%)
  }
}

section {
  position: relative;
  margin: 0 auto
}

section h1, section h2, section p, section dl, section dt, section dd, section ul {
  margin: 0 auto
}

section a {
  display: block
}

body {
  background: #fff
}

@media(max-width: 768px) {
  body {
    height: 100vh;
    padding-top: 0
  }
}

@media(hover: hover) {
  a {
    -webkit-transition: .5s;
    transition: .5s
  }
}

header {
  position: relative;
  height: 5.3rem;
  overflow: hidden;
  background: -webkit-gradient(linear, left top, left bottom, from(#fff), color-stop(79%, #fff), color-stop(79%, #f7f7f7), color-stop(82%, #f7f7f7), color-stop(82%, #efefef), color-stop(87%, #efefef), color-stop(87%, #e8e8e8), color-stop(92%, #e8e8e8), color-stop(93%, #e1e1e1), to(#e1e1e1));
  background: linear-gradient(to bottom, #fff 0%, #fff 79%, #f7f7f7 79%, #f7f7f7 82%, #efefef 82%, #efefef 87%, #e8e8e8 87%, #e8e8e8 92%, #e1e1e1 93%, #e1e1e1 100%);
  border-bottom: .14rem solid #000;
  -o-border-image: none;
  border-image: none
}

header .inner {
  width: 12rem
}

@media(max-width: 768px) {
  header .inner {
    width: 100%
  }
}

@media(max-width: 768px) {
  header {
    height: 9.39rem;
    border-bottom: .21rem solid #000
  }
}

header h1, header p {
  position: absolute;
  right: 0;
  left: 0;
  margin: 0 auto
}

header h1 {
  top: .6rem;
  z-index: 10;
  width: 6.52rem
}

@media(max-width: 768px) {
  header h1 {
    top: .8rem
  }
}

header h1 img {
  -webkit-filter: drop-shadow(0 0 0.05rem #fff);
  filter: drop-shadow(0 0 0.05rem #fff)
}

header p {
  top: 2.9rem;
  width: 3.88rem
}

@media(max-width: 768px) {
  header p {
    top: 2.85rem
  }
}

header ul {
  position: relative
}

header ul li {
  position: absolute
}

header ul li:nth-child(1) {
  top: -2.45rem;
  left: calc(50% - 42vw);
  width: 4.63rem
}

@media(max-width: 768px) {
  header ul li:nth-child(1) {
    top: -1rem;
    left: calc(50% - 4.7rem);
    width: 3.8rem
  }
}

header ul li:nth-child(2) {
  top: -2rem;
  left: calc(50% - 58vw);
  width: 5.82rem
}

@media(max-width: 768px) {
  header ul li:nth-child(2) {
    top: .25rem;
    left: calc(50% - 4.4rem);
    width: 4.95rem
  }
}

header ul li:nth-child(3) {
  top: -1.6rem;
  left: calc(50% - 74vw);
  width: 6.1rem
}

@media(max-width: 768px) {
  header ul li:nth-child(3) {
    top: 1.6rem;
    left: calc(50% - 5.8rem);
    width: 5.1rem
  }
}

header ul li:nth-child(4) {
  top: -2.65rem;
  right: calc(50% - 36vw);
  width: 3.18rem
}

@media(max-width: 768px) {
  header ul li:nth-child(4) {
    top: -1rem;
    right: calc(50% - 4.15rem);
    width: 2.65rem
  }
}

header ul li:nth-child(5) {
  top: -2.5rem;
  right: calc(50% - 47vw);
  width: 3.8rem
}

@media(max-width: 768px) {
  header ul li:nth-child(5) {
    top: 0;
    right: calc(50% - 3rem);
    width: 3.25rem
  }
}

header ul li:nth-child(6) {
  top: -1.8rem;
  right: calc(50% - 70vw);
  width: 7.02rem
}

@media(max-width: 768px) {
  header ul li:nth-child(6) {
    top: 1.2rem;
    right: calc(50% - 5.7rem);
    width: 6rem
  }
}

main {
  position: relative;
  padding-top: 1.7rem;
  overflow: hidden
}

@media(max-width: 768px) {
  main {
    padding-top: 1rem
  }
}

main .inner {
  width: 12rem;
  margin: 0 auto
}

@media(max-width: 768px) {
  main .inner {
    width: 100%
  }
}

main::before {
  position: absolute;
  top: -0.7rem;
  display: block;
  width: 100vw;
  height: 50vw;
  -webkit-clip-path: polygon(0 0, 50% 50%, 100% 0, 100% 100%, 50% 50%, 0 100%);
  clip-path: polygon(0 0, 50% 50%, 100% 0, 100% 100%, 50% 50%, 0 100%);
  content: "";
  background-color: #f7f7f7
}

@media(max-width: 768px) {
  main::before {
    top: 11.5rem;
    height: 64vw
  }
}

main .bg_chara {
  position: relative
}

@media(max-width: 768px) {
  main .bg_chara {
    top: 12rem
  }
}

main .bg_chara li {
  position: absolute
}

main .bg_chara li:nth-child(1) {
  top: -1.3rem;
  left: calc(50% - 5.55rem);
  width: 2.11rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(1) {
    top: -2.95rem;
    left: calc(50% - 3.32rem)
  }
}

main .bg_chara li:nth-child(2) {
  top: -1.1rem;
  left: calc(50% - 8.05rem);
  width: 2.28rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(2) {
    top: -1.45rem;
    left: calc(50% - 3.05rem)
  }
}

main .bg_chara li:nth-child(3) {
  top: -1.2rem;
  left: calc(50% - 9.1rem);
  width: 1.88rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(3) {
    top: -1.4rem;
    left: calc(50% - 4.1rem)
  }
}

main .bg_chara li:nth-child(4) {
  top: 1.8rem;
  left: calc(50% - 5.5rem);
  width: 2.76rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(4) {
    top: 2.9rem;
    left: calc(50% - 2.25rem)
  }
}

main .bg_chara li:nth-child(5) {
  top: 2.25rem;
  left: calc(50% - 7.2rem);
  width: 1.76rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(5) {
    top: 1rem;
    left: calc(50% - 1.9rem)
  }
}

main .bg_chara li:nth-child(6) {
  top: 3.6rem;
  left: calc(50% - 8.9rem);
  width: 2.86rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(6) {
    top: 3.3rem;
    left: calc(50% - 3.7rem)
  }
}

main .bg_chara li:nth-child(7) {
  top: -1.4rem;
  right: calc(50% - 4.5rem);
  width: .9rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(7) {
    top: -3rem;
    right: calc(50% - .6rem)
  }
}

main .bg_chara li:nth-child(8) {
  top: -0.6rem;
  right: calc(50% - 6.4rem);
  width: 1.88rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(8) {
    top: -2.1rem;
    right: calc(50% - 2.25rem)
  }
}

main .bg_chara li:nth-child(9) {
  top: -1.5rem;
  right: calc(50% - 9.75rem);
  width: 3.49rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(9) {
    top: -3.4rem;
    right: calc(50% - 4.65rem)
  }
}

main .bg_chara li:nth-child(10) {
  top: .7rem;
  right: calc(50% - 7.7rem);
  width: 1.37rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(10) {
    top: -0.3rem;
    right: calc(50% - 3.3rem)
  }
}

main .bg_chara li:nth-child(11) {
  top: 1.8rem;
  right: calc(50% - 6rem);
  width: 2.64rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(11) {
    top: 1.1rem;
    right: calc(50% - 2.5rem)
  }
}

main .bg_chara li:nth-child(12) {
  top: 2rem;
  right: calc(50% - 9.4rem);
  width: 2.55rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(12) {
    top: 1.8rem;
    right: calc(50% - 4.8rem)
  }
}

main .bg_chara li:nth-child(13) {
  top: 3.9rem;
  right: calc(50% - 7.8rem);
  width: 2.05rem
}

@media(max-width: 768px) {
  main .bg_chara li:nth-child(13) {
    top: 3.4rem;
    right: calc(50% - 2.8rem)
  }
}

main section {
  position: relative;
  z-index: 1;
  margin: 0 auto
}

main section h2 {
  font-size: .4rem;
  font-weight: 700;
  text-align: center
}

@media(max-width: 768px) {
  main section h2 {
    font-size: .6rem
  }
}

main section h2 span {
  display: inline-block;
  padding: .1rem .091rem;
  margin-right: .05rem;
  font-family: "DotGothic16", sans-serif;
  font-weight: 700;
  line-height: 1;
  color: #ffa800;
  background: #000
}

main section h2.en span {
  padding: .1rem .1835rem
}

@media(max-width: 768px) {
  main section h2.en span {
    padding: .1rem .256rem
  }
}

main section p {
  font-size: .22rem;
  text-align: center
}

@media(max-width: 768px) {
  main section p {
    font-size: .32rem
  }
}

main .catch {
  z-index: 1;
  margin-bottom: 1.8rem
}

@media(max-width: 768px) {
  main .catch {
    margin-bottom: 10rem
  }
  main .catch.en {
    margin-bottom: 11rem
  }
  main .catch.en .bg_chara {
    top: 20rem
  }
  main .catch.en p {
    text-align: justify !important
  }
}

main .catch .inner p {
  width: 6rem
}

@media(max-width: 768px) {
  main .catch .inner p {
    width: 7rem
  }
}

main .cont h2 {
  margin-bottom: .2rem;
  font-size: .27rem;
  color: #ffa800
}

@media(max-width: 768px) {
  main .cont h2 {
    font-size: .48rem
  }
}

main .cont h2 span {
  font-size: .37rem
}

@media(max-width: 768px) {
  main .cont h2 span {
    font-size: .66rem
  }
}

main .cont p {
  padding: 0 1rem;
  margin-bottom: .5rem;
  font-size: .18rem;
  text-align: left
}

@media(max-width: 768px) {
  main .cont p {
    font-size: .32rem
  }
}

main .cont p.img {
  width: 10rem;
  margin-bottom: 2.3rem
}

@media(max-width: 768px) {
  main .cont p.img {
    width: 100%
  }
}

main .bg_ttl {
  position: relative;
  margin-bottom: 1.9rem
}

main .bg_ttl::before {
  display: block;
  width: 100%;
  height: .57rem;
  content: "";
  background: #000
}

main .bg_ttl::after {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  display: block;
  width: 5.52rem;
  height: 1.1rem;
  margin: 0 auto;
  content: "";
  background: url("../img/ddot/ttl_bg.png") no-repeat center/contain
}

main .bg_ttl h2 {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1
}

@media(max-width: 768px) {
  main .bg_ttl h2 img {
    vertical-align: middle
  }
}

main h3 {
  position: relative;
  margin: 0 auto .74rem
}

main h3::before, main h3::after {
  position: absolute;
  top: 0;
  display: block;
  width: .57rem;
  height: .32rem;
  content: "";
  background: url("../img/ddot/f_bg.png") no-repeat center/contain
}

main h3::before {
  left: -0.71rem
}

main h3::after {
  right: -0.71rem;
  left: auto;
  -webkit-transform: scale(-1, 1);
  transform: scale(-1, 1)
}

main .gallery, main .wallpaper {
  width: 100%
}

main .gallery {
  margin-bottom: 2.2rem
}

main .gallery h2 {
  width: 2.01rem
}

main .gallery h3 {
  width: 2.04rem
}

main .gallery ul {
  display: grid;
  grid-template-columns: repeat(4, 2.3rem);
  gap: 1.2rem .26rem;
  place-content: center;
  width: 10rem
}

@media(max-width: 768px) {
  main .gallery ul {
    grid-template-columns: repeat(2, 2.3rem);
    gap: 1.2rem 1rem;
    width: 100%
  }
}

main .gallery ul li {
  display: block;
  width: 2.3rem;
  height: 2.3rem;
  background: #f3f3f3
}

main .gallery ul li:nth-child(1) img {
  width: .78rem
}

main .gallery ul li:nth-child(2) img {
  width: 1.14rem
}

main .gallery ul li:nth-child(3) img {
  width: 1.3rem
}

main .gallery ul li:nth-child(4) img {
  width: .93rem
}

main .gallery ul li:nth-child(5) img {
  width: 1.44rem
}

main .gallery ul li:nth-child(6) img {
  width: 1.49rem
}

main .gallery ul li:nth-child(7) img {
  width: 1.19rem
}

main .gallery ul li:nth-child(8) img {
  width: 1.73rem
}

main .gallery ul li:nth-child(9) img {
  width: 1.69rem
}

main .gallery ul li:nth-child(10) img {
  width: .84rem
}

main .gallery ul li:nth-child(11) img {
  width: 1.22rem
}

main .gallery ul li:nth-child(12) img {
  width: 1.4rem
}

main .gallery ul li a {
  position: relative;
  z-index: 1;
  display: block
}

main .gallery ul li a::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 2.3rem;
  height: 2.3rem;
  content: "";
  background: #ffa800;
  -webkit-transition: -webkit-transform ease .5s;
  transition: -webkit-transform ease .5s;
  transition: transform ease .5s;
  transition: transform ease .5s, -webkit-transform ease .5s;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%
}

main .gallery ul li a:hover {
  color: #000
}

main .gallery ul li a:hover::before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: 0% 50%;
  transform-origin: 0% 50%
}

main .gallery ul li a p {
  display: grid;
  place-content: center;
  place-items: center;
  width: 2.3rem;
  height: 2.3rem;
  margin-bottom: .1rem
}

main .gallery ul li a span {
  display: block;
  font-size: .18rem;
  font-weight: 700;
  text-align: center
}

@media(max-width: 768px) {
  main .gallery ul li a span {
    font-size: .22rem
  }
}

main .stage {
  margin-bottom: 2.3rem
}

main .stage h3 {
  width: 1.06rem
}

main .stage ul {
  display: grid;
  grid-template-columns: repeat(2, 4.8rem);
  gap: .6rem .44rem;
  width: 10rem;
  margin-bottom: 1.7rem
}

@media(max-width: 768px) {
  main .stage ul {
    grid-template-columns: repeat(1, 4.8rem);
    width: 4.8rem;
    margin: 0 auto
  }
}

main .stage ul li a:hover {
  opacity: .5
}

main .wallpaper {
  margin-bottom: 1.65rem
}

main .wallpaper h2 {
  width: 2.88rem
}

main .wallpaper ul {
  display: grid;
  grid-template-columns: repeat(2, 4.8rem);
  gap: .8rem .44rem;
  width: 10rem;
  margin: 0 auto
}

@media(max-width: 768px) {
  main .wallpaper ul {
    grid-template-columns: repeat(1, 4.8rem);
    width: 4.8rem;
    margin: 0 auto
  }
}

main .wallpaper ul li {
  width: 4.8rem;
  height: auto;
  background: none
}

main .wallpaper ul li img {
  width: 4.8rem !important
}

main .wallpaper ul li a {
  position: relative;
  z-index: 1;
  width: 4.3rem;
  padding: .1rem 0;
  margin: .32rem auto;
  font-size: .28rem;
  font-weight: 700;
  color: #000;
  text-align: center;
  background: #ffa800;
  border-radius: .5rem
}

main .wallpaper ul li a::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  color: #fff;
  content: "";
  background: #333;
  border-radius: .5rem;
  -webkit-transition: -webkit-transform ease .5s;
  transition: -webkit-transform ease .5s;
  transition: transform ease .5s;
  transition: transform ease .5s, -webkit-transform ease .5s;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%
}

main .wallpaper ul li a:hover {
  color: #fff
}

main .wallpaper ul li a:hover::before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: 0% 50%;
  transform-origin: 0% 50%
}

.mfp-content {
  z-index: 5
}

.gallery-arrow {
  position: absolute;
  top: 50%;
  z-index: 10;
  display: block;
  width: .4rem;
  height: 1rem;
  margin-top: -0.15rem;
  line-height: 1rem;
  cursor: pointer;
  border-radius: 0
}

.gallery-arrow:hover, .gallery-arrow:focus {
  opacity: .5;
  -webkit-transition: all .5s;
  transition: all .5s
}

.gallery-arrow-left {
  left: calc(50% - 3.8rem);
  background: url("../img/ddot/arrow_left.png") no-repeat center/contain
}

.gallery-arrow-right {
  right: calc(50% - 3.8rem);
  background: url("../img/ddot/arrow_right.png") no-repeat center/contain
}

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: pointer
}

.mfp-close-btn-in .mfp-close {
  top: auto;
  right: 0;
  bottom: .54rem;
  left: 0;
  width: .94rem;
  height: .3rem;
  margin: 0 auto;
  font-size: 0;
  text-indent: -999px;
  background: url("../img/ddot/close.png") no-repeat center/contain
}

.mfp-close-btn-in .mfp-close:hover {
  cursor: pointer
}

.mfp-image-holder .gallery-arrow-left {
  left: .5rem
}

.mfp-image-holder .gallery-arrow-right {
  right: .5rem
}

.mfp-image-holder .mfp-close {
  bottom: -0.3rem
}

.character_pop {
  position: relative;
  width: 6.3rem;
  padding: 1.2rem 1rem .9rem;
  margin: 0 auto;
  background: #fff
}

.character_pop p {
  display: none;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto .9rem
}

.character_pop p.active {
  display: block
}

.character_pop a {
  position: relative;
  z-index: 1;
  display: block;
  width: 4.3rem;
  margin: 0 auto .3rem;
  font-size: .26rem;
  text-align: center;
  background-color: #fff;
  background-image: radial-gradient(#ccc 20%, transparent 20%);
  background-size: .1rem .1rem;
  border: .02rem solid #000
}

.character_pop a.active {
  color: #000;
  background-color: #ffa800;
  background-image: none
}

.character_pop a::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  color: #fff;
  content: "";
  background: #ffa800;
  -webkit-transition: -webkit-transform ease .5s;
  transition: -webkit-transform ease .5s;
  transition: transform ease .5s;
  transition: transform ease .5s, -webkit-transform ease .5s;
  -webkit-transform: scaleX(0);
  transform: scaleX(0);
  -webkit-transform-origin: 100% 50%;
  transform-origin: 100% 50%
}

.character_pop a:hover {
  color: #000
}

.character_pop a:hover::before {
  -webkit-transform: scaleX(1);
  transform: scaleX(1);
  -webkit-transform-origin: 0% 50%;
  transform-origin: 0% 50%
}

.main_charaleft, .main_chararight, .bg_chara_left, .bg_chara_right, .fadeup {
  visibility: hidden
}