@charset "UTF-8";

/* ------------------------------
    features
------------------------------ */
.ttl_sec{
	text-align: center;
	font-style: italic;
	font-weight: 700;
	font-size: 5.0rem;
	color: #0065AF;
}

@media screen and (max-width: 768px) {
	.ttl_sec{
		margin-bottom: 1em;
		font-size: 2.5rem;
	}
}
@media screen and (max-width: 330px) {
	.ttl_sec{
		font-size: 2.3rem;
	}
}

/* ------------------------------
    sec_what
------------------------------ */
.sec_what{
	min-width: 1200px; /*min-width*/
	padding: 70px 0 60px;
	background: url(../img/common/check_bg01.png);
}
.sec_what .ttl_sec{
	margin-bottom: 70px;
}
.sec_what .txt01{
	margin-bottom: 25px;
	line-height: 1.3;
	text-align: center;
	font-style: italic;
	font-weight: 700;
	font-size: 2.4rem;
}
.sec_what .txt01 .em{
	font-size: 3.4rem;
	color: #0065AF;
}
.sec_what .txt02{
	margin-bottom: 45px;
	line-height: 1.875;
	text-align: center;
	font-size: 1.6rem;
}
.sec_what .box_contents{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: center;
	width: 1200px;
	height: 300px;
	background: url(../img/features/what_bg01.png) no-repeat;
	background-size: 100% auto;
}
.sec_what .box_contents .box_ttl{
	width: 300px;
}
.sec_what .box_contents .box_ttl .ttl{
	line-height: 1.3;
	text-align: center;
	font-style: italic;
	font-weight: 700;
	font-size: 3.2rem;
	color: #fff;
}
.sec_what .box_contents .box_txt{
	width: 900px;
	border-left: 1px solid #ffffff;
}
.sec_what .box_contents .box_txt .box_figure{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 560px;
	margin: 0 auto 20px;
}
.sec_what .box_contents .box_txt .box_figure .cell{
	width: 136px;
	margin: 0;
}
.sec_what .box_contents .box_txt .box_figure .cell figcaption{
	margin-top: 15px;
	text-align: center;
	font-size: 1.6rem;
	color: #fff;
}
.sec_what .box_contents .box_txt .box_figure .plus{
	position: relative;
	width: 50px;
	height: 50px;
}
.sec_what .box_contents .box_txt .box_figure .plus:before{
	content: "";
	display: block;
	width: 2px;
	height: 100%;
	margin: auto;
	background-color: #fff;
}
.sec_what .box_contents .box_txt .box_figure .plus:after{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	content: "";
	display: block;
	width: 100%;
	height: 2px;
	margin: auto;
	background-color: #fff;
}
.sec_what .box_contents .box_txt .txt{
	text-align: center;
	font-size: 1.6rem;
	color: #fff;
}
@media screen and (max-width: 768px) {
	.sec_what{
		min-width: 0;
		padding: 10% 0;
		background-size: 700px auto;
	}
	.sec_what .ttl_sec{
		margin-bottom: 10%;
	}
	.sec_what .txt01{
		margin-bottom: 1.5em;
		font-size: 1.5rem;
	}
	.sec_what .txt01 .em{
		font-size: 2.2rem;
	}
	.sec_what .txt02{
		margin-bottom: 13%;
		font-size: 1.3rem;
	}
	.sec_what .box_contents{
		position: relative;
		display: block;
		width: auto;
		height: auto;
    	margin: 5.5% 0 14%;
    	padding: 4.8% 8.8%;
    	background-image: url(../img/index/support_bg01_02_sp.png);
    	background-repeat: repeat-y;
	}
	.sec_what .box_contents:before{
		position: absolute;
		top: 0;
		left: 0;
		content: "";
		display: block;
		width: 100%;
		height: 0;
		margin-top: -4.5%;
		padding-top: 6%;
		background: url(../img/index/support_bg01_01_sp.png) 50% 100% no-repeat;
		background-size: 100% auto;
	}
	.sec_what .box_contents:after{
	    position: absolute;
	    bottom: 0;
	    left: 0;
	    content: "";
	    display: block;
	    width: 100%;
	    height: 0;
	    margin-bottom: -4.5%;
	    padding-top: 6%;
	    background: url(../img/index/support_bg01_03_sp.png) 50% 0 no-repeat;
	    background-size: 100% auto;
	}
	.sec_what .box_contents .box_ttl{
    	width: auto;
    	border-bottom: 1px solid #fff;
	}
	.sec_what .box_contents .box_ttl .ttl{
    	margin-bottom: 9.8%;
    	font-size: 2.1rem;
	}
	.sec_what .box_contents .box_txt{
	    width: auto;
	    padding: 7% 0 0;
	    border-left: none;
	}
	.sec_what .box_contents .box_txt .box_figure{
		width: 100%;
	}
	.sec_what .box_contents .box_txt .box_figure .cell{
		width: 40%;
		text-align: center;
	}
	.sec_what .box_contents .box_txt .box_figure .cell img{
		width: 60%;
	}
	.sec_what .box_contents .box_txt .box_figure .cell figcaption{
		white-space: nowrap;
		font-size: 1.0rem;
	}
	.sec_what .box_contents .box_txt .box_figure .plus{
		width: 20px;
		height: 20px;
	}
	.sec_what .box_contents .box_txt .txt{
		line-height: 1.6;
		font-size: 1.1rem;
	}
}

/* ------------------------------
    sec_features
------------------------------ */
.sec_features{
	min-width: 1200px; /*min-width*/
	padding: 65px 0 35px;
}
.sec_features .ttl_sec{
	margin-bottom: 115px;
}
.anchor{
	display: block;
	margin-top: -260px;
	padding-top: 260px;
}
.box_features{
	position: relative;
	margin-bottom: 110px;
	padding: 0 80px 80px;
	text-align: center;
	border: 1px solid #141414;
	border-top: none;
}
.box_features:last-child{
	margin-bottom: 0;
}
.box_features .ttl_features{
	position: relative;
	display: inline-block;
	margin: -0.5em 0 65px;
	font-style: italic;
	font-weight: 700;
	font-size: 3.4rem;
}
.box_features .ttl_features .en{
	position: absolute;
	left: 0;
	bottom: 100%;
	width: 100%;
	margin-bottom: 10px;
    line-height: 1;
	text-align: center;
	font-family: 'Barlow Semi Condensed', sans-serif;
	font-style: italic;
	font-weight: 500;
	font-size: 2.24rem;
	color: #0065AF;
}
.js-ttlbar{
	width: 100%;
	height: 1px;
}
.js-ttlbar .bar01,
.js-ttlbar .bar02{
	position: absolute;
	top: 0;
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background-color: #141414;
	opacity: 1;
}
.js-ttlbar .bar01{
	left: 0;
}
.js-ttlbar .bar02{
	right: 0;
}
.box_features .flex{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.box_features .flex .img{
	width: 180px;
	height: 180px;
}
.box_features .flex .txt{
	width: 815px;
	line-height: 2;
	font-size: 1.6rem;
}
.box_features .flex .txt .em{
	font-style: normal;
	color: #0065AF;
}
.box_features .ttl_table{
	margin: 35px 0 20px;
	text-align: center;
	font-style: italic;
	font-weight: 700;
	font-size: 2.4rem;
	color: #0065AF;
}
.cover_table table{
	table-layout: fixed;
	width: 1040px;
	border-collapse: collapse;
	border-spacing: 0;
}
.cover_table table .empty{
	border-right: 3px solid #0065AF;
	background: none;
}
.cover_table table th{
	width: 208px;
	height: 60px;
	text-align: center;
	font-size: 1.6em;
	background-color: #E5F0F7;
}
.cover_table table thead th.cell_pro{
	background-color: #0065AF;
}
.cover_table table thead th{
	border-right: 1px solid #fff;
}
.cover_table table tbody th{
	border-bottom: 1px solid #fff;
}
.cover_table table tbody td{
	width: 208px;
	height: 60px;
	text-align: center;
	font-size: 1.6em;
}
.cover_table table .cell_pro{
	color: #0065AF;
	border-left: 3px solid #0065AF;
	border-right: 3px solid #0065AF;
}
.cover_table table tbody td{
	line-height: 1.25;
	background-color: #fff;
	border-right: 1px solid #E5F0F7;
	border-bottom: 1px solid #E5F0F7;
}
.cover_table table tbody td .small{
	display: block;
	text-align: center;
	font-size: 1.2rem;
}
.cover_table table tbody tr:last-child .cell_pro{
	border-bottom: 3px solid #0065AF;
}
.cover_table table tbody tr:last-child td{
	border-bottom: none;
}
.cover_table table tbody td:last-child{
	border-right: none;
}
.box_features .btn_link{
	margin-top: 10px;
}
.features01 .btn_link{
	width: 450px;
}
.features03 .btn_link{
	width: 640px;
}
.features04 .btn_link,
.features05 .btn_link{
	width: 380px;
}
.features05 .btn_link + .btn_link{
	margin-top: 20px;
}
@media screen and (max-width: 768px) {
	.sec_features{
		min-width: 0;
		padding: 10% 0;
	}
	.sec_features .ttl_sec{
		margin-bottom: 20%;
	}
	.anchor{
		margin-top: -100px;
		padding-top: 100px;
	}
	.box_features{
		margin-bottom: 25%;
		padding: 0 5% 8%;
	}
	.box_features .ttl_features{
		margin-bottom: 1em;
		line-height: 1.3;
		text-align: center;
		font-size: 1.8rem;
	}
	.box_features .ttl_features .en{
		font-size: 1.6rem;
	}
	.box_features:nth-of-type(1) .ttl_features,
	.box_features:nth-of-type(3) .ttl_features,
	.box_features:nth-of-type(4) .ttl_features,
	.box_features:nth-of-type(5) .ttl_features,
	.box_features:nth-of-type(6) .ttl_features{
		margin-top: -1em;
	}
	.box_features:nth-of-type(1) + .anchor{
		margin-top: -90px;
		padding-top: 90px;
	}
	.box_features .flex{
		display: block;
	}
	.box_features .flex .img{
		width: 50%;
		max-width: 150px;
		height: auto;
		margin: 0 auto 8%;
	}
	.box_features .flex .txt{
		width: auto;
		font-size: 1.3rem;
	}
	.box_features .ttl_table{
		margin: 10% 0 5%;
		font-size: 1.8rem;
	}
	.cover_table{
		overflow-x: scroll;
		-webkit-overflow-scrolling: touch;
	}
	.cover_table::-webkit-scrollbar{
		height: 5px;
	}
	.cover_table::-webkit-scrollbar-track{
		background-color: #fff;
	}
	.cover_table::-webkit-scrollbar-thumb{
		background-color: #E5F0F7;
	}
	.cover_table table{
		width: 700px;
	}
	.cover_table table th,
	.cover_table table tbody td{
		width: 120px;
		height: 50px;
		font-size: 1.3em;
	}
	.cover_table table tbody td .small{
		font-size: 1.1rem;
	}
	.box_features .btn_link,
	.features01 .btn_link,
	.features03 .btn_link,
	.features04 .btn_link,
	.features05 .btn_link{
		width: auto;
		margin-top: 8%;
	}
	.features05 .btn_link + .btn_link{
		margin-top: 8%;
	}
	.btn_link .link_txt{
		line-height: 1.2;
	}
}

/* ------------------------------
    sec_conference
------------------------------ */
.sec_conference .ttl_sec{
	text-align: left;
}
@media screen and (max-width: 768px) {
	.sec_conference .ttl_sec{
		text-align: center;
	}
	
	.cover_table table th.head{
		width: 34px;
		font-size: 12px;
	}
}