@charset "utf-8";

body {
	color: #434A40;
}
a {
	color: #2E6BF8;
}

.bg {
	background: #434A40;
	padding-top: 80px;
}
/*------------------------------------------------------------------------*/
@media (max-width:767px) {
	.bg{
		padding-top: 0;
	}
	.bg section.first_group:first-of-type {
		padding-top: 200px;
	}
}

/*-------------------------------------------------------------------------
	pagetop
-------------------------------------------------------------------------*/

.pagetop {
	background: #DEEFDC;
}
.pagetop span {
	color: #434A40;
}

/*-------------------------------------------------------------------------
	kv
-------------------------------------------------------------------------*/

#kv {
	width: 100%;
	height: 80%;
	background: url('img/webp/approach_image_1.webp') no-repeat center center / cover;
	position: relative;
	padding-top: 150px;
}
/* Internet Explorer向けの設定（JPEG） */
@media all and (-ms-high-contrast: none),
(-ms-high-contrast: active) {
	#kv {
		background-image: url('img/approach_image_1.jpg');
	}
}
#kv h1 {
	position: absolute;
	top: 150px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	white-space: nowrap;
}

#kv h1 small {
	font-size: 32px;
	text-align: center;
	line-height: 1.5;
}
#kv h1 b {
	font-size: 56px;
	line-height: 1.125;
	text-align: center;
	margin-top: 24px;
	text-shadow:
	-1px -1px 0 #fff,
	1px -1px 0 #fff,
	-1px 1px 0 #fff,
	1px 1px 0 #fff,
	0px -1px 0 #fff,
	0px 1px 0 #fff,
	-1px 0px 0 #fff,
	1px 0px 0 #fff;
}


#kv p {
	position: absolute;
	left: 64px;
	bottom: 100px;
}
.point_group {
    display: flex;
    text-align: center;
	position: absolute;
	column-gap: 3vw;
    bottom: -13%;
    left: 50%;
    transform: translate(-50%, 10%);
}
.point_circle {
	background-color: #c39000;
    color: #fff;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    display: flex;
	flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1.5;
	font-size: 20px;
}
/*------------------------------------------------------------------------*/

@media screen and (max-width: 767px) {


	#kv {
		height: 54%;
	}

	#kv h1 {
		top: 90px;
	}

	#kv h1 small {
		font-size: 18px;
	}
	#kv h1 b {
		font-size: 32px;
		margin-top: 0px;
	}


	#kv p {
		left: 24px;
		bottom: 24px;
	}
	#kv p img {
		zoom: .5;
	}
	.point_group{
		column-gap: 2vw;
		bottom: -130px;
	}
	.point_circle{
		width: 30vw;
		height: 30vw;
		font-size: 3.5vw;
	}

}

/*-------------------------------------------------------------------------
	h2
-------------------------------------------------------------------------*/

h2 {
	font-size: 48px;
	line-height: 1.25;
	text-align: center;
}
.category {
	font-size: 64px;
	line-height: 1;
	padding-top: 80px;
	margin-bottom: 96px;
	display: flex;
	align-items: center;
	position: relative;
}
.category span {
	flex: 1;
	display: flex;
	align-items: center;
	position: relative;
}

.category span:after {
	content: "";
	display: block;
	margin-left: 64px;
	margin-right: calc(50% - 50vw);
	border-top: 2px solid #707070;
	flex: 1;
}

.category:after {
	content: "";
	display: block;
	margin-left: 64px;
	margin-right: calc(50% - 50vw);
	border-top: 1px solid #707070;
	flex: 1;
	position: relative;
	top: -16px;
	right: 0;
}

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

@media screen and (max-width: 767px) {


	h2 {
		font-size: 28px;
	}
	.category {
		font-size: 28px;
		padding-top: 48px;
		margin-bottom: 64px;
	}

	.category span:after {
		margin-left: 24px;
	}

	.category:after {
		margin-left: 24px;
		top: -8px;
	}

}


/*-------------------------------------------------------------------------
	h3
-------------------------------------------------------------------------*/

h3 {
	font-size: 32px;
	line-height: 1.75;
	text-align: center;
}

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

@media screen and (max-width: 767px) {


	h3 {
		font-size: 20px;
	}


}

/*-------------------------------------------------------------------------
	figure
-------------------------------------------------------------------------*/

.figure span.right {
	display: block;
	margin-right: calc(50% - 50vw);
}
.figure span.left {
	display: block;
	margin-left: calc(50% - 50vw);
}
.figure span img {
	width: 100%;
}

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

@media screen and (max-width: 767px) {




}



/*-------------------------------------------------------------------------
	spec
-------------------------------------------------------------------------*/

.spec {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 -16px;
}
.spec li {
	flex: none;
	width: calc(100% / 5 - 32px);
	margin: 0 16px;
}
.spec dl {
}
.spec dt {
	height: 88px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.spec dt img {
	zoom: .75;
}
.spec dd {
	margin-top: 16px;
	text-align: center;
}


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

@media screen and (max-width: 767px) {

	.spec {
		margin-bottom: -24px;
	}
	.spec li {
		width: calc(100% / 3 - 32px);
		margin-bottom: 24px;
	}
	.spec dt {
		height: 60px;
	}
	.spec dt img {
		zoom: .5;
	}


}

/*-------------------------------------------------------------------------
	pickup
-------------------------------------------------------------------------*/


.pickup {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	margin-top: 24px;
}
.pickup dt {
	text-align: center;
	margin-bottom: 24px;
}
.pickup dt img {
	width: 75%;
}
.pickup dd big {
	font-size: 24px;
}
.pickup_second_group .pickup dt img{
	width: 100%;
}

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

@media screen and (max-width: 767px) {

	.pickup {
		display: block;
		margin-top: 16px;
		position: relative;
	}
	.pickup dt {
		margin-left: 0;
		margin-bottom: 24px;
		text-align: center;
	}
	.pickup_second_group .pickup dt img {
		width: 75%;
	}
	.pickup dd h3 {
	}
	.pickup dd big {
		font-size: 24px;
	}



}



/*-------------------------------------------------------------------------
	separate
-------------------------------------------------------------------------*/

.separate {
	display: flex;
	flex-wrap: wrap;
	margin: 64px 0;
}
.separate li {
	width: 75%;
}
.separate img {
}
.separate li:first-child {
	margin-right: auto;
	position: relative;
	z-index: 1;
}
.separate li:last-child {
	margin-left: auto;
	margin-top: -40px;
}

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

@media screen and (max-width: 767px) {



	.separate {
		margin: 32px 0;
	}
	.separate li:last-child {
		margin-top: -24px;
	}


}



/*-------------------------------------------------------------------------
	end
-------------------------------------------------------------------------*/

.end a {
	color: #fff;
}

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

@media screen and (max-width: 767px) {




}
