body {
  font-size: calc(25rem + ((1vw - 6.4px) * 3.571));
}

.br-sp {
  display: block;
}

.br-pc {
  display: none;
}

.pc-hide {
  display: block;
}

.sp-hide {
  display: none;
}

.glNav {
  width: 100%;
  height: auto;
  -webkit-transform: translate(0, -120%);
          transform: translate(0, -120%);
  -webkit-transition: -webkit-transform 0.2s ease;
  transition: -webkit-transform 0.2s ease;
  transition: transform 0.2s ease;
  transition: transform 0.2s ease, -webkit-transform 0.2s ease;
}

.glNav.show {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
}

.glNav_menu {
  display: block;
  -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;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 auto;
}

.glNav_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  padding-left: 1vw;
  padding-right: 1vw;
  padding-top: 2vh;
  padding-bottom: 2vh;
  border-bottom: 1px solid white;
  width: 98%;
  height: auto;
  margin: 0 auto;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.glNav_item img {
  display: block;
  width: 100%;
  height: auto;
  padding: 2%;
}

.glNav_item.logo {
  display: block;
  width: 100%;
  height: auto;
  -webkit-filter: drop-shadow(0px -1px 1px rgba(255, 255, 255, 0.6)) drop-shadow(0px 1px 1px rgba(255, 255, 255, 0.6)) drop-shadow(1px 0px 1px rgba(255, 255, 255, 0.6)) drop-shadow(-1px 0px 1px rgba(255, 255, 255, 0.6));
          filter: drop-shadow(0px -1px 1px rgba(255, 255, 255, 0.6)) drop-shadow(0px 1px 1px rgba(255, 255, 255, 0.6)) drop-shadow(1px 0px 1px rgba(255, 255, 255, 0.6)) drop-shadow(-1px 0px 1px rgba(255, 255, 255, 0.6));
}

.glNav_item.logo .image {
  width: 42%;
  height: auto;
  margin: 0 auto;
  -o-object-fit: cover;
     object-fit: cover;
}

/*
.glNav{
	display: block;
	background-color: $baseColor;
	width: 100%;
	height: 70px;
	position: fixed;

	padding-right: 3vw;
	z-index: 5000;
	box-shadow: 0 0 4px 0 white;
	&_menu{
		width:100%;
		height:100%;
		bottom: 0;
		margin: 0 auto;
		
		display:flex;
		flex-direction: row;
		justify-content: flex-end;
		align-items: center;
		right: 10vw;
		vertical-align: bottom;
	}
	&_item{
		padding-left: 1vw;
		padding-right: 1vw;
		justify-content: center;
		align-items: center;
		display:block;
		transition: all 0.4s ease;

		&.no-anim{
			filter: initial;
			filter: brightness(0.6);
			&:hover{
				filter: initial;
				filter: brightness(0.6);
				transform:none;
			}
		}

		&:hover{
			filter: drop-shadow(0px 0px 4px rgba(10, 186, 255, 0.986));
		}

		&.logo{
			display: block;
			height:70px;
			width:auto;

			filter: drop-shadow(0px -1px 1px rgba(255,255,255,0.6))
			drop-shadow(0px 1px 1px rgba(255,255,255,0.6)) 
			drop-shadow(1px 0px 1px rgba(255,255,255,0.6))
			drop-shadow(-1px 0px 1px rgba(255,255,255,0.6));
			
			&:hover{
				filter: none;
			
			}

			.image{
				height:80%;
				width:auto;
				margin:5px 0 0 0;
			}
		}
	}

}
*/
.header {
  height: calc(90vh);
}

.header .bg {
  background-position: 40% 50%;
}

.header .caption {
  left: 2vw;
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
  width: 98%;
  max-width: 100%;
}

.header .logo {
  max-width: 93vw;
  right: 2vw;
  bottom: calc(50px + 100px + 40px + (100vh - 100%) /2);
}

.header .release {
  max-width: 100%;
  bottom: calc(50px + 40px + (100vh - 100%) / 2);
  right: 2vw;
  width: 65%;
}

.image-wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: auto;
  margin: 0 auto;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.image-wrapper img {
  width: 100%;
  height: auto;
  padding: 2%;
}

.image-wrapper img:only-child {
  width: 100%;
}

@media screen and (orientation: landscape) {
  .header .caption {
    max-width: 75vw;
  }
  .header .logo {
    max-width: 50vw;
    bottom: calc(20px + 100px + (100vh - 100%) /2);
  }
  .header .release {
    max-width: 50vw;
    bottom: calc(20px + (100vh - 100%) / 2);
  }
  .header .DLC-wrapper {
    left: 20%;
    bottom: 20px;
  }
  .header .DLC-wrapper a {
    width: 29vw;
  }
  .header .famitsu-wrapper {
    bottom: 31px;
  }
  .header .famitsu-div {
    width: 16vw;
  }
}

.sp-glNav-button {
  display: block;
  width: 10vw;
  height: 10vw;
  position: fixed;
  top: 2vw;
  right: 2vw;
  z-index: 5010;
}

.sp-glNav-button img {
  display: block;
  width: 100%;
}

.common-button {
  width: 60%;
}

.sns-button {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 5%;
}

.sns-button__item {
  position: relative;
  width: 10.41667%;
}

.official-sns {
  max-width: auto;
  max-width: initial;
  width: 98%;
  margin-top: 5%;
}

.official-sns__item {
  width: 32.66667%;
}

.official-sns__item img {
  width: 100%;
}

.official-sns__item:not(:last-of-type) {
  margin-right: auto;
}

.official-sns__item:not(:nth-of-type(3n)) {
  margin-right: 1%;
}

.copy-wrapper {
  display: block;
  margin: 3% auto 5%;
  padding: 0 2%;
  text-align: center;
}

.banner-nip {
  display: block;
  margin: 5% auto 0;
  width: 50%;
  margin: 0 2px;
}

.banner-nip img {
  width: 100%;
  vertical-align: bottom;
}

.news_old {
  display: block;
}

.about-first {
  height: auto;
  padding-top: 10%;
  padding-bottom: 10%;
}

.about-first .image {
  position: absolute;
  top: 0%;
  left: -19px;
}

.about-first .text {
  display: block;
  position: relative;
  width: 80%;
  height: auto;
  padding-top: 15%;
  padding-left: 4%;
  padding-right: 4%;
  margin: 0 auto;
}

.about-second {
  background: url(../img/bg_about_second.jpg) 50% 100% no-repeat;
  background-size: cover;
  height: auto;
  padding-top: 10%;
  padding-bottom: 10%;
  overflow-y: hidden;
}

.about-second .image {
  left: auto;
  right: -24px;
  z-index: 100;
  top: 2%;
}

.about-second .text {
  display: block;
  position: relative;
  left: auto;
  width: 80%;
  height: auto;
  min-width: auto;
  padding-top: 16%;
  margin: 0 auto;
}

.system {
  height: auto;
  padding-top: 8%;
  padding-bottom: 8%;
}

.system_section1 {
  background: url(../img/bg_system1.jpg) 45% 50% no-repeat;
  background-size: cover;
  height: auto;
}

.system_section2 {
  background: url(../img/bg_system2.jpg) 85% 50% no-repeat;
  background-size: cover;
  height: auto;
}

.system_section3 {
  background: url(../img/bg_system3.jpg) 50% 50% no-repeat;
  background-size: cover;
  height: auto;
}

.system-section-left {
  position: relative;
  width: calc(60vw - ((100vw - 100%)/2));
  left: 0%;
  padding: 2%;
}

.system-section-left_text {
  position: relative;
  width: 96%;
  max-width: 550px;
}

.system-section-left_text_caption {
  font-size: 1.15em;
}

.system-section-left_text_content {
  font-size: 0.8em;
}

.system-section-left_image {
  position: absolute;
  left: auto;
  right: -6%;
  height: 480px;
  bottom: 0%;
  -webkit-transform: translateX(-27px);
          transform: translateX(-27px);
}

.system-section-left_image img {
  height: 480px;
}

.system-section-right {
  position: relative;
  width: calc(60vw - ((100vw - 100%)/2));
  left: 38%;
  padding: 2%;
}

.system-section-right_text {
  position: relative;
  width: 96%;
  max-width: 550px;
}

.system-section-right_text_caption {
  font-size: 1.15em;
}

.system-section-right_text_content {
  font-size: 0.8em;
}

.section-map {
  width: 100%;
  margin: 0 auto;
  position: relative;
  -webkit-box-shadow: 0 0 10px 0 black;
          box-shadow: 0 0 10px 0 black;
  z-index: 10;
}

.map_container {
  width: 95%;
}

.map_caption {
  left: 0%;
  top: 0%;
}

.map_caption p {
  font-size: 1.4em;
}

.map_image.thumbnail {
  width: 90%;
}

.map_image::after {
  font-size: 1.4em;
}

.map_image .spot_info {
  line-height: 20px;
}

.map_image .spot_info a {
  font-size: 0.5em;
  line-height: initial;
}

.map_image .spot_thumbnail-wrapper {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
}

.map_image .spot_thumbnail-container {
  width: 31%;
}

.offer_caption {
  width: 95%;
}

.offer_caption img {
  width: 100%;
}

.offer_container {
  width: 90%;
  margin: 3% auto;
}

.offer_item {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 690px;
  padding: 0%;
  margin: 4% auto;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
}

.offer_logo {
  width: 80%;
  padding: 2%;
  margin: 4% auto;
}

.offer_text {
  padding: 0%;
  width: 90%;
  margin: 2% auto;
}

.offer_text p {
  font-size: 0.8em;
}

.offer_link {
  width: 75%;
  padding: 2%;
  margin: 4% auto;
  -webkit-box-pack: space-evenly;
      -ms-flex-pack: space-evenly;
          justify-content: space-evenly;
}

.offer_link p {
  font-size: 0.8em;
}

.offer_link:hover {
  background: rgba(255, 255, 255, 0.8);
}

.gallery-slider {
  width: 90%;
  padding-top: 10%;
  padding-bottom: 10%;
  margin: 0 auto;
}

.gallery-slide {
  padding: 5% 0;
}

.swiper-pagination {
  position: relative;
  margin-top: 1%;
}

.product_wrapper {
  width: 95%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.product_wrapper_button {
  width: 800px;
}

.product_logo {
  width: 80%;
}

.product_item {
  width: 80%;
  text-align: center;
}

.product_type {
  width: 40vw;
}

.product_type p {
  text-align: left;
  font-size: 0.8em;
}

.product_text {
  width: 60vw;
  padding-left: 10%;
}

.product_text p {
  text-align: left;
  font-size: 0.8em;
}

.product_benefit-container {
  width: 95%;
  margin: 3% auto;
}

.cero {
  text-align: left;
  padding-left: 10%;
}

.copy {
  width: 100%;
}

.banner-wrapper {
  max-width: 60%;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: 0 auto;
}

#page_system .gameflow {
  width: 100%;
  height: auto;
  padding-bottom: 5%;
}

#page_system .gameflow .content-container {
  display: block;
  width: 95%;
  margin-top: 10%;
}

#page_system .gameflow .caption {
  display: block;
  position: relative;
  width: 100%;
  max-height: 100%;
  width: auto;
  top: 0;
  left: -2%;
  padding-top: 4%;
  z-index: 100;
  visibility: hidden;
  opacity: 0;
}

#page_system .gameflow .caption.visible {
  -webkit-animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
          animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
  visibility: visible;
}

#page_system .gameflow .text {
  display: block;
  position: relative;
  color: white;
  width: 95%;
  padding: 0% 2% 2%;
  visibility: hidden;
  opacity: 0;
}

#page_system .gameflow .text.visible {
  -webkit-animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
          animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
  visibility: visible;
}

#page_system .imagebox {
  position: absolute;
  top: 57%;
  left: 18vw;
}

#page_system .imagebox img {
  width: 400px;
}

#page_character .character {
  width: 100%;
  height: auto;
  padding-bottom: 5%;
}

#page_character .character .content-container {
  display: block;
  width: 95%;
  min-height: 900px;
  margin-top: 10%;
}

#page_character .character .caption {
  display: block;
  position: relative;
  width: 100%;
  max-height: 100%;
  width: auto;
  top: 0;
  left: -2%;
  padding-top: 4%;
  z-index: 100;
  visibility: hidden;
  opacity: 0;
}

#page_character .character .caption.visible {
  -webkit-animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
          animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
  visibility: visible;
}

#page_character .character .text {
  display: block;
  position: relative;
  color: white;
  width: 95%;
  padding: 0% 2% 2%;
  visibility: hidden;
  opacity: 0;
}

#page_character .character .text.visible {
  -webkit-animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
          animation: anim-fadeIn-horizontal-right 0.4s ease forwards;
  visibility: visible;
}

#page_character .character .main-character {
  right: -80px;
  top: 0px;
  z-index: 100;
}

.glNav_item.new:before {
  content: "";
  background: url(../img/new.png) 0 0 no-repeat;
  background-size: cover;
  width: 15%;
  height: 0;
  padding-bottom: 5.41667%;
  position: absolute;
  top: 32%;
  left: 5%;
  bottom: auto;
  right: auto;
  pointer-events: none;
  z-index: 100;
  -webkit-animation: anim-new 1.5s infinite ease;
          animation: anim-new 1.5s infinite ease;
}

.common-button.new:before {
  content: "";
  background: url(../img/new.png) 0 0 no-repeat;
  background-size: cover;
  width: 15%;
  height: 0;
  padding-bottom: 5.41667%;
  position: absolute;
  top: 0%;
  left: 1%;
  bottom: auto;
  right: auto;
  pointer-events: none;
  z-index: 100;
  -webkit-animation: anim-new 1.5s infinite ease;
          animation: anim-new 1.5s infinite ease;
}

.famitsu-div {
  width: 25vw;
}

.DLC-wrapper {
  left: calc(35%);
}

.DLC-wrapper a {
  width: 40vw;
}
