﻿@charset “UTF-8”;

html{
	font-size: 16px;
}
body{
	font-family: 'Noto Sans JP',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	position: relative;
	font-weight: 400;
	z-index: 0;
	background-color: #ffffff;
	color: #4e4e4e;
	animation: fadeIn 1.5s ease-in-out 0s 1 normal;
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

.serif{
	font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}

/*     ヘッダー    */

.l-header{
  position: fixed;
	top: 0;
	left: 0;
  z-index: 100;
	width: 100%;
	padding: 10px 0 10px;
	transition: 0.3s;
}

.l-header__inner{
	display: flex;
	height; 40px;
	flex-flow: row nowrap;
	justify-content: space-between;
	align-items: center;
	margin: 0 10px;
}
.l-header__logo{
	flex: 0 0 150px;
}
.l-header__logo .top,
.l-header__logo .fixed{
	max-width: 100%;
	height: auto;
	line-height: 1;
}
.l-header__logo .top{
	display: block;
}
.l-header__logo .fixed{
  display: none;
}

@media screen and (min-width:768px){
	.l-header{
		padding: 35px 0 10px;
		transition: 0.3s;
	}
	.l-header__inner{
		display: flex;
		height; 40px;
		margin: 0 40px;
	}
	.l-header__logo{
		flex: 0 0 200px;
	}

	.l-header__nav{
		display: block;
	}
	.l-header__nav-list{
		display: flex;
		flex-flow: row nowrap;
		justify-content: flex-start;
	}
	.l-header__nav-item{
		margin-right: 30px;
		padding: 20px 0;
	}
	.l-header__nav-item > a{
		position: relative;
		padding: 0 5px;
	  color: #ffffff;
		transition: all .2s ease-in-out;
	}
	.l-header__nav-item > a::after{
		content: "";
		position: absolute;
		bottom: -3px;
		left:0;
		width: 100%;
		height: 1px;
		background: #ffffff;
		transform: scale(0,1);
		transform-origin: right top;
		transition: transform .2s;
	}
	.l-header__nav-item > a:hover::after,
	.l-header__nav-item .is-hover::after{
		transform: scale(1,1);
		transform-origin: left top;
	}

	.nav-submenu-sp{
		display: none;
	}

}

@media screen and (min-width:769px) and (max-width:1279px){
	.l-header__inner{
		margin: 0 0 0 20px;
	}
}

/*     スクロール後ヘッダー    */

.l-header.is-fixed{
	margin: 0;
	padding: 10px 0 10px;
	background: #ffffff;
	box-shadow: 0 2px 3px #eaeaea;
}
.l-header.is-fixed .l-header__logo .top{
	display: none;
}
.l-header.is-fixed .l-header__logo .fixed{
  display: block;
}

@media screen and (min-width:768px){
	.l-header.is-fixed{
		padding: 15px 0 0;
		box-shadow: 0 2px 3px #eaeaea;
	}
	.l-header.is-fixed .l-header__nav-item{
		padding: 20px 0 25px;
	}
	.l-header.is-fixed  .l-header__nav-item > a{
	  color: #2d2d2d;
	}
	.l-header.is-fixed .l-header__nav-item > a:hover,
	.l-header.is-fixed .l-header__nav-item .is-hover{
		color: #85a0e7;
	}
	.l-header.is-fixed .l-header__nav-item > a::after{
		background: #85a0e7;
	}
	.l-header.is-fixed .l-header__nav-item .nav-submenu-pc{
		top: 78px;
	}

}


/*　ドロップダウンメニュー */
.nav-submenu-pc{
	display: none;
}

@media screen and (min-width:768px){
	.nav-submenu-pc{
		opacity: 0;
		position: absolute;
		top: 90px;
		left: 0;
		z-index: -99;
		display: block;
		width: 100vw;
		padding: 40px 70px 55px;
		background: #ffffff;
		transition: all .3s ease-out;
		transform: translate(0, -10px);
		transform-origin: top;
		pointer-events: none;
	}

	.nav-submenu-pc.is-open{
		opacity: 1;
		z-index: 100;
		transform: translate(0, 0);
		pointer-events: auto;
	}

	.nav-submenu__inner{
		display: flex;
	}

	.nav-submenu__contact{
		width: 37vw;
		margin: 0 auto;
	}

	.nav-submenu__header{
		width: 14%;
		min-width: 195px;
	}
	.nav-submenu__ttl{
		font-size: 1.75rem;
		letter-spacing: .3rem;
		margin-bottom: .3rem;
		color: #000000;
		font-weight: 600;
	}
	.nav-submenu__detail{
		font-size: .9rem;
		letter-spacing: .1rem;
	}

	.nav-submenu__card-list{
		display: flex;
		justify-content: space-between;
		box-sizing: border-box;
		width: 86%;
		padding-left: 28px;
		border-left: solid 1px #979797;
	}

	.nav-submenu__service .nav-submenu__card-list__item{
		width: calc((100% / 6) - 20px );
	}
	.nav-submenu__contact .nav-submenu__card-list__item{
		width: calc((100% / 2) - 20px );
	}

	.nav-submenu__thum{
		position: relative;
		flex: 0 0 auto;
		overflow: hidden;
		width: 100%;
		padding-top: 66.66666667%;
		margin-bottom: 12px;
	}
	.nav-submenu__thum::after{
		content: "";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-size: cover;
		background-position: center;
		transition: all .4s;
		transform: scale(1);
	}

	a:hover > .nav-submenu__thum::after{
		transform: scale(1.05);
	}

	.submenu-srvice-thum1::after{
		background-image: url(../img/common/submenu-srvice-thum_carrier.jpg);
	}
	.submenu-srvice-thum2::after{
		background-image: url(../img/common/submenu-srvice-thum_web.jpg);
	}
	.submenu-srvice-thum3::after{
		background-image: url(../img/common/submenu-srvice-thum_adv.jpg);
	}
	.submenu-srvice-thum4::after{
		background-image: url(../img/common/submenu-srvice-thum_system.jpg);
	}
	.submenu-srvice-thum5::after{
		background-image: url(../img/common/submenu-srvice-thum_media.jpg);
	}
	.submenu-srvice-thum6::after{
		background-image: url(../img/common/submenu-srvice-thum_hrd.jpg);
	}

	.submenu-contact-thum1::after{
		background-image: url(../img/common/submenu-contact-thum_corp.jpg);
	}
	.submenu-contact-thum2::after{
		background-image: url(../img/common/submenu-contact-thum_Individual.jpg);
	}

	.nav-submenu__text{
		font-size: 0.7rem;
		color: #5d5d5d;
	}

	.bg-transition::before{
		content: "";
		display: block;
		position: fixed;
		top: 0;
		left: 0;
		z-index: -1;
		width: 100vw;
		height: 100vh;
		background: transparent;
		transition: all .2s ease-in-out;
	}
	.is-bg::before{
		z-index: 10;
		background: rgba(0,0,0,.4);
	}

}

@media screen and (min-width:769px) and (max-width:1279px){
	.nav-submenu-pc{
		padding: 40px 50px 55px;
	}
	.nav-submenu__contact{
		width: 50vw;
		max-width: 480px;
	}

	.nav-submenu__header{
		width: 14%;
		min-width: 150px;
	}
	.nav-submenu__ttl{
		font-size: 1.5rem;
		letter-spacing: .2rem;
		margin-bottom: .3rem;
		color: #000000;
		font-weight: 600;
	}
}


/*     フッター    */

.l-footer{
	width: 100%;
	padding: 40px 0 0;
	background: #1b2b56;
	color: #ffffff;
}

.l-footer__inner{
	width: 88%;
	margin: auto;
}
.l-footer__info{
	text-align: center;
}
.l-footer__logo{
	margin: 0 0 5px;
}
.l-footer__logo img{
	width: 180px;
}
.l-footer__address{
	font-size: .7rem;
}
.l-footer__nav-wrap{
	display: flex;
	justify-content: flex-start;
}
.l-footer__nav-pc{
	display: none;
}

.l-footer__nav-pc{
	font-size: .95rem;
}
.l-footer__nav-pc a{
	color: #ffffff;
}

.l-footer__nav-item{
	margin: 16px 0 26px 0;
	font-weight: 600;
}

.l-footer__nav-item__child{
	margin: -14px 0 0 5px;
	font-size: .75rem;
}
.l-footer__nav-item__child p{
	margin-bottom: 12px;
}

.l-footer__bottom{
	width: 88%;
	margin: 0 auto;
	padding: 26px 0 40px;
	font-size: .75rem;
	color: #ffffff;
}

.l-footer__sub-nav{
	display: flex;
	justify-content: center;
	margin-bottom: 32px;
}
.l-footer__sub-nav p:first-of-type{
	margin-right: 20px;
}
.l-footer__copy{
	text-align: center;
}



@media screen and (min-width:768px){
	.l-footer{
		padding: 85px 0 0;
	}
	.l-footer__inner{
		display: flex;
		justify-content: space-between;
		width: 94%;
		max-width: 1080px;
		margin: auto;
	}
	.l-footer__info{
		justify-content: flex-start;
		text-align: left;
	}
	.l-footer a{
		position: relative;
	}
	.l-footer__nav-wrap{
		margin: 0;
	}
	.l-footer__nav-pc a::after,
	.l-footer__sub-nav a::after{
		content: "";
		position: absolute;
		bottom: -4px;
		left:0;
		width: 100%;
		height: 1px;
		background: #ffffff;
		transform: scale(0,1);
		transform-origin: right top;
		transition: transform .2s;
	}
	.l-footer__nav-pc a:hover::after,
	.l-footer__sub-nav a:hover::after{
		transform: scale(1,1);
		transform-origin: left top;
	}
	.l-footer__logo{
		margin: 0 0 12px;
	}
	.l-footer__logo img{
		width: 220px;
	}
	.l-footer__address{
		font-size: .8rem;
	}

	.l-footer__nav-pc{
		display: block;
	}

	.l-footer__nav-item{
		margin: 16px 46px 26px 0;
	}

	.l-footer__bottom{
		display: flex;
		justify-content: flex-end;
		width: 94%;
		max-width: 1080px;
		margin: 0 auto;
		padding: 90px 0 70px;
		font-size: .75rem;
	}
	.l-footer__sub-nav{
		display: flex;
		justify-content: flex-end;
		margin: 0 80px 0 0;
	}
	.l-footer__sub-nav p{
		margin: 0 25px 0 0;
	}
}

/*    タイトルテキスト周り    */

.c-ttl01{
	font-size: 2.25rem;
	font-weight: 700;
	color: #0f0f0f;
	text-align: center;
}

.c-text01{
	font-size: .9rem;
	line-height: 2;
	font-weight: 400;
}

.c-text01 > p{
		margin-bottom: 1.8125rem;
}

.c-ttl02{
	font-size: 1.8rem;
	font-weight: 600;
}

@media screen and (min-width:768px){
	.c-ttl01{
		font-size: 4rem;
		text-align: left;
	}
	.c-text01{
		font-size: .875rem;
		line-height: 2.8;
		font-weight: 400;
	}
}

/*    ボタン    */

.c-btn{
	width: 220px;
	margin: 35px auto;
}
.c-btn a{
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
  height: 50px;
	border: solid 1px #000000;
	font-size: 0.9rem;
  text-align: center;
	color: #000000;
	transition: all .3s ease-in-out;
}
.c-btn .arrow{
	position: relative;
}
.c-btn .arrow::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 22px;
	margin: auto;
	width: 13px;
	height: 1px;
	background: #000000;
	transition: all .3s ease-in-out;
}
.c-btn .arrow::after{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 22px;
	margin: auto;
	width: 5px;
	height: 5px;
	border-top: solid 1px #000000;
	border-right: solid 1px #000000;
	transform: rotate(45deg);
	transition: all .3s ease-in-out;
}

.c-btn a:hover,
.c-btn input[type="button"]:hover{
	border: solid 1px #716cba;
	background: #716cba;
	color: #ffffff;
}

.c-btn .arrow:hover::before{
	background: #ffffff;
	transform: translate(7px,0);
}
.c-btn .arrow:hover::after{
	border-top: solid 1px #ffffff;
	border-right: solid 1px #ffffff;
	transform: translate(7px,0) rotate(45deg) scale(1.2,1.2);
}

.c-btn-white{

}
.c-btn-white a{
	border: solid 1px #ffffff;
	background: transparent;
	color: #ffffff;
}
.c-btn-white .arrow::before{
	background: #ffffff;
}
.c-btn-white .arrow::after{
	border-top: solid 1px #ffffff;
	border-right: solid 1px #ffffff;
}

.c-btn-white a:hover{
	background: #ffffff;
	border: solid 1px #000000;
	color: #000000;
}
.c-btn-white .arrow:hover::before{
	background: #000000;
}
.c-btn-white .arrow:hover::after{
	border-top: solid 1px #000000;
	border-right: solid 1px #000000;
}

@media screen and (min-width:768px){
	.c-btn{
		margin-right: 0;
		margin-left: 0;
	}
}

.c-btn2{
	width: 220px;
	margin: 35px 0 0;
}
.c-btn2 a{
	display: flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
  height: 55px;
	background-image: linear-gradient(to right, #a259e7, #1e3da1 50%, #38a5de);
	background-size: 200% 100%;
	background-position: right center;
	font-size: 0.9rem;
  text-align: center;
	color: #ffffff;
	transition: all .4s ease-in-out;
}
.c-btn2 .arrow{
	position: relative;
}
.c-btn2 .arrow::before{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 22px;
	margin: auto;
	width: 13px;
	height: 1px;
	background: #ffffff;
	transition: all .3s ease-in-out;
}
.c-btn2 .arrow::after{
	content: "";
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 22px;
	margin: auto;
	width: 5px;
	height: 5px;
	border-top: solid 1px #ffffff;
	border-right: solid 1px #ffffff;
	transform: rotate(45deg);
	transition: all .3s ease-in-out;
}

.c-btn2 a:hover{
	background-position: left center;
}

.c-btn3{
	position: relative;
	margin: 24px 27px 0 0;
	text-align: right;
}
.c-btn3::after{
	content: "";
	display: block;
	position: absolute;
	bottom: -3px;
	right: 0;
	width: 96px;
	height: 1px;
	background: #000000;
}

.c-btn-center{
	margin-right: auto;
	margin-left: auto;
}

/*       下層 kv 共通     */

.p-kv-lower{
	width: 100%;
	height: 146.6667vw;
	position: relative;
	z-index: 0;
	background-size: cover;
	background-position: center;
	margin-bottom: 80px;
}

.p-kv-lower::before{
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: 1;
	background: rgba(0,0,0,.2);
}

.p-kv-lower__ttl{
	position: absolute;
  bottom: 34%;
	right: 0;
	left: 0;
	z-index: 10;
	margin: auto;
	color: #ffffff;
	overflow: hidden;
	text-align: center;
}
.p-kv-lower__ttl__inner{
	transition: all ease .7s;
	transform: translateY(3.3rem);
	opacity: 0;
}
.p-kv-lower__ttl__inner.start{
	transform: translateY(0);
	opacity: 1;
}
.p-kv-lower__ttl .main{
	font-size: 2.16667rem;
	font-weight: 700;
	margin-bottom: .7rem;
	letter-spacing: .15rem;
}
.p-kv-lower__ttl .sub{
	position: relative;
	font-size: 1.6rem;
	letter-spacing: .05rem;
}

.p-kv-lower__ttl .sub::before{
	content: "";
	display: block;
	position: absolute;
	top: -2px;
	right: 0;
	left: 0;
	margin: auto;
	width: 105px;
	height: 1px;
	background: #ffffff;
}

.c-lower-ttlgroup{
	position: relative;
	margin: 65px 0 50px;
}
.c-lower-ttlgroup.center{
	text-align: center;
}

.c-lower-ttlgroup::after{
	content: "";
	display: block;
	position: absolute;
	top: -15px;
	left: 0;
	width: 55px;
	height: 1px;
	background: #212121;
}
.c-lower-ttlgroup.center::after{
	right: 0;
	lef: 0;
	margin: auto;
}

.c-lower-ttl{
	font-size: 1.625rem;
	font-weight: 600;
	letter-spacing: .14em;
	margin-bottom: .2em;
	color: #0f0f0f;
}
.c-lower-subttl{
	font-size: .8125rem;
	color: #6d7eab;
	font-weight: 600;
	letter-spacing: .15em;
}

.p-lower-content{
	margin-bottom: 80px;
}

@media screen and (min-width:768px){
	.p-kv-lower{
		height: 650px;
		margin-bottom: 160px;
	}
	.p-kv-lower__ttl{
		position: absolute;
	  bottom: 100px;
		left: 7%;
		color: #ffffff;
		display: flex;
		align-items: baseline;
		text-align: left;
		overflow: hidden;
	}
	.p-kv-lower__ttl__inner{
		display: flex;
		align-items: baseline;
		transition: all ease .7s;
		transform: translateY(3.3rem);
		opacity: 0;
	}
	.p-kv-lower__ttl .main{
		font-size: 3rem;
		font-weight: 700;
		margin: 0 .8rem 0 0;
		letter-spacing: .15rem;
	}
	.p-kv-lower__ttl .sub{
		position: relative;
		font-size: 1.6rem;
		padding: 0 0 0 .8rem;
		letter-spacing: .05rem;
	}
	.p-kv-lower__ttl .sub::before{
	top: 0;
	bottom: 1px;
	left: 0;
	margin: 0;
	width: 2px;
	height: 27px;
	}

	.c-lower-ttlgroup{
		margin: 75px 0 60px;
	}

	.c-lower-ttlgroup::after{
		top: -20px;
	}

	.c-lower-ttl{
		font-size: 1.75rem;
		margin-bottom: .5em;
	}
	.c-lower-subttl{
		font-size: .9rem;
	}

	.p-lower-content{
		margin-bottom: 180px;
	}

}


/*　NEWSリスト */

.p-news-list{
  border-top: solid 1px #c8c8c8;
}

.p-news-list__item{
  border-bottom: solid 1px #c8c8c8;
}


.p-news-list__body{
  display: flex;
	flex-flow: row wrap;
	align-items: center;
  padding: 1.3rem 1.1rem;
	line-height: 1;
  color: #3b3b3b;
	font-size: .9rem;
}

.p-news-list__day,
.p-news-list__category,
.p-news-list__ttl{
	margin: 0 5px;
}

.p-news-list__category{
	margin: 0 8px;
	padding: 6px 10px;
	border: solid 1px #4d92d9;
	border-radius: 3px;
	color: #4d92d9;
	line-height: 1;
}
.p-news-list__ttl{
	width: 100%;
	margin: 8px 0 0;
	line-height: 1.3;
}

@media screen and (min-width:768px){

	.p-news-list__body{
		flex-flow: row nowrap;
 		padding: 2.5rem 1.6rem;
	}

	.p-news-list__category{
		font-size: 1rem;
	}
	.p-news-list__ttl{
		width: auto;
		margin: 0;
		line-height: 1;
	}
	.p-news-list__item a{
		transition: all .3s;
	}
	.p-news-list__item a:hover{
		color: #a1a1a1;
	  transform: translate(8px,0);
	}
	a:hover .p-news-list__category{
		border: solid 1px #a0bddb;
		color: #a0bddb;
	}
}