@charset "utf-8";


.top-news{
	line-height:30px;
	list-style:disc outside;
	padding:0 0 0 20px;
	margin:0 0 40px;
}

/* <RESET> */
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,textarea,p,blockquote,th,td,article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section,i,a,span{
	margin:0;
	padding:0;
	word-break: normal;
	font-style:normal;
    font-weight: normal;
    /*font-size: 100%;*/
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-webkit-text-size-adjust: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
body,input,select,textarea,button{
	color:#333;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height:1;
	box-sizing:border-box;
}
html,body{ height: 100%; }
html {
	overflow-y: scroll;
}
body{
	text-align: center;
	background-color: #fff;
}
h1,h2,h3,h4,h5,h6{
	font-size:100%;
	font-weight:normal;
}
img{
	border:0;
	vertical-align:top;
}
ul,ol{
	list-style:none;
}
table{
	border-collapse:collapse;
	border-spacing:0;
	font-size:100%;
}
textarea{
	font-size:100%;
}
th {
	text-align:left;
	font-weight:normal;
}
address,em{
	font-style:normal;
	font-weight:normal;
}
sup{
	font-weight:normal;
}
a{
	color:#333;
    filter:alpha(opacity=1);
    opacity:1;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
}
a:hover{
	text-decoration: none;
}
a:hover img{
    filter:alpha(opacity=0.6);
    opacity:0.6;
    -webkit-transition: .5s;
    -moz-transition: .5s;
    transition: .5s;
}
/* </ RESET> */


/* <MODULE> */
.pagettl1{
	text-align: left;
	margin-bottom: 15px;
}
.pagettl1 span{
	display: inline-block;
	font-size: 23px;
	color: #666666;
	padding-bottom: 5px;
	border-bottom: solid 3px #666666;
	font-weight: bold;
	letter-spacing: 0.08rem;
}
.pagettl1 span em{
	font-size: 15px;
	margin-left: 30px;
	letter-spacing: 0.06rem;
}
.pagettl2{
	text-align: left;
	margin-bottom: 15px;
}
.pagettl2 span{
	display: inline-block;
	font-size: 18px;
	color: #666666;
	padding-bottom: 5px;
	border-bottom: dotted 1px #666666;
	font-weight: bold;
	letter-spacing: 0.1rem;
}
.pagebtn1{
	text-align: center;
}
.pagebtn1 a{
	display: inline-block;
	line-height: 44px;
	border-radius:2px;
	color: #ffffff;
	font-size: 16px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
	padding-right: 30px;
	padding-left: 45px;
}
/* </ MODULE> */


/* <LAYOUT> */
#offcanvas-layer,
#offcanvas-menu,
#offcanvas-button{
	display: none;
}
#wrapper{
	width: 1000px;
	margin: 0 auto;
	text-align: left;
	position: relative;
}
header{
	height: 180px;
	position: relative;
	margin-bottom: 40px;
}
header a{
	outline:none;
}
header .logo{
	text-align: center;
	padding-top: 42px;
	margin-bottom: 48px;
	
	font-size:28px;
}
header .subnavi{
	width: 198px;
	position: absolute;
	right: 0;
	top: 20px;
}
header .subnavi ul{
	overflow: hidden;
	margin-bottom: 6px;
}
header .subnavi ul li{
	display: inline;
}
header .subnavi ul li a{
	display: block;
	text-align: center;
	float: left;
	width: 96px;
	height: 24px;
	line-height: 22px;
	margin-right: 6px;
	border: solid 1px #666666;
	position: relative;
	font-size: 12px;
	border-radius:4px;
	text-decoration: none;
	background: #fff;
	color: #666666;
}
header .subnavi ul li.regest a{
	background: #666666;
	color: #ffffff;
	margin-right: 0;
}
header .subnavi .search{
	width:198px;
}
header .subnavi .search .param{
	width:198px;
	border:solid 1px #666666;
	border-radius:10px 0 0 10px;
}
header .subnavi .search .param input{
	border:none;
	width:172px;
	padding:0;
	appearance: none;
	display:block;
	font-size: 14px;
	line-height: 22px;
}
header .subnavi .search .sbtn{
	width:24px;
	border:solid 1px #666666;
}
header .subnavi .search .sbtn input{
	display:block;
	overflow:hidden;
	width: 0;
    height:24px;
	background:#1f69d6 url(/images/common/icon-search.png) no-repeat center center;
	padding:0 0 0 24px;
	border:none;
	cursor:pointer;
}
header .gnavi{
	width: 100%;
	height: 30px;
	border-bottom: solid 1px #d4dbde;
}
header .gnavi>ul{
	width: 720px;
	height: 30px;
	margin: 0 auto;
}
header .gnavi >ul>li{
	position: relative;
	width: 120px;
	height: 30px;
	float: left;
}
header .gnavi>ul>li>a{
	width: 120px;
	height: 30px;
	display: block;
	text-align: center;
	font-size: 12px;
	position: relative;
	text-decoration: none;
	color: #3c3c3c;
}
header .gnavi>ul>li>a:hover{
	color: #666666;
}
header .gnavi>ul>li>a:after{
	content:"";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 48px 8px;
	border-color: transparent transparent #d4dbde transparent;
	position: absolute;
	bottom: 0;
	left: 12px;
}
header .gnavi>ul>li>a:hover:after{
	border-color: transparent transparent #666666 transparent;
}
header .gnavi>ul>li ul.child{
	height:auto;
	position: absolute;
	top: 31px;
	left: -1px;
	z-index:999;
	width:180px;
	background: #fff;
}
header .gnavi>ul>li ul.child li{
	overflow: hidden;
	height: 0;
	transition: .2s;
	float:none;
	z-index:999;
}
header .gnavi>ul>li:hover ul.child li{
	overflow: visible;
	height: 26px;
	border-bottom:solid 1px #d4dbde;
}
header .gnavi>ul>li:hover ul.child li:last-child{
	border-bottom:none;
}
header .gnavi>ul>li ul.child li a{
	display: block;
	height:26px;
	line-height: 26px;
	font-size: 12px;
	margin:0 10px;
	padding: 0 15px;
}
footer{
	margin-top: -75px;
	height: 241px;
	position: relative;
	text-align: center;
	z-index: -1;
}
footer .gnavi{
	position: absolute;
	width: 100%;
	bottom: 70px;
	font-size: 11px;
}
footer .gnavi li{
	display: inline;
}
footer .gnavi li a{
	padding-right: 15px;
	margin-right: 12px;
	border-right:solid 1px #ccc;
	text-decoration: none;
}
footer .gnavi li:first-child a{
	border-left:solid 1px #ccc;
	padding-left: 15px;
	margin-left: 15px;
}
footer #copy{
	position: absolute;
	width: 100%;
	bottom: 30px;
	font-size: 9px;
}
/* </ LAYOUT> */

/* <PAGE> */
#container-wrap{
	overflow: hidden;
}
#contents{
	width: 715px;
	float: left;
}
#sidebar{
	width: 250px;
	float: right;
	font-size: 12px;
}
.login-box{
	border:solid 1px #ccc;
	text-align: center;
	margin-bottom: 20px;
	padding: 16px 0 17px;
	position: relative;
	background-color: #fff;
}
.login-box h3{
	letter-spacing: .1em;
	margin: 0 12px 10px;
	padding-bottom: 13px;
	border-bottom: dotted 1px #666666;
	font-size: 18px;
	color: #666666;
}
.login-box p{
	margin: 10px 0;
	line-height: 15px;
	color: #666666;
}
.login-box .btn{
	text-align: center;
}
.login-box .btn a{
	display: inline-block;
	width: 216px;
	line-height: 38px;
	border-radius:2px;
	color: #ffffff;
	font-size: 15px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
}
.qr-box{
	border:solid 1px #666666;
	background: #fff;
	position: relative;
	margin-bottom: 40px;
}
.qr-box .inner{
	position: relative;
	padding-right: 12px;
}
.qr-box:before,.qr-box:after,.qr-box .inner:before,.qr-box .inner:after{
	content:"";
	display: block;
	z-index: 2;
	position: absolute;
	background-color: #fff;
	width: 4px;
	height: 4px;
}
.qr-box:before{
	top:-1px;
	left: -1px;
}
.qr-box:after{
	top:-1px;
	right: -1px;
}
.qr-box .inner{
	height:94px;
	text-align: left;
}
.qr-box .inner:before{
	bottom:-1px;
	left: -1px;
}
.qr-box .inner:after{
	bottom:-1px;
	right: -1px;
}
.qr-box .qr{
	float: left;
	border: solid #fff 12px;
}
.qr-box h3{
	font-size: 15px;
	line-height: 18px;
	letter-spacing: .1em;
	color: #666666;
	padding: 12px 0 4px;
	border-bottom: dotted 1px #666666;
	margin-bottom: 5px;
}
.qr-box p{
	line-height: 15px;
	color: #666666;
}
.menu-box h3{
	color: #666666;
	padding-bottom: 4px;
	border-bottom: solid 3px #666666;
	margin-bottom: 10px;
	line-height: 18px;
	overflow: hidden;
}
.menu-box h3 .en{
	font-size: 18px;
	float: left;
	display: inline-block;
}
.menu-box h3 .jp{
	font-size: 13px;
	float: right;
	display: inline-block;
}
.ranking-box ul{
	margin-bottom: 20px;
}
.ranking-box ul li{
	position: relative;
	padding-bottom: 10px;
	border-bottom: dotted 1px #d4dbde;
	margin-bottom: 10px;
}
.ranking-box ul li:after{
	content:"";
	display: table;
	clear: both;
}
.ranking-box ul li i{
	display: inline-block;
	background-color: #666666;
	color: #ffffff;
	font-size: 11px;
	line-height: 18px;
	width: 18px;
	border-radius:4px;
	text-align: center;
	position: absolute;
	left: 0;
	top: -5px;
	z-index: 2;
}
.ranking-box ul li .photo{
	width: 90px;
	height: 64px;
	overflow: hidden;
	float: left;
	margin-right: 10px;
}
.ranking-box ul li p{
	line-height: 15px;
	padding-top: 8px;
}
.navi-box ul{
	margin-bottom: 20px;
}
.navi-box ul li{
	line-height: 26px;
	font-size: 12px;
}
.ban-box li{
	margin-bottom: 10px;
}

/*blog detail*/
.blog-detail-box{
	margin: 22px 0 44px;
}
.blog-detail-box p{
	font-size: 14px;
	line-height: 28px;
	margin-bottom: 20px;
}
.blog-detail-box li{
	font-size: 14px;
	line-height: 28px;
}
ol.list-p{
	margin-left: 20px;
	list-style:decimal outside;
}
.blog-detail-box p img{
	margin-bottom: 6px;
}
.blog-detail-box strong{
	color: #666666;
}
.blog-detail-box .readmore,
.blog-detail-box .applyevent,
.blog-detail-box .tail{
	text-align: center;
	margin: 40px 0;
}
.blog-detail-box .readmore .btn a,
.blog-detail-box .applyevent .btn a,
.blog-detail-box .tail .btn a,
.blog-detail-box .applyevent button{
	display: inline-block;
	width: 216px;
	line-height: 38px;
	border-radius:2px;
	color: #ffffff;
	font-size: 15px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
	margin-bottom: 10px;
	border:none;
}
.blog-detail-box .applyevent .btn a,
.blog-detail-box .applyevent button{
	width: 288px;
}
.blog-detail-box .memlogin a{
	text-decoration: underline;
}

/*top*/
#top-main{
	margin-bottom: 0;
}
#top-fa{
	margin-bottom: 85px;
}
#top-fa ul{
	overflow: hidden;
}
#top-fa ul li{
	width: 347px;
	height: 170px;
	background:url(/images/top/fa-bg.gif) no-repeat left top;
	float: left;
	margin-right: 21px;
	padding: 10px;
}
#top-fa ul li:last-child{
	margin-right: 0;
}
.article-loop .inner{
	background:rgba(0,0,0,0.05);
}
#top-topic .inner{
	padding-bottom: 40px;
}
.article-loop ul{
	padding: 50px 0 0 40px;
	overflow: hidden;
}
.article-loop ul li{
	display: inline;
}
.article-loop ul li a{
	display: block;
	width: 293px;
	height:287px;
	float: left;
	position: relative;
	border-bottom: dotted 1px #d4dbde;
	margin-right: 49px;
	margin-bottom: 50px;
	outline:none;
}
.article-loop ul li:nth-child(2n) a{
	margin-right: 0;
}
.article-loop ul li:nth-child(5) a,
.article-loop ul li:nth-child(6) a{
	border-bottom: none;
	margin-bottom: 0;
}
.article-loop ul li .index{
	position: absolute;
	display: inline-block;
	font-weight: bold;
	font-size: 20px;
	line-height: 26px;
	color: #666666;
	border-bottom: solid 5px #666666;
	top:-26px;
	left:0;
	z-index: 9;
}
.article-loop ul li .photo{
	display: block;
	width: 293px;
	height: 160px;
	overflow: hidden;
}
.article-loop ul li .photo img{
	width: 293px;
	height:auto;
	position: relative;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}
.article-loop ul li .ttl{
	display: block;
	margin: 12px 0 9px;
	color: #666666;
	font-size: 15px;
	font-weight: bold;
}
.article-loop ul li .info{
	display: block;
	font-size: 12px;
	line-height: 17px;
	color: #3c3c3c;
}
.article-loop .btn2{
	text-align: center;
}
.article-loop .btn2 a{
	display: inline-block;
	text-align: center;
	width: 200px;
	height: 24px;
	line-height: 22px;
	border: solid 1px #666666;
	position: relative;
	font-size: 12px;
	border-radius:4px;
	text-decoration: none;
	background: #fff;
	color: #666666;
}


/*about*/
#about-box .main{
	margin-bottom: 78px;
}
#about-box .catch{
	text-align: center;
	margin: -60px 0 30px;
	font-size: 18px;
	line-height: 32px;
}
#about-box .about{
	margin-bottom: 50px;
	background:rgba(0,0,0,0.05);
}
#about-box .about ul{
	padding: 0 40px 6px;
}
#about-box .about ul li{
	overflow: hidden;
	border-bottom: solid 1px #d4dbde;
	padding-top: 23px;
}
#about-box .about ul li:nth-child(2){
	padding-top: 40px;
}
#about-box .about ul li:nth-child(3){
	border-bottom: none;
}
#about-box .about ul li .photo{
	float: right;
	padding-bottom: 23px;
	padding-right: 34px;
}
#about-box .about ul li:nth-child(2) .photo{
	float: left ;
	padding-right: 0;
}
#about-box .about ul li dl{
	float: left;
	width: 480px;
	padding-top: 26px;
}
#about-box .about ul li:nth-child(2) dl{
	float: right;
}
#about-box .about ul li dt{
	font-weight: bold;
	font-size: 18px;
	line-height: 32px;
	letter-spacing: 0.02em;
	padding: 0 0 20px 62px;
	background:url(/images/about/icon1.png) no-repeat left top;
}
#about-box .about ul li:nth-child(2) dl dt{
	background-image: url(/images/about/icon2.png);
}
#about-box .about ul li:nth-child(3) dl dt{
	background-image: url(/images/about/icon3.png);
}
#about-box .about ul li dd{
	font-size: 12px;
	line-height: 17px;
	padding-left: 62px;
}

/*howtouse*/
#howtouse-box .ttl2{
	margin-top: 40px;
}
.step-layout{
	margin: 40px 0;
}
.step-layout .col-wrap {
    display: table;
}
.step-layout .col-wrap .col-box{
	display: table-cell;
	vertical-align: top;
	width: 50%;
    padding-right: 8px;
    padding-left: 0;
}
.step-layout h4{
	margin: 0 0 10px;
	color:#666666;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}
.step-layout dl{
	padding: 20px;
	border: 1px solid #d3d3d3;
}
.step-layout dl dt{
    font-size: 15px;
    font-weight: bold;
	line-height: 30px;
}
.step-layout dl dt span{
	font-size: 22px;
	font-weight: bold;
	color: #666666;
	margin-right: 1em;
}
.step-layout dl dd p{
	margin-bottom: 0;
}
.step-layout > li:nth-child(3):before,
.col-wrap .col-box:after {
    display: block;
    margin: 0 auto;
    width: 0;
    height: 1px;
    border-top: 20px solid #666666;
    border-right: 40px solid transparent;
    border-bottom: 0 solid transparent;
    border-left: 40px solid transparent;
    content: "";
    text-align: center;
}
#member-apply dt{
	width: 160px;
}
#member-apply dd{
	padding-left: 200px;
}

/*faq*/
.faq-wrap{
	margin-bottom: 40px;
}
.faq-wrap>li{
    padding: 20px 0 16px;
    border-bottom: 1px solid #d3d3d3;
}
.faq-wrap>li dt{
	display: table;
	table-layout: fixed;
	width: 100%;
	margin-bottom: 13px;
}
.faq-wrap>li .icon{
    width: 42px;
    display: table-cell;
    vertical-align: top;
}
.faq-wrap>li .icon span{
    display: inline-block;
    width: 42px;
    height: 42px;
    line-height: 42px;
    text-align: center;
    background: #666666;
    color: #FFF;
    border-radius: 50%;
    font-size: 20px;
}
.faq-wrap>li dt .txt{
    padding: 12px 0 0 22px;
    display: table-cell;
    vertical-align: top;
	font-size: 17px;
	font-weight: bold;
	color: #666666;
}
.faq-wrap>li dd{
	display: table;
	table-layout: fixed;
	width: 100%;
}
.faq-wrap>li dd .icon-a span{
    background: #fff;
    color: #666666;
	border: solid 2px #666666;
    border-radius: 50%;
    font-size: 20px;
}
.faq-wrap>li dd .txt{
    padding: 10px 0 0 22px;
    display: table-cell;
    vertical-align: top;
}

/*sns*/
#sns-box .ttl2{
	margin-top: 40px;
}
.social-acc{
	margin: 30px 0;
}
.social-acc dt{
	line-height: 40px;
	font-size: 17px;
	vertical-align: middle;
}
.social-acc dt a{
	color: #666666;
	font-weight: bold;
	text-decoration: none;
}
.social-acc dt:before{
	content:"";
	display: inline-block;
	width: 40px;
	height: 40px;
	background-repeat: no-repeat;
	background-position: left top;
	-webkit-background-size: contain;
	background-size: contain;
	margin-right: 10px;
	vertical-align: middle;
	background-color: #666666;
	border-radius:2px;
}
.social-fb dt:before{ background-image:url(/images/common/icon-fb.png) }
.social-tw dt:before{ background-image: url(/images/common/icon-tw.png); }
.social-acc dd{
	padding-left: 50px;
}

/*company*/
#company-box table{
	width: 100%;
	border: 1px solid #d3d3d3;
	box-shadow: 0 3px 0 rgba(8,1,2,0.1);
}
#company-box table th,
#company-box table td{
	width: 175px;
	padding: 16px 20px 14px;
	line-height: 28px;
	font-size: 14px;
	vertical-align: top;
	text-align: left;
	border-bottom: 1px dotted #d3d3d3;
}
#company-box table td{
	width: 540px;
}
#company-box table td p:last-child{
	margin-bottom: 0;
}
#company-box table td p iframe{
	width: 100%;
	height: 360px;
	margin-top: 12px;
}

/*privacy*/
#privacy-box .sign{
	text-align: right;
}
#privacy-box ol{
	margin-bottom: 20px;
}
#privacy-box .ttl2{
	margin-top: 40px;
}

/*inquiry*/
.inq-deco{
	margin-bottom: 50px;
	background:rgba(0,0,0,0.05);
	padding: 23px 20px 6px;
	overflow: hidden;
}
.inq-deco .photo{
	float: right;
	padding-bottom: 23px;
	padding-right: 14px;
}
.inq-deco dl{
	float: left;
	width: 380px;
	padding-top: 12px;
}
.inq-deco dt{
	font-weight: bold;
	font-size: 18px;
	line-height: 32px;
	letter-spacing: 0.02em;
	padding: 0 0 20px;
}
.inq-deco dd{
	font-size: 12px;
	line-height: 17px;
}


.wpcf7-textarea,.wpcf7-text {
	width: 100%;
	border:solid 1px #bcbcbc;
	padding: 8px;
}

.wpcf7 .form_btn input {
 background: #666666;
 width:100px;
 margin-right: 10px;
 border:none;
   color: #FFFFFF;
   font-family: Open Sans;
   font-size: 15px;
   font-weight: 100;
   padding: 10px;
   text-decoration: none;
   display: inline-block;
   cursor: pointer;
}

/*list*/
.wp-pagenavi {
	clear: both;
	padding: 40px 0;
	text-align: center;
}
.wp-pagenavi > a, .wp-pagenavi span {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    height: 40px;
    line-height: 40px;
    border-radius: 2px;
    box-shadow: 0 3px 0 #f2f2f2;
    width: 40px;
    letter-spacing: normal;
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 5.5px;
    vertical-align: middle;
    color: #000;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border-color: #000;
}
.wp-pagenavi span.current {
	font-weight: bold;
}
.wp-pagenavi > span.current {
    color: #fff;
    background: #666666;
    border: 0;
    box-shadow: 0 3px 0 #d9d9d9;
}
/* </ PAGE> */




/*▼スマホ対応*/
@media screen and (max-width: 768px) {
body{
	background-size: 50% auto,auto auto;
	background-image: url(/images/common/body-bg.png),
		url(/images/common/body-bg2.gif);
	background-repeat: no-repeat,
		no-repeat;
	background-position: 0 0,
		center top;
}

*{ min-width:initial !important; }
img{ max-width:100%; }
.smt{ display: inherit; }
.pc{ display: none; }

/* <MODULE> */
.pagettl1{
	margin-bottom: 15px;
}
.pagettl1 span{
	font-size: 15px;
	padding-bottom: 5px;
}
.pagettl1 span em{
	font-size: 12px;
	margin-left: 20px;
}
.pagettl2{
	margin-bottom: 15px;
}
.pagettl2 span{
	font-size: 15px;
	padding-bottom: 5px;
	border-bottom: dotted 1px #666666;
}
.pagebtn1 a{
	display: inline-block;
	line-height: 44px;
	border-radius:2px;
	color: #ffffff;
	font-size: 16px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
	padding-right: 30px;
	padding-left: 45px;
}
/* </ MODULE> */


/* <LAYOUT> */
#wrapper{
	width: auto;
	margin: 0;
    position: relative;
	overflow-x: hidden;
	right: 0;
	padding-top: 72px;
}
#offcanvas-menu{
	display: block;
	position: fixed;
	top: 0;
	padding-top: 52px;
	right: -300px;
	width: 300px;
	height: 100%;
	background: #fff;
	z-index: 9;
	overflow-y: auto;
}
#offcanvas-menu ul{
	margin: 0 16px;
}
#offcanvas-menu li{
	display: inline;
}
#offcanvas-menu li a{
	font-size: 18px;
	font-family: 'Cormorant Garamond';
	padding: 13px 12px;
    display: block;
    border-bottom: solid 1px #cccccc;
    text-align: left;
    position: relative;
}
#offcanvas-menu li a:after {
    content: "";
    display: inline-block;
    background: url(../images/common/arrow.png) no-repeat left top;
    -webkit-background-size: 100%;
    background-size: 100%;
    width: 10px;
    height: 9px;
    right: 12px;
	top:18px;
	position: absolute;
}
#offcanvas-menu ul ul li a:after {
	top: 50%;
	margin-top: -4px;
}
#offcanvas-menu>ul>li.art.closemenu>a:after{
    background: url(../images/common/arrow-below2.png) no-repeat left top;
	transform: scale(1, -1);
}
#offcanvas-menu ul ul{
	margin: 0;
	display: none;
}
#offcanvas-menu ul ul li a{
	font-size: 12px;
	padding: 6px 22px 6px 32px;
}
#offcanvas-menu ul ul li a span{
	display: block;
	margin-bottom: 4px;
	font-size: 16px;
	font-family: 'Cormorant Garamond';
}
#offcanvas-container{
	display: block;
	position: relative;
	top:0 ;
	right:0 ;
	width: 100%;
}
#offcanvas-button{
	display: block;
	background: #666666;
	width: 52px;
	height: 52px;
	position: absolute;
	top: 0;
	right: 0;
	z-index: 999999999999;
	cursor:pointer;
}
#offcanvas-button:after{
	content:"MENU";
    color: #fff;
    bottom: 6px;
    position: absolute;
    text-align: center;
    left: 0;
    font-size: 9px;
	font-family: 'Cormorant Garamond';
    width: 100%;
}
#offcanvas-button span,
#offcanvas-button span:before,
#offcanvas-button span:after{
    position: absolute;
    top: 50%;
    left: 50%;
    height: 2px;
    width: 26px;
    cursor: pointer;
    background: #fff;
    display: block;
    content: '';
    -webkit-transition: all 500ms ease-in-out;
    transition: all 500ms ease-in-out;
}
#offcanvas-button span{
	transform: translate3d(-50%,-4px,0);
	-webkit-transform: translate3d(-50%,-4px,0);
}
#offcanvas-button span:before {
    transform: translate3d(-50%,-10px,0);
    -webkit-transform: translate3d(-50%,-10px,0);
}
#offcanvas-button span:after {
    transform: translate3d(-50%,7px,0);
    -webkit-transform: translate3d(-50%,7px,0);
}
#offcanvas-button.closemenu:after{
	content:"";
}
#offcanvas-button.closemenu span{
	background-color: transparent;	
}
#offcanvas-button.closemenu span:before {
    -ms-transform: translateX(-50%)rotate(45deg);
    transform: translateX(-50%)rotate(45deg);
    -webkit-transform: translateX(-50%)rotate(45deg);
	top:4px;
	width: 36px;
}
#offcanvas-button.closemenu span:after {
    -ms-transform: translateX(-50%)translateY(-10px)rotate(-45deg);
    transform: translateX(-50%)translateY(-10px)rotate(-45deg);
    -webkit-transform: translateX(-50%)translateY(-10px)rotate(-45deg);
    top: 14px;
	width: 36px;
}
header{
	position: fixed;
	top:0;
	left: 0;
	width: 100%;
	height: 52px;
	background-color:rgba(255,255,255,0.8);
	z-index: 999;
}
header .logo{
	text-align: left;
	padding-top: 0;
	margin: 0 62px 0 20px;
	height: 52px;
	position: relative;
}
header .logo img{
	width: auto;
	height: 30px;
	position: relative;
    top: 50%;
    transform: translateY(-50%);
}	
header .subnavi{
	display: none;
}
header .gnavi{
	display: none;
}
footer{
	margin-top: 0;
	height: auto;
	position: static;
	background:url(/images/common/footer-bg.png) no-repeat center bottom;
	color: #fff;
}
footer .gnavi{
	display: none;
}
footer #copy{
	position: static;
	padding: 30px 0;
	width: 100%;
	font-size: 9px;
}
/* </ LAYOUT> */


/* <APP> */
/*01.login*/
.login-area h4{
	font-size: 15px;
	padding-top: 12px;
	margin-bottom: 15px;
}
.login-area .error{
	margin-bottom: 15px;
	padding: 10px 0;
}
.login-area .form-login {
    background-color: #EDEDED;
    padding-top: 10px;
    padding-bottom: 20px;
    padding-left: 20px;
    padding-right: 20px;
    border-radius: 15px;
    border-color:#d2d2d2;
    border-width: 5px;
    box-shadow:0 1px 0 #cfcfcf;
	margin:40px 0 30px;
}
.login-area h4 { 
	border:0 solid #fff; 
	border-bottom-width:1px;
	padding-bottom:10px;
	text-align: center;
}
.login-area .form-control {
    border-radius: 10px;
}
.login-area .wrapper{
	text-align:center;
}

/*02.resist*/
.resist-area{
	width: auto !important;
}
.resist-area h2{
	display: inline-block;
	font-size: 15px;
	font-weight: bold;
	color:#666666;
	padding-bottom: 5px;
	border-bottom: solid 3px #666666;
	margin-bottom: 12px;
}
.resist-area .form-name input{
	width: 100%;
}
.resist-area .form-horizontal{
	margin: 16px 0 0;
}
.resist-area .form-group{
	padding-bottom: 15px;
	border-bottom: solid 1px #d4d4d4;
	margin-left: 0;
	margin-right: 0;
}
.resist-area .form-group:first-child{
	padding-top: 10px;
	border-top: solid 1px #d4d4d4;
}
.resist-area .form-group:last-child button{
	margin-right: 15px;
}
.resist-area input + p{
	margin: 5px 0 0;
}
.form-zip-box #zip-comp{
	margin-left: 0;
}
.form-add-box{
	margin-top: 10px;
}
.form-add-box label{
	margin-right: 0;
}
.after_delete{
	line-height: 34px;
}
/*03.leave*/
#leave-button{
	margin-top: 30px;
}

#msg-script{
	text-align: center;
	font-weight: bold;
	padding: 10px 0;
	border:solid 1px #a94442;
	margin-bottom: 20px;
}
.form-group{
	padding-top: 15px;
}

/* </ APP> */


/* <PAGE> */
#container-wrap{
	overflow: hidden;
	padding: 10px;
}
#contents{
	width: auto;
	float: none;
	margin-bottom: 20px;
}
#sidebar{
	width: auto;
	float: none;
	font-size: 12px;
}
.login-box{
	text-align: center;
	margin: 0 8px 15px;
	padding: 12px 0 12px;
	position: relative;
	background-color: #fff;
	background-image:none;
	border-top: solid 2px #666666;
	border-bottom: solid 2px #666666;
}
.login-box:before,.login-box:after{
	content:"";
	background-color: #666666;
	width: 2px;
	height: calc(100% - 12px);
	position: absolute;
	top: 6px;
}
.login-box:before{
	left: -8px;
}
.login-box:after{
	right: -8px;
}
.login-box h3{
	letter-spacing: .1em;
	margin: 0 10px 10px;
	padding-bottom: 10px;
	border-bottom: dotted 1px #666666;
	font-size: 13px;
	color: #666666;
}
.login-box p{
	margin: 10px 0 0;
	line-height: 15px;
	color: #666666;
}
.login-box .btn{
	text-align: center;
}
.login-box .btn a{
	display: inline-block;
	width: 216px;
	line-height: 38px;
	border-radius:2px;
	color: #ffffff;
	font-size: 15px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
}
.qr-box{
	display: none;
}
.menu-box h3{
	color: #666666;
	padding-bottom: 4px;
	border-bottom: solid 3px #666666;
	margin-bottom: 10px;
	line-height: 18px;
	overflow: hidden;
}
.menu-box h3 .en{
	font-size: 15px;
	float: left;
	display: inline-block;
}
.menu-box h3 .jp{
	font-size: 11px;
	float: right;
	display: inline-block;
}
.ranking-box ul{
	margin-bottom: 15px;
}
.ranking-box ul li{
	position: relative;
	padding-bottom: 10px;
	border-bottom: dotted 1px #d4dbde;
	margin-bottom: 10px;
}
.ranking-box ul li:after{
	content:"";
	display: table;
	clear: both;
}
.ranking-box ul li i{
	display: inline-block;
	background-color: #666666;
	color: #ffffff;
	font-size: 11px;
	line-height: 18px;
	width: 18px;
	border-radius:4px;
	text-align: center;
	position: absolute;
	left: 0;
	top: -5px;
	z-index: 2;
}
.ranking-box ul li .photo{
	width: 90px;
	height: 64px;
	overflow: hidden;
	float: left;
	margin-right: 10px;
}
.ranking-box ul li .photo img{
	width: 120px;
	height:auto;
	position: relative;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}
.ranking-box ul li p{
	line-height: 15px;
	padding-top: 8px;
}
.navi-box{
	display: none;
}
.ban-box{
	overflow: hidden;
}
.ban-box li{
	float: left;
	width: 49%;
	margin-right: 2%;
	margin-bottom: 10px;
}
.ban-box li:last-child{
	margin-right: 0;
}
.ban-box li img{
	width: 100%;
	height: auto;
}

/*blog detail*/
.blog-detail-box{
	margin: 15px 0 30px;
}
.blog-detail-box p{
	font-size: 12px;
	line-height: 20px;
	margin-bottom: 15px;
}
.blog-detail-box li{
	font-size: 12px;
	line-height: 20px;
}
ol.list-p{
	margin-left: 20px;
	list-style:decimal outside;
}
.blog-detail-box p img{
	margin-bottom: 6px;
}
.blog-detail-box strong{
	color: #666666;
}
.blog-detail-box .readmore,
.blog-detail-box .applyevent{
	text-align: center;
	margin: 25px 0;
}
.blog-detail-box .readmore .btn a,
.blog-detail-box .applyevent .btn a,
.blog-detail-box .applyevent button{
	display: inline-block;
	width: 216px;
	line-height: 38px;
	border-radius:2px;
	color: #ffffff;
	font-size: 15px;
	letter-spacing: .1em;
	text-decoration: none;
	background: #666666 url(/images/common/icon-arrow.png) no-repeat 14px center;
	margin-bottom: 10px;
	border:none;
}
.blog-detail-box .applyevent .btn a,
.blog-detail-box .applyevent button{
	width: 288px;
}
.blog-detail-box .memlogin a{
	text-decoration: underline;
}

/*top*/
#top-main{
	margin-bottom: 24px;
}
#top-fa{
	margin-bottom: 55px;
}
#top-fa ul{
	overflow: hidden;
	margin-bottom: 20px;
	text-align: center;
}
#top-fa ul li{
	width: auto;
	height: auto;
	background:url(/images/top/fa-bg.gif) no-repeat center top;
	float: none;
	margin-right: 0;
	margin-bottom: 10px;
	padding: 10px;
}
#top-topic .inner{
	padding-bottom: 30px;
}
.article-loop ul{
	padding: 40px 20px 20px;
	overflow: hidden;
}
.article-loop ul li{
	display: inline;
}
.article-loop ul li a{
	display: block;
	width: 100%;
	height: auto;
	float: none;
	position: relative;
	border-bottom: dotted 1px #d4dbde;
	margin-right: 0;
	padding-bottom: 20px;
	margin-bottom: 40px;
}
.article-loop ul li:nth-child(5) a{
	border-bottom: dotted 1px #d4dbde;
	margin-bottom: 40px;
}
.article-loop ul li .index{
	font-size: 16px;
	line-height: 20px;
	top:-20px;
}
.article-loop ul li .photo{
	display: block;
	width: 100%;
	height: auto;
	overflow:inherit;
}
.article-loop ul li .photo img{
	width: 100%;
	height:auto;
	position: static;
    top: 50%;
    left: 50%;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
}
.article-loop ul li .ttl{
	display: block;
	margin: 12px 0 9px;
	color: #666666;
	font-size: 13px;
	font-weight: bold;
}
.article-loop ul li .info{
	font-size: 11px;
	line-height: 14px;
}
.article-loop .btn2 a{
	display: inline-block;
	text-align: center;
	width: 200px;
	height: 24px;
	line-height: 22px;
	border: solid 1px #666666;
	position: relative;
	font-size: 12px;
	border-radius:4px;
	text-decoration: none;
	background: #fff;
	color: #666666;
}


/*about*/
#about-box .main{
	margin-bottom: 78px;
}
#about-box .catch{
	text-align: center;
	margin: -10px 0 30px;
	font-size: 16px;
	line-height: 30px;
	text-align: left;
}
#about-box .catch br{
	display: none;
}
#about-box .about{
	margin-bottom: 50px;
	background:rgba(0,0,0,0.05);
}
#about-box .about ul{
	padding: 0 20px 6px;
}
#about-box .about ul li{
	overflow: hidden;
	border-bottom: solid 1px #d4dbde;
	padding-top: 23px;
	padding-bottom: 23px;
}
#about-box .about ul li:nth-child(2){
	padding-top: 40px;
}
#about-box .about ul li:nth-child(3){
	border-bottom: none;
}
#about-box .about ul li .photo{
	float: none;
	padding-bottom: 13px;
	padding-right: 0;
	text-align: center;
}
#about-box .about ul li:nth-child(2) .photo{
	float: none;
	padding-right: 0;
}
#about-box .about ul li .photo img{
	width: 100%;
	height: auto;
}
#about-box .about ul li dl{
	float: none;
	width: auto;
	padding-top: 6px;
}
#about-box .about ul li:nth-child(2) dl{
	float: none;
}
#about-box .about ul li dt{
	font-weight: bold;
	font-size: 16px;
	line-height: 28px;
	letter-spacing: 0.02em;
	padding: 0 0 13px 62px;
	background:url(/images/about/icon1.png) no-repeat left top;
}
#about-box .about ul li:nth-child(2) dl dt{
	background-image: url(/images/about/icon2.png);
}
#about-box .about ul li:nth-child(3) dl dt{
	background-image: url(/images/about/icon3.png);
}
#about-box .about ul li dd{
	font-size: 12px;
	line-height: 17px;
	padding-left: 62px;
}

/*howtouse*/
#howtouse-box .ttl2{
	margin-top: 40px;
}
.step-layout{
	margin: 40px 0 20px;
}
.step-layout .col-wrap {
    display: table;
}
.step-layout .col-wrap .col-box{
	display: table-cell;
	vertical-align: top;
	width: 50%;
    padding-right: 8px;
    padding-left: 0;
}
.step-layout h4{
	height: 40px;
	margin: 0;
	color:#666666;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
}
.step-layout dl{
	padding: 20px;
	border: 1px solid #d3d3d3;
}
.step-layout dl dt{
    font-size: 15px;
    font-weight: bold;
	line-height: 30px;
}
.step-layout dl dt span{
	font-size: 22px;
	font-weight: bold;
	color: #666666;
	margin-right: 1em;
}
.step-layout dl dd p{
	margin-bottom: 0;
}
.step-layout > li:nth-child(3):before,
.col-wrap .col-box:after {
    display: block;
    margin: 0 auto;
    width: 0;
    height: 1px;
    border-top: 20px solid #666666;
    border-right: 40px solid transparent;
    border-bottom: 0 solid transparent;
    border-left: 40px solid transparent;
    content: "";
    text-align: center;
}
#member-apply dt{
	width: 160px;
}
#member-apply dd{
	padding-left: 200px;
}

/*faq*/
.faq-wrap{
	margin-bottom: 40px;
}
.faq-wrap>li{
    padding: 20px 0 16px;
    border-bottom: 1px solid #d3d3d3;
}
.faq-wrap>li:first-child{
    padding-top: 0;
}
.faq-wrap>li dt{
	display: table;
	table-layout: fixed;
	width: 100%;
	margin-bottom: 13px;
}
.faq-wrap>li .icon{
    width: 42px;
    display: table-cell;
    vertical-align: top;
}
.faq-wrap>li .icon span{
    display: inline-block;
    width: 42px;
    height: 42px;
    line-height: 42px;
    text-align: center;
    background: #666666;
    color: #FFF;
    border-radius: 50%;
    font-size: 20px;
}
.faq-wrap>li dt .txt{
    padding: 12px 0 0 12px;
    display: table-cell;
    vertical-align: top;
	font-size: 15px;
	font-weight: bold;
	color: #666666;
}
.faq-wrap>li dd{
	display: table;
	table-layout: fixed;
	width: 100%;
}
.faq-wrap>li dd .icon-a span{
    background: #fff;
    color: #666666;
	border: solid 2px #666666;
    border-radius: 50%;
    font-size: 20px;
}
.faq-wrap>li dd .txt{
    padding: 10px 0 0 12px;
    display: table-cell;
    vertical-align: top;
}

/*sns*/
#sns-box .ttl2{
	margin-top: 40px;
}
.social-acc{
	margin: 30px 0;
}
.social-acc dt{
	line-height: 40px;
	font-size: 17px;
	vertical-align: middle;
}
.social-acc dt a{
	color: #666666;
	font-weight: bold;
	text-decoration: none;
}
.social-acc dt:before{
	content:"";
	display: inline-block;
	width: 40px;
	height: 40px;
	background-repeat: no-repeat;
	background-position: left top;
	-webkit-background-size: contain;
	background-size: contain;
	margin-right: 10px;
	vertical-align: middle;
	background-color: #666666;
	border-radius:2px;
}
.social-fb dt:before{ background-image:url(/images/common/icon-fb.png) }
.social-tw dt:before{ background-image: url(/images/common/icon-tw.png); }
.social-acc dd{
	padding-left: 50px;
}

/*company*/
#company-box table{
	width: 100%;
	border: 1px solid #d3d3d3;
	box-shadow: 0 3px 0 rgba(8,1,2,0.1);
}
#company-box table th,
#company-box table td{
	width: 175px;
	padding: 16px 20px 14px;
	vertical-align: top;
	text-align: left;
	border-bottom: 1px dotted #d3d3d3;
	
	font-size: 12px;
    line-height: 20px;
}
#company-box table td{
	width: 540px;
}
#company-box table td p:last-child{
	margin-bottom: 0;
}
#company-box table td p iframe{
	width: 100%;
	height: 220px;
	margin-top: 12px;
}

/*privacy*/
#privacy-box .sign{
	text-align: right;
}
#privacy-box ol{
	margin-bottom: 20px;
}
#privacy-box .ttl2{
	margin-top: 40px;
}

/*inquiry*/
.inq-deco{
	margin-bottom: 25px;
	padding: 20px;
}
.inq-deco .photo{
	float: none;
	padding-bottom: 15px;
	padding-right: 0;
	text-align: center;
}
.inq-deco dl{
	float: none;
	width: auto;
	padding-top: 0;
}
.inq-deco dt{
	font-weight: bold;
	font-size: 15px;
	line-height: 28px;
	letter-spacing: 0.02em;
	padding: 0 0 15px;
}
.inq-deco dd{
	font-size: 12px;
	line-height: 15px;
}
.wpcf7-textarea,.wpcf7-text {
	width: 100%;
	border:solid 1px #bcbcbc;
	padding: 8px;
}

.wpcf7 .form_btn input {
 background: #666666;
 width:100px;
 margin-right: 10px;
 border:none;
   color: #FFFFFF;
   font-family: Open Sans;
   font-size: 15px;
   font-weight: 100;
   padding: 10px;
   text-decoration: none;
   display: inline-block;
   cursor: pointer;
}

/*list*/
.wp-pagenavi {
	clear: both;
	padding: 40px 0;
	text-align: center;
}
.wp-pagenavi > a, .wp-pagenavi span {
    display: inline-block;
    *display: inline;
    *zoom: 1;
    height: 40px;
    line-height: 40px;
    border-radius: 2px;
    box-shadow: 0 3px 0 #f2f2f2;
    width: 40px;
    letter-spacing: normal;
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 5.5px;
    vertical-align: middle;
    color: #000;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border-color: #000;
}
.wp-pagenavi span.current {
	font-weight: bold;
}
.wp-pagenavi > span.current {
    color: #fff;
    background: #666666;
    border: 0;
    box-shadow: 0 3px 0 #d9d9d9;
}
/* </ PAGE> */
}


