@charset "utf-8";



/* ---[-] ページタイトル --- */
/* Justware AIアプリケーションフレームワーク */
.Platform.AIapfw #TopPageTitleArea {
	background-image: url(../ai-apfw/image/bg_pagetitle_main_aiapfw.png);
}

.Platform.AIapfw #TopPageTitleArea .PageTitleStyle3 {
	height: 260px;
	margin: 0 auto;
}

.Platform.AIapfw #TopPageTitleArea .SubTitle {
	display: table;
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	padding-top: 48px;
	font-size: 100%;
	color: #ffffff;
	text-shadow: 1px 1px 0 #00477a;
}

.Platform.AIapfw #TopPageTitleArea .SubTitle span {
	display: table-cell;
	text-align: center;
	vertical-align: middle;
	width: 100%;
	height: 40px;
	padding-top: 2px;
	background-color: rgba(0, 71, 122, 0.7);
	box-sizing: border-box;
}

.Platform.AIapfw #TopPageTitleArea h1 {
	position: relative;
	width: 600px;
	height: 125px;
	margin: 0 auto;
	box-sizing: border-box;
}

.Platform.AIapfw #TopPageTitleArea h1 span {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	padding: 0 15px;
	line-height: 130%;
	text-align: center;
	font-size: 185%;
	font-weight: bold;
	color: #ffffff;
	background-color: rgba(0, 71, 122, 0.9);
	box-sizing: border-box;
}

/* ---[-] イントロ --- */
.Platform #about {
	text-align: center;
}

.Platform #about h2 {
	margin-bottom: 18px;
	font-size: 127.5%;
}

.Platform #about .AboutBox .TextStyle1 {
	line-height: 150%;
}

.Output {
	margin: 25px auto 15px;
	padding-top: 10px;
}

.Output .CatchCopy {
	margin-top: 25px;
	line-height: 170%;
	font-size: 200%;
	color: #00477a;
}

.Output .CatchCopy strong {
	color: inherit;
}

.Output .OutputText {
	display: inline-block;
}

.Output .OutputText .CatchCopy {
	margin-top: 10px;
	margin-bottom: 2px;
	font-size: 160%;
	font-weight: bold;
}

.Output .OutputList li {
	margin-bottom: 6px;
	padding: 5px 20px 3px;
	line-height: 130%;
	font-size: 120%;
	color: #ffffff;
	background-color: #00477a;
	border-radius: 30px;
	box-sizing: border-box;
}

dl.ListStyle1.Square {
	margin-bottom: 8px;
	text-align: left;
}

dl.ListStyle1.Square dt {
	font-weight: bold;
	text-indent: -1em;
	background-image: none;
}
dl.ListStyle1.Square dt:before {
	content: "■";
}

/* ---[-] 機能構成 --- */
.Platform #function {
	padding: 40px 0;
	background-color: #ccdae4;
}

.Platform #function h2 {
	padding-bottom: 5px;
	font-size: 190%;
}

#function .TextStyle1 {
	margin-bottom: 35px;
	line-height: 175%;
	text-align: center;
	font-size: 100%;
}

.FunctionList {
	display: flex;
	flex-flow: row wrap;
}

.FunctionList li {
	width: 315px;
	margin: 0 0 15px 10px;
	box-sizing: border-box;
}
.FunctionList li:first-child {
	margin-left: 0;
}

.FunctionList li div {
	height: 100%;
	padding: 15px 15px 0;
	background-color: #ffffff;
	border: 1px solid #707070;
	box-sizing: border-box;
}

.FunctionList li h3 {
	margin: 0 -10px 10px;
	text-align: center;
	font-size: 110%;
	color: #333333;
}

#function .FunctionList li .TextStyle1 {
	margin-bottom: 10px;
	text-align: left;
	line-height: 150%;
	font-size: 90%;
}

.FunctionList dl.ListStyle1 {
	margin-bottom: 15px;
}

.FunctionList dl.ListStyle1 dt {
	text-indent: -1em;
	font-weight: bold;
	background-image: none;
}
.FunctionList dl.ListStyle1 dt:before {
	content: "●";
}

.FunctionImage {
	display: inline-block;
	max-width: 100%;
	vertical-align: top;
}

.FunctionImage dl {
	margin-top: 30px;
}

/* ---[-] 特長 --- */
.Platform #feature {
	padding-bottom: 45px;
	background-color: #d9f2f0;
}

.Platform #feature h2 {
	margin-bottom: 25px;
	font-size: 190%;
}

#feature .FeatureSection {
	max-width: 810px;
	margin: 0 auto 30px;
}
#feature .FeatureSection:last-child {
	margin-bottom: 0;
}

.FeatureSection .FeatureList {
	display: table;
}

.FeatureSection .FeatureList .FeatureListHeader {
	display: table-cell;
	width: 150px;
	padding-right: 25px;
	vertical-align: middle;
}

.FeatureSection .FeatureList .FeatureDetail {
	display: table-cell;
	vertical-align: middle;
	overflow: hidden;
}

.FeatureSection h3 {
	margin-bottom: 5px;
	font-size: 125%;
	color: #00477a;
}

.FeatureSection p {
	line-height: 175%;
	font-size: 100%;
}

.FeatureSection ul li {
	margin: 5px 0 0 1em;
	text-indent: -1em;
}
.FeatureSection ul li:before {
	content: "●";
}

/* ---[-] サービスメニュー --- */
.AIapfw #service h2 {
	font-size: 190%;
}


/* for Responsive Web Design
=========================================================================================== */
/*--- for - 994px ---*/
@media screen and (max-width: 994px) {
	.JS .FunctionList {
		margin-left: -10px;
	}

	.JS .FunctionList li {
		width: 33.33333333%;
		margin-left: 0;
		padding-left: 10px;
	}

	.JS .AIapfw #exampleContents > div {
		max-width: 654px;
		margin: 0 auto;
		text-align: left;
	}

	.JS .AIapfw #exampleContents div.inlineEx {
		text-align: center;
	}
}

/*--- for - 767px ---*/
@media screen and (max-width: 767px) {
	.JS .Platform.AIapfw #TopPageTitleArea .PageTitleStyle3 {
		height: 230px;
		background-color: transparent;
	}

	.JS .Platform.AIapfw #TopPageTitleArea .SubTitle {
		max-width: 480px;
		font-size: 96%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 {
		width: 480px;
		height: 100px;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 span {
		font-size: 150%;
	}

	.JS #about .TextStyle1,
	.JS #function .TextStyle1 {
		text-align: left;
	}

	.JS .Output .CatchCopy {
		font-size: 170%;
	}

	.JS .Output .OutputList li {
		text-align: left;
	}

	.JS .FunctionList li {
		width: 100%;
	}
}

/*--- for - 579px ---*/
@media screen and (max-width: 579px) {
	.JS .Platform #TopPageTitleArea .Title {
		padding-top: 6.55%;
		font-size: 83%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea .PageTitleStyle3 {
		height: 0;
		padding-bottom: 39.655172%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea .SubTitle {
		width: 82.75862069%;
		padding-top: 8%;
		font-size: 71%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea .SubTitle span {
		height: 35px;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 {
		width: 82.75862069%;
		height: 0;
		padding-bottom: 17.24137931%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 span {
		font-size: 4.3vw;
	}

	.JS .Platform #what p,
	.JS .Platform #about .TextStyle1,
	.JS .Platform #function .TextStyle1,
	.JS .FeatureSection p {
		font-size: 96%;
	}

	.JS .Platform #about .Output .CatchCopy {
		font-size: 150%;
	}

	.JS .AboutSection dl.ListStyle1.Square dt {
		font-size: 90%;
	}

	.JS .Platform #about h2 {
		font-size: 120%;
	}

	.JS .Platform #about .Output .OutputText .CatchCopy {
		margin-bottom: 5px;
		line-height: 130%;
		text-align: left;
	}

	.JS .Output .OutputList li {
		font-size: 110%;
	}

	.JS .FeatureList .FeatureListHeader {
		width: 30%;
		padding-right: 15px;
		vertical-align: top;
	}

	.JS .FeatureList .FeatureListHeader img {
		width: 100%;
		max-width: 150px;
	}

	.JS .FeatureList .FeatureDetail {
		width: 70%;
		vertical-align: top;
	}
}

/*--- for - 399px ---*/
@media screen and (max-width: 399px) {
	.JS .Platform.AIapfw #TopPageTitleArea .SubTitle {
		width: 90%;
		max-width: 330px;
		padding-top: 6.55%;
		font-size: 63%;
	}
	.JS .Platform.AIapfw #TopPageTitleArea .SubTitle span {
		height: 30px;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 {
		width: 90%;
		max-width: 330px;
		padding-bottom: 18.75%;
	}

	.JS .Platform.AIapfw #TopPageTitleArea h1 span {
		font-size: 4.8vw;
		padding-left: 5px;
		padding-right: 5px;
	}

	.JS #what {
		padding-top: 25px;
		padding-bottom: 20px;
	}

	.JS #what p {
		line-height: 160%;
	}

	.JS .Platform #what p,
	.JS .Platform #about .TextStyle1,
	.JS .Platform #function .TextStyle1,
	.JS .FeatureSection p {
		font-size: 90%;
	}

	.JS .Platform #about {
		padding-bottom: 15px;
	}

	.JS .Platform #about .Grid4 > p:nth-of-type(1) {
	    font-size: 83%;
	}

	.JS .Platform #about h2 {
		text-align: left;
	}

	.JS .Output {
		margin-top: 15px;
	}

	.JS .Output .OutputList li {
		padding-left: 15px;
		padding-right: 15px;
		font-size: 90%;
	}

	.JS .Platform #about .Output .CatchCopy {
		font-size: 130%;
	}

	.JS .Platform #about h2 {
		padding-bottom: 0;
	}

	.JS .Platform #function,
	.JS .Platform #feature {
		padding-top: 20px;
		padding-bottom: 20px;
	}

	.JS .Platform #feature h2 {
		margin-bottom: 5px;
	}

	.JS .Platform #function .TextStyle1 {
		margin-bottom: 15px;
	}

	.JS #feature .FeatureSection {
		margin-bottom: 30px;
	}
	.JS #feature .FeatureSection:last-child {
		margin-bottom: 0;
	}

	.JS .FeatureSection ul {
		font-size: 90%;
	}

	.JS .FeatureList .FeatureListHeader {
		display: block;
		width: 100px;
		padding-right: 0;
		margin: 0 auto 15px;
	}

	.JS .FeatureList .FeatureDetail {
		display: block;
		width: auto;
	}
}
