﻿@charset "utf-8";
/* CSS Document */
#container{
	font-family:"メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#222222;
}
.c-f:after{
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}
.c-f{
	min-height:1%;
	display:block;
}
.mt15{
	margin-top:15px !important;
}
.mt20{
	margin-top:20px !important;
}
.mt40{
	margin-top:40px !important;
}
.mb15{
	margin-bottom:15px !important;
}
.mb20{
	margin-bottom:20px !important;
}
.sp-head{
	display: none;
}
.lead {
	font-size:14px;
	line-height:1.7;
}
.lead  a{
	text-decoration:underline;
}
.section h2.rs_h2_title_bar {
	padding: 10px 15px;
	background-color:#3695d6;
	color: #fff;
	font-size: 16px;
	margin-top:20px;
	margin-bottom: 0;
}
h3.rs_h3_title_bar{
	padding: 5px 15px !important;
	background-color:#666666;
	color: #fff;
	font-size: 16px;
	font-weight:normal !important;
	border-left:none !important;
	margin-top:20px !important;
}
h4.rs_h4_title_bar{
	border-left:5px solid #898989;
	padding:0 15px;
	color:#434343;
	font-size: 16px !important;
	font-weight:normal !important;
	margin-top:20px !important;
}
.bold{
	font-weight:bold;
}
.txt-red{
	color:#eb4055;
}
.txt-gray{
	color:#434343;
}
.txt-kome{
	font-size:11px;
	color:#434343;
}
.tl{
	text-left:center;
}
.tc{
	text-align:center;
}
.tr{
	text-align:right;
}
.pc-block{
	display: block;
}
.sp-block{
	display: none;
}
button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	width: 100%;
}
@media screen and (max-width: 768px) {
	.c-f:after{
		content:none;
		display:block;
		width:0;
		height:0;
	}
	.spmt20{
		margin-top:20px !important;
	}
	.spmt30{
		margin-top:30px !important;
	}
	#container{
		font-family: 'ヒラギノ角ゴ ProN W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
	}
	
	#str_container{
		width:100%;
		margin:0 auto;
	}
	.pc-head{
		display:none;
	}
	.sp-head{
		display:block;
	}
	.lead {
		padding:0 10px;
		max-height:999999px;
	}
	h2.rs_h2_title_bar{
		margin: 15px 10px 0 !important;
		max-height:999999px;
		font-weight:normal !important;
		padding: 7px 10px !important;
	}
	h3.rs_h3_title_bar{
		margin: 15px 10px 0 !important;
		padding: 5px 10px !important;
		max-height:999999px;
	}
	h4.rs_h4_title_bar{
		border-left:5px solid #898989;
		margin: 15px 10px 0 !important;
		padding:0 10px;
		max-height:999999px;
	}
	.txt-kome{
		padding:0;
	}
	.bottom_btn{
		margin:0 10px;
		max-height:999999px;
	}
	.sp-block{
		display: block;
	}
	.pc-block{
		display: none;
	}
}

/*--------------------------------------
  　キャンペーン期間＆プレー対象期間
--------------------------------------*/
.deadline_sp{
	display:none;
}
.deadline_pc {
	background-color: #fff;
	color: #fff;
	font-size: 1.3em;
	font-weight: bold;
	height: 40px;
	text-align: center;
	margin:20px 0;
}
.deadline_pc ul {
    border: 1px solid #acacaa;
    line-height: 2.5;
}
.deadline_pc ul li {
    background-color: #ffffff;
    color: #313131;
    display: table-cell;
    font-weight: bold;
    padding: 0 16px;/*年をまたぐ時は9px*/
}
.deadline_pc ul li.ulTitle01 {
    background-color: #c0c0c0;
}
.deadline_pc ul li.ulTitle02 {
    background-color: #c0c0c0;
}
br.sp_block,br.sp_block_02{
	display:none;
}
@media screen and (max-width: 768px) {
	.deadline_pc{
		display:none;
	}
	.deadline_sp{
		background-color:#fff;
		text-align:left;
		display:block;
		padding:5px 0 0;
		font-weight:bold !important;
		font-size:14px;
		margin-bottom:15px;
	}
	.deadline_sp dl{
		border-left:1px solid #acacaa;
		border-right:1px solid #acacaa;
		border-bottom:1px solid #acacaa;
		font-weight:bold !important;
	}
	.deadline_sp dt{
		width:40%;
		float : left;
		clear : both;
		padding:3px 0;
		text-align:center;
	}
	.deadline_sp dd{
		background-color:#fff;
		padding:3px 0 3px 43%;
	}
	.deadline_sp .Title01 dt{
		background-color:#c0c0c0;
		text-align:center;
		border-top:1px solid #acacaa;
	}
	.deadline_sp .Title02 dt{
		background-color:#c0c0c0;
		text-align:center;
	}
	.deadline_sp .Title01 dd{
		border-top:1px solid #acacaa;
	}
	br.sp_block_02{
		display:block;
	}
}
@media screen and (max-width: 480px) {
	.deadline_sp .Title02 dt{
		line-height:2.6;
	}
	br.sp_block{
		display:block;
	}
}
	
/*--------------------------------------
  　ボタン赤
--------------------------------------*/
.btn-red a {
	display: block;
	width: 600px;
	margin: 0 auto;
	padding: 15px 0;
	background-color: #eb4055;
	border-radius: 5px;
	box-shadow: 0px 5px 0px 0px #bf3646;
	-moz-box-shadow: 0px 5px 0px 0px #bf3646;
	-webkit-box-shadow: 0px 5px 0px 0px #bf3646;
	color: #FFF;
	font-size:28px;
	text-align: center;
}
.btn-red a:hover {
	color: #FFF;
	filter:alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
	-moz-transition: .3s;
	-webkit-transition: .3s;
	-o-transition: .3s;
	-ms-transition: .3s;
	transition: .3
}
.btn-red-fin span {
	display: block;
	width: 600px;
	margin: 0 auto;
	padding: 15px 0;
	background-color: #75202a;
	border-radius: 5px;
	box-shadow: 0px 5px 0px 0px #5f1b23;
	-moz-box-shadow: 0px 5px 0px 0px #5f1b23;
	-webkit-box-shadow: 0px 5px 0px 0px #5f1b23;
	color: #7f7f7f;
	font-size:28px;
	text-align: center;
}
@media screen and (max-width: 768px) {
	.btn-red a,.btn-red-fin span {
		width:auto;
		margin:0 15px 20px;
		padding:10px 0;
		max-height:999999px;
		font-size:16px;
	}
}

/*---------------------------------
  　独自のコンテンツエリア
-----------------------------------*/
.contents-area{
	background-color:#d2d2d2;
	text-align:center;
	padding:130px 0;
	margin-top:20px;
	font-size:18px;
}
@media screen and (max-width: 768px) {
	.contents-area{
		padding: 80px 0;
		margin: 10px;
		font-size: 12px;
		max-height: 999999px;
	}
}

/*---------------------------------
  　　エリアメニュー
-----------------------------------*/
/*6エリア*/
.tab-area{
	width:960px;
	margin:15px 0;
}
.rs-gc-ttl_content{
	display:none;
}
.tab-area li{
	margin-right:5px;
	float:left;
}
.tab-area li:last-child{
	margin-right:0;
}
.tab-area li a{
	display: table-cell;
	width: 185px;
	vertical-align: middle;
	padding:15px 0;
	border: 1px solid #5A5A5A;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	background: #fff;
	color: #333;
	font-size: 18px;
	text-align: center;
	box-shadow: 0px 3px 0px 0px #5A5A5A;
	-moz-box-shadow: 0px 3px 0px 0px #5A5A5A;
	-webkit-box-shadow: 0px 3px 0px 0px #5A5A5A;
}
.tab-area li a:hover{
	background:#FFFFFF;
	border:#e7364a 1px solid;
	color:#e7364a;
	box-shadow: 0px 3px 0px 0px #e7364a;
	-moz-box-shadow: 0px 3px 0px 0px #e7364a;
	-webkit-box-shadow: 0px 3px 0px 0px #e7364a;
}
.tab-area li a.active{
	display: block;
	padding:15px 0;
	border: 1px solid #e7364a;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	background: #fff;
	color: #eb4055;
	font-size: 18px;
	text-align: center;
	box-shadow: 0px 3px 0px 0px #e7364a;
	-moz-box-shadow: 0px 3px 0px 0px #e7364a;
	-webkit-box-shadow: 0px 3px 0px 0px #e7364a;
}
/*2エリア*/
.tab-area-02{
	width:960px;
	margin:15px 0;
}
.rs-gc-ttl_content-02{
	display:none;
}
.tab-area-02 li{
	width:470px;
	margin-right:15px;
	float:left;
}
.tab-area-02 li.last{
	margin-right:0;
}
.tab-area-02 li a{
	display: block;
	padding:15px 0;
	border: 1px solid #5A5A5A;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	background: #fff;
	color: #333;
	font-size: 18px;
	text-align: center;
	box-shadow: 0px 3px 0px 0px #5A5A5A;
	-moz-box-shadow: 0px 3px 0px 0px #5A5A5A;
	-webkit-box-shadow: 0px 3px 0px 0px #5A5A5A;
}
.tab-area-02 li a:hover{
	background:#FFFFFF;
	border:#e7364a 1px solid;
	color:#e7364a;
	box-shadow: 0px 3px 0px 0px #e7364a;
	-moz-box-shadow: 0px 3px 0px 0px #e7364a;
	-webkit-box-shadow: 0px 3px 0px 0px #e7364a;
}
.tab-area-02 li a.active{
	display: block;
	padding:15px 0;
	border: 1px solid #e7364a;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	background: #fff;
	color: #eb4055;
	font-size: 18px;
	text-align: center;
	box-shadow: 0px 3px 0px 0px #e7364a;
	-moz-box-shadow: 0px 3px 0px 0px #e7364a;
	-webkit-box-shadow: 0px 3px 0px 0px #e7364a;
}
@media screen and (max-width: 768px) {
/*6エリア*/
	.tab-area,.tab-area-02{
		width:auto;
		margin:10px 0;
	}
	#menu-box {
	overflow: hidden;
	padding: 0 10px;
	}
	.rs-gc-ttl_content{
		display:block;
	}
	/*--
	.rs-gc-ttl_content{
		padding: 10px 20px;
		border-top:1px solid #d2d2d2;
		border-bottom:1px solid #d2d2d2;
		position: relative;
		max-height:999999px;
		font-size: 16px;
	}--*/

	/*--
	.tab-area .rs-gc-content li a,.tab-area-02 .rs-gc-content li a{
		display: block;
		padding:10px 20px;
		color: #222;
		border-bottom:1px solid #d2d2d2;
		border-top:none;
		border-left:none;
		border-right:none;
		border-radius:0;
		box-shadow:none;
    	-moz-box-shadow: none;
    	-webkit-box-shadow: none;
		font-size:16px;
		text-align: left;
	}--*/
.tab-area .rs-gc-content li a,.tab-area-02 .rs-gc-content li a{
	display: block;
	width: auto;
	padding:15px 0;
	border: 1px solid #5A5A5A;
	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	-ms-border-radius: 5px;
	background: #fff;
	color: #333;
	font-size: 18px;
	text-align: center;
	box-shadow: 0px 3px 0px 0px #5A5A5A;
	-moz-box-shadow: 0px 3px 0px 0px #5A5A5A;
	-webkit-box-shadow: 0px 3px 0px 0px #5A5A5A;
	box-sizing: border-box;
}
.tab-area li{
	 margin-right: 10px; 
	 margin-bottom: 10px;
	width: 48%;
	 box-sizing: border-box; 
	display: inline-block;
}
.tab-area li.two-lines a{
	line-height:2.5;
}
.tab-area li:nth-child(2n){
	margin-right: 0; 
}
	.tab-area .rs-gc-content li:first-child,
.tab-area-02 .rs-gc-content li:first-child{
		border-top: none;
	}
	.tab-area .rs-gc-content li a.active,
.tab-area-02 .rs-gc-content li a.active{
		color: #3695d6;
	}
/*--
	.rs-js-acc-basic_trriger:after {
		content: "";
		display: block;
		width: 15px;
		height: 15px;
		position: absolute;
		right: 20px;
		margin-top: -20px;
		color: #318fdb;
		font-weight: bold;
		font-size: 40px;
		line-height: 1;
		text-align: center;
		background: url(../images/ico_plus.png) center center no-repeat;
	}
	.rs-js-acc-basic_trriger.is-open:after {
		background: url(../images/ico_minus.png) center center no-repeat;
	}
	.rs-gc-content {
		display:none;
	}--*/
}

/*---------------------------------
  　　応募ステップ
-----------------------------------*/
/*4STEP*/
.step{
	width:223px;
	float:left;
	border:1px solid #898989;
	padding-bottom:10px;
}
.step p,.step02 p{
	font-size:14px;
	padding:10px;
	margin-top:0;
}
.step-title{
	background-color:#666666;
	color:#FFFFFF;
	font-size:16px;
	font-weight:bold;
}
.step > img,.step02 > img {
    display: block;
    margin: 0 auto;
	width:89px;
}
.step .bold,.step02 .bold{
	display: inline-block;
	font-weight: bold;
	padding-bottom:5px;
}
.triangle {
	display: flex;
	float:left;
	width:20px;
	position: relative;
}
.triangle .ic{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 12.5px 0 12.5px 10px;
	border-color: transparent transparent transparent #666666;
	position:absolute;
	top: 45%;
	left: 25%;
}
.step .btn,.step02 .btn{
	position:relative;
}
.step .btn a,.step02 .btn a{
	background-color:#02c2f2;
	border-radius: 18px;
	display:block;
	text-align:center;
	color:#FFFFFF;
	padding:8px;
}
.step .btn a:hover,.step02 .btn a:hover{
	background-color:#31c8ee;
}
.step .btn .arrow,.step02 .btn .arrow{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 6px;
	border-color: transparent transparent transparent #ffffff;
	display: inline-block;
	position: absolute;
	right: 20px;
	top: 40%;
}
/*3STEP*/
.step02{
	width:298px;
	float:left;
	border:1px solid #898989;
	padding-bottom:10px;
}
.triangle02 {
	display: flex;
	float:left;
	width:30px;
	position: relative;
}
.triangle02 .ic{
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 12.5px 0 12.5px 10px;
	border-color: transparent transparent transparent #666666;
	position:absolute;
	top: 45%;
	left: 30%;
}
@media screen and (max-width: 768px) {
	.step,.step02{
		width:auto;
		margin:0 10px;
		float:none;
	}
	.step p,.step02 p{
		padding:10px 5px;
		max-height:999999px;
	}
	.step-title{
		padding:10px !important;
	}
	.step > img,.step02 > img {
		width: 20%;
	}
	.triangle,.triangle02 {
		float:none;
		position:static;
		margin: 0 auto;
	}
	.triangle .ic,.triangle02 .ic{
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 15px 15px 0 15px;
		border-color: #666666 transparent transparent transparent;
		margin:5px auto;
		position:static;
	}
	.step .btn,.step02 .btn{
		margin: 0 50px;
		padding-top:0;
	}
	.step .btn a,.step02 .btn a{
		border-radius: 30px;
		padding:10px;
	}
	.step .btn .arrow, .step02 .btn .arrow {
		border-width: 6px 0 6px 7px;
		top: 25%;
	}
}
@media screen and (max-width: 640px) {
	.step > img,.step02 > img {
		width: 30%;
	}
}
@media screen and (max-width: 325px) {
	.tab-area li.two-lines a{
		line-height:1.3;
	}
}

/*--------------------------------------
  　　賞品一覧
--------------------------------------*/
.sp-area{
	display:none;
}
.pc-area .pre-2box div{
	float:left;
	margin-right:20px;
	width:470px;
	margin-top:0;
}
.pc-area .pre-2box p.txt{
	width:440px;
	background-color:#666666;
	color:#FFFFFF;
	font-size:14px;
	font-weight:bold;
	padding:15px;
	margin-top: 0;
	display: inline-block;
}
.pc-area .pre-2box p span.name-txt{
	width:330px;
	float:left;
}
.pc-area .pre-2box p span.number{
	width:110px;
	font-size:24px;
	display: inline-block;
	text-align:right;
}
.pc-area .pre-2box p span.number .big-txt{
	font-size:40px;
}
.pre-4box div{
	float:left;
	margin-right:13px;
	width:230px;
	margin-top:20px;
	border:1px solid #999;
	box-sizing:border-box;
}
.pre-4box p.txt{
	background-color:#666666;
	color:#FFFFFF;
	font-size:12px;
	font-weight:bold;
	padding:10px;
	margin-top: 0;
}
.pre-4box p span.name-txt{
	width:145px;
	display: inline-block;
	text-align: left;
}
.pre-4box p span.number{
	width:60px;
	font-size:14px;
	display: inline-block;
	text-align:right;
}
.pre-4box p span.number .big-txt{
	font-size:21px;
}
.pc-area .pre-5box p{
	float:left;
	width:180px;
	margin-right:15px;
	margin-top:0;
	position:relative;
}
.pc-area .pre-5box p span.number{
	display: inline-block;
	font-size: 16px;
	font-weight: bold;
	position: absolute;
	right: 10px;
	text-align: right;
	top: 60px;
	width: 100px;
	color:#FFFFFF;
}
.pc-area .pre-5box p span.number .big-txt{
	font-size:24px;
}
.pc-area .pre-5box p span{
	padding-top:5px;
	display: inline-block;
}
.mr0{
	margin-right:0;
}
@media screen and (max-width: 768px) {
	.pc-area{
		display:none;
	}
	.sp-area{
		display:block;
	}
	.sp-area .pre-2box{
		margin:10px;
	}
	.sp-area .pre-2box div img{
		width:100%;
	}
	.sp-area .pre-2box p.txt{
		background-color:#666666;
		color:#FFFFFF;
		font-weight:bold;
		bottom: 10px;
		width:100%;
		max-height:999999px;
		margin-top: 0;
		position: relative;
	}
	.sp-area .pre-2box .name-txt {
		display: inline-block;
		padding: 8px 10px;
		width: 70%;
		font-size: 14px;
		line-height: 1.5;
	}
	.sp-area .pre-2box p span.number{
		display:block;
		text-align:right;
		width: auto;
		font-size: 14px;
		line-height: 0.8;
		position: absolute;
		bottom: 10px;
		right: 10px;
	}
	.sp-area .pre-2box p span.number .big-txt{
		font-size:30px;
	}
	.sp-area .pre-3box{
		margin:0 10px;
	}
	.sp-area .pre-3box div{
		margin-top:10px;
		width:100%;
		display:flex;
	}
	.sp-area .pre-3box img{
		float:left;
		width:50%;
		height: 100%;
	}
	.sp-area .pre-3box p.txt{
		float:left;
		width:50%;
		color:#FFFFFF;
		background-color:#666666;
		font-size:14px;
		max-height:999999px;
		position:relative;
		margin-top: 0;
	}
	.sp-area .pre-3box .name-txt {
		display: inline-block;
		padding:10px;
	}
	.sp-area .pre-3box p span.number{
		font-size:14px;
		display:block;
		text-align:right;
		vertical-align:bottom;
		font-weight:bold;
		position: absolute;
		bottom: 10px;
		right: 15px;
	}
	.sp-area .pre-3box p span.number .big-txt{
		font-size:30px;
	}
	.pre-4box{
		margin:0 20px;
	}
	.pre-4box div{
		margin-top: 15px;
		border: 1px solid #333;
		box-sizing: border-box;
		float: none;
		display: table;
		width: 100%;
		margin-right: 0;
	}
	.pre-4box span{
		display: table-cell;
		vertical-align: middle;
		box-sizing:border-box;
		width: 50%;
	}
/*	.pre-4box img{
		float:left;
		width: 50%;
	}*/
	.pre-4box p.txt{
		display: table-cell;
		color:#FFFFFF;
		background-color:#666666;
		padding:10px;
		height: auto;
		width: 50%;
		box-sizing: border-box;
		font-size:24px;
		max-height:999999px;
		position:relative;
	}
	.pre-4box p span.name-txt{
		height: auto;
		width: 100%;
		font-size: 14px;
		display:inline-block;
	}
	.pre-4box p span.number{
		font-size: 14px;
		display:inline-block;
		text-align:right;
		vertical-align:bottom;
		font-weight:bold;
		position: absolute;
		bottom: 0;
		right: 10px;
		width: 70px;
	}
	.pre-4box p span.number .big-txt{
		font-size:25px;
	display:inline-block;
	}
	.sp-area .pre-5box{
		margin:0 10px;
	}
	.sp-area .pre-5box div{
		margin-top:15px;
		width:100%;
		display:flex;
	}
	.sp-area .pre-5box img{
		float:left;
		width:30%;
		height:100%;
	}
	.sp-area .pre-5box p.txt{
		float:left;
		padding:0 0 0 15px;
		font-size:14px;
		max-height:999999px;
		position:relative;
		width:69%;
		margin-top:0;
	}
	.sp-area .pre-5box p span.number{
		font-size:14px;
		display:block;
		text-align:right;
		vertical-align:bottom;
		font-weight:bold;
		position: absolute;
		right: 15px;
		bottom:0;
	}
	.sp-area .pre-5box p span.number .big-txt{
		font-size:28px;
	}
}
@media screen and (max-width: 640px) {
	.sp-area .pre-3box p span.number{
		bottom: 1px;
		right: 5px;
	}
	.sp-area .pre-3box p span.number .big-txt{
		font-size:25px;
	}
	.sp-area .pre-4box div{
		margin-right:10px;
		width:48%;
	}
	.sp-area .pre-5box p.txt{
		padding:0 0 0 10px;
	}
}
@media screen and (max-width: 320px) {
	.sp-area .pre-3box .name-txt {
		padding: 6px;
		font-size: 13px;
	}
	.sp-area .pre-3box p span.number .big-txt {
		font-size: 20px;
	}
	.sp-area .pre-5box p span.number .big-txt {
		font-size: 20px;
	}
}

/*---------------------------------
  　ゴルフ場コース
-----------------------------------*/
.rs_course .cbox{width: 930px; margin-left: auto; margin-right: auto; background: #eee; margin-top: 20px; padding: 14px; border: 1px solid #ccc;line-height:1.5;}
.rs_course .limg{padding: 6px; background: #fff; width: 410px;}
.rs_course .simg{width:430px;}
.rs_course .simg img{margin:6px 6px 0 0; padding: 5px; background: #fff; float:left; cursor:pointer;}
.rs_course .imbox{float: left;width:410px;}
.rs_course .cbox .course-name{font-size: 24px; font-weight:bold; }
.rs_course .acs{color: #009900}
.rs_course .copy{font-size:14px;}
.rs_course .detailbox {width:480px;float:right;}
.rs_course .star {display:inline-block;float:left;}
.rs_course .detail-right {width:300px;}
.rs_course .detail-left {width:320px;}
.rs_course .txt-yellow {color:#FFAE00;}
.rs_course .txt-14{font-size:105%;}
.rs_course .as{font-size:90%;}
.rs_course .btn-red a {
	display: block;
	width: 400px;
	margin:20px 30px 28px 35px;
	padding: 15px 0;
	background-color: #eb4055;
	border-radius: 4px;
	box-shadow: 0px 4px 0px 0px #bf3646;
	-moz-box-shadow: 0px 4px 0px 0px #bf3646;
	-webkit-box-shadow: 0px 4px 0px 0px #bf3646;
	color: #fff;
	font-size:16px;
	text-align: center;
}
.rs_course .btn-red a:hover {
	color: #FFF;
	filter:alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
	-moz-transition: .3s;
	-webkit-transition: .3s;
	-o-transition: .3s;
	-ms-transition: .3s;
	transition: .3
}
.rs_course .btn-red-fin span {
	display: block;
	width: 400px;
	margin:20px 30px 28px 35px;
	padding: 15px 0;
	background-color: #75202a;
	border-radius: 4px;
	box-shadow: 0px 4px 0px 0px #5f1b23;
	-moz-box-shadow: 0px 4px 0px 0px #5f1b23;
	-webkit-box-shadow: 0px 4px 0px 0px #5f1b23;
	color: #7f7f7f;
	font-size:16px;
	text-align: center;
}
.label-pink {
	background-color: #ff6699;
	border-radius: 3px;
	color: #fff;
	display: inline-block;
	font-size: 12px;
	line-height: 14px;
	margin-right: 3px;
	padding: 3px 7px;
	text-align: center;
	vertical-align: baseline;
	white-space: nowrap;
}
.label-orange {
	background-color: #ff7e00;
	border-radius: 3px;
	color: #fff;
	display: inline-block;
	font-size: 12px;
	line-height: 14px;
	padding: 3px 7px;
	text-align: center;
	vertical-align: baseline;
	white-space: nowrap;
}
.label-blue {
	background-color: #3695d6;
	border-radius: 3px;
	color: #fff;
	display: inline-block;
	font-size: 12px;
	line-height: 14px;
	padding: 3px 7px;
	text-align: center;
	vertical-align: baseline;
	white-space: nowrap;
}
.label-gray {
	background-color: #898989;
	border-radius: 3px;
	color: #fff;
	display: inline-block;
	font-size: 12px;
	line-height: 14px;
	padding: 3px 7px;
	text-align: center;
	vertical-align: baseline;
	white-space: nowrap;
}
.mr3{
	margin-right:3px;
}
@media screen and (max-width: 768px) {
	.rs_course .cbox {
		margin: 20px 10px 0;
		width: auto;
		padding:10px;
	}
	.rs_course .cbox .course-name {
		font-size: 18px;
		margin-top: 0;
		float: left;
		width: 68%;
		padding-left: 5px;
	}
	.rs_course .imbox {
		width: 30%;
	}
	.rs_course .limg {
		padding: 3px;
		width: auto;
	}
	.rs_course .simg {
		display: none;
	}
	.rs_course .detailbox {
		width:auto;
		float:none;
		margin-left:0 !important;
		position:relative;
	}
	.rs_course .copy {
		clear: both;
		padding-top: 5px;
	}
	.rs_course .detail-left02 {
		left: 31%;
		position: absolute;
		top: 10%;
	}
	.rs_course .detail-right {width:auto;}
	.rs_course .detail-left {width:auto;}
	.rs_course .btn-red{
		margin-top:0;
	}
	.rs_course .btn-red a {
		width:auto;
		margin:10px;
		padding: 10px 0;
		font-size:16px;
	}
	.rs_course .btn-red-fin span {
		width:auto;
		margin:10px;
		padding: 10px 0;
		font-size:16px;
	}
}
@media screen and (max-width: 640px) {
	.rs_course .cbox {
		margin:10px 10px 0;
		width: auto;
		padding:5px;
	}
	.rs_course .detailbox {
		margin-left: 10px;
	}
	.rs_course .detail-left02 {
		position:static;
	}
}

/*--------------------------------------
  　キャンペーン概要
--------------------------------------*/
#outline_box {
	margin: 0 0 15px;
	border: 2px solid #3695d6;
	font-size: 1.2em;
}
#outline_box dl{
	margin:5px 0;
}
#outline_box dt{
	padding:10px 0 0 15px;
	font-weight:bold;
	color:#3695d6;
	float:left;
}
#outline_box dd{
	padding:10px 10px 10px 210px;
	border-bottom:1px dashed #ccc;
	line-height:140%;
}
#outline_box dd.last{
	border:0;
}
@media screen and (max-width: 768px) {
	#outline_box {
		margin: 0 10px;
		padding-top:5px;
	}
	#outline_box dl{
		margin: 0;
		padding: 3px;
	}
	#outline_box dt{
		float:none;
		padding: 0 0 0 5px;
		max-height:999999px;
		text-align: left;
	}
	dl.outline dt {
		padding: 5px;
	}
	#outline_box dd{
		padding: 0 0 10px 5px;
		max-height:999999px;
	}
}

/*--------------------------------------
  　注意事項
--------------------------------------*/
.notice_tit {
	padding: 8px 15px;
	background-color: #ccc;
	font-size: 1.2em;
}
#notice_box {
	margin: 0 0 10px;
	width:956px;
	border: 2px solid #ccc;
	font-size: 1.2em;
}
#notice_box dl{
	margin: 0;
}
#notice_box dt{
	padding:10px 0 0 15px;
	font-weight:bold;
	float:left;
}
#notice_box dd{
	padding:10px 10px 10px 210px;
	border-bottom:1px dashed #ccc;
	line-height:140%;
}
#notice_box dd.last{
	border:0;
}
#notice_box ul{
	margin-left: 0;
}
#notice_box ul li {
	list-style: disc;
	list-style-position: outside;
}
@media screen and (max-width: 768px) {
	.notice_tit {
		padding:5px 10px;
		font-size:14px;
		margin:0 10px;
	}
	#notice_box {
		margin: 0 10px 20px;
		width:auto;
		padding-top:5px;
	}
	#notice_box dl{
		margin: 0;
		padding: 3px;
	}
	#notice_box dt{
		float:none;
		padding: 0 0 0 5px;
		text-align: left;
	}
	#notice_box dd{
		padding: 10px 15px;
	}
	#notice_box ul{
		margin-left:10px;
	}
	#notice_box ul li {
		list-style: disc;
		list-style-position: outside;
		max-height:999999px;
	}
	.btn_info{
		margin:0 10px;
	}
}

/*--------------------------------------
  　キャンペーン終了対応
--------------------------------------*/
#str_container #res-header .h-txt{
	display:none;
}
#str_container #res-header-fin{
	position:relative;
	background:#000;
}
#str_container #res-header-fin .pc-head{
	width: 100%;
	height: 100%;
	z-index: 999;
	filter: alpha(opacity=70);
	-moz-opacity: 0.7;
	opacity: 0.7;
}
#str_container #res-header-fin .h-txt {
	position:absolute;
	background:#fff;
	padding:20px 40px;
	top:50%;
	left:290px;
	margin:-50px 0 0;
	border-radius:8px;
	-moz-border-radius:8px;
	-webkit-border-radius:8px;
	border-radius:8px;
	-moz-border-radius:8px;
	-webkit-border-radius:8px;
	z-index: 999999;
	text-align:center;
}
#str_container #res-header-fin .h-txt p {
	font-size:160%;
	font-weight:bold;
	color:#ff0000;
}
#str_container #res-header-fin .h-txt p span {
	font-size:80%;
	font-weight:normal;
}
@media screen and (max-width: 768px) {
	#str_container #res-header-fin{
		margin:0 0 10px;
	}
	#str_container #res-header-fin .sp-head{
		width: 100%;
		height: 100%;
		z-index: 999;
		filter: alpha(opacity=70);
		-moz-opacity: 0.7;
		opacity: 0.7;
		line-height:0;
	}
	#str_container #res-header-fin .h-txt {
		max-height: 999999px;
		line-height: 1.3;
		margin-left: -38%;
		left: 50%;
		width: 66%;
		padding: 5% 5%;
	}
	#str_container #res-header-fin .h-txt p {
		font-size:14px;
	}
	#str_container #res-header-fin .h-txt p span {
		font-size:14px;
	}
}

/*---------------------------------
  　ページTOP
-----------------------------------*/
#page-top {
	bottom: 20px;
	display: block;
	position: fixed;
	margin-left: 980px;
	width: 960px;
}
#page-top img{
	width:50px;
	height:50px;
}
@media screen and (max-width: 768px) {
/*通常ページ*/
	#page-top {
		right: 20px;
		width:auto;
		margin-left:0;
		z-index:5;
	}
/*/s/ページ*/
	/*#page-top {
		bottom: 100px;
		width:auto;
		margin-left:0;
		right: 20px;
		z-index:5;
	}*/
}
@media screen and (max-width: 640px) {
	#page-top img {
		width: 40px;
		height: 40px;
	}
}
/*Safariだけに適用されるCSSハック*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
  ::i-block-chrome,#container {
	  font-family:"メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
}

/*---------------------------------
movie
-----------------------------------*/
.movie_box{
	padding:40px 0;
	background:url(../images/cont_bk_01.png) repeat left top;
	border:none;
}
.movie-wrap{
	position:relative;
	width:80%;
	margin:0 auto;
	padding-bottom:56.25%;
	padding-top:30px;
	height:0;
}
.movie-wrap iframe {
	position:absolute;
	top:0;
	left:0;
	width:100% !important;
	height:100% !important;
}
.movie_Block .pc_right{
	background:#fff;
	padding:0;
}
.movie_Block .pc_right>div{
	border:solid 1px #ccc;
	padding:8px 20px;
}
.movie_Block .pc_right div+div{
	border-top:none;
}

@media screen and (max-width: 768px) {
	.movie_Block{
		background-color:#eee;
	}
	.movie_box{
		margin:0;
		padding: 10px 0;
	}
	.movie_Block .pc_left,
	.movie_Block .pc_right{
		width:100%;
	}
	.movie_Block .pc_right{
		padding:10px 10px 0;
	}
	.movie_Block .pc_right>div{
		padding:10px 8px;
	}
}

/*---------------------------------
共通部分
-----------------------------------*/
.section{
	text-align:center;
}
.section h2{
	margin-bottom:50px;
}
#res-header{
  width: 1190px;
	left: 50%;
  margin-left: -595px;
  position:relative;
  text-align: center;
  background: url(../images/header_back_pc.jpg) left top no-repeat;
  /*background-size: cover;*/
}
.pc-head{
	width:960px;
	margin:0 auto;
}

@media screen and (max-width: 768px) {
	.section h2 {
		margin-bottom: 25px;
	}
	#res-header{
		width: auto;
		margin-left: 0;
		left: 0;
		position:relative;
		text-align: center;
		background: none;
	}
	.sp-head{
		margin:0 auto;
	}
}
/*---------------------------------
contents01
-----------------------------------*/
.contents01_box{
	position:relative;
}
.contents01_box .text_inner{
	background:url(../images/ph001_1_pc.png) no-repeat center;
	padding:100px 0;
}
.qa_text{
	font-size:22px;
}
.qa_text span{
	position: relative;
	top: -25px;
}

@media screen and (max-width: 768px) {
	.contents01_box .text_inner{
		background:url(../images/ph001_1_sp.png) no-repeat center;
		background-size:100%;
		position:relative;
		padding:16% 0;
	}
	.qa_text{
		font-size:13px;
	}
	.qa_text span{
		position: absolute;
		top: 0;
		left: 0;
		bottom: 0;
		right: 0;
		margin: auto;
		height: 50px;
		width: 70%;
	}
}
/*---------------------------------
contents02
-----------------------------------*/
.contents02_box_inner{
	position: relative;
}
.contents02_box_inner p{
	margin-top:20px;
}
.text-link{
	position: absolute;
	margin: 0;
	right: 100px;
	top: 340px;
}
.menu-btn{
	width: 450px;
	position: absolute;
	margin: 0;
	left: 500px;
	top: 570px;
}
#nv_menu2 li{
	float: left;
	color: #1da1f2;
	border: 1px solid #1da1f2;
	border-radius: 16px;
	padding: 0;
	margin: 10px 15px;
	width: 190px;
}
.menu-btn2{
	width: 450px;
	position: absolute;
	margin: 0;
	left: 500px;
	top: 530px;
}
#nv_menu3 li{
	float: left;
	color: #1da1f2;
	border: 1px solid #1da1f2;
	border-radius: 16px;
	padding: 0;
	margin: 10px 15px;
	width: 190px;
}
#nv_menu3 li:nth-child(2n){
	margin-right: 0;
}
#nv_menu2 a, #nv_menu3 a,#nv_menu3 button{
	color:#1da1f2;
	padding: 10px;
	display: block;
	cursor: default;
}
#nv_menu2 a.disabled{
	background-color: rgb(127, 127, 127);
	color: rgb(27, 74, 107);
	border-radius: 16px;
}
.contents02 .txt-kome{
	text-align:left;
	padding-bottom:35px;
}

@media screen and (max-width: 768px) {
	.contents02_box_inner{
		text-align:center;
	}
	.contents02_box_inner p{
		text-align:center;
	}
	.text-link{
		position: relative;
		right: 0;
		top: 0;
	}
	.menu-btn{
		width:auto;
		position: relative;
		margin: 0;
		left: 0;
		bottom: 0;
		 top: 0;
	}
	.menu-btn2{
		width:auto;
		position: relative;
		margin: 0;
		left: 0;
		bottom: 0;
		 top: 0;
	}
	#nv_menu2 li{
		margin: 20px 0px 0;
		width: 46%;
		float: none;
		display: inline-block;
		vertical-align:top;
		text-align: center;
		box-sizing: border-box;
		padding: 0;
	}
	#nv_menu2 li:nth-child(odd) {
		margin-right: 5%;
	}
	#nv_menu2 a, #nv_menu3 a{
		padding: 5px;
	}
	#nv_menu2 a, #nv_menu3 a, #nv_menu3 button{
		padding: 5px;
	}
}

/*---------------------------------
contents03
-----------------------------------*/
.contents03_box{
	position:relative;
}
.contents03_box_ttl{
	position:absolute;
	top:-25px;
  left: 0;
  right: 0;
  margin: auto;
}
.contents03 .main_box .txt{
	font-size:20px;
}
.contents03 .main_box .box1 p{
	float:left;
	margin-right: 30px;
}
.contents03 .main_box .box1 p:last-child{
	margin-right:0;
}
.contents03 .main_box .box1 img{
	margin-bottom:30px;
}
.contents03 .main_box .box2{
	width: 630px;
	text-align: center;
	margin: 0 auto;
}
.contents03 .main_box .box2 p{
	float:left;
	margin-right: 30px;
}
.contents03 .main_box .box2 p:last-child{
	margin-right:0;
}
.contents03 .main_box .box2 img{
	margin-bottom:50px;
}
.contents03 .main_box .box3 p{
	float:left;
	margin-right: 30px;
}
.contents03 .main_box .box3 p:last-child{
	margin-right:0;
}
.contents03 .main_box .box3 img{
	margin-bottom:30px;
}

/*---------------------------------
contents04
-----------------------------------*/
.contents03_box, .contents04_box{
	position:relative;
	margin-top: 30px;
}
.contents03_box_inner, .contents04_box_inner{
	border:3px #1c8c42 solid;
	border-radius:20px;
	padding:50px 50px 200px;
}
.menu-btn3{
	width: 540px;
	position: absolute;
	margin: 0;
	left: 200px;
	top: 205px;
}
#nv_menu4 li{
	float:left;
	color:#1da1f2;
	border:1px solid #1da1f2;
	border-radius:16px;
	margin:10px 15px;
	width: 240px;
	box-sizing: border-box;
}
.menu-btn4{
	width: 540px;
	position: absolute;
	margin: 0;
	left: 200px;
	top: 205px;
}
#nv_menu5 li{
	float:left;
	color:#1da1f2;
	border:1px solid #1da1f2;
	border-radius:16px;
	margin:10px 15px;
	width: 240px;
	box-sizing: border-box;
}
#nv_menu4 a{
	color:#1da1f2;
	padding: 10px;
	display: block;
	line-height: 1.5;
}
#nv_menu5 button{
	color:#1da1f2;
	padding: 10px;
	display: block;
	font-size: 100%;
}
@media screen and (max-width: 768px) {
	.contents03_box_inner, .contents04_box_inner{
		border:3px #1c8c42 solid;
		border-radius:20px;
		padding:30px 10px 40px;
	}
	.contents03_box_ttl{
		top:-15px;
	}
	.contents03_box_ttl img{
		width: 90%;
	}
	.contents03 .main_box .box1 p{
		float: none;
		margin-right: 0;
	}
	.contents03 .main_box .box1 img{
		margin-bottom:10px;
	}
	.contents03 .main_box .box2{
		width: auto;
		text-align: center;
		margin: 0 auto;
	}
	.contents03 .main_box .box2 p{
		float: none;
		margin-right: 0;
	}
	.contents03 .main_box .box3 p{
		float: none;
		margin-right: 0;
	}
	.contents03 .main_box .box2 img{
		margin-bottom:10px;
	}
	.contents03 .main_box .box3 img{
		margin-bottom:10px;
	}
	.menu-btn3{
			left: 0;
			bottom: 0;
			width: auto;
			position: relative;
			top: 0;
			text-align: left;
	}
	#nv_menu3 li{
		margin: 20px 0px 0;
		padding: 0;
		width: 47%;
		float: none;
		display: inline-block;
		text-align: center;
		box-sizing: border-box;
	}
	#nv_menu4 li{
		margin: 20px 0px 0;
		width: 48%;
		float: none;
		display: inline-block;
		vertical-align: top;
		text-align: center;
		box-sizing: border-box;
		padding: 0;
		font-size: 91%;
	}
	#nv_menu4 li:nth-child(odd){
		margin-right: 2%;
	}
	#nv_menu5 li:nth-child(odd){
		margin-right: 2%;
	}
	#nv_menu4 a{
		padding: 5px;
		font-size: 100%;
		line-height: 1.5;
	}
	#nv_menu5 button{
		padding: 5px;
		font-size: 91%;
	}
	.menu-btn4{
		width: auto;
		position: relative;
		margin: 0;
		left: 0;
		bottom: 0;
		top: 0;
	}
	#nv_menu5 li{
		margin: 20px 0px 0;
		width: 48%;
		float: none;
		display: inline-block;
		vertical-align: top;
		text-align: center;
		box-sizing: border-box;
		padding: 0;
	}
}

/*---------------------------------
contents05
-----------------------------------*/
.contents05 dd, .rs_h2_title_bar, .notice_tit{
	text-align:left;
}
#lightgallery {
	text-align: center;
}
#lightgallery a{
	display: block;
	margin: 0 15px 16px 0;
	float: left;
	width: 180px;
}
#lightgallery a:nth-child(5n) {
	margin-right: 0;
}

@media only screen and (max-width: 768px) {
	.main_box{
		padding: 0 20px;
	}
	#lightgallery{
		text-align:left;
	}
	#lightgallery a{
		display: inline-block;
		margin: 0 5px 16px 0;
		 float: none; 
		padding: 0;
		width: 48%;
		text-align: center;
	}
	#lightgallery a:nth-child(5n) {
		margin-right: 5px;
	}
}

/*タブ切り替え全体のスタイル*/
.tabs {
  margin: 50px auto;
  padding-bottom: 40px;
  background-color: #fff;
  width: 960px;
  margin: 0 auto;
}

/*タブのスタイル*/
.tab_item, .tab_item2 {
  width: calc(100%/2);
  height: 50px;
  line-height: 50px;
  font-size: 16px;
  text-align: center;
  color: #565656;
  display: block;
  float: left;
  text-align: center;
  font-weight: bold;
  transition: all 0.2s ease;
}
/*.tab_item:hover, .tab_item2:hover {
  opacity: 0.75;
    transition: all 0.2s ease;
}*/
input + label.tab_item,
input + label.tab_item2{
    background-color: #000;
    display: inline-block;
    height:100%;
}
input + label.tab_item img,
input + label.tab_item2 img{
    opacity: 0.4; 
    display: block;
}
input:checked + label.tab_item img,
input:checked + label.tab_item2 img{
    opacity: 1; 
    transition: all 0.2s ease;
}
/*ラジオボタンを全て消す*/
input[name="tab_item"] {
  display: none;
}
input[name="tab_item2"] {
  display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab_content {
  display: none;
  padding: 40px 0 0;
  clear: both;
  overflow: hidden;
}
.tab2_content {
  display: none;
  padding: 40px 0 0;
  clear: both;
  overflow: hidden;
}

/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#instagram:checked ~ #instagram_content{
  display: block;
}

/*選択されているタブのコンテンツのみを表示*/
#all2:checked ~ #all2_content,
#instagram2:checked ~ #instagram2_content{
  display: block;
}

@media only screen and (max-width: 768px) {
/*タブ切り替え全体のスタイル*/
	.tabs {
		width: 100%;
		margin: 0 auto;
		padding-bottom: 20px;
	}
	/*タブのスタイル*/
	.tab_item, .tab_item2 {
		width: calc(100%/2);
		height: 50px;
		line-height: 50px;
		font-size: 16px;
		text-align: center;
		color: #565656;
		display: block;
		float: left;
		text-align: center;
		font-weight: bold;
		transition: all 0.2s ease;
	}
	/*タブ切り替えの中身のスタイル*/
	.tab_content {
		display: none;
		padding:0 10px 20px;
		clear: both;
		overflow: hidden;
	}
	.tab2_content {
		display: none;
		padding: 20px 20px 0;
		clear: both;
		overflow: hidden;
	}
}