@charset "UTF-8";

/*-----------------------------------

	contents

-----------------------------------*/
#contents {
	padding-top: 120px;
	margin-top: 0;
}
@media screen and (max-width: 840px) {
	#contents {
		padding-top: 90px;
	}
}
/*-----------------------------------

	headline

-----------------------------------*/
#headline {
	width: 100%;
	height: 196px;
	display: grid;
	place-content: center;
}
#headline h1 {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
}
#headline h1::before {
	font-size: 60px;
	color: var(--mClr1);
	display: block;
	margin-bottom: 10px;
}
@media screen and (max-width: 640px) {
	#headline {
		height: 140px;
	}
	#headline h1::before {
		font-size: 40px;
		margin-bottom: 5px;
	}
}
/*-----------------------------------

	mainvisual

-----------------------------------*/
#mainvisual {
	width: 100%;
	height: 650px;
	position: relative;
	z-index: 0;
	margin-bottom: 100px;
}
#mainvisual::before,
#mainvisual::after {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
#mainvisual::before {
	background: url(../img/common/mv_logo.svg) no-repeat center center/180vw;
	z-index: 10;
}
#mainvisual::after {
	background: #00000073;
	z-index: 5;
}
#mainvisual img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#mainvisual .mv_inner {
	width: max-content;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 15;
	color: #FFF;
}
#mainvisual .mv_inner .copy {
	font-size: 40px;
	font-weight: 700;
	line-height: 1.5;
	white-space: pre-line;
	margin-bottom: 30px;
}
#mainvisual .mv_inner .copy br {
	display: none;
}
#mainvisual .mv_inner p {
	font-size: 16px;
	font-weight: 600;
	line-height: 2;
	white-space: pre-line;
}
@media screen and (max-width: 1160px) {
	#mainvisual .mv_inner .copy {
		font-size: 32px;
	}
	#mainvisual .mv_inner p {
		font-size: 15px;
	}
}
@media screen and (max-width: 840px) {
	#mainvisual::before {
		background: url(../img/index/mv_logo.svg) no-repeat center center/210vw;
	}
	#mainvisual .mv_inner {
		width: 90%;
	}
	#mainvisual .mv_inner .copy {
		font-size: 22px;
	}
}
@media screen and (max-width: 640px) {
	#mainvisual {
		height: auto;
		margin-bottom: 80px;
	}
	#mainvisual::before,
	#mainvisual::after {
		height: 450px;
	}
	#mainvisual::before {
		background: url(../img/index/mv_logo.svg) no-repeat center center/210vw;
	}
	#mainvisual img {
		height: 450px;
	}
	#mainvisual .mv_inner {
		display: contents;
	}
	#mainvisual .mv_inner .copy {
		text-align: center;
		line-height: 1.72;
		width: 100%;
		height: 450px;
		display: grid;
		place-content: center;
		position: absolute;
		top: 0;
		z-index: 10;
	}
	#mainvisual .mv_inner .copy br {
		display: inline;
	}
	#mainvisual .mv_inner p {
		color: #000;
		padding: 40px 5% 0;
		white-space: normal;
	}
}
@media screen and (max-width: 480px) {
	#mainvisual::before {
		background: url(../img/index/mv_logo.svg) no-repeat center center/245vw;
	}
}
