@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	padding: 21.2rem 0 9rem;
	background: #030b20 url("../img/index/main_bg.png") no-repeat right top;
	background-size: auto 100%;
	position: relative;
	overflow: hidden;
}
#main .mainVisual .title {
	margin-bottom: 2.5rem;
	text-align: center;
	color: #fff;
	font-size: 8rem;
	font-weight: 900;
	letter-spacing: 0.05em;
}
#main .mainVisual .title .sml {
	margin-top: 0.2rem;
	color: #6db3f4;
	font-size: 4rem;
	display: block;
	letter-spacing: 0.04em;
}
#main .mainVisual .movieUl {
	margin-bottom: 2.3rem;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0 3.6rem;
}
#main .mainVisual .movieUl li {
	width: 40rem;
	position: relative;
}
#main .mainVisual .movieUl .image {
	overflow: hidden;
	aspect-ratio: 400/226;
}
#main .mainVisual .movieUl .image iframe,
#main .mainVisual .movieUl .image video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .mainVisual .movieUl .play {
	position: absolute;
	bottom: 4.3rem;
	right: 2.1rem;
}
#main .mainVisual .movieUl .play a {
	display: block;
}
#main .mainVisual .enImg {
	position: absolute;
	top: 0;
	left: 0;
	width: 95.4rem;
}
#main .mainVisual .enImg02 {
	top: auto;
	bottom: -0.7rem;
	left: 0;
	width: 172rem;
	filter: brightness(160%) contrast(120%);
  	opacity: 0.05;
}
#main .mainVisual .content {
	position: relative;
	z-index: 10;
}
@media all and (min-width: 897px) {
	#main .mainVisual .movieUl .play a:hover{
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .mainVisual .title {
		margin: 0 -2rem 5.3rem 0;
		text-align: left;
		font-size: 4.8rem;
		line-height: 1.08;
	}
	#main .mainVisual .title .sml {
		margin-top: 1.4rem;
		font-size: 3rem;
		line-height: 1.33;
	}
	#main .mainVisual .movieUl {
		display: block;
		margin: 0 -0.2rem 6.1rem 0;
	}
	#main .mainVisual .movieUl li {
		margin-bottom: 2.9rem;
		width: auto;
	}
	#main .mainVisual .movieUl li:last-child {
		margin-bottom: 0;
	}
	#main .mainVisual {
		padding: 4.6rem 1.6rem 8.9rem;
		background-image: url("../img/index/sp_main_bg.png");
		background-size: 100% auto;
	}
	#main .mainVisual .movieUl .play {
		bottom: 3.7rem;
		right: 2rem;
	}
	#main .mainVisual .movieUl img {
		width: 100%;
	}
	#main .mainVisual .comBtn {
		margin: 0 -1.7rem 0 -1.5rem;
	}
	#main .mainVisual .enImg02 {
		top: auto;
		bottom: 2.7rem;
		left: 0;
		width: 39rem;
	}
}



/* movieBox */
#main .movieBox {
	padding: 5.6rem 0 5rem;
	background-color: #030b20;
	background: linear-gradient(to bottom, #030b20 55%,#0d3051 100%);
	position: relative;
	overflow: hidden;
}
#main .movieBox .enImg {
	position: absolute;
	top: 19.8rem;
	right: 0;
}
#main .movieBox .content {
	max-width: 121.8rem;
	position: relative;
	z-index: 10;
}
#main .movieBox .playBox {
	padding: 0 13.9rem;
	margin-bottom: 5.5rem;
	position: relative;
}
#main .movieBox .playBox .play {
	position: absolute;
	right: 0;
	bottom: 0.5rem;
}
#main .movieBox .playBox .play a {
	display: block;
	position: relative;
}
#main .movieBox .playBox .play .txt {
	width: 100%;
	position: absolute;
	top: 0;
	left: 0;
	animation: 4s linear infinite rotation;
}
@keyframes rotation {
	0% {
		transform: rotate(0)
	}
	100% {
		transform: rotate(360deg)
	}
}
#main .movieBox .playBox .image {
	aspect-ratio: 756/425;
	overflow: hidden;
}
#main .movieBox .playBox .image img {
	width: 100%;
}
#main .movieBox .playBox .image iframe,
#main .movieBox .playBox .image video {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .movieBox .textBox {
	margin: 0 14.2rem;
	color: #fff;
	font-size: 2rem;
	line-height: 1.9;
	font-weight: 500;
	letter-spacing: 0.15em;
}
@media all and (min-width: 897px) {
	#main .movieBox .playBox .play a:hover{
		opacity: 0.7;
	}
	#main .movieBox .textBox .big {
		margin-top: 2.4rem;
		font-size: 2.4rem;
		font-weight: 700;
		line-height: 1.66;
		letter-spacing: 0.1em;
	}
}
@media all and (max-width: 896px) {
	#main .movieBox .playBox {
		padding: 0;
		margin: 0 -2rem 11.5rem;
	}
	#main .movieBox .playBox .image {
		border-radius: 0;
	}
	#main .movieBox .playBox .play {
		right: 1.7rem;
		bottom: -9.9rem;
		width: 7.9rem;
	}
	#main .movieBox {
		padding: 7.3rem 0 4.7rem;
	}
	#main .movieBox .textBox {
		margin: 0 1.2rem;
		font-size: 1.4rem;
		line-height: 2.28;
		letter-spacing: 0.05em;
	}
	#main .movieBox .enImg {
		top: auto;
		right: -0.3rem;
		bottom: -0.2rem;
		width: 7.3rem;
	}
}


/* aboutBox */
#main .aboutBox {
	padding: 8.9rem 0;
	background-color: #030b20;
	position: relative;
}
#main .aboutBox .enImg {
	position: absolute;
	top: 23rem;
	right: 0;
}
#main .aboutBox .listUl {
	margin-bottom: 8.7rem;
	display: flex;
	flex-wrap: wrap;
	gap: 6rem;
}
#main .aboutBox .listUl li {
	width: calc((100% - 12rem)/3);
	position: relative;
	cursor: pointer;
	border: 1px solid #fff;
}
#main .aboutBox .listUl li::after {
	width: 1.3rem;
	height: 1.3rem;
	position: absolute;
	bottom: 1rem;
	right: 1rem;
	background: url("../img/index/arrow.png") no-repeat left top / 100% 100%;
	content: "";
	transition: 0.3s;
}
#main .aboutBox .listUl .image {
	overflow: hidden;
	aspect-ratio: 359/339;
}
#main .aboutBox .listUl .image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .aboutBox .listUl .ttl {
	font-size: 3.4rem;
	font-weight: 900;
	line-height: 1.29;
	transition: 0.3s;
}
#main .aboutBox .listUl .txt {
	font-size: 2.2rem;
	font-weight: 900;
	line-height: 1.54;
	transition: 0.3s;
}
#main .aboutBox .listUl .txt small {
	margin-top: 0.3rem;
	display: block;
	font-size: 1.6rem;
}
#main .aboutBox .headLine01 {
	margin-bottom: 5.7rem;
}
#main .aboutBox .imgBox {
	padding: 6.2rem 6.9rem;
	display: flex;
	line-height: 2.14;
	font-weight: 500;
	border: 1px solid #6db3f4;
	letter-spacing: 0.1em;
}
#main .aboutBox .imgBox .photo {
	width: 34rem;
}
#main .aboutBox .imgBox .photo img {
	width: 100%;
}
#main .aboutBox .imgBox .rightBox {
	flex: 1;
	margin: 2.4rem 0 0 4.1rem;
}
#main .aboutBox .imgBox .title {
	margin-bottom: 3.4rem;
	font-weight: 900;
	font-size: 1.8rem;
	line-height: 1;
	letter-spacing: 0.1em;
}
#main .aboutBox .imgBox .title .big {
	font-size: 3.4rem;
	display: block;
	margin-top: 1.9rem;
	letter-spacing: 0.1em;
}
#main .aboutBox .imgBox .link {
	margin-top: 1.9rem;
	font-size: 1.3rem;
}
#main .aboutBox .imgBox .link a {
	color: #ec88c3;
}
#main .aboutBox .imgBox .link span {
	padding-bottom: 0.3rem;
	border-bottom: 1px solid #ec88c3;
}
@media all and (min-width: 897px) {
	#main .aboutBox .listUl .ttl {
		width: 100%;
		position: absolute;
		top: 50%;
		left: 0;
		opacity: 1;
		transform: translateY(-50%);
		padding: 0 2.9rem 1.3rem;
	}
	#main .aboutBox .listUl .txt {
		width: 100%;
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		text-align: center;
		opacity: 0;
		padding: 0 0.5rem 0.1rem;
	}
	#main .aboutBox .imgBox .link a:hover{
		opacity: 0.7;
	}
	#main .aboutBox .listUl li:hover .txt {
		opacity: 1;
	}
	#main .aboutBox .listUl li:hover .ttl {
		opacity: 0;
	}
	#main .aboutBox .listUl li:hover::after {
		display: none;
	}
}
@media all and (max-width: 896px) {
	#main .aboutBox .enImg {
		top: 2.8rem;
		right: -0.1rem;
		width: 7rem;
	}
	#main .aboutBox .listUl {
		display: block;
		margin-bottom: 5.7rem;
	}
	#main .aboutBox .listUl li {
		margin-bottom: 1.9rem;
		width: auto;
	}
	#main .aboutBox .listUl li:last-child {
		margin-bottom: 0;
	}
	#main .aboutBox .listUl li::after {
		display: none;
	}
	#main .aboutBox .listUl .textBox {
		margin-top: 0.8rem;
		width: 100%;
		position: absolute;
		top: 50%;
		left: 0;
		opacity: 1;
		transform: translateY(-50%);
		padding: 0;
		text-align: center;
	}
	#main .aboutBox .imgBox {
		border-width: 0.2rem;
		padding: 3.3rem 3.3rem 4.4rem;
		margin: 0 -2rem;
		font-size: 1.6rem;
		display: block;
		line-height: 1.88;
		letter-spacing: 0.2rem;
	}
	#main .aboutBox .imgBox .photo {
		width: auto;
		margin-bottom: 3.4rem;
	}
	#main .aboutBox .imgBox .rightBox {
		margin: 0;
	}
	#main .aboutBox {
		padding: 6.4rem 0;
	}
	#main .aboutBox .headLine01 {
		margin-bottom: 7.8rem;
	}
	#main .aboutBox .listUl .image {
		aspect-ratio: 359/360;
	}
	#main .aboutBox .listUl .ttl {
		margin-bottom: 1.7rem;
	}
	#main .aboutBox .imgBox .title {
		margin-bottom: 3.4rem;
	}
	#main .aboutBox .imgBox .link {
		margin-top: 0.9rem;
		font-size: 1.5rem;
	}
	#main .aboutBox .imgBox .link span {
		padding-bottom: 0.5rem;
	}
}




/* checkBox */
#main .checkBox {
	padding: 0.9rem 0 0;
	background-color: #030b20;
	position: relative;
}
#main .checkBox .headLine01 {
	margin-bottom: 8.1rem;
}
#main .checkBox .enImg {
	position: absolute;
	top: 3.4rem;
	left: 0;
}
#main .checkBox .subTtl {
	margin-bottom: 4.7rem;
	text-align: center;
	font-size: 2.4rem;
	color: #6db3f4;
	font-weight: 900;
	border-top: 1px solid #6db3f4;
	border-bottom: 1px solid #6db3f4;
	padding: 1.1rem 0 1.2rem;
	letter-spacing: 0.13em;
	position: relative;
}
#main .checkBox .subTtl::before {
	width: 5rem;
	height: 2.8rem;
	position: absolute;
	bottom: calc(100% - 0.2rem);
	left: 7.2rem;
	background: url("../img/index/icon05.jpg") no-repeat left top / 100% 100%;
	content: "";
}
#main .tabUl {
	display: flex;
	flex-wrap: wrap;
	gap: 0 2.4rem;
	position: relative;
	z-index: 10;
}
#main .tabUl li {
	padding-bottom: 4.3rem;
	width: 18rem;
	position: relative;
}
#main .tabUl li::after {
	margin-left: -0.2rem;
	position: absolute;
	bottom: -0.4rem;
	left: 50%;
	transform: translateX(-50%);
	width: 3.3rem;
	height: 3.4rem;
	background: url("../img/index/icon06.jpg") no-repeat left top / 100% 100%;
	content: "";
	opacity: 0;
}
#main .tabUl .clickBox {
	color: #030b20;
	font-weight: 900;
	font-size: 2.6rem;
	background-color: #fff;
	border: 0.2rem solid #6db3f4;
	border-radius: 0 0 1rem 1rem;
	overflow: hidden;
	cursor: pointer;
	transition: 0.3s;
}
#main .tabUl .clickBox .photo {
	height: 13.1rem;
	overflow: hidden;
	border-bottom: 1px solid #fff;
}
#main .tabUl .clickBox .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .tabUl .clickBox .ttl {
	line-height: 1.3;
	padding: 2.2rem 1.9rem 2rem;
	height: 22.6rem;
}
#main .tabUl .clickBox .ttl .num {
	margin-bottom: 1.2rem;
	display: block;
	line-height: 1;
	font-size: 6rem;
}
#main .tabUl .clickBox .btmTxt {
	font-size: 1.6rem;
	color: #fff;
	background: url("../img/index/bg01.jpg") repeat left top;
	text-align: center;
	border-top: 0.2rem solid #6db3f4;
	padding: 0.5rem 0 0.7rem;
	letter-spacing: 0.1em;
}
#main .tabUl .clickBox .btmTxt span {
	font-weight: normal;
}
#main .tabUl .open .clickBox .btmTxt {
	background: #030b20;
}
#main .tabUl .on::after {
	opacity: 1;
}
#main .tabBox {
	border: 0.2rem solid #fff;
	border-radius: 2rem;
	position: relative;
	display: none;
}
#main .tabBox .imgBox {
	display: flex;
	line-height: 1.57;
	font-weight: 200;
	letter-spacing: 0.15em;
}
#main .tabBox .imgBox .photo {
	width: 39rem;
	min-height: 28rem;
	overflow: hidden;
	margin: -0.2rem 0 -0.1rem 0;
}
#main .tabBox .imgBox .photo img,
#main .tabBox .imgBox .photo iframe {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .tabBox .imgBox .leftBox {
	flex: 1;
	padding: 2.9rem 5.2rem 2rem 14.7rem;
}
#main .tabBox .title {
	margin: 0 0 3.2rem 0.4rem;
	color: #6db3f4;
	font-size: 3rem;
	font-weight: 900;
	letter-spacing: 0.15em;
}
#main .tabBox .title .img {
	position: absolute;
	top: 3.2rem;
	left: 4.6rem;
}
#main .tabBox .title .num span {
	border-bottom: 2px solid #6db3f4;
	padding-bottom: 0.8rem;
}
#main .tabBox .subTitle {
	margin-bottom: 0.6rem;
	font-size: 1.8rem;
	font-weight: 900;
	line-height: 1.44;
	letter-spacing: 0.15em;
}
@media all and (min-width: 897px) {
	#main .tabBox {
		overflow: hidden;
	}
	#main .tabBox .tab01 {
		display: block;
	}
	#main .tabUl .on .clickBox .btmTxt {
		background: #030b20;
	}
	#main .tabUl .clickBox:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .tabUl li {
		padding-bottom: 1.6rem;
		width: auto;
	}
	#main .tabUl {
		display: block;
	}
	#main .tabUl .clickBox .ttl {
		padding: 2.2rem 1.9rem 3.3rem;
		display: flex;
		align-items: center;
		font-size: 2.8rem;
		line-height: 1.21;
		height: auto;
	}
	#main .tabUl .clickBox .ttl .num {
		margin: 0 1.5rem 0 0;
		width: 4.1rem;
	}
	#main .tabUl .clickBox .ttl .txt {
		flex: 1;
		margin-top: 0.3rem;
	}
	#main .tabUl li::after {
		display: none;
	}
	#main .tabBox {
		margin-top: 4.2rem;
	}
	#main .tabBox::before {
		margin-left: -0.2rem;
		position: absolute;
		top: -3.2rem;
		left: 50%;
		transform: translateX(-50%);
		width: 3.3rem;
		height: 3.4rem;
		background: url("../img/index/icon06.jpg") no-repeat left top / 100% 100%;
		content: "";
	}
	#main .tabBox .imgBox {
		display: block;
		line-height: 1.22;
		font-size: 1.8rem;
	}
	#main .tabBox .imgBox .leftBox {
		padding: 2.2rem 2.4rem 3.7rem;
	}
	#main .tabBox .title {
		padding-bottom: 3.6rem;
		line-height: 1.8;
		display: flex;
		align-items: center;
		justify-content: space-between;
		position: relative;
		max-width: 34rem;
    	margin: 0 auto;
	}
	#main .tabBox .title::before {
		width: calc(100% - 14.3rem);
		height: 1.2rem;
		background: url("../img/index/arrow03.png") no-repeat center bottom / auto 100%;
		position: absolute;
		bottom: 2rem;
		left: 0;
		content: "";
	}
	#main .tabBox .title .img {
		margin-right: -0.8rem;
		width: 10rem;
		position: relative;
		top: auto;
		left: auto;
		text-align: center;
	}
	#main .tabBox .title .num {
		margin-top: -1.2rem;
		flex: 1;
	}
	#main .checkBox .enImg {
		top: 0.5rem;
		left: 0;
		width: 100%;
		text-align: center;
	}
	#main .checkBox .enImg img {
		width: 35.1rem;
	}
	#main .checkBox {
		padding: 5.7rem 0 0 0;
	}
	#main .checkBox .subTtl {
		font-size: 2rem;
		margin-bottom: 5.4rem;
	}
	#main .checkBox .headLine01 {
		margin-bottom: 6.5rem;
	}
	#main .tabUl .clickBox .photo {
		height: auto;
		overflow: hidden;
		border-bottom: none;
		border-top: 0.2rem solid #6db3f4;
		aspect-ratio: 346/157;
	}
	#main .tabBox .subTitle {
		margin-bottom: 0.8rem;
	}
	#main .tabBox .imgBox .photo {
		width: auto;
		min-height: 0;
		margin: 0;
		font-size: 0;
		line-height: 1;
		aspect-ratio: 560/315;
		display: block !important;
		border-radius: 0 0 2.2rem 2.2rem;
	}
}

/* btmBox */
#main .btmBox {
	padding: 15.3rem 0 10.5rem;
}
#main .btmBox .topTxt {
	margin-bottom: 3.1rem;
}
@media all and (min-width: 897px) {
	#main .btmBox .btnUl {
		margin-bottom: 6rem;
	}
}
@media all and (max-width: 896px) {
	#main .btmBox {
		padding: 11.2rem 0 4.6rem;
	}
	#main .btmBox .topTxt {
		margin-bottom: 2.4rem;
	}
	#main .btmBox .btnUl li {
		margin-bottom: 4.1rem;
	}
}

.mfp-iframe-scaler {
	position: relative;
}
.mfp-iframe-scaler video {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.contactCover {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 98;
	opacity: 0;
	visibility: hidden;
}
.contactCover.show {
	opacity: 1;
	visibility: visible;
}

#contact {
	padding: 3rem 5.8rem 4.4rem 4.9rem;
	color: #000000;
	width: 63rem;
	border: 0.6rem solid #fff;
	border-radius: 2rem;
	background-color: #f3f3f3;
	position: fixed;
	left: 3rem;
	bottom: 3rem;
	z-index: 99;
	opacity: 0;
	visibility: hidden;
	transition: all ease 0.5s;
	max-height: calc(100svh - 6rem);
  	overflow-y: auto;
}
#contact iframe {
	width: 100%;
	height: 686px;
}
#contact.show {
	opacity: 1;
	visibility: visible;
}
#contact .close {
	width: 1.7rem;
	position: absolute;
	top: 1.8rem;
	right: 2rem;
	cursor: pointer;
}
.iframeHtml,
.iframeHtml body {
	color: #000;
	background: transparent;
}
.iframeHtml a {
	color: #000;
}
.contactBox {
	color: #000;
	background-color: #f3f3f3;
}
.contactBox .errorMsg {
	margin-bottom: 2rem;
}
.contactBox .errorMsg li {
	color: #ff0000;
}
.contactBox input[type="text"],
.contactBox input[type="email"],
.contactBox input[type="tel"],
.contactBox textarea,
.contactBox input[type="submit"]  {
	padding: 0 2.1rem;
	width: 100%;
	height: 5.1rem;
	border: 1px solid #b3b3b3;
	box-sizing: border-box;
	border-radius: 0.8rem;
	background-color: #fff;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	appearance: none;
	-webkit-appearance: none; 
}
.contactBox textarea {
	padding: 2.1rem;
	height: 13rem;
}
.contactBox input::-webkit-input-placeholder {
	color: #8e8e8e;
}
.contactBox input:-moz-placeholder {
	color: #8e8e8e;
}
.contactBox input::-moz-placeholder {
	color: #8e8e8e;
}
.contactBox input:-ms-input-placeholder {
	color: #8e8e8e;
} 
.contactBox .fromUl > li {
	margin-bottom: 0.9rem;
}
.contactBox .fromUl > li:last-child {
	margin-bottom: 0;
}
.contactBox .radioUl {
	padding-bottom: 1.1rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0 5.1rem;
}
.contactBox .radioUl input[type="radio"],
.contactBox .btmTxt input[type="checkbox"] {
	display: none; 
}
.contactBox .radioUl input[type="radio"] ~ span,
.contactBox .btmTxt input[type="checkbox"] ~ span {
	padding: 0.4rem 0 0.4rem 3.1rem;
	line-height: 2rem;
	border-radius: 0;
	color: #08325a;
	font-size: 1.6rem;
	font-weight: 900;
	border: none;
	display: inline-block;
	background: url("../img/index/radio_icon01.png") no-repeat left 0.2rem top 0.6rem;
	background-size: 2rem;
	cursor: pointer;
	letter-spacing: 0.1em;
}
.contactBox .radioUl input[type="radio"]:checked ~ span,
.contactBox .btmTxt input[type="checkbox"]:checked ~ span {
	background-image: url("../img/index/radio_icon02.png");
}
.contactBox .radioUl .item02 input[type="radio"] ~ span {
	color: #665e05;
}
.contactBox .radioUl .item02 input[type="radio"]:checked ~ span {
	background-image: url("../img/index/radio_icon03.png");
}
.contactBox .fromUl {
	margin-bottom: 2.3rem;
}
.contactBox .btmTxt {
	margin-bottom: 1.5rem;
	text-align: center;
}
.contactBox .btmTxt a {
	color: #3868e2;
	text-decoration: underline;
}
.contactBox .btmTxt input[type="checkbox"] ~ span {
	font-weight: 400;
	font-size: 1.4rem;
	padding: 0.5rem 0 0.4rem 2.9rem;
}
.contactBox .submit input {
	color: #fff;
	background-color: #08325a;
	border: none;
	height: 7rem;
	font-weight: 800;
	font-size: 2rem;
	cursor: pointer;
	transition: 0.3s;
}
.contactBox .title {
	margin-bottom: 2.5rem;
	font-size: 2.4rem;
	font-weight: 900;
	letter-spacing: 0.1em;
}
.contactBox .ttl {
	padding: 0.4rem 0.4rem 0.2rem;
	color: #2f2f2f;
	font-size: 1.4rem;
	margin-bottom: 0.5rem;
	letter-spacing: 0.1em;
}
.contactBox .submit li {
	margin-bottom: 1rem;
}
.contactBox .submit li:last-child {
	margin-bottom: 0;
}
.contactBox .thanks {
	font-size: 1.6rem;
	text-align: center;
	line-height: 2;
	padding: 5rem 0;
}
.contactBox .btmTxt a:hover {
	text-decoration: none;
}
.contactBox .submit input:hover {
	opacity: 0.7;
}
@media all and (min-width: 897px) {
	#contact .close:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#contact {
		padding: 3rem 2rem 4.4rem;
		width: calc(100% - 2rem);
		left: 1rem;
		bottom: 1rem;
		max-height: calc(100svh - 2rem);
		border-width: 0.4rem;
	}

	.spStyle .contactBox .btmTxt a:hover {
		text-decoration: underline;
	}
	.spStyle .contactBox .submit input:hover {
		opacity: 1;
	}
	.spStyle .contactBox .radioUl {
		gap: 0.5rem;
	}
	.spStyle .contactBox input[type="text"],
	.spStyle .contactBox input[type="email"],
	.spStyle .contactBox input[type="tel"],
	.spStyle .contactBox textarea,
	.spStyle .contactBox input[type="submit"]  {
		font-size: 1.4rem;
		padding: 0 1.2rem;
		letter-spacing: 0;
	}
	.spStyle .contactBox textarea {
		padding: 1.2rem;
	}
	.spStyle .contactBox .radioUl input[type="radio"] ~ span {
		font-size: 1.4rem;
		background-size: 1.8rem 1.8rem;
	}
}


/* caseBox */
#main .caseBox {
	padding: 6.5rem 0 13.5rem;
	background-color: #12234d;
	position: relative;
	overflow: hidden;
}
#main .caseBox .headLine01 {
	margin-bottom: 7.8rem;
}
#main .caseBox .slideBox {
	position: relative;
}
#main .caseBox .slideBox .arrowUl li {
	width: 5.6rem;
	position: absolute;
	top: 50%;
	left: 0;
	cursor: pointer;
	transform: translateY(-50%);
}
#main .caseBox .slideBox .arrowUl .next {
	left: auto;
	right: 0;
}
#main .caseBox .enImg {
	position: absolute;
	top: -4.6rem;
	right: -2.6rem;
}
#main .caseBox .listUl {
	display: flex;
	flex-wrap: wrap;
	font-weight: 900;
	color: #030b20;
}
#main .caseBox .listUl li {
	margin: 0 2.8rem;
	padding-bottom: 1.6rem;
	width: 37rem !important;
	position: relative;
}
#main .caseBox .listUl .bgBox {
	color: #030b20;
	background-color: #fff;
	display: block;
}
#main .caseBox .listUl .title {
	font-size: 2.6rem;
	letter-spacing: 0.1em;
	margin: 0 -1.5rem 2.2rem 0;
}
#main .caseBox .listUl .title span {
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.13em;
}
#main .caseBox .listUl .price {
	color: #a19510;
	font-size: 2.4rem;
}
#main .caseBox .listUl .photo {
	aspect-ratio: 370/240;
	overflow: hidden;
	position: relative;
}
#main .caseBox .listUl .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .caseBox .listUl .photo::before {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	border: 1rem solid #ffff;
	opacity: 0.4;
	content: "";
	box-sizing: border-box;
}
#main .caseBox .listUl .btn {
	position: absolute;
	bottom: 0;
	right: 1.2rem;
}
#main .caseBox .listUl .btn span {
	padding: 0.4rem 1.6rem 0.4rem;
	width: 12.4rem;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 900;
	text-align: right;
	display: inline-block;
	background-color: #a19510;
}
#main .caseBox .listUl .topBox {
	padding: 4.1rem 3.2rem 4.3rem;
}
@media all and (min-width: 897px) {
	#main .caseBox .listUl a:hover {
		opacity: 0.7;
	}
	#main .caseBox .slideBox .arrowUl li:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .caseBox {
		padding: 9.3rem 0 7.3rem;
	}
	#main .caseBox .headLine01 {
		margin-bottom: 5.1rem;
	}
	#main .caseBox .listUl li {
		margin: 0 1rem;
		width: 35rem !important;
	}
	#main .caseBox .listUl .topBox {
		padding: 2.8rem 3.2rem 4.3rem;
	}
	#main .caseBox .listUl .title {
		margin-bottom: 2.3rem;
	}
	#main .caseBox .enImg {
		top: 2.2rem;
		right: auto;
		width: 35rem;
		left: 50%;
		transform: translateX(-50%);
	}
}




/* worksBox */
#main .worksBox {
	padding: 10rem 0 17rem;
	background-color: #030b20;
	position: relative;
}
#main .worksBox .content {
	max-width: 132.4rem;
}
#main .worksBox .enImg {
	position: absolute;
	top: 0;
	left: 0;
}
#main .worksBox .headLine01 {
	margin-bottom: 5.4rem;
}
#main .worksBox .slideBox .image {
	overflow: hidden;
	aspect-ratio: 1200/660;
}
#main .worksBox .slideBox .image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#main .worksBox .smallUl {
	margin: 2.6rem 6.2rem 0;
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
}
#main .worksBox .smallUl li {
	width: calc((100% - 12rem)/7);
	cursor: pointer;
}
#main .worksBox .bigUl li {
	position: relative;
	padding: 0 6.2rem;
}
#main .worksBox .bigUl .textBox {
	width: 56.3rem;
	color: #030b20;
	position: absolute;
	bottom: 3.4rem;
	left: 0;
	font-weight: 900;
	font-size: 1.4rem;
	line-height: 1.42;
}
#main .worksBox .bigUl .textBox p {
	background-color: rgba(255, 255, 255, 0.8);
	padding: 1rem 1.6rem 1.2rem;
	letter-spacing: 0.05em;
}
#main .worksBox .bigUl .textBox .title {
	margin-bottom: 0.6rem;
	font-size: 2.4rem;
	padding: 0.6rem 1.6rem 0.4rem;
}
#main .worksBox .slideBox .smallUl .image {
	aspect-ratio: 1200/650;
}
#main .worksBox .slideBox .smallUl li {
	opacity: 0.3;
	position: relative;
}
#main .worksBox .slideBox .smallUl li::before {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	border: 0.2rem solid #fff;
	box-sizing: border-box;
	content: "";
	opacity: 0;
}
#main .worksBox .slideBox .smallUl .on {
	opacity: 1;
}
#main .worksBox .slideBox .smallUl .on::before {
	opacity: 1;
}
@media all and (max-width: 896px) {
	#main .worksBox .bigUl li {
		padding: 0;
	}
	#main .worksBox .smallUl {
		margin: 3.4rem 0 0 0;
		gap: 2.4rem 0;
		justify-content: space-between;
	}
	#main .worksBox .smallUl li {
		width: calc(50% - 1.2rem);
	}
	#main .worksBox .bigUl .textBox {
		margin-top: 0.6rem;
		width: auto;
		position: static;
		bottom: auto;
		left: auto;
		font-size: 1.4rem;
		line-height: 1.42;
	}
	#main .worksBox .enImg {
		top: 6.6rem;
		left: 50%;
		width: 35rem;
		transform: translateX(-50%);
	}
	#main .worksBox {
		padding: 11.5rem 0 6.8rem;
	}
	#main .worksBox .headLine01 {
		font-size: 2rem;
		margin-bottom: 4.1rem;
	}
	#main .worksBox .headLine01 .en {
		margin-bottom: 1.7rem;
	}
	#main .worksBox .slideBox .image {
		aspect-ratio: 1200/676;
	}
	#main .worksBox .bigUl .textBox p {
		padding: 1rem 1.6rem 0.9rem;
		letter-spacing: 0.1em;
	}
}

/* flowBox */
#main .flowBox {
	padding: 10rem 0 13.5rem;
	background-color: #030b20;
	position: relative;
}
#main .flowBox::before {
	width: 94.8%;
	height: 0.2rem;
	position: absolute;
	right: 0;
	top: 0;
	background-color: #6db3f4;
	content: "";
}
#main .flowBox .enImg {
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
}
#main .flowBox .listUl {
	display: flex;
	flex-wrap: wrap;
	color: #000000;
	font-size: 1.6rem;
	font-weight: 700;
}
#main .flowBox .listUl li {
	margin-right: 2.4rem;
	width: 18rem;
	border: 1px solid #fff;
	background-color: #fff;
	box-sizing: border-box;
	position: relative;
}
#main .flowBox .listUl li::after {
	margin-top: -1.7rem;
	width: 1.4rem;
	height: 3rem;
	position: absolute;
	top: 50%;
	right: -2.1rem;
	background: url("../img/index/arrpw04.png") no-repeat center center;
	background-size: 100% 100%;
	transform: translateY(-50%);
	content: "";
}
#main .flowBox .listUl li:last-child {
	margin-right: 0;
}
#main .flowBox .listUl li:last-child:after {
	display: none;
}
#main .flowBox .listUl .textBox {
	padding: 1.9rem 1.5rem 3.3rem;
}
#main .flowBox .listUl .title {
	height: 14.3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #2266a8;
	font-size: 2.2rem;
	font-weight: 900;
	color: #fff;
	padding-bottom: 0.5rem;
	letter-spacing: 0.1em;
}
#main .flowBox .listUl .item01 {
	padding: 2rem;
	color: #fff;
	width: 17rem;
	margin-right: 3.1rem;
	background-color: transparent;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}
#main .flowBox .listUl .item01::after {
	right: -2.6rem;
}
#main .flowBox .listUl .inner {
	width: 100%;
	padding-top: 4.2rem;
}
#main .flowBox .listUl .item01 .ttl {
	margin-bottom: 0.9rem;
	font-weight: 900;
	font-size: 2.2rem;
}
#main .flowBox .listUl .item01 .ttl img {
	margin-bottom: 1rem;
	width: 3.2rem;
}
#main .flowBox .listUl .item01 a {
	text-decoration: underline;
	margin-top: 0.6rem;
	display: inline-block;
}
#main .flowBox .headLine01 {
	margin-bottom: 5.6rem;
}
@media all and (max-width: 896px) {
	#main .flowBox::before {
		width: 100%;
		height: 0.4rem;
	}
	#main .flowBox .headLine01 {
		font-size: 2rem;
		margin-bottom: 6.8rem;
	}
	#main .flowBox .headLine01 .en {
		margin-bottom: 1.7rem;
	}
	#main .flowBox .enImg {
		left: 50%;
		top: 3.3rem;
		width: 35rem;
	}
	#main .flowBox .listUl {
		display: block;
		font-size: 1.8rem;
		line-height: 1.44;
	}
	#main .flowBox .listUl li {
		width: auto !important;
		margin: 0 0 4rem !important;
	}
	#main .flowBox .listUl li:last-child {
		margin-bottom: 0 !important;
	}
	#main .flowBox .listUl .title {
		height: 7rem;
		font-size: 2.35rem;
		padding-bottom: 0.5rem;
		letter-spacing: 0.1em;
	}
	#main .flowBox .listUl .textBox {
		padding: 1.9rem 2.3rem 2.5rem;
	}
	#main .flowBox .listUl li::after {
		margin: 0 0 0 -0.8rem;
		top: auto;
		right: auto;
		transform: rotate(90deg) translateX(-50%);
		left: 50%;
		bottom: -4.5rem;
	}
	#main .flowBox .listUl li:last-child:after {
		display: none;
	}
	#main .flowBox {
		padding: 10rem 0 8.1rem;
	}
	#main .flowBox .listUl .item01 .ttl img {
		margin-bottom: 0;
		position: absolute;
		top: 3.5rem;
		left: 0.4rem;
		width: 4.2rem;
	}
	#main .flowBox .listUl .inner {
		width: 100%;
		margin: 0 auto;
		max-width: 35rem;
		padding: 0.4rem 0 0 6.7rem;
		position: relative;
		text-align: left;
	}
	#main .flowBox .listUl .item01 {
		line-height: 1.33;
		padding-bottom: 3.7rem;
	}
	#main .flowBox .listUl .item01 .ttl {
		font-size: 2.4rem;
		margin-bottom: 0.7rem;
	}
	#main .flowBox .listUl .item01 a {
		font-size: 2rem;
		margin-top: 0.7rem;
	}
}

/* productBox */
#main .productBox {
	padding: 6.5rem 0 14.1rem;
	color: #030b20;
	position: relative;
}
#main .productBox .content {
	max-width: inherit;
	width: auto;
}
#main .productBox .headLine01 {
	color: #030b20;
	margin-bottom: 2.3rem;
}
#main .productBox .centerTxt {
	color: #665e05;
	margin-bottom: 1.4rem;
}
#main .productBox .listUl {
	font-size: 1.2rem;
	line-height: 1.33;
	text-align: center;
	letter-spacing: 0.1em;
}
#main .productBox .listUl li {
	width: 35.6rem !important;
}
#main .productBox .listUl .ttl {
	margin-bottom: 0.8rem;
	font-size: 1.6rem;
	font-weight: 900; 
}
#main .productBox .enImg {
	width: 98.6rem;
	position: absolute;
	left: 50%;
	bottom: -7.4rem;
	transform: translateX(-50%);
}
#main .productBox .listUl .image {
	width: 100%;
	margin-bottom: 1.1rem;
	height: 25.5rem;
}
#main .productBox .listUl .image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
#main .productBox .centerTxt {
	font-size: 2rem;
}
@media all and (max-width: 896px) {
	#main .productBox {
		padding: 8rem 0 18.9rem;
	}
	#main .productBox .headLine01 {
		margin-bottom: 3.3rem;
		font-size: 2.4rem;
	}
	#main .productBox .headLine01 .en {
		margin-bottom: 1.3rem;
	}
	#main .productBox .centerTxt {
		font-size: 2rem;
		line-height: 1.4;
		margin-bottom: 5.6rem;
	}
	#main .productBox .listUl .ttl {
		font-size: 1.8rem;
	}
	#main .productBox .listUl {
		font-size: 1.4rem;
		margin: 0 -2rem;
	}
	#main .productBox .enImg {
		width: 30.3rem;
		bottom: -4.1rem;
	}
	#main .productBox .listUl li {
		margin: 0 -2.5rem;
	}
}
/* btmBox */
#main .movieBox .bottomBox {
	margin: 0 auto;
	padding: 17px 0 0 92px;
	max-width: 93.4rem;
	position: relative;
	display: flex;
	color: #fff;
}
#main .movieBox .bottomBox .enImg {
	width: 10.5rem;
	left: -0.2rem;
	top: -6.1rem;
	right: auto;
	z-index: -1;
}
#main .movieBox .bottomBox .leftBox {
	width: 36.5rem;
}
#main .movieBox .bottomBox .rightBox {
	flex: 1;
	margin: 6.9rem 0 0 6.5rem;
	font-weight: 700;
	font-size: 1.8rem;
	order: 3;
}
#main .movieBox .bottomBox .title {
	margin-bottom: 2.6rem;
	font-size: 2.7rem;
	line-height: 1.8;
}
#main .movieBox .bottomBox p {
	line-height: 2;
	margin-bottom: 3.5rem;
}
#main .movieBox .bottomBox p:last-child {
	margin-bottom: 0;
}
#main .movieBox .imgUl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#main .movieBox .imgUl li {
	width: 13rem;
	overflow: hidden;
}
#main .movieBox .imgUl img {
	width: 100%;
}
#main .movieBox .imgUl .item02 {
	width: 17rem;
	margin-top: 78px;
}
#main .movieBox .imgUl .item03 {
	width: 17rem;
	margin: -11.3rem 0 0 -1.5rem;
}
#main .movieBox .imgUl .item04 {
	width: 15.1rem;
	margin: 8.2rem -1.2rem 0 0;
}
#main .movieBox .imgUl .image {
	overflow: hidden;
	aspect-ratio: 406/720;
}
#main .movieBox .imgUl .image iframe,
#main .movieBox .imgUl .image video {
	width: 100%;
	height: 100%;
	object-fit: cover
}
@media all and (max-width: 896px) {
	#main .movieBox .bottomBox {
		margin: 0 auto;
		padding: 0 0 0 5.4rem;
		max-width: inherit;
		display: block;
	}
	#main .movieBox .bottomBox .leftBox {
		width: auto;
	}
	#main .movieBox .imgUl li {
		width: 41%;
	}
	#main .movieBox .imgUl .item02 {
		width: 45%;
	}
	#main .movieBox .bottomBox .rightBox {
		margin: 0 0 5.9rem 0;
		font-size: 1.6rem;
	}
	#main .movieBox .bottomBox .enImg {
		width: 6.5rem;
		left: -2rem;
		top: -2.1rem;
		right: auto;
	}
	#main .movieBox .bottomBox .title {
		font-size: 2.5rem;
	}
	#main .movieBox .imgUl .item03 {
		width: 47%;
	}
	#main .movieBox .imgUl .item04 {
		width: 40%;
	}
}