@charset "UTF-8";






/*-----------------------------------
■ トップページイメージ
-----------------------------------*/

.main-img .img-container {
	position: absolute;
	top: 450px; 
	margin: 0;
	z-index: 100;
}

.main-img .main-img-title {
	padding: 0 0 0 0px;
	margin-left: 150px; 
}

.main-img .st001 {
	font-size: 60px;
	font-family: '小塚明朝 Pro L', serif;
	margin-top: 5px;
	color: #fff;
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 1), -2px 2px 2px rgba(0, 0, 0, 1), 2px -2px 2px rgba(0, 0, 0, 1), -2px -2px 2px rgba(0, 0, 0, 1), 4px 4px 4px rgba(0, 0, 0, 1), 4px -4px 4px rgba(0, 0, 0, 1), -4px 4px 4px rgba(0, 0, 0, 1), -4px -4px 4px rgba(0, 0, 0, 1);

}
.main-img .main-sentence { 
	font-size: 24px;
	font-family: '小塚明朝 Pro L', serif;
	letter-spacing: 0.01em;
	margin: 20px 0 0;
	color: #fff;
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 1), -2px 2px 2px rgba(0, 0, 0, 1), 2px -2px 2px rgba(0, 0, 0, 1), -2px -2px 2px rgba(0, 0, 0, 1), 4px 4px 4px rgba(0, 0, 0, 1), 4px -4px 4px rgba(0, 0, 0, 1), -4px 4px 4px rgba(0, 0, 0, 1), -4px -4px 4px rgba(0, 0, 0, 1);
}

.main-img { position: relative; text-align: left; padding: 0; height: 900px; }

.main-img .mv-slider { position: relative; height: 100%; width: 100%; }

.main-img .mv-slider .img-object { object-position: center; }

.main-img .mv-slider .slick-list { height: 100%; width: 100%; }

.main-img .mv-slider .slick-track { height: 100%; }

.main-img .mv-slider .slick-slide {
	width: 100%;
	height: 100%;
}

.main-img .mv-slider .slick-slide .slide, .main-img .mv-slider .slick-slide > div
{ 
	height: 100%;
}


/*---------------------
■ 767
---------------------*/

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


.main-img { height: 100vh; }
.main-img .img-container { padding: 0px; }
.main-img .mv-catch { padding: 0px; margin-left: 0px;}



.main-img .img-container {
	position: absolute;
	top: 100px; 
	margin: 0;
	z-index: 100;
}

.main-img .main-img-title { padding: 0 0 0 20px; margin-left: 0px; }


.main-img .st001 {
	color: #fff;
	font-size: 36px;
	margin: 0px 0 0;
	letter-spacing: 0.01em;
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 1), -2px 2px 2px rgba(0, 0, 0, 1), 2px -2px 2px rgba(0, 0, 0, 1), -2px -2px 2px rgba(0, 0, 0, 1), 4px 4px 4px rgba(0, 0, 0, 1), 4px -4px 4px rgba(0, 0, 0, 1), -4px 4px 4px rgba(0, 0, 0, 1), -4px -4px 4px rgba(0, 0, 0, 1);
}

.main-img .main-sentence { 
	color: #fff;
	font-size: 20px;
	font-weight: normal;
	margin: 130px 0 0;
	letter-spacing: 0.01em;
	text-shadow: 2px 2px 2px rgba(0, 0, 0, 1), -2px 2px 2px rgba(0, 0, 0, 1), 2px -2px 2px rgba(0, 0, 0, 1), -2px -2px 2px rgba(0, 0, 0, 1), 4px 4px 4px rgba(0, 0, 0, 1), 4px -4px 4px rgba(0, 0, 0, 1), -4px 4px 4px rgba(0, 0, 0, 1), -4px -4px 4px rgba(0, 0, 0, 1);
}





.main-img .mv-slider .slide { position: relative; }
.main-img .mv-slider .slide img { width: 100%; height: 100%; }



} /*------------------------------------------■ ここまで 括弧付き ---------------------*/





/*-----------------------------------
■ infomation
-----------------------------------*/

.index-infomation{
	position: relative;
	padding: 0;
	margin-top: 50px;
}

.corp-box-title-headline{
	margin-top: 0px;
	margin-bottom: 0px;
}

.corp-box-sentence {
	text-align:left;
	margin-top: 10px;
	font-size : 24px;
}

.corp-box-title{
	padding : 0px;
	padding-top : 10px;
	margin : 0px;

	text-align : left;
	color : #000;
	font-weight : normal;
	line-height : 150%;
	font-size : 18px;
}

.corp-box-comment{
	padding : 0px;
	padding-top : 20px;
	margin : 0px;

	text-align : left;
	color : #666;
	font-weight : normal;
	line-height : 150%;
	font-size : 18px;
}

.index-next-button {
	width: 100%;
	max-width: 470px;
	display: inline-block;
	position: relative;
	color: #fff;
	font-size: 18px;
	text-align: center;
	padding: 30px 30px 30px 30px;
	margin-top: 55px;
	border-radius: 40px;
	text-decoration: none !important;
	overflow: hidden;
	background: url(../parts/index/bar/corp002.png) no-repeat center center;
}

.index-next-button:after {
	width: 10px;
	height: 19px;
	position: absolute; content: "";
	right: 30px; top: 50%;
	background-image: url(../parts/index/next-arrow.png);
	background-size: 100% auto; background-repeat: no-repeat; margin: -9px 0 0;
}





/*-----------------------------------
■ 768 PCと合併できるよ
-----------------------------------*/

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



.corp-box-contena {
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.corpblock-img {
	width: 46.5%; text-align: right; order: 1;
}

.corpblock-img img{
	width: 100%;
	border-radius:0 0 10px 0;
}

.corp-block{
	max-width: 600px;
	order: 2;
	width: 53.5%;
	padding: 30px 0 20px 50px;
}

.corp-box { max-width: 600px; } 





}
/*---------------------
■ ここまで @media print, screen and (min-width: 768px)
---------------------*/




/*---------------------
■ 767
---------------------*/

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

.index-next-button {
	margin-top: 55px;
	text-align: center;
}





} /*------------------------------------------■ ここまで 括弧付き ---------------------*/





/*-----------------------------------
■　トップページ 事業紹介
-----------------------------------*/

.index-business-box-title{
	text-align : center;
	color : #666;
	font-weight : normal;
	line-height : 150%;
	font-size : 20px;
	margin-top: 10px;
	margin-bottom: 20px;

	margin-left: auto;
	margin-right: auto;
	max-width: 870px;

}

.index-business-box-flex {
	display: flex;
	margin-bottom: 0px;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}


.index-business-box {
	width: 50%;
	aspect-ratio: 16 / 7.5;
	overflow: hidden;
	position: relative;
}

.index-business-box::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	z-index: -20;
	transition: All 0.3s ease;
}

.index-business-box.business-box_1::after {
	background: url(../parts/index/business/001.jpg)no-repeat center / cover;
}

.index-business-box.business-box_2::after {
	background: url(../parts/index/business/002.jpg)no-repeat center / cover;
}


.index-business-box:hover::after {
	transform: scale(1.1);
}

.index-business-box a {
	display: flex;
	flex-direction: column;
	text-align: center;
	height: 100%;
	text-decoration: none;
}

.index-business-box a {
	opacity: 1;
	display: flex;
	flex-direction: column;
}

.index-business-box a,
.index-business-title002 {
	color: #FFF;
}

.index-business-box-head {
	font-size: 30px;
	font-weight: bold;
	margin-top: 15%
}

.index-business-title002 {
	margin-top: 40px
}

.index-b_next{
	margin-top: 0px
}

.index-business-box:hover .index-b_next span::after {
	right: -15px;
}

.index-b_next span {
	position: relative;
	padding-right: 6rem;
}

.index-b_next span::after {
	width: 5rem;
	height: 1px;
	background-color: #FFF;
	position: absolute;
	top: 50%;
	right: 0;
	transition: All 0.3s ease;
	content: "";
	display: block;
}

.index-next-button:hover { opacity: 0.7; }





/*---------------------
■ 767
---------------------*/
@media only screen and (max-width: 767px) {



.index-business-box-title{
	padding: 0px;
	margin: 0px;
	margin-bottom: 20px;
}

.index-business-box-head {
	font-size: 16px;
	font-weight: normal;
	margin-top: 10%
}

.index-business-title002 {
	margin-top: 0px;
}

.index-b_next{
	margin-top: 2000px;
}


} /*------------------------------------------■ ここまで 括弧付き ---------------------*/




/*-----------------------------------
■ award
-----------------------------------*/

.index-award{
	position: relative;
	padding: 0;
	margin-top: 150px;
	margin-bottom: 150px;
}

/*---------------------
■ 767
---------------------*/
@media only screen and (max-width: 767px) {


.index-award{
	margin-top: 100px;
	margin-bottom: 100px;
}


} /*------------------------------------------■ ここまで 括弧付き ---------------------*/


/*-----------------------------------
■ work
-----------------------------------*/

.index-work{
	max-width: 1100px;
	padding : 0px;
	margin : 0px;
	margin-top: 100px;
	margin-bottom: 50px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.index-work-box{
	text-align: center;
}

.index-work-box-title-headline{
	text-align : center;
	margin-top: 0px;
	margin-bottom: 0px;
}

.index-work-box-sentence {
	text-align : center;
	margin-top: 10px;
	font-size : 20px;
}
.index-work-box-title{
	text-align : center;
	color : #666;
	font-weight : normal;
	line-height : 150%;
	font-size : 20px;
}

/*-------------------
■ LIST設定
-------------------*/

.index-work .work-list {
	max-width: 1100px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 30px auto 0 auto;
}

.index-work .work-list li { 
	width: 48%;
	margin: 0 4% 46px 0;
}

.index-work .work-list li .workli-box {
	position: relative;
	z-index: 120;
}

.index-work .work-list li .workli-box:after {
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	background: #cbb900;
	opacity: 0;
	z-index: 125;
	transition: All 0.3s ease;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
}

.index-work .work-list li .workli-box .img {
	position: relative;
}

.index-work .work-list li .workli-box .img:before {
	display: block;
	content: " ";
	width: 100%;
	padding-top: 40%;
}

.index-work .work-list li .w_next {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 130;
	transition: All 0.3s ease;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
}

.index-work .work-list li .w_next img{
	max-width: 140px;
}

.index-work .work-list li .work_st {
	position: relative;
	z-index: 120;
	text-align: center;
	color: #217ba3;
	font-size: 20px;
	line-height: 1.5;
	margin-top: 10px;
}

.index-work .work-list li:nth-child(2n) {
	margin-right: 0;
}

.index-work .work-list li a {
	width: 100%;
	display: block;
	overflow: hidden;
	text-decoration: none;
	transition: All 0.3s ease;
	-webkit-transition: All 0.3s ease;
	-moz-transition: All 0.3s ease;
	-o-transition: All 0.3s ease;
}





/*---------------------
■ 768
---------------------*/
@media print, screen and (min-width: 768px) { 

.index-work .work-list li a:hover { opacity: 1;}
.index-work .work-list li a:hover .workli-box { position: relative;z-index: 35;}
.index-work .work-list li a:hover .workli-box:after { opacity: 0.7;}


.index-work .work-list li a:hover .w_next { opacity: 1;}


}
/*---------------------
■ ここまで @media print, screen and (min-width: 768px)
---------------------*/





/*---------------------
■ 767
---------------------*/
@media only screen and (max-width: 767px) {

.index-work {
	margin-top: 50px;
	margin-bottom: 0px;
}

.index-work-box{
	text-align: center;
}

.index-work-box-title{text-align: left;
	font-size : 20px;
	padding: 15px;
}

.index-work .work-list { margin: 20px auto 0; }



.index-work .work-list li { width: 48%; margin: 0 4% 20px 0; }
.index-work .work-list li {
	width: 100%;
	padding : 0px;
	margin : 0px;
	text-align : center;
}

.index-work .work-list li .workli-box img { width: 600p;}

.index-work .work-list li .work_st {
	font-size: 20px;
	margin-top: 8px;
	margin-bottom: 30px;
}

.index-work .work-list li .work_st {
	position: relative;
	z-index: 120;
	text-align: center;
	color: #217ba3;
	font-size: 20px;
	line-height: 1.5;
	margin-top: 10px;
}

.index-work .work-list li:nth-child(2n) { margin-right: 0; }



} /*------------------------------------------■ ここまで 括弧付き ---------------------*/





/*-----------------------------------
■　トップページ マップ
-----------------------------------*/

.index-map{
	width: 100%;
	padding : 0px;
	margin : 0px;
	margin-top: 100px;
	margin-bottom: 50px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}

.index-map-box-title-headline{
	text-align : center;
	margin-top: 0px;
	margin-bottom: 0px;
}

.index-map-box-sentence {
	text-align : center;
	margin-top: 10px;
	margin-bottom: 20px;
	font-size : 20px;
}

.index-map-box {
    width: 100%;
	position: relative;
	padding-bottom: 35%; 
	height: 0;
	overflow: hidden;
	margin-bottom: 100px;
	filter: saturate(33%);
}

.index-map-box iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}





/*---------------------
■ 767
---------------------*/
@media screen and (max-width: 767px) {


.index-map{
	width: 100%;
	padding : 0px;
	margin : 0px;
	margin-top: 50px;
	margin-bottom: 0px;
	margin-left: auto;
	margin-right: auto;
}

.index-map-box {
	margin-top: 0px;
	margin-bottom: 20px;
	height: 250px;
}

} /*------------------------------------------■ ここまで 括弧付き ---------------------*/



h1, h2, h3, h4, h5, h6, p, li, pre, td, th, dt, dd { line-height: 1.8; }




/*-----------------------------------
■　イメージ箇所
-----------------------------------*/

.img-wire { position: relative; }

.img-object { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }

.img-object.is-noimg { background-color: #ebe7e4; object-fit: contain; object-position: center; }

.img-objectfit { display: block; width: 100%; height: 100%; object-fit: cover; object-position: top; }



} /*------------------------------------------■ ここから下は別の箇所 ---------------------*/
























































/* ----------------------------------------プレスリリース　設定開始----------------------------------------*/




.index-press{
	max-width: 1100px;
	padding : 0px;
	margin : 0px;
	margin-top: 100px;
	margin-bottom: 50px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.index-work-box{
	text-align: center;
}






.pressrelease_waku {
	max-width : 980px;
	padding: 0;
	margin: 0;
	margin-left: auto;
	margin-right : auto;
	margin-top: 80px;
	text-align : center;
}

.work_title010{
	max-width : 980px;
	height: 40px;
	padding : 0px;
	margin : 0px;
	margin-top : 10px;
	margin-left: auto;
	margin-right: auto;
	vertical-align : top;
	ZOOM: 1; DISPLAY: inline-block;
	clear : both;
}





.work_title010 p{
	font-size : 32px;
	font-family : 小塚ゴシック Pro R;
	padding : 0px;
	padding-top : 2px;
	padding-left: 15px;
	padding-right: 15px;
	vertical-align : top;
	text-align : left;
	color: #217ba3;
}


.pressrelease {
	max-width : 900px;
	padding: 0;
	margin: 0;
	margin-left: auto;
	margin-right : auto;
	text-align : center;
	vertical-align : top;
}

.pressrelease dl {
	padding: 0;
	padding-top: 0px;
	padding-left: 20px;
	margin: 0;
	text-align : left;
	clear : both;
}

.pressrelease dl dt {
	width : 80px;
	font-size : 1px;
	text-align : left;
	padding: 3px;
	margin : 0px;
	font-weight : bold;
	float : left;
}



.pressrelease dl dd {
	text-align : left;
	font-size : 18px;
	padding-top: 20px;
	padding-left: 145px;
	padding-right : 0px;
	padding-bottom: 40px;
	margin-left: 0px;
	margin-bottom: 10px;
	background : url(../parts/sub/press.png) repeat-x left bottom;
	line-height : 150%;
	font-weight : bold;
	color: #217ba3;
}

.pressrelease dl dd b {
	font-size : 18px;
	color : #0d2440;
	font-weight : normal;
}
.pressrelease dl dd a {
	font-size : 18px;
	color : #0d2440;
	font-weight : normal;
}

.pressrelease dl dd a:hover {
	color: #217ba3;
}










/* =スマホ限定追加要素
--------------------------------------------------------*/
@media
only screen and (max-width : 640px){




/*-----------------------------------
■ プレスリリース　
-----------------------------------*/





.pressrelease_waku {
	max-width: 620px;
	padding: 0;
	margin: 0;
	margin-left: auto;
	margin-right : auto;
	margin-top: 50px;
	text-align : center;
}


.work_title010{
	max-width: 620px;
	padding : 0px;
	margin : 0px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 20px;
	margin-bottom : 40px;
	vertical-align : top;
	ZOOM: 1; DISPLAY: inline-block;
	clear : both;
}


.work_title010 p{
	font-size : 32px;
	padding : 0px;
	vertical-align : top;
	text-align : left;
	background-color : #ffffff;
}


.pressrelease dl dt {
	width : 80px;
	font-size : 1px;
	text-align : left;
	padding : 0px;
	margin : 0px;
	font-weight : bold;
	float : left;
}
.pressrelease dl dt img {
	width : 100%;
}

.pressrelease dl dd {
	font-size : 18px;
	text-align : left;
	padding-top: 0px;
	padding-left: 100px;
	padding-right : 20px;
	padding-bottom: 40px;
	margin-left: 0px;
	margin-bottom: 10px;
	background : url(../parts/sub/press.png) repeat-x left bottom;
	line-height : 150%;
	color: #217ba3;
}

.pressrelease dl dd a {
	font-size : 18px;
	color : #0d2440;
}

.pressrelease dl dd a:hover {
	color: #217ba3;
}




} /*------------------------------------------■ ここまで 括弧付き ---------------------*/











/*-----------------------------------
■ 消さない
-----------------------------------*/

.margin_top10{
	padding: 0;
	margin: 0;
	margin-top: 10px;
}

.margin_top15{
	padding: 0;
	margin: 0;
	margin-top: 15px;
}

.margin_top20{
	padding: 0;
	margin: 0;
	margin-top: 20px;
}

.margin_top30{
	padding: 0;
	margin: 0;
	margin-top: 30px;
}

.margin_top40{
	padding: 0;
	margin: 0;
	margin-top: 40px;
}

.margin_top50{
	padding: 0;
	margin: 0;
	margin-top: 50px;
}

.margin_top100{
	padding: 0;
	margin: 0;
	margin-top: 100px;
}



.margin_tb20{
	padding: 0;
	margin: 0;
	margin-top: 20px;
	margin-bottom: 20px;
}


.margin_t30b10{
	padding: 0;
	margin: 0;
	margin-top: 30px;
	margin-bottom: 10px;
}

.margin_t30b20{
	padding: 0;
	margin: 0;
	margin-top: 30px;
	margin-bottom: 20px;
}



A:hover IMG{
	FILTER: Alpha(opacity=50); opacity: 0.5
}

.clear{
	clear:both;
}

.clearfix:after {
	DISPLAY: block; HEIGHT: 0px; VISIBILITY: hidden; CLEAR: both; CONTENT: "."
}
.clearfix {
	ZOOM: 1; DISPLAY: inline-block;
}
* HTML .clearfix {
	ZOOM: 1; HEIGHT: 1px
}
.clearfix {
	DISPLAY: block
}










