@charset "UTF-8";
figure {
	text-align: center;
	margin-bottom: 0px;
}
ul {
	list-style: none;
}
.mv {
	background-image: -moz-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
	background-image: -webkit-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
	background-image: -ms-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
	
}
.mv_area {
	background-image:  url(mv.png);
	background-position: right 15% bottom;
	background-size: 40%;
	background-repeat: no-repeat;
	padding: 120px 0 220px 0;
}

.mv h1 {
	color: #fff;
	font-size: 52px;
	font-style: italic;
	line-height: 64px;
	font-weight: bold;
	letter-spacing: 0.2rem;
	padding: 0 0 40px 0;
}
.mv_ttl p {
	font-size: 20px;
	color: #fff;
}
#intro {
	padding: 80px 0;
}
#intro figure img {
	width: 262px;
}
#intro p {
	font-size: 20px;
	line-height: 2.0;
	text-align: center;
	color: #343434;
	margin-top: 50px;
	font-weight: bold;
}
#service {
	background-color: #64b4f0;
	padding: 80px 0;
	color: #fff;
}
#service h2 {
	color: #fff;
	font-size: 42px;
}
.service_intro {
	padding: 40px 0;
}
.service_intro b {
	display: block;
	text-align: center;
	font-size: 28px;
	color: #fff;
}
.service_intro figure img {
	width: 490px;
	margin: 40px 0 40px 0;
}
.service_intro p {
	text-align: center;
	font-size: 22px;
	line-height: 1.5;
}
ul.chart_list {
	width: 696px;
	margin: 80px auto 40px auto;
}
ul.chart_list li {
	color: #fff;
	text-align: center;
	font-size: 22px;
	font-weight: bold;
	background-color: #147bab;
	padding: 12px 0;
	margin-bottom: 50px;
	width: 100%;
	position: relative;
}
ul.chart_list li::after {
	content: "";
	width: 40px;
	position: absolute;
    left: 0;
    right: 0;
    margin: auto;
    bottom: -32px;
    border-style: solid;
    border-width: 12px 20px 0 20px;
    border-color: #147bab transparent transparent transparent;
}
ul.chart_list li span {
	padding-right: 20px;
}
ul.chart_list li:last-child::after {
	display: none;
}
.service_sample h3 {
	text-align: center;
	margin-bottom: 40px;
}
.service_list {
	margin-bottom: 60px;
}
.service_list p {
	text-align: center;
	margin-bottom: 40px;
}
.service_list p span {
	background-color: #fff;
	color: #64b4f0;
	font-size: 20px;
	padding: 2px 8px;
}
.service_list ul li {
	width: 33%;
}
.service_list ul li img{ 
	width: 200px;
	padding-bottom: 10px;
}
p.explain {
	text-align: center;
	margin: 0;
}
#price {
	padding: 80px 0 60px 0;
}
#price table {
	width: 772px;
	margin: 40px auto;
	box-shadow: 0px 9px 16px 0px rgba(0, 0, 0, 0.07);
}
#price table tr td {
	text-align: center;
	padding: 10px 0;
	font-size: 18px;
	font-weight: bold;
}
#price table tr:nth-child(odd) {
	background-color: #f7f7f7;
}
#price table tr:nth-child(1) {
	background-color: #31a5fe;
}
#price table tr:nth-child(even) {
	background-color: #dcdcdc;
}
#price table tr:nth-child(4) {
	background-color: #dcdcdc;
}
#price table tr:nth-child(5) {
	background-color: #f7f7f7;
}
#price table tr:nth-child(1) td {
	color: #fff;
	text-align: center;
}
#price table tr td:nth-of-type(1) {
	width: 20%;
}
#price table tr td:nth-of-type(2) {
	width: 54%;
}
#price table tr td:nth-of-type(3) {
	width: 26%;
}
#price table tr td:nth-child(2){
	border-right: 2px solid #fff;
	border-left: 2px solid #fff;
	text-align: left;
	box-sizing: border-box;
	padding-left: 20px;
}
#price table tr:nth-child(1) td {
	border-left: none;
}
#flow {
	background-image: -moz-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
  background-image: -webkit-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
  background-image: -ms-linear-gradient( 168deg, rgb(8,163,216) 6%, rgb(8,108,216) 100%);
}
#price p {
	text-align: center;
	color: #ff3b65;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.8;
	margin-bottom: 40px;
}
#price ul li {
	font-size: 16px;
	font-weight: bold;
	color: #313131;
	width: 690px;
	margin: 0 auto 4px auto;
	text-indent: -1rem;
	padding-left: 1rem;
}
#flow h2.flow_ttl:after,
#flow h2.flow_ttl:before {
	display: none;
}
@media screen and (max-width: 767px) {
	.mv h1 {
		font-size: 32px;
		line-height: 1.5;
		padding: 0 0 20px 0;
	}
	.mv_area .container figure img {
		width: 50%;
	}
	.mv {
		padding: 0;
	}
	.mv_area {
		width: 100%;
		overflow: hidden;
		padding: 30px 0 190px 0;
		background-size: 60%;
	}
	.mv_area::before {
		left: -10%;
		width: 70%;
	}
	.mv_area figure {
		text-align: right;
	}

	.solution {
		width: 100%;
	}
	.solution p {
		font-size: 18px;
	}
	.what_intro p {
		font-size: 16px;
	}
	#price table,
	#price p,
	#price ul li {
		width: 100%;
	}

	#service {
		padding: 40px 0 60px 0;
	}
	#price table tr td {
		font-size: 14px;
	}
	#flow ul li figure:after {
		bottom: -160%;
	}
	#flow ul li:nth-child(2) figure:after {
		bottom: -160%;
	}
	#flow ul li:nth-child(3) figure:after {
		bottom: -160%;
	}
	#intro figure img {
		width: 160px;
	}
	#intro p {
		font-size: 16px;
	}
	h2.ttl_only,
	#service h2 {
		font-size: 2rem;
	}
	.service_intro b {
		font-size: 18px;
	}
	.service_intro figure img {
		width: 100%;
	}
	.service_intro p {
		font-size: 16px;
	}
	ul.chart_list {
		width: 100%;
	}
	ul.chart_list li {
		font-size: 16px;
		line-height: 1.8;
	}
	.service_sample h3 {
		font-size: 20px;
	}
	.service_list ul li {
		width: 45%;
	}
	.service_list ul li img {
		width: 100%;
	}
	.service_list {
		margin-bottom: 0;
	}
	#price table tr td:nth-of-type(1) {
		width: 25%;
	}
	#price table tr td:nth-child(2) {
		padding: 10px ;
	}
	#intro {
		padding: 40px 0;
	}
	.service_intro {
		padding: 20px 0;
	}
	#price {
		padding: 40px 0;
	}
	#flow {
		padding: 40px 0;
	}
}


