@charset "UTF-8";

/* =================================
common
================================= */

html,body{
	background: #FFF;
}

.only-sp{
	display: none;
}
@media screen and (max-width: 640px) {
	.only-pc{
		display: none;
	}
	.only-sp{
		display: block;
	}
	.only-sp-new{
		color:#1da2cc;
	}
}

/*.category-products #rim-tpl-header #rim-tpl-categorynav li.rim-tpl-btn-products a {
	background-position: left 0;
}*/
#rim-tpl-header #rim-tpl-categorynav li.rim-tpl-btn-products a:hover {
	background-position: left -39px;
}

#container {
	background-color: #fff;
	border-top: 1px solid #ccc;
}
@media screen and (max-width: 640px) {
	#container {
		width: 100%;
		border-top: none;
	}
}
.main-contents .text-nomal {
	font-size: 14px;
	line-height: 1.5;
	color: #333;
}

/* =================================
main-contents
================================= */
.main-contents {
	background-color: #fff;
	max-width: 980px;
	margin: 0 auto;
}
@media screen and (max-width: 640px) {
	.main-contents {
		padding: 0 15px 15px 15px;
	}
}
.main-contents .main-visual {
	width: 100vw;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	background: url("../img/main_bg.png") no-repeat;
	background-size: cover;
}
.main-contents .main-visual h2 {
	margin: 0 auto;
	position: relative;
	max-width: 980px;
}
.main-contents .main-visual h2 img {
	max-width: 980px;
	width: 100%;
	margin: auto;
}
.main-contents .main-visual h2 img.btn{
	margin:0 auto;
	width: 172px;
	position: absolute;
	right: 0px;
	bottom: 45px;
}
@media screen and (max-width: 640px){
	.main-contents .main-visual h2 img.btn{
		width:32%;
		bottom: -15px;
		right: 30px;
	}
}
.main-contents .main-visual p{
	margin: 0 auto;
	max-width: 1180px;
}
.main-contents .main-visual p img{
	max-width: 1180px;
	width: 100%;
	margin: auto;
}
@media screen and (max-width: 640px){
	.main-contents .main-visual p img{
		width:86%;
	}
}

.main-contents .ban-tit {
	text-align: center;
	font-size: 32px;
	line-height: 1.5;
	color: #333;
	margin-bottom: 10px;
	/*padding:0 50px;*/
	margin-top:40px;
}
@media screen and (max-width: 640px){
	.main-contents .ban-tit {
		font-size: 22px;
		line-height: 1.5;
		margin-bottom: 5px;
		/*padding:0 50px;*/
		margin-top:20px;
	}
}


.special_banner {
	display: block;
	margin-left: auto;
	font-size: 12px;
	width: 210px;
	text-align: center;
}
.special_banner img{
	width:100%;
}
.special_banner .stxt {
	padding: 2px 0 1px 10px;
	background: url(/common/img/icon-cursor.png) no-repeat 0 center;
}
@media screen and (max-width: 750px) {
	.special_banner {
		margin: 30px auto;
		width:80%;
	}

}

.main-contents .contents-txt {
	font-size: 14px;
	line-height: 1.5;
	color: #333;
	margin-bottom: 40px;
	/*padding:0 50px;*/
	margin-top:30px;
}

.main-contents .begining-area .contents-txt{
	padding:0 70px;
}
@media screen and (max-width: 640px){
	.main-contents .contents-txt{
		margin-bottom: 30px;
		/*padding:0;*/
	}
	.main-contents .begining-area .contents-txt{
		padding:0;
	}
}
/*.main-contents .begining-area {
	padding-bottom: 40px;
}*/


.main-contents .intro-block{
	margin-bottom: 70px;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block{
		margin-bottom: 50px;
		padding:0 10px;
	}
}
.main-contents .intro-block .intro{
	width:680px;
	padding:40px;
	box-sizing:border-box;
	-moz-box-sizing:border-box; 
	-webkit-box-sizing:border-box; 
	text-align: center;
	margin:0 auto;
	border:3px solid #3068a0;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro{
		width:100%;
		height:auto;
		padding:25px 20px;
	}
}
.main-contents .intro-block .intro .division{
	/*color:#3068a0;*/
	font-size: 12px;
	font-weight: bold;
	margin-bottom:10px;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .division{
		font-size: 10px;
	}
}
.main-contents .intro-block .intro .ttl{
	font-size: 24px;
	width: 45%;
	font-weight: bold;
	padding-bottom:10px;
	margin:0 auto 35px;
	border-bottom:2px solid #3068a0;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .ttl{
		margin-bottom:20px;
		width: 85%;
		font-size: 18px;
	}
}
.main-contents .intro-block .intro .text{
	font-size: 14px;
	line-height: 2.0;
	margin-bottom:25px;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .text{
		font-size: 12px;
		margin-bottom:15px;
	}
}
.main-contents .intro-block .intro .detail{
	font-size: 14px;
	line-height: 2.0;
	margin-bottom:25px;
	text-align: left;
	text-indent: -5em;
	margin-left: 160px;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .detail{
		font-size: 12px;
		margin-left:5em;
	}
}
.main-contents .intro-block .intro .time{
	margin-bottom: 30px;
}
.main-contents .intro-block .intro .time span{
	display: inline-block;
	font-size: 18px;
	font-weight: bold;
	color:#333;
	padding:8px 25px;
	background: #eee;
	border-radius: 20px;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .time span{
		font-size: 14px;
	}
}
.main-contents .intro-block .intro .note{
	font-size: 12px;
	text-align: center;
	line-height: 1.6;
	margin-bottom:0;
}
@media screen and (max-width: 640px){
	.main-contents .intro-block .intro .note{
		text-align: left;
	}
}

.main-contents .accordion-contents .ttl{
	font-size: 22px;
	font-weight: bold;
	color:#333;
	padding-left:25px;
	background: url("../img/arrow_r.gif") no-repeat left top 8px;
	background-size: 12px;
	display: inline-block;
	cursor: pointer;
	margin-bottom: 50px;
}
.main-contents .accordion-contents .ttl.close{
	background: url(../img/arrow_b.gif) no-repeat left top 8px;
	background-size: 12px;
}
.main-contents .accordion-contents .ttl .smaller{
	font-size: 16px;
}
@media screen and (max-width: 640px){
	.main-contents .accordion-contents .ttl{
		font-size: 20px;
		background: url("../img/arrow_r.gif") no-repeat left top 10px;
		background-size: 8px;
		padding-left:18px;
		margin-bottom: 30px;
	}
	.main-contents .accordion-contents .ttl.close{
		background: url(../img/arrow_b.gif) no-repeat left top 10px;
		background-size: 8px;
	}
	.main-contents .accordion-contents .ttl .smaller{
		font-size: 14px;
	}
}
.main-contents .main-btn{
	width:430px;
	height:80px;
	margin:0 auto 70px;
	background: #292929;
	border-radius: 6px;
}
.main-contents .main-btn a{
	display: inline-block;
	width:400px;
	line-height: 1.0;
	padding:28px 0 28px 45px;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	margin:0px 0 70px;
	color:#fff;
	background: url("../img/icon_arrow_r.png") no-repeat left 35px top 32px;
	background-size: 10px;
	box-sizing: border-box;
	
}
.main-contents .main-btn img{
	max-width: 400px;
}
@media screen and (max-width: 640px){
	.main-contents .main-btn{
		width:100%;
		margin:0px auto 50px;
		height:60px;
		max-width: 370px;
	}
	.main-contents .main-btn a{
		width:100%;
		font-size: 20px;
		padding:20px 0 20px 10px;
		background: url("../img/icon_arrow_r.png") no-repeat left 35px top 23px;
		background-size: 8px;
	}
}
@media screen and (max-width: 375px){
	.main-contents .main-btn a{
		padding:20px 0 20px 15px;
		background: url("../img/icon_arrow_r.png") no-repeat left 25px top 23px;
		background-size: 8px;
	}
}
@media screen and (max-width: 330px){
	.main-contents .main-btn a{
		background: url("../img/icon_arrow_r.png") no-repeat left 16px top 23px;
		background-size: 8px;
		font-size: 18px;
	}
}

@media screen and (max-width: 640px) {
	.main-contents .lead {
		margin: 0px 0;
		padding: 20px 0 40px 0;
	}
}
.main-contents .article{
	padding-bottom: 40px;
}
@media screen and (max-width: 640px){
	.main-contents .article.a1{
		padding-bottom: 10px;
	}
}
.main-contents h2{
	text-align: center;
	margin-bottom: 20px;
}

/* .article a1
-------------------------------- */

.main-contents .a1 h3{
	font-size: 16px;
  	font-weight: 800;
	margin-bottom: 20px;
	padding: 10px 0 10px;
	border-bottom: 1px solid #000;
}
.main-contents .a1 h2 span{
	float: none;
}
.main-contents .a1 ul{

}
.main-contents .a1 ul li{
	float: left;
	text-align: center;
	margin-bottom: 50px;
	position: relative;
}
.main-contents .a1 ul li .name{
	display: inline-block;
	font-size: 18px;
	font-weight: bold;
	width:100%;
	text-align: center;
	position: absolute;
	bottom:-5px;
	left:0;
}
@media screen and (max-width: 640px){
	.main-contents .a1 ul li .name{
		font-size: 13px;
		bottom:0px;
	}
}
.main-contents .a1 ul li img{
	width:166px;
}

.main-contents .a1 ul.hard_1{
	width:740px;
	margin:0 auto;
}
.main-contents .a1 ul.hard_1 li{
	width:33.33%;
}
.main-contents .a1 ul.hard_2 li{
	width:24%;
}

.main-contents .a1 ul.hard_sp li{
	width:45%;
	padding: 0 2.5%;
}
.main-contents .a1 ul.hard_sp li img{
	width:100%;
}
/* .article a2
-------------------------------- */

.main-contents .a2 h2 span{
	float: none;
}
.main-contents .a2 .app-acordion{
	border: #ccc 1px solid;
}
.main-contents .a2 h3{
	cursor: pointer;
	font-size: 16px;
	text-align: center;
  	font-weight: 800;
	padding: 15px 0;
}
.main-contents .a2 h3:hover{
	opacity: 0.6;
	text-decoration: underline;
}
.main-contents .a2 .app-reg{
	padding: 0 30px 30px 30px;

}
.main-contents .a2 .app-reg ul{
	padding: 0 0 0 8px;
	list-style-type: disc;
}
.main-contents .a2 ul li{
	font-size: 12px;
	line-height: 1.5;
	margin-top: 10px;
}


/* .article a3
-------------------------------- */

.main-contents .a3 p.text-nomal{
	margin: 0 0 10px 0;
	text-align: center;
}
.main-contents .a3 .btn-block{
	width:82.68%;
	margin:0 auto;
}
/*.main-contents .a3 .btn-block .btn-red{
	margin-right: 30px;
}*/
.main-contents .a3 .modal-button{
	margin: 0 auto 20px;
	display: block;
	width: 390px;
	height: 90px;
	padding:25px 0 15px;
	cursor: pointer;
	font-size: 28px;
	text-align: center;
	font-weight: bold;
	border-style: none;
	color: #fff;
	background: url(../img/btn-golden.png) no-repeat;
	
}
.main-contents .a3 .modal-button span.small{
	font-size: 20px;
}
.main-contents .a3 .modal-button a{
	color: #fff;
}
@media screen and (max-width: 640px){
	.main-contents .a3 .btn-block{
		width:100%;
	}
	.main-contents .a3 .modal-button{
		width: 76.8%;
		height: auto;
		padding:15px 0; 
		border-radius: 5px;
		font-size: 17px;
		background: url(../img/btn-golden_sp.png) no-repeat;
		background-size: 100%;
	}
	.main-contents .a3 .modal-button a{

	}
	
	.main-contents .a3 .modal-button span.small{
		font-size: 13px;
	}
	
}
.main-contents .a3 .modal-button a:hover{
	text-decoration: underline;
}
.main-contents .center{
	text-align: center;
}
.main-contents .note{
	font-size: 14px;
	/*text-align: center;*/
	margin-bottom: 20px;
}
.main-contents .a1 .note{
	font-size: 12px;
	text-align: left;
	margin-bottom: 20px;
	}
.main-contents .a1 h3 span.note{
	display: inline-block;
	font-size: 12px;
	margin-left:30px;
	font-weight: normal;
	margin-bottom:0;
}
@media screen and (max-width: 640px){
	.main-contents .a1 h3 span.note{
			display: block;
			margin-left:0px;
	}
}
#rim-tpl-pagetop-box{
	background: #FFF;
	border-top: none;
	border-bottom: 1px solid #DDDDDB;

}
#rim-tpl-copyright{
	max-width: 980px;
	margin: 0px auto;
	padding: 20px 0;
	font-size: 9px;
	text-align: right;
}


