@charset "UTF-8";
/*-------------------------------------
	共通スタイル
-------------------------------------*/
body {
	color: #2C3E50;
	font-size: 14px;
	font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;
	text-align: center;
	-webkit-text-size-adjust: none;
}

a:link {
	color: #9C1B27;
}

a:visited {
	color: #9C1B27;
}

a:active {
	color: #9C1B27;
}

a:hover {
	text-decoration: none;
}

a:hover img {
	opacity: 0.7;
}
img {
	max-width: 100%;
	height: auto;
}
.marginT20 {
	margin-top: 20px;
}


/*-------------------------------------
	見出し
-------------------------------------*/
h1.page-title {
	margin-bottom: 20px;
	padding: 70px 0 50px;
	width: 100%;
	background: url(/img/bg_service-area.jpg) no-repeat center -40px;
	background-size: cover;
	font-size: 40px;
	font-weight: bold;
}

h1.page-title span {
	display: block;
	font-size: 12px;
	color: #9C1B27;
}

#conts .ttl02 {
	margin-top: 50px;
	margin-bottom: 35px;
	padding-bottom: 22px;
	border-bottom: 2px solid #0F2955;
	color: #0F2955;
	font-size: 34px;
	font-weight: bold;
}

#conts .ttl02:first-child {
	margin-top: 0;
}

#conts .ttl03 {
	margin: 25px 0;
	padding: 15px 20px;
	background: #DDD;
	color: #0F2955;
	font-size: 26px;
	font-weight: bold;
}

#conts .ttl04 {
	margin: 15px 0;
	padding: 6px 15px;
	border-left: 3px solid #0F2955;
	color: #333;
	font-size: 22px;
	font-weight: bold;
}

@media only screen and (max-width: 736px) {
	h1.page-title {
		margin-bottom: 30px;
		padding: 45px 10px 35px;
		background: url(/img/bg_service-area.jpg) no-repeat center top;
		background-size: cover;
		font-size: 30px;
		box-sizing: border-box;
	}

	#conts .ttl02 {
		margin-bottom: 20px;
		padding-bottom: 16px;
		font-size: 26px;
	}

	#conts .ttl03 {
		margin-bottom: 15px;
		font-size: 24px;
	}

	#conts .ttl04 {
		margin-bottom: 12px;
		padding: 6px 15px;
		font-size: 18px;
		font-weight: bold;
	}

}

#conts p {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.7;
}

#conts .notes li {
	margin-bottom: 10px;
	text-indent: -1em;
	padding-left: 1em;
}


/*-------------------------------------
	ボタン
-------------------------------------*/

#conts .btnList li {
	margin-right: 15px;
	float: left;
}

#conts .btnList li:last-child {
	margin-right: 0;
}

#conts .btn a {
	display: inline-block;
	font-size: 14px;
}

#conts .btn01 a {
	padding: 12px 0;
	width: 240px;
	border: 1px solid #9C1B27;
	background: #FFF;
	color: #9C1B27;
	text-align: center;
	text-decoration: none;
	position: relative;
}

#conts .btn01 a:hover {
	background: #9C1B27;
	color: #FFF;
}

#conts .btn01 a:after {
	margin-top: -7px;
	content: "";
	width: 15px;
	height: 15px;
	background: url(/img/icon_link-arrow03.png) no-repeat;
	position: absolute;
	top: 50%;
	right: 15px;
}

#conts .btn01 a:hover:after {
	background: url(/img/icon_link-arrow02.png) no-repeat;
}

@media only screen and (max-width: 736px) {
	#conts .btn01 a {
		width: 100%;
	}

	#conts .btnList li {
		margin-right: 0;
		margin-bottom: 10px;
		float: none;
	}
}


/*-------------------------------------
	PC・SP　改行振り分け
-------------------------------------*/
.sp {
	display: none;
}

.pc {
	display: block;
}

br.sp {
	display: none!important;
}

br.pc {
	display: inline!important;
}

@media only screen and (max-width: 736px) {
	.sp {
		display: block;
	}
	.pc {
		display: none;
	}
	br.sp {
		display: inline!important;
	}
	br.pc {
		display: none!important;
	}
}

/*-------------------------------------
	dl
-------------------------------------*/
#conts .com-dl01 {
	border-top: 1px dashed #CCC;
}

#conts .com-dl01 dt,
#conts .com-dl01 dd {
	padding: 25px 10px;
	font-size: 16px;
}

#conts .com-dl01 dt {
	width: 140px;
	float: left;
	clear: left;
	font-weight: bold;
}

#conts .com-dl01 dd {
	border-bottom: 1px dashed #CCC;
	padding-left: 170px;
}

@media only screen and (max-width: 736px) {
	#conts .com-dl01 {
		border: none;
	}
	#conts .com-dl01 dt,
	#conts .com-dl01 dd {
		padding: 10px 0;
	}
	#conts .com-dl01 dt {
		width: 100%;
		box-sizing: border-box;
		float: none;
		border-bottom: 1px dashed #0F2955;
		font-weight: bold;
	}
	#conts .com-dl01 dd {
		border-bottom: none;
	}
}

#conts .qaList {
	padding-top: 30px;
}

#conts .qaList dd,
#conts .qaList dt {
}

#conts .qaList dt {
	margin-bottom: 2px;
	padding: 15px 20px;
	border-left: 4px solid #9C1B27;
	color: #9C1B27;
	font-size: 18px;
	font-weight: bold;
}

#conts .qaList dd {
	margin-bottom: 30px;
	padding: 15px 20px;
	border-left: 4px solid #0F2955;
	font-size: 16px;
}

/*-------------------------------------
	table
-------------------------------------*/
#conts .com-table01 {
	margin-bottom: 30px;
	width: 100%;
	border-collapse: collapse;
	font-size: 15px;
}

#conts .com-table01 th,
#conts .com-table01 td {
	padding: 25px 15px;
	border: 2px solid #FFF;
	text-align: left;
}

#conts .com-table01 th {
	background: #0F2955;
	color: #FFF;
	font-weight: bold;
	text-align: center;
}

#conts .com-table01 td {
	background: #DFDFDF;
}

#conts .com-table01 td.price {
	color: #9C1B27;
	font-size: 22px;
	font-weight: bold;
	text-align: center;
}

#conts .name-image {
	float: right;
}

@media only screen and (max-width: 736px) {
	#conts .com-table01 {
		font-size: 14px;
	}
	#conts .com-table01 th,
	#conts .com-table01 td {
		padding: 20px 10px;
	}
	#conts .com-table01 td.price {
		font-size: 14px;
		white-space: nowrap;
	}
}

/*-------------------------------------
	header
-------------------------------------*/
#g-header {
	background: #FFF;
}

#g-header .inner {
	margin: 0 auto;
	padding: 0;
	width: 960px;
	min-height: 95px;
}

#g-header .logo {
	margin-top: 35px;
	float: left;
}

#g-header .logo a img {
	display: block;
}

@media only screen and (max-width: 736px) {
	#g-header {
		position: relative;
		z-index: 99;
	}

	#g-header .inner {
		padding: 15px;
		width: 100%;
		box-sizing: border-box;
		min-height: 0;
	}

	#g-header .contact {
		padding-right: 50px;
	}

	#g-header .logo {
		margin: 5px 0;
	}
	
	#g-header .logo img {
		width: 60%;
		height: auto;
	}

}

/*-------------------------------------
	g-nav
-------------------------------------*/
#g-header .g-nav {
	float: right;
}

#g-header .g-nav ul {
}

#g-header .g-nav li {
	float: left;
	position: relative;
}

#g-header .g-nav li a {
	padding: 40px 15px;
	display: block;
	color: #0F2955;
	font-size: 14px;
	text-decoration: none;
}

#g-header .g-nav li a:hover {
	background: rgba(15,41,85,0.1);
}

#g-header .g-nav li .sub {
	position: absolute;
	top: 100px;
	left: 0;
}

#g-header .g-nav li .sub li {
	float: none;
  overflow: hidden;
  height: 0;
  transition: .2s;
}

#g-header .g-nav li .sub li a {
	width: 200px;
	padding: 10px 15px;
	background: rgba(15,41,85,0.8);
	color: #FFF;
	text-align: left;
}

#g-header .g-nav li .sub li a:hover {
	background: rgba(15,41,85,0.95);
}

#g-header .g-nav li:hover .sub li{
	overflow: visible;
	height: 40px;
}

@media only screen and (max-width: 736px) {
	#g-header .g-nav {
		display: none;
		width: 100%;
		float: none;
		position: absolute;
		top: 63px;
		left: 0;
		z-index: 9999;
	}

	#g-header .g-nav ul li {
		float: none;
		border-top: 1px solid rgba(255,255,255,0.8);
		background: rgba(15,41,85,0.9);
		width: 100%;
	}

	#g-header .g-nav ul li a {
		padding: 20px 0;
		color: #FFF;
		font-size: 16px;
		font-weight: bold;
		display: block;
		width: 100%;
	}

	#g-header .sp {
		position: absolute;
		top: 20px;
		right: 20px;
	}

	#g-header .sp .menu-trigger,
	#g-header .sp .menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	#g-header .sp .menu-trigger {
		position: relative;
		width: 20px;
		height: 20px;
	}
	#g-header .sp .menu-trigger span {
		position: absolute;
		left: 0;
		width: 100%;
		height: 2px;
		background-color: #0F2955;
		border-radius: 2px;
	}
	#g-header .sp .menu-trigger span:nth-of-type(1) {
		top: 0;
	}
	#g-header .sp .menu-trigger span:nth-of-type(2) {
		top: 9px;
	}
	#g-header .sp .menu-trigger span:nth-of-type(3) {
		bottom: 0;
	}
	#g-header .sp .menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(9px) rotate(-45deg);
		transform: translateY(9px) rotate(-45deg);
	}
	#g-header .sp .menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	#g-header .sp .menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-9px) rotate(45deg);
		transform: translateY(-9px) rotate(45deg);
	}

	#g-header .contact {
		padding-right: 40px;
	}

	#g-header .g-nav li .sub {
		display: none;
	}
}

/*-------------------------------------
	main-image
-------------------------------------*/
.main-image {
	padding-top: 70px;
	width: 100%;
	height: 310px;
	background: url(/img/main-image.jpg) no-repeat center bottom;
	background-size: cover;
	text-align: center;
}

.main-image .copy {
	margin-bottom: 20px;
	font-size: 50px;
	line-height: 1;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 300;
	animation: fadeIn 2s linear 0s 1;
	-webkit-animation: fadeIn 2s linear 0s 1;
}

.main-image .lead {
	text-shadow: 1px 1px 0 #B3E2FA;
}

@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@media only screen and (max-width: 736px) {
	.main-image {
		padding: 50px 0 70px;
		width: 100%;
		height: auto;
		background: url(/img/main-image.jpg) no-repeat left top;
		background-size: cover;
		text-align: center;
	}
	.main-image .copy {
		margin-bottom: 25px;
		font-size: 36px;
		line-height: 1;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 200;
		animation: fadeIn 2s linear 0s 1;
		-webkit-animation: fadeIn 2s linear 0s 1;
	}

	.main-image .lead {
		padding: 0 30px;
		text-shadow: 1px 1px 0 #B3E2FA;
	}

}

/*-------------------------------------
	パンくず
-------------------------------------*/
.page-navi {
	margin: 0 auto 40px;
	width: 960px;
	text-align: left;
}
.page-navi li {
	display: inline!important;
}

@media only screen and (max-width: 736px) {
	.page-navi {
		padding: 0 20px;
		width: 100%;
		font-size: 12px;
		box-sizing: border-box;
	}
}

/*-------------------------------------
	conts
-------------------------------------*/
#conts {
	margin: 0 auto;
	padding-bottom: 70px;
	width: 960px;
	text-align: left;
}

#index #conts {
	margin: 0;
	width: 100%;
}

#conts .box {
	padding: 60px 0;
	border-bottom: 1px solid #CCC;
}

#conts .box:last-child {
	border-bottom: none;
}

#conts .box .inner {
	margin: 0 auto;
	width: 960px;
}


@media only screen and (max-width: 736px) {
	#conts {
		margin: 0;
		padding: 0 20px 70px;
		width: 100%;
		text-align: left;
		box-sizing: border-box;
	}

	#index #conts {
		padding: 0;
	}

	#conts .box .inner {
		padding: 0 20px;
		width: 100%;
		box-sizing: border-box;
	}
}

/*-------------------------------------
	service-area
-------------------------------------*/
#index #conts .service-area {
	width: 100%;
	background: url(/img/bg_service-area.jpg) no-repeat center top;
	background-size: cover;
}

#conts .service-area .service-list li {
	position: relative;
	margin-bottom: 30px;
}

#conts .service-area .service-list li:nth-child(4),
#conts .service-area .service-list li:nth-child(5),
#conts .service-area .service-list li:nth-child(6) {
	margin-bottom: 0;
}

#conts .service-area .service-list li:after {
	content: "";
	width: 15px;
	height: 15px;
	background: url(/img/icon_link-arrow02.png);
	position: absolute;
	bottom: 10px;
	right: 10px;
}

#conts .service-area .service-list li a {
	padding: 30px;
	display: block;
	background:-webkit-gradient(linear, left top, right bottom, color-stop(0.5, #153A77), color-stop(0.5, #0F2955), color-stop(1, #0F2955));
	background:-webkit-linear-gradient(left top, #153A77 50%, #0F2955 50%);
	background:-moz-linear-gradient(left top, #153A77 50%, #0F2955 50%);
	background:-o-linear-gradient(left top, #153A77 50%, #0F2955 50%);
	background:linear-gradient(to right bottom, #153A77 50%, #0F2955 50%);
	color: #FFF;
	text-decoration: none;
	text-align: center;
	position: relative;
}

#conts .service-area .service-list li a:after {
	content: "";
	position: absolute;
	border-top: 27px solid transparent;
	border-left: 27px solid transparent;
	border-right: 27px solid #9C1B27;
	border-bottom: 27px solid #9C1B27;
	bottom: 0;
	right: 0;
}

#conts .service-area .service-list li a:hover {
	opacity: 0.8;
}

#conts .service-area .service-list li h3 {
	margin: 25px 0;
	font-size: 20px;
	line-height: 1;
}

#conts .service-area .service-list li p {
	margin-bottom: 0;
	font-size: 14px;
	text-align: left;
}

@media only screen and (max-width: 736px) {
	#conts .service-area .service-list li:nth-child(4),
	#conts .service-area .service-list li:nth-child(5),
	#conts .service-area .service-list li:nth-child(6) {
		margin-bottom: 30px;
	}
}



/*-------------------------------------
	voice-area
-------------------------------------*/
#conts .voice-area {
	width: 100%;
	background: url(/img/bg_mind-area.jpg) no-repeat center top;
	background-size: cover;
}

#conts .voice-area .lead span {
	font-size: 24px;
}

#conts .voice-area .voice-list {
	margin-bottom: 40px;
}

#conts .voice-area .voice-list li a {
	color: #333;
	text-decoration: none;
}

#conts .voice-area .voice-list li a:hover .detail {
	background: #DCAFB4;
}

#conts .voice-area .voice-list li .detail {
	padding: 20px;
	background: #FFF;
	text-align: left;
}

#conts .voice-area .voice-list li img {
	display: block;
}

#conts .voice-area .voice-list li .tag {
	margin-bottom: 10px;
	padding: 0 10px;
	background: #9C1B27;
	color: #FFF;
	font-size: 11px;
	display: inline-block;
}

#conts .voice-area .voice-list li .company {
	margin-bottom: 8px;
	font-size: 20px;
}

#conts .voice-area .voice-list li .text {
	margin-bottom: 0;
	font-size: 14px;
	line-height: 1.2;
}

@media only screen and (max-width: 736px) {
	#conts .voice-area .voice-list li img {
		width: 100%;
	}
}


/*-------------------------------------
	objective-area
-------------------------------------*/
#conts .objective-list li {
	text-align: left;
}

#conts .objective-list li .imgL {
	float: left;
	margin-right: 20px;
}

#conts .objective-list li .ttl {
	margin-bottom: 5px;
	color: #0F2955;
	font-size: 20px;
	font-weight: bold;
}

#conts .objective-list li .text {
	margin-bottom: 0;
	font-size: 14px;
	line-height: 1.6;
	overflow: hidden;
}
	

/*-------------------------------------
	info-area
-------------------------------------*/
#conts .info-list {
	margin-bottom: 25px;
	border-top: 1px solid #DBDFE8;
	text-align: left;
}

#conts .info-list dt {
	padding: 23px 0 10px;
	color: #333;
	font-size: 14px;
	font-weight: bold;
}

#conts .info-list dt span {
	margin-right: 10px;
	padding: 5px 10px;
	background: #DBDFE8;
	border-radius: 3px;
	display: inline-block;
	color: #0B2A63;
	font-size: 12px;
	font-weight: bold;
	line-height: 1;
}

#conts .info-list dd {
	padding-bottom: 20px;
	border-bottom: 1px solid #DBDFE8;
	font-size: 16px;
	width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

#conts .info-list dd a {
	color: #0B2A63;
	text-shadow: none;
}

#conts .info-list dd a:hover {
	text-decoration: underline;
}

@media only screen and (max-width: 736px) {
	#conts .info-area .col2 li:first-child {
		padding-bottom: 30px;
		border-bottom: 1px dashed #EEE;
	}
}


/*-------------------------------------
	about-area
-------------------------------------*/

#conts .about-area {
	width: 100%;
	background: url(/img/bg_about.jpg) no-repeat center bottom;
	background-size: cover;
}

#conts .about-area h2 {
	color: #FFF!important;
}

#conts .about-area h2:before,
#conts .about-area h2:after {
	display: none;
}

#conts .about-area .lead {
	color: #FFF;
	font-size: 20px;
}

@media only screen and (max-width: 736px) {
	#conts .about-area .lead {
		color: #FFF;
		font-size: 16px;
		line-height: 1.4;
	}
}

/*-------------------------------------
	column
-------------------------------------*/
/*---カラム共通---*/

/*---2カラム---*/
#conts .col2 li {
	margin-right: 30px;
	width: 465px;
	float: left;
}

#conts .col2 li:nth-child(2n) {
	margin-right: 0;
}

/*---3カラム---*/
#conts .col3 li {
	margin-right: 30px;
	width: 300px;
	float: left;
}

#conts .col3 li:nth-child(3n) {
	margin-right: 0;
}

#g-footer .col3 li {
	margin-right: 30px;
	width: 300px;
	float: left;
}

#g-footer .col3 li:nth-child(3n) {
	margin-right: 0;
}

/*---4カラム---*/
#conts .col4 li {
	margin-right: 30px;
	width: 217px;
	float: left;
}

#conts .col4 li:nth-child(4n) {
	margin-right: 0;
}

/*---6カラム---*/
#conts .col6 li {
	margin-right: 15px;
	width: 147px;
	float: left;
}

#conts .col6 li:nth-child(6n) {
	margin-right: 0;
}

/*---画像左---*/
#conts .img-boxL,
#g-footer .img-boxL {
	text-align: left;
}

#conts .img-boxL img:first-child {
	float: left;
	margin-right: 30px;
	margin-bottom: 30px;
}

/*---画像右---*/
#conts .img-boxR {
	text-align: left;
}

#conts .img-boxR img:first-child {
	float: right;
	margin-left: 30px;
	margin-bottom: 30px;
}

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

	#conts .col2 li {
		margin-right: 0;
		margin-bottom: 35px;
		width: 100%;
		float: none;
	}

	#conts .col3 li {
		margin-right: 0;
		margin-bottom: 25px;
		width: 100%;
		float: none;
	}

	#conts .col4 li {
		margin-right: 0;
		margin-bottom: 20px;
		width: 100%;
		float: none;
	}

	/*---6カラム---*/
	#conts .col6 li {
		margin-right: 10%;
		width: 45%;
		float: left;
		text-align: center;
	}

	#conts .col6 li:nth-child(2n) {
		margin-right: 0;
	}


	#conts .img-boxR img:first-child,
	#conts .img-boxL img:first-child {
		width: 30%;
		margin-bottom: 15px;
	}

	#conts .img-boxR img:first-child {
		margin-left: 15px;
	}

	#conts .img-boxL img:first-child {
		margin-right: 15px;
	}
}


/*-------------------------------------
	SPスタイル
-------------------------------------*/
@media only screen and (max-width: 736px) {
	#conts img.spCenter {
		margin: 0 0 15px!important;
		width: 100%!important;
		float: none!important;
	}
}

/*-------------------------------------
	footer
-------------------------------------*/
#g-footer {
	border-top: 1px solid #CCC;
	background: #E5E5E5;
	color: #666;
	font-size: 13px;
}

#g-footer .inner {
	padding: 30px 0;
	width: 960px;
	margin: 0 auto;
	text-align: left;
}

#g-footer .inner .ttl {
	margin-bottom: 10px;
	font-size: 16px;
}

#g-footer .inner li li {
	display: inline-block;
	margin: 0 10px 15px;
	background: url(../img/icon_link-arrow04.png) no-repeat left 6px;
	padding-left: 10px;
}

#g-footer .inner li li a {
	text-decoration: none;
	color: #666;
}

#g-footer .inner li li a:hover {
	text-decoration: underline;
}

#g-footer .inner p span {
	font-weight: bold;
}

#g-footer .inner .logo {
	margin-top: 20px;
}

#g-footer .inner .logo .imgL {
	float: left;
}

#g-footer .inner .logo p {
	padding-top: 10px;
}

#g-footer .copyright {
	background: #3F5477;
	padding: 0;
}

#g-footer .copyright .inner {
	position: relative;
}

#g-footer .copyright p {
	text-align: left;
	color: #FFF;
}

#g-footer .copyright p a {
	text-decoration: none;
	color: #FFF;
}

#g-footer .copyright .pagetop {
	position: absolute;
	top: 30px;
	right: 0;
	transform: rotate(-90deg);
}


@media only screen and (max-width: 736px) {
	#g-footer .inner {
		padding: 30px 15px;
		width: 100%;
		margin: 0;
		text-align: left;
		box-sizing: border-box;
	}
	#g-footer .col3 li {
		margin-right: 0;
		margin-bottom: 25px;
		width: 100%;
		float: none;
	}
	
	#g-footer .inner .ttl {
		font-size: 18px;
		font-weight: bold;
	}
	
	#g-footer .inner .logo img {
		width: 70px;
		height: auto;
	}
	
	#g-footer .inner .logo p {
		padding-top: 5px;
	}
	
	#g-footer .copyright p {
		color: #FFF;
		width: 100%;
		margin: 0;
	}
	#g-footer .copyright .pagetop {
		right: 15px;
	}
}
/*-------------------------------------
	汎用スタイル
-------------------------------------*/
.clearfix:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}

	*html .clearfix:after {
		zoom: 1;
	}

	*:first-child+html .clearfix:after {
		zoom: 1;
	}

/*-------------------------------------
	TOP
-------------------------------------*/
#index #conts {
	text-align: center;
	padding-bottom: 0;
}

#index #conts h2 {
	margin-bottom: 30px;
	color: #0B2A63;
	font-size: 28px;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	letter-spacing: 5px;
	position: relative;
	display: inline-block;
}

#index #conts h2 span {
	margin-top: 5px;
	color: #9C1B27;
	font-size: 12px;
	font-weight: bold;
	letter-spacing: 0px;
	display: block;
}

#index #conts h2:before,
#index #conts h2:after {
	content: "";
	position: absolute;
	height: 1px;
	width: 20px;
	background: #0F2955;
	top: 20px;
}

#index #conts h2:before{
	left: -50px;
}
#index #conts h2:after {
	right: -42px
}

@media only screen and (max-width: 736px) {
	#index #conts h2 {
		margin-bottom: 30px;
		font-size: 24px;
		letter-spacing: 3px;
	}
	#index #conts h2:before,
	#index #conts h2:after {
		content: "";
		position: absolute;
		height: 1px;
		width: 15px;
		background: #0F2955;
		top: 20px;
	}
	#index #conts h2:before{
		left: -30px;
	}
	#index #conts h2:after {
		right: -27px
	}
}

/*-------------------------------------
	company
-------------------------------------*/
#company .message {
	margin-bottom: 50px;
	padding-top: 150px;
    background: url(/img/bg_company.jpg) no-repeat center bottom;
	height: 250px;
}

#company .message p {
	color: #FFF;
	font-size: 20px;
	text-align: center;
	margin-bottom: 0;
}

#company .message p.ttl {
	font-size: 30px;
	margin-bottom: 20px;
}

@media only screen and (max-width: 736px) {
	#company .message {
		padding: 40px 20px;
		height: auto;
	}
	
	#company .message p {
		font-size: 16px;
	}
}

/*-------------------------------------
	feature
-------------------------------------*/
#check .column3 {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#check .column3 li {
	width: 31.5%;
	margin-bottom: 25px;
	text-align: center;
}
@media only screen and (max-width: 736px) {
	#check .column3 li {
		width: 48%;
	}
}
#study .img-center {
	text-align: center;
}

#conts .sdList h3 {
	margin: 10px 0;
	color: #0F2955;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}

#conts .sdList p {
	font-size: 14px;
}

/*-------------------------------------
	member
-------------------------------------*/
#member #conts dl,
#member #conts dt,
#member #conts dd {
	box-sizing: border-box;
}
#member #conts dl {
	display: flex;
	margin-bottom: 30px;
	padding-bottom: 15px;
	border-bottom: #CCC 1px solid;
	flex-wrap: wrap;
}
#member #conts dt {
	width: 50%;
	padding-right: 15px;
	border-right: #CCC 1px solid;
	font-size: 20px;
}
#member #conts dd {
	width: 50%;
	padding-left: 15px;
}
#member #conts dd address {
	display: block;
	font-style: normal;
}
#member #conts dd span::before {
	padding-right: 5px;
	font-family: "Font Awesome 5 Free";
	font-weight: 700;
	content: "\f2a0";
}
#member #conts dd a {
	display: inline-block;
	margin-left: 20px;
	padding: 3px 10px;
	background-color: #9C1B27;
	border-radius: 4px;
	color: #FFF;
	text-decoration: none;
}

/*-------------------------------------
	CONTACT
-------------------------------------*/
#contact h1.page-title {
    background: url(/img/bg_title_contact.jpg) no-repeat center;
    background-size: cover;
	color: #FFF;
}

#contact h1.page-title span {
	color: #FFF;
}

#contact #mail_form dl {
	margin-bottom: 25px;
}

#contact #mail_form dt {
	padding-top: 19px;
	width: 250px;
	float: left;
	color: #2C3E50;
	font-size: 18px;
	font-weight: bold;
	vertical-align: middle;
	clear: left;
}

#contact #mail_form dt .required {
	margin-right: 10px;
	padding: 2px 4px;
	background: #FC0;
	font-size: 11px;
	line-height: 1;
	vertical-align: middle;
}

#contact #mail_form dt .optional {
	margin-right: 10px;
	padding: 2px 4px;
	background: #DDD;
	font-size: 11px;
	line-height: 1;
	vertical-align: middle;
}

#contact #mail_form dd.required span {
	color: #C00;
	display: block;
}

#contact #mail_form #mail_submit_button {
	padding: 20px 60px;
    background: #2C3E50;
    border: 1px solid #2C3E50;
    border-radius: 35px;
    display: inline-block;
    color: #FFF;
    font-size: 26px;
    font-weight: bold;
    line-height: 1;
}

#contact #mail_form #mail_submit_button:hover {
    background: #FFF;
    color: #2C3E50;
    border: 1px solid #2C3E50;
}

#contact #mail_form .select-list li {
	line-height: 2;
}

#contact #mail_form input,
#contact #mail_form select,
#contact #mail_form textarea {
	padding: 5px 10px;
	font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;
}

#contact #mail_form select {
	-webkit-appearance: none;
	background: #EEE;
}


#contact #mail_form textarea {
	line-height: 1.6;
}

#contact #mail_form dd {
	padding: 15px 0 15px 250px;
	border-bottom: 1px dotted #333;
}

#contact #mail_form input[type="text"] {
	width: 320px;
}

#contact #mail_form .send-btn {
	text-align: center;
}

@media only screen and (max-width: 736px) {
	#contact #mail_form dt,
	#contact #mail_form dd {
		float: none;
	}


	#contact #mail_form dt {
		padding-top: 15px;
		width: auto;
	}

	#contact #mail_form dd {
		padding: 15px 0;
	}

	#contact #mail_form dd .link {
		margin: 5px 0 0;
		display: block;
	}

	#contact #mail_form input[type="text"],
	#contact #mail_form textarea {
		width: 100%;
		box-sizing: border-box;
	}
}


/*-------------------------------------
	info
-------------------------------------*/
#conts .info-box .post-title {
	margin-top: 15px;
	margin-bottom: 35px;
	padding-bottom: 22px;
	border-bottom: 2px solid #0F2955;
	color: #0F2955;
	font-size: 34px;
	font-weight: bold;
}

#conts .info-box h2 {
	margin: 25px 0;
	padding: 15px 20px;
	background: #DDD;
	color: #0F2955;
	font-size: 26px;
	font-weight: bold;
}

#conts .info-box h3 {
	margin: 15px 0;
	padding: 6px 15px;
	border-left: 3px solid #0F2955;
	color: #333;
	font-size: 22px;
	font-weight: bold;
}

@media only screen and (max-width: 736px) {
	#conts .info-box .post-title {
		margin-bottom: 20px;
		padding-bottom: 16px;
		font-size: 26px;
	}

	#conts .info-box h2 {
		margin-bottom: 15px;
		font-size: 24px;
	}

	#conts .info-box h3 {
		margin-bottom: 12px;
		padding: 6px 15px;
		font-size: 18px;
		font-weight: bold;
	}

}

#conts .info-box  p {
	margin-bottom: 20px;
	font-size: 16px;
	line-height: 1.7;
}

/*-------------------------------------
	2カラム
-------------------------------------*/
#conts #main {
	margin-right: 30px;
	width: 680px;
	float: left;
}

#conts #side {
	width: 250px;
	float: right;
}

#conts #side .cat-list {
	border-bottom: 1px solid #CCC;
}

#conts #side .cat-list li {
	border: 1px solid #CCC;
	border-bottom: none;
}

#conts #side .cat-list a {
	display: block;
	padding: 15px 10px 15px 35px;
	text-decoration: none;
	background: url(../img/icon_link-arrow03.png) no-repeat 10px;
}

#conts #side .cat-list a:hover {
	background: #DCAFB4 url(../img/icon_link-arrow02.png) no-repeat 10px;
}

@media only screen and (max-width: 736px) {
	#conts #main {
		margin-right: 0;
		width: 100%;
		float: none;
	}
	
	#conts #side {
		width: 100%;
		float: none;
	}
}