@charset "utf-8";
/* CSS Document */

main section h2:before {
	background: #005596;
}

aside h4:before {
	content: "\e900";
	vertical-align: middle;
}
aside .btn a {
	color: #ffffff;
	background: #005596;
}
aside .flow a:before {
	color: #005596;
}
aside .flow a:after {
	color: #005596;
}

main #strength section.block01 .text {
	color: #ffffff;
	background: #005596;
}
main #strength section .flow {
	color: #ffffff;
}
main #strength section .flow ul {
	display: -webkit-flex;
	display: flex;
	background: #005596;
}
main #strength section .flow ul li:last-child:after {
	display: none;
}
main #strength section .flow ul li {
	position: relative;
}
main #strength section .flow ul li:after {
	position: absolute;
	color: #578fba;
}
main #strength section .flow ul li strong {
	display: block;
}

span.notes {
	color: #005596;
	font-weight: bold;
}
.notes li:before {
	color: #005596;
}

@media screen and (min-width: 768px) {
	aside .inner {
		border: 20px solid #005596;
	}
	aside h4:before {
		font-size: 4.0rem;
	}
	aside .btn {
		margin: 0;
	}
	aside .btn a:hover {
		color: #005596;
	}
	aside .btn a:hover:after {
		color: #005596;
	}
	aside .tel {
		width: 290px;
		margin-left: 40px;
		font-size: 2.0rem;
	}
	aside .tel strong {
		color: #005596;
		font-size: 3.4rem;
	}
	aside .tel span {
		font-size: 1.8rem;
	}
	main nav a:hover {
		color: #005596;
	}
	main nav a:hover:after {
		color: #005596;
	}
	.panel li a:hover .img:after {
		box-shadow: inset 0 0 0 10px #005596;
	}
	.panel li a:hover .title {
		color: #005596;
	}

	main #strength section.block02 .img {
		padding: 100px 0 100px 95px;
	}
	main #strength section.block02 .img img {
		max-width: none;
		width: 405px;
	}
	main #strength section.block04 {
		margin-top: 0;
	}
	main #strength section.block04 .img {
		padding: 110px 40px 100px 0;
	}
	main #strength section .flow {
		max-width: 1120px;
		width: 100%;
		margin: 40px auto 0  auto;
	}
	main #strength section .flow ul li {
		width: 244px;
		padding: 40px 50px 25px 30px;
		font-size: 1.4rem;
		line-height: 1.85;
	}
	main #strength section .flow ul li:last-child {
		width: 224px;
		padding-right: 30px;
	}
	main #strength section .flow ul li:after {
		content: "\e91a";
		top: 110px;
		right: 0;
		font-size: 5.3rem;
	}
	main #strength section .flow ul li strong {
		height: 70px;
		font-size: 2.4rem;
		line-height: 1.25;
	}

}

@media screen and (min-width: 1460px) {
	main #strength section.block04 .img {
		padding: 110px 80px 100px 0;
	}
	main #strength section .flow {
		max-width: 1200px;
	}
}


@media screen and (max-width: 767px) {
	aside .inner {
		border: 3.2vw solid #005596;
	}
	aside h4:before {
		font-size: 9vw;
	}
	aside .btn a {
		padding: 6vw 8vw;
	}
	aside .tel strong {
		color: #005596;
	}
	main #strength section.block02 .img,
	main #strength section.block04 .img {
		padding: 0 6.25vw 6.25vw 6.25vw;
	}
	main #strength section.block04 {
		margin-top: 0;
	}
	main #strength section.block05 {
		-webkit-flex-direction: column-reverse;
		flex-direction: column-reverse;
	}
	main #strength section.block03 .text {
		-webkit-order: 1;
		order: 1;
	}
	main #strength section.block03 .img {
		-webkit-order: 2;
		order: 2;
		padding: 0 0 6.25vw 0;
	}
	main #strength section .flow {
		-webkit-order: 3;
		order: 3;
		padding: 0 6.25vw;
	}
	main #strength section .flow ul {
		-webkit-flex-direction: column;
		flex-direction: column;
		margin: 0;
		padding: 6.25vw;
	}
	main #strength section .flow ul li {
		padding-bottom: 17.5vw;
		font-size: 4.3vw;
		line-height: 1.75;
	}
	main #strength section .flow ul li:last-child {
		padding-bottom: 0;
	}
	main #strength section .flow ul li:after {
		content: "\e91b";
		display: block;
		bottom: 6.25vw;
		left: 0;
		width: 100%;
		font-size: 15.6vw;
		text-align: center;
	}
	main #strength section .flow ul li strong {
		margin-bottom: 1.5vw;
		font-size: 5.6vw;
		text-align: center;
		line-height: 1.25;
	}
}


.flowCol h3 {
	display: block;
	height: auto;
	margin: 0 0 0.15em 0;
	padding: 0;
	line-height: 1.4;
	border: 0;
}
.flowCol h3:before {
	display: none;
}
.flowCol h3 span {
	color: #005596;
	font-size: 1.1em;
}
.flowCol:after {
	content: "";
	display: block;
	width: 100%;
	height: 0;
	padding-top: calc(180 / 960 * 100%);
	background: url(../images/bg_flow_client.png) center center no-repeat;
	background-size: contain;
}
.flowCol.last {
	margin-bottom: 80px;
}
.flowCol.last:after {
	display: none;
}
@media screen and (min-width: 768px) {
	.flowCol h3 span {
		display: block;
	}
}
@media screen and (max-width: 767px) {
	.flowCol:after {
		padding-top: calc(300 / 960 * 100%);
	}
	.flowCol h3 {
		margin-bottom: 0.5em;
	}
}