@charset "UTF-8";
:root {
  --color-key1: #EE6200;
  --color-key2: #b0e1ff;
  --color-key3: #ffb269;
  --color-key4: #4eace7;
  --color-white: #fff;
  --color-black: #232122;
  --color-gray: #e8e8e8;
  --color-lightGray: #f5f6f7;
  --color-red: #d80000;
}

a * {
  pointer-events: none;
}

/* layout */
.separate {
  padding: min(12.8vw, 96px) 0;
}
@media print, screen and (min-width: 751px) {
  .separate {
    padding: min(7.27vw, 80px) 0;
  }
}
.separate--bgcKey2 {
  background-color: var(--color-key2);
}
.separate--bgcGray {
  background-color: var(--color-lightGray);
}

/* font size */
.hp_fontSz14 {
  font-size: 1.08em;
}
@media print, screen and (min-width: 751px) {
  .hp_fontSz14 {
    font-size: 0.88em;
  }
}

.hp_fontSz16 {
  font-size: 1em;
}
@media print, screen and (min-width: 751px) {
  .hp_fontSz16 {
    font-size: 1em;
  }
}

.hp_fontSz18 {
  font-size: 1.15em;
}
@media print, screen and (min-width: 751px) {
  .hp_fontSz18 {
    font-size: 1.13em;
  }
}

/* margin */
.hp_mt20 {
  margin-top: min(2.66vw, 20px) !important;
}
@media print, screen and (min-width: 751px) {
  .hp_mt20 {
    margin-top: 20px !important;
  }
}

/* marker */
.hp_text-marker {
  /*background: var(--color-key3);*/
  /*background: linear-gradient(0deg, var(--color-key3) 0%, var(--color-key3) 35%, transparent 35%);*/
  background: #ddf3ff;
  background: linear-gradient(0deg, #ffff0087 0%, #ffff0087 50%, transparent 50%);
}

/* Btn */
.el_campaignBtn {
  font-size: 1.38em;
  display: grid;
  place-content: center;
}
@media print, screen and (min-width: 751px) {
  .el_campaignBtn {
    width: 54.54vw;
    max-width: 600px;
    font-size: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }
}
.el_campaignBtn--fontSz-s {
  font-size: 0.72em;
  font-weight: normal;
}
@media print, screen and (min-width: 751px) {
  .el_campaignBtn--fontSz-s {
    font-size: 0.67em;
  }
}

/* ふきだし */
.el_campaignFukidashi {
  display:flow-root;
  place-content: center;
  padding: min(2vw, 15px) min(3.33vw, 25px);
  font-weight: bold;
  background-color: var(--color-key1);
  border-radius: min(4.26vw, 32px);
  text-align: center;
  line-height: 1.3;
}
@media print, screen and (min-width: 751px) {
  .el_campaignFukidashi {
    padding: 15px 20px;
    font-size: 1.13em;
    border-radius: 24px;
  }
}
.el_campaignFukidashi--right {
  border-bottom-right-radius: 0;
}
.el_campaignFukidashi--left {
  border-bottom-left-radius: 0;
}

.el_campaignFukidashi--big > span {
    font-size: 2em;
    color: #FFFF00;
}

.el_campaignFukidashi--big {
    width: 100%;
    color: #fff;
}

.txtInd{
	padding-left: 1em;
    text-indent: -1em;
}

/* アイコン */
.el_campaignIcon {
  display: inline-block;
  width: 1.2em;
  height: 1.2em;
  transform: translateY(0.2em);
}

/* 基本フォントサイズ */
.campaign {
  font-size: clamp(0.81rem, 0rem + 3.47vw, 1.63rem);
}
@media print, screen and (min-width: 751px) {
  .campaign {
    font-size: clamp(0.81rem, 0.41rem + 0.86vw, 1rem);
  }
}

/* 終了対応
-----------------------------------*/
.campaignEnd {
  margin: min(5.3333333vw, 20px) auto;
}
@media print, screen and (min-width: 751px) {
  .campaignEnd {
    margin: min(2.5390625vw, 26px) auto;
  }
}
.campaignEnd-inner {
  padding: 0 min(4vw, 15px);
}
@media print, screen and (min-width: 751px) {
  .campaignEnd-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 min(2.27vw, 25px);
    box-sizing: content-box;
  }
}
.content .campaignEnd-inner {
  padding: 0;
}

.campaignEnd-inner p {
  font-size: 1.13em;
}
@media print, screen and (min-width: 751px) {
  .campaignEnd-inner p {
    font-size: 1.25em;
  }
}

/* Title
-----------------------------------*/
.campaignTtl {
  font-size: 2em;
  font-weight: bold;
  text-align: center;
  margin-bottom: min(8vw, 60px);
}
@media print, screen and (min-width: 751px) {
  .campaignTtl {
    font-size: 3em;
    margin-bottom: min(5.45vw, 60px);
  }
}
.campaignTtl--underline {
  position: relative;
  padding-bottom: min(6.66vw, 50px);
}
@media print, screen and (min-width: 751px) {
  .campaignTtl--underline {
    padding-bottom: min(4.54vw, 50px);
  }
}
.campaignTtl--underline::after {
  content: "";
  width: min(20.53vw, 154px);
  height: clamp(0.06rem, 0.03rem + 0.14vw, 0.13rem);
  background-color: var(--color-black);
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
@media print, screen and (min-width: 751px) {
  .campaignTtl--underline::after {
    width: min(14vw, 154px);
    height: 2px;
  }
}

/* mainVisual
-----------------------------------*/
.campaignHeader-mainvisual {
  text-align: center;
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-mainvisual {
    margin: min(2.27vw, 25px);
  }
}
.campaignHeader-mainvisual_img {
  display: block;
}
.campaignHeader-mainvisual_img > img {
  width: auto;
  max-width: 100%;
  vertical-align: bottom;
}
.campaignHeader-contents {
  margin-top: min(5.33vw, 40px);
  margin-bottom: clamp(1.75rem, 0.23rem + 6.48vw, 4.69rem);
}
.campaignHeader-label {
  display: grid;
  place-content: center;
  padding: 0.5em;
  color: var(--color-white);
  font-weight: bold;
  background: var(--color-red);
  border-radius: min(1.06vw, 8px);
  margin-left: -1.9230769231vw;
  margin-right: -1.9230769231vw;
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-label {
    font-size: 1.25em;
    margin: auto;
    border-radius: 4px;
  }
}
.campaignHeader-period {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: min(2.66vw, 20px) 0;
  margin-top: min(2.66vw, 20px);
  margin-bottom: min(8vw, 60px);
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period {
    gap: 15px 0;
    margin-top: min(2.72vw, 30px);
    margin-bottom: min(3.63vw, 40px);
  }
}
.campaignHeader-period .w-space {
  white-space: nowrap;
}
.campaignHeader-period_ttl {
  flex-basis: 30%;
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_ttl {
    flex-basis: 24.35%;
    min-height: 74px;
  }
}
.campaignHeader-period_ttl:first-of-type {
  background-color: var(--color-key1);
  color: var(--color-white);
}
.campaignHeader-period_ttl.el_campaignFukidashi {
  padding-left: min(1.33vw, 10px);
  padding-right: min(1.33vw, 10px);
  font-size: clamp(0.75rem, -0.13rem + 3.73vw, 1.63rem);
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_ttl.el_campaignFukidashi {
    font-size: 1.13em;
  }
}
.campaignHeader-period_date-wrapper {
  flex-basis: 66.66%;
  display: flex;
  letter-spacing: -0.04em;
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date-wrapper {
    flex-basis: 71.79%;
  }
}
.campaignHeader-period_date {
  display: grid;
  align-items: end;
  font-weight: bold;
  line-height: 1.1;
}
.campaignHeader-period_date:not(:first-of-type) {
  position: relative;
  margin-left: calc(1em + 10px);
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date:not(:first-of-type) {
    margin-left: calc(1.25em + 10px);
  }
}
.campaignHeader-period_date:not(:first-of-type)::before {
  content: "～";
  position: absolute;
  bottom: 0.1em;
  left: calc(-1em - 5px);
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date:not(:first-of-type)::before {
    font-size: 1.25em;
  }
}
.campaignHeader-period_date-year {
  font-size: clamp(0.69rem, 0rem + 2.93vw, 1.38rem);
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date-year {
    font-size: 1.13em;
  }
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date-md {
    font-size: 1.25em;
  }
}
.campaignHeader-period_date-md .num {
  font-size: 1.62em;
  font-weight: 900;
}
@media print, screen and (min-width: 751px) {
  .campaignHeader-period_date-md .num {
    font-size: 1.9em;
  }
}
.campaignHeader-period_date-md .num2 {
  font-size: 1.12em;
}

.btn-box {
    margin: min(5.1282051vw, 40px) auto 0;
    width: min(58.974358vw, 520px);
}

@media only screen and (max-width: 750px) {
  .btn-box {
      margin: 8vw auto 0;
      width: 86.933333vw;
  }
}

.btn-box > p:nth-of-type(n + 2) {
    margin-top: min(3.205128vw, 25px);
}

.u-mt20 {
    margin-top: 20px !important;
}

/* 賞品
-----------------------------------*/
.campaignPrize {
  overflow: hidden;
  padding-bottom: min(12.8vw, 96px);
  border-radius: min(4vw, 30px);
  background-color: var(--color-white);
  box-shadow: 0 5px 16px 0 rgba(0, 0, 0, 0.09);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize {
    padding-bottom: min(7.27vw, 80px);
    border-radius: 30px;
  }
}
.campaignPrize + .campaignPrize {
  margin-top: 7.6923076923vw;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize + .campaignPrize {
    margin-top: min(3.90625vw, 40px);
  }
}
.campaignPrize-ttl {
  color: var(--color-white);
  background-color: var(--color-key1);
  border-bottom: clamp(0.25rem, 0rem + 1.07vw, 0.5rem) solid var(--color-key3);
  text-align: center;
  padding: min(1.86vw, 14px);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-ttl {
    padding: 10px;
    border-bottom-width: 8px;
  }
}
.campaignPrize-ttl .lsS {
  letter-spacing: 0.2em !important;
}
.campaignPrize-ttl .lsM {
  letter-spacing: 0.6em !important;
}
.campaignPrize-ttl .lsL {
  letter-spacing: 1.2em !important;
}
.campaignPrize-ttl > span {
  display: inline-block;
  font-size: 1.85em;
  font-weight: bold;
  letter-spacing: 0.6em;
  transform: translateX(0.3em); /* ← letter-spacingのズレを修正 */
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-ttl > span {
    font-size: 2.25em;
  }
}
.campaignPrize-contents {
  max-width: 860px;
  margin: 0 auto;
  padding: min(12vw, 90px) min(5.33vw, 40px) 0;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-contents {
    padding-top: min(3.63vw, 40px);
  }
}
.campaignPrize-fukidashi {
  margin-top: 0;
  margin-bottom: min(4vw, 30px);
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 1em;
  text-align: center;
  font-size: 1.23em;
  font-weight: bold;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-fukidashi {
    margin-bottom: min(1.81vw, 20px);
    font-size: 1.5em;
    gap: 1.4em;
  }
}
.campaignPrize-fukidashi > span {
  display: inline-block;
  padding-bottom: 0.4em;
}
.campaignPrize-fukidashi::before, .campaignPrize-fukidashi::after {
  content: "";
  width: min(0.53vw, 4px);
  height: 2.66em;
  background-color: var(--color-black);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-fukidashi::before, .campaignPrize-fukidashi::after {
    width: 3px;
    height: 3.54em;
  }
}
.campaignPrize-fukidashi::before {
  transform: rotate(-25deg);
}
.campaignPrize-fukidashi::after {
  transform: rotate(25deg);
}
.campaignPrize-item {
  padding: min(7.33vw, 55px) min(6.66vw, 50px);
  border: min(0.8vw, 6px) solid var(--color-gray);
  border-radius: min(2.66vw, 20px);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item {
    padding: min(2.72vw, 30px) min(6.36vw, 70px);
    border-width: 3px;
    border-radius: 20px;
  }
}
.campaignPrize-item + .campaignPrize-item {
  margin-top: min(5.33vw, 40px);
}
.campaignPrize-item_ttl {
  margin-bottom: min(8vw, 60px);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_ttl {
    margin-bottom: min(3.27vw, 36px);
  }
}
.campaignPrize-item_ttl > span {
  display: inline-block;
  padding: 0.3em 1em;
  color: var(--color-white);
  font-size: 1.15em;
  font-weight: bold;
  background-color: var(--color-black);
  border-radius: 50vw;
  border-bottom-left-radius: 0;
  box-shadow: 0.19em 0.19em 0px 0px var(--color-key3);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_ttl > span {
    font-size: 1.88em;
  }
}
.campaignPrize-item_img {
  margin: min(2.66vw, 20px) auto;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_img {
    margin: min(1.81vw, 20px) auto;
  }
}
.campaignPrize-item_img > img {
  display: block;
  margin: 0 auto;
  width: 100%;
  max-width: 90%;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_img > img {
    max-width: 440px;
  }
}
.campaignPrize-item_lead {
  font-size: 1.38em;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_lead {
    font-size: 2.25em;
  }
}
.campaignPrize-item_lead .num {
  font-size: 1.56em;
}
.campaignPrize-item_lead .point {
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-size: 1.94em;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0.06em 0.06em 0px var(--color-key3);
  padding-right: 0.2em;
}
.campaignPrize-item_line {
  border: none;
  border-top: clamp(0.06rem, 0rem + 0.27vw, 0.13rem) solid var(--color-gray);
  margin: min(5.33vw, 40px) auto;
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-item_line {
    border-top-width: 1px;
    margin: 30px auto;
  }
}
.campaignPrize .compartment {
  margin-top: min(3.46vw, 26px);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize .compartment {
    margin-top: min(3.63vw, 40px);
  }
}
/* エントリー方法
-----------------------------------*/
.campaignEntry-lead {
  text-align: left;
}
@media print, screen and (min-width: 751px) {
  .campaignEntry-lead {
    text-align: center;
  }
}
.campaignEntry-link {
  display: flex;
  justify-content: center;
  gap: 0.6em 1.4em;
  flex-wrap: wrap;
}
@media print, screen and (min-width: 751px) {
  .campaignEntry-link {
    font-size: 0.88em;
  }
}

/* 注意事項
-----------------------------------*/
@media print, screen and (min-width: 751px) {
  .campaignNotes {
    font-size: 1em;
  }
}

/* 下部バナーエリア
-----------------------------------*/
.campaignBnr {
	margin: 30px auto;
	padding: 0 3.8461538462vw;
    box-sizing: content-box;
	max-width: 860px;
}
.campaignBnr .campaignBn_ttl{
	font-size: 1.25em;
    margin: 60px auto 20px;
    border-radius: 4px;
	display: grid;
    place-content: center;
    padding: 0.5em;
    color: var(--color-white);
    font-weight: bold;
    background: #1644ab;
}
.campaignBnr picture img{
	max-width: 100%;
}
.vcapp a{
	display:inline-block;
}
.vcapp a,
.vcapp a img{width:100%;
margin-top: 10px}

@media print, screen and (min-width: 751px) {
  .campaignBnr {
    margin-top: 60px;
  }
  .campaignBnr p{
	width: 100%;
  margin-top: 20px;
  }
}


/* campaignFooter
-----------------------------------*/
.campaignFooter {
  padding: min(13.33vw, 100px) 0 min(12vw, 90px);
}
@media print, screen and (min-width: 751px) {
  .campaignFooter {
    padding: min(5.45vw, 60px) 0 min(9.09vw, 100px);
    border-bottom: 1px solid var(--color-gray);
  }
}/*# sourceMappingURL=style.css.map */


/* add */
.discList.counterList {
  counter-reset:cp_clist;
  list-style-type: none;
}

.discList.counterList li {
  padding-left: 6.589744vw;
}

@media print, screen and (min-width: 751px) {
  .discList.counterList li {
    padding-left: min(3.367188vw, 26px);
  }
}

.discList.counterList li::before {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  counter-increment: cp_clist;
  content: counter(cp_clist);
  background: var(--color-key1);
  color: var(--color-white);
  font-weight: 600;
  width: 5.051282vw;
  height: 5.051282vw;
  border-radius: 50vh;
  top: 3px;
}

@media print, screen and (min-width: 751px) {
  .discList.counterList li::before {
    width: min(2.367188vw, 20px);
    height: min(2.367188vw, 20px);
  }
}

.campaignPrize-fukidashi {
margin-top: min(6.46vw, 30px);
}

@media print, screen and (min-width: 751px) {
  .campaignPrize-fukidashi {
      margin-top: min(3.63vw, 40px);
      margin-bottom: min(1.81vw, 20px);
      font-size: 2em;
      gap: 1.4em;
  }
}

.campaignPrize-fukidashi.a-center {
  align-items: center;
}

.campaignPrize-fukidashi.vsstitle {
  display: inline-block;
  position: relative;
  padding: 0 min(3.367188vw, 46px);
}

@media print, screen and (max-width: 750px) {
.campaignPrize-fukidashi.vsstitle {
  margin-top: 0;
  font-size: 1.85em;
  padding: 0 6vw;
}
}

.campaignPrize-fukidashi.vsstitle::before,
.campaignPrize-fukidashi.vsstitle::after {
  position: absolute;
  top: 50%;
}

.campaignPrize-fukidashi.vsstitle::before {
  transform: translateY(-50%) rotate(-25deg);
  left: 0;
}

.campaignPrize-fukidashi.vsstitle::after {
  transform: translateY(-50%) rotate(25deg);
  right: 0;
}

.campaignPrize-fukidashi > span {
  padding-bottom: 0;
  padding: 0 0.2em;
  display: inline;
  background: linear-gradient(0deg, var(--color-key2) 0%, var(--color-key2) 50%, transparent 50%);
}

@media print, screen and (min-width: 751px) {
.campaignPrize-fukidashi > span {
}
}

@media print, screen and (min-width: 751px) {
  .campaignPrize-fukidashi::before, .campaignPrize-fukidashi::after {
      width: 3px;
      height: 2.54em;
  }
}

@media print, screen and (min-width: 751px) {
.vss-step + .compartment {
  margin-top: min(1.63vw, 20px);
}
}

.vss-step__ttl {
  font-size: 1em;
  background: var(--color-key2);
  color: var(--color-black);
  text-align: center;
  margin-top: min(6.46vw, 30px);
  border-radius: min(4.26vw, 32px);
    padding: min(2vw, 15px) min(3.33vw, 25px);
    border-bottom-left-radius: 0;
}

@media print, screen and (min-width: 751px) {
  .vss-step__ttl {
    padding: 15px 20px;
    margin-top: min(3.63vw, 40px);
    border-radius: 24px;
    font-size: 1.13em;
    border-bottom-left-radius: 0;
  }
}

.vss-step__ttl__top {
  font-size: 1.15em;
}

@media print, screen and (min-width: 751px) {
  .vss-step__ttl__top {
    font-size: 1.4em;
  }
}

.vss-step__ttl__step {
  color: var(--color-red);
  font-size: 1.4em;
}

.vss-stepList {
  display: flex;
  flex-direction: column;
  max-width: 860px;
  gap: 20px;
  padding-top: 10px;
  margin-top: min(6.46vw, 30px);
}

@media print, screen and (min-width: 751px) {
  .vss-stepList {
    margin-top: min(3.63vw, 40px);
    flex-direction: row;
  }
}

.vss-stepList_item {
  position: relative;
  width: 100%;
  padding: min(7.33vw, 55px) min(6.66vw, 50px);
  border: min(0.8vw, 6px) solid var(--color-gray);
  border-radius: min(2.66vw, 20px);
  display: flex;
        flex-direction: column;
}

@media print, screen and (min-width: 751px) {
  .vss-stepList_item {
    width: calc(100% / 3 - 13px);
    padding: min(1.72vw, 20px) min(2.36vw, 25px);
    border-width: 3px;
    border-radius: 20px;
  }
}

.vss_num {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  counter-increment: cp_clist;
  content: counter(cp_clist);
  background: var(--color-key4);
  color: var(--color-white);
  font-weight: 600;
  width: 9vw;
  height: 9vw;
  font-size: 1.4em;
  border-radius: 50vh;
  top: -10px;
  left: -10px;
}

@media print, screen and (min-width: 751px) {
.vss_num {
width: 35px;
  height: 35px;
}
}

.vss_inner {
  display: flex;
      flex-direction: column;
      flex-grow: 1;
}

.vss_inner img {
  width: 60%;
  margin: auto;
}

@media print, screen and (min-width: 751px) {
  .vss_inner img {
    width: 100%;
  }
}

.vss_text {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  justify-content: center;
    text-align: center;
    align-items: center;
    font-size: 1.15em;
    font-weight: 600;
}

@media print, screen and (min-width: 751px) {
  .vss_text {
    font-size: 1em;
  }
}

.guideBnr {
  margin: 30px auto 0;
  padding: 0;
  box-sizing: content-box;
  max-width: 860px;
}

.guideBnr a, .guideBnr a img {
  width: 100%;
  display: block;
}

.vcappBnr {
  max-width: 600px;
  padding: 0 3.8461538462vw;
  margin: 30px auto 0;
  text-align: center;
}

@media print, screen and (min-width: 751px) {
  .vcappBnr {
    padding: 0;
  }
}

.vcappBnr a, .vcappBnr a img {
  width: 100%;
  display: block;
  margin-bottom: 10px;
}