
div.mainimg {
	background: url(images/top_mainimg_bg.jpg) no-repeat center top;
	height: 740px;
}

div.mainimg div {
	margin: 0 auto;
	padding-top: 40px;
	text-align: right;
	width: 900px;
}

div.mainimg h1 {
	margin: -15px 0 50px 0;
}

div.servicebg {
	background: url(images/top_service_bgillust.png) no-repeat center bottom;
}

ul.service {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

ul.service li {
	background-color: white;
	background-position: center top 10px;
	background-repeat: no-repeat;
	background-size: 200px;
	border-radius: 20px;
	margin: 20px 10px;
	padding: 160px 30px 20px 30px;
	width: 340px;
}

ul.service li:nth-child(1) {
	background-image: url(images/top_service01@2x.jpg);
}

ul.service li:nth-child(2) {
	background-image: url(images/top_service02@2x.jpg);
}

ul.service li:nth-child(3) {
	background-image: url(images/top_service03@2x.jpg);
}

ul.service li:nth-child(4) {
	background-image: url(images/top_service04@2x.jpg);
}

ul.service li:nth-child(5) {
	background-image: url(images/top_service05@2x.jpg);
}

ul.service li h3 {
	background: url(images/top_service_line.png) no-repeat center bottom;
	color: #3b7bb3;
	display: table-cell;
	font-size: 25px;
	height: 90px;
	line-height: 1.3em;
	padding-bottom: 20px;
	vertical-align: middle;
	width: 280px;
}

ul.service li div.text {
	padding: 5px 10px 0 10px;
}

ul.service li div.text p {
	font-weight: 500;
}

ul.fees {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

ul.fees li {
	background: url(images/top_fees_libg.jpg);
	border-radius: 20px;
	color: white;
	padding: 20px 40px;
	width: 540px;
}

ul.fees li h3 {
	border-bottom: 2px solid white;
	font-size: 24px;
	font-weight: 400;
	margin: 0 -20px 20px -20px;
	padding-bottom: 10px;
}

ul.qa li {
	margin: 20px 0;
	padding: 30px;
}

ul.qa li h3 {
	font-size: 24px;
	padding-left: 20px;
	text-align: justify;
}

ul.qa li h3 em {
	background: url(images/top_qa_qbg.jpg);
	border-radius: 50%;
	color: white;
	display: inline-block;
	font-weight: 400;
	height: 50px;
	margin-right: 20px;
	padding-top: 5px;
	text-align: center;
	width: 50px;
}

ul.qa li div.answer {
	background-color: rgba(255,255,255,.8);
	border-radius: 20px;
	margin-top: 20px;
	padding: 20px;
}

ul.qa li div.answer h4 {
	background: url(images/top_qa_line.png) no-repeat center bottom;
	color: #3b7bb3;
	font-size: 24px;
	padding: 20px 0 10px 100px;
	position: relative;
	text-align: justify;
}

ul.qa li div.answer h4::before {
	content: "A";
	font-size: 36px;
	font-weight: 400;
	left: 50px;
	margin-right: 10px;
	position: absolute;
	top: 10px;
}

ul.qa li div.answer div.text {
	padding: 10px 50px;
}

div.profile-line {
	background-image: url(images/top_profile_line.png),
	url(images/top_profile_line.png);
	background-position: center top,
	center bottom;
	background-repeat: no-repeat;
	background-size: 100%, 100%;
}

div.profile {
	background: url(images/top_profile_illust@2x.jpg) no-repeat right 30px top 50px;
	background-size: 220px;
	padding: 80px 0 20px 0;
}

div.profile div.photo {
	float: left;
	width: 420px;
}

div.profile div.text {
	float: right;
	padding-top: 50px;
	width: 670px;
}

div.profile div.text h3 ruby {
	ruby-position: under;
}

div.profile div.text h3 {
	font-size: 18px;
	padding-bottom: 20px;
	text-align: justify;
}

div.profile div.text h3 em {
	font-size: 24px;
}

div.profile div.text div.qualification {
	border: 3px solid #f9d7d7;
	border-radius: 10px;
	display: inline-block;
	width: auto;
}

div.profile div.text div.qualification h4 {
	background-color: #f3b2b3;
	color: white;
}

div.profile div.text div.qualification ul {
	line-height: 1.5em;
	padding: 10px 50px 10px 30px;
}

div.profile div.text div.qualification ul li {
	background: url(images/ul_list_li_pink.svg) no-repeat left 32px top 9px;
	background-size: 8px;
	border-bottom: 1px solid #f3b2b3;
	padding: 2px 60px 2px 50px;
}

div.profile div.text div.qualification ul li:first-child {
	border-top: 1px solid #f3b2b3;
}