@charset "UTF-8";

* {
  line-height: 2rem;
}

body {
  width: 100%;
  margin: auto;
  background-color: #000;
  -webkit-font-smoothing: antialiased;
  -moz-font-smoothing: antialiased;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

a {
  word-break: break-all;
}

ul {
  list-style: none;
}

a:hover,
a:visited,
a:focus,
a:active {
  color: #fff;
}

.clear {
  clear: both;
}

.nopadding {
  padding: 0px 0px 0px 0px !important;
}

.mg-8 {
  width: 100%;
  height: 8px;
}

.mg-16 {
  width: 100%;
  height: 16px;
}

.mg-20 {
  width: 100%;
  height: 20px;
}

.mg-24 {
  width: 100%;
  height: 24px;
}

.mg-32 {
  width: 100%;
  height: 32px;
}

.mg-40 {
  width: 100%;
  height: 40px;
}

.line1 {
  border-top: 1px dashed #8c8b8b;
  margin-top: 30px;
  margin-bottom: 30px;
}

.Errorobi {
  text-align: left;
  color: #3792ff;
  font-size: 16px;
  font-weight: bold;
  padding: 10px 0 8px;
  text-align: center;
  margin: 20px auto;
  line-height: 1.2;
}

.Errorobi_oreng {
  color: #00a3d9;
  font-size: 16px;
  padding: 10px 0 8px;
  text-align: center;
  margin: 20px auto;
  line-height: 1.2;
}

.Reciptgazou {
  width: 90%;
  margin: 5px auto 32px;
  text-align: center;
  overflow: hidden;
}

.Reciptgazou img {
  width: 60%;
  margin: 5px auto;
  text-align: center;
}

.Reciptgazou .formReciptbox {
  float: left;
  width: 33%;
  text-align: center;
  margin-bottom: 30px;
}

.Reciptgazou .formReciptbox:after {
  content: "";
  clear: both;
  height: 0;
  display: block;
  visibility: hidden;
}

.Reciptgazou .formReciptbox img {
  width: 80%;
}

.Reciptgazou .formReciptbox p {
  font-size: 19px;
  margin-bottom: 10px;
}

.sbm {
  vertical-align: 0.3em;
}

.UpPreviewBox {
  width: 80%;
  margin: 10px auto;
  text-align: center;
}

.UpPreviewBox img a {
  margin: 0 auto 30px;
}

/***************
　PC用クエリ
***************/
@media only screen and (min-width: 640px) {
  body {
    max-width: 640px;
  }
}

/* ナビゲーションメニュー */
.main-wrapper .nav-sp {
  width: 100%;
  max-width: 640px;
  position: fixed;
  z-index: 999;
  right: auto;
  left: auto;
  top: 0;
}

.sp-inner {
  z-index: 999;
  margin: 0;
  text-align: center;
  width: 100%;
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.sp-inner a {
  display: block;
  padding: 10px 0;
  color: #fff;
  font-weight: bold;
  width: 100%;
  background: #000;
}

.sp-inner a:hover {
  text-decoration: underline;
  background: #353535;
}

.sp-logo {
  text-align: left;
}

.sp-logo img {
  margin: 2px 0px;
  width: auto;
  height: 60px;
}

.text-indent-setting {
  text-indent: -1em;
  margin-left: 1em !important;
}

/* キービジュアル */
.main-wrapper {
  overflow: hidden;
  position: relative;
  margin: 0;
  padding: 0;
  font-family: Quicksand, 游ゴシック体, "Yu Gothic", YuGothic,
    "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo,
    Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  /* iPhoneバンドル */
  width: 100%;
  height: 100%;
  transition: all 0.5s ease;
  z-index: 2;
}

.main-wrapper.upload {
  background: #ffeeef;
}

.kv {
  margin-top: 40px;
  margin-bottom: 20px;
}

.kv img {
  width: 100%;
}

/* キャンペーン期間 */
.block {
  margin: 12px 0px;
  text-align: center;
  width: 100%;
  margin: auto;
}

.block .title {
  position: relative;
  background: #5bc146;
  margin: 0;
  border: 1px solid #5bc146;
  padding: 10px 20px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
}

.block .title.w-chance {
  background: #ff9000;
  border: 1px solid #ff9000;
}

.contents_wrapper {
  padding: 16px 12px 8px;
  border: 1px solid #5bc146;
}

.contents_wrapper hr {
  margin-top: 40px;
  margin-bottom: 30px;
  border: 0;
  border-top: 1px dashed #5bc146;
}

.campaign-term .deadline {
  position: relative;
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.8rem;
  margin-bottom: 12px;
  color: #e70012;
}

.campaign-term .caution {
  position: relative;
  margin: 0 0 8px 1em;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  text-align: left;
}

/* 応募方法の説明 */
.middle-area {
  background: #ff5722;
  color: #fff;
  padding: 14px 3%;
  text-align: center;
  width: 100%;
  margin: 20px auto;
  font-size: 16px;
}

.entry_easy_title {
  font-size: 18px;
  font-weight: bold;
}

.entry_easy_step {
  line-height: 1.5;
}

.entry_easy_step:last-of-type {
  margin-bottom: 0;
}

/* 賞品一覧 */
.prize_list .contents_wrapper {
  padding-bottom: 32px;
}

.prize_wrapper:last-of-type {
  margin-bottom: 0;
}

.prize_name {
  text-align: center;
  color: #e70012;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.5rem;
  margin-bottom: 12px;
}

.prize_img_wrapper {
  width: 100%;
  margin-bottom: 16px;
}

.prize_img_wrapper.my {
  margin-bottom: 8px;
}

.prize_img_wrapper img {
  width: 100%;
}

.prize_description_text {
  text-align: left;
  color: #000;
  font-size: 14px;
  margin: auto auto 16px;
  padding: 0 12px;
}

.prize_description_text.my {
  margin-bottom: 36px;
}

.prize_description_text.my:last-of-type {
  margin-bottom: 0;
}

.prize_description_caution {
  text-align: left;
  color: #000;
  font-size: 14px;
  text-indent: -1em;
  margin-left: 1em;
}

.entry_button {
  margin: auto;
  padding: 12px 8px;
  background-color: #c75c97;
  border: 2px solid #c75c97;
  box-shadow: 0px 6px 0px #daaac5;
  width: 92%;
  text-align: center;
  color: #fff;
  font-size: min(4.4vw, 29px);
  font-weight: bold;
  display: block;
  border-radius: 999px;
}

/* .entry_button:hover,
.entry_button:visited,
.entry_button:focus,
.entry_button:active {
  color: #fff;
} */

/* 対象商品 */
.products_img_wrapper {
  width: 100%;
  margin: auto auto 16px;
}

.products_img_wrapper img {
  width: 100%;
}

.products_description_text_top {
  text-align: center;
  margin-bottom: 16px;
  line-height: 2.8rem;
  font-size: 18px;
  font-weight: bold;
  color: #01a046;
}

.products_description_text_top span {
  font-size: 16px;
  line-height: 1.5;
  display: block;
  margin-top: 6px;
  margin-bottom: 10px;
  color: #000;
}

.target_store_caution {
  text-align: left;
  text-indent: -1em;
  margin: auto auto 8px 1em;
}

.products_description_text_bottom {
  text-align: left;
  text-indent: -1em;
  margin: auto auto 8px 1em;
}

.target_list {
  text-align: left;
  padding: 0;
  font-size: 16px;
}

.target_item {
  margin-bottom: 8px;
  text-indent: -1em;
  margin-left: 1em;
}

/* アコーディオンメニュー */
.accordion {
  width: 88%;
  margin: auto;
}

.accordion_menu-btn {
  text-align: center;
  background: #5bc146;
  font-weight: bold;
  color: #fff;
  margin: 0 auto;
  padding: 12px 0;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  position: relative;
  cursor: pointer;
}

.accordion_icon {
  position: absolute;
  margin: 0 auto;
  display: block;
  top: 50%;
  transform: translateY(-50%);
  right: 4%;
  transition: 1s;
  width: 10%;
}

.accordion_icon .fa-plus-circle,
.accordion_icon .fa-minus-circle {
  font-size: 28px;
  color: #fff;
}

.accordionbox {
  margin-bottom: 20px;
}

.accordionbox .child {
  display: none;
  padding: 16px;
  word-break: break-all;
  background-color: #ffffff;
}

.accordionbox .child:last-of-type {
  padding-top: 16px;
}

.flow-description {
  margin: 5px 0px 0px 0px;
  text-align: left;
  color: #000;
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}

.caret_down {
  margin: 0 auto;
  text-align: center;
}

.method_wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.method_img_wrapper {
  width: 48%;
}

.method_img_wrapper img {
  width: 100%;
}

.method_text_wrapper {
  width: 48%;
}

.fa-caret-down {
  font-size: 44px;
  color: #5bc146;
}

.method_caution_wrapper {
  margin-top: 20px;
  margin-bottom: 20px;
  width: 96%;
  margin-left: auto;
  margin-right: auto;
}

.method_caution {
  text-indent: -1em;
  margin-left: 1rem;
}

.shot_good,
.shot_bad {
  position: relative;
  padding: 20px 0 16px;
  text-align: center;
  height: auto;
  background-color: #fff;
}

.shot_good_title,
.shot_bad_title {
  text-align: center;
  height: auto;
  color: #5bc146;
  font-size: 16px;
  font-weight: 800;
  width: 100%;
  padding: 8px;
  border: 1px solid #5bc146;
  margin-bottom: 12px;
}

.shot_good_img_wrapper {
  width: 80%;
  margin: auto auto 16px;
}

.shot_good_img_wrapper img {
  width: 100%;
}

.shot_text_list {
  text-align: left;
  padding: 0;
  text-indent: -1em;
  margin-left: 1em;
}

.shot_text_item {
  margin-bottom: 8px;
}

.shot_bad img {
  text-align: center;
  width: 96%;
  height: auto;
}

.shot_caution {
  text-align: left;
  color: #d80c18;
  font-size: 14px;
  font-weight: bold;
}

.shot_bad_wrapper {
  width: 100%;
  margin-bottom: 20px;
}

.shot_bad_wrapper img {
  width: 88%;
}

.shot_bad_caution {
  text-align: left;
  margin-left: 1rem;
}

.notes_title {
  margin: 24px auto 8px;
  padding: 8px 12px;
  width: 100%;
  text-align: center;
  border: 2px solid #5bc146;
  color: #5bc146;
  font-size: 16px;
  font-weight: bold;
}

.notes_title:first-of-type {
  margin-top: 0;
}

.notes_text {
  margin: auto auto 12px 1em;
  line-height: 2.2rem;
  padding: 0 4px;
  text-indent: -1em;
}

.notes_text.noindent {
  text-indent: 0;
  margin-left: auto;
}

.notes_text a,
.notes_text a:hover,
.notes_text a:visited,
.notes_text a:focus,
.notes_text a:active {
  color: #000;
  text-decoration: underline;
}

/* 事務局 */
.inquiry {
  text-align: center;
  margin: 0;
  padding: 20px 20px 70px;
  background-color: #000;
  width: 100%;
}

.inquiry_wrapper {
  border-radius: 2px;
  position: relative;
  padding: 8px;
  margin: auto;
  color: #fff;
  border: 4px solid #fff;
}

.inquiry_title {
  text-align: center;
  margin: 8px 0px 16px;
  font-size: min(4.3vw, 27px);
  font-weight: bold;
  line-height: 2.5rem;
  color: #ff0;
}

.inquiry_name {
  text-align: center;
  font-size: 15px;
  margin-bottom: 20px;
  line-height: 2.5rem;
}

.inquiry_contents_wrapper dt {
  text-align: center;
  font-size: 15px;
  font-weight: normal;
}

.inquiry_contents_wrapper dd {
  text-align: center;
  font-size: 15px;
}

.inquiry_contents_wrapper a,
.inquiry_contents_wrapper a:hover,
.inquiry_contents_wrapper a:visited,
.inquiry_contents_wrapper a:active {
  color: #fff;
}

.inquiry_caution {
  text-align: left;
  font-size: 15px;
  margin-left: 1em;
  padding: 0 16px;
  line-height: 1.5;
}

/* コピーライト */
.copyright {
  padding: 12px 0 20px;
  text-align: center;
  background-color: #ff7e9a;
  color: #fff;
  font-size: 12px;
  width: 100%;
}

#pageTop {
  position: fixed;
  bottom: clamp(20px, 19vw, 120px);;
  right: 8px;
  z-index: 999;
}

#pageTop .fa-arrow-alt-circle-up {
  display: inline-block;
  z-index: 999;
  font-size: 44px;
  color: #5bc146;
  background: #fff;
  border-radius: 50%;
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.7);
}

@media only screen and (min-width: 640px) {
  #pageTop {
    right: auto;
    left: auto;
    margin-left: 580px;
  }
}

/* アップロードページ */
.main_contents_wrapper {
  position: relative;
  width: 90%;
  margin: 60px auto 24px;
  padding: 56px 20px 32px;
  text-align: center;
  height: auto;
  background-color: #fff;
}

.main_contents_wrapper.closed {
  padding-bottom: 20px;
  margin-top: 20px;
}

.main_contents_title {
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  background-color: #5bc146;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  width: 100%;
  padding: 12px 8px;
}

.main_contents_subtitle {
  margin: 40px 0 12px;
  padding: 8px;
  width: 100%;
  text-align: center;
  border: 2px solid #5bc146;
  color: #5bc146;
  font-size: 16px;
  font-weight: bold;
}

.upload_caution {
  text-align: left;
  color: #000;
  font-size: 14px;
  margin-left: 1rem;
  font-weight: bold;
  width: 90%;
  margin: auto 1em 8px auto;
  line-height: 2.2rem;
}

.select_prize_area {
  margin: 0 auto 28px;
  font-size: 16px;
  text-align: left;
  width: 92%;
}

.select_prize_area label {
  display: flex;
  align-items: flex-start;
  margin-top: 18px;
  cursor: pointer;
  line-height: 1.5;
  font-size: 14px;
}

.select_prize_area select {
  width: 100%;
  padding: 10px;
  font-weight: bold;
}

.prize_select_heading {
  text-align: center;
  font-weight: bold;
  margin: 16px 0;
  color: #d80c18;
}

.prize_number {
  text-align: center;
  font-weight: bold;
}

.form-item-01 {
  width: 100%;
  text-align: left;
  color: rgb(40, 50, 60);
  /* iPhoneバンドル */
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}

.form-item-01 span {
  width: 100%;
  text-align: left;
  color: #bd2557;
  /* iPhoneバンドル */
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}

.confirm_btn {
  margin: 24px 0;
  padding: 12px 0px;
  background-color: #e70012;
  border: 1px solid #e70012;
  box-shadow: 0px 6px 0px rgb(255 146 152);
  width: 88%;
  text-align: center;
  color: #fff;
  font-size: min(4.4vw, 29px);
  font-weight: 800;
}

.goto_top_btn {
  margin: 24px auto 36px;
  background-color: #252525;
  border: 1px solid #252525;
  box-shadow: 0px 6px 0px #cecece;
  width: 88%;
  text-align: center;
  color: #fff;
  font-size: min(4.4vw, 29px);
  font-weight: 800;
}

.goto_top_btn a {
  padding: 12px 8px;
  display: block;
  width: 100%;
  color: #fff;
}

.form_caution {
  text-align: left;
  color: #3792ff;
  font-size: 14px;
  font-weight: bold;
  margin-top: 12px;
}

.input_message {
  text-align: center;
  color: #d80c18;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.5rem;
}

/* アップロード確認画面 */
.upload_confirm_prize_name_title {
  margin: 0 0 8px;
  width: 100%;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  text-align: left;
}

.upload_confirm_prize_name {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 24px;
  line-height: 1.5;
  text-align: left;
}

.modifi_btn {
  margin: 12px auto;
  background-color: #1f5fa7;
  border: 1px solid #1f5fa7;
  box-shadow: 0px 6px 0px #b7cde6;
  width: 88%;
  text-align: center;
  color: #fff;
  font-size: min(4.4vw, 29px);
  font-weight: 800;
  padding: 12px 8px;
  display: block;
}

.user_email_form_wrapper {
  margin-bottom: 20px;
}

/* アップロード完了ページ */
.already_finished {
  text-align: center;
  color: #d80c18;
  font-size: 16px;
  font-weight: bold;
}

.entried_message_heading {
  margin: 5px 0 20px;
  text-align: center;
  color: #000;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.7rem;
}

.entried_message_caution {
  margin: 0px 0 24px 1rem;
  width: 100%;
  text-align: left;
  color: #000;
  font-size: 14px;
  font-weight: bold;
}

/* フォーム */
.form_name {
  width: 100%;
  text-align: left;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  margin-top: 28px;
}

.form_name span {
  color: #e70012;
}

.form_input_area {
  text-align: left;
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 8px;
}

.form_input_area:last-of-type {
  margin-bottom: 30px;
}

.form_input_area input {
  padding: 8px;
  width: 100%;
  text-align: left;
  color: #000;
  background-color: #f4f4f4;
  font-size: 13px;
  font-weight: bold;
  border: 0;
  border: solid 1px rgb(230, 232, 234);
  border-radius: 2px;
}

.radio_button input[type="checkbox"],
.radio_button input[type="radio"] {
  margin: 0 4px 2px 0;
}

.form_error {
  text-align: left;
  color: #3792ff;
  font-size: 14px;
  font-weight: bold;
  margin-top: 8px;
  margin-bottom: 20px;
}

.dropdown-select {
  padding: 3px 12px 3px 12px;
  position: relative;
  width: 100%;
  height: 40px;
  font-size: 14px;
  font-weight: 800;
  line-height: 32px;
  border: 0;
  border: solid 1px rgb(230, 232, 234);
  border-radius: 2px;
}

/* アンケート */
.enquate_top_text {
  margin: 30px 5% 0;
  padding: 6px 3px;
  width: 90%;
  text-align: center;
  border: 2px solid #d80c18;
  color: #d80c18;
  font-size: 16px;
  font-weight: 800;
}

.enquate_sub_text {
  font-size: 14px;
  text-align: left;
  margin-bottom: 12px;
}

/* アップロードボタン */
label.formUpload {
  margin: 40px auto 20px;
  padding: 15px 15px;
  display: block;
  text-align: center;
  background: #f1f1f1;
  color: #000000;
  border: 2px solid #000000;
  font-weight: bold;
  font-size: min(4.4vw, 29px);
  width: 88%;
  border-radius: 6px;
  box-shadow: 2px 2px 0px rgb(182 182 182);
}

label.formUpload:hover,
label.formUpload:active,
label.formUpload:visited {
  cursor: pointer;
  background: #f1f1f1;
  color: #000000;
  border: 2px solid #000000;
}

.formUploadPreviewBox {
  width: 80%;
  margin: 2px auto;
  text-align: center;
}

.formUploadPreviewBox img {
  width: 150px;
  display: block;
  margin: 0 auto 30px;
}

.radio_button label {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 8px;
}

/* フォーム入力確認画面 */
.form_confirm_input {
  text-align: left;
  font-size: 16px;
  font-weight: bold;
}

.form_confirm_input a {
  pointer-events: none;
  color: #000;
}

/* メール添付型画面 */
.send_receipt_btn {
  margin: 12px 0px 32px;
  padding: 12px 0px;
  background-color: #d80c18;
  border: 1px solid #d80c18;
  box-shadow: 0px 6px 0px rgba(151, 9, 16, 1);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  display: block;
}

/* .send_receipt_btn:hover,
.send_receipt_btn:visited,
.send_receipt_btn:focus,
.send_receipt_btn:active {
  color: #fff;
} */

.send_check_text {
  text-align: left;
  margin-top: 0px;
  position: relative;
  color: rgb(40, 50, 60);
  font-size: 14px;
  font-weight: bold;
  line-height: 24px;
  margin-bottom: 8px;
}

.send_check_list {
  padding: 0;
}

.send_check_item {
  margin: 0px 0px 8px 0px;
  width: 100%;
  text-align: left;
  color: #f59107;
  font-size: 14px;
  font-weight: bold;
  line-height: 24px;
}

.send_caution_text {
  text-align: left;
  position: relative;
  color: #000;
  font-size: 14px;
  margin-left: 1rem;
  line-height: 2.2rem;
  margin-bottom: 20px;
}

/* ティザーページ */
.ts_box {
  padding: 16px 24px;
  text-align: center;
  height: auto;
  background-color: #fff;
  width: 90%;
  margin: auto auto 20px;
}

.ts_box p {
  font-size: 16px;
  line-height: 3rem;
  margin: 0;
}

/* クローズページ */

.close_text {
  font-size: 16px;
  line-height: 3rem;
  margin: 0;
}

/* マイページありトップページ */
.register_btn {
  margin: 12px auto;
  padding: 12px 0px;
  border: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  display: block;
  width: 100%;
  text-decoration: none;
}

.register_btn.login {
  background: #5BC146;
}

/* .register_btn a:hover,
.register_btn a:visited,
.register_btn a:focus,
.register_btn a:active {
  color: #fff;
} */

.first_register {
  background: #e9630a;
  padding: 0;
}

.first_register a {
  padding: 12px 0px;
  display: block;
  width: 100%;
  text-decoration: none;
}

.register_btn a {
  color: #fff;
}

.login:hover {
  background: #379e23;
}

.first_register:hover {
  background-color: #f18035;
}

.forget-pw {
  font-size: 14px;
  color: #000 !important;
  text-decoration: underline;
}

.register_caution_text {
  margin: 0 0 10px;
  text-align: left;
  color: #111;
  font-size: 14px;
  line-height: 2.5rem;
}

.register_caution_text:last-of-type {
  margin-bottom: 0;
}

/* 登録画面 */
.regist_top_message {
  font-size: 16px;
  text-align: center;
  font-weight: bold;
  line-height: 2.5rem;
}

.confirm_btn.regist {
  margin-bottom: 0;
}

.regist_nomal_text {
  text-align: left;
  font-size: 14px;
}

.regist_caution {
  text-align: left;
  font-size: 14px;
  margin-left: 1em;
}

.form_input_area.regist_pw {
  margin-bottom: 10px;
}

.form_error.regist_pw {
  margin-bottom: 16px;
}

/* 登録確認画面 */
.regist_btn {
  margin: 12px 0px;
  padding: 12px 0px;
  background: #dc00a5;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  border: none;
}

/* .regist_btn:hover,
.regist_btn:visited,
.regist_btn:focus,
.regist_btn:active {
  color: #fff;
} */

.regist_btn.back {
  background: #4681c0;
}

/* ログイン後TOPページ */
.account-name {
  font-weight: bold;
  font-size: 16px;
  line-height: 1.8em;
  margin-bottom: 4px;
}

.point-text {
  line-height: 3rem;
}

.confirm_point {
  margin-top: 8px;
  margin-bottom: 20px;
  font-weight: bold;
  font-size: 16px;
  line-height: 2.2em;
}

.confirm_point span {
  font-size: 20px;
  color: #5bc146;
}

.mypage-point {
  font-size: 16px;
  line-height: 36px;
}

.mypage-point span {
  font-size: 28px;
  font-weight: bold;
}

.receipt_send_btn {
  margin: 12px 0px 16px;
  padding: 12px 0px;
  background: #5bc146;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  border: none;
  display: block;
}

/* .receipt_send_btn:hover,
.receipt_send_btn:visited,
.receipt_send_btn:focus,
.receipt_send_btn:active {
  color: #fff;
} */

.receipt_send_btn:last-of-type {
  margin-bottom: 0;
}

.receipt_send_btn.history {
  background: #000;
}

/* 履歴ページ */
.toggle {
  display: block;
  font-size: 16px;
  text-align: center;
  background: #5bc146;
  font-weight: bold;
  color: #fff;
  margin: 30px auto;
  padding: 7px 0;
  width: 60%;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
}

.history_caution {
  text-align: left;
  color: #000;
  font-size: 14px;
  margin-left: 1em;
  margin-bottom: 20px;
  line-height: 2.2rem;
}

.status a {
  color: #c81f3b;
}

/* ポイント不足エラーページ */
.point_error_text {
  text-align: center;
  margin: 20px 0 40px;
  color: #000;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.5rem;
}

/* 応募確認ページ */
.entry_button.mypage {
  margin: 12px auto 36px;
  background-color: #5bc146;
  border: 1px solid #5bc146;
  box-shadow: 0px 6px 0px #c3e9bc;
  width: 88%;
  text-align: center;
  color: #fff;
  font-size: min(4.4vw, 29px);
  font-weight: 800;
  border-radius: 0;
}

.entry_button.mypage:hover {
  opacity: 0.8;
}

.entry_confirm_text {
  font-size: 16px;
  margin-bottom: 20px;
}

.entry_prize_name {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  color: #5bc146;
}

.entry_prize_number {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
}

.entry_prize_img_wrapper {
  width: 100%;
  margin-bottom: 12px;
}

.entry_prize_img_wrapper img {
  width: 100%;
}

.prize_description {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 12px;
  color: #e70012;
}

.schedule {
  text-align: left;
  text-indent: -1em;
  margin: auto auto 8px 2em;
  font-size: 16px;
  line-height: 1.6;
}

.prize_caution {
  text-align: left;
  text-indent: -1em;
  margin: auto 1em 16px 2em;
  font-size: 14px;
  line-height: 1.6;
}

.size_wrapper {
  display: flex;
  align-items: flex-start;
  margin-bottom: 10px;
}

.size_wrapper .right {
  text-align: left;
}

.entry-notice {
  font-size: 14px;
  text-align: left;
  margin-bottom: 20px;
}

.entry_use_point {
  font-size: 16px;
  padding: 6px 0;
  border-radius: 100px;
  margin-bottom: 28px;
  font-weight: bold;
}

/* ポイント確認ページ */
.point_confirm_top_text {
  text-align: center;
  margin: 0 0 20px;
  color: #000;
  font-size: 14px;
  font-weight: bold;
}

.point {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 24px;
}

/* ログインページ */
.main_contents_wrapper.login_wrapper {
  padding-top: 80px;
}

.login_btn {
  margin: 32px 0 20px;
  padding: 12px 0px;
  background: #000000;
  border: 1px solid #000000;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  display: block;
}

.forget_pw_link_text {
  color: #000;
  text-align: center;
  font-size: 14px;
}

.forget_pw_link_text:hover,
.forget_pw_link_text:visited,
.forget_pw_link_text:focus,
.forget_pw_link_text:active {
  color: #000;
}

.login-title {
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}

.sns-login-btn {
  border: none;
  background: #fff;
}

.login-form input,
.main-wrapper .content .box.login .form-input input {
  width: 100%;
  margin-bottom: 20px;
  padding: 8px;
}

/* パスワードを忘れた方ページ */
.forget_password .content {
  margin: 80px 0 30px;
}

.forget_password input {
  width: 100%;
  margin-bottom: 20px;
}

.main_contents_top_text {
  text-align: center;
  font-size: 16px;
  margin-bottom: 20px;
  line-height: 2.4rem;
}

.form_input_area.reset {
  margin-bottom: 36px;
}

.reset_bottom_text {
  text-indent: -1em;
  margin-left: 1em;
  text-align: left;
  margin-top: 20px;
}

/* パスワード再設定ページ */
.reset_bottom_text.no-indent {
  text-indent: 0;
  margin-left: 0;
  margin-top: 12px;
}

.reset_bottom_text.mail_input_bottom {
  margin-top: 12px;
  margin-bottom: 32px;
}

/* パスワードリセット完了画面 */
.main_contents_wrapper.reset_pw {
  padding-bottom: 8px;
}

/* インスタントウィン抽選中画面 */
.instantwin-pic.lottery {
  width: 60%;
}

.lottery_result_btn {
  margin: 32px auto 0;
  padding: 12px 8px;
  background-color: #ff7600;
  border: 2px solid #ffb100;
  border-radius: 100px;
  box-shadow: 0px 6px 0px #ffd77c;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}

/* 即時インスタントウィン当落画面 */
.instantwin-result_message {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.4rem;
}

.instantwin-pic {
  width: 100%;
}

.to_history_message {
  font-size: 16px;
  text-align: center;
  margin-bottom: 20px;
}

.prrsonal_input_btn {
  margin: 8px auto 32px;
  padding: 12px 8px;
  background-color: #2c63a7;
  border: 2px solid #2c95d3;
  border-radius: 100px;
  box-shadow: 0px 6px 0px #9cbbff;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}

.code_confirm_btn {
  margin: 8px auto 32px;
  padding: 12px 8px;
  background-color: #2c63a7;
  border: 2px solid #2c95d3;
  border-radius: 100px;
  box-shadow: 0px 6px 0px #9cbbff;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}

/* コード当選ページ */
.win_digital_code {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

/* デジコン当選ページ */
.degicon_text {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

/* 入力エラーページ */
.input_error_message {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  color: #f00;
}

.back_btn {
  margin: 8px auto 32px;
  padding: 12px 8px;
  background-color: #2c63a7;
  border: 2px solid #2c95d3;
  border-radius: 100px;
  box-shadow: 0px 6px 0px #9cbbff;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}

/* 当選ページ */
.win_prize_item {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-top: 12px;
  margin-bottom: 20px;
}

.please_input_message {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}

.deadline_date {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: #e0009d;
  margin-bottom: 20px;
}

/* 賞品応募完了ページ */
.thanks_message {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  margin-top: 30px;
  margin-bottom: 40px;
}

/* お届け先入力済ページ */
.alredy_input_message {
  text-align: center;
  font-size: 14px;
  font-weight: bold;
}

/* ポイント反映ページ */
.point_complete_message {
  text-align: center;
  font-size: 14px;
  font-weight: bold;
}

/* 複数応募複数口数選択画面 */
.entry_num_select {
  margin: 8px 5% 12px;
  padding: 8px;
  width: 90%;
  text-align: center;
  border: 2px solid #d80c18;
  color: #d80c18;
  font-size: 16px;
  font-weight: bold;
}

.form_input_area.num_select,
.form_confirm_input.num_select {
  margin-bottom: 20px;
}

/* LINEログインモーダル */
.login_modal_title {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 20px;
}

.login_modal_description {
  font-size: 16px;
  text-align: left;
  margin-bottom: 20px;
}

.login_modal_caution {
  text-indent: -1em;
  margin-left: 1em;
}

.sns_login_btn_wrapper_modal {
  margin-bottom: 20px;
}

.sns_login_btn_modal {
  width: 100%;
}

/* TOPページSNSログイン部分 */
.sns_login_title {
  font-weight: bold;
  font-size: 16px;
  text-align: center;
}

.sns_login_btn {
  width: 100%;
  padding: 0;
  border: none;
  margin-bottom: 40px;
}

.sns_login_btn img {
  width: 100%;
}

/* 賞品詳細モーダル */
.detail_btn {
  width: 90%;
  margin: auto;
}

.detail_btn.fixed {
  position: fixed;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  max-width: 600px;
}


.entry_btn,
.direct_entry_btn {
  width: 72%;
  margin: 16px auto auto;
  border: 2px solid #f00;
  background-color: #fff;
  box-shadow: 0 6px 0px 0px rgb(255, 207, 188);
}

.entry_btn a,
.direct_entry_btn a {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.4px;
  padding: 6px 0;
  display: block;
  color: #000;
  text-decoration: none;
}

.oubo_btn {
  width: 100%;
  margin: 12px auto auto;
  border: 1px solid #5bc146;
  border-radius: 8px;
  box-shadow: 0 2px 4px 0 rgba(248, 231, 28, 0.48);
  background-color: #5bc146;
  text-align: center;
}

.oubo_btn a {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  padding: 4px;
  display: block;
  color: #fff;
}

.team {
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  line-height: 1.5;
}

/* フィルター背景 */
.filter {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1000;
  display: none;
}

/* モーダル */
.modal {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  max-width: 600px;
  background: white;
  border-radius: 8px;
  z-index: 1001;
  display: none;
  overflow: hidden;
}

.modal .head {
  display: flex;
  align-items: center;
  padding: 15px 20px;
  background: #5bc146;
  border-bottom: 1px solid #c3f9b8;
  position: relative;
}

.modal .head img {
  width: 32px;
  height: 32px;
  cursor: pointer;
  position: absolute;
  right: 15px;
}

.modal .head p {
  margin: auto;
  font-weight: bold;
  font-size: 16px;
  color: #fff;
}

.modal .content {
  padding: 20px;
  overflow-y: auto;
}

.modal .content img {
  width: 100%;
  height: auto;
  margin: 12px auto 16px;
  display: block;
}

.btn.close {
  text-align: center;
  margin: 40px auto 0;
  width: 100%;
  opacity: 0.4;
  font-weight: normal;
  padding: 0;
}

.btn.close a {
  background: #000000;
  color: white;
  padding: 10px 30px;
  text-decoration: none;
  border-radius: 5px;
  cursor: pointer;
  display: block;
  font-size: 16px;
}

.btn.close a:hover {
  background: #545b62;
}

/* デモ用のダミー要素 */
.slick-arrow,
.onepage-pagination {
  display: none;
}


.check_img {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: -2px 0 0;
}




.point_wrapper {
  border: 2px solid #f00;
  padding: 8px;
  margin: auto auto 12px;
}

.point_name {
  color: #f00;
}

.point_wrapper.w-chance {
  border: 2px solid #ff9001;
}

.point_wrapper.w-chance .point_name {
  color: #ff9001;
}