/* ===========================================
 * top use css
=========================================== */

/* SLIDE */
#top_slide{
	width: 100%;
	background-image: linear-gradient(0deg, #e4ebf7 50%, #ffffff 50%);
	overflow: hidden;
	margin-top: 80px;
}
#top_slideInner{
	width: 100%;
	position: relative;
	right: 0;
}
#fv_img{
	max-height: 800px;
	height: 800px;
	overflow: hidden;
	width: calc(100% - 7%);
	margin-left: 7%;
}
#fv_img::before {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    height: 800px;
    background: url(../img/top/fv.jpg) left top no-repeat;
    background-size: cover;
    z-index: 0;
	overflow: hidden;
	width: calc(100% - 7%);
	margin-left: 7%;
}
#fv_desc{
    position: absolute;
    top: 50%;
	left: 50%;
	transform: translate(-50% , -50%);
	width: 1165px;
	margin: 0 auto;
}
#fv_text{
	width: 368px;
}
#fv_text img{
	width: 368px;
	object-fit: cover;
}
#fv_title{
	width: 100%;
}
#fv_title img{
	width: 100%;
	object-fit: cover;
}


#top_message{
	padding: 55px 0 80px;
	background: #e4ebf7;
	overflow: visible;
}
#top_messageInner .title{
	display: flex;
	justify-content: space-between;
}
#top_messageInner .title h2{
	color: #133B6B;
	font-size: 28px;
	line-height: 30px;
}
#top_messageInner .title h2 span{
	font-size: 16px;
	font-weight: 700;
}
#top_messageInner .title p{
	color: #133B6B;
	font-size: 12px;
}
#top_messageInner .block{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-top: 40px;
}
#top_messageInner .block .text_box{
	width: 610px;
}
#top_messageInner .block .text_box p{
	font-size: 16px;
}
#top_messageInner .block .text_box h4{
	font-size: 24px;
	color: #113763;
	margin: 40px 0;
}
#top_messageInner .block .text_box h5{
	font-size: 16px;
	color: #113763;
	font-weight: 400;
}
#top_messageInner .block .text_box h5 strong{
	font-size: 24px;
	color: #113763;
}
#top_messageInner .block .img_box{
	width: 410px;
	position: sticky;
	top: 0;
}


#top_menu{
	padding: 70px 0;
}

#top_menuInner .block{
	width: 1100px;
	height: 360px;
	box-sizing: border-box;
	border-radius: 10px;
	display: flex;
}
#top_menuInner .block:nth-of-type(1){
	background: #133B6A;
	margin-bottom: 40px;
}
#top_menuInner .block:nth-of-type(2){
	background: #175BA3;
	margin-bottom: 40px;
}
#top_menuInner .block:nth-of-type(3){
	background: #2B9CD4;
}
#top_menuInner .block .title_box{
	width: 70px;
	height: 360px;
	border-right: 1px solid #fff;
	padding: 0 25px;
	box-sizing: border-box;
}
#top_menuInner .block .title_box p{
	writing-mode: vertical-rl;
	color: #fff;
	font-size: 12px;
	margin-top: 30px;
}
#top_menuInner .block .text_box{
	width: 465px;
	padding: 40px;
	box-sizing: border-box;
	position: relative;
} 
#top_menuInner .block .text_box h3{
	font-size: 28px;
	color: #fff;
	margin-bottom: 40px;
}
#top_menuInner .block .text_box p{
	color: #fff;
}
#top_menuInner .block .text_box .growth{
	width: 385px;
	background: #fff;
	padding: 15px;
	box-sizing: border-box;
	margin: 10px 0;
}
#top_menuInner .block .text_box .growth p{
	color: #133B6A;
}
#top_menuInner .block .text_box .growth ul{
	list-style: none;
}
#top_menuInner .block .text_box .growth ul li{
	color: #133B6A;
	text-indent: 1em;
}
#top_menuInner .block .text_box .growth ul li::before{
	content: "■";
}
#top_menuInner .block .text_box .btn{
	position: absolute;
	bottom: 40px;
	right: 40px;
}
#top_menuInner .block .text_box .btn a{
	color: #fff;
	font-weight: 700;
}
#top_menuInner .block .text_box .btn a img{
	vertical-align: middle;
}
#top_menuInner .block .img_box{
	width: 419px;
	height: auto;
	margin: 40px 40px 40px auto;
	overflow: hidden;
	box-sizing: border-box;
}
#top_menuInner .block .img_box img{
	width: 419px;
	height: auto;
	object-fit: cover;
	transition: transform 0.4s ease;
}
#top_menuInner .block .img_box:hover img{
  transform: scale(1.1);
}

#top_carousel{
	padding: 80px 0;
}
.bx-wrapper ul.bxslider{
	margin-left: 33%;
}
.bxslider li{
	width: 240px;
	height: 400px;
	border-radius: 10px;
	background: #D4D4D4;
}
.bx-wrapper {
	max-width: 100% !important; /*スライドの幅に合わせて変更*/
	margin-left: auto;
	margin-right: auto;
	background: none;
	border: none;
	box-shadow: none;
	overflow: hidden;
}
.bx-viewport {
	overflow: visible !important;
}



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

	/* SLIDE */
	#top_slide{
		width: 100%;
		background-image: linear-gradient(0deg, #e4ebf7 50%, #ffffff 50%);
		overflow: hidden;
	}
	#top_slideInner{
		width: 100%;
		position: relative;
		right: 0;
	}
	#fv_img{
		max-height: 580px;
		height: 580px;
		overflow: hidden;
		width: calc(100% - 30px);
		margin-left: 30px;
	}
	#fv_img::before {
		position: absolute;
		content: "";
		top: 0;
		left: 0;
		height: 400px;
		background: url(../img/top/fv.jpg) left top no-repeat;
		background-size: cover;
		z-index: 0;
		overflow: hidden;
		width: calc(100% - 30px);
		margin-left: 30px;
	}
	#fv_desc{
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50% , -50%);
		width: 580px;
		margin: 0 auto;
	}
	#fv_text{
		width: 368px;
		margin-top: 0px;
		margin-left: 20px;
	}
	#fv_text img{
		width: 368px;
		object-fit: cover;
	}
	#fv_title{
		width: 100%;
		margin-top: 40px;
	}
	#fv_title img{
		width: 100%;
		object-fit: cover;
	}


	#top_message{
		padding: 55px 0 80px;
		background: #e4ebf7;
	}
	#top_messageInner .title{
		display: block;
		justify-content: space-between;
	}
	#top_messageInner .title h2{
		color: #133B6B;
		font-size: 30px;
		line-height: normal;
	}
	#top_messageInner .title h2 span{
		font-size: 22px;
		font-weight: 700;
	}
	#top_messageInner .title p{
		color: #133B6B;
		font-size: 18px;
		text-align: right;
	}
	#top_messageInner .block{
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: flex-start;
		margin-top: 40px;
	}
	#top_messageInner .block .text_box{
		order: 2;
		width: 580px;
	}
	#top_messageInner .block .text_box p{
		font-size: 22px;
	}
	#top_messageInner .block .text_box h4{
		font-size: 30px;
		color: #113763;
		margin: 40px 0;
	}
	#top_messageInner .block .text_box h5{
		font-size: 22px;
		color: #113763;
		font-weight: 400;
	}
	#top_messageInner .block .text_box h5 strong{
		font-size: 30px;
		color: #113763;
	}
	#top_messageInner .block .img_box{
		order: 1;
		width: 410px;
		position: relative;
		top: 0;
		margin: 0 auto 40px;
	}
		#top_messageInner .block .img_box p{
			text-align: center;
			font-size: 20px;
		}


	#top_menu{
		padding: 70px 0;
	}

	#top_menuInner .block{
		width: 580px;
		height: auto;
		box-sizing: border-box;
		border-radius: 10px;
		display: flex;
		flex-wrap: wrap;
	}
	#top_menuInner .block:nth-of-type(1){
		background: #133B6A;
		margin-bottom: 40px;
	}
	#top_menuInner .block:nth-of-type(2){
		background: #175BA3;
		margin-bottom: 40px;
	}
	#top_menuInner .block:nth-of-type(3){
		background: #2B9CD4;
	}
	#top_menuInner .block .title_box{
		order: 1;
		width: 580px;
		height: auto;
		border-right: 0;
		border-bottom: 1px solid #fff;
		padding: 25px;
		box-sizing: border-box;
	}
	#top_menuInner .block .title_box p{
		writing-mode: horizontal-tb;
		color: #fff;
		font-size: 18px;
		margin-top: 0;
		text-align: center;
	}
	#top_menuInner .block .text_box{
		order: 3;
		width: 580px;
		padding: 0 40px 40px;
		box-sizing: border-box;
		position: relative;
	} 
	#top_menuInner .block .text_box h3{
		font-size: 32px;
		color: #fff;
		margin-bottom: 20px;
	}
	#top_menuInner .block .text_box p{
		color: #fff;
	}
	#top_menuInner .block .text_box .growth{
		width: 500px;
		background: #fff;
		padding: 15px;
		box-sizing: border-box;
		margin: 20px 0;
	}
	#top_menuInner .block .text_box .growth p{
		color: #133B6A;
	}
	#top_menuInner .block .text_box .growth ul{
		list-style: none;
	}
	#top_menuInner .block .text_box .growth ul li{
		color: #133B6A;
		text-indent: 1em;
	}
	#top_menuInner .block .text_box .growth ul li::before{
		content: "■";
	}
	#top_menuInner .block .text_box .btn{
		position: relative;
		bottom: 0;
		right: 0;
		text-align: right;
		margin-top: 30px;
	}
	#top_menuInner .block .text_box .btn a{
		color: #fff;
		font-weight: 700;
	}
	#top_menuInner .block .text_box .btn a img{
		vertical-align: middle;
	}
	#top_menuInner .block .img_box{
		order: 2;
		width: 580px;
		height: auto;
		margin: 0;
		padding: 40px;
		overflow: hidden;
		box-sizing: border-box;
	}
	#top_menuInner .block .img_box img{
		width: 500px;
		height: auto;
		object-fit: cover;
		transition: transform 0.4s ease;
	}
	#top_menuInner .block .img_box:hover img{
	  transform: scale(1);
	}

	#top_carousel{
		padding: 80px 0;
	}
	.bx-wrapper ul.bxslider{
		margin-left: 33%;
	}
	.bxslider li{
		width: 240px;
		height: 400px;
		border-radius: 10px;
		background: #D4D4D4;
	}
	.bx-wrapper {
		max-width: 100% !important; /*スライドの幅に合わせて変更*/
		margin-left: auto;
		margin-right: auto;
		background: none;
		border: none;
		box-shadow: none;
		overflow: hidden;
	}
	.bx-viewport {
		overflow: visible !important;
	}
	
	
	
	
	

	
}

