@charset "utf-8";
/*==================================================
	【サブ】ページ固有のスタイル
==================================================*/
#philosophy {
	margin-bottom: 30px;
}
#philosophy .box {
	width: 300px;
}
#philosophy .box .ico {
	text-align: center;
	width: 70px;
	height: 60px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 20px;
}
#philosophy .box .txt {
	text-align: center;
	font-size: 18px;
}
#philosophy h4 {
	color: #18bfa1;
	font-size: 24px;
	font-weight: normal;
}
#service .service .list {
	width: 686px;
}
#service .service .list ul li {
	width: 220px;
	font-size: 18px;
	padding-left: 30px;
	background: url("../img/service/ico-reef.png") no-repeat left top 5px;
	border-bottom: 3px solid #fff;
	padding-bottom: 20px;
	margin-bottom: 20px;
}
#service .service .list ul li:nth-of-type(even) {
	width: 434px;
}
#service .service .info {
	width: 362px;
}
#service .service .info dl:not(:last-of-type) {
	margin-bottom: 20px;
}
#service .service .info dl dt {
	font-size: 24px;
	color: #000;
	font-weight: 500;
}
#service .service .info dl dt span {
	width: 51px;
	text-align: center;
	display: inline-block;
	margin-right: 20px;
	position: relative;
	top: -10px;
}
#service .service .info dl:last-of-type dt span {
	top: -2px;
}
#service .service .info dl dd {
	padding-left: 72px;
	font-size: 17.2px;
}
#service .flow h4 {
	font-size: 45px;
	color: #18bfa1;
	margin-bottom: 50px;
}
#service .flow .box {
	width: 525px;
	border: 2px solid var(--color-primary);
	overflow: hidden;
	border-radius: 25px;
}
#service .flow .box dl dt {
	padding: 33px 0;
	text-align: center;
	font-size: 20px;
	color: #000;
	font-weight: bold;
	background: url("../img/bg-slash.png");
	position: relative;
}
#service .flow .box dl dt::before {
	position: absolute;
	content: "";
	left: 50%;
	bottom: -83px;
	margin-left: -56px;
	border: 56px solid transparent;
	border-top: 27px solid #fef098;
}
#service .flow .box dl dt.green {
	color: var(--color-green);
}
#service .flow .box dl dt .line {
	font-size: 35px;
	background: linear-gradient(transparent 70%, #fef098 70%) ;
}
#service .flow .box dl dd {
	padding: 50px 0 30px;
	text-align: center;
	line-height: 2;
	font-size: 18px;
}
#company .info .box {
	width: 530px;
}
#company .info .box dl {
	border-top: 3px solid #fff;
	font-size: 18px;
	display: flex;
	align-items: center;
	padding: 20px 0;
}
#company .info .box dl:last-of-type {
	border-bottom: 3px solid #fff;
}
#company .info .box dl dt {
	color: var(--color-green);
	width: 150px;
	padding-left: 20px;
}
#company .info .box dl dd {
	width: calc(100% - 150px);
}
#company .business {
	margin-bottom: 50px;
}
#company .business h4 {
	font-size: 45px;
	margin-bottom: 50px;
}
#company .business .box {
	width: 50%;
	font-size: 18px;
}
#company .business .box .ico {
	height: 48px;
	display: flex;
	justify-content: center;
	margin-bottom: 30px;
	align-items: center;
}
#company .business .box dl dt {
	font-size: 32px;
	text-align: center;
	font-weight: bold;
	color: var(--color-primary);
}
#company .business .box dl dd {
	text-align: center;
}
@media print, screen and (min-width: 769px){ /* PCのみ */
}
@media print, screen and (min-width: 641px){ /* PC・タブレット */
}
@media only screen and (max-width: 768px) and (min-width: 641px){ /* タブレットのみ */
}
@media only screen and (max-width: 768px) {  /* タブレット以下 */
	#philosophy .box {
		width: 33%;
	}
	#philosophy .box .ico {
		margin-bottom: 15px;
	}
	#philosophy .box .ico img {
		transform: scale(0.8	);
	}
	#philosophy .box .txt {
		font-size: 16px;
		text-align: left;
	}
	#philosophy .box .txt br {
		display: none;
	}
	#philosophy h4 {
		font-size: 22px;
	}
	#service .service .list {
		width: 100%;
		margin-bottom: 30px;
	}
	#service .service .list ul li, #service .service .list ul li:nth-of-type(even) {
		width: 49%;
		font-size: 110%;
		padding-bottom: 10px;
		margin-bottom: 15px;
	}
	#service .service .info {
		width: 100%;
		display: flex;
		align-items: flex-end;
	}
	#service .service .info dl:not(:last-of-type) {
		margin-right: 20px;
		margin-bottom: 0;
	}
	#service .service .info dl dt {
		font-size: 20px;
	}
	#service .service .info dl dt span {
		margin-right: 10px;
	}
	#service .service .info dl dd {
		padding-left: 62px;
	}
	#service .flow h4 {
		margin-bottom: 30px;
	}
	#service .flow .box {
		width: 49%;
	}
	#service .flow .box dl dd {
		padding: 30px 15px 15px;
		line-height: 1.8;
	}
	#service .flow h4 {
		font-size: 30px;
	}
	#service .flow .box dl dt {
		padding: 15px 0;
		font-size: 18px;
	}
	#service .flow .box dl dt::before {
		bottom: -46px;
		margin-left: -28px;
		border: 28px solid transparent;
		border-top: 18px solid #fef098;
	}
	#service .flow .box dl dt .line {
		font-size: 25px;
	}
	#service .flow .box dl dd {
		text-align: left;
		font-size: 110%;
	}
	#service .flow .box dl dd br {
		display: none;
	}
	#company .info .box {
		width: 100%;
	}
	#company .info .box:not(:first-of-type) dl:first-of-type {
		border-top: none;
	}
	#company .info .box dl {
		padding: 10px 0;
		font-size: 110%;
	}
	#company .business h4 {
		font-size: 30px;
		margin-bottom: 30px;
	}
	#company .business .box {
		width: 49%;
		font-size: 110%;
	}
	#company .business .box .ico {
		margin-bottom: 15px;
	}
	#company .business .box .txt {
		text-align: left;
	}
	#company .business .box .txt br {
		display: none;
	}
	#company .business .box dl dt {
		font-size: 23px;
		margin-bottom: 15px;
	}
}
@media only screen and (max-width: 640px){ /* スマホ */
	#philosophy .box {
		width: 100%;
		margin-bottom: 30px;
	}
	#philosophy .box:last-of-type {
		margin-bottom: 0;
	}
	#philosophy .box .ico {
		margin-bottom: 5px;
	}
	#philosophy h4 {
		font-size: 20px;
	}
	#service .service .list ul li, #service .service .list ul li:nth-of-type(even) {
		width: 100%;
	}
	#service .service .info {
		display: block;
	}
	#service .service .info dl dt span {
		width: 45px;
	}
	#service .service .info dl:last-of-type dt span {
		top: 3px;
	}
	#service .service .info dl dd {
		padding-left: 55px;
		font-size: 110%;
	}
	#service .flow h4 {
		font-size: 25px;
	}
	#service .flow .box {
		width: 100%;
		margin-bottom: 20px;
	}
	#service .flow .box:last-of-type {
		margin-bottom: 0;
	}
	#company .info .box dl {
		display: block;
	}
	#company .info .box dl dt {
		padding-left: 0;
	}
	#company .info .box dl dd {
		width: 100%;
	}
	#company .business h4 {
		font-size: 25px;
	}
	#company .business .box {
		width: 100%;
		margin-bottom: 30px;
	}
	#company .business .box:last-of-type {
		margin-bottom: 0;
	}
	#company .business .box dl dt {
		font-size: 20px;
	}
}