@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.loading {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background-color: #000;
	z-index: 200;
}
#main .mainVisual {
	margin-bottom: -7.76vw;
	padding-top: 10.029vw;
	position: relative;
	aspect-ratio: 1366/883;
	background: url(../img/index/mv_bg.jpg) no-repeat center top/cover;
}
#main .mainVisual .subBox {
	margin: 0 8.419vw 0 4.905vw;
}
#main .mainVisual .lBox {
	margin-top: 6.65vw;
	width: 41.288vw;
}
#main .mainVisual .slideTxt {
	width: 6.149vw;
}
#main .mainVisual .topTxt {
	margin: 0 auto 2.562vw;
	width: fit-content;
	color: #fff;
	font-size: 1.135vw;
	letter-spacing: 0.12em;
	text-shadow: 0 0 1.464vw #000, 0 0 1.464vw #000, 0 0 1.464vw #000, 0 0 1.464vw #000, 0 0 1.464vw #000, 0 0 1.464vw #000;
}
#main .mainVisual h1 {
	margin-bottom: 6vw;
}
#main .mainVisual .txtBox {
	margin-bottom: 1.04vw;
}
#main .mainVisual .txtBox .date {
	width: 6.93vw;
}
#main .mainVisual .txtBox .rTxt {
	margin: 1.098vw 0 0 1.464vw;
	flex: 1;
}
#main .mainVisual .txtBox .rTxt p {
	color: #fff;
	opacity: 0.65;
	font-size: 0.732vw;
}
#main .mainVisual .txtBox .rTxt .txt01 {
	margin-bottom: 0.293vw;
	line-height: 1.35;
}
#main .mainVisual .txtBox .rTxt p .large {
	font-size: 1vw;
}
#main .mainVisual .phoList {
	margin-left: 0.952vw;
	gap: 0.55vw;
}
#main .mainVisual .phoList li {
	width: 9.444vw;
}
#main .mainVisual .phoList img {
	width: 100%;
}
#main .bgSec {
	padding-top: 3rem;
	color: #fff;
	background-color: #000;
}
#main .about .topTxt {
	margin: 0 3rem 3.5rem;
	padding-bottom: 8.3rem;
	position: relative;
	text-align: center;
}
#main .about .topTxt:after {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 1px;
	height: 5.1rem;
	opacity: 0.7;
	background-color: #fff;
	content: "";
}
#main .about .topTxt img {
	width: 95.1rem;
}
#main .about .topBox {
	padding: 5.3rem 0 5.8rem;
	background: url(../img/index/about_bg.png) repeat-x left top/55rem 100%;
}
#main .about .sns {
	text-align: center;
}
#main .about .sns p {
	font-size: 2.1rem;
	margin-bottom: 1rem;
}
#main .about .sns .btn {
	margin: 0 auto;
	width: 6.5rem;
}
#main .preview {
	padding-top: 7rem;
}
#main .preview .movie {
	margin-bottom: 9.4rem;
	aspect-ratio: 16/9;
}
#main .preview .movie iframe {
	width: 100%;
	height: 100%;
	display: block;
}
#main .preview .bgBox {
	padding: 5rem 0 6rem;
	min-height: 42rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: url(../img/index/preview_photo.jpg) no-repeat center top/cover;
}
#main .preview .bgBox .content {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
#main .preview .bgBox h3 {
	font-size: 4.4rem;
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0.05em;
	text-shadow: 0px 0px 1.2rem rgba(0, 0, 0, 1);
	text-align: center;
}
#main .story .bgBox {
	padding: 8.2rem 0 4.8rem;
	background: url(../img/index/story_bg.jpg) no-repeat center top/cover;
}
#main .story .bgBox h2 {
	margin-bottom: 2.5rem;
	color: #000;
	letter-spacing: 0.08em;
}
#main .story .bgBox .subTtl {
	margin-bottom: 2.3rem;
	color: #29637e;
	font-size: 4.1rem;
	font-weight: 500;
	line-height: 1.58;
	letter-spacing: 0;
	text-align: center;
}
#main .story .bgBox p {
	margin-bottom: 2rem;
	color: #000;
	line-height: 1.89;
	letter-spacing: -0.03em;
	text-align: justify;
}
#main .story .bgBox p rt {
	text-align: center;
	font-size: 1rem;
	font-family: "Noto Sans JP", sans-serif;
}
#main .story .bgBox .subBox:not(:last-child) {
	margin-bottom: 5.7rem;
	padding-bottom: 2.5rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}
#main .story .bgBox .subBox02 .subTtl {
	color: #286B4F;
}
#main .story .bgBox02 {
	padding: 5.5rem 0;
	min-height: 44rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: url(../img/index/story_photo01.jpg) no-repeat center top/cover;
}
#main .story .bgBox02 .content {
	width: 100%;
}
#main .story .bgBox02 .txtBox {
	max-width: 59rem;
}
#main .story .bgBox02 h3 {
	margin-bottom: 1.5rem;
	font-size: 4.1rem;
	font-weight: 400;
	line-height: 1.59;
	letter-spacing: 0.08em;
	text-shadow: 0px 0px 1rem rgba(0, 0, 0, 1);
}
#main .story .bgBox02 p {
	line-height: 1.89;
	letter-spacing: -0.03em;
	text-align: justify;
	text-shadow: 0px 0px 1.2rem rgba(0, 0, 0, 1);
}
#main .story .phoList li {
	width: 50%;
}
#main .story .phoList img {
	width: 100%;
}
#main .review {
	padding: 8rem 0;
}
#main .review h2 {
	margin-bottom: 5rem;
	letter-spacing: 0;
}
#main .review .txtList li {
	padding: 2.6rem 0.2rem;
	width: 47.6%;
	letter-spacing: 0.02em;
	display: flex;
	align-items: center;
	line-height: 1.89;
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}
#main .review .txtList li:first-child,
#main .review .txtList li:nth-child(2) {
	border-top: 1px solid rgba(255, 255, 255, 0.4);
}
#main .staff {
	padding: 10rem 0 0;
}
#main .staff h2 {
	margin-bottom: 4.8rem;
	letter-spacing: 0;
}
#main .staffList li {
	padding: 4.2rem 0;
	display: flex;
	align-items: center;
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}
#main .staffList:not(:last-child) {
	margin-bottom: 2.8rem;
}
#main .staffList li:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.4);
}
#main .staffList .phoBox {
	margin-right: 4.6rem;
	width: 20.6rem;
}
#main .staffList .phoBox img {
	width: 100%;
}
#main .staffList .txtBox {
	margin-bottom: 0.7rem;
	width: calc(100% - 25.2rem);
}
#main .staffList .txtBox h3 {
	margin-bottom: 2.2rem;
	font-size: 2.8rem;
	font-weight: 400;
	letter-spacing: 0.08em;
}
#main .staffList .txtBox p {
	font-size: 1.6rem;
	line-height: 1.6;
	text-align: justify;
	letter-spacing: 0.04em;
}
#main .staff .subBox {
	padding-bottom: 3.3rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}
#main .staff .subBox h3 {
	margin-bottom: 2.6rem;
	color: #999;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: 0.18em;
}
#main .staff .subBox p {
	font-size: 1.6rem;
	line-height: 1.6;
	text-align: justify;
	letter-spacing: 0.04em;
}
#main .staff .subBox p:not(:last-child) {
	margin-bottom: 2.8rem;
}
#main .cast {
	padding: 9rem 0 10.5rem;
}
#main .cast h2 {
	margin-bottom: 4.8rem;
	letter-spacing: 0;
}
#main .cast .staffList li {
	padding: 3rem 0;
}
#main .cast .staffList .txtBox h3 {
	margin-bottom: 1.5rem;
}
#main .information {
	padding: 7.3rem 0 10.6rem;
}
#main .information h2 {
	margin-bottom: 3.5rem;
}
#main .information h3 {
	margin-bottom: 5.7rem;
}
#main .information .linkList {
	margin-bottom: 4.6rem;
	gap: 1.8rem;
}
#main .information .linkList li {
	width: calc((100% - 9rem)/6);
}
#main .information .linkList a {
	display: block;
	padding: 0.4rem 1.5rem;
	font-size: 1.5rem;
	font-weight: 500;
	text-align: center;
	background: url(../img/common/icon02.png) no-repeat right 1rem center/0.6rem;
	border: 1px solid #000;
	border-radius: 3rem;
}
#main .information .linkList .disabled {
	opacity: 0.3;
	pointer-events: none;
}
#main .information .listBox {
	border-bottom: 1px solid #000;
}
#main .information .ttlList {
	background-color: #000;
}
#main .information .ttlList li {
	padding: 1rem 1rem 1.3rem;
	width: 20%;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	text-align: center;
}
#main .information .ttlList li:nth-child(2) {
	width: 33.5%;
}
#main .information .ttlList li:nth-child(3) {
	margin-right: 5%;
}
#main .information .infoBox {
	margin-bottom: 2.7rem;
}
#main .information .infoBox h4 {
	padding: 0.8rem 1rem 1.6rem;
	font-size: 2rem;
	font-weight: 500;
	text-align: center;
	background: #E6E6E6;
}
#main .information .infoList li {
	display: flex;
	flex-wrap: wrap;
}
#main .information .infoList li:not(:last-child) {
	border-bottom: 1px solid #E6E6E6;
}
#main .information .infoList p {
	padding: 2.3rem 1rem 2.3rem;
	width: 20%;
	font-weight: 500;
	text-align: center;
	word-wrap: break-word;
}
#main .information .infoList p .txtLink {
	text-decoration: underline;
}
#main .information .infoList p:nth-child(2) {
	width: 33.5%;
}
#main .information .infoList p:nth-child(3) {
	margin-right: 5%;
}
@media all and (min-width: 1025px) {
	#main .information .infoList p .txtLink:hover {
		text-decoration: none;
	}
	#main .about .sns .btn a:hover, #main .information .linkList a:hover {
		opacity: 0.7;
	}
}
@media all and (min-width: 897px) and (max-width: 950px) {
	#main .story .bgBox .subTtl {
		font-size: 3.9rem;
	}
}
@media all and (max-width: 896px) {
	#main .mainVisual {
		margin-bottom: 0;
		padding-top: 48.533vw;
		aspect-ratio: 750/1120;
		background-color: #000;
		background-image: url(../img/index/mv_bg_sp.jpg);
		background-size: 100% auto;
	}
	#main .mainVisual .subBox {
		margin: 0 6.9vw 0 5.2vw;
		flex-direction: column-reverse;
	}
	#main .mainVisual .lBox {
		margin-top: 29.3vw;
		width: 100%;
	}
	#main .mainVisual .slideTxt {
		width: 100%;
		text-align: right;
	}
	#main .mainVisual .slideTxt img {
		width: 13.733vw;
	}
	#main .mainVisual .ttlBox {
		position: absolute;
		top: 10.133vw;
		left: 0;
		text-align: center;
		width: 100%;
	}
	#main .mainVisual .topTxt {
		margin-bottom: 1.867vw;
		font-size: 3.2vw;
		letter-spacing: 0.05em;
		text-shadow: 0 0 1.5rem rgba(34, 24, 21, 1),0 0 1.5rem rgba(34, 24, 21, 1),0 0 1.5rem rgba(34, 24, 21, 1);
	}
	#main .mainVisual h1 {
		margin-bottom: 0;
	}
	#main .mainVisual h1 img {
		width: 90.6vw;
	}
	#main .mainVisual .txtBox {
		margin-bottom: 4.2vw;
	}
	#main .mainVisual .txtBox .date {
		width: 20.9vw;
	}
	#main .mainVisual .txtBox .rTxt {
		margin: 3.467vw 0 0 4.533vw;
	}
	#main .mainVisual .txtBox .rTxt p {
		margin-right: -1.5vw;
		font-size: 2.4vw;
		line-height: 1.4;
		letter-spacing: -0.02em;
	}
	#main .mainVisual .txtBox .rTxt .txt01 {
		margin: 0 0 1.5vw;
		font-size: 2.133vw;
		line-height: 1.3;
	}
	#main .mainVisual .txtBox .rTxt p .large {
		font-size: 2.933vw;
	}
	#main .mainVisual .phoList {
		margin: 0 -6.9vw 0 -5.2vw;
		gap: 1.3vw;
	}
	#main .mainVisual .phoList li {
		width: calc((100% - 3.9vw)/4);
	}
	#main .bgSec {
		padding-top: 4.8rem;
	}
	#main .about .topTxt {
		margin: 0 0 2.7rem;
		padding-bottom: 6.1rem;
	}
	#main .about .topTxt:after {
		height: 3.7rem;
		opacity: 1;
	}
	#main .about .topTxt img {
		width: 31.4rem;
		margin-right: 0.5rem;
	}
	#main .about .topBox {
		padding: 4.4rem 0 5.3rem;
		background-image: url(../img/index/about_bg_sp.png);
		background-size: 37.5rem 100%;
	}
	#main .about .sns p {
		font-size: 1.8rem;
	}
	#main .preview {
		padding-top: 4rem;
	}
	#main .preview .movie {
		margin-bottom: 5.3rem;
		aspect-ratio: 16/9;
	}
	#main .preview .movie iframe {
		width: 100%;
		height: 100%;
		display: block;
	}
	#main .preview .bgBox {
		padding: 0 0 4.1rem;
		min-height: inherit;
		display: block;
		background: none;
	}
	#main .preview .bgBox .photo img {
		width: 100%;
	}
	#main .preview .bgBox .content {
		margin-top: -9.7vw;
		display: block;
	}
	#main .preview .bgBox h3 {
		font-size: 2.8rem;
		line-height: 1.46;
		letter-spacing: 0;
		text-shadow: none;
	}
	#main .story .bgBox {
		padding: 5.6rem 0 3rem;
		background-image: url(../img/index/story_bg_sp.jpg);
	}
	#main .story .bgBox h2 {
		margin-bottom: 2.1rem;
		letter-spacing: 0.1em;
	}
	#main .story .bgBox .subTtl {
		margin: 0 -2rem 2.1rem;
		font-size: 2.5rem;
		font-weight: 400;
		line-height: 1.52;
		letter-spacing: -0.02em;
	}
	#main .story .bgBox p {
		margin-bottom: 1.6rem;
		line-height: 1.69;
	}
	#main .story .bgBox p rt {
		font-size: 0.8rem;
	}
	#main .story .bgBox .subBox:not(:last-child) {
		padding-bottom: 1.7rem;
		margin-bottom: 4.3rem;
	}
	#main .story .bgBox02 {
		padding: 0 0 3.6rem;
		min-height: inherit;
		display: block;
		background: none;
	}
	#main .story .bgBox02 .photo img {
		width: 100%;
	}
	#main .story .bgBox02 .content {
		margin-top: -1.5vw;
	}
	#main .story .bgBox02 .txtBox {
		max-width: inherit;
	}
	#main .story .bgBox02 h3 {
		margin-bottom: 1.5rem;
		font-size: 2.8rem;
		line-height: 1.46;
		letter-spacing: 0.02em;
		text-shadow: none;
	}
	#main .story .bgBox02 p {
		line-height: 1.69;
		letter-spacing: -0.05em;
		text-shadow: none;
		text-align: left;
	}
	#main .story .phoList li {
		width: 100%;
	}
	#main .review {
		padding: 5.8rem 0;
	}
	#main .review h2 {
		margin-bottom: 2.5rem;
	}
	#main .review .txtList {
		display: block;
	}
	#main .review .txtList li {
		padding: 2.3rem 0;
		width: auto;
		display: block;
		line-height: 1.75;
	}
	#main .review .txtList li:nth-child(2) {
		border-top: none;
	}
	#main .staff {
		padding: 8rem 0 4.1rem;
	}
	#main .staff h2 {
		margin-bottom: 3.5rem;
	}
	#main .staffList:not(:last-child) {
		margin-bottom: 2.5rem;
	}
	#main .staffList li {
		padding: 4.5rem 0 2.7rem;
		display: block;
	}
	#main .staffList li:first-child {
		border-top: none;
		padding-top: 0;
	}
	#main .staffList .phoBox {
		margin: 0 0 2.9rem;
		width: auto;
	}
	#main .staffList .txtBox {
		margin-bottom: 0;
		width: auto;
	}
	#main .staffList .txtBox h3 {
		font-size: 2.3rem;
		margin-bottom: 1.9rem;
		letter-spacing: 0.03em;
	}
	#main .staffList .txtBox p {
		line-height: 1.75;
		letter-spacing: -0.03em;
	}
	#main .staff .subBox {
		padding-bottom: 3.3rem;
	}
	#main .staff .subBox h3 {
		margin-bottom: 2rem;
		font-size: 1.8rem;
	}
	#main .staff .subBox p {
		letter-spacing: -0.03em;
		line-height: 1.75;
	}
	#main .cast {
		padding: 8rem 0 5.2rem;
	}
	#main .cast h2 {
		margin-bottom: 3.5rem;
	}
	#main .cast .staffList .txtBox h3 {
		margin-bottom: 1.9rem;
	}
	#main .information {
		padding: 3.9rem 0 4rem;
	}
	#main .information .content {
		padding: 0 2rem;
	}
	#main .information h2 {
		margin-bottom: 2.4rem;
	}
	#main .information h3 {
		margin-bottom: 3.9rem;
	}
	#main .information .linkList {
		margin-bottom: 4rem;
		gap: 2rem 1.8rem;
	}
	#main .information .linkList li {
		width: calc((100% - 1.8rem)/2);
	}
	#main .information .linkList a {
		font-size: 1.6rem;
	}
	#main .information .infoBox {
		margin-bottom: 2rem;
	}
	#main .information .infoBox h4 {
		padding: 1rem 1rem 1.3rem;
		font-size: 1.8rem;
		letter-spacing: 0.22em;
	}
	#main .information .infoList li {
		padding: 2rem 0;
		display: block;
	}
	#main .information .infoList p {
		padding: 0;
		width: auto;
		display: flex;
		align-items: center;
		line-height: 1.2;
		text-align: left;
	}
	#main .information .infoList p:not(:last-child) {
		margin-bottom: 0.7rem;
	}
	#main .information .infoList p .bgTtl {
		margin-right: 1rem;
		width: 6.2rem;
		min-width: 6.2rem;
		padding: 0.6rem 0.2rem;
		color: #fff;
		font-size: 1.1rem;
		text-align: center;
		background-color: #000;
	}
	#main .information .infoList p:nth-child(2) {
		width: auto;
	}
	#main .information .infoList p:nth-child(3) {
		margin-right: 0;
	}
}