@charset "shift_jis";

/* ========================================
	#contents
======================================== */

/* soft-title */
#soft-title {
	background: #F00;
}
#soft-title h1 {
	min-width: 298px;
	padding: 6px 8px;
	color: #FFF;
	border-left: 6px solid  #FF0;
	font-size: 12px;
	line-height: 1.3;
}
#soft-title h1 .hard {
	padding-right: 8px;
	color: #FF0;
	display: table-cell;
	vertical-align: middle;
}
#soft-title .soft-title-name {
	display: table-cell;
}

/* main-inner */
#main-inner img {
	vertical-align: bottom;
}
.in-txt {
	position: relative;
}
.txt01 {
	position: absolute;
	top: 0;
	padding: 0 5%;
	color: #FFF;
	font-size: 13px;
	line-height: 1.69;
}

/* main-visual */
.main-visual .txt01 {
	width: 90%;
	text-align: center;
}

/* article01 */
.article01 .a01-btn01 {
	position: relative;
}
.article01 .a01-btn01 span {
	display: block;
	position: absolute;
	top: 11.25%;
	right: 0.78125%;
	width: 37.5%;
}

/* article03 */
.article03 .txt01 span {
	display: block;
	padding: 5% 0;
	font-size: 18px;
	line-height: 1.3;
}
.article03 .a03-btn01 {
	position: relative;
}
.article03 .a03-btn01 .btn {
	position: absolute;
	top: 0;
	padding: 0 4.6875%;
}

/* spec */
#spec {
	margin-bottom: 15px;
	padding-top: 20px;
	text-align: center;
}
#spec .back-btn {
	margin: 0 0 15px;
	text-align: center;
}
#spec .spec-border01 {
	padding: 15px 0 0;
	border-top: 1px solid #000;
}
#spec .logo {
	margin-bottom: 20px;
}
#spec .title {
	margin-bottom: 20px;
	font-size: 16px;
	font-weight: bold;
}
#spec .hardware {
	margin-top: 14px;
	margin: 20px 0;
}
#spec .official {
	position: relative;
	width: 250px;
	margin: 0 auto 20px;
}
#spec .official a {
	display: block;
	border-radius: 8px;
	padding: 18px 0;
	color: #FFF;
	text-decoration: none;
	background-repeat: no-repeat;
	background-position: 226px center;
	font-size: 15px;
}
#spec .official01 a {
	background-color: #000;
	background-image: url(../img/official_arrow01.png);
	background-size: 9px 8px;
}
#spec .official02 a {
	background-color: #FF2600;
	background-image: url(../img/official_arrow02.png);
	background-size: 16px 16px;
}
#spec .f-soft02 .f-ballon02 {
	position: relative;
	margin-bottom: -7px;
	text-align: center;
}
#spec .f-soft02 .f-ballon02::after {
	z-index: -2;
	content:'';
	display: block;
	position: absolute;
	top: 22px;
	width: 100%;
	border-bottom: 1px solid #000;
}
#spec .copy {
	display: block;
	padding: 0 10px;
	margin-bottom: 20px;
	color: #8C8C8C;
	text-align: center;
	font-size: 10px;
	line-height: 1.4;
}

/* clearfix */
.clearfix:after {
	content: '';
	display: block;
	clear: both;
}