@charset "utf-8";
/* CSS Document */
/*******************************************************************************************
	index.css
********************************************************************************************/

/*==========================================================================
	メインビジュアル
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.mainArea {
	padding: 0 10px;
	background-color: #effcf6;
}
.mainArea .mainAreainnr {
	width: 100%;
	padding: 0 10px;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.mainArea .mainAreainnr .mainleft {
	width: 100%;
	padding: 40px 0 0;
}
.mainArea .mainAreainnr .mainright {
	width: 70%;
	margin: 0 auto;
}
.mainArea .mainAreainnr h1 {
	text-align: center;
	margin: 0 auto 20px;
	width: 90%;
}
.mainArea .mainAreainnr h2 {
	text-align: center;
	font-size: 40px;
	line-height: 1.3;
	margin-bottom: 20px;
}
.mainArea .mainAreainnr h2 span {
	color: #78be43;
}
.mainArea .mainAreainnr p {
	font-weight: 600;
	margin-bottom: 10px;
	font-size: 16px;
}
.mainArea .mainAreainnr p span {
	color: #78be43;
}

/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.mainArea .mainAreainnr {
	}
	.mainArea .mainAreainnr .mainleft {
		width: 60%;
		padding: 30px 0 0;
	}
	.mainArea .mainAreainnr .mainright {
		width: 40%;
	}
	.mainArea .mainAreainnr h1 {
		text-align: left;
		width: 80%;
		margin: 0 0 30px 0;
	}
	.mainArea .mainAreainnr h2 {
		text-align: left;
		font-size: 50px;
		margin-bottom: 30px;
	}
	.mainArea .mainAreainnr p {
		font-size: 18px;
		margin-bottom: 13px;
	}

}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.mainArea .mainAreainnr {
		max-width: 1100px;
		margin: 0 auto;
	}
	.mainArea .mainAreainnr .mainleft {
		width: 50%;
		padding: 80px 0 0;
	}
	.mainArea .mainAreainnr .mainright {
		width: 50%;
	}
	.mainArea .mainAreainnr h1 {
		width: 100%;
		margin: 0 0 40px 0;
	}
	.mainArea .mainAreainnr h2 {
		text-align: left;
		font-size: 66px;
		margin-bottom: 40px;
	}
	.mainArea .mainAreainnr p {
		font-size: 24px;
		margin-bottom: 13px;
	}
}

/*==========================================================================
	課題・要望
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.assiArea {
	background-color: #effcf6;
}
.assiArea .assiAreainnr {
	padding: 15px;
	background-color: #FFF;
	box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);
	border-top: 4px solid #78be43;
	box-sizing: border-box;
}
.assiArea .assiAreainnr .assiList {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content:center;
}
.assiArea .assiAreainnr .assiList li {
	width: 49%;
	margin: 10px 0;
	text-align: center;
	/*opacity: 0;*/
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.assiArea {
	}
	.assiArea .assiAreainnr {
		padding: 40px;
	}
	.assiArea .assiAreainnr .assiList li {
		width: 25%;
		margin: 10px 0;
	}
	
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.assiArea {
	}
	.assiArea .assiAreainnr {
		margin: 0 auto;
		max-width: 1200px;
	}
}


/*==========================================================================
	ラインナップメニュー　閉まるアニメ部分
============================================================================*/
.menuLineup {
	width: 100%;
}
.menuLineup .menuLineupinnr {
	overflow-x: hidden;
}

.contPin {
	background-color:#FFF;
	height: auto;
}
.lineupttl {
	height: auto;
	padding: 20px 0;
	background-color: #07191d;
	box-sizing: border-box;
	border-top: 6px solid;
    border-image: linear-gradient(to right, #117a40 0%, #5ab448 100%);
    border-image-slice: 1;
	color: #fbf5c2;
	line-height: 1.2;
	font-size: 22px;
	font-weight: 600;
	
	display: flex;
    align-items: center;
	justify-content: center;
	text-align: center;
}
.boxWap {
	height: auto;
	width: 100%;
	color: #FFF;
	font-weight: 600;
	position: relative;
	background-image:url("../common/img/intoro_cv_bg.jpg");
    background-size:cover;
	background-position: center center;
}
.box1 {
	background-color: #117a40;
	width: 100%;
	/*height: 50%;
	position: absolute;
	left:-100%;
	z-index: 1;*/
	/*text-align: center;*/
	box-sizing: border-box;
}
.box2 {
	background-color: #5ab448;
	width: 100%;
	/*height: 50%;
	position: absolute;
	top:50%;
	right: -100%;
	z-index: 1;*/
	/*text-align: center;*/
	box-sizing: border-box;
}
.box1wap,
.box2wap
{
	padding: 30px 10px;
	text-align: center;
}
.boxWap .ttl {
	font-size: 22px;
}
.boxWap ul {
	list-style: none;
}
.boxWap ul li {
	margin-top: 10px;
	font-weight: normal;
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.boxWap .ttl {
		font-size: 26px;
	}
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.menuLineup .menuLineupinnr {
	}
	.contPin {
		height: 100vh;
	}
	.lineupttl {
		height: 15vh;
		background-color: #07191d;
		box-sizing: border-box;
		border-top: 6px solid;
        border-image: linear-gradient(to right, #117a40 0%, #5ab448 100%);
        border-image-slice: 1;
		color: #fbf5c2;
		line-height: 1.2;
		font-size: 34px;
		font-weight: 600;
	
		display: flex;
    	align-items: center;
		justify-content: center;
		text-align: center;
	}
	.boxWap {
		height: 85vh;
		width: 100%;
		color: #FFF;
		font-weight: 600;
		position: relative;
		background-image:url("../common/img/intoro_cv_bg.jpg");
    	background-size:cover;
	}
	.box1 {
		background-color: #117a40;
		width: 50%;
		height: 100%;
		position: absolute;
		left:-50%;
		z-index: 1;
		/*text-align: center;*/
		box-sizing: border-box;
	}
	.box2 {
		background-color: #5ab448;
		width: 50%;
		height: 100%;
		position: absolute;
		top:auto;
		right: -50%;
		z-index: 1;
		/*text-align: center;*/
		box-sizing: border-box;
	}
		
	.box1wap,
	.box2wap {
		padding: 40px 0;
	}
	.boxWap .ttl {
		font-size: 30px;
	}
	.boxWap ul li {
		margin-top: 15px;
		font-weight: normal;
	}
}



/*==========================================================================
	ソリューション
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.solutionArea {
	background-color: #FFF;
}
.solutionArea .solutionAreainnr {
	padding: 0 10px;
	box-sizing: border-box;
}



/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.solutionArea .solutionAreainnr {
	}
}

/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.solutionArea .solutionAreainnr {
		box-sizing: border-box;
		margin: 0 auto;
		max-width: 1100px;
	}
}



/*==========================================================================
	強みエリア
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.forteArea {
	background-color: #117a40;
	padding: 8vw 10px 60px;
	position: relative;
	box-sizing: border-box;
	overflow: hidden;
}
.forteArea::before {
	content: "";
	z-index: 2;
    width: 0;
    height: 0;
    margin: auto;
    border-top: 6vw solid #FFF;
    border-left: 49.5vw solid transparent;
    border-right: 49.5vw solid transparent;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}
.forteArea .forteAreainnr {
	padding: 0 10px;
	box-sizing: border-box;
}

/*******************************
	1024px以上【PC】
********************************/
@media print, screen and (min-width: 1024px) {
	.forteArea .forteAreainnr {
		max-width: 1000px;
		margin: 0 auto;
	}
	
}
/*****************************************************
	767px以下【sp】
******************************************************/
/*------------------------------------------------------------------------------------
強みリスト
--------------------------------------------------------------------------------------*/
.forteArea .forteAreainnr .funcListEnd {
	list-style: none;
	box-sizing: border-box;
}
.forteArea .forteAreainnr .funcListEnd > li {
	margin-bottom: 10px;
	background-color: #FFF;
	box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
	border-radius: 6px;
	padding: 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.forteArea .forteAreainnr .funcListEnd > li .txtArea {
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 20px;
}
.forteArea .forteAreainnr .funcListEnd > li .picArea {
	box-sizing: border-box;
	width: 100%;
	background-color: #f7f5f5;
	border-radius: 8px;
	padding: 10px;
	text-align: center;
}
.forteArea .forteAreainnr .funcListEnd > li .txtArea2 {
	box-sizing: border-box;
	width: 100%;
	margin-bottom: 20px;
}
.forteArea .forteAreainnr .funcListEnd > li .picArea2 {
	box-sizing: border-box;
	width: 100%;
	background-color: #f7f5f5;
	border-radius: 8px;
	padding: 10px;
	text-align: center;
}
.forteArea .forteAreainnr .funcListEnd > li .ttl {
	font-size: 18px;
	margin-bottom: 5px;
	font-weight: bold;
}
/*******************************
	768px以上【tablet】
********************************/
@media print, screen and (min-width: 768px) {
	/*----------------
	強みリスト
	------------------*/
	.forteArea .forteAreainnr .funcListEnd {
		list-style: none;
	}
	.forteArea .forteAreainnr .funcListEnd > li {
		margin-bottom: 25px;
		background-color: #FFF;
		box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
		border-radius: 12px;
		padding: 20px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .txtArea {
		width: 100%;
	}
	.forteArea .forteAreainnr .funcListEnd > li .picArea {
		width: 100%;
		border-radius: 8px;
		padding: 15px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .txtArea2 {
		width: 55%;
	}
	.forteArea .forteAreainnr .funcListEnd > li .picArea2 {
		width: 42%;
		border-radius: 8px;
		padding: 15px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .ttl {
		font-size: 20px;
		margin-bottom: 15px;
	}
}
/*******************************
	1024px以上【PC】
********************************/
@media print, screen and (min-width: 1024px) {
	.forteArea .forteAreainnr {
		max-width: 1000px;
		margin: 0 auto;
	}
	/*----------------
	強みリスト
	------------------*/
	.forteArea .forteAreainnr .funcListEnd {
		max-width: 1000px;
		margin: 0 auto;
	}
	.forteArea .forteAreainnr .funcListEnd > li {
		padding: 30px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .txtArea {
		width: 100%;
		font-size: 20px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .picArea {
		width: 100%;
		border-radius: 8px;
		padding: 20px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .txtArea2 {
		width: 55%;
		font-size: 20px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .picArea2 {
		width: 42%;
		border-radius: 8px;
		padding: 20px;
	}
	.forteArea .forteAreainnr .funcListEnd > li .ttl {
		font-size: 26px;
		margin-bottom: 20px;
	}
}



/*==========================================================================
社会インフラとしてのAbsolute
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.infraArea {
	background-image:url("../common/img/infr_bg_cv.jpg");
    background-size:cover;
	background-position: center center;
}
.infraArea .infraAreainnr {
	padding: 0 10px;
}
.infraArea .infraAreainnr .infrMsgBox {
	width: 100%;
	box-sizing: border-box;
	padding: 20px;
	background-color: rgb(255 255 255 / 90%);
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.infraArea .infraAreainnr .infrMsgBox {
		width: 85%;
		box-sizing: border-box;
		padding: 30px;
		margin: 0 auto;
	}
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.infraArea .infraAreainnr .infrMsgBox {
		max-width: 1000px;
		margin: 0 auto;
		box-sizing: border-box;
		padding: 60px;
	}
}


/*==========================================================================
	タブ切り替え上のタイトル
============================================================================*/
.tabttlblock {
	display: none;
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.tabttlblock {
		display: flex;
		list-style: none;
		justify-content: space-between;
		margin-bottom: 5px;
	}
	.tabttlblock li {
		width: 49.8%;
		box-sizing: border-box;
		padding: 8px;
		background-color: #117a40;
		text-align: center;
		font-weight: 600;
		color: #FFF;
	}
	.tabttlblock li:last-child {
		background-color: #339966;
	}
}

/*==========================================================================
	Absolute Enterprise タブ切り替え
============================================================================*/
.solutionArea .enttcArea {
}
.enttcArea .tab-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  box-sizing: border-box;
}
.enttcArea .tab-container {
    margin: 0 0 6px;
}
.enttcArea .tab-container .tab {
  box-sizing: border-box;
  font-weight: 500;
  text-align:center;
  width: 100%;
  background-color: #f9f9f9;
  cursor: pointer;
  padding-bottom: 15px;
}
.enttcArea .tab-container .tab:hover {
	 background-color: #edf8ec;
}
.enttcArea .tab-container .tab .ttl {
	background-color: #c0e6bd;
	color: #000;
	padding: 10px;
	margin-bottom: 2px;
}
.enttcArea .tab-container .tab .detail {
	text-align: center;
	color: #FFF;
	background-color: #888888;
	padding: 5px;
	width: 80%;
	margin: 0 auto;
	border-radius: 30px;
	font-size: 14px;
	line-height: 1.4;
}
/*-- アクティブ時 --*/
.enttcArea .tab-container .tab.active {
  background-color: #edf8ec;
}
.enttcArea .tab-container .tab.active .ttl {
	background-color: #117a40;
	color: #fff;
	margin-bottom: 2px;
}
.enttcArea .tab-container .tab:nth-child(3).active .ttl,
.enttcArea .tab-container .tab:nth-child(4).active .ttl {
	background-color: #339966;
}
/*-- コンテンツ詳細部 --*/
.enttcArea .content-container .content {
  display: none; /*必須*/
}
.enttcArea .content-container .content.show {
  display: block; /*必須*/
}

/*-- タブコンテンツレイアウト----------------------------------------*/
.enttcArea .content-container .content .tcontwap {
	background-color: #edf8ec;
	border-top: solid 2px #59b047;
	padding: 15px;
}
.enttcArea .content-container .content .tcontwap .featbox {
	display: flex;
  	justify-content: space-between;
	align-items: center;
	background-color: #FFF;
	padding: 10px;
	border: 1px solid #CCCCCC;
	box-sizing: border-box;
	border-radius: 6px;
}
.enttcArea .content-container .content .tcontwap .featbox .iconArea {
	display: none;
}
.enttcArea .content-container .content .tcontwap .featbox .txtArea {
	width: 100%;
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.enttcArea .tab-container .tab {
 		width: 24.7%;
	}
	.enttcArea .tab-container .tab.active .detail {
  		background-color: #117a40;
	}
	.enttcArea .tab-container .tab:nth-child(3).active .detail,
	.enttcArea .tab-container .tab:nth-child(4).active .detail {
		background-color: #339966;
	}
	/*-- タブコンテンツレイアウト--*/
	.enttcArea .content-container .content .tcontwap {
		background-color: #edf8ec;
		border-top: solid 4px #117a40;
		padding: 30px;
	}
	.enttcArea .content-container .content .tcontwap .featbox {
		padding: 15px 20px;
		border-radius: 8px;
	}
	.enttcArea .content-container .content .tcontwap .featbox .iconArea {
		display: block;
		width: 25%;
	}
	.enttcArea .content-container .content .tcontwap .featbox .txtArea {
		width: 74%;
	}
	
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	/*-- タブコンテンツレイアウト--*/
	.enttcArea .content-container .content .tcontwap {
		padding: 40px;
	}
}


/*==========================================================================
	AbsoluteEndpoint タブ切り替え
============================================================================*/
.solutionArea .endtcArea {
}
.endtcArea .tab-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  box-sizing: border-box;
}
.endtcArea .tab-container {
    margin: 0 0 6px;
}
.endtcArea .tab-container .tab {
  box-sizing: border-box;
  font-weight: 500;
  text-align:center;
  width: 100%;
  background-color: #f9f9f9;
  cursor: pointer;
  padding-bottom: 15px;
}
.endtcArea .tab-container .tab:hover {
	 background-color: #edf8ec;
}
.endtcArea .tab-container .tab .ttl {
	background-color: #c0e6bd;
	color: #000;
	padding: 10px;
	margin-bottom: 2px;
}
.endtcArea .tab-container .tab .detail {
	text-align: center;
	color: #FFF;
	background-color: #888888;
	padding: 5px;
	width: 80%;
	margin: 0 auto;
	border-radius: 30px;
	font-size: 14px;
	line-height: 1.4;
}
/*-- アクティブ時 --*/
.endtcArea .tab-container .tab.active {
  background-color: #edf8ec;
}
.endtcArea .tab-container .tab.active .ttl {
	background-color: #5ab448;
	color: #fff;
	margin-bottom: 2px;
}
/*-- コンテンツ詳細部 --*/
.endtcArea .content-container .content {
  display: none; /*必須*/
}
.endtcArea .content-container .content.show {
  display: block; /*必須*/
}

/*-- タブコンテンツレイアウト----------------------------------------*/
.endtcArea .content-container .content .tcontwap {
	background-color: #edf8ec;
	border-top: solid 2px #59b047;
	padding: 15px;
}
.endtcArea .content-container .content .tcontwap .featbox {
	display: flex;
  	justify-content: space-between;
	align-items: center;
	background-color: #FFF;
	padding: 10px;
	border: 1px solid #CCCCCC;
	box-sizing: border-box;
	border-radius: 6px;
}
.endtcArea .content-container .content .tcontwap .featbox .iconArea {
	display: none;
}
.endtcArea .content-container .content .tcontwap .featbox .txtArea {
	width: 100;
}
/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.endtcArea .tab-container .tab {
 		width: 33%;
	}
	.endtcArea .tab-container .tab.active .detail {
  		background-color: #5ab448;
	}
	/*-- タブコンテンツレイアウト--*/
	.endtcArea .content-container .content .tcontwap {
		background-color: #edf8ec;
		border-top: solid 4px #59b047;
		padding: 30px;
	}
	.endtcArea .content-container .content .tcontwap .featbox {
		padding: 30px;
		border-radius: 8px;
	}
	.endtcArea .content-container .content .tcontwap .featbox .iconArea {
		display: block;
		width: 25%;
	}
	.endtcArea .content-container .content .tcontwap .featbox .txtArea {
		width: 74%;
	}
	
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	/*-- タブコンテンツレイアウト--*/
	.endtcArea .content-container .content .tcontwap {
		padding: 40px;
	}
}

/*==========================================================================
タブコンテンツの中のリストボックス
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/
.opt01_featList {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 20px 0;
	
	font-size: 14px;
}
.opt01_featList > li {
	background-color: #FFF;
	/*box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);*/
	width: 100%;
	margin-bottom: 20px;
}
.opt01_featList > li .ttl {
	background-color: #59b047;
	text-align: center;
	color: #FFF;
	padding: 4px;
}
.opt01_featList > li .innr {
	padding: 10px;
}
.opt01_featList > li .innr .sttl {
	font-weight: 500;
	margin-bottom: 15px;
	font-size: 18px;
	line-height: 1.4;
	text-align: center;
}
.opt01_featList > li .innr p {
	line-height: 1.8;
	font-size: 18px;
	padding: 10px 15px;
	margin: 10px 0;
}

/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.opt01_featList > li .innr {
		padding: 20px 10px;
	}
	.opt01_featList > li {
		width: 49%;
		margin-bottom: 30px;
	}
	.opt01_featList > li .innr .sttl {
		font-size: 18px;
	}
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.opt01_featList > li .innr {
		padding: 20px 10px;
		font-size: 18px;
	}
}
/*****************************************************
	767px以下【sp】
******************************************************/
.opt02_featList {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 20px 0;
	
	font-size: 14px;
}
.opt02_featList > li {
	background-color: #FFF;
	/*box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.2);*/
	width: 100%;
	margin-bottom: 20px;
}
.opt02_featList > li .ttl {
	background-color: #59b047;
	text-align: center;
	color: #FFF;
	padding: 4px;
}
.opt02_featList > li .innr {
	padding: 10px;
}
.opt02_featList > li .innr .sttl {
	font-weight: 500;
	margin-bottom: 15px;
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
}
.opt02_featList > li .innr p {
	line-height: 1.8;
	font-size: 15px;
	padding: 10px 15px;
	margin: 10px 0;
}

/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
	.opt02_featList > li .innr {
		padding: 20px 10px;
	}
	/*.opt02_featList > li {
		width: 48%;
		margin-bottom: 30px;
	}*/
	.opt02_featList > li .innr .sttl {
		font-size: 18px;
	}
}
/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
	.opt02_featList > li .innr {
		padding: 20px 10px;
	}
}


/*==========================================================================
	
============================================================================*/
/*****************************************************
	767px以下【sp】
******************************************************/


/*****************************************************
	320px以下【sp】
******************************************************/
@media print, screen and (max-width: 320px) {
}

/*****************************************************
	768px以上【tablet】
******************************************************/
@media print, screen and (min-width: 768px) {
}

/*****************************************************
	1024px以上【PC】
******************************************************/
@media print, screen and (min-width: 1024px) {
}

