@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
	position: relative;
	z-index: 2;
	min-height: 94rem;
	background: url(../img/index/main_bg01.png) no-repeat center top /cover;
	overflow: hidden;
}
.mainVisual .bg {
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
}
.mainVisual .bg img {
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	object-fit: cover;
}
.mainVisual .imgBox {
	padding-top: 12.5rem;
	margin: 0 auto;
	position: relative;
	z-index: 2;
	max-width: 129rem;
	min-height: 94rem;
}
.mainVisual .imgBox .photoBox {
	position: absolute;
	z-index: 1;
	right: 0;
	bottom: 0;
	width: 75rem;
}
.mainVisual .textBox {
	position: relative;
	z-index: 2;
	width: 61.8%;
}
.mainVisual .textBox .imgtext01 {
	margin: 0 auto 2.4rem;
	width: 34.7rem;
}
.mainVisual .textBox .imgtext02 {
	margin: 0 auto 10rem;
	width: 55.1rem;
}
.mainVisual .textBox .imgtext03 {
	margin: 0 auto;
	width: 55.9rem;
}
#main .sec01 {
	padding: 8.5rem 0 3.2rem;
	position: relative;
	z-index: 1;
	background: url(../img/index/sec01_bg01.png) no-repeat left top /cover;
	border-bottom: 0.4rem solid #D3BB79;
	overflow: hidden;
}
#main .sec01 .content {
	position: relative;
}
#main .sec01 .img {
	width: 38.9rem;
	position: absolute;
	z-index: -1;
	top: 50%;
	transform: translateY(-49.2%);
}
#main .sec01 .lImg {
	left: -31rem;
}
#main .sec01 .rImg {
	right: -31rem;
}
#main .sec01 .textBox {
	margin-bottom: 5.3rem;
	padding: 7.3rem 4rem 7rem;
	position: relative;
	z-index: 1;
}
#main .sec01 .textBox::after {
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	content: "";
	background: url(../img/index/sec01_bg02.png) no-repeat left top / 100% 100%;
	pointer-events: none;
}
#main .sec01 .textBox .title {
	margin-bottom: 3.8rem;
	color: #D3BB79;
	text-align: center;
	font-weight: 500;
	font-size: 3.5rem;
	line-height: 1.428;
}
#main .sec01 .textBox .text {
	margin-bottom: 3.6rem;
	text-align: center;
	line-height: 2.18;
}
#main .sec01 .textBox .text:last-child {
	margin-bottom: 0;
}
#main .sec01 .subText {
	padding: 1.7rem 2rem 1.8rem;
	text-align: center;
	border-top: 1px solid #D3BB79;
	border-bottom: 1px solid #D3BB79;
}
#main .sec01 .subText p {
	color: #D3BB79;
	font-size: 1.5rem;
}
#main .sec01 .subText p span {
	margin-bottom: 1.1rem;
	font-weight: 500;
	font-size: 3.5rem;
	display: block;
}
@media all and (max-width: 960px) {
	.mainVisual {
		min-height: 115.5rem;
		background-image: url(../img/index/main_bg01_sp.png);
	}
	.mainVisual .imgBox {
		padding-top: 10.7rem;
		max-width: 100%;
		min-height: 115.5rem;
	}
	.mainVisual .imgBox .photoBox {
		margin: 0 -10rem 0 -5rem;
		text-align: center;
		position: static;
		width: auto;
	}
	.mainVisual .imgBox .photoBox img {
		width: 52.5rem;
	}
	.mainVisual .textBox {
		width: auto;
	}
	.mainVisual .textBox .imgtext01 {
		margin: 0 auto 3.2rem;
		width: 23.9rem;
	}
	.mainVisual .textBox .imgtext02 {
		margin: 0 auto;
		width: 33.9rem;
	}
	.mainVisual .imgtext03 {
		padding: 1.3rem 0;
		width: auto;
		text-align: center;
		background-color: #000;
	}
	.mainVisual .imgtext03 img {
		width: 32.4rem;
	}
	#main .sec01 {
		padding: 7.1rem 0 5.8rem;
		background-image: url(../img/index/sec01_bg01_sp.png);
		background-size: 100% 100%;
	}
	#main .sec01 .textBox {
		margin: 0 auto 8.2rem;
		padding: 7.8rem 3rem 8rem;
		width: 35.5rem;
	}
	#main .sec01 .img {
		width: 27.7rem;
		top: -7.2rem;
		transform: translateY(0);
	}
	#main .sec01 .lImg {
		left: -7rem;
	}
	#main .sec01 .rImg {
		top: auto;
		bottom: -7rem;
		right: -7rem;
	}
	#main .sec01 .textBox::after {
		background-image: url(../img/index/sec01_bg02_sp.png);
	}
	#main .sec01 .textBox .title {
		margin-bottom: 2.5rem;
	}
	#main .sec01 .textBox .text {
		margin-bottom: 3.1rem;
		line-height: 2.13;
	}
	#main .sec01 .subText {
		margin: 0 1.7rem;
		padding: 2.8rem 0 3.7rem;
	}
	#main .sec01 .subText p {
		line-height: 2.13;
	}
	#main .sec01 .subText p span {
		margin-bottom: 0.9rem;
		line-height: 1.47;

	}
}