@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Barlow+Semi+Condensed:wght@500;700;800&family=Noto+Sans+JP:wght@400;700;900&display=swap");
@keyframes scrollbar {
  0% {
    height: 0; }
  15% {
    height: 0; }
  30% {
    height: 0; }
  75% {
    height: 100%; }
  100% {
    height: 100%; } }
@keyframes scrollbar2 {
  0% {
    height: 100%; }
  15% {
    height: 0%; }
  50% {
    height: 0%; }
  100% {
    height: 0%; } }
@keyframes extend {
  0% {
    transform: scaleY(0); }
  100% {
    transform: scaleY(1); } }
@keyframes hidden {
  0% {
    transform: scaleY(1); }
  100% {
    transform: scaleY(0); } }
@keyframes arrowlong01 {
  0% {
    height: 0;
    opacity: 0; }
  20% {
    height: 0;
    opacity: 1; }
  80% {
    height: 100%;
    opacity: 1; }
  100% {
    height: 100%;
    opacity: 0; } }
@keyframes arrowlong02 {
  0% {
    width: 100%;
    opacity: 1; }
  2% {
    width: 100%;
    opacity: 0; }
  3% {
    width: 0;
    opacity: 0; }
  10% {
    width: 0;
    opacity: 1; }
  100% {
    width: 100%;
    opacity: 1; } }
@keyframes arrowslide {
  0% {
    left: -100%;
    opacity: 0; }
  1% {
    left: -100%;
    opacity: 1; }
  100% {
    left: 0;
    opacity: 1; } }
/*
  movie modal
*/
#modalMask {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1600000;
  display: none;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(3px); }

#modalContent {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  z-index: 1600001;
  display: none;
  cursor: pointer; }

#modalContent.view div.mc {
  -webkit-transform: scale(1, 1);
  -moz-transform: scale(1, 1);
  -o-transform: scale(1, 1);
  -ms-transform: scale(1, 1);
  transform: scale(1, 1); }

#modalContent div.mc {
  padding: 10.742vw 0;
  position: fixed;
  left: 50%;
  top: 50%;
  margin-left: 0px;
  margin-top: 0;
  z-index: 10;
  transition: 0.8s ease;
  -webkit-transform: scale(0, 0);
  -moz-transform: scale(0, 0);
  -o-transform: scale(0, 0);
  -ms-transform: scale(0, 0);
  transform: scale(0, 0);
  text-align: center;
  width: 100%;
  height: 100%; }

#modalContent .close {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1000; }
  #modalContent .close a {
    width: 10.742vw;
    height: 10.742vw;
    display: block;
    position: relative;
    white-space: nowrap;
    text-indent: 100%;
    overflow: hidden; }
    #modalContent .close a::before {
      content: '';
      width: 140%;
      height: 0.391vw;
      background: #e60012;
      position: absolute;
      left: -20%;
      top: 50%;
      margin: -0.195vw 0 0;
      transform: rotate(45deg); }
    #modalContent .close a::after {
      content: '';
      width: 0.391vw;
      height: 140%;
      background: #e60012;
      position: absolute;
      left: 50%;
      top: -20%;
      margin: 0 0 -0.195vw;
      transition: 0.4s;
      transform: rotate(45deg); }

@media screen and (min-width: 1024px) {
  #modalMask {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 100000;
    display: none; }

  #modalContent {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 100001;
    display: none;
    cursor: pointer; }

  #modalContent.view div.mc {
    -webkit-transform: scale(1, 1);
    -moz-transform: scale(1, 1);
    -o-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1); }

  #modalContent div.mc {
    padding: 64px 0;
    box-sizing: border-box;
    position: fixed;
    left: 50%;
    top: 50%;
    margin-left: 0px;
    margin-top: 0;
    z-index: 10;
    transition: 0.8s ease;
    -webkit-transform: scale(0, 0);
    -moz-transform: scale(0, 0);
    -o-transform: scale(0, 0);
    -ms-transform: scale(0, 0);
    transform: scale(0, 0);
    text-align: center; }

  #modalContent .close {
    transition: 0.2s;
    top: -6px;
    right: 2px;
    white-space: nowrap;
    text-indent: 100%;
    overflow: hidden; }
    #modalContent .close a {
      width: 70px;
      height: 70px; }
      #modalContent .close a::before {
        content: '';
        width: 140%;
        height: 3px;
        margin: -1.5px 0 0; }
      #modalContent .close a::after {
        content: '';
        width: 3px;
        height: 140%;
        margin: 0 0 -1.5px; }

  #modalContent .close:hover {
    opacity: 0.7;
    transform: scale(0.8);
    transition: 0.4s; } }
/* 
	loader
*********************/
#loader {
  background: black;
  backdrop-filter: blur(3px);
  width: 100%;
  height: 100%;
  z-index: 1000000;
  position: fixed;
  left: 0;
  top: 0; }

#loader .loader {
  width: 64px;
  height: 64px;
  position: fixed;
  right: 50%;
  top: 50%;
  margin: -32px -32px 0 0; }

/*!
 * Load Awesome v1.1.0 (http://github.danielcardoso.net/load-awesome/)
 * Copyright 2015 Daniel Cardoso <@DanielCardoso>
 * Licensed under MIT
 */
.la-ball-clip-rotate,
.la-ball-clip-rotate > div {
  position: relative;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

.la-ball-clip-rotate {
  display: block;
  font-size: 0;
  color: #fff; }

.la-ball-clip-rotate.la-dark {
  color: #333; }

.la-ball-clip-rotate > div {
  display: inline-block;
  float: none;
  background-color: currentColor;
  border: 0 solid currentColor; }

.la-ball-clip-rotate {
  width: 32px;
  height: 32px; }

.la-ball-clip-rotate > div {
  width: 32px;
  height: 32px;
  background: transparent;
  border-width: 2px;
  border-bottom-color: transparent;
  border-radius: 100%;
  -webkit-animation: ball-clip-rotate .75s linear infinite;
  -moz-animation: ball-clip-rotate .75s linear infinite;
  -o-animation: ball-clip-rotate .75s linear infinite;
  animation: ball-clip-rotate .75s linear infinite; }

.la-ball-clip-rotate.la-sm {
  width: 16px;
  height: 16px; }

.la-ball-clip-rotate.la-sm > div {
  width: 16px;
  height: 16px;
  border-width: 1px; }

.la-ball-clip-rotate.la-2x {
  width: 64px;
  height: 64px; }

.la-ball-clip-rotate.la-2x > div {
  width: 64px;
  height: 64px;
  border-width: 2px; }

.la-ball-clip-rotate.la-3x {
  width: 96px;
  height: 96px; }

.la-ball-clip-rotate.la-3x > div {
  width: 96px;
  height: 96px;
  border-width: 6px; }

@media screen and (max-width: 1023px) {
  #loader .loader {
    width: 12.5vw;
    height: 12.5vw;
    position: fixed;
    right: 50%;
    top: 50%;
    margin: -6.25vw -6.25vw 0 0; }

  .la-ball-clip-rotate.la-2x > div {
    width: 12.5vw;
    height: 12.5vw;
    border-width: 2px; } }
/*
 * Animation
 */
@-webkit-keyframes ball-clip-rotate {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-moz-keyframes ball-clip-rotate {
  0% {
    -moz-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -moz-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -moz-transform: rotate(360deg);
    transform: rotate(360deg); } }
@-o-keyframes ball-clip-rotate {
  0% {
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
@keyframes ball-clip-rotate {
  0% {
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  50% {
    -webkit-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg); }
  100% {
    -webkit-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
html, body, p, ol, ul, li, dl, dt, dd, blockquote, figure, fieldset, legend, textarea, pre, iframe, hr, h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal; }

ol, ul {
  list-style: none; }

button, input, select, textarea {
  margin: 0; }

html {
  box-sizing: border-box; }

* {
  box-sizing: inherit; }
  *:before, *:after {
    box-sizing: inherit; }

img, embed, iframe, object {
  width: 100%;
  height: auto;
  max-width: 100%; }

audio {
  max-width: 100%; }

iframe {
  border: 0; }

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

td, th {
  padding: 0;
  text-align: left; }

textarea {
  -webkit-appearance: none; }

input[type="email"], input[type="password"], input[type="text"], input[type="button"], input[type="submit"] {
  -webkit-appearance: none; }

textarea {
  resize: vertical; }

input {
  outline: none; }
  input:-webkit-autofill {
    -webkit-box-shadow: 0 0 1000px #3f5076 inset;
    outline: none; }

button {
  outline: none; }

area {
  border: none;
  outline: none; }

img {
  -ms-interpolation-mode: bicubic;
  display: block;
  vertical-align: baseline; }

* {
  -webkit-tap-highlight-color: rgba(63, 80, 118, 0.5);
  max-height: 999999px; }
  *::before, *::after {
    will-change: all;
    box-sizing: border-box; }

b {
  font-weight: normal;
  font-style: normal; }

body {
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, sans-serif;
  background: #fff;
  overflow-x: hidden;
  color: #000000; }

input, textarea, select {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, sans-serif; }

a {
  cursor: pointer;
  text-decoration: none; }
  a:link {
    color: #000000;
    transition: opacity 0.3s; }
  a:visited {
    color: #000000; }
  a:hover {
    color: #000000;
    text-decoration: none; }
  a:active {
    color: #000000; }

b {
  font-weight: bold; }

i {
  font-style: normal; }

.clr {
  clear: both; }

.hide {
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important; }

section {
  clear: both;
  zoom: 1; }

article:after, section:after, .clrFx:after {
  content: '';
  clear: both;
  display: block; }

.pc-item {
  display: none !important; }

@media screen and (min-width: 1024px) {
  .pc-item {
    display: block !important; }

  .sp-item {
    display: none !important; } }
body {
  background: #000000; }

.loader_wrap {
  min-width: 1280px;
  position: relative; }

#siteheader {
  width: 100%;
  height: 9.766vw;
  background: #000000;
  position: relative;
  z-index: 100;
  overflow: hidden; }
  #siteheader .logo {
    width: 21.289vw;
    position: absolute;
    left: 3.906vw;
    top: 0.977vw; }
  #siteheader .btn-twitter {
    display: block;
    width: 3.809vw;
    position: absolute;
    top: 2.93vw;
    right: 3.906vw; }

footer {
  background: #000000;
  padding: 0 0 16.211vw;
  position: relative;
  z-index: 15; }
  footer .btn-pagetop {
    position: absolute;
    width: 17.773vw;
    height: 8.887vw;
    position: absolute;
    left: 0;
    right: 0;
    top: -8.887vw;
    margin: auto; }
    footer .btn-pagetop:before {
      content: "";
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 0 8.838vw 8.887vw 8.838vw;
      border-color: transparent transparent #b70918 transparent;
      position: absolute;
      left: 0;
      bottom: 0; }
    footer .btn-pagetop i {
      display: block;
      font-family: "Barlow Semi Condensed", sans-serif;
      color: #fff;
      font-size: 3.418vw;
      font-weight: 500;
      text-align: center;
      position: relative;
      z-index: 5;
      padding-top: 3.906vw; }
  footer .bnrs {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 6.715vw; }
    footer .bnrs.bnrs01 {
      padding: 7.883vw 0 0; }
      footer .bnrs.bnrs01 li {
        width: 40.527vw;
        height: 12.793vw;
        border: 1px solid #fff; }
        footer .bnrs.bnrs01 li a {
          display: block;
          width: 100%;
          height: 100%;
          display: flex;
          align-items: center;
          justify-content: center;
          padding-bottom: 0.8vw; }
          footer .bnrs.bnrs01 li a i {
            font-size: 4.395vw;
            font-weight: bold;
            font-family: "Barlow Semi Condensed", sans-serif;
            color: #fff; }
    footer .bnrs li {
      width: 43.262vw;
      margin: 3.906vw 1.953vw 0; }
  footer .textlinks {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    position: relative;
    padding: 0 0 7.813vw; }
    footer .textlinks:before {
      content: "";
      width: 90.234vw;
      height: 1px;
      background-color: #404040;
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      margin: auto; }
    footer .textlinks li {
      padding: 0 4.688vw;
      margin-bottom: 1.465vw;
      font-size: 3.027vw;
      position: relative; }
      footer .textlinks li + li:before {
        content: none;
        width: 1px;
        height: 3.125vw;
        position: absolute;
        top: 0.977vw;
        left: 0;
        background: #fff; }
      footer .textlinks li a {
        color: #fff; }
  footer .bnrs-dls {
    padding: 7.813vw 0 0;
    margin: 0 0 0 0; }
    footer .bnrs-dls .box {
      display: flex;
      align-items: center;
      justify-content: center; }
      footer .bnrs-dls .box a {
        display: block;
        margin: 0 2.441vw; }
    footer .bnrs-dls a {
      display: block; }
    footer .bnrs-dls .btn-appstore {
      width: 27.734vw;
      height: 10.059vw; }
    footer .bnrs-dls .btn-googleplay {
      width: 34.668vw;
      height: 10.156vw; }
    footer .bnrs-dls .btn-dmmgames {
      display: block;
      width: 36.328vw;
      height: 4.395vw;
      margin: 5.859vw auto 0; }
  footer .copyright {
    color: #fff;
    font-size: 2.441vw;
    line-height: 2.56;
    text-align: center;
    padding-top: 8.766vw; }

@media screen and (min-width: 1024px) {
  body {
    min-width: 1280px;
    overflow-x: auto; }

  #siteheader {
    width: 100%;
    height: 60px; }
    #siteheader .logo {
      width: 136px;
      left: 43px;
      top: 5px;
      transition: opacity 0.3s; }
      #siteheader .logo:hover {
        opacity: 0.7; }
    #siteheader .btn-twitter {
      width: 23px;
      top: 19px;
      right: 30px;
      transition: opacity 0.3s; }
      #siteheader .btn-twitter:hover {
        opacity: 0.7; }

  footer {
    padding: 0 0 64px;
    z-index: 11; }
    footer .btn-pagetop {
      width: 88px;
      height: 44px;
      top: -43px;
      transition: filter 0.3s; }
      footer .btn-pagetop:before {
        border-width: 0 44px 44px 44px; }
      footer .btn-pagetop i {
        font-size: 17px;
        padding-top: 20px; }
      footer .btn-pagetop:hover {
        filter: brightness(1.2); }
    footer .bnrs {
      margin: 0 0 45px 0; }
      footer .bnrs li {
        transition: opacity 0.3s; }
        footer .bnrs li:hover {
          opacity: 0.7; }
      footer .bnrs.bnrs01 {
        padding: 65px 0 0; }
        footer .bnrs.bnrs01 li {
          width: 310px;
          height: 98px;
          margin: 0 12.5px; }
          footer .bnrs.bnrs01 li a {
            padding-bottom: 5px; }
            footer .bnrs.bnrs01 li a i {
              font-size: 31px; }
      footer .bnrs.bnrs02 {
        margin: 44px 0 0; }
        footer .bnrs.bnrs02 li {
          width: auto;
          height: 70px;
          margin: 0 10px; }
          footer .bnrs.bnrs02 li a {
            display: block;
            height: 70px; }
            footer .bnrs.bnrs02 li a img {
              display: block;
              width: auto;
              max-width: inherit;
              height: 100%; }
    footer .textlinks {
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      padding: 0 0 47px; }
      footer .textlinks:before {
        width: 960px; }
      footer .textlinks li {
        padding: 0 24px;
        font-size: 16px; }
        footer .textlinks li + li:before {
          content: "";
          height: 16px;
          position: absolute;
          top: 2px; }
        footer .textlinks li a {
          color: #fff; }
          footer .textlinks li a:hover {
            text-decoration: underline; }
    footer .bnrs-dls {
      padding: 50px 0 0 40px;
      margin: 0 0 0;
      display: flex;
      align-items: center;
      justify-content: center; }
      footer .bnrs-dls .box a {
        display: block;
        margin: 0 17px; }
      footer .bnrs-dls a {
        display: block;
        transition: opacity 0.3s;
        will-change: opacity; }
        footer .bnrs-dls a:hover {
          opacity: 0.7; }
      footer .bnrs-dls .btn-appstore {
        width: 145px;
        height: 53px; }
      footer .bnrs-dls .btn-googleplay {
        width: 183px;
        height: 54px; }
      footer .bnrs-dls .btn-dmmgames {
        width: 192px;
        height: 23px;
        margin: 0 17px; }
    footer .copyright {
      font-size: 12px;
      line-height: 2.17;
      text-align: center;
      padding-top: 43px; } }
@media screen and (min-width: 1281px) and (max-width: 1920px) {
  #siteheader {
    width: 100%;
    height: 60px; }
    #siteheader .logo {
      width: 136px;
      left: 43px;
      top: 5px; }
    #siteheader .btn-twitter {
      width: 23px;
      top: 19px;
      right: 30px; } }
@media screen and (min-width: 1921px) {
  #siteheader {
    width: 100%;
    height: 60px; }
    #siteheader .logo {
      width: 136px;
      left: 43px;
      top: 5px; }
    #siteheader .btn-twitter {
      width: 23px;
      top: 19px;
      right: 30px; } }
/*@media screen and (min-width: $break_width1 + 1px ){
	body{min-width: $min-width;overflow-x: auto;}
	#siteheader{width: 100%;height: 60px;
		.logo{width:136px;left: 43px;top:5px;}
		.btn-twitter{width: 23px;top:19px;right:30px;transition: opacity 0.3s;
				&:hover{opacity: 0.7;}
		}
	}

	section.mvarea{background: url("/wp/wp-content/themes/cb/images/mv-bg@pc.jpg")no-repeat top center / cover;overflow: hidden;height: 860px;
		.wrap{max-width: 1920px;height: 860px;padding: 0;position: relative;margin: 0 auto;
			.catch{width:398px;height: auto;position: absolute;top: 17px;left: auto;right: 57px;z-index: 4;}
			.mv{width: 1280px;position: absolute;left: 0;right: 0;top: -63px;margin: auto}
			.text-area{text-align: center;position:absolute;top: 0;left: 60px;z-index: 6;width: 530px;height: 100%;padding: 60px 0 0;
				h1{width: 531px;margin: 0 auto 0;}
				.text01{width: 445px;margin: 0 0 0 36px;}
			}
			.movie{width: 369px;height: 221px;margin: 0 auto 0;position: absolute;left: 133px;bottom: 208px;
				&:hover{
					i{filter: brightness(1.2);}
					img{transform: scale(1.1);}
				}
				i{width: 75px; height: 75px;transition: filter 0.3s;}
				img{transition: 0.3s;}
			}
		}
	}

	footer{padding: 0 0 64px;z-index: 11;
		.btn-pagetop{width: 88px; height: 44px;top: -43px;transition: filter 0.3s;
				&:hover{filter: brightness(1.2);}
		}
		.bnrs{margin:0 0 54px 0;
			li{transition: opacity 0.3s;
				&:hover{opacity: 0.7;}
			}
			&.bnrs01{padding:63px 0 0;
				li{ width: 310px;margin: 0 12.5px;}
			}
			&.bnrs02{margin:44px 0 0;
				li{width: auto;height: 70px;margin: 0 10px;
					a{display: block;height: 70px;
						img{display: block;width: auto;max-width: inherit;height: 100%;}
					}
				}
			}
		}
		.copyright{font-size: 12px; line-height: 2.17;text-align: center;}
	}
}*/
