@charset "utf-8";
/* CSS Document */

html::-webkit-scrollbar{
  display: none;
  overflow: scroll;
  -ms-overflow-style: none;
}

body{
  width: 100%;
  margin: 0 auto;
  overflow-x: hidden;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

#root, #__next {
  isolation: isolate;
}


:root{
  --fontsize__x-small: 12px;
  --fontsize__small: 14px;
  --fontsize__normal: 16px;
  --fontsize__large: 18px;
  --fontsize__X-large: 20px;
  --fontsize__XX-large: 24px;
  --fontsize__title: 32px;
}




@media screen and (min-width:320px) { 
  :root{
    --fontsize__x-small: 12px;
    --fontsize__small: 12px;
    --fontsize__normal: 14px;
    --fontsize__large: 16px;
    --fontsize__X-large: 16px;
    --fontsize__XX-large: 14px;
    --fontsize__title: 16px;
  }
  .pc{ display: none; }
  .sp{ display: block; }
}
@media screen and (min-width:375px) { 
  :root{
    
    --fontsize__x-small: 12px;
    --fontsize__small: 12px;
    --fontsize__normal: 14px;
    --fontsize__large: 18px;
    --fontsize__X-large: 20px;
    --fontsize__XX-large: 16px;
    --fontsize__title: 20px;
  }
  .pc{ display: none; }
  .sp{ display: block; }
}
@media screen and (min-width:768px) { 
  :root{
    --fontsize__x-small: 12px;
    --fontsize__small: 14px;
    --fontsize__normal: 16px;
    --fontsize__large: 18px;
    --fontsize__X-large: 20px;
    --fontsize__XX-large: 24px;
    --fontsize__title: 32px;
  }
  .pc{ display: block; }
  .sp{ display: none; }
}
@media screen and (min-width:900px) { 

}




.main{
  width: 100vw;
}
.mainInner{
  max-width: 960px;
  margin: 0 auto;
  padding-bottom: 48px;
}
.stripe--bg{
  background-image: repeating-linear-gradient(-45deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0.15) 40px,transparent 0, transparent 80px);
}
.star--bg{
  background-image: url(../images/bg_star.png);
  background-repeat: none;
  background-size: 100%;
}


@media screen and (min-width:320px) { 
  .mainInner{
    padding: 0px 0px 24px 0px;
  }
  .gradation--bg{
    background-image: linear-gradient(254deg, rgba(255, 132, 243, 1), rgba(252, 255, 129, 1) 35%, rgba(129, 255, 255, 1) 65%, rgba(255, 132, 243, 1));
  }
}
@media screen and (min-width:375px) { 
  .mainInner{
    padding: 0px 0px 24px 0px;
  }
  .gradation--bg{
    background-image: linear-gradient(254deg, rgba(255, 132, 243, 1), rgba(252, 255, 129, 1) 35%, rgba(129, 255, 255, 1) 65%, rgba(255, 132, 243, 1));
  }
}
@media screen and (min-width:768px) { 
  .mainInner{
    padding: 0px 24px 48px 24px;
  }
  .gradation--bg{
    background-image: linear-gradient(235deg, rgba(255, 132, 243, 1), rgba(252, 255, 129, 1) 35%, rgba(129, 255, 255, 1) 65%, rgba(255, 132, 243, 1));
  }
}
@media screen and (min-width:900px) { 
  .mainInner{
    padding: 0px 40px 48px 40px;
  }
}








/* =========
キャッチ
=========*/

@media screen and (min-width:320px) { 
  .catch{
    width: calc( 303 / 375 * 100%);
    margin: 24px auto;
  }
}
@media screen and (min-width:375px) { 
  .catch{
    width: calc( 303 / 375 * 100%);
    margin: 24px auto;
  }
}
@media screen and (min-width:768px) { 
  .catch{
    width: 100%;
    max-width: 490px;
    margin: 48px auto;
  }
}

/* =========
PRESENT 共通
=========*/

.presentWrap{
  margin-top: 48px;
}

.presentInner{
  background-color: #FFF;
  border-radius: 0 0 20px 20px;
  padding-bottom: 40px;
}

.present__title{
  margin: 0 24px;
  padding-top: 24px;
}




.conditions{
  margin: 40px 24px 0 24px;
}

.conditions__content{
  margin-top: 24px;
}

.conditions__headlineWrap{
  position: relative;
}
.conditions__headline{
  border-radius: 500px;
  border: 1px solid #323232;
  padding: 0 50px;
  font-size: var(--fontsize__X-large);
  font-weight: 600;
  display: block;
  margin: 0 auto;
  width: 200px;
  text-align: center;
  z-index: 20;
  background-color: #FFF;
  position: relative;
}
.conditions__decoration {
  position: absolute;
  width: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  z-index: 1;
}




.conditions__title{
  font-size: var(--fontsize__large);
  font-weight: 600;
  position:relative;
  display:inline-block;
  padding-left: 14px;
}
.conditions__title--01::after{
  content:"";
  display:inline-block;
  width:9px;
  border-radius: 100px;
  height:24px;
  background-color: #99D1F2;
  position:absolute;
  top:6px;
  left:-5px;
}
.conditions__title--02::after{
  content:"";
  display:inline-block;
  width:9px;
  border-radius: 100px;
  height:24px;
  background-color: #FF82CD;
  position:absolute;
  top:6px;
  left:-5px;
}
.conditions__title--03::after{
  content:"";
  display:inline-block;
  width:9px;
  border-radius: 100px;
  height:24px;
  background-color: #EFDC31;
  position:absolute;
  top:6px;
  left:-5px;
}


.conditions__notes{
  font-size: var(--fontsize__normal);
  white-space: pre-line;
}
.conditions__notesLink{
  font-size: var(--fontsize__normal);
  text-decoration: underline;
  color: #0048FF;
}
.conditions__notesEmphasis{
  font-size: var(--fontsize__normal);
  color: #E71F0A;
}
.present__title--sp{
  margin: 0 auto;
}
@media screen and (min-width:320px) { 
  .presentWrap{
    margin-top: 24px;
  }
  .present__subjectTag{
    width: 100%;
    max-width: 206px;
    margin: 16px auto 0;
  }
  .present__smprTag{
    width: 100%;
    max-width: 300px;
    margin: 16px auto 0;
  }
}
@media screen and (min-width:375px) { 
  .presentWrap{
    margin-top: 24px;
  }
  .present__subjectTag{
    width: 100%;
    max-width: 206px;
    margin: 16px auto 0;
  }
  .present__smprTag{
    width: 100%;
    max-width: 300px;
    margin: 16px auto 0;
  }
}
@media screen and (min-width:768px) { 
  .present__smprTag{
    max-width: 484px;
  }
  .present__subjectTag{
    max-width: 336px;
  }
}
@media screen and (min-width:900px) { 

}



/* =========
PRESENT01
=========*/

.present__infoDescription{
  background-color: #FFF59E;
  padding: 16px 16px;
  width: 100%;
  max-width: 780px;
  border-radius: 10px;
  margin: 24px auto 0;
}
.present__infoTitle{
  white-space: pre-line;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
}
.present__titleNotes{
  display: inline;
  font-size: 18px;
}
.present__infoNotes{
  text-align: center;
  font-size: 18px;
}



.doubleChance__title{
  width: 100%;
  max-width: 500px;
}
.doubleChance__content{
  margin: 0 24px;
}
.doubleChance__gift{
  width: 100%;
  max-width: 380px;
  margin: 0 8px;
}

@media screen and (min-width:320px) { 
  .present__infoDescription{
    padding: 16px 8px;
  }
  .present__info, .present__gift{
    margin: 8px auto 0;
    padding: 0 8px;
  }
  .doubleChance{
    margin: 26px auto 0;
  }
  .doubleChance__title{
    width: calc(288 / 375 * 100%);
    margin: 0 auto;
  }
  .doubleChance__content{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .doubleChance__gift {
    margin: 20px 0 0 0;
  }
  .present__infoTitle{
    white-space: pre-line;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
  }
  .present__titleNotes{
    display: inline-block;
    font-size: 10px;
  }
  .present__infoNotes{
    text-align: center;
    font-size: 10px;
  }
}


@media screen and (min-width:375px) { 
  .present__infoDescription{
    padding: 16px 8px;
  }
  .present__info, .present__gift{
    margin: 8px auto 0;
    padding: 0 8px;
  }
  .doubleChance{
    margin: 26px auto 0;
  }
  .doubleChance__title{
    width: calc(288 / 375 * 100%);
    margin: 0 auto;
  }
  .doubleChance__content{
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .doubleChance__gift {
    margin: 20px 0 0 0;
  }
  .present__infoTitle{
    white-space: pre-line;
    text-align: center;
    font-size: 16px;
    font-weight: 600;
  }
  .present__titleNotes{
    display: inline-block;
    font-size: 10px;
  }
  .present__infoNotes{
    text-align: center;
    font-size: 10px;
  }
}
@media screen and (min-width:768px) { 
  .present__infoDescription{
    padding: 16px 16px;
  }
  .present__info, .present__gift{
    margin: 24px auto 0 auto;
    padding: 0 24px;
  }
  .doubleChance__content{
    display: flex;
    align-items: flex-start;
    justify-content: space-evenly;
    flex-direction: row;
  }
  .present__infoTitle{
    font-size: 18px;
  }
  .present__titleNotes{
    display: inline;
    font-size: 18px;
  }
  .present__infoNotes{
    font-size: 18px;
  }
  .doubleChance{
    margin: 46px auto 0;
  }
}
@media screen and (min-width:900px) { 

}






/* =========
PRESENT02
=========*/
.present__giftNotes{
  text-align: right;
}
@media screen and (min-width:320px) { 
  .present__giftNotes{
    white-space: pre-line;
    text-align: left;
  }
}
@media screen and (min-width:375px) { 
  .present__giftNotes{
    white-space: pre-line;
    text-align: left;
  }
}
@media screen and (min-width:768px) { 
  .present__giftNotes{
    white-space: normal;
    text-align: right;
  }
}
@media screen and (min-width:900px) { 

}





/* =========
エントリー
=========*/

.entry{
  margin: 48px 0;
  padding: 0 40px;
}
.entryInner{
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
}




.step:first-child:before{
  display: none;
}


.stepInner{
  box-shadow: 0px 1px 10px -2px rgba(0,0,0,0.8);
}

.smprTag{
  width: 100%;
  max-width: 768px;
  margin: 0 auto;
}

.smpr__catch{
  margin-top: 40px;
  text-align: center;
}
.smpr__catchText{
  font-size: var(--fontsize__title);
  font-weight: 600;
  background:linear-gradient(transparent 60%, #ff6 60%);
  display: inline-block;
}

.smpr__detail{
  margin-top: 8px;
  text-align: center;
  font-size: var(--fontsize__small);
  font-weight: 600;
}
.smpr__detailLink{
  font-size: var(--fontsize__X-large);
  color: #E71F0A;
  text-align: center;
  position: relative;
}
.smpr__detailLink::after{
  content: '';
  width: 8px;
  height: 8px;
  margin-top: -5px;
  border-top: solid 1px #E71F0A;
  border-right: solid 1px #E71F0A;  
  transform: rotate(45deg);
  position: absolute;
  top: 60%;
  right: -20px;
}
.smpr__merit{
  margin-top: 32px;
  width: 100%;
  max-width: 466px;
  margin: 32px auto 0 auto;
}
.spmr__btnWrap{
  width: 100%;
  max-width: 540px;
  margin: 24px auto 0 auto;
}
.spmr__notes{
  margin-top: 16px;
}
.spmr__notesText{
  white-space: pre-line;
  font-size: var(--fontsize__normal);
}

.step__menuCatch{
  font-size: var(--fontsize__XX-large);
  text-align: center;
  font-weight: 600;
  white-space: pre-line;
}
.step__text{
  font-size: var(--fontsize__normal);
  white-space: pre-line;
  margin-top: 16px;
}
.step__notesText{
  color: #E71F0A;
  font-size: var(--fontsize__normal);
}

.menuBenefit{
  max-width: 634px;
  margin: 0 auto;
}

.alignmentBtn{
  max-width: 480px;
  margin: 24px auto 0 auto;
}

.entryDeadline{
  background-color: #0A86CC;
  padding: 18px;
}
.entryDeadline__text{
  font-weight: 600;
  font-size: var(--fontsize__XX-large);
  color: #FFF;
  text-align: center;
}
.step__deadline{
  margin-top: 32px;
}




@media screen and (min-width:320px) { 
  .stepInner{
    padding: 24px 8px;
  }
  .step{
    position: relative;
    margin-top: 58px;
  }
  .step::before{
    content: "";
    position: absolute;
    top: -30px;
    border: 25px solid transparent;
    border-top: 26px solid #000;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
}
@media screen and (min-width:375px) { 
  .stepInner{
    padding: 24px 8px;
  }
  .step{
    position: relative;
    margin-top: 58px;
  }
  .step::before{
    content: "";
    position: absolute;
    top: -30px;
    border: 25px solid transparent;
    border-top: 26px solid #000;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
}
@media screen and (min-width:768px) { 
  .stepInner{
    padding: 40px 38px;
  }
  .step{
    position: relative;
    margin-top: 90px;
  }
  .step::before{
    content: "";
    position: absolute;
    top: -50px;
    border: 45px solid transparent;
    border-top: 28px solid #000;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  }
}




















.entry__headlineWrap{
  padding: 27px 0;
}
.entry__headline{
  color: #FFF;
  font-size: var(--fontsize__title);
  font-weight: 600;
  text-align: center;
}
.entry__title{
  margin-top: 33px;
  padding: 0 24px;
}
.entry__comeingsoon{
  width: 100%;
  max-width: 480px;
  margin: 24px auto 0;
  padding: 0 24px;
}
@media screen and (min-width:320px) { 
  .entry{
    padding: 0 16px;
  }
  .entry__headlineWrap{
    padding: 8px 0;
  }
}
@media screen and (min-width:375px) { 
  .entry{
    padding: 0 16px;
  }
  .entry__headlineWrap{
    padding: 8px 0;
  }
}
@media screen and (min-width:768px) { 
  .entry{
    padding: 0 24px;
  }
}
@media screen and (min-width:900px) { 
  .entry{
    padding: 0 40px;
  }
}






/* =========
注意事項
=========*/

.attention{
  max-width: 880px;
  margin: 40px auto 0;
  padding: 0 40px;
}
.attention__titleWrap{
  background-color: #E71F0A;
  padding: 18px 0px;
  text-align: center;
}
.attention__title{
  font-size: var(--fontsize__title);
  color: #fff;
}

/* アコーディオン */
.accordion-container {
  position: relative;
  width: 100%;
  border-top: none;
  outline: 0;
  cursor: pointer
}

.accordion-container .accordion-title {
  display: block;
  position: relative;
  margin: 0;
  padding: 24px 0;
  font-size: var(--fontsize__XX-large);
  font-weight: 500;
  color: #E71F0A;
  cursor: pointer;
  border-bottom: 1px solid #E71F0A;
}

.accordion-container .accordion-title:active,
.accordion-container .content-entry.open .accordion-title {
  color: #E71F0A;
}

.accordion-container i:active,
.accordion-container .content-entry.open i {
  color: #E71F0A;
}

.accordion-title{
  position: relative;
}

.accordion-title:after {
  content: "";
  position: absolute;
  right: 25px;
  top: 42%;
  transition: all 0.2s ease-in-out;
  display: block;
  width: 10px;
  height: 10px;
  border-top: solid 2px #E71F0A;
  border-right: solid 2px #E71F0A;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}

.accordion-title.open:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  top: 45%;
}

.accordion-content {
  display: none;
  padding-bottom: 40px;
  border-bottom: #E71F0A 1px solid;
}

/* CSS for CodePen */
.accordion-container {
  margin: 0 auto;
}


.attention__notesWrap{
  margin-top: 32px;
}

.attention__notesTitle{
  font-size: var(--fontsize__normal);
}
.attention__notestext{
  white-space: pre-line;
  font-size: var(--fontsize__small);
}
.attention__notesLink{
  font-size: var(--fontsize__small);
  color: #0048FF;
  text-decoration: underline;
}


@media screen and (min-width:320px) { 
  .attention{
    max-width: 100%;
    margin: 40px auto 0;
    padding: 0px;
  }
  .attention__titleWrap{
    padding: 10px 0px;
  }
}
@media screen and (min-width:375px) { 
  .attention{
    max-width: 100%;
    margin: 40px auto 0;
    padding: 0px;
  }
  .attention__titleWrap{
    padding: 10px 0px;
  }
}
@media screen and (min-width:768px) { 
  .attention{
    max-width: 100%;
    margin: 40px auto 0;
    padding: 0px;
  }
}
@media screen and (min-width:900px) { 
  .attention{
    max-width: 880px;
    margin: 40px auto 0;
    padding: 0 40px;
  }
}







/* =========
menuダウンロード
=========*/

.menuDownload__inner{
  position: relative;
  margin-top: 45px;
}

.menuDownload__btn{
  width: 100%;
  max-width: 460px;
  margin: 0 auto;
}
.menuDownload__qr{
  width: 100%;
  max-width: 90px;
  position: absolute;
  top: 50%;
  right: 0%;
  transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
}







@media screen and (max-width:768px) { 
  .menuDownload__qr{
    display: none;
  }
  .menuDownload__inner{
    margin-top: 20px;
  }
}













/* =========
応募フロー
=========*/
.flow{
  background: #FFF;
  background-image: url(../images/flow/bg_menuIcon.png);
  background-repeat: repeat;
}

.flowInner{
  padding: 40px 0;
}


.flowTitle{
  background-image: url(../images/bg_flowTitle.png);
  background-repeat: repeat-x;
  width: 100vw;
  background-size: contain;
}
.flowTitle__inner{
  padding: 22px 0;
  max-width: 602px;
  margin: 0 auto;
}








/* =========
シェア
=========*/

.shareInner{
  max-width: 780px;
  margin: 0 auto;
  padding: 0;
}


.shareCatch{
  font-size: var(--fontsize__title);
  text-align: center;
  font-weight: 600;
}


.shareBtn__wrap{
  display: flex;
  justify-content: center;
  margin-top: 28px;
}

.menuLogo{
  margin: 43px auto 0 auto;
  max-width: 300px;
}

.menuDescription{
  margin-top: 24px;
}
.menuDescription__text{
  font-size: var(--fontsize__normal);
  text-align: center;
  white-space: pre-line;
}

@media screen and (min-width:320px) { 
  .shareBtn{
    max-width: 60px;
    margin: 0 10px;
  }
  .menuLogo{
    max-width: 240px;
  }
  .share{
    background-color: #F2F2F4;
    padding: 40px 16px;
  }
}
@media screen and (min-width:375px) { 
  .shareBtn{
    max-width: 60px;
    margin: 0 10px;
  }
  .menuLogo{
    max-width: 240px;
  }
  .share{
    background-color: #F2F2F4;
    padding: 40px 16px;
  }
}
@media screen and (min-width:768px) { 
  .shareBtn{
    max-width: 77px;
  }
  .share{
    padding: 40px 24px;
  }
}
@media screen and (min-width:900px) { 
  .share{
    padding: 40px 40px;
  }
}





/* =========
追尾　　
=========*/

.sticky{
  position: relative;
  height: 100%;
}

.tracking{
  height: 100%;
}
.trackingInner{
  justify-content: center;
  display: flex;
  background-image: linear-gradient(179deg, rgba(10, 134, 204, 1), rgba(88, 199, 255, 1));
  width: 100%;
  position: -webkit-sticky;
  position: sticky;
  bottom: 0;
  z-index: 9999;
}

@media screen and (min-width:320px) { 
  .tracking{
    background-image: linear-gradient(179deg, rgba(10, 134, 204, 1), rgba(88, 199, 255, 1));
    width: 100vw;
    padding: 10px 0 15px 0;
    position: -webkit-sticky;
    position: sticky;
    bottom: 0;
    z-index: 9999;
  }
  .spmr__trackingBtn, .entry__trackingBtn{
    width: 100%;
    max-width: 420px;
    margin: 0 5px;
  }
}
@media screen and (min-width:375px) { 
  .tracking{
    background-image: linear-gradient(179deg, rgba(10, 134, 204, 1), rgba(88, 199, 255, 1));
    width: 100vw;
    padding: 10px 5px 15px;
    position: -webkit-sticky;
    position: sticky;
    bottom: 0;
    z-index: 9999;
  }
  .spmr__trackingBtn, .entry__trackingBtn{
    width: 100%;
    max-width: 420px;
    margin: 0 5px;
  }
}
@media screen and (min-width:768px) { 
  .tracking{
    padding: 10px 20px;
  }
  .spmr__trackingBtn, .entry__trackingBtn{
    margin: 0 10px;
    max-width: 350px;
  }
}










/* =========
footer　　
=========*/

.footer{
  background-color: #000;
  padding: 11px 20px;
}
.copylight{
  color: #FFF;
  font-size: var(--fontsize__x-small);
  text-align: center;
}
@media screen and (min-width:320px) { 
  .copylight{
    white-space: pre-line;
  }
}
@media screen and (min-width:375px) { 
  .copylight{
    white-space: pre-line;
  }
}
@media screen and (min-width:768px) { 
  .copylight{
    white-space: normal;
  }
}





