@charset "UTF-8";

/*================================================

　vision

=================================================*/
.vision {
	width: 100%;
	margin: 0 auto 40px;
	padding: 0;
}
.vision__content {
	position: relative;
	max-width: 1105px;
	margin: auto;
	padding: 0;
}
.vision__content::after {
	position: absolute;
	content: '';
	top: 61px;
	left: -36px;
	width: 648px;
	height: 505px;
	background: url("../images/top/vision_img_02.png") center center / 100% auto no-repeat;
	z-index: -1;
}
.vision__content h3 {
	width: 9em;
	margin: 0 auto 30px;
	font-size: 4.5rem;
	font-weight: 900;
	line-height: 0.85;
}
.vision__content h3 span {
	display: block;
}
.vision__content h3 span:last-child {
	text-indent: 2em;
}
.vision__content .vision-card {
	position: relative;
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
	max-width: 1100px;
	margin: auto;
	padding: 0 20px;
}
.vision__content .vision-card .vision-card__text {
	width: 51%;
}
.vision__content .vision-card p {
	margin-bottom: 1.5em;
	font-size: 1.8rem;
	line-height: 1.5;
}
.vision__content .vision-card p:first-child {
	margin-top: -0.25em;
}
.vision__content .vision-card figure {
	width: 49%;
	text-align: center;
}
.vision__content .vision-card figure img {
	width: 56.5217%;
}
.vision__content .vision-card figure figcaption {
	margin-top: 10px;
	font-size: 1.8rem;
}

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

	.vision {
		margin: 0 auto 40px;
	}
	.vision__content::after {
		top: 5.65338276vw;
		left: -3.33642261vw;
		width: 60.055607vw;
		height: 46.802595vw;
	}
	.vision__content h3 {
		width: 9.01em;
		margin: 0 auto 30px;
		font-size: clamp(3.3rem, (100vw - 769px) * 12 / 310 + 33px, 4.5rem);
	}
	.vision__content .vision-card p {
		font-size: clamp(1.3rem, (100vw - 769px) * 5 / 310 + 13px, 1.8rem);
	}
	.vision__content .vision-card figure figcaption {
		font-size: clamp(1.3rem, (100vw - 769px) * 5 / 310 + 13px, 1.8rem);
	}


}

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

	.vision {
		margin: 0 auto 5.33333333vw;
	}
	.vision__content::after {
		top: 8.26666666vw;
		left: 50%;
		width: 86.4vw;
		height: 67.3333333vw;
		transform: translateX(-50%);
	}
	.vision__content .title img {
		width: 27.0666666vw;
	}
	.vision__content h3 {
		margin: 0 auto 4.66666666vw;
		font-size: clamp(2.3rem, (100vw - 375px) * 23.5 / 393 + 23px, 4.65rem);
	}
	.vision__content .vision-card {
		flex-direction: column-reverse;
		align-items: center;
	}
	.vision__content .vision-card .vision-card__text {
		width: 74.2666667vw;
		margin-top: 5.33333333vw;
	}
	.vision__content .vision-card p {
		font-size: clamp(1.1rem, (100vw - 375px) * 10 / 393 + 11px, 2.1rem);
	}
	.vision__content .vision-card figure {
		width: 41.6vw;
	}
	.vision__content .vision-card figure img {
		width: 100%;
	}
	.vision__content .vision-card figure figcaption {
		margin-top: 1.33333333vw;;
		font-size: clamp(1rem, (100vw - 375px) * 8.5 / 393 + 10px, 1.85rem);
	}
	
}

/*================================================

　business

=================================================*/
.business {
	width: 100%;
	margin: 0 auto 90px;
	padding: 0;
}
.business__content {
	position: relative;
	max-width: 1105px;
	margin: auto;
	padding: 0;
}
.business__content .business-card {
	position: relative;
	display: flex;
	justify-content: space-between;
	max-width: 1100px;
	margin: 50px auto 70px;
	padding: 0 20px;
}
.business__content .business-card:nth-of-type(even) {
	flex-direction: row-reverse;
}
.business__content .business-card::after {
	position: absolute;
	content: '';
	left: 20px;
	bottom: 0;
	width: 100%;
	max-width: 505px;
	height: 3px;
	background-image : linear-gradient(to right, #000 3px, transparent 3px);
	background-size: 16px 3px;
	background-repeat: repeat-x; 
	background-position: left bottom;
}
.business__content .business-card:nth-of-type(even)::after {
	left: auto;
	right: 20px;
}
.business__content .business-card:last-child::after {
	display: none;
}
.business__content .business-card .business-card__text {
	max-width: 505px;
}
.business__content .business-card .business-card__text h3 {
	margin-bottom: 25px;
	font-size: 2.5rem;
	font-weight: 900;
}
.business__content .business-card .business-card__text h3 span {
	display: inline-block;
	margin-right: 0.5em;
	font-family: "Roboto", sans-serif;
	font-size: 4.5rem;
}
.business__content .business-card .business-card__text p {
	margin-bottom: 1.5em;
	font-size: 1.8rem;
	line-height: 1.5;
}
.business__content .business-card figure {
	max-width: 500px;
}

@media screen and (max-width: 1079px) {
	.business {
		margin: 0 auto 8.34105653vw;
	}
	.business__content .business-card {
		margin: 4.6339203vw auto 6.48748842vw;
	}
	.business__content .business-card::after {
		max-width: 46.802595vw;
	}
	.business__content .business-card .business-card__text {
		max-width: 46.802595vw;
	}
	.business__content .business-card .business-card__text h3 {
		margin-bottom: 2.31696015vw;
		font-size: clamp(1.8rem, (100vw - 769px) * 7 / 310 + 18px, 2.5rem);
	}
	.business__content .business-card .business-card__text h3 span {
		font-size: clamp(3.3rem, (100vw - 769px) * 12 / 310 + 33px, 4.5rem);
	}
	.business__content .business-card .business-card__text p {
		font-size: clamp(1.3rem, (100vw - 769px) * 5 / 310 + 13px, 1.8rem);
	}
	.business__content .business-card figure {
		max-width: 46.339203vw;
	}

}

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

	.business__content .title img {
		width: 32.9427083vw;
	}
	.business__content .business-card {
		justify-content: space-between;
		flex-direction: column;
		align-items: center;
		margin: 8vw auto;
		padding: 0;
	}
	.business__content .business-card:nth-of-type(even) {
		flex-direction: column;
	}
	.business__content .business-card::after {
		display: none;
	}
	.business__content .business-card .business-card__text {
		max-width: 66.8vw;
	}
	.business__content .business-card .business-card__text h3 {
		margin-bottom: 3.33333333vw;
		font-size: clamp(1.3rem, (100vw - 375px) * 13 / 393 + 13px, 26rem);
	}
	.business__content .business-card .business-card__text h3 span {
		font-size: clamp(2.3rem, (100vw - 375px) * 23.5 / 393 + 23px, 4.65rem);
	}
	.business__content .business-card .business-card__text p {
		margin-bottom: 2.66666666vw;
		font-size: clamp(1rem, (100vw - 375px) * 8.5 / 393 + 10px, 1.85rem);
	}
	.business__content .business-card figure {
		max-width: 66.8vw;
	}

}

/*================================================

　company

=================================================*/
.company {
	width: 100%;
	height: 108px;
	margin-bottom: 90px;
	background: url("../images/top/company_bg_pc_01.jpg") center center / 100% auto no-repeat; background-size: cover;
}
.company__content {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
}
.company__content a {
	position: relative;
	display: block;
}
.company__content a::before {
	position: absolute;
	content: '';
	top: 0;
	left: -47px;
	width: 39px;
	height: 39px;
	background: url("../images/top/company_icon_01.svg") center center / 100% auto no-repeat;
}

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

	.company {
		height: 14.4vw;
		margin-bottom: 12vw;
		background-image:  url("../images/top/company_bg_sp_01.jpg");
	}
	.company__content a {
		width: 50.1333333vw;
	}
	.company__content a::before {
		left: -6.26666666vw;
		width: 5.2vw;
		height: 5.2vw;
	}

}

/*================================================

　access

=================================================*/
.access {
	width: 100%;
	margin: 0 auto 70px;
	padding: 0;
}
.access__content {
	position: relative;
	max-width: 1105px;
	margin: auto;
	padding: 0;
}
.access__content .access-card {
	width: 480px;
	margin: 0 auto;
	padding: 0;
}
.access__content .access-card dl {
	padding: 0 40px;
}
.access__content .access-card dl dt {
	margin-bottom: 10px;
	font-size: 2.3rem;
	font-weight: 900;
}
.access__content .access-card dl  dd {
	margin-bottom: 20px;
	font-size: 1.8rem;
	line-height: 1.5;
}
.google-map {
	position: relative;
	margin: 0;
	padding-bottom: 78.75%;
	overflow: hidden;
}
.google-map iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

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

	.access {
		margin: 0 auto 9.33333333vw;
	}
	.access__content .title img {
		width: 10.9375vw;
	}
	.access__content .access-card {
		width: 70.4vw;
	}
	.access__content .access-card dl {
		padding: 0 3.33333333vw;
	}
	.access__content .access-card dl dt {
		margin-bottom: 1.33333333vw;
		font-size: clamp(1.4rem, (100vw - 375px) * 14 / 393 + 14px, 2.8rem);
	}
	.access__content .access-card dl  dd {
		margin-bottom: 4vw;
		font-size: clamp(1.1rem, (100vw - 375px) * 11 / 393 + 11px, 2.2rem);
	}

}

/*================================================

　parent

=================================================*/
.parent {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}
.parent__content {
	position: relative;
	max-width: 1105px;
	margin: auto;
	padding: 0;
}
.parent__content .parent-card {
	max-width: 1100px;
	margin: 40px auto 0;
	padding: 0 20px;
}

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

	.parent__content .title img {
		width: 27.8645833vw;
	}
	.parent__content .parent-card {
		margin: 5.333333333vw auto 0;
		padding: 0 2.66666666vw;
	}

}
