body{
  -webkit-text-size-adjust: 100%;
}

.body_inner{
  min-width: 960px;
  background-color:#000;
  font-size:14px;
  line-height: 1.43;
  background-image:url(../img/bg_top.png),url(../img/bg_bottom.png),url(../img/bg_pattern.jpg);
  background-repeat:repeat-x,no-repeat,repeat;
  background-position:center top,center bottom,center top;
}
a, a:link, a:visited, a:hover, a:active{
  font-weight: bold;
  color:#ffff3c;
}

.inner{
  width:960px;
  margin:0 auto;
}
.floatLeft{float:left;}
.floatRight{float:right;}
.cf:before,
.cf:after {
  content:"";
  display:table;
}
.cf:after {
  clear:both;
}
.hide-text,.btn{
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden
}
.btn{
  position:relative;
  display: block;
}
.btn:before,
.btn:after{
  position:absolute;
  content:"";
  display:block;
  top:0;
  bottom:0;
  right:0;
  left:0;
  transition:0.2s;
}
.btn:after{
  opacity: 0;
}
.btn:before{
  opacity: 1;
}
/*.btn:hover:before{
  opacity: 0;
}*/
.btn:hover:after{
  opacity: 1;
}


/*mainvisual*/
.mainvisual{
  background:url(../img/mainvisual.png) no-repeat center top;
  height: 530px;
}

/*headline*/
.entry h1,.prize h1,.detail h1{
  height: 65px;
  margin-top:40px;
}

/*entry*/
.entry h1{
  background:url(../img/head_entry.png) no-repeat center top;
}
.entry ol{
  margin-top:5px;
}
.entry ol li{
  float:left;
  margin-left: 7px;
  height: 321px;
  background-color:#c00;
  box-sizing: border-box;
  padding:20px 10px 0 22px;
  position:relative;
}
.entry ol .step1{
  width:338px;
  background:url(../img/entry_step1.png) no-repeat;
}
.entry ol .step2{
  width:308px;
  background:url(../img/entry_step2.png) no-repeat;
}
.entry ol .step3{
  width:276px;
  background:url(../img/entry_step3.png) no-repeat;
}
.entry ol .step1:after,
.entry ol .step2:after{
  position:absolute;
  content:'';
  display:block;
  width:50px;
  height: 43px;
  top:145px;
  right:-35px;
  z-index:1;
  background:url(../img/enrty_arrow.png) no-repeat;
}
.entry ol li .caption{
  margin-left: 40px;
}
.entry ol li .caption strong{
  font-weight: bold;
  color:#0033ff;
}
.entry ol li img{
  display: block;
  margin:5px auto;
}
.entry ol li .sup{
  font-size:11px;
}
.entry .step1 .btn{
  width:303px;
  height:55px;
  margin:10px auto 5px;
}
.entry .step1 .btn:before{
  background:url(../img/btn_familymart.png)no-repeat center top;
}
.entry .step1 .btn:after{
  background:url(../img/btn_familymart.png)no-repeat center bottom;
}
.entry a{
  color:#0033ff;
}

/*prize*/
.prize h1{
  background:url(../img/head_prize.png) no-repeat center top;
}
.prize .inner{
  position: relative;
  height: 937px;
  background:url(../img/prize.png) no-repeat center top;
}
.prize .inner .btn_area{
  position: absolute;
  top:745px;
  left:70px;
}
.prize .inner .btn_area p{
  width:470px;
}
.prize .btn{
  width:487px;
  height:84px;
  margin:20px 0 0 25px;
}
.prize .btn:before{
  background:url(../img/btn_entry.png)no-repeat center top;
}
.prize .btn:after{
  background:url(../img/btn_entry.png)no-repeat center bottom;
}



/*detail*/
.detail{
  padding-bottom:40px;
}
.detail h1{
  background:url(../img/head_detail.png) no-repeat center top;
}
.detail ul.inner{
  background-image:url(../img/detail_bg_bottom.jpg),url(../img/detail_bg_top.jpg),url(../img/detail_bg_middle.png);
  background-repeat:no-repeat,no-repeat,repeat-y;
  background-position:center bottom,center top,center top;
  min-height: 655px;
  color:#fff;
  box-sizing: border-box;
  padding:25px 18px 0;
  margin-top:12px;
}
.detail ul.inner > li{
  border-bottom:1px solid #b7b9bb;
  margin-bottom:22px;
  padding-bottom:22px;
  line-height: 21px;
}
.detail ul.inner > li:last-child{
  border-bottom:none;
  margin-bottom:0;
}
.detail ul.inner > li > h2{
  float:left;
  width:170px;
}
.detail ul.inner > li > div{
  width:750px;
}
.detail .sup,.detail .attention_list{
  font-size:12px;
}
.detail .sup{
  margin-top:10px;
}
.detail h2{
  background-repeat:no-repeat;
  background-position:top 1px left 5px;
}
.detail h2.period{
  background-image:url(../img/detail_ttl_period.png);
}
.detail h2.period + div > p,
.detail h2.period + div > h2{
  float:left;
}
.detail h2.period + div > h2{
  margin-left:10px;
  margin-right:5px;
}
.detail h2.limit{
  width:100px;
  background-image:url(../img/detail_ttl_limit.png);
}
.detail h2.target{
  background-image:url(../img/detail_ttl_target.png);
}
.detail h2.receiving{
  background-image:url(../img/detail_ttl_receiving.png);
}
.detail h2.attention{
  background-image:url(../img/detail_ttl_attention.png);
}
/*pagetop*/
.pagetop{
  width:960px;
  margin:0 auto;
}
.pagetop a{
  position: fixed;
  display: block;
  width:75px;
  height:81px;
  bottom:20px;
  left:auto;
  margin-left:870px;
}
.pagetop a:before{
  background:url(../img/btn_totop.png)no-repeat center top;
}
.pagetop a:after{
  background:url(../img/btn_totop.png)no-repeat center bottom;
}
/*footer*/
.footer{
  background:url(../img/bg_footer.jpg) repeat center top;
  color:#fff;
  text-align: center;
  padding:20px 0;
}
.footer_contact{
  font-size:14px;
  line-height: 24px;
  font-weight: bold;
}
.footer_copy{
  margin-top:20px;
  color:#b5b6ec;
}
.footer .btn-home{
  text-align:center
  font-size:1em
}
.footer .btn-home a{
  display:inline-block;
  margin:20px auto 0;
  padding:.5em 2em .3em;
  border-radius:30px;
  text-decoration:none;
  background-color:#fff;
  color:#2309c0;
}
.footer .btn-home+p{
  margin-top:0
}
