@charset "utf-8";
.top-mv::after{
	content: "";
	background: -moz-linear-gradient(left, #C81E00, #FF8200, #C81E00);
	background: -webkit-linear-gradient(left, #C81E00, #FF8200, #C81E00);
	background: linear-gradient(to right, #C81E00, #FF8200, #C81E00);
	display: block;
	height: 13px;
	width: 100%;
}

.main-contnets.blue-contents-bg{
//	background: url(../images/common/bg-grad.jpg) repeat-y;
	background: -moz-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: -webkit-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: linear-gradient(to right, #012462 50%, #0082E8 100%);
	padding: 50px 0 180px;
}

.main-contnets.blue-contents-bg::before,
.main-contnets.blue-contents-bg::after{
	content: "";
	position: absolute;
	left: 0;
	height: 550px;
	width: 100%;
}

.main-contnets.blue-contents-bg::before{
	background: url(../images/top/contents-bg.png) no-repeat;
	background-size: 100% 100%;
	background-position: center top;
	top: 0;
}

.main-contnets.blue-contents-bg::after{
	background: url(../images/top/contents-bg2.png) no-repeat;
	background-size: 100% 100%;
	background-position: center bottom;
	bottom: 0;
}

.main-contnets.top .scroll{
	font-size: 17px;
	letter-spacing: 0.1em;
	margin-bottom: 100px;
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 60px;
}

.main-contnets.top .scroll::after {
	content: "";
	background: #ffffff;
	height: 30px;
	width: 1px;
	display: block;
	margin-top: 5px;
	position: relative;
	animation: pathmove 1.4s ease-in-out infinite;
	opacity: 0;
}

.mv-slider .slick-current img{
	transform: scale(1.0);
	animation: zoomimg 10.0s linear infinite;
}

@keyframes zoomimg{
	0%{
		transform: scale(1.0);
	}
	100%{
		transform: scale(1.3);
	}
}

@keyframes pathmove{
	0%{
		height:0;
		top:0;
		opacity: 0;
	}
	30%{
		height: 30px;
		opacity: 1;
	}
	100%{
		height: 0;
		top: 30px;
		opacity: 0;
	}
}

.mv-slider .slick-dots{
	width: auto;
	right: 50px;
	top: calc(100% + 40px);
	z-index: 5;
}

.mv-slider .slick-dots li{
	background: #ffffff;
	height: 18px;
	margin: 0 10px;
	width: 18px;
	border-radius: 50%;
}

.mv-slider .slick-dots li.slick-active{
	background: #EC6C2B;
}

.main-contnets.blue-contents-bg section{
	position: relative;
	z-index: 2;
}

.bg-sc-img {
	position: relative;
	height: 0%;
	padding-top: unquote("min(100vh,75%)");
	margin-top: 80px;
}

.sc-img1{
	background: url(../images/top/top-sc1_pc.png) no-repeat;
	background-size: cover;
}

.sc-img2{
	background: url(../images/top/top-sc2_pc.png) no-repeat;
	background-size: cover;
}

.main-contnets.top .concept-sec .img{
	width: calc(50% + 70px);
}

.main-contnets.top .concept-sec .img > .blo:not(:first-child){
	margin-top: 50px;
}

.main-contnets.top .concept-sec h1{
	font-size: 46px;
	font-weight: 400;
	letter-spacing: 0.12em;
	line-height: 1.52;
}

.main-contnets.top .concept-sec .sub-title{
	font-size: 13px;
	letter-spacing: 0.1em;
	margin-top: 40px;
}

.main-contnets.top .concept-sec h2{
	border-top: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0.15em;
	line-height: 2;
	margin-top: 40px;
	padding: 25px 0;
	width: 247px;
}

.main-contnets.top .concept-sec h2::before,
.main-contnets.top .concept-sec h2::after{
	content: "";
	background: #ffffff;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
}

.main-contnets.top .concept-sec h2::before{
	left: 0;
	top: -4px;
}

.main-contnets.top .concept-sec h2::after{
	right: 0;
	bottom: -4px;
}

.main-contnets.top .concept-sec .main-p{
	font-size: 18px;
	letter-spacing: 0.15em;
	line-height: 3.88;
}

.parallax-sec.para-img1{
	background: url(../images/top/sc1_pc.jpg) no-repeat;
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.parallax-sec.para-img2{
	background: url(../images/top/sc2_pc.jpg) no-repeat;
	background-attachment: fixed;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.parallax-sec:before,
.parallax-sec:after{
	content: "";
	height: 340px;
	width: 100%;
	display: block;
	background: -moz-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: -webkit-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: linear-gradient(to right, #012462 50%, #0082E8 100%);
	position: relative;
}

.parallax-sec:before {
	clip-path: polygon(0 0, 0% 100%, 100% 0);
	top: -1px;
}

.parallax-sec:after {
	clip-path: polygon(0 100%, 100% 0, 100% 100%);
	bottom: -1px;
}

.main-contnets.top .concept-sec.sec1{
	z-index: 3;
}

.main-contnets.top .concept-sec.sec1 .img{
	bottom: -125px;
	position: relative;
}

.main-contnets.top .concept-sec.sec2 .img{
	top: -180px;
	position: relative;
}

.f-menu-area{
	background: -moz-linear-gradient(left, #012462 50%, #000000 100%);
	background: -webkit-linear-gradient(left, #012462 50%, #000000 100%);
	background: linear-gradient(to right, #012462 50%, #000000 100%);
	padding: 100px 0;
}

.f-menu-area .f-menu-list li h4{
	font-size: 13px;
	letter-spacing: 0.2em;
	position: relative;
	z-index: 2;
	padding: 5px 10px;
}

.f-menu-area .f-menu-list li h4:after{
	content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #005AC8;
    transform: scaleY(0.8) perspective(0.8em) rotateX(-1deg);
    transform-origin: bottom left;
	width: 0;
	margin-top: -5px;
	-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.f-menu-area .f-menu-list li h4:before{
	content: "";
	background: #ffffff;
	height: calc(tan(60deg) * 14px / 2);
	width: 12px;
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	display: inline-block;
	margin-right: 10px;
	vertical-align: middle;
}

.f-menu-area .inner > a{
	display: block;
	margin: 35px 0;
	filter: brightness(1);
}

.main-contnets.lower-page{
	padding: 280px 0 100px;
}

.page-title{
	display: table;
	text-align: center;
	margin: 0 auto 100px;
	max-width: 510px;
	width: 100%;
}

.page-title .en{
	color: #0F32AA;
	display: block;
	font-size: 52px;
	font-weight: 400;
	letter-spacing: 0.1em;
	padding-bottom: 10px;
}

.page-title .en::after{
	content: "";
	background: #003780;
	height: 1px;
	width: 0;
	position: absolute;
	left: 0;
	bottom: 0;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.page-title.active .en::after{
	width: 100%;
}

.page-title .en::before{
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px;
}

.page-title .ja{
	color: #000000;
	display: block;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0.4em;
	padding-top: 10px;
}

.page-title.c-white .en,
.page-title.c-white .ja{
	color: #ffffff;
}

.page-title.c-white .en::before,
.page-title.c-white .en::after{
	background: #ffffff;
}

.main-contnets.safety-page .safety-list{
	margin-top: -50px;
	margin-right: -50px;
}

.main-contnets.safety-page .safety-list li{
	margin-top: 50px;
	margin-right: 50px;
}

.main-contnets.safety-page .safety-list li:not(:first-child){
	background: #005ac8;
}

.page-sc-btn{
	cursor: pointer;
}

.main-contnets.safety-page .sec1{
	padding-bottom: 160px;
}

.main-contnets.safety-page .safety-list-sec .sec-blo:not(:last-child){
	margin-bottom: 160px;
}

.main-contnets.safety-page .sec-num-title{
	border-bottom: 1px solid #005AC8;
	border-top: 1px solid #005AC8;
	color: #0F32AA;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0.2em;
	margin-bottom: 50px;
}

.main-contnets.safety-page .sec-num-title .num{
	background: #005AC8;
	color: #ffffff;
	font-size: 38px;
	font-weight: 400;
	font-style: italic;
	letter-spacing: 0.025em;
	margin-right: 20px;
	height: 70px;
	width: 100px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.main-contnets.safety-page .sec-num-title img{
	position: absolute;
	right: 30px;
	top: 50%;
	transform: translateY(-50%);
}

.safety-list-sec .num-title{
	font-size: 17px;
	font-weight: 400;
	letter-spacing: 0.1em;
	margin-bottom: 15px;
}

.safety-list-sec .sec-num p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2.13;
}

.safety-list-sec .sec-num .img-list .blo.w180{
	width: 180px;
}

.safety-list-sec .sec-num .img-list .blo:not(:last-child){
	margin-right: 50px;
}

.safety-list-sec .sec-num .img-list .blo span{
	display: block;
	font-size: 12px;
	letter-spacing: 0.035em;
	margin-top: 10px;
	text-align: center;
}

.safety-list-sec .sec-num:not(:last-child){
	margin-bottom: 80px;
}

.table-box.safety-table .th{
	background: #005AC8;
	width: 256px;
}

.table-box.safety-table .th,
.table-box.safety-table .td{
	border-bottom: 1px solid #003780;
	vertical-align: middle;
	padding: 30px;
}

.table-box.safety-table .row:first-child .th,
.table-box.safety-table .row:first-child .td{
	border-top: 1px solid #003780;
	padding: 15px 50px;
}

.table-box.safety-table .row p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2;
}

.table-box.safety-table .td p{
	color: #595757;
}

.table-box.safety-table .td .indent-num{
	display: flex;
}

.store-table{
	border-collapse: collapse;
	width: 100%;
}

.store-table th,
.store-table td{
	border: 1px solid #003780;
}

.store-table th:first-child,
.store-table td:first-child{
	border-left: unset;
}

.store-table th:last-child,
.store-table td:last-child{
	border-right: unset;
}

.store-table th,
.store-table td{
	padding: 15px 20px;
}

.store-table thead th{
	background: #005AC8;
	text-align: center;
}

.table-box.safety-table .store-table thead th p{
	color: #ffffff;
	font-weight: 400;
}

.v-top{
	vertical-align: top;
}

.link-btn{
	border: 1px solid #595757;
	border-radius: 25px;
	color: #595757;
	font-size: 14px;
	letter-spacing: 0.05em;
	padding: 4px 21px;
}

.lower-mv{
	margin-bottom: -90px;
	position: relative;
	z-index: 3;
}

.main-contnets.lower-top-page{
	padding: 180px 0 100px;
}

.concept-txt h2{
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0.2em;
	margin-bottom: 20px;
}

.concept-txt p{
	font-size: 16px;
	letter-spacing: 0.1em;
	line-height: 2;
}

.main-contnets.company-page .concept-sec,
.main-contnets.services-page .concept-sec,
.main-contnets.network-page .concept-sec,
.main-contnets.network-page .recruit-sec,
.main-contnets.group-page .concept-sec{
	padding-bottom: 160px;
}

.aco-btn{
	cursor: pointer;
	margin: 0 auto;
	max-width: 900px;
	width: 90%;
}

.aco-btn a{
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 0.2em;
	height: 56px;
	padding: 0 30px;
	display: flex;
	align-items: center;
}

.aco-btn span{
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0.1em;
	margin-left: 20px;
}

.aco-btn a:after{
	content: "\f13a";
	font-family: 'Fontawesome';
	position: absolute;
	right: 30px;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	line-height: 1;
}

.aco-btn.active a:after{
	content: "\f139";
	color: #ec6c2b;
	background: #ffffff;
	border-radius: 50%;
}

.aco-btn.active.brackets::before,
.aco-btn.active.brackets::after{
	height: calc(100% - 1px);
	width: calc(100% - 1px);
}

.main-contnets.company-page .aco-btn-sec + .aco-btn-sec{
	margin-top: 80px;
}

.main-contnets.company-page .aco-btn-sec .aco-in{
	background: #ffffff;
	display: none;
	margin-top: 20px;
	padding: 60px 0;
}

.main-contnets.company-page .aco-btn-sec .aco-in p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2.13;
}

.main-contnets.company-page .aco-btn-sec .aco-in p.f-16{
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.15em;
	line-height: 2.06;
}

.main-contnets.company-page .aco-btn-sec .aco-in p.name{
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.2em;
}

.main-contnets.company-page .aco-btn-sec .aco-in p.name span{
	font-size: 17px;
	letter-spacing: 0.15em;
	margin-right: 20px;
}

.main-contnets.blue-contents-bg.btm-img-none::after{
	display: none;
}

.main-contnets.company-page .aco-btn-sec .aco-in h3{
	border-bottom: 1px solid #003780;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0.2em;
	margin-bottom: 20px;
	padding: 0 15px 15px 15px;
}

.main-contnets.company-page .aco-btn-sec .aco-in h3::before{
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px;
}

.main-contnets.company-page .aco-btn-sec .aco-in p + h3,
.main-contnets.company-page .aco-btn-sec .aco-in .company-table + h3{
	margin-top: 60px;
}

.company-table .th,
.company-table .td{
	border-top: 1px solid #003780;
	padding: 15px 20px;
	vertical-align: middle;
}

.company-table .th p,
.company-table .td p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2;
}

.company-table .row:last-child .th,
.company-table .row:last-child .td{
	border-bottom: 1px solid #003780;
}

.company-table .th{
	background: #005AC8;
	color: #ffffff;
	width: 140px;
}

.company-table .td .posi-flex,
.company-table .td .num-flex{
	display: flex;
}

.company-table .td .posi-flex > p:first-child{
	margin-right: 20px;
	width: 205px;
}

.company-table .td .num-flex > p:first-child{
	margin-right: 20px;
	width: 80px;
}

.company-table .td .posi-flex > p:first-child span{
	line-height: 1.46;
	display: block;
}

.company-table .td .posi-flex > p:last-child span{
	line-height: 2.8;
	display: block;
}

.company-table .td .num-flex > p:last-child{
	text-align: right;
}

.table-out-flex .blo{
	max-width: 415px;
	width: 100%;
}

.table-out-flex .blo .company-table .th{
	width: 323px;
}

.table-out-flex .blo .company-table .td{
	text-align: right;
}

.flex-rows{
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.main-contnets.company-page .aco-btn-sec .aco-in h3 span{
	font-size: 16px;
	margin-left: 1rem;
}

.more-link{
	font-size: 12px;
	letter-spacing: 0.075em;
	padding: .8em 1.6em .4em 1.8em;
	position: relative;
	color: #0F32AA;
	z-index: 1;
	right: 30px;
}

.more-link::before{
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	border: 1px solid #0F32AA;
	transform: scaleY(0.6) perspective(0.8em) rotateX(-3deg);
	transform-origin: bottom left;
	-webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.services-sec{
//	margin: 0 auto;
//	max-width: 680px;
}

.service-slider{
//	margin-left: calc(20% - 100px);
//	width: 680px;
}

.service-slider .slick-track {
	display: flex;
}

.service-slider .slick-slide {
	height: auto !important;
}

.service-slider .blo{
	background-image: url(../images/services/service-bg.png);
	background-size: 100% 100%;
	background-repeat: no-repeat;
	background-position: center top;
	padding: 40px 60px 60px;
	width: 680px;
}

.service-slider .blo{
//	margin: 0 50px;
}

.service-slider .blo h3{
	color: #005AC8;
	font-size: 22px;
	font-weight: 500;
	letter-spacing: 0.2em;
	margin-bottom: 30px;
}

.service-slider .blo h3 span{
	font-size: 60px;
	font-weight: 400;
	font-style: italic;
	letter-spacing: 0.1em;
	margin-right: 15px;
}

.service-slider .blo h3 span:before{
	content: "#";
	font-size: 20px;
	font-style: italic;
}

.service-slider .blo .txt{
	border-bottom: 1px solid #005AC8;
	border-top: 1px solid #005AC8;
	padding: 20px 0;
	margin-top: 40px;
}

.service-slider .blo .txt::before,
.service-slider .blo .txt::after{
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
}

.service-slider .blo .txt::before{
	left: 0;
	top: -4px;
}

.service-slider .blo .txt::after{
	right: 0;
	bottom: -4px;
}

.service-slider .blo .txt h4{
	color: #005AC8;
	font-size: 18px;
	font-weight: 500;
	letter-spacing: 0.2em;
	margin-bottom: 15px;
}

.service-slider .blo .txt p{
	font-size: 15px;
	letter-spacing: 0.045em;
	line-height: 2.13;
}

.service-slider .blo .label-blo .flex-label{
	display: flex;
	align-items: center;
}

.service-slider .blo .label-blo .flex-label:not(:last-child){
	margin-bottom: 10px;
}

.service-slider .blo .label-blo .flex-label span{
	font-size: 13px;
	letter-spacing: 0.1em;
	padding: 0.8em 0.6em 0.4em 0.6em;
	z-index: 1;
	width: 90px;
	display: block;
}

.service-slider .blo .label-blo .flex-label span:before{
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: #005AC8;
    transform: scaleY(0.6) perspective(0.8em) rotateX(-3deg);
    transform-origin: bottom left;
	width: 87%;
}

.service-slider .blo .label-blo .flex-label p{
	font-size: 13px;
	letter-spacing: 0.075em;
	margin-left: 30px;
	position: relative;
	top: 5px;
}

.network-sec,
.group-sec{
	background: #ffffff;
	padding: 60px 0 100px;
}

.network-sec::before,
.group-sec::before{
	content: "";
	background: #ffffff;
	border-radius: 100% 100% 0 0;
	margin-left: -100px;
	margin-right: -100px;
	padding-left: 100px;
	padding-right: 100px;
	position: absolute;
	left: 0;
	top: -100px;
	height: 100px;
	width: 100%;
}

.network-list .border-title{
    border-bottom: 1px solid #003780;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.2em;
    margin-bottom: 30px;
    padding: 0 0 15px 15px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.network-list .border-title span{
    font-size: 20px;
    font-weight: 400;
}

.network-list .border-title::before {
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px;
}

.network-list .blo .body .address{
	width: 50%;
}

.network-list .blo .body .address p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2;
}

.network-list .blo .g-map{
	position: relative;
	padding-bottom: 400px;
	height: 0;
	overflow: hidden;
	margin-top: 30px;
	width: 100%;
}

.network-list .blo .g-map iframe{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.network-list .blo:not(:last-child){
	margin-bottom: 100px;
}

.recruit-link-area .recruit-btn:not(:last-child){
	margin-bottom: 100px;
}

.recruit-btn{
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 0.2em;
	position: relative;
	height: 126px;
	width: 316px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	flex-direction: column;
}

.recruit-btn::before,
.recruit-btn::after {
	content: '';
	width: 8px;
	height: 8px;
	position: absolute;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.recruit-btn::before {
	border-left: 1px solid #ffffff;
	border-top: 1px solid #ffffff;
	top: 0;
	left: 0;
}

.recruit-btn::after {
	border-right: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
	bottom: 0;
	right: 0;
}

.recruit-btn hr{
	border: none;
	border-top: 1px solid #ffffff;
	display: block;
	width: 82%;
}

.lower-title{
	background: #005AC8;
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 0.2em;
	height: 126px;
	width: 316px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 100px;
	flex-direction: column;
}

.lower-title hr{
	border: none;
	border-top: 1px solid #ffffff;
	display: block;
	width: 82%;
}

.graduate-page .border-title{
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.2em;
	margin-bottom: 40px;
	padding: 0 15px 15px 15px;
	display: table;
}

.graduate-page .border-title span {
	font-size: 32px;
	font-weight: 400;
	letter-spacing: 0.1em;
	margin-right: 10px;
}

.graduate-page .border-title::before {
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px;
}

.graduate-page .border-title::after {
	content: "";
	background: #003780;
	height: 1px;
	width: 0;
	position: absolute;
	left: 0;
	bottom: 0;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.graduate-page .border-title.active::after {
	width: 100%;
}

.staff-list .blo{
	width: 280px;
}

.staff-list .blo .img{
	filter: grayscale(1);
}

.staff-list .blo .txt{
	margin-top: 15px;
}

.staff-list .blo .txt h4{
	font-size: 13px;
	letter-spacing: 0.1em;
	margin-bottom: 10px;
	padding: 0.8em 0.6em 0.4em 0.6em;
	z-index: 1;
	width: calc(100% - 20px);
	display: block;
}

.staff-list .blo .txt h4:before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	background: #005AC8;
	transform: scaleY(0.8) perspective(0.8em) rotateX(-1deg);
	transform-origin: bottom left;
}

.staff-list .blo .txt p{
	font-size: 20px;
	letter-spacing: 0.2em;
}

.staff-list .blo .txt p span{
	font-size: 12px;
	letter-spacing: 0.075em;
	margin-left: 15px;
}

.graduate-page .sec1{
	padding-bottom: 60px;
}

.graduate-page .sec2{
	background: #F0FCFF;
	padding: 100px 0;
}

.graduate-page .training-area .blo:not(:last-child){
	margin-bottom: 100px;
}

.graduate-page .training-area h4{
	margin: 0 auto 30px;
	height: 50px;
	width: 150px;
	font-size: 21px;
	font-weight: 500;
	letter-spacing: 0.2em;
	display: flex;
	align-items: center;
	justify-content: center;
}

.training-box > div{
	max-width: 280px;
	width: 100%;
}

.training-box > div .img{
	display: table;
	margin: 0 auto 20px;
	height: 75px;
}

.training-box > div .label-title{
	font-size: 17px;
    letter-spacing: 0.075em;
    margin-bottom: 15px;
}

.training-box > div p{
	font-size: 15px;
	letter-spacing: 0.05em;
	line-height: 2.13;
}

.label-title{
    padding: 0.8em 0.6em 0.4em 0.6em;
    z-index: 1;
    width: calc(100% - 20px);
    display: block;
}

.label-title:before{
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -1;
	background: #005AC8;
	transform: scaleY(0.8) perspective(0.8em) rotateX(-1deg);
	transform-origin: bottom left;
}

.graduate-page .sec3{
	padding-top: 100px;
}

.graduate-page .sec3 p{
	font-size: 15px;
	letter-spacing: 0.05em;
	line-height: 2.13;
}

.mynavi-link{
	border: 1px solid #005AC8;
	height: 80px;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mynavi-link .window-icon{
	position: absolute;
	right: 10px;
	bottom: 10px;
}

/*========= LoadingのためのCSS ===============*/
/* Loading背景画面設定　*/
#splash {
    /*fixedで全面に固定*/
	position: fixed;
	width: 100%;
	height: 100%;
	z-index: 999;
	text-align:center;
	color:#fff;
}

/* Loading画像中央配置　*/
#splash_text {
	position: absolute;
	top: 50%;
	left: 50%;
    z-index: 999;
	transform: translate(-50%, -50%);
	color: #fff;
	width: 100%;
}

#splash_text .load-logo{
	display: none;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -150%);
}

/*IE11対策用バーの線の高さ※対応しなければ削除してください*/
#splash_text svg{
    height: 5px;
}

/*割れる画面のアニメーション*/
.loader_cover {
    width: 100%;
    height: 50%;
	background: -moz-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: -webkit-linear-gradient(left, #012462 50%, #0082E8 100%);
	background: linear-gradient(to right, #012462 50%, #0082E8 100%);
    transition: all .2s cubic-bezier(.04, .435, .315, .9);
    transform: scaleY(1);
}
/*上の画面*/
.loader_cover-up {
    transform-origin: center top;
}

/*下の画面*/
.loader_cover-down {
    position: absolute;
    bottom: 0;
    transform-origin: center bottom;
}
/*クラス名がついたらY軸方向に0*/
.coveranime {
    transform: scaleY(0);
}

.brackets{
	position: relative;
}

.brackets::before,
.brackets::after {
    content: '';
    width: 8px;
    height: 8px;
    position: absolute;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.brackets::before{
	border-left: 1px solid #ffffff;
	border-top: 1px solid #ffffff;
	top: 0;
	left: 0;
}

.brackets::after{
	border-right: 1px solid #ffffff;
	border-bottom: 1px solid #ffffff;
	bottom: 0;
	right: 0;
}

.border-blue.brackets::before,
.border-blue.brackets::after{
	border-color: #003780;
}

.graduate-page .training-area h4.border-blue.brackets.active::before,
.graduate-page .training-area h4.border-blue.brackets.active::after{
	width: calc(100% - 1px);
	height: calc(100% - 1px);
}

.main-contnets.company-page .concept-sec .img-flex > div{
	width: 250px;
}

.single-sec .eyecatch{
	margin-bottom: 40px;
}

.single-sec .editor h2{
	font-size: 20px;
	font-weight: 400;
	letter-spacing: 0.2em;
	line-height: 1.9;
	margin-bottom: 20px;
	padding: 0 15px 15px;
	position: relative;
}

.single-sec .editor h2:before{
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px
}

.single-sec .editor h2:after{
	content: "";
	background: #003780;
	height: 1px;
	width: 0;
	position: absolute;
	left: 0;
	bottom: 0;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.single-sec .editor h2.active:after{
	width: 100%;
}

.single-sec .editor .name-blo{
	display: flex;
	align-items: center;
	margin-bottom: 60px;
	padding: 0 15px;
}

.single-sec .editor .name-blo .label-title{
	color: #ffffff;
	font-size: 13px;
	width: 113px;
	margin-right: 20px;
}

.single-sec .editor .name-blo .name{
	font-size: 20px;
	letter-spacing: 0.2em;
}

.single-sec .editor .name-blo .name span{
	font-size: 12px;
	letter-spacing: 0.075em;
	margin-left: 10px;
}

.single-sec .editor h3{
	color: #0F32AA;
	font-size: 18px;
	font-weight: 400;
	letter-spacing: 0.2em;
	margin-bottom: 15px;
}

.single-sec .editor p{
	font-family: "Noto Sans JP", sans-serif;
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2.13;
}

.single-sec .editor p + h3,
.single-sec .editor p:last-child{
	margin-top: 60px;
}

.graduate-page.mid-career-page .border-title{
	border-color: #595757;
	font-size: 18px;
	margin-bottom: 30px;
	padding: 0 15px 15px 15px;
	width: 100%;
}

.graduate-page.mid-career-page .border-title:before{
	background: #595757;
}

.main-contnets.mid-career-page .row p {
    font-size: 15px;
    letter-spacing: 0.035em;
    line-height: 2.13;
}

.mid-career-box > .blo:not(:last-child){
	margin-bottom: 100px;
}

.group-list-box .border-title {
    border-bottom: 1px solid #003780;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.075em;
    margin-bottom: 20px;
    padding: 0 0 15px 10px;
    display: flex;
    align-items: flex-end;
}

.group-list-box .border-title::before {
	content: "";
	background: #003780;
	border-radius: 50%;
	height: 8px;
	width: 8px;
	position: absolute;
	left: 0;
	bottom: -4px;
}

.group-list-box .border-title span{
	font-size: 13px;
	font-weight: 400;
    letter-spacing: 0.075em;
    margin-left: 10px;
}

.group-list-box .border-title a:after{
	content: "";
	background: url(../images/common/window-icon.png);
	background-size: cover;
	height: 12px;
	width: 15px;
	display: inline-block;
	margin-left: 0;
}

.group-list-box .blo p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2;
}

.group-list-box .blo:not(:last-child){
	margin-bottom: 80px;
}

.main-contnets.lower-top-page.group-page{
	padding-bottom: 0;
}

.privacy-sec p{
	font-size: 15px;
	letter-spacing: 0.035em;
	line-height: 2.13;
}

.privacy-sec p + h3{
	margin-top: 80px;
}

.privacy-sec h3{
	font-size: 18px;
	font-weight: 500;
	letter-spacing: 0.075em;
	margin-bottom: 30px;
}

.privacy-sec .label-title:before {
	width: calc(100% - 30px);
}

.site-map-out .site-map-side{
	width: 320px;
}

.site-map-out .site-map-side .blo:not(:last-child){
	margin-bottom: 70px;
}

.site-map-out .site-map-side h3{
	width: 100%;
}

.site-map-out .site-map-side h3 a{
	border-bottom: 1px solid #595757;
	display: block;
	font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.2em;
    padding: 0 0 15px 15px;
}

.site-map-out .site-map-side h3 a::before {
    content: "";
    background: #595757;
    border-radius: 50%;
    height: 8px;
    width: 8px;
    position: absolute;
    left: 0;
    bottom: -4px;
}

.site-map-out .site-map-side h3 a span{
	font-size: 16px;
    font-weight: 400;
    letter-spacing: 0.1em;
    margin-left: 10px;
}

.site-map-out .site-map-side ul{
	margin-top: 20px;
}

.site-map-out .site-map-side ul li a{
	font-size: 15px;
    letter-spacing: 0.035em;
    line-height: 2.13;
}

.site-map-out .site-map-side ul li a:before{
	content: "▷";
	margin-right: 5px;
}

.privacy-sec p > span{
	display: flex;
}

.main-contnets.lower-top-page.no-link-page{
	padding: 0;
}

.main-contnets.blue-contents-bg section.no-link-sec{
	height: 100vh;
}

.pc-map .map-list{
	position: absolute;
}

.pc-map .map-list1{
	left: 70px;
	top: 84px;
}

.pc-map .map-list2{
	right: 55px;
	top: -2px;
}

.pc-map .map-list3{
	right: -135px;
	top: 171px;
}

.pc-map .map-list4{
	right: -70px;
	top: 296px;
}

.pc-map .map-list5{
	right: -8px;
	top: 380px;
}

.pc-map .map-list6{
	top: 380px;
	left: 190px;
}

.pc-map .map-list7{
	right: 45px;
	bottom: 237px;
}

.pc-map .map-list8{
	right: -95px;
	bottom: 57px;
}

.pc-map .map-list9{
	left: 310px;
	bottom: 51px;
}

.pc-map .map-list10{
	left: 308px;
	bottom: 4px;
}

.pc-map .map-list li{
	cursor: pointer;
	letter-spacing: 0.035em;
	line-height: 2.18;
	padding: 0 10px;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.pc-map .map-list li:before{
	content: "▷";
}

.single-links p a{
	color: #595757;
	font-size: 14px;
	letter-spacing: 0.05em;
}

.single-links p.prev-link-s a:before,
.single-links p.next-link-s a:after{
	content: "";
	width: 12px;
	height: 12px;
	border: 1px solid;
	display: inline-block;
	line-height: 1;
	vertical-align: middle;
	transform: rotate(45deg);
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}

.single-links p.prev-link-s a::before{
	border-color: transparent transparent #595757 #595757;
	margin-right: 5px;
}

.single-links p.next-link-s a::after{
	border-color: #595757 #595757 transparent transparent;
	margin-left: 5px;
}

.pc-services-sec .page-link-blo{
	max-width: 700px;
	margin: -100px auto 100px;
}

.pc-services-sec .page-link-blo > *{
	margin-top: 100px;
}

.pc-services-sec .page-link-blo > a{
	filter: brightness(1.0);
}

.pc-services-sec .service-slider .blo{
	margin: 0 auto 80px;
}

.pc-services-sec .service-slider .blo:last-chils{
	margin-bottom: 0;
}

.pc-services-sec .service-slider .blo .txt{
	margin-top: 0;
}
/*------------------------------------------------------------
	ホバーエフェクト
------------------------------------------------------------*/
	.f-menu-area .f-menu-list li a:hover h4:after{
		width: 95%;
	}
	
	.f-menu-area .inner > a:hover{
		filter: brightness(1.15);
	}
	
	footer .footer .f-menu li a:hover,
	footer .f-nav > li:nth-child(1) a:hover,
	footer .f-nav > li:nth-child(2) a:hover,
	footer .f-nav > li:nth-child(3) a:hover,
	footer .f-nav > li:nth-child(4) a:hover,
	footer .f-nav > li:nth-child(5) a:hover{
		background: #0F32AA;
	}
	
	.mynavi-link:hover{
		background: #005AC8;
	}
	
	.mynavi-link:hover img{
		-webkit-filter: brightness(0) invert(1);
		filter: brightness(0) invert(1);
	}
	
	.link-btn:hover{
		border-color: #005AC8;
		background: #005AC8;
		color: #ffffff;
	}
	
	.recruit-btn:hover::before,
	.recruit-btn:hover::after{
		height: calc(100% - 1px);
		width: calc(100% - 1px);
	}
	
	.staff-list .blo a:hover .img {
		filter: grayscale(0);
	}
	
	.main-contnets.safety-page .safety-list li:hover:not(:first-child) {
		background: #0f32aa;
	}
	
	.site-map-out .site-map-side a:hover{
		color: #0F32AA;
	}
	
	.pc-map .map-list li:hover{
		background: #ffffff;
		color: #0F32AA;
	}
	
	.more-link:hover{
		color: #ffffff;
	}
	
	.more-link:hover::before{
		background: #0F32AA;
	}

	.single-links p a:hover{
		color: #0F32AA;
	}

	.single-links p.prev-link-s a:hover::before{
		border-color: transparent transparent #0F32AA #0F32AA;
	}

	.single-links p.next-link-s a:hover::after{
		border-color: #0F32AA #0F32AA transparent transparent;
	}

@media all and (min-width: 768px){
	.header .nav-menu li a:hover{
		background-size: 100% 100%;
	}
	
	.aco-btn.brackets:hover::before,
	.aco-btn.brackets:hover::after{
		height: calc(100% - 1px);
		width: calc(100% - 1px);
	}
	
	.scroll_container {
		height: 3500px;
	}
 
	.sticky_wrap {
		position: sticky;
		overflow: hidden;
		top: 0;
		height: 100vh;
	}
 
	.horizontal_scroll {
		position: absolute;
		top: 100px;
		height: auto;
		width: 4500px;
		will-change: transform;
		display: flex;
		justify-content: space-between;
		align-items: stretch;
		left: calc(50% - 340px);
	}
	
	.horizontal_scroll > .blo{
		background: none;
		padding: 0;
		width: 600px;
//		height: 810px;
//		min-width: 680px;
	}
	
	.horizontal_scroll > .blo:not(:last-child){
//		margin-right: 50px;
	}
	
	.horizontal_scroll > .blo:first-child{
//		margin-left: 25vw;
	}
	
	body.services-body{
		overflow: unset;
	}
	
	.group-list-box .blo p span{
		display: none;
	}

	.pc-services-sec .page-link-blo > a:hover{
		filter: brightness(1.20);
	}

}
/*------------------------------------------------------------
	レスポンシブ
------------------------------------------------------------*/
@media all and (min-width: 0) and (max-width: 767px){
	.main-contnets.blue-contents-bg::before {
		background: url(../images/top/contents-bg.png) no-repeat;
		background-size: 100% auto;
		background-position: center top;
	}
	
	.main-contnets.blue-contents-bg::after {
		background: url(../images/top/contents-bg2.png) no-repeat;
		background-size: 100% auto;
		background-position: center bottom;
	}
	
	.main-contnets.top .scroll {
		font-size: 13px;
		margin-bottom: 70px;
	}
	
	.main-contnets.top .concept-sec .img {
		width: 86%;
	}
	
	.main-contnets.top .concept-sec .img .blo:nth-child(2){
		width: 64%;
	}
	
	.main-contnets.top .concept-sec .txt{
		margin: 0 auto;
		width: 270px;
	}
	
	.main-contnets.top .concept-sec h1{
		line-height: 1.38;
	}
	
	.main-contnets.top .concept-sec .sub-title {
		margin-top: 10px;
	}
	
	.main-contnets.top .concept-sec .img > .blo:not(:first-child){
		margin-top: 30px;
	}
	
	.main-contnets.top .concept-sec .flex.reverse,
	.main-contnets.top .concept-sec .sp-reverse {
		flex-direction: column-reverse;
	}
	
	.main-contnets.top .concept-sec .img.txt-right .blo{
		margin-left: auto;
	}

	.main-contnets.top .concept-sec .sp-reverse .img{
		margin-right: auto;
	}

	.main-contnets.top .concept-sec .sp-reverse .img .blo:nth-child(1){
		width: 64%;
	}

	.main-contnets.top .concept-sec .sp-reverse .img .blo:nth-child(2){
		width: 100%;
	}
	
	.f-menu-area{
		padding: 50px 0;
	}
	
	.f-menu-area .f-menu-list{
		margin-bottom: -20px;
	}

	.f-menu-area .f-menu-list li{
		margin-bottom: 20px;
		width: calc(50% - 10px);
	}
	
	.sc-img1 {
		background: url(../images/top/top-sc1_sp.png) no-repeat;
		background-size: cover;
	}
	
	.sc-img2{
		background: url(../images/top/top-sc2_sp.png) no-repeat;
		background-size: cover;
	}
	
	.mv-slider .slick-dots {
		right: 20px;
		top: calc(100% + 20px);
	}
	
	.mv-slider .slick-dots li {
		height: 12px;
		margin: 0 5px;
		width: 12px;
	}
	
	.main-contnets.top .concept-sec.sec1 .img {
		bottom: 0;
		position: relative;
		margin-bottom: 60px;
	}
	
	.parallax-sec:before,
	.parallax-sec:after{
		display: none;
	}
	
	.parallax-sec.para-img1,
	.parallax-sec.para-img2 {
		background: none;
	}
	
	.main-contnets.top .concept-sec.sec2 .img {
		top: 0;
		margin-bottom: 50px;
	}
	
	.main-contnets.safety-page .safety-list {
		margin-top: -10px;
		margin-right: 0;
	}

	.main-contnets.safety-page .safety-list li {
		margin-top: 10px;
		margin-right: 0;
	}
	
	.main-contnets.lower-page {
		padding: 120px 0 60px;
	}
	
	.page-title {
		margin: 0 auto 60px;
	}
	
	.page-title .en {
		font-size: 36px;
		letter-spacing: 0.05em;
	}
	
	.main-contnets.safety-page .sec1 {
		padding-bottom: 100px;
	}
	
	.main-contnets.safety-page .sec-num-title .num {
		font-size: 38px;
		margin-right: 10px;
		width: 50px;
	}
	
	.main-contnets.safety-page .sec-num-title img{
		display: none;
	}
	
	.main-contnets.safety-page .sec-num-title p{
		width: calc(100% - 60px);
	}
	
	.main-contnets.safety-page .sec-num-title {
		margin-bottom: 30px;
	}
	
	.safety-list-sec .sec-num .img-list .blo.w180{
		width: auto;
	}

	.safety-list-sec .sec-num .img-list .blo:not(:last-child) {
		margin-right: 0;
		margin-bottom: 25px;
	}
	
	.safety-list-sec .sec-num:not(:last-child) {
		margin-bottom: 60px;
	}
	
	.main-contnets.safety-page .safety-list-sec .sec-blo:not(:last-child) {
		margin-bottom: 100px;
	}
	
	.table-box .row.sp_only_row{
		display: none;
	}
	
	.table-box.safety-table .row > div{
		display: block;
	}
	
	.table-box.safety-table .th {
		width: 100%;
	}
	
	.table-box.safety-table .th, .table-box.safety-table .td {
		padding: 5px 15px;
		margin-bottom: 0;
	}
	
	.table-box.safety-table .th,
	.table-box.safety-table .td{
		border: unset;
	}
	
	.store-table thead th {
		background: unset;
	}
	
	.store-table th:first-child,
	.store-table td:first-child {
		border-left: 1px solid #003780;
	}
	
	.store-table th:last-child,
	.store-table td:last-child{
		border-right: 1px solid #003780;
	}
	
	.table-box.safety-table .store-table thead th p {
		color: #595757;
	}
	
	.store-table th, .store-table td {
		padding: 10px;
	}
	
	.lower-mv {
		margin-bottom: -20px;
	}
	
	.concept-txt h2 {
		font-size: 22px;
	}
	
	.main-contnets.lower-top-page {
		padding: 120px 0 60px;
	}
	
	.main-contnets.company-page .concept-sec .img-flex > div {
		width: 112%;
		margin: 0 -6% 10px;
	}

	.main-contnets.company-page .concept-sec .img-flex > div:last-child{
		margin-bottom: 0;
	}
	
	.main-contnets.company-page .concept-sec,
	.main-contnets.services-page .concept-sec,
	.main-contnets.network-page .concept-sec,
	.main-contnets.network-page .recruit-sec {
		padding-bottom: 50px;
	}
	
	.aco-btn a {
		padding: 0 10px;
	}
	
	.aco-btn span {
		font-size: 15px;
		margin-left: 10px;
	}
	
	.aco-btn a:after{
		right: 10px;
	}
	
	.main-contnets.company-page .aco-btn-sec .aco-in {
		padding: 30px 0;
	}
	
	.main-contnets.company-page .aco-btn-sec .aco-in p + h3,
	.main-contnets.company-page .aco-btn-sec .aco-in .company-table + h3 {
		margin-top: 40px;
	}
	
	.company-table.table-box .row > div{
		display: block;
	}
	
	.company-table .th{
		width: 100%;
	}
	
	.company-table .th,
	.company-table .td,
	.company-table .row:last-child .th,
	.company-table .row:last-child .td{
		border: none;
	}
	
	.company-table .th, .company-table .td {
		padding: 5px 10px;
	}
	
	.service-slider .blo{
		background-image: url(../images/services/service-bg_sp.png);
		background-size: cover;
		background-repeat: no-repeat;
		background-position: center top;
		margin: 0 15px;
		padding: 15px;
		width: 72vw;
	}
	
	.service-slider .blo h3 span {
		display: block;
		font-size: 50px;
		margin-right: 0;
		margin-bottom: 5px;
	}
	
	.service-slider .blo h3 span:before {
		font-size: 18px;
	}
	
	.service-slider .blo h3 {
		font-size: 20px;
		margin-bottom: 15px;
	}
	
	.service-slider .blo .txt {
		margin-top: 20px;
	}
	
	.service-slider .blo .txt h4 {
		font-size: 16px;
	}
	
	.service-slider .blo .label-blo .flex-label {
		align-items: flex-start;
		flex-direction: column;
	}
	
	.service-slider .blo .label-blo .flex-label p {
		font-size: 14px;
		margin-left: 0;
		top: 3px;
	}
	
	.services-sec .arrows-area{
		display: flex;
		justify-content: center;
		margin: 0 auto 70px;
	}
	
	.services-sec .arrows-area .slick-arrow-c{
		background: #ffffff;
		border-radius: 50%;
		margin: 0 10px;
		height: 40px;
		width: 40px;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	
	.services-sec .arrows-area .slick-arrow-c span{
		background: #005ac8;
		height: calc(tan(60deg) * 20px / 2);
		display: block;
		width: 15px;
		position: relative;
	}
	
	.services-sec .arrows-area .slick-prev-c span{
		clip-path: polygon(0 50%, 100% 0, 100% 100%);
		left: -2px;
	}
	
	.services-sec .arrows-area .slick-next-c span{
		clip-path: polygon(0 0, 100% 50%, 0 100%);
		right: -2px;
	}
	
	.network-page .pc-map{
		display: none;
	}
	
	.network-page .sp-map h3{
		border-bottom: 1px solid #ffffff;
		font-size: 22px;
		font-weight: 500;
		letter-spacing: 0.1em;
		margin-bottom: 30px;
		padding: 0 0 10px 10px;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
	
	.network-page .sp-map h3::before {
		content: "";
		background: #ffffff;
		border-radius: 50%;
		height: 8px;
		width: 8px;
		position: absolute;
		left: 0;
		bottom: -4px;
	}
	
	.network-sec::before {
		top: -15px;
	}
	
	.network-page .sp-map .map-list{
		padding: 0 10px;
	}

	.network-page .sp-map .map-list li{
		font-size: 17px;
		letter-spacing: 0.075em;
	}

	.network-page .sp-map .map-list li:before{
		content: "▷";
		margin-right: 5px;
	}

	.network-page .sp-map .map-list li:not(:last-child){
		margin-bottom: 10px;
	}
	
	.network-page .sp-map .map-list + h3{
		margin-top: 40px;
	}
	
	.network-list .border-title {
		font-size: 18px;
		letter-spacing: 0.1em;
		padding: 0 0 10px 10px;
		align-items: flex-start;
		flex-direction: column;
	}
	
	.network-list .border-title span {
		font-size: 10px;
		margin-top: 5px;
	}
	
	.network-list .blo .body .img,
	.network-list .blo .body .img img,
	.network-list .blo .body .address{
		width: 100%;
	}

	.network-list .blo .body .img{
		text-align: center;
		margin-bottom: 15px;
	}
	
	.network-list .blo:not(:last-child) {
		margin-bottom: 80px;
	}
	
	.lower-title {
		width: 100%;
		margin: 0 auto 60px;
	}
	
	.graduate-page .border-title {
		padding: 0 10px 10px 10px;
		width: 100%;
	}
	
	.staff-list .blo {
		width: 100%;
	}
	
	.staff-list .blo:not(:last-child){
		margin-bottom: 30px;
	}
	
	.staff-list .blo .img {
		filter: grayscale(0);
	}
	
	.staff-list .blo .txt .more-link{
		position: absolute;
		right: 0;
		bottom: 0;
		padding: 0.8em 2em 0.4em 1.2em;
	}
	
	.staff-list .blo .txt .more-link::before {
		width: 80%;
	}
	
	.graduate-page .sec2 {
		padding: 60px 0;
	}
	
	.graduate-page .training-area h4 {
		font-size: 22px;
		margin: 0 auto 60px;
	}
	
	.training-box > div {
		max-width: 100%;
	}
	
	.training-box > div:not(:last-child){
		margin-bottom: 50px;
	}
	
	.graduate-page .sec3 {
		padding-top: 60px;
	}
	
	.graduate-page .border-title span{
		font-size: 28px;
	}
	
	.mid-career-box > .blo:not(:last-child) {
		margin-bottom: 60px;
	}
	
	.group-sec{
		padding-top: 0;
	}
	
	.group-list-box .border-title {
		font-size: 18px;
		letter-spacing: 0.1em;
	}
	
	.group-list-box .border-title span{
		display: none;
	}
	
	.group-list-box .border-title a:after {
		position: absolute;
		right: 0;
		bottom: 20px;
	}
	
	.group-list-box .blo p{
		font-size: 14px;
	}
	
	.group-list-box .blo p span{
		display: block;
		font-size: 13px;
	}
	
	.group-list-box .blo:not(:last-child) {
		margin-bottom: 60px;
	}
	
	.privacy-sec h3{
		width: 100%;
	}
	
	.privacy-sec p + h3 {
		margin-top: 60px;
	}
	
	.site-map-out .site-map-side .blo:not(:last-child),
	.site-map-out .site-map-side:not(:last-child){
		margin-bottom: 50px;
	}
	
	.site-map-out .site-map-side{
		width: 100%;
	}
	
	.company-table .row:last-child .th,
	.company-table .row:last-child .td{
		border-bottom: 1px solid #003780;
	}
	
	.table-out-flex .blo .company-table .th{
		border-top: 1px solid #003780;
		display: table-cell;
		width: calc(100% - 80px);
	}
	
	.table-out-flex .blo .company-table .td{
		border-top: 1px solid #003780;
		display: table-cell;
		width: 80px;
	}
	
	.company-table .td .posi-flex > p:first-child {
		margin-right: 10px;
		width: calc(100% - 80px);
	}
	
	.table-box.safety-table .v-top p{
		-ms-writing-mode: tb-rl;
		writing-mode: vertical-rl;
		width: 30px;
		white-space: pre;
	}

}