@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.wrap {
	position: relative;
	background-color: #fff;
}
.mainVisual {
	margin: 0.7rem 0 5.1rem;
}
.mainVisual .imgtext01 {
	margin: 0 auto 1.2rem;
	width: 24.4rem;
}
.mainVisual .photo {
	margin-bottom: 1.5rem;
}
.mainVisual .photo img {
	width: 100%;
}
.mainVisual .imgtext02 {
	margin: 0 auto 1.2rem;
	width: 31.7rem;
}
#main .activity {
	margin-bottom: 6.6rem;
}
#main .activity .videoBox {
	aspect-ratio: 335/180;
}
#main .activity .videoBox iframe {
	width: 100%;
	height: 100%;
}
#main .participate {
	margin-bottom: 5.2rem;
}
#main .participate .imgBox {
	margin: 0 auto 4.2rem;
	width: 94.1%;
}
#main .participate .imgBox:last-child {
	margin-bottom: 0;
}
#main .participate .imgBox .photoBox {
	margin-bottom: 0.6rem;
}
#main .participate .imgBox .photoBox img {
	width: 100%;
}
#main .participate .imgBox .textBox .title {
	margin-bottom: 1rem;
	text-align: center;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.07rem;
}
#main .participate .imgBox .textBox .name {
	margin-left: 1.5rem;
	display: inline-block;
	font-size: 1.6rem;
}
#main .participate .imgBox .textBox .name span {
	font-size: 1.3rem;
}
#main .participate .imgBox .textBox .text {
	text-align: justify;
	line-height: 1.75;
	letter-spacing: 0.07rem;
}
#main .support {
	padding: 5.1rem 1rem 6.2rem;
	background-color: #FDF3F6;
}
#main .support .supportUl .title {
	margin-bottom: 0.7rem;
	text-align: center;
}
#main .support .supportUl .title .text {
	display: block;
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.17rem;
}
#main .support .supportUl .title img {
	height: 1.8rem;
}
#main .support .supportUl li:not(:last-child) {
	margin-bottom: 4.2rem;
}
#main .support .supportUl li > .text {
	line-height: 1.75;
	letter-spacing: 0.07rem;
	text-align: justify;
}
#main .benefits {
	padding: 5rem 0 6.9rem;
}
#main .benefits .headLine01 {
	margin-bottom: 2.8rem;
}
#main .benefits .textBox {
	margin-bottom: 1rem;
	padding: 1.9rem 2.5rem 2.2rem;
	background-color: #FCECF1;
}
#main .benefits .textBox:last-child {
	margin-bottom: 0;
}
#main .benefits .textBox .h_title {
	padding: 1.2rem 0 0.7rem;
	margin: 0 auto 0.4rem;
	width: fit-content;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.16rem;
	background: url(../img/index/benefits_img.png) no-repeat right 0.7rem bottom 0.3rem / 3.9rem;
}
#main .benefits .textBox .h_title span {
	display: block;
	font-size: 1.4rem;
}
#main .benefits .textBox .text {
	line-height: 1.75;
	letter-spacing: 0.14rem;
	text-align: justify;
}
#main .benefits .textBox01 {
	background-color: #E6F4FC;
}
#main .benefits .textBox01 .text {
	line-height: 1.75;
	letter-spacing: 0.14rem;
	text-align: center;
}
#main .benefits .textBox02 {
	padding: 0.8rem 2.5rem 1.6rem;
	background-color: #FEF4D5;
}
#main .benefits .textBox02 .h_title {
	padding-bottom: 1rem;
	margin-bottom: 0;
	background-position: right 0.7rem bottom;
}
#main .benefits .textBox02 .sub .text {
	flex: 1;
	text-align: left;
}
#main .benefits .textBox02 .sub .photo {
	margin: -2.1rem -3.2rem 0 0;
	width: 11.5rem;
}
#main .flow {
	margin-bottom: 6.9rem;
	padding: 0 1rem;
}
#main .flow .imgBox:not(:last-child) {
	margin-bottom: 4.7rem;
}
#main .flow .imgBox .title {
	overflow: hidden;
	margin-bottom: 0.5rem;
	padding: 0 0.2rem 0.9rem;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.17rem;
	background: url(../img/index/flow_h_bg.png) no-repeat right bottom  / 90rem 1.5rem;
}
#main .flow .imgBox .title .imgtext {
	margin-right: 1.6rem;
	display: inline-block;
	vertical-align: -0.3rem;
}
#main .flow .imgBox .title .imgtext img {
	height: 1.9rem;
}
#main .flow .imgBox .text {
	margin-bottom: 2.1rem;
	line-height: 1.75;
	letter-spacing: 0.098rem;
	text-align: justify;
}
#main .flow .imgBox .photo img {
	width: 100%;
}
#main .flow .imgBox .intro {
	margin-top: 0.5rem;
	font-size: 1.2rem;
	line-height: 1.6;
	letter-spacing: 0.06rem;
}
#main .period {
	padding: 0 2rem 5rem;
}
#main .period .time {
	padding: 1.6rem 1.4rem 1.7rem 1rem;
	margin: 0 auto 2.9rem;
	width: fit-content;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.7;
	letter-spacing: 0.17rem;
	min-width: 24rem;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	background-color: #FDF3F6;
}
#main .period .title {
	margin-bottom: 1.2rem;
	padding-left: 1.6rem;
	position: relative;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.16rem;
}
#main .period .title::after {
	position: absolute;
	top: 1rem;
	left: 0;
	content: "";
	z-index: 1;
	width: 0.8rem;
	height: 0.8rem;
	border-radius: 50%;
	background-color: #EA617F;
}
#main .period .text {
	margin-bottom: 3rem;
	line-height: 1.75;
	letter-spacing: 0.14rem;
}
#main .period .photo {
	margin: 0 auto;
	width: 91.19%;
}
#main .period .photo img {
	width: 100%;
}
#main .recruit {
	padding: 5rem 1rem 6rem;
	background-color: #FFFAEF;
}
#main .recruit .textBox {
	margin-bottom: 3rem;
}
#main .recruit .textBox .tag {
	padding: 0.5rem 1.7rem;
	margin: 0 auto 1rem;
	width: fit-content;
	text-align: center;
	color: #EA617F;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.14rem;
	background-color: #fff;
}
#main .recruit .textBox .title {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.18rem;
}
#main .recruit .textBox .text {
	margin: 0.5rem 0 0.8rem;
	text-align: center;
	font-size: 1.3rem;
	line-height: 1.4;
	letter-spacing: 0.13rem;
}
#main .recruit .textBox .sml {
	text-align: center;
	font-weight: 700;
	line-height: 1.75;
	letter-spacing: 0.14rem;
}
#main .recruit .textBox01 {
	margin-bottom: 4rem;
}
#main .recruit .textBox01 .title {
	margin-bottom: 1rem;
	font-size: 1.5rem;
	line-height: 1.75;
}
#main .recruit .textBox .notes {
	letter-spacing: 0.13rem;
	font-size: 1.3rem;
	line-height: 1.6;
}
#main .recruit .btn {
	margin: 0 auto;
	width: 27.5rem;
}
#main .recruit .btn a {
	padding: 1rem 4rem;
	min-height: 7rem;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 1.25;
	letter-spacing: 0.16rem;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #EA617F url(../img/common/icon01.png) no-repeat right 1.2rem center / 1.5rem;
	border-radius: 10rem;
}
#main .recruit .btn a:hover {
	opacity: 0.7;
}
@media all and (min-width: 897px) {
	.wrap {
		margin: 0 auto;
		max-width: 37.5rem;
		position: relative;
		z-index: 1;
	}
	.wrap::after {
		position: absolute;
		top: 0;
		left: -6.25rem;
		right: -6.25rem;
		bottom: 0;
		background-color: #fff;
		content: "";
		z-index: -1;
	}
}