.tab {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	margin-top: 2vw;
}

.tab a {
	width: 200px;
	height: 50px;
	background-color: #fff;
	border-radius: 30px;
	margin: 0 10px;
	display: block;
	text-align: center;
	font-weight: 500;
	color: #222;
	line-height: 50px;
}

.tab .active {
	background-color: #008cd6;
	color: #fff;
}

.title {
	margin-top: 2.25vw;
}

.top_btns {
	width: 360px;
	position: relative;
}

.top_btns span {
	position: absolute;
	right: 0px;
	top: -10px;
	background-color: #ec4420;
	color: #fff;
	padding: 5px 10px;
	border-radius: 20px;
	font-size: 12px;
	height: auto;
	line-height: 1;
}

.cd {
	margin-top: 1.66vw;
	line-height: 1;
}

.top_box {
	padding-bottom: 1.66vw;
}

.introduction {
	width: 91.67%;
	margin: 6.25vw auto 0;
}

.int_top {
	color: #777;
	line-height: 2;
	text-align: center;
	margin-top: 2.6vw;
	padding-bottom: 1.6vw;
	border-bottom: 1px solid #ddd;
}

.int_top span {
	color: #008cd6;
}

.int_bot {
	color: #777;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-pack: center;
	justify-content: center;
	-ms-flex-align: center;
	align-items: center;
	margin-top: 1.77vw;
}

.int_bot>span:nth-child(1) {
	line-height: 1.5;
	font-weight: 700;
	color: #141515;
}

.chara {
	margin-top: 5.15vw;
}

.chara_list {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-top: 3.54vw;
	padding-bottom: 2vw;
}

.chara_items {
	width: 23.6%;
	margin-right: calc(5.6% / 3);
	background-color: #fff;
	box-shadow: rgba(0, 0, 0, .1) 0 4px 12px;
	padding: 2vw 1.5vw 1.8vw;
	border-radius: 10px;
}

.chara_items:nth-child(4n) {
	margin-right: 0;
}

.top_ico {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background-color: #008cd6;
	margin: 0 auto;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.top_ico img {
	width: auto;
	max-width: 80%;
}

.chara_tit {
	line-height: 1.5;
	color: #222;
	text-align: center;
	margin-top: 1.77vw;
}

.chara_des {
	color: #777;
	text-align: center;
	line-height: 24px;
	margin-top: 9px;
}

.conditions {
	margin-top: 4.25vw;
}

.cond {
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	border-radius: 10px;
	-ms-flex-align: center;
	align-items: center;
	background-color: #fff;
	box-shadow: rgba(0, 0, 0, .1) 0 4px 12px;
	margin-top: 3.125vw;

}

.cond>div {
	-ms-flex: 1;
	flex: 1;
}

.cond_right .text_list {
	padding: 0 11%;
}

.text_list li {
	position: relative;
	line-height: 2;
	color: #222;
	font-weight: 500;
	padding: 0.9375vw 0 0.9375vw 26px;
}

.text_list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: #008cd6;
	transform: translateY(-50%);
}

@media screen and (max-width:1600px) {
	.top_btns {
		width: 320px;
		height: 54px;
		border-radius: 27px;
		line-height: 54px;
	}

	.tab a {
		width: 220px;
		height: 54px;
		border-radius: 27px;
		line-height: 54px;
	}
}

@media screen and (max-width:1440px) {
	.text_list li {
		line-height: 1.5;
	}

}

@media screen and (max-width:1200px) {
	.top_btns {
		width: 280px;
	}
}

@media screen and (max-width:768px) {
	.int_bot>span:nth-child(2) {
		-ms-flex: 1;
		flex: 1;
	}

	.top_btns {
		width: 160px;
		height: 40px;
		border-radius: 20px;
		line-height: 40px;
		margin-top: 30px;
	}

	.top_btns span {
		top: -15px;
	}

	.tab a {
		width: 120px;
		height: 40px;
		border-radius: 20px;
		line-height: 40px;
	}

	.cd {
		margin-top: 10px;
		line-height: 1;
	}

	.top_box {
		padding-bottom: 20px;
	}

	.chara_list {
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.chara_items {
		width: 48%;
		margin-right: 4%;
		margin-bottom: 20px;
		padding: 5vw 3vw;
	}

	.chara_items:nth-child(2n) {
		margin-right: 0;
	}

	.top_ico {
		width: 50px;
		height: 50px;
	}

	.top_ico img {
		max-width: 50%;
	}

	.cond>div {
		-ms-flex: 0 0 100%;
		flex: 0 0 100%;
	}

	.int_top {
		line-height: 1.8;
	}

	.chara {
		margin-top: 30px;
	}

	.chara_list,
	.int_top {
		margin-top: 20px;
	}

	.cond {
		margin-top: 20px;
		overflow: hidden;
	}

	.cond_right .text_list {
		padding: 5%;
	}

	.cont1 {
		padding-bottom: 30px;
	}

	.tab {
		margin-top: 8vw;
	}

	.title {
		margin-top: 8vw;
	}
}