@charset "utf-8";

/*mv
--------------------------------------------*/
.business #lp_mainv .lp_mainv-img{
	background: url(../img/business/lp_business_sp.jpg);
	background-position: center;
}


/*business_future
--------------------------------------------*/
#business_future{
	padding:45px 0 20px;
}
#business_future .ttl02{
	margin-bottom: 45px;
}
#business_future .ttl02::before{
	color: #fff2e9;
	content: "Future";
}
#business_future .ttl02::after{
	background-color: var(--main-color);
}
#business_future .future_img{
	padding: 0 8px;
	text-align: center;
	margin-bottom: 40px;
}

#business_future .accordion{
	width: 90%;
	margin:0 auto;
}


#business_future .case_ttl{
	color: #fff;
	font-size: 1.7rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.666;
	padding-left: 11px;
	padding-right: 45px;
}
#business_future .accordion_container{
	margin-bottom: 40px;
}
#business_future .accordion_title {
	position: relative;
	background-color: var(--main-color);
	color: #fff;
	font-size: 3rem;
	letter-spacing: 0.2em;
	font-weight: 500;
	padding: 20px 10px;
	z-index: +1;
	cursor: pointer;
	transition-duration: 0.2s;
}
#business_future .accordion_container:nth-of-type(2) .accordion_title{
	background-color: var(--main-color3);
}
#business_future .accordion_container:nth-of-type(3) .accordion_title{
	background-color: var(--main-color2);
}
#business_future .accordion_title::before{
	position: absolute;
	content: "01";
	color: rgba(255,255,255,.4);
	font-size: 4rem;
	letter-spacing: 0;
	font-family: var(--font-family-serif);
	font-style: italic;
	line-height: 1;
	top: -4px;
	left: -2px;
}
#business_future .accordion_container:nth-of-type(2) .accordion_title::before{
	content: "02";
}
#business_future .accordion_container:nth-of-type(3) .accordion_title::before{
	content: "03";
}
#business_future .accordion_inner{
	font-size: 1.3rem;
	line-height: 2;
	background-color: #f2f2f2;
	padding: 16px 10px;
}
/* 矢印の挙動 */
#business_future .accordion_title::after {
	position: absolute;
	content: "";
	background-image: url(../img/cmn/arrow_triangle_white_up.png);
	width: 18px;
	height: 13px;
	background-repeat: no-repeat;
	background-size: cover;
	transition: 0.3s;
	transform: rotate(180deg);
	top: 45%;
	right: 10px;
}
#business_future .accordion_title.open::after {
	transform: rotate(0deg);
}
/* 一つ目のアコーディオンのみ矢印の挙動を逆に */
#business_future .accordion_container:first-of-type .accordion_title.open::after{
	transform: rotate(180deg);
}
#business_future .accordion_container:first-of-type .accordion_title::after{
	transform: rotate(0deg);
}
#business_future .accordion_inner {
	display: none;
}
#business_future .accordion_inner.default {
	display: block;
}



/*business_strategy
--------------------------------------------*/

#business_strategy{
	padding:48px 0 50px;
	background-color: #ecf4f2;
}
#business_strategy .ttl02{
	margin-bottom: 46px;
}
#business_strategy .ttl02::before{
	content: "Strategy";
}
#business_strategy .lead{
	width: 90%;
	line-height: 2;
	margin: 0 auto 24px;
}
#business_strategy .list{
	width: 94%;
	margin:0 auto;
}
#business_strategy .list_item{
	width: 48.5%;
	position: relative;
	width: 100%;
	margin-bottom: 40px;
}
#business_strategy .list_item:last-of-type{
	margin-bottom: 0;
	min-width: 270px;
}
#business_strategy .list_item::before{
	position: absolute;
	content: "Strategy";
	font-size: 2.5rem;
	color:#87c8c0;
	writing-mode: vertical-rl;
	transform: rotate(180deg);
	font-family: var(--font-family-serif);
	bottom: 0;
	left: -5px;
}
#business_strategy .list_item .ttl{
	position: relative;
	display: inline-block;
	text-align: left;
	font-size: 1.7rem;
	line-height: 1.41;
	letter-spacing: 0.02em;
	font-weight: 500;
	min-width: 270px;
	background-color: #fff;
	padding:15px 20px 14px;
	margin-bottom:10px;
	z-index: 1;
}
#business_strategy .list_item .ttl::before{
	position: absolute;
	content: "";
	background-image: url(../img/employee/L_border_l.png);background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 20px;
	top: 0;
	left: 0;
}
#business_strategy .list_item .ttl::after{
	position: absolute;
	content: "";
	background-image: url(../img/employee/L_border_r.png);background-repeat: no-repeat;
	background-size: contain;
	width: 20px;
	height: 20px;
	bottom: 0;
	right: 0;
}
#business_strategy .list_item .ttl span{
	position: relative;
	display: block;
}
#business_strategy .list_item .ttl span::before{
	position: absolute;
	content: "01";
	font-size: 3.6rem;
	color: var(--main-color);
	font-style: italic;
	font-family: var(--font-family-serif);
	line-height: 1;
	font-weight: 600;
	transform: translateX(-50%);
	bottom: -35px;
	left: 2px;
}
#business_strategy .list_item:nth-of-type(2) .ttl span::before{
	content: "02";
}
#business_strategy .detail{
	position: relative;
	font-size: 1.3rem;
	line-height: 2;
	letter-spacing: 0;
	padding: 10px;
	background-color: rgba(255,255,255,0.6);
	text-align: justify;
	width: calc( 100% - 66px );
	min-height: 160px;
	margin:-22px 0 0 auto;
	padding-top: 26px;
}
#business_strategy .list_item .detail::after {
	position: absolute;
	content: "";
	background-color: #87c8c0;
	width: 1px;
	height: calc(100% - 139px);
	left: -38px;
	bottom: 100px;
}
#business_strategy .list_item:nth-of-type(2) .detail::after {
	height: calc(100% - 139px);
	left: auto;	
	right: -38px;
	bottom: 100px;
}
#business_strategy .detail .em{
	color: var(--main-color3);
	font-weight: 600;
}
#business_strategy .detail .em_u-line{
	font-weight: 600;
	background:linear-gradient(transparent 70%, #fff59c 70%);
}
#business_strategy .list_item:nth-of-type(2){
	text-align: right;
}
#business_strategy .list_item:nth-of-type(2) .detail{
	margin:-22px 0 0 0;
}
#business_strategy .list_item:nth-of-type(2) .ttl{
	text-align: right;
}
#business_strategy .list_item:nth-of-type(2) .ttl span::before{
	left: auto;
	right: -30px;
}
#business_strategy .list_item:nth-of-type(2)::before{
	left: auto;
	right: 8px;
} 
/* #business_strategy .list_item:nth-of-type(2)::after{
	left: auto;
	right: 28px;
} */
#business_strategy .list_item:nth-of-type(2) .ttl::before{
	left: auto;
	right: 0;
	transform: rotate(90deg);
}
#business_strategy .list_item:nth-of-type(2) .ttl::after{
	right: auto;
	left: 0;
	transform: rotate(90deg);
}

/*business_introduction
--------------------------------------------*/
#business_introduction{
	padding:45px 0 0;
}
#business_introduction .ttl02{
	margin-bottom: 40px;
}
#business_introduction .ttl02::before{
	content: "Business";
	color: #fff2e9;
}
#business_introduction .ttl02::after{
	background-color: var(--main-color);
}
#business_introduction .lead{
	width: 90%;
	margin: 0 auto 24px;
	font-size: 1.3rem;
	line-height: 2;
	text-align: justify;
}
#business_introduction .ttl03{
	width: 90%;
	margin-left:auto;
	margin-right:auto;
	margin-bottom: 26px;
}
#business_introduction .modal_item{
	position: relative;
	background-color: #fff;
	width: 33.33%;
	box-shadow: 2px 2px 4px #999;
	padding: 30px 6px 3px;
	text-align: center;
	margin: 30px 5px 10px;
}
#business_introduction .modal_item .modal_ttl{
	font-size: 1.3rem;
	color: var(--main-color2);
	font-weight: 600;
	line-height: 1.4;
	min-height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 0;
}
#business_introduction .modal_item .more{
	font-size: 1.2rem;
}
#business_introduction .modal_item .click{
	font-size: 1.0rem;
	color: var(--main-color);
	list-style: 1;
}
#business_introduction .modal_item .more::after{
	content: "";
	background-image: url(../img/employee/benefits_arrow.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	width: 30px;
	height: 6px;
	display: inline-block;
	margin-left: 5px;
}
#business_introduction .slick-dots{
	bottom: -38px !important;
}
#business_introduction .slick-dots li button:before{
	font-size: 1rem;
	color: var(--main-color2);
}
#business_introduction .department{
	margin-bottom: 70px;
}

/* モーダル基本設定 */
body.fixed {
	position: fixed;
	width: 100%;
	top: 0;
	left: 0;
	overflow-y: scroll;
}
.modal {
	position: fixed;
	/* top: 0; */
	top: 80px;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 99;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch;
	text-align: center;
	display: flex;
	align-items: center;
	justify-content: center;
}
.modal * {
	text-shadow: none;
	color: #333;
}
.modal-bg {
	position: fixed;
	/* top: 0; */
	top: 80px;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
	-webkit-backdrop-filter: blur(5px);
			backdrop-filter: blur(5px);
	/* background: rgba(16, 16, 16, .1); */
}
.modal-content {
	position: relative;
	z-index: 2;
	padding: 50px 0;
	width: 80vw;
	max-height: 90vh;
	max-width: 240px;
	box-sizing: border-box;
}		
.modal-inner {
	position: relative;
	background: #fff;
	padding: 80px 20px 20px;
	text-align: left;
	box-shadow: 2px 2px 4px #999;
}
.modal-item {
	word-break: break-all;
}
#business_introduction .benefits_item .ttl::before,
#business_introduction .modal_item::before{
	position: absolute;
	content: "";
	background-image: url(../img/business/business_icon01.png);
	width: 50px;
	height: 50px;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	transform: translateX(-50%);
	left: 50%;
	top: -60px;
}
#business_introduction .modal_item::before{
	top: -25px !important;
}
#business_introduction .modal_item.modal02::before{
	background-image: url(../img/business/business_icon02.png);
}
#business_introduction .modal_item.modal03::before{
	background-image: url(../img/business/business_icon03.png);
}
#business_introduction .modal_item.modal04::before{
	background-image: url(../img/business/business_icon04.png);
}
#business_introduction .modal_item.modal05::before{
	background-image: url(../img/business/business_icon05.png);
}
#business_introduction .modal_item.modal06::before{
	background-image: url(../img/business/business_icon06.png);
}
#business_introduction .modal_item.modal07::before{
	background-image: url(../img/business/business_icon07.png);
}
#business_introduction .modal_item.modal08::before{
	background-image: url(../img/business/business_icon08.png);
}
#business_introduction .modal_item.modal09::before{
	background-image: url(../img/business/business_icon09.png);
}


#business_introduction .benefits_item:nth-of-type(2) .ttl:before{
	background-image: url(../img/business/business_icon02.png);
}
#business_introduction .benefits_item:nth-of-type(3) .ttl:before{
	background-image: url(../img/business/business_icon03.png);
}
#business_introduction .benefits_item:nth-of-type(4) .ttl:before{
	background-image: url(../img/business/business_icon04.png);
}
#business_introduction .benefits_item:nth-of-type(5) .ttl:before,
#business_introduction .modal_item.modal05::before{
	background-image: url(../img/business/business_icon05.png);
}
#business_introduction .benefits_item:nth-of-type(6) .ttl:before,
#business_introduction .modal_item.modal06::before{
	background-image: url(../img/business/business_icon06.png);
}
#business_introduction .benefits_item:nth-of-type(7) .ttl:before,
#business_introduction .modal_item.modal07::before{
	background-image: url(../img/business/business_icon07.png);
}
#business_introduction .benefits_item:nth-of-type(8) .ttl:before,
#business_introduction .modal_item.modal08::before{
	background-image: url(../img/business/business_icon08.png);
}
#business_introduction .benefits_item:nth-of-type(9) .ttl:before,
#business_introduction .modal_item.modal09::before{
	background-image: url(../img/business/business_icon09.png);
}
#business_introduction .benefits_item .ttl{
	position: relative;
	font-size: 1.3rem;
	color: var(--main-color2);
	font-weight: 600;
	text-align: center;
	margin-bottom: 8px;
}
#business_introduction .benefits_item .detail{
	font-size: 1.3rem;
	line-height: 2;
}
.modal .btn-close:hover {
	cursor: pointer;
}
.modal.is_close > * {
	pointer-events: none;
}
.modal.is_close {
	pointer-events: none;
	visibility: hidden;
	-webkit-transition: visibility .3s;
	transition: visibility .3s;
}
.modal.is_close .modal-bg,
.modal.is_close .modal-content {
	opacity: 0;
	-webkit-transition: .3s opacity 0s;
	transition: .3s opacity 0s;
}
.modal.is_open {
	visibility: visible;
}
.modal.is_open .modal-bg {
	opacity: 1;
	-webkit-transition: .3s opacity 0s;
	transition: .3s opacity 0s;
}
.modal.is_open .modal-content {
	pointer-events: none;
	opacity: 1;
	-webkit-transition: .3s opacity .3s;
	transition: .3s opacity .3s;
}
.modal.is_open .btn-close, .modal.is_open .modal-inner {
	pointer-events: auto;
}
.modal.is_open .btn-close{
	position: absolute;
	top: 60px;
	right: 10px;
	content: url(../img/cmn/icon_close.png);
	width: auto;
	height: auto;
}
#business_introduction .department .media_img{
	text-align: center;
	max-width: 72%;
	margin: 0 auto;
}
#business_introduction .department .media_ttl{
	display: block;
	text-align: center;
	color: var(--main-color2);
	font-weight: 500;
	font-size: 1.7rem;
	margin-top: 8px;
	margin-bottom: 0;
}
#business_introduction .department:nth-of-type(2) .media_img img{
	max-width: 100%;
}

/*business_achievements
--------------------------------------------*/
#business_achievements{
	padding:48px 0 30px;
	background-color: #ecf4f2;
}
#business_achievements .ttl02{
	margin-bottom: 45px;
}
#business_achievements .ttl02::before{
	content: "Achievements";
}
#business_achievements .lead{
	margin-bottom: 24px;
	line-height: 2;
}
#business_achievements .data_wrapper{
	margin-bottom: 22px;
}
#business_achievements .data_wrapper:last-of-type{
	margin-bottom: 0;
}
#business_achievements .data{
	text-align: center;
	padding: 0 0 20px;
}
#business_achievements .ttl03{
	margin-bottom: 12px;
}
#business_achievements .data01{
	border-right: none;
	margin-bottom: 20px;
}
#business_achievements .data01 img{
	padding-right: 10%;
}
#business_achievements .data02 img{
	width: 75%;
	padding-right: 10%;
}
#business_achievements .ttl04{
	margin-bottom: 20px;
}
#business_achievements .note_txt{
	font-size: 1.2rem;
	padding-top: 10px;
	line-height: 1.5;
}
#business_achievements .note_txt dl{
	display: flex;
	margin-bottom: 5px;
}
#business_achievements .note_txt dt{
	font-weight: 400;
	color: var(--main-color3);
	width: 90px;
	text-align: left;
	font-size: 1.3rem;
}
#business_achievements .note_txt dt span{
	font-size: 1.1rem;
	display: inline-block;
	margin-left: 3px;
	padding-bottom: 2px;
}
#business_achievements .note_txt dd{
	flex: 1;
	text-align: left;
}


/*business_organization
--------------------------------------------*/
#business_organization{
	padding:38px 0 110px;
}
#business_organization .lead{
	width: 90%;
	margin: 0 auto 24px;
}
#business_organization .ttl02{
	margin-bottom: 40px;
}
#business_organization .ttl02::before{
	color: #fff2e9;
	content: "Organization";
	letter-spacing: 0;
}
#business_organization .ttl02::after{
	background-color: var(--main-color);
}
#business_organization .lead{
	font-size: 1.3rem;
	line-height: 2;
	margin-bottom: 32px;
}
#business_organization .sp_img_wrapper{
	width: 90%;
	margin: 0 auto;
	text-align: center;
}
#business_organization .sp_img_wrapper .note{
	text-align: left;
	padding-top: 10px;
}
.smartphoto-nav{
	display: none !important;
}



/*sec_jobs
--------------------------------------------*/
#sec_jobs{
	margin-bottom: 70px;
}