@charset "utf-8";
/*.contents01ここから*/
.contents01{
	width: 100%;
	height: auto;
	display: block;
}
.contents01 .contents01_01{
	width: 118.0rem;
	height: auto;
	min-height: calc(100vh - 9.0rem - 3.5rem);
	min-height: calc((var(--vh, 1vh) * 100) - 9.0rem - 3.5rem);
	padding: 10.0rem 0 0;
	margin: 0 auto;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-direction: column;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01{
		width: 32.0rem;
		min-height: calc(100vh - 6.0rem - 3.2rem);
		min-height: calc((var(--vh, 1vh) * 100) - 6.0rem - 3.2rem);
		padding: 8.0rem 0 0;
	}
}
.contents01 .contents01_01 .contents01_01_01{
	width: 100%;
	height: auto;
	margin: 0 0 6.8rem;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-direction: column;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_01{
		margin: 0 0 3.8rem;
	}
}
.contents01 .contents01_01 .contents01_01_01 > .text01{
	width: auto;
	height: auto;
	margin: 0 0 1.0rem;
	font-size: 4.5rem;
	line-height: 4.5rem;
	display: block;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_01 > .text01{
		font-size: 3.0rem;
		line-height: 3.0rem;
	}
}
.contents01 .contents01_01 .contents01_01_01 > .text02{
	width: auto;
	height: auto;
	margin: 0;
	font-size: 2.2rem;
	line-height: 2.2rem;
	display: block;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_01 > .text02{
		font-size: 1.8rem;
		line-height: 2.4rem;
	}
}
.contents01 .contents01_01 .contents01_01_01 > .text03{
	width: auto;
	height: auto;
	margin: 2.0rem auto 0;
	font-size: 3.5rem;
	line-height: 3.5rem;
	display: block;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_01 > .text03{
		font-size: 2.0rem;
		line-height: 2.0rem;
	}
}
.contents01 .contents01_01 .contents01_01_02{
	width: 100%;
	height: auto;
	margin: 0;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	position: relative;
}
.contents01 .contents01_01 .contents01_01_02 > .link01{
	width: calc((100% - 3.0rem * 3) / 4);
	height: auto;
	aspect-ratio: 1/1;
	margin: 3.0rem 3.0rem 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	position: relative;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_02 > .link01{
		width: calc((100% - 2.0rem * 1) / 2);
		margin: 2.0rem 2.0rem 0 0;
	}
}
.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(-n+4){
	margin-top: 0;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(-n+4){
		margin-top: 2.0rem;
	}
	.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(-n+2){
		margin-top: 0;
	}
}
.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(4n){
	margin-right: 0;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(4n){
		margin-right: 2.0rem;
	}
	.contents01 .contents01_01 .contents01_01_02 > .link01:nth-of-type(2n){
		margin-right: 0;
	}
}
.contents01 .contents01_01 .contents01_01_02 > .link01 > .link01_01{
	width: auto;
	height: auto;
	padding: .5rem;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	font-size: 2.2rem;
	line-height: 2.5rem;
	color: #ffffff;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto;
	text-shadow: 1px 1px 2px rgba(0, 0, 0, .8), 1px 1px 2px rgba(0, 0, 0, .8), 1px 1px 2px rgba(0, 0, 0, .8);
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 .contents01_01_02 > .link01 > .link01_01{
		font-size: 1.5rem;
		line-height: 1.8rem;
	}
}
.contents01 .contents01_01 > .link01{
	width: 20.0rem;
	height: 5.0rem;
	margin: 5.0rem 0 0;
	font-size: 1.5rem;
	line-height: 1.9rem;
	color: #B7B7B7;
	border: .1rem solid #B7B7B7;
	display: flex;
	justify-content: center;
	align-items: center;
}
@media only screen and (max-width: 767px) {
	.contents01 .contents01_01 > .link01{
		width: 25.0rem;
		margin: 3.6rem 0 0;
	}
}
.contents01 .contents01_01 > .link01:hover{
	color: #ffffff;
	background-color: #B7B7B7;
	opacity: 1;
}
/*.contents01ここまで*/