@charset "utf-8";

html{overflow:auto;}
body{
  position:relative;
  min-width:950px;
  overflow:hidden;
}
#riGlobalWrap{
  overflow:hidden;
  /* IE Bug Support */
  overflow-x:hidden;
}
/* contents[common] 
--------------------------------------------*/
/* bg */
[bg] {
  position: relative;
}
[bg]:before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  padding: 0 500%;
  margin: 0 -500%;
}

/* text_box01 */
.text_box01{
  width: 690px;
  margin: 20px auto 0;
  font-size: 14px;
  line-height: 1.35;
  text-align: center;
}
/* text_box02 */
.text_box02{
  margin: 0 0 72px;
  font-size: 18px;
  line-height: 1.8;
  text-align: center;
}
.text_box02 p + p{
  margin-top: 28px;
}
/* button02 */
.button02{
  margin: 0 auto 48px;
}
.button02 a.buttonLink{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 376px;
  height: 58px;
  margin: 0 auto;
  border-radius: 30px;
  background: #ff008c;
  color: #fff;
  font-size: 18px;
  text-align: center;
  line-height: 1;
  box-sizing: border-box;
  font-weight: bold;
  box-shadow: 0 2px 12px rgba(0,0,0,.2);
}
.button02 a.buttonLink::before{
  content: "";
  display: inline-block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 22px;
  width: 6px;
  height: 6px;
  margin: auto;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
  transform: rotate(45deg);
}
.button02 a.buttonLink:hover{
  opacity: .8;
}

.periodTxt{
  margin-top: 12px;
  text-align: center;
  font-size: 20px;
}
.periodTxt:first-of-type{
  margin-top: 28px;
}
._bold{
  font-weight: bold;
}
.hukidashi{
  position: relative;
  width: 695px;
  margin: 36px auto 44px;
  padding: 22px 0 20px;
  background-color: #ff008c;
  border-radius: 16px;
  color: #fff;
  text-align: center;
  font-size: 24px;
}
.hukidashi ._bold{
  font-size: 40px;
}
.hukidashi::after {
  position: absolute;
  left: calc(50% - 16px);
  bottom: -15px;
  display: inline-block;
  content: "";
  width: 0;
  height: 0;
  border-color: #ff008c transparent transparent;
  border-style: solid;
  border-width: 16px 16px 0;
}

.spImg_wrap{
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 810px;
  margin: 0 auto 80px;
}
.spImg_left{
  width: 334px;
}
.spImg_right{
  width: 422px;
  text-align: center;
}
.spImg_right ._txt{
  margin-bottom: 32px;
  font-size: 18px;
}

.logoImg{
  margin-bottom: 32px;
  text-align: center;
}

.rule{
  position: relative;
  padding: 60px 0 0;
}
.rule:last-of-type{
  padding-bottom: 60px;
}
.rule::before{
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  padding: 0 500%;
  margin: 0 -500%;
  background-color: #f0f0f0;
}

.rule .rc-campaignRules__contents p a{
  text-decoration: underline;
}