img {
  line-height: 0;
  vertical-align: top;
  width: 100%;
  height: auto;
}
body {
  position: relative;
  background: #ffffff;
  margin: 0;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",
    "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro",
    "HG丸ｺﾞｼｯｸM-PRO", "HGMaruGothicMPRO";
}
a {
  cursor: pointer;
}

/* フォントサイズ */
.font-20 {
  font-size: min(2.6vw, 20px);
}
.font-24 {
  font-size: min(3.2vw, 24px);
}
.font-28 {
  font-size: min(3.7vw, 28px);
}
.font-30 {
  font-size: min(4vw, 30px);
}
.font-32 {
  font-size: min(4.2vw, 32px);
}
.font-35 {
  font-size: min(4.6vw, 35px);
}
.font-50 {
  font-size: min(6.6vw, 50px);
}
.font-155 {
  font-size: min(20.6vw, 155px);
}

/***********
 共通
***********/

/* 注記 */
.common_note {
  margin-top: 5%;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
  border-radius: 20px;
}
.common_noteHead {
  padding: 3% 0;
  border-radius: 20px 20px 0 0;
  background: #f08a1d;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  column-gap: 3%;
}
.common_noteHead span {
  background-color: #fff;
  color: #ff0000;
  padding: 1.5%;
}
.common_noteBody {
  padding: 4.5% 3%;
  background-color: #fff;
  border-radius: 0 0 20px 20px;
}
.common_noteBody p {
  font-weight: bold;
  line-height: 1.3;
  margin-top: 1.5%;
  text-align: left !important;
}
.common_noteBody span {
  color: #ff0000;
}

/* modal */
.modal {
  display: none;
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 9999;
  background-color: rgba(0, 0, 0, 0.5);
}
.modal_content {
  position: absolute;
  width: min(86%, 650px);
  /* height: min(132vw, 990px); */
  height: min(140vw, 1050px);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

/* 初回 */
.modal_content.__first {
  height: min(100vw, 750px);
}
.modal_content.__first img {
  padding: 0;
}
.btn_fitstUpload {
  margin-top: 6%;
}

.modal_inner {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 8% 4.5%;
  background-color: #fff;
  border-radius: 20px;
  overflow: hidden;
}

/* レシート初回登録・ポイント獲得 */
.common_modal img {
  padding: 3% 0 0;
}
.common_modal div {
  margin-top: 6%;
}
.common_modal p {
  line-height: 1.3;
  margin-top: 2%;
}
.common_modal p:first-child {
  margin-top: 0;
}

#modal_point {
  overflow-y: scroll;
  height: 100%;
}

#modal_point img {
  padding: 0 6%;
}

/* 注記 */
.modal_note {
  position: absolute;
  bottom: 4.5%;
  left: 4.5%;
  line-height: 1.5;
}

/* 上下フレーム */
.modal_flame {
  position: absolute;
  background-image: linear-gradient(
    90deg,
    rgba(252, 165, 78, 1),
    rgba(253, 165, 129, 1) 0%,
    rgba(255, 166, 203, 1)
  );
  width: 100%;
  height: 3%;
  left: 0;
}
.modal_flame.__top {
  top: 0;
  border-radius: 20px 20px 0 0;
}
.modal_flame.__bottom {
  bottom: 0;
  border-radius: 0 0 20px 20px;
}

/* とじるボタン */
.btn_modalClose01 {
  position: absolute;
  right: 0;
  top: -8%;
  width: 9.3%;
  height: 6%;
}
.__first .btn_modalClose01 {
  top: -10%;
  height: 8%;
}

/* wrapper */
.wrapper {
  width: min(100%, 750px);
  margin: 0 auto;
  padding: min(1.3%, 10px);
}
.top_wrapper {
  background-image: url(../img/top_bg.jpg);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  background-color: #ffa6cb;
}

/* セクション */
.secCommon {
  padding: 7% 4.2% 11%;
  background-image: url(../img/common_bg.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  border-radius: 32px;
  background-color: #fcf7fa;
}

/* 注記 */
.note {
  margin-top: 2%;
  line-height: 1.5;
}

/* アコーディオン */
.common_toggleHead {
  border: clamp(2px, 0.4vw, 3px) #f10082 solid;
  border-radius: 12px;
  line-height: 1.3;
  position: relative;
  transition: border-radius 0.7s;
  color: #f10082;
  font-weight: bold;
  letter-spacing: 1px;
  background-color: #fff;
}
.common_toggleHead.__active {
  border-radius: 12px 12px 0 0;
}
.common_toggleHead::after {
  content: "";
  width: min(2.6vw, 20px);
  height: min(2.6vw, 20px);
  border: 0;
  border-top: solid clamp(2px, 0.4vw, 3px) #e4007c;
  border-right: solid clamp(2px, 0.4vw, 3px) #e4007c;
  position: absolute;
  top: 50%;
  right: 6.5%;
  margin-top: -2.5%;
  transform: rotate(135deg);
  transition: 0.3s;
}
.common_toggleHead.__active::after {
  margin-top: -1%;
  transform: rotate(-45deg);
}
.common_toggleBody {
  padding: 5% 4.5%;
  border: clamp(2px, 0.4vw, 3px) #f10082 solid;
  border-top: none;
  border-radius: 0 0 12px 12px;
  line-height: 1.5;
  background-color: #fff;
  display: none;
}

/* ボタン */
.common_btn {
  transition: opacity 0.4s;
}
.common_btn.__disabled {
  pointer-events: none;
  opacity: 0.3;
}

/* select */
select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  font-size: 1.6rem;
}
select::-ms-expand {
  display: none;
}
select {
  position: relative;
  width: min(46.6vw, 350px);
  padding: 7%;
  border-radius: 8px;
  border: solid 1px #ccc;
  background-color: #fff;
  color: #000;
}
select.__small {
  width: min(20.6vw, 155px);
  padding: 13%;
}
select:invalid {
  color: #ccc;
}
select option {
  color: #000;
}
select option:first-child {
  color: #ccc;
}

.select {
  display: inline-block;
  position: relative;
  margin-top: 3%;
}
.select::after {
  pointer-events: none;
  position: absolute;
  content: "";
  width: 24%;
  height: 100%;
  display: block;
  top: 0px;
  right: 0px;
  border-radius: 0 8px 8px 0;
  background-color: #ccc;
  background-size: 40% 20%;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../img/icon_selectArrow.png);
}
.select.__small {
  margin-top: 0;
}
.select.__small::after {
  width: 45%;
}

/***********
 TOPページ(index.html)
***********/

/* sec01 */
.sec01 {
  padding: 6.2% 4% 9%;
  background-image: url(../img/sec01_bg.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  background-color: #fcf7fa;
}
.sec01 p {
  font-weight: bold;
  line-height: 1.4;
}

.sec01_presentImg {
  display: flex;
  flex-direction: column;
  row-gap: min(1.3vw, 10px);
}

/* アコーディオン */
.sec01_content_toggleHead {
  padding: 5% 4.5%;
  text-align: center;
  margin-top: 3%;
}
.sec01_content_toggleBody {
  padding: 5% 4% 9%;
  text-align: center;
}
.sec01_content_toggleBody ul {
  margin-top: 5%;
  display: flex;
  flex-wrap: wrap;
  column-gap: min(2.6vw, 20px);
  row-gap: min(5.3vw, 40px);
  justify-content: space-between;
}
.sec01_content_toggleBody li {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: min(1.3vw, 10px);
  width: 31%;
}
.sec01_content_toggleBody li img {
  height: min(14vw, 105px);
  width: auto;
}
.sec01_content_toggleBody li span {
  line-height: 1.3;
}

.sec01_content_toggleBody h2:last-of-type {
  margin-top: 10.5%;
  text-align: left;
}

.sec01_text {
  background-color: #fff;
  border-radius: 20px;
  margin-top: 6%;
  padding: 6% 3.5% 4.5%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
}
.sec01_text p {
  text-align: center;
}
.sec01_text p:first-of-type {
  margin-top: 5%;
}
.sec01_text p:last-of-type {
  margin-top: 5%;
  text-align: left;
}

/* sec02 */
.sec02 {
  padding: 9% 4% 11%;
  background-image: linear-gradient(
    135deg,
    rgba(253, 165, 94, 1),
    rgba(255, 166, 190, 1)
  );
}

/* sec03 */
.sec03 {
  padding: 9% 4% 11%;
  background-image: url(../img/sec03_bg.png);
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: top;
  background-color: #fcf7fa;
}
.sec03_title {
  padding: 0 7.5%;
}
.sec03_content {
  margin-top: 6%;
}

.brandLink {
  margin-top: 6%;
}

.sec03_note {
  margin-top: 5%;
}

.movie {
  margin-top: 9.5%;
}
video {
  width: 100%;
  height: auto;
}

.lineLink {
  margin-top: 8%;
}
/* 注記 */
.sec03 p {
  margin-top: 3%;
  font-weight: bold;
  line-height: 1.3;
  text-align: center;
}

/* sec04 */
.sec04 {
  padding: 7% 4% 0;
  background-color: #fff;
}
.sec04_title {
  padding: 0 37%;
}
.sec04_content {
  background-color: #fcf7fa;
  padding: 5% 4.5%;
  border-radius: 12px;
  margin-top: 5%;
  height: min(124vw, 930px);
  overflow-y: scroll;
}
.sec04_content div {
  margin-top: 5%;
}
.sec04_content div:nth-child(1),
.sec04_content div:nth-child(11) {
  margin-top: 8%;
}
.sec04_content div:nth-child(10) {
  margin-top: 12%;
}
.sec04_content p {
  line-height: 1.5;
  margin-top: 2.5%;
}
.sec04_content span,
.sec04_content a {
  color: rgb(61, 61, 248);
  text-decoration: underline;
}

/* sec05 */
.sec05 {
  padding: 8% 4%;
  background-color: #fff;
}
.sec05_title {
  padding: 0 31%;
}
.sec05_content {
  display: flex;
  flex-direction: column;
  row-gap: min(4.2vw, 32px);
  margin-top: 5%;
}
.sec05_content li {
  list-style: none;
  color: #f10082;
  font-weight: bold;
  letter-spacing: 1px;
}
.sec05_content_toggleHead {
  padding: 5% 13% 5% 4.5%;
  display: flex;
  align-items: center;
  column-gap: 2%;
}

/* sec06 */
.sec06 {
  padding: 9% 4% 5%;
  background-image: url(../img/sec06_bg.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: top;
  border-radius: 0 0 32px 32px;
}
.sec06_title {
  padding: 0 31%;
}
.sec06_content {
  background-color: #fff;
  padding: 6% 10.5%;
  border-radius: 12px;
  margin-top: 5%;
}
.sec06_content h2 {
  text-align: center;
  line-height: 1.3;
}
.sec06_content div {
  display: flex;
  column-gap: 6%;
  align-items: center;
  margin-top: 6%;
}
.sec06_content div img {
  width: 21%;
}
.sec06_content div p {
  line-height: 1.3;
}
.sec06_content div a {
  color: #000;
  text-decoration: none;
  line-height: 2;
}
.sec06_note {
  line-height: 1.3;
  margin-top: 5%;
}

/* 追従ボタン */
.btn_follow {
  width: min(100%, 750px);
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.btn_follow_mask {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
}

/***********
 ポイントページ(main.html)
***********/
.secMain_title {
  padding: 0 16%;
}

/* ポイント */
.secMain_point {
  margin-top: 7%;
  position: relative;
}
.secMain_point_sum {
  color: #ef1e94;
  font-weight: bold;
  font-family: "Sofia Sans Condensed", sans-serif;
  position: absolute;
  top: 35%;
  left: 52%;
  transform: translateX(-50%);
  letter-spacing: -3px;
}
.secMain_point_sum span:last-of-type {
  letter-spacing: 0;
  margin-left: 2px;
}
.secMain_point_remaining {
  color: #fff;
  font-weight: bold;
  font-family: "Sofia Sans Condensed", sans-serif;
  text-shadow: 0px 0px 5px rgba(36, 125, 199, 1);
  position: absolute;
  top: 75%;
  left: 50%;
  transform: translateX(-50%);
}
.secMain_point_remaining span:last-of-type {
  margin-left: 2px;
}

.btn_join {
  margin-top: 6%;
  padding: 0 4.5%;
}
.btn_history {
  margin-top: 6%;
  text-align: center;
  position: relative;
  text-decoration: underline;
}
.btn_history::after {
  content: "";
  width: min(1.3vw, 10px);
  height: min(1.3vw, 10px);
  border: 0;
  border-top: solid clamp(1px, 0.2vw, 2px) #000;
  border-right: solid clamp(1px, 0.2vw, 2px) #000;
  position: absolute;
  top: 50%;
  right: 26%;
  margin-top: -1%;
  transform: rotate(45deg);
}
.btn_history a {
  color: #000;
}

/***********
 応募方法ページ(howto.html)
***********/
.secHowto_title {
  padding: 0 22.5%;
}
.secHowto_content {
  margin-top: 7%;
}
.secHowto_text {
  margin-top: 2%;
  padding: 5%;
  background: #fff;
  border-radius: 20px;
}
.secHowto_text p {
  line-height: 1.4;
  margin-top: 1.5%;
}

/* checkbox */
.check {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  column-gap: 3%;
  margin-top: 5%;
}
input[type="checkbox"] {
  position: relative;
  width: min(4.8vw, 36px);
  height: min(4.8vw, 36px);
  border: 1px solid #ccc;
  background-color: #fff;
  border-radius: 20%;
  vertical-align: -5px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  transition: 0.3s;
}
input[type="checkbox"]:checked {
  background-color: #fff;
  border: 1px solid #f10082;
}
input[type="checkbox"]:checked:before {
  position: absolute;
  top: 10%;
  left: 33%;
  transform: rotate(50deg);
  width: min(1vw, 8px);
  height: min(2.1vw, 16px);
  border-right: clamp(2px, 0.4vw, 3px) solid #f10082;
  border-bottom: clamp(2px, 0.4vw, 3px) solid #f10082;
  content: "";
}
.check_text {
  color: #f10082;
  line-height: 1.3;
}

.btn_next {
  margin-top: 6%;
  padding: 0 3%;
}

/***********
 アップロードページ(upload.html)
***********/
.secUpload_title {
  padding: 0 12%;
}

/* 店舗選択 */
.secUpload_store {
  padding: 5% 4% 9%;
  background-color: #fff;
  border-radius: 20px;
  margin-top: 7%;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
}
.secUpload_store h2 {
  line-height: 1.4;
  text-align: center;
}
.secUpload_store h3 {
  color: #ef2185;
}
.secUpload_storeWrapper {
  margin-top: 7%;
  display: flex;
  flex-direction: column;
  row-gap: min(9.3vw, 70px);
  align-items: flex-start;
}

/* テキストボックス */
input[type="text"] {
  width: min(81.3vw, 610px);
  padding: 3.5%;
  border-radius: 8px;
  border: solid 1px #ccc;
  background-color: #fff;
  margin-top: 2.5%;
}
input[type="text"]::placeholder {
  color: #ccc;
}

/* 商品選択 */
.secUpload_purchase {
  padding: 5% 4% 9%;
  background-color: #fff;
  border-radius: 20px;
  margin-top: 6%;
  text-align: center;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
}
.secUpload_purchase ul {
  margin-top: 6.5%;
  display: flex;
  flex-wrap: wrap;
  column-gap: min(2.6vw, 20px);
  row-gap: min(9vw, 70px);
  justify-content: space-between;
  align-items: flex-end;
}
.secUpload_purchase li {
  list-style: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: min(1.3vw, 10px);
  width: 31%;
}
.secUpload_purchase li img {
  height: min(14vw, 105px);
  width: auto;
}
.secUpload_purchase li span {
  line-height: 1.3;
}

.secUpload_purchase h2:last-of-type {
  margin-top: 10.5%;
  text-align: left;
}

.btn_upload {
  margin-top: 7.5%;
  padding: 0 3%;
}
#upload-label {
  display: none;
}

/***********
 アップロードページ(upload.html)
 確認画面
***********/
.secConfirm_title {
  padding: 0 3%;
}

.secConfirm_upload {
  margin-top: 7%;
  border-radius: 20px;
  background-color: #fff;
  padding: 4% 4% 7%;
}
.secConfirm_uploadImg {
  width: 100%;
}
.secConfirm_upload p {
  color: #ef2185;
  font-weight: bold;
  text-align: center;
  margin-top: 6.5%;
}

#previewStore p,
#previewItems p {
  color: #140700;
  text-align: left;
  margin-top: 4%;
  display: flex;
  column-gap: 2%;
  align-items: center;
}
#previewStore span,
#previewItems span {
  width: min(4.2vw, 32px);
  height: min(4.2vw, 32px);
  background-image: url(../img/icon_mark.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* 注記 */
.secConfirm_note {
  margin-top: 5%;
}
.secConfirm_note p {
  line-height: 1.4;
  margin-top: 1.3%;
}

.btn_regist {
  margin-top: 7%;
  padding: 0 3%;
}
.btn_back {
  margin-top: 5%;
  padding: 0 3%;
}

/***********
 アンケートページ(question.html)
***********/
.secQuestion_title {
  padding: 0 7.5%;
}
.secQuestion_content {
  margin-top: 7%;
  padding: 10% 4%;
  background-color: #fff;
  border-radius: 20px;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
  display: flex;
  flex-direction: column;
  row-gap: min(9.3vw, 70px);
}
.secQuestion_content h3 {
  color: #f10082;
  line-height: 1.2;
}

/* checkbox */
.checkbox {
  display: flex;
  flex-direction: column;
  row-gap: 5px;
  margin-top: 5%;
}
.checkboxItem {
  display: flex;
  align-items: center;
  column-gap: 2%;
}

/* radio
.radio {
  display: flex;
  flex-wrap: wrap;
  row-gap: min(2.6vw, 20px);
  align-items: flex-start;
  margin-top: 5%;
}
input[type="radio"] {
  border-radius: 50% !important;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  width: min(4.8vw, 36px);
  height: min(4.8vw, 36px);
  border: 1px solid #ccc;
  vertical-align: -5px;
  border-radius: 4px;
  transition: .3s;
  margin: 0;
}
input[type="radio"]:checked {
  background-color: #fff;
  border: 1px solid #f10082;
}
input[type="radio"]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width: 55%;
  height: 55%;
  border-radius: 50%;
  background-color: #f10082;
  content: '';
}
.radio label {
  cursor: pointer;
  display: flex;
  column-gap: 10px;
  align-items: center;
  width: 40%;
  font-weight: bold;
} */

.btn_answer {
  margin-top: 7%;
  padding: 0 3%;
}

/***********
 レシート履歴ページ(list.html)
***********/
.secList_title {
  padding: 0 4.5%;
}
.secList_content {
  margin-top: 7%;
}

.list {
  display: flex;
  flex-direction: column;
  row-gap: min(2.6vw, 20px);
}
.list-item {
  list-style: none;
  width: 100%;
  background-color: #fff;
  padding: 4.5% 3%;
  border-radius: 8px;
  box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.1);
  background-image: url(../img/icon_plus.png);
  background-repeat: no-repeat;
  background-position: right 3% center;
  background-size: 5% auto;
}

.btn_backPoint {
  margin-top: 7%;
  padding: 0 3%;
}

/* レシート履歴モーダル */
.modal_content.__receipt {
  position: absolute;
  width: min(89%, 670px);
  height: min(143vw, 1072px);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  background-color: #fff;
  background-image: none;
  border-radius: 20px;
  padding: min(3.5%, 30px);
  overflow-y: scroll;
}
.modal_content.__receipt p {
  font-weight: bold;
  text-align: center;
}
#receipt_img {
  margin-top: 6%;
}
.btn_modalClose02 {
  margin-top: 8%;
}

/*******
 ローディング画面 
 *******/
.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(241, 0, 130, 0.6);
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  box-sizing: border-box;
  z-index: 999;
}
.loading.__active {
  opacity: 1;
  visibility: visible;
}
.leap-frog {
  --uib-size: 40px;
  --uib-speed: 2.5s;
  --uib-color: #fff;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: var(--uib-size);
  height: var(--uib-size);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.leap-frog__dot {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
}
.leap-frog__dot::before {
  content: "";
  display: block;
  height: calc(var(--uib-size) * 0.22);
  width: calc(var(--uib-size) * 0.22);
  border-radius: 50%;
  background-color: var(--uib-color);
  will-change: transform;
}
.leap-frog__dot:nth-child(1) {
  animation: leapFrog var(--uib-speed) ease infinite;
}
.leap-frog__dot:nth-child(2) {
  transform: translateX(calc(var(--uib-size) * 0.4));
  animation: leapFrog var(--uib-speed) ease calc(var(--uib-speed) / -1.5)
    infinite;
}
.leap-frog__dot:nth-child(3) {
  transform: translateX(calc(var(--uib-size) * 0.8)) rotate(0deg);
  animation: leapFrog var(--uib-speed) ease calc(var(--uib-speed) / -3) infinite;
}
@keyframes leapFrog {
  0% {
    transform: translateX(0) rotate(0deg);
  }
  33.333% {
    transform: translateX(0) rotate(180deg);
  }
  66.666% {
    transform: translateX(calc(var(--uib-size) * -0.4)) rotate(180deg);
  }
  99.999% {
    transform: translateX(calc(var(--uib-size) * -0.8)) rotate(180deg);
  }
  100% {
    transform: translateX(0) rotate(0deg);
  }
}
