/* タブの動作に関わる処理 */
.tab-content {
	transition: all .3s;
	opacity: 0;
}
.tab-content.is_show {
	opacity: 1;
}

.tabs {
	margin: 0px -5px 0 0;
	padding: 0 0px;
	overflow:auto;
	text-align:right;
}
.tabs li {
	display: inline-block;
	list-style: none;
	padding: 0 10px 0 10px;
	margin: 5px 5px 15px 5px;
	font-size: 12px;
	border:1px solid #CCC;
	text-align:center;
	width:40px;
}
.tabs li + li a {
	margin-left: 0px;
}
.tabs a {
	color: #333;
	display: block;
	font-size: 12px;
	padding: 2px 0px 2px 0px;
	margin: 0px 0px 0px 0px;
	position: relative;
	text-decoration: none;
	transition: all .3s;
	transform-origin: 50% 90%;
	text-align:center;
}
.tabs .is_active {
	box-shadow: none;
	font-weight: bold;
	z-index: 1;
	transform: scale(1.0);
}

body.pc .tab-content {
	width: 645px;
	background-color: #fff;
	border: 0px solid #eee;
	box-shadow: 0 1px 0 0 #ccc;
	padding: 0px 0px 30px 0;
	position: absolute;
	overflow:hidden;
}

body.pc .tab_wrap {
	width: 645px;
	height:auto;
	margin:0 auto;
	overflow:hidden;
	position: static;
}

body.sp .tab-content {
	width: 280px;
	background-color: #fff;
	border: 0px solid #eee;
	box-shadow: 0 1px 0 0 #ccc;
	padding: 0px 0px 30px 0;
	position: absolute;
}

body.sp .tab_wrap {
	width: 280px;
	height:auto;
	margin:0;
	overflow:auto;
	position: static;
}

body.sp .tabs {
	margin: 0px -5px 0 0;
	padding: 0 0px;
	overflow:auto;
	text-align:right;
}
body.sp .tabs li {
	display: inline-block;
	list-style: none;
	padding: 0;
	font-size: 10px;
	width:40px;
}
body.sp .tabs li + li a {
	margin-left: 0px;
}
body.sp .tabs a {
	color: #333;
	display: block;
	font-size: 10px;
	padding: 6px 0px 6px 0px;
	margin: 0px 0px 0px 0px;
	position: relative;
	text-decoration: none;
	transition: all .3s;
	transform-origin: 50% 90%;
	text-align:center;
}
body.sp .tabs .is_active {
	box-shadow: none;
	font-weight: bold;
	z-index: 1;
	transform: scale(1.0);
}
