@charset "UTF-8";

:root {
  --primaryColor: #e4c2e8;
  --secondaryColor: #c2e3e8;
}

* {
  line-height: 2rem;
}

html {
  background-color: #fff;
}

body {
  width: 100%;
  margin: auto;
}

a {
  word-break: break-all;
}

ul {
  list-style: none;
}

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

input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] {
  -moz-appearance:textfield;
}

.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 {
  color: #00A3D9;
  font-size: 16px;
  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;
  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: .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;
  font-size: min(3.2vw, 14px)
}

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

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



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

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

.text-indent-setting {
  text-indent: -1.0em;
}


/* キービジュアル */
.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 .5s ease;
  z-index: 2;
  background-color: #c2e3e8;
}

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

.kv img {
  width: 100%;
}

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

.block .title {
  position: relative;
  background: var(--primaryColor);
  margin: auto;
  padding: 10px 20px;
  text-align: center;
  color: #000;
  font-size: 18px;
  font-weight: bold;
}

.contents_wrapper {
  padding: 12px;
}

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

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

.campaign-term .caution {
  position: relative;
  margin: 0 0 8px 16px;
  color: #000;
  font-size: 14px;
  text-align: left;
}
.campaign-term .caution:last-of-type {
  margin-bottom: 0;
}

.campaign-term .caution span {
  color: #f00;
}


/* 応募方法の説明 */
.middle-area {
  background: #fff;
  color: #000;
  margin: 28px auto;
  padding: 16px 3% 6px;
  text-align: center;
  line-height: 2.5rem;
  width: 90%;
  font-size: 16px;
}


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

.prize_wrapper {
  margin-bottom: 40px;
}

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

.prize_name {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  color: #000;
}

.prize_point {
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  border-top: 2px dotted var(--primaryColor);
  border-bottom: 2px dotted var(--primaryColor);
  padding: 8px;
  color: var(--primaryColor);
  margin-top: 52px;
}

.prize_point:first-child {
  margin-top: 12px;
}

.prize_img_wrapper {
  width: 90%;
  margin: 28px auto;
}

.prize_img_wrapper.my {
  width: 90%;
  margin: 28px auto 12px;
}

.prize_img_wrapper img {
  width: 100%;
}

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

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

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

.entry_button {
  margin: 20px auto 8px;
  padding: 12px 8px;
  background-color: var(--primaryColor);
  border-radius: 100px;
  box-shadow: 0px 6px 0px #c88cc8;
  width: 90%;
  text-align: center;
  color: #000;
  font-size: 18px;
  font-weight: bold;
  display: block;
}

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


/* 対象商品 */
.products_img_wrapper {
  width: 100%;
  padding: 0;
  margin-bottom: 16px;
}

.products_img_wrapper img {
  width: 100%;
}

.products_description_text_top {
  text-align: center;
  margin-bottom: 16px;
  line-height: 1.5;
  font-size: 18px;
  font-weight: bold;
  margin-top: 8px;
  color: #f00;
}

.products_description_text_bottom {
  text-align: left;
  line-height: 1.5;
  margin: auto auto auto 1em;
  text-indent: -1em;
}

.target_product_name {
  font-weight: bold;
}

.target_product_name.second {
  margin-top: 20px;
}

.target_product_list {
  padding: 0;
}

.target_product_item {
  margin: auto auto 4px;
}



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

.accordion_menu-btn {
  text-align: center;
  background: var(--primaryColor);
  font-weight: bold;
  color: #000;
  margin: 0 auto;
  padding: 12px 0;
  letter-spacing: 0.2em;
  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: 32px;
  color: #fff;
}

.accordionbox .child {
  display: none;
  padding: 0 16px 16px ;
  word-break: break-all;
  background-color: #ffffff;
  transform: translateY(-12px);
  padding-top: 12px;
}

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

.clearfix {
  padding-bottom: 12px;
}

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

.flow-description {
  margin: 5px 0px 0px 0px;
  text-align: left;
  color: #000;
  font-size: 16px;
  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: var(--primaryColor);
}

.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: 60px 20px 16px 20px;
  text-align: center;
  height: auto;
  background-color: #fff;
}

.shot_good {
  margin-bottom: 20px;
}

.shot_good_title,
.shot_bad_title {
  text-align: center;
  height: auto;
  background-color: var(--primaryColor);
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 12px;
}

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

.shot_good_img_wrapper img {
  width: 100%;
}

.shot_text_list {
  text-align: left;
  padding: 0;
}

.shot_text_item {
  margin-bottom: 8px;
  text-indent: -1em;
  margin-left: 1em;
  font-size: 16px;
}

.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: 100%;
}

.shot_bad_caution {
  text-align: left;
  margin-left: 1rem;
  font-size: 16px;
}

.notes_title {
  margin: 20px auto 8px;
  padding: 8px 12px;
  width: 100%;
  text-align: center;
  border: 2px solid var(--primaryColor);
  color: #721E73;
  font-size: 16px;
  font-weight: bold;
}

.notes_title:first-child {
  margin-top: 0;
}

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

.notes_text.red {
  color: #f00;
}

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

.notes_text a:hover,
.notes_text a:visited,
.notes_text a:active,
.notes_text a:focus {
  color: #337ab7;
}


/* 事務局 */
.inquiry {
  text-align: center;
  margin: 0;
  padding: 20px;
  background-color: var(--primaryColor);
  width: 100%;
}

.inquiry_wrapper {
  border-radius: 2px;
  position: relative;
  padding: 8px;
  margin: auto;
  color: #000;
  border: 4px solid #ffffff;
  background-color: var(--primaryColor);
}

.inquiry_title {
  text-align: center;
  margin: 5px 0px 16px;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.5rem;
}

.inquiry_name {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 20px;
  line-height: 1.5;
}

.inquiry_contents_wrapper dt {
  text-align: center;
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 4px;
}

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

.inquiry_contents_wrapper dd a {
  color: #fff;
  text-decoration: underline;
}

.inquiry_caution {
  text-align: left;
  font-size: 16px;
  margin-left: 1rem;
  padding: 0 16px;
}


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

#pageTop {
  position: fixed;
  bottom: 12px;
  right: 12px;
  z-index: 999;
}

#pageTop .fa-arrow-alt-circle-up {
  display: inline-block;
  z-index: 999;
  font-size: 48px;
  color: var(--primaryColor);
  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: 64px 20px 20px;
  text-align: center;
  height: auto;
  background-color: #fff;
}

.main_contents_wrapper.second {
  margin-top: 60px;
}

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

.main_contents_title {
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  background-color: var(--primaryColor);
  color: #000;
  font-size: 18px;
  font-weight: bold;
  width: 100%;
  padding: 12px 8px;
}

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

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

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

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

.select_prize_area select {
  width: 100%;
  padding: 10px;
  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: 12px 0px 36px;
  padding: 12px 0px;
  background-color: #023f97;
  border: 1px solid #023f97;
  box-shadow: 0px 6px 0px rgb(163 201 255);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
}

.goto_top_btn {
  margin: 0 0 16px;
  background-color: #002060;
  border: 1px solid #002060;
  box-shadow: 0px 6px 0px rgb(165 181 215);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
}

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

.form_caution {
  text-align: left;
  color: #3792FF;
  font-size: 16px;
  line-height: 24px;
  margin-top: 16px;
  margin-bottom: 12px;
}

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

.input_hissu_message {
  font-size: 14px;
  text-align: left;
  color: #f00;
  font-weight: bold;
  line-height: 2.5rem;
}


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

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

.modifi_btn {
  margin: 0 0 16px;
  padding: 12px 0px;
  background-color: #002060;
  border: 1px solid #002060;
  box-shadow: 0px 6px 0px rgb(165 181 215);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
}

.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: #003187;
  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: #f00;
}

.mail_input_caution {
  text-align: left;
  color: #0073cd;
}

.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: #f00;
  font-size: 14px;
  font-weight: bold;
}

.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 auto 0;
  padding: 10px 3px;
  width: 100%;
  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: 50px auto 30px;
  padding: 15px 15px;
  display: block;
  text-align: center;
  background: #F2F1EE;
  color: #615941;
  border: 2px solid #ADA385;
  font-weight: bold;
  font-size: 19px;
  width: 100%;
  border-radius: 6px;
  box-shadow: 2px 2px 0px rgba(173, 163, 133, 1.0);
}

label.formUpload:hover {
  cursor: pointer;
  border: 2px solid #ADA385;
  background: #f9f2e1;
  color: #000;
}

.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.0);
  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_check_item .fa-check-square{
}

.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: 24px 32px;
  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: #eb0050;
}

/* .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: #246acf;
}

.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;
  padding: 0 0 0 20px;
}

.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-top: 40px;
}

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

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

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

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


/* 登録確認画面 */
.regist_btn {
  margin: 12px 0px 28px;
  padding: 12px 0px;
  background-color: #023f97;
  border: 1px solid #023f97;
  box-shadow: 0px 6px 0px rgb(163 201 255);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
}

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

.regist_btn.back {
  background: #c91137;
  border: 1px solid #c91137;
  box-shadow: 0px 6px 0px rgb(231 167 181);
}



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

.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;
}

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

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

.receipt_send_btn {
  margin: 12px 0px 24px;
  padding: 12px 0px;
  background: #dc00a5;
  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: #4681c0;
}


/* 履歴ページ */
.toggle {
  display: block;
  font-size: 16px;
  text-align: center;
  background: var(--primaryColor);
  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;
} */

.status a {
  color: #337ab7;
  text-decoration: underline;
}


/* ポイント不足エラーページ */
.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: 20px auto 36px;
  padding: 12px 8px;
  background-color: #c91137;
  border: 2px solid #c91137;
  border-radius: 0px;
  box-shadow: 0px 6px 0px rgb(255 176 193);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}

.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;
}

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

.entry_prize_img_wrapper {
  width: 60%;
  margin: 28px auto;
}

.entry_prize_img_wrapper img {
  width: 100%;
}

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

.entry_use_point {
  display: block;
  font-size: 16px;
  padding: 6px 0;
  border-radius: 100px;
  color: #000;
  margin-bottom: 28px;
}


/* ポイント確認ページ */
.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;
}

.point_ng_btn {
  margin: 0 0 32px;
  background-color: #ff4f00;
  border: 1px solid #ff4f00;
  box-shadow: 0px 6px 0px rgb(255 179 173);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
  padding: 12px 8px;
}

.point_ok_btn {
  margin: 20px auto 36px;
  padding: 12px 8px;
  background-color: #E91E63;
  border: 2px solid #e91e63;
  border-radius: 0px;
  box-shadow: 0px 6px 0px rgb(255 159 191);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
}


/* ログインページ */
.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: 20px auto 36px;
  padding: 12px 8px;
  background-color: #c91137;
  border: 2px solid #c91137;
  border-radius: 0px;
  box-shadow: 0px 6px 0px rgb(255 176 193);
  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: 20px auto 36px;
  padding: 12px 8px;
  background-color: #c91137;
  border: 2px solid #c91137;
  border-radius: 0px;
  box-shadow: 0px 6px 0px rgb(255 176 193);
  width: 100%;
  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;
}

.win_digital_code a {
  color: #000;
  text-decoration: underline;
}

.win_digital_code a:hover,
.win_digital_code a:active,
.win_digital_code a:visited {
  color: #000;
}


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


/* 入力エラーページ */
.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%;
}




.link_btn_wrapper {
  display: flex;
  width: 90%;
  margin: auto auto 20px;
  gap: 12px;
}

.link_btn {
  width: 33%;
  background: #bfe6ed;
  text-align: center;
  color: #002c83;
  padding: 8px 4px;
  font-size: 16px;
  font-weight: bold;
}

.link_btn:hover,
.link_btn:active,
.link_btn:focus,
.link_btn:visited {
  color: #002c83;
}



.modal_product_btn {
  background-color: var(--secondaryColor);
  color: #fff;
  width: 80%;
  margin: 20px auto auto;
  padding: 12px;
  border: none;
  text-align: center;
  display: block;
  border-radius: 4px;
  font-size: 16px;
}


.modal-dialog .modal-footer {
  border-top: none;
  text-align: center;
  padding-top: 0;
}

.modal-dialog .modal-footer button.close {
  margin: 0 0 12px;
  padding: 12px 0;
  background-color: #000;
  border: 1px solid #000;
  border-radius: 4px;
  width: 100%;
  text-align: center;
  color: #FFF;
  font-size: 16px;
  font-weight: 800;
  line-height: 24px;
  letter-spacing: 0.4px;
  opacity: 1;
  text-shadow: none;
}


.product_list_heading {
  font-size: 16px;
  color: #e63563;
  font-weight: bold;
  margin-top: 12px;
  text-align: left;
}

.product_list {
  margin-bottom: 20px;
  padding: 0;
  text-align: left;
}

.product_list_item {
  list-style: none;
  margin-bottom: 8px;
  line-height: 1.5;
  text-indent: -1em;
  margin-left: 1em;
}

.product_list_item::before {
  content: "・";
}

.product_list_item.heading {
  color: #000;
  font-weight: bold;
  text-indent: 0;
  margin-left: 0;
}

.product_list_item.heading::before {
  content: "";
}

