@charset "UTF-8";
/*
**************************************************************************
*	fields odanobuna top style.css
**************************************************************************/

/* --------------------------------------------------
		override
-------------------------------------------------- */

/*
.c-h2__title {
	background-color: unset;
}*/
body,
.c-h2__title {
  font-family:'Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
}
.concept,
.story,
.character {
  font-family: YakuHanMP, "Hiragino Mincho ProN", "Noto Serif JP", "Yu Mincho", YuMincho, serif;
}
/* --------------------------------------------------
		opening
-------------------------------------------------- */

@media screen and (max-width: 767px) {
}


/* --------------------------------------------------
		visual
-------------------------------------------------- */
.visual {
	position: relative;
	overflow: hidden;
  aspect-ratio: 1920 / 1080;
	background-color: #FFFFFF;
}
.visual_bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url(../img/visual_01.jpg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
	opacity: 0;
}
.visual .u-cts__inner {
	max-width: 1400px;
	height: 100%;
}
.visual__logo{
	position: absolute;
  width: 587px;
  height: auto;
  left: 2%;
  top: 23vw;
	opacity: 0;
}
.visual__copy {
	position: absolute;
	z-index: 4;
  left: 4%;
  top: 13vw;
	opacity: 0;
}
.visual__copy img{
	width:480px;
}

@media screen and (min-width: 768px) {
  .visual__logo {
    top: 23vw;
  }
	.visual__logo img {
		width: 33vw;
	}
  .visual__copy img {
		width: 28vw;
	}
}
@media screen and (min-width: 1537xp) {
  .visual__logo {
    left: 2%;
  }
}
@media screen and (max-width: 1536px) and (min-width: 1367px) {
  .visual__logo {
    left: 10%;
  }
}
@media screen and (max-width: 1366px) and (min-width: 768px) {
  .visual__logo {
    left: 13%;
  }
}
@media screen and (max-width: 767px) {
	.visual {
		height: 160vw;
    aspect-ratio: auto;
	}
	.visual_bg {
		background-image: url(../img/visual_01_sp.jpg);
		background-size: cover;
    background-position: 55% 0;
	}
	.visual__logo{
		top: 9vw;
    width: 57%;
    right: 0;
    left: 22%;
		text-align: center;
		z-index: 10;
	}
	.visual__logo img{
		width: 100%;
	}
	.visual__copy{
		top: 5vw;
		width: 100%;
		text-align: center;
    left: 0;
	}
	.visual__copy img{
		width: 49vw;
		max-width: 220px;
	}
}

/* タブレット デバイス縦向き */
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
  .visual {
    height: 800px;
    aspect-ratio: auto;
  }
  .visual_bg {
    background-size: cover;
    background-position: 86% 0%;
  }
  .visual__logo {
    top: 57vw;
  }
  .visual__logo img{
    width: 39vw;
  }
  .visual__copy{
    top: 5vw;
  }
  .visual__copy img{
    width: 32vw;
  }
}
/* タブレット デバイス横向き */
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: landscape){
  .visual__logo {
    bottom: 46vh;
    right: 6vw;
  }
  .visual__logo img{
    max-width: 360px;
  }
}
.top-complete {
  /* height: 92px; */
  background-color: #333333;
  color: #ffffff;
  font-size: 3.5rem;
  text-align: center;
  padding: 28px 0 29px;
  line-height: 1;
}
.promotion_tittle {
  /* height: 92px; */
  color: #333333;
  font-weight: bold;
  font-size: 2.5rem;
  text-align: center;
  padding: 28px 0 29px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .top-complete {
    font-size: 2rem;
    padding: 18px 0;
  }
}
/* --------------------------------------------------
		concept
-------------------------------------------------- */

.concept-box__body {
	display: flex;
	flex-direction: row;
	width: 100%;
	height: auto;
  gap: 3.5rem;
  background: #dfe4de;
  padding: 24px 19px;
}
.concept-box__image {
	flex: 1;
 }
.concept-box__text{
	flex: 1;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-direction: column;
	padding: 3rem 2rem;
	font-size: 1.8rem;
	box-sizing: border-box;
  padding: 0 0 0 10px;
}
.concept-box__text h3{
	width: 100%;
	text-align: left;
	font-size: 3.3rem;
	letter-spacing: -0.1rem;
	line-height: 1.3;
	font-weight: 500;
	margin-bottom: 1.5em;
}
.concept-box__text h3 span{
	margin-right: -20px;
	transform: scale(0.95, 1);
	transform-origin: left top;
  display: flex;
  align-items: flex-end;
}
.concept-box__logo {
	font-size: 2.6rem;
}
.concept-box__logo img{
	width: 33%;
}
.concept-box__text p{
	max-width: 600px;
	margin-bottom: 1.3em;
	font-weight: 500;
  font-size: 2rem;
}
.concept-box__text p:last-child{
	margin-bottom: 0;
}
.concept-box__text h3,
.concept-box__text p {
  color: #333333;
  text-shadow: 0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),  0 0 2px rgba(255,255,255,1),0 0 3px rgba(255,255,255,1),0 0 3px rgba(255,255,255,1);
}
@media screen and (max-width: 820px) {
	.concept .u-cts__inner {
    padding: 0;
	}
	.concept-box__body {
		flex-direction: column;
    gap: 0;
	}
	.concept-box__image {
		width: 100%;
	}
	.concept-box__text{
		width: 100%;
		height: auto;
		padding: 30px 12px;
		font-size: 3.4vw;
	}
	.concept-box__text h3{
		font-size: 5.2vw;
    text-shadow: #FFFFFF 0 0 10px, #FFFFFF 0 0 10px, #FFFFFF 0 0 14px, #FFFFFF 0 0 20px;
	}
  .concept-box__logo {
    font-size: 5vw;
  }
  .concept-box__text p {
		font-size: 3.4vw;
  }
}
@media screen and (max-width: 1200px) and (min-width: 768px) {
	.concept-box__image {
		width: 100%;
		min-height: 600px;
	}
  .concept-box__body {
    background-position: 30% 100%;
	}
}
@media screen and (max-width: 767px) and (min-width: 576px) {
	.concept-box__image {
		min-height: 550px!important;
	}
	.concept-box__text {
		background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0), rgba(255, 255, 255, 1));
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0), 10%, rgba(255, 255, 2550, 1), 60%, rgba(255, 255, 2550, 1));
	}
}
@media screen and (min-width: 1201px) {
  .concept-box__body{
    background-position: 0% 30%;
  }
}

/* --------------------------------------------------
		point
-------------------------------------------------- */
.point__title--01{
	margin-bottom: 30px;
	text-align: center;
	font-size: 3.0rem;
	line-height: 1.2;
}
.point__title--02{
	margin-top: 60px;
	margin-bottom: 30px;
	text-align: center;
	font-size: 3.0rem;
	line-height: 1.2;
}
.point--01 {
	position: relative;
	background-image: url(../img/point_01.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.point--01-box {
	display: flex;
	justify-content: right;
	position: relative;
	height: 680px;
	color: #ffffff;
}
.point--01-box__inner {
	width: 45%;
	position: relative;
	display: inline-block;
	padding-top: 160px;
	height: 100%;
}
.point--01-box__inner:before {
	content: "";
	position: absolute;
	top: 0;
	left: -190px;
	width: 190px;
	height: 100%;
	background: -webkit-linear-gradient(left, rgba(0,0,0,0), rgba(0,0,0,0.8));
	background: linear-gradient(to right, rgba(0,0,0,0), rgba(0,0,0,0.8));
}
.point--01-box__inner:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 50vw;
	height: 100%;
	background-color: rgba(0,0,0,0.8);
}
.point--01__title {
	padding-bottom: 20px;
	font-size: 3rem;
	line-height: 1.4;
}
.point--01__title:after {
	right: auto;
	left: 0;
	width: 100vw;
}
.point--01__text {
	font-size: 1.8rem;
}
.point--01__text_small {
	margin-top: 20px;
	font-size: 1.1rem;
	line-height: 1.9;
}
.point--02 {
	position: relative;
	background-image: url(../img/point_02.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.point--02-box {
	position: relative;
	height: 680px;
	color: #ffffff;
}
.point--02-box__inner {
	width: 47%;
	position: relative;
	display: inline-block;
	padding-top: 180px;
	height: 100%;
}
.point--02-box__inner:before {
	content: "";
	position: absolute;
	top: 0;
	left: 100%;
	width: 190px;
	height: 100%;
	background: -webkit-linear-gradient(right, rgba(0,0,0,0), rgba(0,0,0,0.65));
	background: linear-gradient(to left, rgba(0,0,0,0), rgba(0,0,0,0.65));
}
.point--02-box__inner:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 50vw;
	height: 100%;
	background-color: rgba(0,0,0,0.65);
}
.point--02__title {
	padding-bottom: 20px;
	font-size: 3rem;
	line-height: 1.4;
}
.point--02__title:after {
	left: auto;
	right: 0;
	width: 100vw;
}
.point--02__text {
	font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
	.point__title--01{
		padding: 0 4.166666666666667%;
		margin-bottom: 20px;
		font-size: 1.8rem;
	}
	.point__title--02{
		padding: 0 4.166666666666667%;
		margin-top: 30px;
		margin-bottom: 20px;
		font-size: 1.8rem;
	}
	.point--01:after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 400px;
		background: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.9) 20%, rgba(0, 0, 0, 0));
		background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 20%, rgba(0, 0, 0, 0));
	}
	.point--01-box {
		height: 420px;
	}
	.point--01-box__inner {
		width: inherit;
		height: auto;
		position: absolute;
		bottom: 0;
		padding: 0 4.166666666666667% 20px;
	}
	.point--01-box__inner:before {
		content: none;
	}
	.point--01-box__inner:after {
		content: none;
	}
	.point--01__title {
		padding-bottom: 12px;
		display: inline-block;
		font-size: 2rem;
	}
	.point--01__title:after {
		left: 0;
		right: auto;
		width: 100%;
	}
	.point--01__text {
		font-size: 1.3rem;
	}
	.point--01__text_small {
		font-size: 1rem;
	}
	.point--02:after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 400px;
		background: -webkit-linear-gradient(bottom, rgba(0, 0, 0, 0.9) 20%, rgba(0, 0, 0, 0));
		background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 20%, rgba(0, 0, 0, 0));
	}
	.point--02-box {
		height: 420px;
	}
	.point--02-box__inner {
		width: inherit;
		height: auto;
		position: absolute;
		bottom: 0;
		padding: 0 4.166666666666667% 20px;
	}
	.point--02-box__inner:before {
		content: none;
	}
	.point--02-box__inner:after {
		content: none;
	}
	.point--02__title {
		padding-bottom: 12px;
		display: inline-block;
		font-size: 2rem;
	}
	.point--02__title:after {
		left: 0;
		right: auto;
		width: 100%;
	}
	.point--02__text {
		font-size: 1.3rem;
	}
}

@media screen and (max-width: 1120px) and (min-width: 768px) {
	.point--01__title,
	.point--02__title{
		font-size: 2rem;
	}
	.point--01__text,
	.point--02__text{
		font-size: 1.6rem;
	}
	/*
	.point--03-box__inner {
		padding-top: 55px;
	}
	*/
}

/* --------------------------------------------------
		gameflow
-------------------------------------------------- */
.gameflow-box {
	position: relative;
	padding: 0 0 60px;
	overflow: hidden;
	text-align: center;
}
.gameflow-box:before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 600px;
	height: 100%;
	background: -webkit-linear-gradient(left, rgba(255,255,255,0), rgba(255,255,255,0.9));
	background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,0.9));
}

@media screen and (max-width: 767px) {
	.gameflow-box {
		padding: 0 0 30px;
	}
	.gameflow-box:before {
		width: 30%;
	}
	.gameflow__image {
		padding: 0 4.166666666666667%;
	}
}


/* --------------------------------------------------
		story
-------------------------------------------------- */

.story--area {
  aspect-ratio: 1 / 1.275;
	width: 100%;
	height: auto;
	background-image: url(../img/story_01.jpg);
	background-repeat: no-repeat;
	background-position: top center;
  background-size: contain;
  background-color: #ffffff;
	padding-bottom: 50px;
  margin-top: 90px;
  max-width: 1106px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
.story--box {
	max-width: 900px;
	z-index: 1;
	padding: 50px 40px 50px;
  margin: 0 auto;
  color: #333333;
  text-shadow: 0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),0 0 2px rgba(255,255,255,1),  0 0 2px rgba(255,255,255,1),0 0 3px rgba(255,255,255,1),0 0 3px rgba(255,255,255,1);
  text-align: center;
  line-height: 1.28;
	
}
.story--box .c-h2__title {
  margin: 0 0 30px;
}
.story__title {
	font-size: 4.6rem;
	line-height: 1.2;
	font-weight: bold;
}
.story__title span{
	transform: scale(0.95, 1);
	transform-origin: center top;
	display: block;
  font-weight: 500;
}
.story__text {
	font-size: 2.7rem;
	font-weight: 500;
	line-height: 1.3;
	margin-bottom: 30px;
}
.story__text span {
  letter-spacing: -4px;
}
@media screen and (max-width: 1060px) and (min-width: 767px) {

	.story__text {
		font-size: 2rem;
	}
	.story__title {
		font-size: 3rem;
	}

}
@media screen and (max-width: 767px) {
  .story--area {
    margin-top: 30px;
    aspect-ratio: auto;
    height: 146vw;
  }
	.story--box {
		max-width: inherit;
		width: 90%;
		margin: 0 auto;
		padding: 18px 5px 0;
	}
  .story--box .c-h2__title {
    margin: 0 auto 10px;
	  font-size: 5vw;
  }
	.story__title {
		font-size: 4vw;
	}
	.story__text {
		font-size: 3vw;
		margin-bottom: 10px;
	}
	.story__text br.pc-only{
		display: none;
	}
}


/* --------------------------------------------------
		character
-------------------------------------------------- */
.character {
	padding: 0 0 35px;
}
.character-container {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: center;
	align-items: flex-start;
	margin: 0 auto;
}
.character-container__col {
	width: 18.8%;
	max-height: 100%;
	margin-right: 2px;
	margin-left: 2px;
	margin-bottom: 25px;
}
.character-container__col > img {
	margin-bottom: -30px
}
.character-container__col:nth-of-type(3) > img {
	margin-bottom: -19px
}
.character-container__col > span {
	display: inline-block;
	width: 100%;
	font-size: 1.4rem;
	text-align: center;
  line-height: 1.2;
}
.character-container__col > strong {
	display: inline-block;
	width: 100%;
	font-size: 2.6rem;
	font-weight: bold;
	text-align: center;
  line-height: 1.2;
}
#character-long strong {
	font-size: 1.5rem;
}
#character-long img {
  margin-bottom: -30px;
}
.character-container #character-long:last-child img {
  margin-bottom: -24px;
}
.character-container__col > p {
	font-size: 1.55rem;
	line-height: 1.7;
	margin: 5px 10px;
}
@media screen and (max-width: 767px) {
	.character {
		padding: 15px 0 30px;
	}
	.character-container {
		width: 95%;
		margin-right: auto;
		margin-left: auto;
		justify-content: space-around;
	}
	.character-container__col {
		width: 46%;
		margin-bottom: 15px;
	}
	.character-container__col > strong {
		font-size: 2rem;
	}
	#character-long span {
		font-size: 1.3rem;
	}
	#character-long strong {
		font-size: 1.5rem;
	}
	.character-container__col > p {
		font-size: 1.3rem;
		margin: 5px 0 0;
	}
}


/* --------------------------------------------------
		spec
-------------------------------------------------- */
.spec-box {
	position: relative;
	background-image: url(../img/spec_bg.jpg);
	background-repeat: repeat;
	background-position: center center;
	padding: 1px 0 100px;
	text-align: center;
}
.spec-box:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 600px;
	height: 100%;
	background: -webkit-linear-gradient(right, rgba(255,255,255,0), rgba(255,255,255,0.9));
	background: linear-gradient(to left, rgba(255,255,255,0), rgba(255,255,255,0.9));
}
.spec-box:after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	/* height: 150px; */
	background: -webkit-linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,1));
	background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,1));
}
.machine-box{
	padding: 0 20px;
}

@media screen and (max-width: 767px) {
.spec-box {
	padding: 10px 0 40px;
}
.spec-box:before {
	width: 30%;
}
/* .spec-box:after {
	height: 80px;
} */
.spec__image--02{
	width: 90%;
	margin-right: auto;
	margin-left: auto;
}
}

/* --------------------------------------------------
		promotion
-------------------------------------------------- */
.promotion {
	padding: 90px 0 0;
}
.promotion .u-cts__inner + .u-cts__inner {
  margin-top: 60px;
}
.promotion-box {
  position: relative;
}
.promotion-box__body {
  position: relative;
	z-index: 1;
	box-sizing: border-box;
	/* width: 800px; */
	max-width: 800px;
	margin: 0 auto 0;
}
.promotion-box__body .promotion-button .button {
	position: relative;
	display: block;
	max-width: 800px;
  width: 100%;
  height: auto;
	margin: 0 auto;
}
.promotion-box__body .promotion-button a.button {
	transition: opacity .3s ease;
}
.promotion-box__body .promotion-button a.button:after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 128px;
	height: 80px;
	background-image: url(../img/icon_play.png);
	background-size: 100% 100%;
	transform: translate(-50%, -50%);
}
.promotion-button{
	max-width: 800px;
	margin: 0 auto;
}
.promotion-button img{
	max-width: 100%;
	height: auto;
}
.promotion-box-link li {
  aspect-ratio: 9 / 16;
  max-width: 338px;
}

.promotion-box-link a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}

.promotion-box-link .promotion-box-link-button {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.promotion-box-link a::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url(../img/icon_play.png) center / 45% auto no-repeat;
}
@media screen and (min-width: 768px) {
	.promotion-box__body .promotion-button a.button:hover {
		opacity: 0.85;
	}
}
@media screen and (max-width: 767px) {
	.promotion {
		min-height: inherit;
    padding: 30px 0 0;
	}
	.promotion-box__body {
		width: 90%;
		max-width: inherit;
	}
	.promotion-box__h3 {
		font-size: 1.8rem;
		margin-bottom: 20px;
	}
	.promotion-box__text{
		font-size: 1.3rem;
	}
  .promotion-box__body .promotion-button a.button:after {
		width: 64px;
		height: 40px;
	}
  .promotion .u-cts__inner + .u-cts__inner {
    margin-top: 30px;
  }
}


/* --------------------------------------------------
		slider
-------------------------------------------------- */
.content-box__slider {
	position: relative;
}
.slider-image {
	max-width: 1030px;
	margin: 0 auto 30px;
}
.slider-image-items .slick-slide {
	padding: 0 15px;
}
.slider-image-items .slick-slide img {
	width: 100%;
	height: auto;
}
@media screen and (min-width: 768px) {
  .slider-image-items {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 20px;
  }
}
@media screen and (max-width: 767px) {
	.slider-image {
		margin: 0 0 15px;               /* ← 仕様変更（中央化ズレ対策で左右はみ出しを撤廃） */
	}
	.slider-image-items .slick-slide {
		padding: 0 8px;                 /* ← 仕様変更（スライド間の余白を確保／box-sizing:border-box で幅計算は不変） */
	}
}
/* ===== [SP slider 追加] ここから ===== */
@media screen and (max-width: 767px) {
	.slider-image-items .slick-list {
		overflow: visible;
	}
	.slider-image-items .slick-slide {
		opacity: 0.4;                   /* ← 仕様変更（非選択スライドを薄く） */
		transition: opacity 0.3s ease;
	}
	.slider-image-items .slick-slide.slick-current {
		opacity: 1;                     /* ← 仕様変更（選択中のみ不透明） */
	}
	.slider-image-items .slick-dots {
		display: flex !important;
		justify-content: center;
		gap: 8px;
		list-style: none;
		padding: 12px 0 0;
		margin: 0;
	}
	.slider-image-items .slick-dots li {
		line-height: 0;
	}
	.slider-image-items .slick-dots li button {
		width: 10px;
		height: 10px;
		padding: 0;
		border: none;
		border-radius: 50%;
		background: #cccccc;            /* ← 仕様変更（白背景でも見えるグレー） */
		font-size: 0;
		cursor: pointer;
		transition: background 0.2s ease;
	}
	.slider-image-items .slick-dots li.slick-active button {
		background: #555555;            /* ← 仕様変更（選択中は濃いグレー） */
	}
}
/* ===== [SP slider 追加] ここまで ===== */

/* --------------------------------------------------
		common style
-------------------------------------------------- */

.pc-br{
	display: inline;
}
.sp-br{
	display: none;
}
@media screen and (max-width: 767px) {
	.pc-br{
		display: none;
	}
	.sp-br{
		display: inline;
	}
}


/* --------------------------------------------------
		※※※※※
-------------------------------------------------- */

@media screen and (max-width: 767px) {
}
