@charset "utf-8";
/*******************************************************
mescius -http://www.mescius.jp/
Copyright(c)
by mescius GCTeam AC
*******************************************************/
/*** Form normalizing style  ***/
/* Base for label styling */

/*一覧 - カード型UI - 上書き用*/
.card--example-3 {
	position: unset;
	border-radius: 5px;
	border: solid 1px #2ea875;
}
.card--example-title {
    margin-bottom: 50px;
	font-weight: 600;
    font-size: 34px;
    line-height: 1.5;
    color: #2ea875;
    text-align: left;
}

.industry { 
	max-width: 250px;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
    padding: 0.5em 1em;
    margin: 2em 0;
    background: -webkit-repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
    background: repeating-linear-gradient(-45deg, #f0f8ff, #f0f8ff 3px,#e9f4ff 3px, #e9f4ff 7px);
}

.answer h4 { /* Forguncyだからできる解決策 */
	position: relative;
	color: white;
	font-size: 20px;
	background: #2ea875;
	line-height: 1.4;
	padding: 0.5em 0.5em 0.5em 1.8em;
	margin-bottom: 30px;
}
	.answer h4:before {
		font-family: "Font Awesome 5 Free";
		content: "\f14a";
		font-weight: 900;
		position: absolute;
		left : 0.5em; /*左端からのアイコンまでの距離*/
	}

.effect h4 {
	position: relative;
	border-top: solid 2px #2ea875;
	font-size: 20px;
	background: #f4f4f4;
	line-height: 1.4;
	padding: 0.4em 0.5em;
	margin: 2em 0 0.5em;
}
  
.effect h4:after {/*タブ*/
	position: absolute;
	font-family: "Font Awesome 5 Free";
	content: '\f0a7\ 導入効果';
	background: #2ea875;
	color: #fff;
	left: 0px;
	bottom: 100%;
	border-radius: 5px 5px 0 0;
	padding: 5px 7px 3px;
	font-size: 0.8em;
	line-height: 1;
	letter-spacing: 0.05em;
  }


select {
	padding: 0.7em 1em;
	border: solid 2px #036db7;
}

.sort--img-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 30%;
	height: fit-content;
	min-width: 200px;
/*	max-width: */
	margin-right: 5%;
	padding: 2rem 50px;
	background: #fff;
	border: solid 1px #c0c0c0;
}

.sort--img {
	width: 100%;
	max-width: 215px;
}

.sort--info-wrap {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	width: 65%;
}

.sort--title {
	font-size: 24px;
	margin-bottom: 1.5rem;
}

.sort--detail {
	color: #666;
	line-height: 2em;
	margin-bottom: 2rem;
}

.main-visual {
	display: flex;
	width: 80%;
	object-fit: contain;
	margin: 5rem auto 3rem;
}

.case--two-culumns {
	display: flex;
	margin-bottom: 2rem;
}

.case--column-left {
	width: 55%;
	margin-right: auto;
}

.case--column-right {
	width: 35%;
	text-align: center;
}

.img--interview {
	width: 100%;
	max-width: 300px;
	margin-bottom: 1.5rem;
}

.text--interview {
	font-size: 14px;
	line-height: 2em;
	color: #646464;
	text-align: center;
}

.case--point {
	width: 100%;
	padding: 2em;
	background: #c0d5e0;
}

.case--point_ul {
	margin: 0;
	padding-left: 20px;
}

.figure--case {
	display: flex;
	flex-direction: column;
	width: 100%;
	margin: 0 auto 3rem;
}

.figure--case-img {
	width: 100%;
	max-height: 450px;
	object-fit: contain;
}

.figure--case-caption {
	margin-top: 1rem;
	font-size: 14px;
	text-align: center;
}

.section--case-info {
	margin-top: 50px;
}

.case--info-img {
	margin-bottom: 2rem;
}

.table--case {
	width: 100%;
	min-width: 500px;
	border: solid 1px #999;
}

.table--case-th {
	width: 30%;
	padding: 15px 2rem;
	font-weight: bold;
	background: #b1d5e1;
}

.table--case-tr {
	border-bottom: solid 1px #999;
}

.table--case-td {
	padding: 15px 2rem;
}

.table--case-ul {
	margin: 0;
	padding-left: 20px;
}

.section--case-partner {
	background: #d7e0c0;
	padding: 20px 15px;
}

.block--case-parter_wrap {
	display: flex;
	flex-wrap: wrap;
	margin-top: 3rem;
}

.block--case-parter_img {
	min-width: 220px;
	margin: 0 2rem 1rem 0;
}

.block--case-parter_p {
	width: calc(100% - (220px + 3rem));
}


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

.main-visual {
	margin: 2.5rem auto 1.5rem;
	}
	
.case--two-culumns {
	flex-direction: column;
	align-items: center;
}
	
.case--column-left, .case--column-right {
	width: 100%;
	margin-bottom: 1.5rem;
	}
	
.block--case-parter_wrap {
	flex-direction: column;
	}
	
.block--case-parter_img {
	margin: 0 0 2rem;
	}
	
.block--case-parter_p {
	width: 100%;
	}	
}

/*数字付きカード型UI*/
.cardContainer {
	display: flex;
	flex-flow: row wrap;
	margin: 50px 0;
}

@media screen and (max-width: 768px) {
	.cardBox {
		width: 100%;
		margin-bottom: 50px;
	}
	.cardBox:last-child {
		margin-bottom: 20px;
	}
}

.cardBox {
	position: relative;
	padding: 60px 20px 80px;
	border: 2px solid #2ea875;
	border-radius: 5px;
	box-shadow: 0 5px 12px rgba(0, 0, 0, 0.15);
}
@media screen and (max-width: 768px) {
	.cardBox {
		padding: 50px 20px 40px;
	}
}

.cardBox img {
	display: block;
	max-width: 120px;
	margin: 0 auto 30px;
}

.cardTtl {
	text-align: center;
	font-size: 24px;
	line-height: 1.5;
	margin-bottom: 30px;
}
.cardTtl span{
	text-align: center;
	font-size: 130%;
	font-weight: bold;
}

.cardNumber {
	position: absolute;
	top: -35px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	display: inline-block;
	width: 70px;
	height: 70px;
	color: #fff;
	font-size: 160%;
	line-height: 1;
	padding-top: 15px;
	border: 2px solid #2ea875;
	border-radius: 50%;
	background-color: #2ea875;
	z-index: 0;
}

.cardText p {
	margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
	.cardText {
		margin-bottom: 50px;
	}
}
.cardText a {
	text-align: center;
	position: absolute;
	left: 28px;
}

.btn--green-line {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 200px;
	max-width: 100%;
	height: 50px;
	padding: 1rem;
	font-size: 1rem;
	color: #2ea875 !important;
	background: #eff3f5;
	border: solid 2px #2ea875;
	border-radius: 3rem;
}

.btn--green-line:hover, .btn--green-line:active {
	color: #fff !important;
	background: #2ea875;
	text-decoration: none;
}