@charset "UTF-8";
:root {
  --color-key1: #b3e565;
  --color-key2: #b3e565;
  --color-key3: #dbeaf1;
  --color-white: #fff;
  --color-black: #232122;
  --color-gray: #e8e8e8;
  --color-lightGray: #f5f6f7;
  --color-red: #d80000;
  --color-green: #1d78c3;
}

/* layout */
.separate {
  padding: min(12.8vw, 96px) 0;
}
@media print, screen and (min-width: 751px) {
  .separate {
    padding: min(7.27vw, 80px) 0;
  }
}
.separate--bgcKey3 {
  background-color: var(--color-key3);
}
.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;
  }
}


@media print, screen and (min-width: 980px) {
    .u-spItem2 {
        display: none !important;
    }
}

.center{
	text-align: center;
}

/* 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-key1);
  background: linear-gradient(0deg, var(--color-key1) 0%, var(--color-key1) 35%, transparent 35%);
}

/* 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: inline-grid;
  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_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);
  }
}

/* 行間 */
.lsS {
    letter-spacing: 0.2em !important;
}
.lsM {
    letter-spacing: 0.6em !important;
}
.lsL {
    letter-spacing: 1.2em !important;
}

/* 改行なし */
.nowrap {
    white-space: nowrap;
}

/* 終了対応
-----------------------------------*/
.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-green);
  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_ttl {
  flex-basis: 30.43%;
}
@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-key2);
}
.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 .num02 {
  font-size: 1.4rem;
  font-weight: 900;
  margin-right: 5px;
}

/* 賞品
-----------------------------------*/
.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-green);
  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 > 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: min(9.33vw, 70px);
  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-top: min(4.54vw, 50px);
    margin-bottom: min(1.81vw, 20px);
    font-size: 2em;
    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-green);
}
@media print, screen and (min-width: 751px) {
  .campaignPrize-fukidashi::before, .campaignPrize-fukidashi::after {
    width: 3px;
    height: 2em;
  }
}
.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(5.45vw, 60px);
    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-green);
  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: left;
}
.campaignPrize-item_lead02 {
  font-size: 1em;
  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_lead02 {
    font-size: 1.6em;
  }
}
.campaignPrize-item_lead .num {
  font-size: 1.56em;
}
.campaignPrize-item_lead02 .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_lead02 .point {
  font-family: "Montserrat", Helvetica, Arial, sans-serif;
  font-size: 1.6em;
  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;
  }
  .campaignPrize-itemNotes {
    font-size: 1em;
    color: #222;
  }
  .campaignPrize-item02Notes {
    color: #222;
  }
}

/* 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 */



/*さらにVIEWプラスでもっとおトクに！*/
@media screen and (max-width: 640px){
	.prarea img {
		width: 100%;
	}

	.prarea img.auto {
		width: auto;
	}
	.regularRange {
		margin: 0;
		padding: 3%;
		width: 100%;
	}
}
.prarea {
    margin-top: 50px;
}

	/*画像スクロール*/
	.scrolImg {
		overflow: auto;
	}
	.scrolImg img {
		width: 80%;
		padding-bottom: 10px;
	}
@media screen and (max-width: 640px){
	.scrolImg img {
		width: 500px;
		padding-bottom: 10px;
	}
}
#viewPlus .cp-color {
	background-color: #0086cd;
	border-bottom: none;
	color: #ffffff;
}
#viewPlus h3 {
	text-align: center;
	font-weight: bold;
	font-size: 160%;
	background-color: #ffec00;
	padding: 15px;
	border-radius: 50px;
	margin: 50px 0;
}
#viewPlus h4 {
	text-align: center;
	font-weight: bold;
	font-size: 160%;
	margin: 50px 0 20px;
}
#viewPlus .txt {
	text-align: center;
	margin-top: 30px;
	font-size: 110%;
}
.cp-category .cp-color {
	padding: 10px;
	text-align: center;
	font-weight: bold;
	/*font-size: 115%;*/
}
/* タブレット */
@media screen and (min-width: 641px) and (max-width: 949px) {
	.tabletImg img {
		width:100% !important;
	}
}
/* えきねっと ポイント付与の条件・注意点 */
.ekinet-caution {
	margin-top: 70px;
	border:solid 1px #000;
	border-radius: 50px;
	padding: 0 50px 45px;
}
@media screen and (max-width: 640px){
.ekinet-caution {
	padding: 0 5% 10%;
}
}
/* えきねっと導線 */
.ekinet-link {
	margin: 40px auto 0;
	width: 100%;
}
.ekinet-link .link-inner {
	display: flex;
	justify-content: center;
}
.ekinet-link .link-list {
	width: 370px;
}
.ekinet-link .link-txt {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 15px;
	height: 50px;
	text-align: center;
	letter-spacing: 0.17em;
	font-size: 1rem;/*16px*/
	font-weight: bold;
	white-space: nowrap;
}
.ekinet-link .link-box {
	box-sizing: border-box;
	margin: 0 auto;
	border-radius: 36px;
	border: 6px solid #008561;
	width: 310px;
	height: 76px;
	box-shadow: 0 5px 0 0 black;
}
.ekinet-link .link-box:hover {
	box-shadow: none !important;
	transform: translateY(5px) !important;
}
.ekinet-link .link-box a {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
}
.ekinet-link .link-box p {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.ekinet-link .link-box p.ekinet {
	width: 117px;
}
.ekinet-link .link-box p.ekinet img {
	width: 100%;
	vertical-align: bottom;
}
.ekinet-link .link-box .outer {
	position: absolute;
	top: 50%;
	right: 30px;
	width: 18px;
	height: 18px;
	background: url("../img/common_outer_link_block.png") no-repeat;
	background-size: contain;
	transform: translateY(-50%);
}
.cpbtn {
	background: #000;
	color: #fff;
	text-align: center;
	padding: 15px;
	font-size: 105%;
	margin: 70px auto;
	border-radius: 50px;
	width: 50%;
	text-decoration: none;
	display: block;
	position:relative;
}
@media screen and (max-width: 640px){
.cpbtn {
	width: 80%;
}
}
.cpbtn:hover {
	background: #085EB4;
	border-bottom-color: #008CD0;
}
.cpbtn::before {
	background: transparent url("/card/common/img/cmn-parts.png") no-repeat scroll -52px 0px;
	display: block;
	content: "";
	height: 16px;
	position: absolute;
	right: 30px;
	top: 0;
	bottom: 0;
	width: 10px;
	margin: auto;
}
@media screen and (max-width: 640px){
.img50 {
    width: 50% !important;
}
}

/* 注意文言　全体中央寄せ、文字列左寄せ */
@media print, screen and (min-width: 751px) {
.notesWrap {
    text-align: center;
    display: block;
}
.notesWrap ul {
    display: inline-block;
}
.notesWrap li {
    text-align: left;
}
}