@charset "utf-8";

/* ----------------------------------------

content

---------------------------------------- */
.box02 {
	margin: 0 0 50px;
}
@media screen and (max-width:767px){
	.box02 {
		margin: 0 15px 40px;
	}
}


/* 一覧ページ画像拡大 */
@media screen and (min-width:768px){
	.listIndex02 .fig {
		overflow: hidden;
	}
	.listIndex02 a .fig img {
		-webkit-transition: all 0.5s ease;
		-moz-transition: all 0.5s ease;
		-o-transition: all 0.5s ease;
		transition: all 0.5s ease;
	}
	.listIndex02 a:hover .fig img {
		-webkit-transform: scale(1.1);
		-moz-transform: scale(1.1);
		-o-transform: scale(1.1);
		-ms-transform: scale(1.1); 
		transform: scale(1.1);
	}
	/*	
	.listIndex01 li a:hover {
		opacity: 1.0;
	}
	.listIndex01 li a:hover .textArea {
		opacity: 0.7;
	}
	*/
}



/*
.growthBox {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 30px;
	width: 100%;
}
.growthBox > .inBox {
	border: 1px solid #999;
	border-top: 3px solid #007;
	width: 100%;
	margin-left: 2.586%;
	margin-top: 30px;
	width: 48.707%;
}
.growthBox > .inBox:nth-of-type(2n + 1) {
	margin-left: 0;
}
.growthBox > .inBox:nth-of-type(-n + 2) {
	margin-top: 0;
}
.growthBox > .inBox > h3 {
	background: #f0f0f0;
	color: #007;
	font-size: 128.6%;
	font-weight: bold;
	padding: 15px;
	text-align: center;
}
.growthBox > .inBox > ul {
	list-style: none;
	padding: 20px 3.454% 30px;
}
.growthBox > .inBox > ul > li {
	margin-top: 10px;
	padding-left: 20px;
	position: relative;
}
.growthBox > .inBox > ul > li::before {
	background-color: #999;
	border-radius: 50%;
	content: "";
	display: block;
	height: 6px;
	left: 5px;
	position: absolute;
	top: 7px;
	width: 6px;
}

@media screen and (max-width:767px){
	.growthBox {
		display: block;
	}
	.growthBox > .inBox {
		margin-left: 0;
		width: 100%;
	}
	.growthBox > .inBox:nth-of-type(-n + 2) {
		margin-top: 30px;
	}
	.growthBox > .inBox > h3 {
		font-size: 128.6%;
	}
	.growthBox > .inBox > ul {
		padding: 10px 3.454% 20px;
	}
}

.growthCaution > li {
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
}
.growthCaution > li > .mark {
	margin-right: .5em;
}
.growthCaution > li > .text {
	display: block;
	flex: 0 1 auto;
}
@media screen and (max-width:767px){
	.growthCaution > li > .mark {
		display: block;
		white-space: nowrap;
	}
}
*/



/* model
------------------------------- */
.h3_model {
	width: 640px;
	margin: 0 auto 50px;
	padding: 5px 0 7px;
	font-size: 142.9%;
	font-weight: 700;
	color: #fff;
	background: #193771;
}
.modelBrand {
	width: 600px;
	margin: 0 auto -30px;
}
.modelBrand ul {
	float: left;
	width: 300px;
}
.modelBrand ul li {
	margin-bottom: 50px;
}
.modelBox {
	width: 100%;
	margin-bottom: 20px;
	display: table;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}
.modelBox .logo {
	width: 220px;
	display: table-cell;
	padding: 10px 0;
	text-align: center;
	background: #e8f6fd;
	vertical-align: middle;
}
.modelBox .logo h3 {
	font-size: 128.6%;
	font-weight: 700;
	color: #193771;
	margin-bottom: 12px;
	line-height: 1.4;
}
.modelBox .cont {
	width: auto;
	display: table-cell;
	padding: 15px 15px 10px 20px;
	vertical-align: top;
}
.modelBox .cont ul li {
	position: relative;
	margin: 0 0 7px 0;
	padding-left: 1em;
}
.modelBox .cont ul li:before {
	position: absolute;
	display: inline-block;
	height: 6px;
	width: 6px;
	content: "";
	background-color: #b5b5b5;
	border-radius: 3px;
	top: 9px;
	left: 0;
}
.modelBox .cont p {
	margin-bottom: 10px;
}
.modelBox .cont dt {
	font-weight: 600;
}
.modelBox .cont dd {
	margin: 0 0 10px 1em;
}
.modelBox .cont ul li dd {
	text-indent: -1em;
}

@media screen and (max-width:767px){
	.h3_model {
		width: auto;
		margin: 0 auto 30px;
	}
	.modelBrand {
		width: 100%;
		margin: 0 auto -10px;
	}
	.modelBrand ul {
		width: 50%;
		padding: 0 2%;
	}
	.modelBrand ul li {
		margin-bottom: 20px;
	}
	.modelBox {
		width: auto;
		margin: 0 15px 20px;
	}
	.modelBox .logo {
		padding: 10px 5px;
	}
}
@media screen and (max-width:580px){
	.modelBox .logo {
		width: 40%;
		padding: 10px 5px;
	}
	.modelBox .logo h3 {
		font-size: 16px;
	}
	.modelBox .cont {
		padding: 15px 5px 10px 10px;
	}
}



/* group
------------------------------- */
.groupLogo {
	width: calc(100% - 30px);
	display: table;
	margin: 0 auto 20px;
}
.groupLogo .logo {
	display: table-cell;
	text-align: center;
	vertical-align: middle;
}
.groupLogo .photo {
	display: table-cell;
	text-align: right;
	vertical-align: middle;
}
.groupLogo.bdr01 {
	border: 1px solid #ccc;
}
@media screen and (max-width:767px){
	.groupLogo {
		width: calc(100% - 30px);
		margin: 0 15px 20px;
	}
}


/* brand
------------------------------- */
.title03 {
	font-weight: 500;
	font-size: 142.9%;
	color: #000;
	margin-bottom: 10px;
}
.title03.bdrbtm {
	margin-bottom: 15px;
	padding-bottom: 5px;
	border-bottom: 2px solid #ccc;
}

.brandSec {
	margin-bottom: 40px;
	display: table;
}
.brandSec .logo {
	margin-bottom: 30px;
	display: table-cell;
	width: 220px;
}
.brandSec .detail {
	display: table-cell;
	padding-left: 20px;
	vertical-align: top;
}
.brandSec .detail p {
	margin-bottom: 15px;
}
.brandSec .brandBtn01 a,
.brandSec .brandBtn02 a {
	float: left;
	width: 48%;
	background: #f7923c;
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 128.6%;
	border-radius: 5px;
	line-height: 1.3;
	margin: 0 0 0 auto;
	padding: 6px 10px;
	text-align: center;
}
.brandSec .brandBtn02 a {
	float: right;
	width: 48%;
 }
.brandSec a:hover {
	opacity: .7;
}

@media screen and (max-width:767px){
	.brandSec {
		margin-bottom: 30px;
		display: table;
	}
	.brandSec .logo {
		margin-bottom: 10px;
		display: block;
		width: auto;
		text-align: center;
	}
	.brandSec .detail {
		display: block;
		padding: 0;
		vertical-align: top;
	}
}
@media screen and (max-width:600px){
	.brandSec .brandBtn01 a,
	.brandSec .brandBtn02 a {
		float: none;
		width: 100%;
	}
	.brandSec .brandBtn01 a {
		margin-bottom: 10px;
	}
}


/* employ
------------------------------- */
.mvService {
	position: relative;
	margin-bottom: 30px;
}
.mvService h2 {
	position: absolute;
	color: #193871;
	font-weight: 700;
	font-size: 171.5%;
	top: calc(50% - 44px);
	left: 5%;
	margin-right: 0.5em;
	text-shadow: 1px 1px 1px #949494;
}
.figEmploy01 {
	display: table;
	margin: 0 -15px 40px;
	padding: 0;
	text-align: center;
	width: calc(100% + 30px);
}
.figEmploy01 div {
	display: table-cell;
	padding: 0 15px;
	width: auto;
}
.figEmploy01 div h4 {
	font-weight: 700;
	font-size: 114.3%;
}
.contactImg {
	width: 70%;
	text-align: center;
	margin: 50px 15% 0;
}
@media screen and (max-width:767px){
	.figEmploy01 {
		margin: 0 0 40px;
		width: auto;
		padding: 0;
	}
	.contactImg {
		width: auto;
		margin: 50px 0 50px;
	}
}
@media screen and (max-width:540px){
	.mvService h2 {
		position: static;
		font-size: 22px;
		margin-left: 15px;
    	margin-right: 15px;
    	margin-top: 20px;
    	text-shadow: none;
	}
	.figEmploy01 {
		margin: 0 0 40px;
		width: 100%;
	}
	.figEmploy01 div {
		display: block;
		margin: 0;
		padding: 15px;
		width: 100%;
		text-align: center;
	}
}
@media screen and (max-width:374px){
	.mvService h2 {
		font-size: 18px;
	}
}

.contactBox {
	background: #f2f2f2;
	text-align: center;
	margin-bottom: 50px;
	padding: 40px 40px 20px;
}
.contactBox h3 {
	font-size: 157.2%;
	font-weight: 500;
	margin-bottom: 18px;
}
.contactBox p {
	margin-bottom: 30px;
}
.contactBox .contactBtn {
	margin: 0 0 15px;
}
.contactBox .contactBtn a {
	width: 440px;
	background: #f7923c;
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 128.6%;
	line-height: 1.3;
	margin: 0 auto;
	padding: 10px 10px 11px;
}
.contactBox .contactBtn a:hover {
	opacity: .7;
}
.contactBox .tel {
	position: relative;
	display: inline-block;
	margin-bottom: 15px;
	padding-left: 50px;
}
.contactBox .tel a {
	font-size: 214.3%;
	font-weight: 500;
	color: #193771 !important;
	line-height: 1;
	border-bottom: solid 1px #193771;
}
.contactBox .tel:before {
	position: absolute;
	top: -5px;
	left: 0;
	display: inline-block;
	content: "";
	background: url(/files/img/business/icon_tel_02.png);
	height: 40px;
	width: 40px;
}
@media screen and (max-width:767px){
	.contactBox {
		margin: 0 15px 40px;
		padding: 20px 15px 10px;
	}
	.contactBox h3 {
		font-size: 20px;
	}
	.contactBox p {
		margin-bottom: 20px;
	}
	.contactBox .contactBtn a {
		width: auto;
		font-size: 18px;
		line-height: 1.3;
		margin: 0 auto;
		padding: 8px 10px 7px;
	}
	.contactBox .tel {
		position: relative;
		display: inline-block;
		margin-bottom: 15px;
		padding-left: 40px;
	}
	.contactBox .tel a {
		font-size: 24px;
		border: none;
	}
	.contactBox .tel:before {
		top: -2px;
		background: url(/files/img/business/icon_tel_02.png);
		height: 30px;
		width: 30px;
		background-size: 30px;
	}
}

.stepList {
	margin-bottom: 50px;
}
.stepList li {
	display: table;
	width: 100%;
	margin-bottom: 20px;
}
.stepList li .stepNum {
	position: relative;
	display: table-cell;
	width: 80px;
	background: #00a9e0;
	text-align: center;
	vertical-align: middle;
}
.stepList li .stepNum:after {
	position: absolute;
	content: "";
	bottom: -10px;
	left: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 40px 0 40px;
	border-color: #00a8e0 transparent transparent transparent;
}
.stepList li:last-of-type .stepNum:after {
	border: none;
}
.stepList li .stepCont {
	position: relative;
	width: auto;
	min-height: 122px;
	padding: 0 20px 0 118px;
	vertical-align: middle;
	border: 1px solid #ccc;
	border-left: none;
}
.stepList li .stepCont img {
	position: absolute;
	left: 0;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.stepList li .stepCont h3 {
	margin: 15px 0 8px;
	font-size: 128.6%;
	font-weight: 700;
	color: #193771;
}
.stepList li .stepCont p {
	margin-bottom: 17px;
	overflow: auto;
}
@media screen and (max-width:767px){
	.stepList {
		margin: 0 15px 50px;
	}
}
@media screen and (max-width:540px){
	.stepList {
		margin: 0 15px 40px;
	}
	.stepList li .stepNum {
		width: 60px;
	}
	.stepList li .stepNum:after {
		border-width: 10px 30px 0 30px;
	}
	.stepList li .stepCont {
		min-height: 92px;
		padding: 0 15px 0 90px;
	}
	.stepList li .stepCont img {
		width: 90px;
	}
}

/* candidate
------------------------------- */
.brand5 {
	width: calc(100% + 20px);
	margin: 0 -10px 40px;
}
.brand5 li {
	float: left;
	width: 220px;
	padding: 15px 5px;
	text-align: center;
	border-left: 1px solid #ccc;
}

.brand5 li:nth-child(1) img {
	margin: 0 5px;
}
.brandBtn {
	margin: 10px 5px 0px;
	text-align: center;
}
.brandBtn a {
	position: relative;
	width: 100%;
	background: #f7923c;
	display: block;
	color: #fff;
	text-align: left;
	text-decoration: none;
	font-size: 85%;
	border-radius: 5px;
	border: 2px solid #f68430;
	line-height: 1.3;
	margin: 0 auto 0 0;
	padding: 8px 8px;
}
.brandBtn a:after {
	position: absolute;
	content: "\f105";
	font-family: FontAwesome;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	right: 5px;
}
.brandBtn a:hover {
	opacity: .7;
}
@media screen and (max-width:767px){
	.brand5 {
		width: auto;
		margin: 0 15px 40px;
	}
	.brand5 li,
	.brand5 li:nth-child(1) {
		float: none;
		width: 100%;
		margin-bottom: 30px;
		padding: 0;
		border-left: none;
		text-align: left;
	}
	.brand5 li img,
	.brand5 li:nth-child(1) img {
		margin: 0 20px;
	}
	.brandBtn {
		margin: 10px 0 0px;
	}
	.brandBtn a {
		width: auto;
		text-align: center;
	}
}

.promiseBox {
	margin: 0;
	padding: 30px 50px 40px;
	background: #effaff;
}
.promiseBox ol {
	margin: 0 40px 30px 20px;
}
.promiseBox ol li {
	text-indent: -1.8em;
	margin: 0 0 15px 2em;
	padding: 0 15px 15px 40px;
	border-bottom: solid 1px #e0e0e0;
}
.promiseBox ol li:last-of-type {
	padding: 0 15px 0 40px;
	border: none;
}
.promiseBox .cautionBox {
	padding: 20px 25px;
	border: 1px solid #ccc;
	background: #fff;
}
.promiseBox .cautionBox h4 {
	margin-bottom: 10px;
	text-align: center;
	font-size: 114.3%;
	color: #c00;
}
.promiseBox .cautionBox li {
	font-size: 92.4%;
	margin: 0 0 5px 1.2em;
	text-indent: -1.2em;
}
@media screen and (max-width:640px){
	.promiseBox {
		margin: 0 15px;
		padding: 20px 20px 20px;
	}
	.promiseBox ol {
		margin: 0 0 20px -30px;
	}
	.promiseBox ol li {
		text-indent: -1.8em;
		margin: 0 0 15px 2em;
		padding: 0 0 15px 30px;
		border-bottom: solid 1px #e0e0e0;
	}
	.promiseBox ol li:last-of-type {
		padding: 0 0 0 30px;
		border: none;
	}
	.promiseBox .cautionBox {
		padding: 20px 15px;
		border: 1px solid #ccc;
	}
	.promiseBox .cautionBox h4 {
		margin-bottom: 10px;
		text-align: center;
		font-size: 114.3%;
		color: #c00;
	}
	.promiseBox .cautionBox li {
		font-size: 92.4%;
		margin: 0 0 5px 1.2em;
		text-indent: -1.2em;
	}
}


/* sa
------------------------------- */
.saSec {
	margin: 0 0 50px;
}
.saSec .download {
	float: left;
	width: 33%;
	text-align: center;
}
.saSec .writer {
	float: right;
	width: 66%;
	padding: 20px 20px 20px 20px;
	background: #F5F3F4; 
}
.saSec .writer h3 {
	font-size: 114.3%;
}
.saSec .writer .post {
	border-bottom: 1px solid #ccc;
	padding-bottom: 10px;
	margin-bottom: 15px;
}
.saSec .writer .imgR {
	float: right;
	margin: 0 0 10px 15px;
}
.download .dlBtn {
	margin: 15px 0 0;
}
#main .download .dlBtn a {
	width: 90%;
	background: #f7923c;
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 128.6%;
	line-height: 1.3;
	margin: 0 auto;
	padding: 10px 10px 11px;
	border-radius: 5px;
	border: 2px solid #f68430;
}
}
#main .download .dlBtn a:active,
#main .download .dlBtn a:hover {
	opacity: .7;
	text-decoration: none;
	color: #fff;
}
.registSec {
	text-align: center;
}
.registSec h3 {
	font-size: 157.2%;
	font-weight: 500;
	margin-bottom: 20px;
}
.registSec p {
	margin-bottom: 30px;
}
.registSec .registBtn {
	margin: 0 0 15px;
}
.registSec .registBtn a {
	width: 440px;
	background: #f7923c;
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 128.6%;
	line-height: 1.3;
	margin: 0 auto;
	padding: 10px 10px 11px;
	border-radius: 5px;
	border: 2px solid #f68430;
}
.registSec .registBtn a:hover {
	opacity: .7;
}
@media screen and (max-width:767px){
	.saSec {
		margin: 0 15px 50px;
	}
	.saSec .download {
		float: none;
		width: auto;
		margin-bottom: 30px;
	}
	.saSec .writer {
		float: none;
		width: auto;
	}
	.download .dlBtn a {
		width: auto;
		font-size: 18px;
		line-height: 1.3;
		margin: 0 auto;
		padding: 8px 10px 7px;
	}
	.registSec h3,
	.registSec p {
		text-align: left;
	}
	.saSec .writer .imgR {
		float: none;
		margin: 0 0 15px;
		text-align: center;
	}
	.registSec {
		margin: 0 15px 40px;
	}
	.registSec h3 {
		font-size: 20px;
	}
	.registSec p {
		margin-bottom: 20px;
	}
	.registSec .registBtn a {
		width: auto;
		font-size: 18px;
		line-height: 1.3;
		margin: 0 auto;
		padding: 8px 10px 7px;
	}
}


/* common
------------------------------- */
.leftBtn01 {
	margin: 0 15px 25px;
	text-align: center;
}
.leftBtn01 a {
	width: 300px;
	background: #f7923c;
	display: block;
	color: #fff;
	text-decoration: none;
	font-size: 142.9%;
	border-radius: 5px;
	border: 2px solid #f68430;
	line-height: 1.3;
	margin: 0 auto 0 0;
	padding: 6px 10px;
}
.leftBtn01 a:hover {
	opacity: .7;
}
@media screen and (max-width:767px){
	.leftBtn01 a {
		width: auto;
		position: relative;
		padding: 5px 30px;
	}
	.leftBtn01 a.icon_arrow_01:after {
		position: absolute;
		margin: 0;
		top: 50%;
		-webkit-transform: translate(0,-50%);
		transform: translate(0,-50%);
		right: 15px;
	}
}


/* listIndex02
------------------------------- */
.listIndex02 li{
	margin-bottom: 30px;
}
.listIndex02 li.serviceSub {
	display: block;
	/*border: 1px solid #ccc;*/
	background: #e6e6e6;
	text-decoration: none;
}
.listIndex02 li a:hover {
	opacity: .7;
}
.listIndex02 li.serviceSub .fig {
	width: 360px;
	float: left;
}
.listIndex02 li.serviceSub .textArea {
	width: 770px;
	padding: 15px 18px;
	float: left;
}
.listIndex02 li.serviceSub .textArea .tit {
	font-size: 157.2%;
	font-weight: 500;
	color: #193771;
	margin-bottom: 3px;
}
.listIndex02 li.serviceSub .textArea a {
	border: none;
	font-weight: 700;
	color: #333;
}
.listIndex02 li.serviceSub .textArea ul {
	margin: 10px 0 0 20px;
}
.listIndex02 li.serviceSub .textArea ul li:last-of-type {
	margin-bottom: 5px;
}
.listIndex02 li.serviceSub .textArea ul li ul {
	margin: 10px 0 0 20px;
}
.listIndex02 li.serviceSub .textArea ul li li {
	margin-bottom: 5px;
}

.listIndex02 li.serviceSub .textArea a:before {
	content: "\f105";
	font-family: FontAwesome;
	font-size: 110%;
	margin-right: 10px;
}
@media screen and (max-width:767px){
	.listIndex02 li.serviceSub .fig {
		width: auto;
		float: none;
		text-align: center;
	}
	.listIndex02 li.serviceSub .textArea {
		width: auto;
	}
}


.subNav > li > ul > li > ul > li {
	border: none;
}
.subNav > li > ul > li > ul > li:last-of-type {
	border: none;
}
.subNav > li > ul > li > ul > li > a {
	padding: 7px 5px 7px 55px;
	position: relative;
} 
.subNav > li > ul > li > ul > li > a:before {
	content:"ー";
	display: block;
	position: absolute;
	top: 50%;
	left: 38px;
	-webkit-transform: translate(0,-50%);
	transform: translate(0,-50%);
	font-weight: normal;
	font-size: 10px;
}
.subNav > li > ul > li > ul > li.active > a {
	background: #b3b3b3;
	color: #fff;
}
.subNav > li > ul > li > ul > li.active > a:before {
	color: #fff;
}


.kome01 {
	display: block;
	margin-left: 1em;
	text-indent: -1em;
}
.txtBlue {
	font-weight: 700;
	color: #00A9E0;
}
.w400 a {
	width: 400px;
}
@media screen and (max-width:767px){
	.w400 a {
		width: auto;
	}
}


/* ----------------------------------------

clearfix

---------------------------------------- */

/* Modern Browsers
------------------------------- */
.listIndex02 li.serviceSub:after,
.modelBrand:after,
.brandSec:after,
.stepList li .stepCont:after,
.brandList01:after,
.saSec:after,
.brand5:after {
	display: block;
	visibility: hidden;
	clear: both;
	height: 0;
	content: ".";
	line-height: 0;
}

/* Legacy IE
------------------------------- */
.listIndex02 li.serviceSub,
.modelBrand,
.brandSec,
.stepList li .stepCont,
.brandList01,
.saSec,
.brand5 {
	*zoom: 1;
}