@charset "UTF-8";
/*********************************************************

二階層目専用CSS

/*********************************************************/
.second {
  padding-bottom: 230px;
}
@media screen and (max-width: 480px) {
  .second {
    padding: 60px 0 80px;
  }
}

.second-bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  background-color: #fff;
}
.second-bg img {
  min-height: 100vh;
  min-width: 100vw;
}

.page-title {
  text-align: center;
  position: relative;
  padding: 0 30px;
  text-shadow: 0px 0px 7px rgba(208, 180, 162, 0.8);
  border-bottom: 1px solid #fff;
  margin-bottom: 100px;
  z-index: 10;
}
@media screen and (max-width: 480px) {
  .page-title {
    padding-top: 50px;
    margin-bottom: 70px;
  }
}
.page-title::before, .page-title::after {
  position: absolute;
  content: "";
  display: block;
  height: 2em;
  bottom: 2px;
  width: 26%;
  background-color: #fff;
}
@media screen and (min-width: 1500px) {
  .page-title::before, .page-title::after {
    width: 33%;
  }
}
@media screen and (max-width: 480px) {
  .page-title::before, .page-title::after {
    height: 1.6em;
    width: 17%;
  }
}
.page-title::before, .page-title::after {
  transform: perspective(0.6em) rotateX(1deg);
}
@media screen and (max-width: 480px) {
  .page-title::before, .page-title::after {
    transform: perspective(0.1em) rotateX(1deg);
  }
}
.page-title::before {
  left: 0;
  transform-origin: bottom left;
}
.page-title::after {
  right: 0;
  transform-origin: bottom right;
}
.page-title .title {
  font-weight: 400;
  line-height: 1;
  font-size: 4.8rem;
  position: relative;
}
@media screen and (max-width: 480px) {
  .page-title .title {
    font-size: 7.5vw;
  }
}
.page-title .title small {
  position: absolute;
  width: 100%;
  text-align: center;
  font-size: 1.3rem;
  bottom: -1.8em;
  letter-spacing: 2px;
  left: 0;
}
@media screen and (max-width: 480px) {
  .page-title .title small {
    font-size: 3vw;
  }
}

.tab-midashi {
  position: relative;
  font-weight: 400;
  color: #000;
  margin: 80px 0 35px;
  overflow: hidden;
}
.tab-midashi::after {
  content: "";
  display: block;
  width: 100%;
  height: 5px;
  position: absolute;
  bottom: 0px;
  background-color: #fff;
}
@media screen and (max-width: 480px) {
  .tab-midashi {
    margin: 50px 0 25px;
    border-bottom-width: 3px;
  }
  .tab-midashi::after {
    height: 2px;
  }
}
.tab-midashi .tab {
  display: inline-block;
  position: relative;
  background-color: #fff;
  max-width: 80%;
}
@media screen and (max-width: 480px) {
  .tab-midashi .tab {
    max-width: 75%;
  }
}
.tab-midashi .tab::after {
  position: absolute;
  transform: perspective(50px) rotateX(40deg) translate3d(0, 0, 0px);
  content: "";
  display: block;
  right: -20px;
  bottom: 0px;
  height: 150%;
  width: 50px;
  z-index: 0;
  background-color: #fff;
}
.tab-midashi .tab > p {
  position: relative;
  z-index: 10;
  transform: translate3d(0, 0, 100px);
  padding: 5px 5px 9px 15px;
  font-size: 2.2rem;
  line-height: 1.3;
  font-weight: bold;
}
@media screen and (max-width: 480px) {
  .tab-midashi .tab > p {
    font-size: 4vw;
    padding: 5px 0px 7px 10px;
    letter-spacing: 0px;
  }
}
.tab-midashi .tab > p > span {
  display: inline-block;
  font-size: 120%;
  line-height: 0.6;
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: 0;
  margin: 5px 5px 0 0;
}
@media screen and (max-width: 480px) {
  .tab-midashi .tab > p > span {
    line-height: 1.1;
  }
}

.nav2nd {
  padding-bottom: 20px;
}
@media screen and (max-width: 480px) {
  .nav2nd {
    padding-bottom: 0px;
  }
}
.nav2nd ul {
  display: flex;
  flex-wrap: wrap;
}
.nav2nd li {
  width: 33.33%;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .nav2nd li {
    width: 50%;
    font-size: 2.5vw;
    margin-bottom: 7px;
    letter-spacing: 0.5px;
  }
}
.nav2nd li .new {
  background-color: #fcc800;
  line-height: 1;
  font-size: 40%;
  color: #000;
  transform: translateY(1px);
  padding: 3px 5px 2px;
  margin-right: 10px;
}
@media screen and (max-width: 480px) {
  .nav2nd li .new {
    display: inline-block;
    margin: 2px 5px;
    font-size: 10px;
    padding: 2px 4px;
    transform: translateY(0px);
  }
}
.nav2nd li a {
  background-color: #000;
  border: 1px solid #333;
  text-decoration: none;
  padding: 15px;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
@media screen and (max-width: 480px) {
  .nav2nd li a {
    padding: 6px 5px;
    flex-wrap: wrap;
  }
}
.nav2nd li a::before {
  content: "";
  top: 0;
  left: 0;
  border-bottom: 20px solid transparent;
  border-left: 20px solid #fff;
  position: absolute;
}
@media screen and (max-width: 480px) {
  .nav2nd li a::before {
    border-width: 10px;
  }
}
.nav2nd li a:hover:not(.selected) {
  background-color: #333;
  color: #fff;
}
.nav2nd li a:hover:not(.selected)::before {
  border-left-color: #000;
}
.nav2nd li a.selected {
  background-color: #fff;
  color: #000;
}
.nav2nd li a.selected::before {
  border-left-color: #000;
  top: -1px;
}

/*********************************************************

ストーリー

/*********************************************************/
.story .maintxt {
  font-size: 2.1rem;
  text-align: center;
  line-height: 3.0;
  text-shadow: 1px 1px 3px #000, 0px 0px 2px #000;
  padding-top: 50px;
  position: relative;
  z-index: 15;
}
@media screen and (max-width: 480px) {
  .story .maintxt {
    font-size: 4.5vw;
    padding: 0px 0px 70px;
    line-height: 2.5;
  }
}
.story .marker {
  position: relative;
  display: inline-block;
  margin: 0 10px;
  font-size: 150%;
  overflow-wrap: break-word;
  white-space: nowrap;
}
@media screen and (max-width: 480px) {
  .story .marker {
    font-size: 125%;
  }
}
.story .marker::before {
  content: "";
  width: calc(100% + 10px);
  left: -5px;
  height: 0.7em;
  top: 46%;
  background-color: rgba(255, 255, 255, 0.2);
  font-weight: 600;
  display: block;
  position: absolute;
  z-index: -1;
}
.story .marker.red {
  color: #ffa0a0;
}
.story .marker.red::before {
  background-color: rgba(255, 0, 0, 0.3);
}
.story .marker.star {
  color: #fff000;
}
.story .marker.star::before {
  background-color: rgba(255, 235, 0, 0.3);
}
.story .img {
  position: absolute;
  width: 550px;
}
@media screen and (max-width: 480px) {
  .story .img {
    width: 75%;
  }
  .story .img::before {
    content: "";
    background-color: rgba(0, 0, 0, 0.4);
    width: 110%;
    height: 110%;
    position: absolute;
    top: -5%;
    left: -5%;
  }
}
.story .img.scr1 {
  top: -50px;
  right: -180px;
}
@media screen and (max-width: 480px) {
  .story .img.scr1 {
    top: -20px;
    right: -10%;
  }
}
.story .img.scr2 {
  top: 35%;
  left: -250px;
}
@media screen and (max-width: 480px) {
  .story .img.scr2 {
    top: 40%;
    left: -10%;
  }
}
.story .img.scr3 {
  bottom: -100px;
  right: -230px;
}
@media screen and (max-width: 480px) {
  .story .img.scr3 {
    bottom: 30px;
    right: 0%;
  }
}

/*********************************************************

キャラクター

/*********************************************************/
.character .second {
  padding-bottom: 0;
}
@media screen and (max-width: 480px) {
  .character .nav2nd li {
    width: 33.33%;
  }
}
.character .chara-new {
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1;
  pointer-events: none;
}
.character .chara-new > span {
  position: absolute;
  top: 14px;
  left: 2px;
  transform: rotate(-45deg);
  color: #000;
  letter-spacing: 0;
  font-family: "Orbitron", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, monospace;
  font-weight: 700;
  font-size: 1.4rem;
}
@media screen and (max-width: 480px) {
  .character .chara-new > span {
    font-size: 3vw;
    top: 10px;
    left: 0px;
  }
}
.character .chara-new::before {
  content: "";
  top: 0;
  left: 0;
  border-bottom: 55px solid transparent;
  border-left: 55px solid #fcc800;
  position: absolute;
}
@media screen and (max-width: 480px) {
  .character .chara-new::before {
    border-width: 40px;
  }
}
.character .smpOnly {
  display: none;
}
@media screen and (max-width: 480px) {
  .character .smpOnly {
    text-align: center;
    margin: 20px 0 30px;
    display: block;
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 480px) {
  .character .chart-wrap {
    overflow: auto;
  }
  .character .chart-wrap > .commonPadding {
    width: 200%;
  }
}
.character .chart {
  position: relative;
  margin: 70px 0 120px;
}
@media screen and (max-width: 480px) {
  .character .chart {
    margin: 0px 0 20px;
  }
}
.character .chart .chara-new {
  background: linear-gradient(to bottom, #fcc800, rgba(255, 255, 255, 0.3));
  width: 105%;
  height: 105%;
  top: -2.5%;
  left: -2.5%;
}
.character .chart .chara-new > span {
  top: 8px;
  left: -1px;
  color: #fcc800;
  z-index: 6;
  font-size: 10px;
}
@media screen and (max-width: 480px) {
  .character .chart .chara-new > span {
    top: 4px;
    left: -5px;
    font-size: 10px;
    transform: scale(0.8) rotate(-45deg);
  }
}
.character .chart .chara-new::before {
  border-bottom: 34px solid transparent;
  border-left: 34px solid #000;
  z-index: 5;
}
@media screen and (max-width: 480px) {
  .character .chart .chara-new::before {
    border-width: 26px;
  }
}
.character .chart .gtlabo {
  background-color: #1f4c90;
}
.character .chart .earth {
  background-color: #4c3d00;
}
.character .chart .relayer {
  background-color: #901f44;
}
.character .chart .company {
  background-color: #521b84;
}
.character .chart .other {
  background-color: #000;
}
.character .chart__thumb {
  position: absolute;
  width: 6.8%;
  font-size: 1.0rem;
}
.character .chart__thumb p {
  text-align: center;
  line-height: 0;
  letter-spacing: 0px;
}
.character .chart__thumb p span {
  transform: scale(0.95);
  display: block;
  width: 130%;
  margin-left: -14%;
  line-height: 1;
  padding: 2px 0 4px;
}
@media screen and (max-width: 480px) {
  .character .chart__thumb p span {
    transform: scale(0.8);
    line-height: 1;
    padding-bottom: 2px;
  }
}
.character .chart__thumb a {
  text-decoration: none;
  transition: all 0.2s ease;
  display: block;
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0);
}
.character .chart__thumb a:hover {
  color: #fff;
}
.character .chart__thumb::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 0;
  bottom: 0;
  background: linear-gradient(to top, #fff, rgba(255, 255, 255, 0.2));
  transition: all 0.2s ease;
}
.character .chart__thumb:hover a {
  border-color: rgba(255, 255, 255, 0.8);
}
.character .chart__thumb:hover::before {
  height: 100%;
}
.character .chart .terra, .character .chart .luna, .character .chart .himiko {
  width: 12.5%;
  font-size: 1.4rem;
}
@media screen and (max-width: 480px) {
  .character .chart .terra, .character .chart .luna, .character .chart .himiko {
    font-size: 4vw;
  }
}
.character .chart .terra p, .character .chart .luna p, .character .chart .himiko p {
  letter-spacing: 2px;
}
.character .chart .greson, .character .chart .observer, .character .chart .aphrodite {
  width: 10%;
  font-size: 1.2rem;
}
@media screen and (max-width: 480px) {
  .character .chart .greson, .character .chart .observer, .character .chart .aphrodite {
    font-size: 2.8vw;
  }
}
.character .chart .greson p, .character .chart .observer p, .character .chart .aphrodite p {
  letter-spacing: 1px;
}
.character .chart .voice-log {
  width: 0%;
  font-size: 0rem;
}
@media screen and (max-width: 480px) {
  .character .chart .voice-log {
    font-size: 0vw;
  }
}
.character .chart .voice-log p {
  letter-spacing: 1px;
}
.character .chart .terra {
  top: 38.4%;
  left: 39.1%;
}
.character .chart .himiko {
  top: 38.4%;
  left: 25.3%;
}
.character .chart .uranus {
  top: 34.8%;
  left: 9.1%;
}
.character .chart .amanogawa {
  top: 34.8%;
  left: 17.1%;
}
.character .chart .mercury {
  top: 41.6%;
  left: 9.1%;
}
.character .chart .sun {
  top: 41.6%;
  left: 17.1%;
}
.character .chart .mars {
  top: 48.4%;
  left: 9.1%;
}
.character .chart .yodaka {
  top: 48.4%;
  left: 17.1%;
}
.character .chart .gillian {
  top: 23%;
  left: 8.3%;
}
.character .chart .media {
  top: 23%;
  left: 16%;
}
.character .chart .pluto {
  top: 23%;
  left: 23.7%;
}
.character .chart .akeboshi {
  top: 23%;
  left: 33.0%;
}
.character .chart .venus {
  top: 23%;
  left: 44.9%;
}
.character .chart .isaac {
  top: 8.0%;
  left: 6%;
}
.character .chart .neil {
  top: 8.2%;
  left: 19.3%;
}
.character .chart .halley {
  top: 8.2%;
  left: 27%;
}
.character .chart .jupiter {
  top: 8.2%;
  left: 39%;
}
.character .chart .saturn {
  top: 8.2%;
  left: 49%;
}
.character .chart .greson {
  top: 76.5%;
  left: 5%;
}
.character .chart .nile {
  top: 89.5%;
  left: 6.5%;
}
.character .chart .eight {
  top: 89.5%;
  left: 14.4%;
}
.character .chart .azul {
  top: 89.5%;
  left: 22.3%;
}
.character .chart .venera {
  top: 89.5%;
  left: 30.2%;
}
.character .chart .hoshino-oji {
  top: 89.5%;
  left: 38.1%;
}
.character .chart .mizuno {
  top: 77%;
  left: 30.5%;
}
.character .chart .technical-chief {
  top: 77%;
  left: 21%;
}
.character .chart .chairman-xoth {
  top: 33.7%;
  left: 88.2%;
}
.character .chart .chairman-atlas {
  top: 7.8%;
  left: 71.5%;
}
.character .chart .mintaka {
  top: 17.9%;
  left: 71.5%;
}
.character .chart .alnilam {
  top: 17.9%;
  left: 79%;
}
.character .chart .alnitak {
  top: 17.9%;
  left: 86.5%;
}
.character .chart .aphrodite {
  top: 65%;
  left: 76%;
}
.character .chart .dark-knight {
  top: 78.6%;
  left: 69.7%;
}
.character .chart .dark-walker {
  top: 78.6%;
  left: 77.8%;
}
.character .chart .dark-lord {
  top: 78.6%;
  left: 85.9%;
}
.character .chart .black-commander {
  top: 90%;
  left: 73.5%;
}
.character .chart .black-soldier {
  top: 90%;
  left: 81.5%;
}
.character .chart .luna {
  top: 46%;
  left: 65%;
}
.character .chart .observer {
  top: 63.1%;
  left: 46%;
}
.character .diagram {
  padding: 0 70px;
  margin-top: -40px;
}
@media screen and (max-width: 480px) {
  .character .diagram {
    padding: 0 0 40px;
    margin-top: 0;
  }
}
@media screen and (max-width: 480px) {
  .character .diagramPadding {
    padding-left: 3vw;
    padding-right: 3vw;
  }
}
.character .glossary {
  position: relative;
  color: #000;
  border-bottom: 10px solid rgba(255, 255, 255, 0.3);
  margin: 180px 0 200px;
}
@media screen and (max-width: 480px) {
  .character .glossary {
    margin: 40px 0;
  }
}
.character .glossary__name {
  position: relative;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
  padding: 50px 0px 0px;
  font-weight: 700;
}
@media screen and (max-width: 480px) {
  .character .glossary__name {
    padding-top: 35px;
  }
}
.character .glossary__name dl {
  position: relative;
  display: flex;
  line-height: 1;
  align-items: center;
  z-index: 1;
  padding-left: 20px;
}
@media screen and (max-width: 480px) {
  .character .glossary__name dl {
    display: block;
    padding: 0px;
  }
}
.character .glossary__name dt {
  font-size: 4.8rem;
  letter-spacing: -1px;
}
@media screen and (max-width: 480px) {
  .character .glossary__name dt {
    font-size: 7vw;
    letter-spacing: 0;
  }
}
.character .glossary__name dd {
  text-align: right;
  font-size: 1.6rem;
  padding: 10px 15px 0 0;
  letter-spacing: 0;
}
@media screen and (max-width: 480px) {
  .character .glossary__name dd {
    text-align: left;
    font-size: 3.5vw;
    padding: 0px 0px 7px 5px;
  }
}
.character .glossary__name dd small {
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  display: block;
  margin-top: 5px;
  font-weight: 400;
  font-size: 80%;
}
@media screen and (max-width: 480px) {
  .character .glossary__name dd small {
    display: inline-block;
    font-size: 70%;
    margin: 0 5px;
  }
}
.character .glossary__name::before {
  position: absolute;
  content: "";
  display: block;
  height: 93%;
  left: -5%;
  bottom: -1px;
  width: 62.5%;
  background-color: #fff;
  transform: skewX(31deg);
}
@media screen and (max-width: 480px) {
  .character .glossary__name::before {
    height: 87%;
    left: -7%;
    width: 88.5%;
  }
}
.character .glossary__name::after {
  position: absolute;
  content: "";
  display: block;
  height: 45%;
  bottom: 0px;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.3);
}
.character .glossary__txtbg {
  background-color: #fff;
  padding: 30px 0 60px;
  line-height: 2;
}
@media screen and (max-width: 480px) {
  .character .glossary__txtbg {
    padding: 20px 0 40px;
    line-height: 1.6;
  }
}
.character .glossary__txt {
  padding: 0px 20px;
}
@media screen and (max-width: 480px) {
  .character .glossary__txt {
    width: 80%;
    padding: 0px;
    position: relative;
    z-index: 2;
    background-color: rgba(255, 255, 255, 0.6);
  }
}
.character .glossary__img {
  position: absolute;
  z-index: 1;
  top: -150px;
  width: 45%;
}
@media screen and (max-width: 480px) {
  .character .glossary__img {
    width: 60%;
    top: 50px;
  }
}
.character .left .glossary__img {
  right: 0;
}
@media screen and (max-width: 480px) {
  .character .left .glossary__img {
    right: -20%;
  }
}
.character .left .glossary__txt {
  width: 60%;
}
@media screen and (max-width: 480px) {
  .character .left .glossary__txt {
    width: 80%;
  }
}
@media screen and (max-width: 480px) {
  .character .right.glossary {
    margin-bottom: 100px;
  }
}
.character .right .glossary__name dl, .character .right .glossary__txt {
  margin-left: 44%;
}
@media screen and (max-width: 480px) {
  .character .right .glossary__name dl, .character .right .glossary__txt {
    margin-left: 20%;
  }
}
.character .right .glossary__name::before {
  left: 40%;
  transform: skewX(-31deg);
}
@media screen and (max-width: 480px) {
  .character .right .glossary__name::before {
    left: 18%;
  }
}
.character .right .glossary__img {
  left: 0;
  text-align: right;
}
@media screen and (max-width: 480px) {
  .character .right .glossary__img {
    left: -17%;
  }
}
.character .letter-5 {
  letter-spacing: -5px !important;
}
@media screen and (max-width: 480px) {
  .character .letter-5 {
    letter-spacing: -2px !important;
  }
}
.character .chara-img {
  position: relative;
  top: -70px;
  right: -32%;
  width: 105%;
}
@media screen and (max-width: 1300px) {
  .character .chara-img {
    right: -24.5%;
  }
}
@media screen and (max-width: 480px) {
  .character .chara-img {
    top: -40px;
    right: 3%;
  }
}
.character .chara-img__common {
  position: absolute;
  top: 0;
  left: 0;
  width: 85%;
  transition: all 0.2s ease;
  z-index: 2;
}
@media screen and (max-width: 1300px) {
  .character .chara-img__common {
    width: 100%;
  }
}
@media screen and (max-width: 480px) {
  .character .chara-img__common {
    width: 150%;
    max-width: inherit;
  }
}
.character .chara-img .hide {
  opacity: 0;
}
.character .chara-img .chara-img__word {
  animation: show 1.5s both;
}
@media screen and (max-width: 480px) {
  .character .chara-img .chara-img__word {
    left: -6%;
  }
}
@keyframes show {
  0% {
    opacity: 0;
    transform: translate(-50px, 20px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
.character .chara-img .chara-img__mecha {
  z-index: 0;
  left: -19%;
  top: -170px;
  width: 90%;
}
@media screen and (max-width: 1300px) {
  .character .chara-img .chara-img__mecha {
    left: -12%;
    top: -140px;
  }
}
@media screen and (max-width: 480px) {
  .character .chara-img .chara-img__mecha {
    top: -20px;
    left: -5%;
  }
}
.character .chara-contents {
  width: 61%;
  position: relative;
  z-index: 2;
  min-height: 800px;
}
@media screen and (max-width: 480px) {
  .character .chara-contents {
    width: 100%;
    min-height: inherit;
  }
}
.character .chara-name {
  display: flex;
  padding: 30px 0 0;
}
@media screen and (max-width: 480px) {
  .character .chara-name {
    padding-top: 20px;
    flex-wrap: wrap;
    width: 80%;
  }
}
.character .chara-name__emblem {
  width: 20%;
  padding-right: 10px;
}
@media screen and (max-width: 480px) {
  .character .chara-name__emblem {
    width: 100%;
    padding: 0 0 15px;
    margin-left: -5%;
  }
  .character .chara-name__emblem > img {
    width: 30%;
  }
}
.character .chara-name__box {
  min-width: 58%;
}
@media screen and (max-width: 480px) {
  .character .chara-name__box {
    min-width: 70%;
  }
}
.character .chara-name__jp {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
  position: relative;
  font-size: 2.4rem;
  color: #000;
  font-weight: 700;
  position: relative;
  overflow: hidden;
  line-height: 0;
}
@media screen and (max-width: 480px) {
  .character .chara-name__jp {
    font-size: 3.5vw;
    padding-right: 40px;
  }
}
.character .chara-name__jp::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  position: absolute;
  bottom: 0px;
  background-color: #fff;
}
.character .chara-name__jp br {
  display: none;
}
.character .chara-name__jp .tab {
  display: inline-block;
  position: relative;
  background-color: #fff;
  max-width: 80%;
}
@media screen and (max-width: 480px) {
  .character .chara-name__jp .tab {
    max-width: 100%;
    margin-right: 30px;
  }
}
.character .chara-name__jp .tab::before {
  position: absolute;
  content: "";
  display: block;
  right: -15px;
  bottom: 0px;
  height: 150%;
  width: 50px;
  z-index: -1;
  background-color: #fff;
  transform: perspective(0.6em) rotateX(20deg);
}
@media screen and (max-width: 480px) {
  .character .chara-name__jp .tab::before {
    right: -5px;
    transform: perspective(0.9em) rotateX(15deg);
  }
}
.character .chara-name__jp .tab > p {
  position: relative;
  z-index: 1;
  padding: 4px 0px 6px 10px;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0px;
}
@media screen and (max-width: 480px) {
  .character .chara-name__jp .tab > p {
    font-size: 3.5vw;
    padding: 2px 0px 4px 7px;
    letter-spacing: 0px;
  }
}
.character .chara-name__jp .tab > p > span {
  display: inline-block;
  font-size: 120%;
  line-height: 0.6;
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: 0;
  margin: 10px 5px 0 0;
}
@media screen and (max-width: 480px) {
  .character .chara-name__jp .tab > p > span {
    margin-top: 5px;
  }
}
.character .chara-name__en {
  font-size: 6.5rem;
  line-height: 1.0;
  font-weight: 400;
  font-family: "Orbitron", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, monospace;
  padding: 10px 5px;
  text-shadow: 2px 2px 3px #000;
}
@media screen and (max-width: 480px) {
  .character .chara-name__en {
    font-size: 8vw;
    padding-bottom: 3px;
  }
}
.character .chara-name__cv {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 2rem;
  padding-left: 10px;
  text-shadow: 2px 2px 3px #000;
  letter-spacing: 0.5px;
}
@media screen and (max-width: 480px) {
  .character .chara-name__cv {
    font-size: 3.5vw;
    letter-spacing: 0px;
    padding-left: 7px;
  }
}
.character .costume-change, .character .sample-voice, .character .chara-txt {
  width: 80%;
}
@media screen and (max-width: 480px) {
  .character .costume-change, .character .sample-voice, .character .chara-txt {
    width: 80%;
  }
}
.character .costume-change {
  text-align: right;
  padding-top: 30px;
  margin-top: -60px;
  position: absolute;
  right: 20%;
}
@media screen and (max-width: 480px) {
  .character .costume-change {
    margin-top: -50px;
    text-align: left;
    left: 45%;
  }
}
.character .costume-change__btm {
  width: 86px;
  cursor: pointer;
  position: relative;
  display: inline-block;
}
@media screen and (max-width: 480px) {
  .character .costume-change__btm {
    width: 15vw;
  }
}
.character .costume-change__btm img {
  position: relative;
  z-index: 1;
}
.character .costume-change__btm::before {
  content: "";
  position: absolute;
  width: 90%;
  height: 90%;
  background-color: rgba(255, 207, 0, 0.3);
  opacity: 0;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 50%;
  transition: all 0.2s ease;
}
.character .costume-change__btm:hover::before {
  opacity: 1;
  width: 100%;
  height: 100%;
}
.character .sample-voice {
  font-family: "Orbitron", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, monospace;
  margin-top: 50px;
}
@media screen and (max-width: 480px) {
  .character .sample-voice {
    margin-top: 35px;
  }
}
.character .sample-voice__title {
  position: relative;
  color: #000;
  line-height: 0;
  overflow: hidden;
}
.character .sample-voice__title .tab {
  display: inline-block;
  position: relative;
  background-color: #fff;
  max-width: 80%;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__title .tab {
    max-width: 75%;
  }
}
.character .sample-voice__title .tab::before {
  position: absolute;
  content: "";
  display: block;
  right: -10px;
  bottom: 0px;
  height: 150%;
  width: 50px;
  z-index: -1;
  background-color: #fff;
  transform: perspective(0.6em) rotateX(20deg);
}
@media screen and (max-width: 480px) {
  .character .sample-voice__title .tab::before {
    transform: perspective(0.3em) rotateX(15deg);
  }
}
.character .sample-voice__title .tab > p {
  position: relative;
  z-index: 1;
  padding: 6px 5px 3px 12px;
  font-size: 1.2rem;
  line-height: 1;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__title .tab > p {
    font-size: 3vw;
    padding: 5px 5px 5px 10px;
    letter-spacing: 0px;
  }
}
.character .sample-voice__title .tab > p > span {
  display: inline-block;
  font-size: 120%;
  line-height: 0.6;
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: 0;
  margin: 10px 5px 0 0;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__title .tab > p > span {
    margin-top: 5px;
  }
}
.character .sample-voice__list {
  align-items: center;
  justify-content: flex-start;
  background-image: url(../../character/img/sv_bg.png);
  background-size: 100% 100%;
  padding: 15px 30px 17px 10px;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__list {
    flex-wrap: wrap;
    justify-content: flex-start;
    padding: 8px 20px 10px 10px;
  }
}
.character .sample-voice__btm {
  width: 32%;
  text-align: center;
  cursor: pointer;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 7px 5px;
  transition: all 0.2s ease;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__btm {
    align-items: center;
    padding: 5px 7px;
  }
}
@media screen and (min-width: 481px) {
  .character .sample-voice__btm:hover {
    background-color: rgba(0, 0, 0, 0.57);
  }
}
.character .sample-voice__btm.play {
  background-color: rgba(255, 255, 255, 0.46);
  color: #000;
}
.character .sample-voice__btm.play .sample-voice__txt {
  text-shadow: 2px 2px 1px #fff;
}
.character .sample-voice__btm.play .sample-voice__icon {
  padding: 5px;
  background-color: rgba(0, 0, 0, 0.6);
}
.character .sample-voice__btm.play .sample-voice__icon::before {
  border-width: 5px;
  border-color: #fff;
}
.character .sample-voice__icon {
  background-color: rgba(255, 255, 255, 0.6);
  padding: 5px 7px;
  margin-right: 7px;
  line-height: 1;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__icon {
    padding: 3px 5px;
    margin-right: 3px;
  }
}
.character .sample-voice__icon::before {
  content: "";
  display: block;
  position: relative;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #000;
}
.character .sample-voice__txt {
  font-size: 2.6rem;
  line-height: 0.8;
  text-shadow: 3px 3px 0 #000;
  padding-bottom: 3px;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__txt {
    font-size: 5vw;
    padding-bottom: 3px;
    text-shadow: 2px 2px 0 #000;
  }
}
.character .sample-voice__txt > small {
  font-size: 45%;
  display: inline-block;
  margin-right: 5px;
  font-weight: 500;
}
@media screen and (max-width: 480px) {
  .character .sample-voice__txt > small {
    display: block;
    margin-right: 0;
    margin-bottom: 2px;
    transform: scale(0.8);
  }
}
.character .chara-txt {
  margin: 40px 0 60px;
  line-height: 2;
}
@media screen and (max-width: 480px) {
  .character .chara-txt {
    margin: 20px 0 50px;
    background-color: rgba(0, 0, 0, 0.4);
    padding: 15px;
    font-size: 3vw;
  }
}
.character .mv-scr {
  margin: 30px 30px 180px 0;
}
@media screen and (max-width: 480px) {
  .character .mv-scr {
    margin: 0px 0 100px;
    padding-top: 20px;
  }
}
.character .mv-scr__btmimg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.character .mv-scr__img {
  opacity: 0.8;
}
.character .mv-scr__thumb {
  margin-top: -30px;
  position: relative;
}
.character .mv-scr__thumb a {
  display: inline-block;
  width: 60%;
  background-image: url(../../special/img/movie/movie_bg.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding: 12px 10px;
  position: relative;
}
@media screen and (max-width: 480px) {
  .character .mv-scr__thumb a {
    padding: 7px 5px;
  }
}
.character .mv-scr__thumb .over-border.bg::before {
  background-color: rgba(255, 255, 255, 0.8);
}
.character .mv-scr__thumb:nth-of-type(even) {
  text-align: right;
}
.character .mv-scr__thumb:nth-of-type(1) {
  z-index: 3;
}
.character .mv-scr__thumb:nth-of-type(2) {
  z-index: 2;
}
.character .mv-scr__thumb:nth-of-type(3) {
  z-index: 1;
}
.character .svg-bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 85%;
  height: 100%;
  z-index: 1;
}
@media screen and (max-width: 480px) {
  .character .svg-bg {
    width: 150%;
    right: -15%;
  }
}
.character .gtlabo {
  fill: #348ad3;
}
.character .earth {
  fill: #a58c00;
}
.character .relayer {
  fill: #901f44;
}
.character .company {
  fill: #684588;
}
.character .other {
  fill: #777;
}
.character .foot-nav {
  background-color: #666;
  position: relative;
  z-index: 5;
  border-bottom: 30px solid #000;
}
@media screen and (max-width: 480px) {
  .character .foot-nav {
    border-width: 20px;
  }
}
.character .foot-nav .swiper-container {
  padding: 5px 0;
}
@media screen and (max-width: 480px) {
  .character .foot-nav .swiper-container {
    padding: 3px 0;
  }
}
.character .foot-nav .chara-new {
  z-index: 5;
}
.character .foot-nav .gtlabo {
  background-color: #348ad3;
}
.character .foot-nav .earth {
  background-color: #a58c00;
}
.character .foot-nav .relayer {
  background-color: #901f44;
}
.character .foot-nav .company {
  background-color: #684588;
}
.character .foot-nav .other {
  background-color: #777;
}
.character .foot-nav .catlink {
  display: flex;
  background-color: #000;
}
@media screen and (max-width: 480px) {
  .character .foot-nav .catlink {
    flex-wrap: wrap;
  }
}
.character .foot-nav .catlink li {
  text-align: center;
  width: 25%;
  cursor: pointer;
  padding: 15px;
  border-top: 1px solid #333;
  transition: all 0.2s ease;
}
@media screen and (max-width: 480px) {
  .character .foot-nav .catlink li {
    width: 33.333%;
    letter-spacing: 0;
    padding: 15px 0;
    font-size: 3vw;
  }
  .character .foot-nav .catlink li.cat-gtlabo, .character .foot-nav .catlink li.cat-earth {
    width: 50%;
  }
}
.character .foot-nav .catlink li:nth-of-type(even) {
  background-color: #222;
}
.character .foot-nav .catlink li.cat-gtlabo:hover {
  background-color: #348ad3;
}
.character .foot-nav .catlink li.cat-earth:hover {
  background-color: #a58c00;
}
.character .foot-nav .catlink li.cat-company:hover {
  background-color: #684588;
}
.character .foot-nav .catlink li.cat-relayer:hover {
  background-color: #901f44;
}
.character .foot-nav .catlink li.cat-other:hover {
  background-color: #777;
}
.character .foot-nav__thumb {
  position: relative;
  height: 100%;
}
.character .foot-nav__thumb br {
  display: none;
}
.character .foot-nav__thumb .num {
  font-family: "Orbitron", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, monospace;
  font-size: 3.0rem;
  position: absolute;
  top: 0;
  line-height: 0.8;
}
@media screen and (max-width: 480px) {
  .character .foot-nav__thumb .num {
    font-size: 6.5vw;
  }
}
.character .foot-nav__thumb a {
  display: block;
  position: relative;
}
.character .foot-nav__thumb a .over {
  background-color: rgba(0, 0, 0, 0.7);
  font-feature-settings: normal;
  color: #fff;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
  font-size: 2.2rem;
  writing-mode: vertical-rl;
  text-orientation: upright;
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 1;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0;
  letter-spacing: 0px;
  transition: all 0.2s ease;
}
@media screen and (max-width: 480px) {
  .character .foot-nav__thumb a .over {
    opacity: 1;
    font-size: 3.5vw;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.5) 20%, transparent 80%);
    justify-content: flex-end;
    align-items: flex-end;
    padding-bottom: 5px;
    color: rgba(255, 255, 255, 0.81);
  }
}
@media screen and (min-width: 481px) {
  .character .foot-nav__thumb a:hover .over {
    opacity: 1;
  }
}

/*********************************************************

ロボット

/*********************************************************/
.robot .mecha .itembox, .robot .mecha_next .itembox {
  display: flex;
  flex-wrap: wrap;
}
.robot .mecha .itembox:last-of-type, .robot .mecha_next .itembox:last-of-type {
  margin-bottom: 0;
}
.robot .mecha dl, .robot .mecha_next dl {
  display: flex;
  width: 48%;
  margin: 0px 0 35px;
  align-items: flex-start;
}
@media screen and (max-width: 480px) {
  .robot .mecha dl, .robot .mecha_next dl {
    width: 100%;
    display: block;
    margin-bottom: 30px;
  }
}
.robot .mecha dl:nth-of-type(2n), .robot .mecha_next dl:nth-of-type(2n) {
  margin-left: 4%;
}
@media screen and (max-width: 480px) {
  .robot .mecha dl:nth-of-type(2n), .robot .mecha_next dl:nth-of-type(2n) {
    margin-left: 0;
  }
}
.robot .mecha dt, .robot .mecha_next dt {
  border-left: 5px solid #fff;
  padding-left: 5px;
  width: 35%;
}
.robot .mecha dt img, .robot .mecha_next dt img {
  border: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 480px) {
  .robot .mecha dt, .robot .mecha_next dt {
    border-width: 0px;
    padding: 0 15px 5px 0;
    float: left;
  }
}
.robot .mecha dd, .robot .mecha_next dd {
  padding: 0px 0px 0 20px;
  width: 65%;
}
@media screen and (max-width: 480px) {
  .robot .mecha dd, .robot .mecha_next dd {
    width: auto;
    margin-left: 34%;
    padding: 0;
  }
}
.robot .mecha dd .name, .robot .mecha_next dd .name {
  padding: 7px 10px;
  font-weight: 500;
  margin-bottom: 15px;
  line-height: 1.4;
  font-size: 1.7rem;
  background: linear-gradient(to right, rgba(89, 89, 89, 0.7) 40%, transparent);
}
@media screen and (max-width: 480px) {
  .robot .mecha dd .name, .robot .mecha_next dd .name {
    font-size: 3vw;
    line-height: 1.3;
    margin-bottom: 10px;
  }
}
.robot .mecha dd .txt, .robot .mecha_next dd .txt {
  font-size: 1.3rem;
}
@media screen and (max-width: 480px) {
  .robot .mecha dd .txt, .robot .mecha_next dd .txt {
    font-size: 3vw;
    padding: 0 5px;
  }
}
.robot .mecha .type_1 .name, .robot .mecha_next .type_1 .name {
  background: linear-gradient(to right, rgba(255, 36, 36, 0.7) 40%, transparent);
}
.robot .mecha .type_2 .name, .robot .mecha_next .type_2 .name {
  background: linear-gradient(to right, rgba(48, 80, 255, 0.7) 40%, transparent);
}
.robot .mecha .type_3 .name, .robot .mecha_next .type_3 .name {
  background: linear-gradient(to right, rgba(156, 39, 176, 0.7) 40%, transparent);
}
.robot .mecha .type_4 .name, .robot .mecha_next .type_4 .name {
  background: linear-gradient(to right, rgba(7, 163, 82, 0.7) 40%, transparent);
}

/*********************************************************

システム

/*********************************************************/
.system .txtbox {
  display: flex;
  margin-bottom: 150px;
}
@media screen and (max-width: 480px) {
  .system .txtbox {
    flex-wrap: wrap;
    margin-bottom: 70px;
  }
}
.system .txtbox.mb50 {
  padding-bottom: 30px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 480px) {
  .system .txtbox.mb50 {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
}
.system .txtbox:last-of-type {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .system .txtbox:last-of-type {
    margin-bottom: 30px;
  }
}
.system .txtbox .txt {
  width: 60%;
  padding-right: 50px;
}
@media screen and (max-width: 480px) {
  .system .txtbox .txt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 35px;
  }
}
.system .txtbox .txt .job_img img {
  width: 40%;
  margin: 3% 0 0 3%;
}
@media screen and (max-width: 480px) {
  .system .txtbox .txt .job_img img {
    width: 45%;
  }
}
.system .txtbox .img {
  width: 40%;
}
@media screen and (max-width: 480px) {
  .system .txtbox .img {
    width: 100%;
  }
}
.system .txtbox .img img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.system .txtbox .img a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.system .txtbox .img a:hover img {
  opacity: 0.8;
}
.system .job_icon img {
  width: 3%;
  vertical-align: text-top;
  margin: 0 1% 0 1%;
}
@media screen and (max-width: 480px) {
  .system .job_icon img {
    width: 8%;
    margin: 0 2% 0 2%;
  }
}

/*********************************************************

スペシャル

/*********************************************************/
.special .movie .mvList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList {
    padding-top: 15px;
  }
}
.special .movie .mvList li {
  width: 47.5%;
  margin-bottom: 40px;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList li {
    width: 100%;
    margin-bottom: 30px;
  }
}
.special .movie .mvList .txt {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  line-height: 1.2;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList .txt {
    padding-bottom: 5px;
  }
}
.special .movie .mvList .txt .name {
  font-size: 3.2rem;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList .txt .name {
    font-size: 6.5vw;
    line-height: 1;
  }
}
.special .movie .mvList .thumb {
  position: relative;
}
.special .movie .mvList .thumb a {
  display: block;
  background-image: url(../../special/img/movie/movie_bg.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding: 15px 10px;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList .thumb a {
    padding: 10px 8px;
  }
}
.special .movie .mvList .thumb a img {
  border: 1px solid #ccc;
}
.special .movie .mvList .new .thumb::before {
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  z-index: 1;
  border-bottom: 80px solid transparent;
  border-left: 80px solid #fcc800;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList .new .thumb::before {
    border-width: 60px;
  }
}
.special .movie .mvList .new .thumb::after {
  content: "NEW";
  top: 14px;
  left: 4px;
  position: absolute;
  z-index: 1;
  font-weight: 700;
  color: #000;
  transform: rotate(-45deg);
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: -1px;
  font-size: 2.0rem;
}
@media screen and (max-width: 480px) {
  .special .movie .mvList .new .thumb::after {
    top: 10px;
    left: 2px;
    font-size: 1.6rem;
  }
}
.special .movie .mvList .over-border:hover::before {
  width: 94%;
  height: 87%;
}
.special .dlc .itembox {
  display: flex;
  flex-wrap: wrap;
}
.special .dlc .itembox:last-of-type {
  margin-bottom: 0;
}
.special .dlc dl {
  display: flex;
  width: 48%;
  margin: 0px 0 35px;
  align-items: flex-start;
}
@media screen and (max-width: 480px) {
  .special .dlc dl {
    width: 100%;
    display: block;
    margin-bottom: 30px;
  }
}
.special .dlc dl:nth-of-type(2n) {
  margin-left: 4%;
}
@media screen and (max-width: 480px) {
  .special .dlc dl:nth-of-type(2n) {
    margin-left: 0;
  }
}
.special .dlc dt {
  border-left: 5px solid #fff;
  padding-left: 5px;
  width: 35%;
}
.special .dlc dt img {
  border: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 480px) {
  .special .dlc dt {
    border-width: 0px;
    padding: 0 15px 5px 0;
    float: left;
  }
}
.special .dlc dd {
  padding: 0px 0px 0 20px;
  width: 65%;
}
@media screen and (max-width: 480px) {
  .special .dlc dd {
    width: auto;
    margin-left: 34%;
    padding: 0;
  }
}
.special .dlc dd .name {
  padding: 7px 10px;
  font-weight: 500;
  margin-bottom: 15px;
  line-height: 1.4;
  font-size: 1.7rem;
  background: linear-gradient(to right, rgba(0, 149, 184, 0.7) 40%, transparent);
}
@media screen and (max-width: 480px) {
  .special .dlc dd .name {
    font-size: 3vw;
    line-height: 1.3;
    margin-bottom: 10px;
  }
}
.special .dlc dd .txt {
  font-size: 1.3rem;
}
@media screen and (max-width: 480px) {
  .special .dlc dd .txt {
    font-size: 3vw;
    padding: 0 5px;
  }
}
.special .dlc dd .price {
  font-size: 1.4rem;
  text-align: right;
}
@media screen and (max-width: 480px) {
  .special .dlc dd .price {
    font-size: 3vw;
    line-height: 1.2;
  }
}
.special .dlc dd .price span {
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  font-size: 200%;
  display: inline-block;
  padding: 0 5px;
  transform: translateY(2px);
  letter-spacing: 0;
}
.special .dlc dd .price::before {
  content: "価格：";
}
.special .dlc .paid .name {
  background: linear-gradient(to right, rgba(184, 156, 0, 0.7) 40%, transparent);
}
.special .dlc .paid .price::after {
  content: "円+税";
}
.special .tw-icon .list {
  display: flex;
  flex-wrap: wrap;
}
.special .tw-icon .list a {
  margin: 0.5%;
}
.special .tw-icon .icon a {
  width: 15.6666%;
}
@media screen and (max-width: 480px) {
  .special .tw-icon .icon a {
    width: 31.333%;
  }
}
.special .tw-icon .header-img a {
  width: 32.333%;
}
@media screen and (max-width: 480px) {
  .special .tw-icon .header-img a {
    width: 98%;
  }
}

/*********************************************************
オンラインマニュアル
/*********************************************************/
.manual .manual__img {
  display: flex;
  flex-wrap: wrap;
}
.manual .manual__img a {
  display: block;
  width: 32.333%;
  margin: 0.5%;
}
@media screen and (max-width: 480px) {
  .manual .manual__img a {
    width: 100%;
    margin: 0 0 20px;
  }
}

/*********************************************************
ディレクターメッセージ
/*********************************************************/
.message .txtbox {
  display: flex;
  margin-bottom: 150px;
}
@media screen and (max-width: 480px) {
  .message .txtbox {
    flex-wrap: wrap;
    margin-bottom: 70px;
  }
}
.message .txtbox.mb50 {
  padding-bottom: 30px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 480px) {
  .message .txtbox.mb50 {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
}
.message .txtbox:last-of-type {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .message .txtbox:last-of-type {
    margin-bottom: 30px;
  }
}
.message .txtbox .txt {
  width: 100%;
  padding-right: 50px;
}
@media screen and (max-width: 480px) {
  .message .txtbox .txt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 35px;
  }
}
.message .txtbox .img {
  width: 25%;
}
@media screen and (max-width: 480px) {
  .message .txtbox .img {
    width: 60%;
    margin: auto;
  }
}
.message .txtbox .img img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}

/*********************************************************
出演キャスト 応援メッセージ
/*********************************************************/
.cast_message .mvList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList {
    padding-top: 15px;
  }
}
.cast_message .mvList li {
  width: 47.5%;
  margin-bottom: 40px;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList li {
    width: 100%;
    margin-bottom: 30px;
  }
}
.cast_message .mvList .txt {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  line-height: 1.2;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList .txt {
    padding-bottom: 5px;
  }
}
.cast_message .mvList .txt .name {
  font-size: 3.2rem;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList .txt .name {
    font-size: 6.5vw;
    line-height: 1;
  }
}
.cast_message .mvList .thumb {
  position: relative;
}
.cast_message .mvList .thumb a {
  display: block;
  background-image: url(../../special/img/movie/movie_bg.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding: 15px 10px;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList .thumb a {
    padding: 10px 8px;
  }
}
.cast_message .mvList .thumb a img {
  border: 1px solid #ccc;
}
.cast_message .mvList .new .thumb::before {
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  z-index: 1;
  border-bottom: 80px solid transparent;
  border-left: 80px solid #fcc800;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList .new .thumb::before {
    border-width: 60px;
  }
}
.cast_message .mvList .new .thumb::after {
  content: "NEW";
  top: 14px;
  left: 4px;
  position: absolute;
  z-index: 1;
  font-weight: 700;
  color: #000;
  transform: rotate(-45deg);
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: -1px;
  font-size: 2.0rem;
}
@media screen and (max-width: 480px) {
  .cast_message .mvList .new .thumb::after {
    top: 10px;
    left: 2px;
    font-size: 1.6rem;
  }
}
.cast_message .mvList .over-border:hover::before {
  width: 94%;
  height: 87%;
}

/*********************************************************
インフルエンサー メッセージ
/*********************************************************/
.influencer .mvList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 480px) {
  .influencer .mvList {
    padding-top: 15px;
  }
}
.influencer .mvList li {
  width: 47.5%;
  margin-bottom: 40px;
}
@media screen and (max-width: 480px) {
  .influencer .mvList li {
    width: 100%;
    margin-bottom: 30px;
  }
}
.influencer .mvList .txt {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  line-height: 1.2;
}
@media screen and (max-width: 480px) {
  .influencer .mvList .txt {
    padding-bottom: 5px;
  }
}
.influencer .mvList .txt .name {
  font-size: 3.2rem;
}
@media screen and (max-width: 480px) {
  .influencer .mvList .txt .name {
    font-size: 6.5vw;
    line-height: 1;
  }
}
.influencer .mvList .thumb {
  position: relative;
}
.influencer .mvList .thumb a {
  display: block;
  background-image: url(../../special/img/movie/movie_bg.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  padding: 15px 10px;
}
@media screen and (max-width: 480px) {
  .influencer .mvList .thumb a {
    padding: 10px 8px;
  }
}
.influencer .mvList .thumb a img {
  border: 1px solid #ccc;
}
.influencer .mvList .new .thumb::before {
  content: "";
  top: 0;
  left: 0;
  position: absolute;
  z-index: 1;
  border-bottom: 80px solid transparent;
  border-left: 80px solid #fcc800;
}
@media screen and (max-width: 480px) {
  .influencer .mvList .new .thumb::before {
    border-width: 60px;
  }
}
.influencer .mvList .new .thumb::after {
  content: "NEW";
  top: 14px;
  left: 4px;
  position: absolute;
  z-index: 1;
  font-weight: 700;
  color: #000;
  transform: rotate(-45deg);
  font-family: "Goldman", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "游ゴシック", YuGothic, sans-serif;
  letter-spacing: -1px;
  font-size: 2.0rem;
}
@media screen and (max-width: 480px) {
  .influencer .mvList .new .thumb::after {
    top: 10px;
    left: 2px;
    font-size: 1.6rem;
  }
}
.influencer .mvList .over-border:hover::before {
  width: 94%;
  height: 87%;
}

/*********************************************************
攻略情報
/*********************************************************/
.strategy .list {
  display: flex;
  flex-wrap: wrap;
}
.strategy .list a {
  margin: 0.5%;
}
@media screen and (max-width: 480px) {
  .strategy .list a {
    margin: 2% auto;
  }
}
.strategy .btn-img a {
  width: 32.333%;
}
@media screen and (max-width: 480px) {
  .strategy .btn-img a {
    width: 75%;
  }
}

/*********************************************************
アップデート
/*********************************************************/
/*********************************************************
マニュアル
/*********************************************************/
.manual .txtbox {
  display: flex;
  margin-bottom: 150px;
}
@media screen and (max-width: 480px) {
  .manual .txtbox {
    flex-wrap: wrap;
    margin-bottom: 70px;
  }
}
.manual .txtbox.mb50 {
  padding-bottom: 30px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 480px) {
  .manual .txtbox.mb50 {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
}
.manual .txtbox:last-of-type {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .manual .txtbox:last-of-type {
    margin-bottom: 30px;
  }
}
.manual .txtbox .txt {
  width: 60%;
  padding-right: 50px;
}
@media screen and (max-width: 480px) {
  .manual .txtbox .txt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 35px;
  }
}
.manual .txtbox .img {
  width: 40%;
}
@media screen and (max-width: 480px) {
  .manual .txtbox .img {
    width: 100%;
  }
}
.manual .txtbox .img img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.manual .txtbox .img a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.manual .txtbox .img a:hover img {
  opacity: 0.8;
}

/*********************************************************
アンケート結果
/*********************************************************/
.questionnaire .txtbox {
  display: flex;
  margin-bottom: 150px;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox {
    flex-wrap: wrap;
    margin-bottom: 70px;
  }
}
.questionnaire .txtbox.mb50 {
  padding-bottom: 30px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox.mb50 {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
}
.questionnaire .txtbox:last-of-type {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox:last-of-type {
    margin-bottom: 30px;
  }
}
.questionnaire .txtbox .txt {
  width: 60%;
  padding-right: 50px;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox .txt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 35px;
  }
}
.questionnaire .txtbox .txt .job_img img {
  width: 40%;
  margin: 3% 0 0 3%;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox .txt .job_img img {
    width: 45%;
  }
}
.questionnaire .txtbox .img {
  width: 40%;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox .img {
    width: 100%;
  }
}
.questionnaire .txtbox .img img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.questionnaire .txtbox .img a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.questionnaire .txtbox .img a:hover img {
  opacity: 0.8;
}
.questionnaire .txtbox .img_left {
  width: 50%;
  padding-right: 10px;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox .img_left {
    width: 100%;
    padding-right: 0;
  }
}
.questionnaire .txtbox .img_left img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.questionnaire .txtbox .img_left a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.questionnaire .txtbox .img_left a:hover img {
  opacity: 0.8;
}
.questionnaire .txtbox .img_right {
  width: 50%;
  padding-left: 10px;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox .img_right {
    width: 100%;
    padding-left: 0;
  }
}
.questionnaire .txtbox .img_right img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.questionnaire .txtbox .img_right a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.questionnaire .txtbox .img_right a:hover img {
  opacity: 0.8;
}
.questionnaire .txtbox2 p {
  text-align: center;
}
@media screen and (max-width: 480px) {
  .questionnaire .txtbox2 p {
    text-align: left;
  }
}

/*********************************************************
404エラー
/*********************************************************/
.error404 .center {
  text-align: center;
}
.error404 h2 {
  font-size: 11rem;
  line-height: 0.8;
  font-weight: 500;
  display: inline-block;
  border: 1px solid #333;
  padding: 20px 40px 30px;
  letter-spacing: -5px;
  text-shadow: 0px 0px 10px #999;
}
@media screen and (max-width: 480px) {
  .error404 h2 {
    font-size: 22vw;
    padding: 5vw 8vw 6vw;
  }
}
.error404 h2 small {
  display: block;
  font-size: 35%;
  margin-top: 5px;
  letter-spacing: 1.5px;
}
.error404 h3 {
  font-size: 1.5rem;
  margin: 50px 0 100px;
  font-weight: normal;
}
@media screen and (max-width: 480px) {
  .error404 h3 {
    text-align: left;
    font-size: 3.8vw;
    margin: 30px 0 50px;
  }
}
.error404 .link {
  text-decoration: none;
  display: inline-block;
  background-color: #fff;
  color: #000;
  padding: 2px 15px 5px;
  letter-spacing: 0px;
  transition: all 0.2s ease;
}
@media screen and (max-width: 480px) {
  .error404 .link {
    padding-top: 5px;
  }
}
.error404 .link:hover {
  background-color: #333;
  color: #fff;
}

/*********************************************************

特典系（初回特典、予約特典）ページ

/*********************************************************/
.shopguide .dot-list {
  display: flex;
  flex-wrap: wrap;
  margin: 30px 0 0;
}
@media screen and (max-width: 480px) {
  .shopguide .dot-list {
    margin-top: 15px;
  }
}
.shopguide .dot-list ol {
  width: 33.33%;
}
@media screen and (max-width: 480px) {
  .shopguide .dot-list ol {
    width: 100%;
  }
}

.shop {
  flex-wrap: wrap;
}
@media screen and (max-width: 480px) {
  .shop {
    padding-top: 10px;
  }
}
.shop__box {
  width: 30.333%;
  margin: 1.5%;
  text-align: center;
  background-color: #000;
  padding: 60px 30px 30px;
  position: relative;
  border-top: 10px solid #fff;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 480px) {
  .shop__box {
    width: 48.5%;
    margin: 0 0 20px;
    padding: 40px 8px 8px;
    border-top-width: 5px;
  }
  .shop__box:nth-of-type(odd) {
    margin-right: 3%;
  }
}
.shop__box::before {
  left: 0;
  border-bottom: 20px solid transparent;
  border-left: 20px solid #fff;
}
.shop__box::after {
  right: 0px;
  border-bottom: 20px solid transparent;
  border-right: 20px solid #fff;
}
.shop__box::before, .shop__box::after {
  content: "";
  top: 0;
  position: absolute;
}
@media screen and (max-width: 480px) {
  .shop__box::before, .shop__box::after {
    border-width: 15px;
    top: -1px;
  }
}
.shop__name {
  font-size: 2.6rem;
  letter-spacing: 0px;
  font-weight: 700;
  padding: 0px 0;
  color: #fff;
  position: relative;
  line-height: 0;
  top: -30px;
}
@media screen and (max-width: 480px) {
  .shop__name {
    top: -22px;
    font-size: 3.6vw;
  }
}
.shop__item p {
  padding: 20px 0;
}
.shop__item small {
  display: block;
  font-size: 70%;
  text-align: left;
}
.shop__item a {
  display: block;
  margin-bottom: 10px;
  padding: 3px 0;
}
@media screen and (max-width: 480px) {
  .shop__item a {
    font-size: 3.2vw;
    letter-spacing: 0px;
    margin-bottom: 5px;
  }
}
.shop__btn {
  margin-top: auto;
}
.shop__btn a {
  display: block;
  margin-bottom: 10px;
  padding: 3px 0;
}
@media screen and (max-width: 480px) {
  .shop__btn a {
    font-size: 3.2vw;
    letter-spacing: 0px;
    margin-bottom: 5px;
  }
}

.nav_changePF {
  padding-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .nav_changePF {
    padding-bottom: 30px;
  }
}
.nav_changePF ul {
  display: flex;
  flex-wrap: wrap;
}
.nav_changePF li {
  width: 33.33%;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .nav_changePF li {
    width: 50%;
    font-size: 2.5vw;
    margin-bottom: 7px;
    letter-spacing: 0.5px;
  }
}
.nav_changePF li .new {
  background-color: #fcc800;
  line-height: 1;
  font-size: 40%;
  color: #000;
  transform: translateY(1px);
  padding: 3px 5px 2px;
  margin-right: 10px;
}
@media screen and (max-width: 480px) {
  .nav_changePF li .new {
    display: inline-block;
    margin: 2px 5px;
    font-size: 10px;
    padding: 2px 4px;
    transform: translateY(0px);
  }
}
.nav_changePF li a {
  background-color: #000;
  border: 1px solid #333;
  text-decoration: none;
  padding: 15px;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-radius: 25px 25px 25px 25px;
}
@media screen and (max-width: 480px) {
  .nav_changePF li a {
    padding: 6px 5px;
    flex-wrap: wrap;
  }
}
.nav_changePF li a:hover:not(.selected) {
  background-color: #292929;
  color: #fff;
}
.nav_changePF li a:hover:not(.selected)::before {
  border-left-color: #000;
}
.nav_changePF li a.selected {
  background-color: #fff;
  color: #000;
}
.nav_changePF li a.selected::before {
  border-left-color: #000;
  top: -1px;
}

/*********************************************************

アドバンスト

/*********************************************************/
.advanced .txtbox {
  display: flex;
  margin-bottom: 150px;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox {
    flex-wrap: wrap;
    margin-bottom: 70px;
  }
}
.advanced .txtbox.mb50 {
  padding-bottom: 30px;
  margin-bottom: 40px;
  border-bottom: 1px dotted #999;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox.mb50 {
    padding-bottom: 20px;
    margin-bottom: 30px;
  }
}
.advanced .txtbox:last-of-type {
  margin-bottom: 50px;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox:last-of-type {
    margin-bottom: 30px;
  }
}
.advanced .txtbox .txt {
  width: 60%;
  padding-right: 50px;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox .txt {
    width: 100%;
    padding-right: 0;
    margin-bottom: 35px;
  }
}
.advanced .txtbox .txt .job_img img {
  width: 40%;
  margin: 3% 0 0 3%;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox .txt .job_img img {
    width: 45%;
  }
}
.advanced .txtbox .img {
  width: 40%;
}
@media screen and (max-width: 480px) {
  .advanced .txtbox .img {
    width: 100%;
  }
}
.advanced .txtbox .img img {
  border: 1px solid #666;
  box-shadow: 5px 5px 5px rgba(0, 0, 0, 0.7);
  transition: all 0.2s ease;
}
.advanced .txtbox .img a {
  margin-bottom: 15px;
  display: block;
  background-color: #fff;
}
.advanced .txtbox .img a:hover img {
  opacity: 0.8;
}

/*# sourceMappingURL=second.css.map */
