@charset "UTF-8";


.p-main_visual_wrap{
	position: relative;
	height: 636px;
	background-color: #eee;
}

.p-main_visual,
.p-main_visual_in{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.p-main_visual{
	z-index: 2;
}

.p-main_visual_in{
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: none;
}

.p-main_visual_img{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.p-main_visual_img .swiper-container_wrap,
.p-main_visual_img .swiper-container,
.p-main_visual_img .swiper-wrapper
.p-main_visual_img .swiper-slide,
.p-main_visual_img .m-img_cover{
	width: 100%;
	height: 100%;
}

.p-mv_scroll{
	position: absolute;
	right: 70px;
	bottom: 30px;
}

@media screen and (max-width: 767px) {
	.p-main_visual_wrap{
		height: 125vw;
	}
	
	.p-mv_scroll{
		right: 4vw;
		bottom: 4vw;
	}
	
}


.p-top_headnews{
	padding-top: 30px;
	padding-bottom: 30px;
}

.p-top_headnews_in{
	max-width: 1000px;
}

.p-top_headnews .m-news_list_wrap{
	border-top: none;
}

.p-top_headnews .m-news_list_item{
	padding-top: 0px;
	padding-bottom: 0px;
	border-bottom: none;
}

.p-top_headnews .m-news_list_content{
	font-size: 1.7rem;
}

@media screen and (max-width: 767px) {
	.p-top_headnews{
		padding-top: 8.666vw;
		padding-bottom: 9.333vw;
	}

	.p-top_headnews_in{
		max-width: none;
	}

	.p-top_headnews .m-news_list_wrap{
		border-top: none;
	}

	.p-top_headnews .m-news_list_item{
		padding-top: 0px;
		padding-bottom: 0px;
		border-bottom: none;
	}

	.p-top_headnews .m-news_list_content{
		font-size: 4vw;
		line-height: 1.8;
	}
}


.p-top_banner{
	padding-top: 42px;
	padding-bottom: 80px;
}

.p-top_banner_in{
	
}

.p-top_banner_area{
	
}

.p-top_banner_sp{
	
}

.p-top_banner_pc{
	
}

.p-top_banner_list_wrap{
	
}

.p-top_banner_list{
	display: flex;
	flex-wrap: wrap;
	margin: 0 -23px -23px 0;
}

.p-top_banner_list_item{
	width: 20%;
	padding: 0 23px 23px 0;
}


/*.swiper-container_wrap.type_banner .swiper-container */

.swiper-container_wrap.type_banner .swiper-container{
	overflow:  visible;
}

.swiper-container_wrap.type_banner .swiper-function_wrap{
	position: relative;
	margin: 9.33vw 0 0 0;
	display: flex;
	justify-content: center;
}

.swiper-container_wrap.type_banner  .swiper-function{
	position: relative;
	line-height: 1;
	padding: 0 11vw;
}

.swiper-container_wrap.type_banner .swiper-button-next,
.swiper-container_wrap.type_banner .swiper-button-prev{
	background-image: none !important;
	margin-top: -2.533vw;
	width: 2.533vw;
	height: 5.066vw;
	transform-origin: 50% 50%;
}

.swiper-container_wrap.type_banner .swiper-button-prev{
	left: 0;
	transform: rotate(-180deg);
}

.swiper-container_wrap.type_banner .swiper-button-next{
	right: 0;
}

.swiper-container_wrap.type_banner .svg_arrow{
	width: 100%;
}

.swiper-container_wrap.type_banner .svg_arrow polygon{
	fill: #0068b2;
}

.swiper-container_wrap.type_banner .swiper-pagination{
	position: static;
	line-height: 0;
	margin: 0 -4vw -4vw 0;
}

.swiper-container_wrap.type_banner .swiper-pagination-bullet{
	width: 2.666vw;
	height: 2.666vw;
	background-color: #cccccc;
	margin: 0 4vw 4vw 0;
	opacity: 1;
}

.swiper-container_wrap.type_banner .swiper-pagination-bullet.swiper-pagination-bullet-active{
	background-color: #0068b7;
}

@media screen and (min-width: 768px) {
	.p-top_banner_sp{
		height: 0;
		overflow:  hidden;
	}

	.p-top_banner_pc{
		height: auto;
	}
}

@media screen and (max-width: 767px) {
	
	.p-top_banner{
		padding-top: 0;
		padding-bottom: 15.2vw;
	}
	
	
	.p-top_banner_in{
		
	}

	.p-top_banner_area{
		margin: 0 auto;
		max-width: 55.733vw;
	}

	.p-top_banner_sp{
		height: auto;
	}

	.p-top_banner_pc{
		height: 0;
		overflow:  hidden;
	}

	.p-top_banner_list_wrap{

	}

	.p-top_banner_list{
		display: flex;
		flex-wrap: wrap;
		margin: 0 -23px -23px 0;
	}

	.p-top_banner_list_item{
		width: 20%;
		padding: 0 23px 23px 0;
	}
	
}

.p-top_about{
	padding-top: 80px;
	padding-bottom: 90px;
	color: #fff;
	background-image: url("../../images/top/top_about_bg_pc.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.p-top_about_in{
	
}

.p-top_about_block{
	display: flex;
	justify-content: space-between;
}

.p-top_about_text{
	/*width: 730px;*/
	width: 680px;
}

.p-top_about_title01{
	position: relative;
	font-size: 4.4rem;
	line-height: 1.53;
	font-weight: 700;
	margin: 0 0 16px 0;
	letter-spacing: 0.06em;
}

.p-top_about_title02{
	position: relative;
	font-size: 2.0rem;
	font-weight: 600;
	margin: 0 0 36px 0;
	padding: 0 0 30px 0;
	letter-spacing: 0.08em;
}

.p-top_about_title02_bar{
	position: absolute;
	bottom: 0;
	left: 0;
	width: 174px;
	height: 2px;
	background-color: #fff;
}

.p-top_about_lead{
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.08em;
}

.p-top_about_img{
	margin: 0 0px 0 0;
}

@media screen and (max-width: 767px) {
	
	.p-top_about{
		padding-top: 12vw;
		padding-bottom: 17.33vw;
		background-image: url("../../images/top/top_about_bg_sp.jpg");
	}

	.p-top_about_in{

	}

	.p-top_about_block{
		flex-wrap: wrap;
	}

	.p-top_about_text{
		width: 100%;
	}

	.p-top_about_title01{
		font-size: 7vw;
		line-height: 1.37;
		margin: 0 0 5.33vw 0;
	}

	.p-top_about_title02{
		font-size: 5.6vw;
		margin: 0 0 4vw 0;
		margin: 0 0 5.33vw 0;
		
	}
	
	.p-top_about_title02_bar{
		width: 34.8vw;
		height: 0.266vw;
	}

	.p-top_about_lead{
		font-size: 4vw;
		line-height: 1.8;
	}
	
	.p-top_about_img{
		width: 100%;
		margin: 6.666vw 0 0 0;
		text-align: center;
	}
	
}

.p-top_service{
	position: relative;
	padding-top: 160px;
	padding-bottom: 100px;
}

.p-top_service:before{
	content: "";
	position: absolute;
	top: 160px;
	left: 0;
	width: 100%;
	height: calc(100% - 160px);
	background-color: #f1f6f9;
}

.p-top_service_in{
	position: relative;
	z-index: 2;
}

.p-top_service .m-title01{
	margin-top: -58px;
}

.p-service_block_wrap{
	margin: 0 0 110px 0;
}

.p-service_block{
	display: flex;
}

.p-service_block_img{
	position: relative;
	width: 50%;
}

.p-service_block_cover{
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	transition: width 0.4s ease 0s;
}

.p-service_block_cover.cover01{
	background-color: #fff;
	z-index: 4;
	transition-delay: 0s;
}

.p-service_block_cover.cover02{
	background-color: #eee;
	z-index: 3;
	transition-delay: 0.4s;
}

.anime_active .p-service_block_cover{
	width: 0;
}

.p-service_block_img .m-img_cover{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.p-service_block_text{
	width: 50%;
	background-color: #fff;
	min-height: 478px;
	display: flex;
	align-items: center;
	padding: 60px;
}

.p-service_block:nth-child(2) .p-service_block_text{
	order: 1;
}

.p-service_block:nth-child(2) .p-service_block_img{
	order: 2;
}

.p-service_block_title01{
	position: relative;
	line-height: 1;
	padding: 0 0 30px 0;
	margin: 0 0 40px 0;
}

.p-service_block_title01:before{
	content: "";position: absolute;
	left: 0;
	bottom: 0;
	background-color: #939393;
	width: 120px;
	height: 1px;
}

.p-service_block_title01 > *{
	display: block;
}

.p-service_block_title01 .m-text01{
	font-size: 4.0rem;
	font-family: 'Teko', sans-serif;
	font-weight: 500;
	margin: 0 0 3px 0;
	color: #0068b2;
	letter-spacing: 0.06em;
}

.p-service_block_title01 .m-text02{
	font-size: 3.6rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.p-service_block_lead{
	font-size: 1.7rem;
	line-height: 1.76;
	margin:  0 0 25px 0;
}

.p-service_block_btn .m-btn_list{
	justify-content: flex-start;
}

.p-service_block_btn .m-btn_list_item{
	width: 174px;
}

.p-service_block_btn  .m-btn_wrap.type01 .m-btn{
	font-size: 1.4rem;
	padding: 10px 18px;
	line-height: 1;
}

@media screen and (max-width: 767px) {
	
	.p-top_service{
		padding-top: 24vw;
		padding-bottom: 18.66vw;
	}

	.p-top_service:before{
		top: 24vw;
		height: calc(100% - 24vw);
	}
	.p-top_service .m-title01{
		margin-top: -10.66vw;
	}

	.p-service_block_wrap{
		margin: 0 0 11.733vw 0;
	}

	.p-service_block{
		flex-wrap: wrap;
	}

	.p-service_block_img{
		order: 1 !important;
		width: 100%;
		padding-bottom: 83%;
	}

	.p-service_block_text{
		order: 2 !important;
		width: 100%;
		padding: 8vw 8vw 12vw 8vw;
		min-height: 0;
	}

	.p-service_block_title01{
		padding: 0 0 5.333vw 0;
		margin: 0 0 5.333vw 0;
	}

	.p-service_block_title01:before{
		width: 24vw;
		height: 0.266vw;
	}

	.p-service_block_title01 > *{
		display: block;
	}

	.p-service_block_title01 .m-text01{
		font-size: 8vw;
		margin: 0 0 0.8vw 0;
	}

	.p-service_block_title01 .m-text02{
		font-size: 6.933vw;
	}

	.p-service_block_lead{
		font-size: 4vw;
		line-height: 1.8;
		margin:  0 0 6vw 0;
	}
	
	.p-service_block_btn .m-btn_list_item{
		width: 46.666vw;
	}
	
	.p-service_block_btn  .m-btn_wrap.type01 .m-btn{
		font-size: 4vw;
		padding: 2.5vw 4vw;
		line-height: 1;
	}
	
}

.p-service_link_list_wrap{
	background-color: #fff;
	padding: 40px 65px 80px 65px;
}

.p-service_link_list{
	display: flex;
	flex-wrap: wrap;
	margin: 0 -40px 0 0;
}

.p-service_link_list_item{
	width: 33.3%;
	padding: 0 40px 0 0;
}

.p-service_link_list_link{
	text-decoration: none !important;
	transition: color 0.4s ease 0s;
}

.p-service_link_obj_img{
	transition: transform 0.4s ease 0s;
}

.p-service_link_list_link:hover{
	color: #0068b7;
}

.p-service_link_list_link:hover .p-service_link_obj_img{
	transform: translateY(-4px);
}

.p-service_link_obj_wrap{
	position: relative;
	border-bottom: 1px solid #e0e0e0;
}

.p-service_link_arrow{
	position: absolute;
	right: 0;
	top: 50%;
	display: flex;
	align-items: center;
	height: 0;
}

.p-service_link_arrow .svg_arrow{
	width: 9px;
}

.p-service_link_arrow .svg_arrow polygon{
	fill: #0068b2;
}

.p-service_link_obj{
	display: flex;
	align-items: center;
	font-size: 1.6rem;
	line-height: 1.5;
	height: 84px;
}

.p-service_link_obj_img{
	min-width: 55px;
	max-width: 55px;
}

.p-service_link_obj_text{

}

@media screen and (max-width: 767px) {
	
	.p-service_link_list_wrap{
		background-color: #fff;
		padding: 0px 4vw 8vw 4vw;
	}

	.p-service_link_list{
		display: flex;
		flex-wrap: wrap;
		margin: 0 0px 0 0;
	}

	.p-service_link_list_item{
		width: 100%;
		padding: 0 0 0 0;
	}

	.p-service_link_obj_wrap{
		border-bottom: 0.266vw solid #e0e0e0;
	}

	.p-service_link_obj{
		display: flex;
		align-items: center;
		font-size: 4.8vw;
		line-height: 1.333;
		min-height: 25.333vw;
	}

	.p-service_link_obj_img{
		min-width: 10.666vw;
		max-width: 10.666vw;
		text-align: center;
	}
	
	.p-service_link_obj_text{
		padding: 0 0 0 4vw;
	}
	
	.p-service_link_arrow .svg_arrow{
		width: 2.4vw;
	}
	
}


.p-scroll_vision{
	height: 340px;
	background-image: url("../../images/top/top_scroll_bg_pc.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	background-attachment: fixed;
}

@media screen and (max-width: 767px) {
	.p-scroll_vision{
		height: 24vw;
		background-image: url("../../images/top/top_scroll_bg_sp.jpg");
	}
}

.p-top_clients{
	padding-top: 100px;
	padding-bottom: 110px;
	background-image: url("../../images/top/top_clients_bg_pc.jpg");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	margin: 0 0 120px 0;
}

.p-top_clients_in{
	
}

.p-top_clients .m-title01{
	margin-bottom: 50px;
}

.p-top_clients_block{
	display: flex;
	justify-content: space-between;
}

.p-top_clients_block_text{
	width: 420px;
}

.p-top_clients_block_text .m-btn_list{
	justify-content: flex-start;
}

.p-top_clients_block_img{
	width: 642px;
}

.p-top_clients_banner_list_wrap{
	
}

.p-top_clients_banner_list{
	display: flex;
	flex-wrap: wrap;
	margin: 0 -12px -18px 0;
}

.p-top_clients_banner_list_item{
	width: 33.3%;
	padding: 0 12px 18px 0;
}

.p-top_clients_banner_list_item figure{
	background-color: #fff;
}

@media screen and (max-width: 767px) {
	
	.p-top_clients{
		padding-top: 12vw;
		padding-bottom: 18.66vw;
		background-image: url("../../images/top/top_clients_bg_sp.jpg");
		margin: 0 0 13.333vw 0;
	}

	.p-top_clients_in{

	}

	.p-top_clients .m-title01{
		margin-bottom: 6.666vw;
	}

	.p-top_clients_block{
		flex-wrap: wrap;
	}

	.p-top_clients_block_text{
		width: 100%;
		margin: 0 0 12vw 0;
	}

	.p-top_clients_block_img{
		width: 100%;
	}

	.p-top_clients_banner_list_wrap{

	}

	.p-top_clients_banner_list{
		margin: 0 -3.2vw -4vw 0;
	}

	.p-top_clients_banner_list_item{
		width: 33.3%;
		padding: 0 3.2vw 4vw 0;
	}
	
}

.p-top_link{
	
}

.p-top_link_in{
	position: relative;
	padding-top: 100px;
	padding-bottom: 100px;
}

.p-top_link_in:before{
	content: "";
	position: absolute;
	top: 0;
	right: 120px;
	width: 100vw;
	min-width: 1500px;
	height: 100%;
	background-color: #e2e9ee;
}

.p-top_link_list_wrap{
	position: relative;
	z-index: 2;
}

.p-top_link_list{
	display: flex;
	flex-wrap: wrap;
	margin: 0 -48px -48px 0;
}

.p-top_link_list_item{
	width: 50%;
	padding: 0 48px 48px 0;
	display: flex;
	flex-direction: column;
}

.p-top_link_href{
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	text-decoration: none !important;
}

.p-top_link_block{
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	box-shadow: 0px 2px 27px 3px #eff3f5;
}

.p-top_link_block_img{
	position: relative;
	overflow:  hidden;
	padding-bottom: 45.2%;
	background-color: #fff;
}

.p-top_link_block_img .m-img_cover{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: opacity 0.4s linear 0s, transform 0.4s linear 0s;
}

.p-top_link_href:hover .m-img_cover{
	opacity: 0.7;
	transform: scale(1.1,1.1);
}

.p-top_link_block_text{
	position: relative;
	background-color: #fff;
	padding: 15px;
}

.p-top_link_block_title01{
	line-height: 1;
	letter-spacing: 0.06em;
	color: #222222;
	display: flex;
	align-items: center;
}

.p-top_link_block_title01 .p-text01{
	font-size: 4.4rem;
	font-family: 'Teko', sans-serif;
	font-weight: 500;
	letter-spacing: 0.06em;
	margin: 7px 17px 0 0;
	line-height: 0.7;
}

.p-top_link_block_title01 .p-text02{
	font-size: 2.0rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.p-top_link_block_arrow{
	position: absolute;
	top: 50%;
	right: 36px;
	display: flex;
	align-items: center;
	height: 0;
}

.p-top_link_block_arrow .svg_arrow{
	width: 11px;
}

.p-top_link_block_arrow .svg_arrow polygon{
	fill: #0068b7;
}

@media screen and (max-width: 767px) {
	
	.p-top_link{

	}

	.p-top_link_in{
		position: relative;
		padding-top: 10.666vw;
		padding-bottom: 10.666vw;
	}

	.p-top_link_in:before{
		right: 8vw;
	}

	.p-top_link_list{
		margin: 0 0 -5.333vw 0;
	}

	.p-top_link_list_item{
		width: 100%;
		padding: 0 0 5.333vw 0;
	}
	
	.p-top_link_block{
		box-shadow: 0px 0.266vw 3.6vw 0.4vw #eff3f5;
	}
	
	.p-top_link_block_img{
		padding-bottom: 44.49%;
	}

	.p-top_link_block_text{
		padding: 4vw;
	}

	.p-top_link_block_title01 .p-text01{
		font-size: 7.2vw;
		margin: 1.3vw 3vw 0 0;
	}

	.p-top_link_block_title01 .p-text02{
		font-size: 3.466vw;
	}
	
	.p-top_link_block_arrow{
		right: 4vw;
	}

	.p-top_link_block_arrow .svg_arrow{
		width: 2.22vw;
	}
	
}


.p-top_column{
	padding-top: 90px;
	padding-bottom: 45px;
}

.p-top_column_in{
}

.p-column .m-title{
	margin-bottom: 10vw;
}


@media screen and (max-width: 767px) {
	
	.p-top_column{
		padding-top: 12vw;
		padding-bottom: 6.666vw;
	}
	
}

.p-top_news{
	/*padding-top: 45px;*/
	padding-top: 90px;
	padding-bottom: 140px;
}

.p-top_news_in{
	
}

.p-top_new_block{
	display: flex;
}

.p-top_new_block_head{
	width: 255px;
}

.p-top_new_block_content{
	width: calc(100% - 255px);
}

@media screen and (max-width: 767px) {
	
	.p-top_news{
		/*padding-top: 6.666vw;*/
		padding-top: 12vw;
		padding-bottom: 18.666vw;
	}

	.p-top_news_in{

	}

	.p-top_new_block{
		flex-wrap: wrap;
	}

	.p-top_new_block_head{
		width: 100%;
	}

	.p-top_new_block_content{
		width: 100%;
	}
	
	.p-top_news .m-title01{
		margin: 0 0 8vw 0;
	}
	
}

/**/

@media screen and (min-width: 768px) {
	
}

@media screen and (max-width: 767px) {
	
}