@charset "UTF-8";

:root {
  --primaryColor: #004098;
}

* {
  line-height: 1.5;
}

img {
  width: 100%;
}

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

a {
  word-break: break-all;
}

ul {
  list-style: none;
}

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

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

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

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

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

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



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

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

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


/* キービジュアル */
.main-wrapper {
  overflow: hidden;
  position: relative;
  margin: 0;
  padding: 0;
  background: #5cb6e8;
  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;
}

.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: 0;
  border: 1px solid var(--primaryColor);
  padding: 6px 20px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
}

.contents_wrapper {
  padding: 8px 12px 16px;
}

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

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

.campaign-term .caution:last-of-type {
  margin-bottom: 0;
}


/* 応募方法の説明 */
.middle-area {
  background: #ff5c7d;
  color: #fff;
  margin: 20px 0;
  padding: 10px 7%;
  text-align: center;
  line-height: 2.5rem;
}


/* 賞品一覧 */
.prize_wrapper {
  margin-bottom: 60px;
}

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

.prize_name {
  text-align: center;
  color: #D80C18;
  font-size: 18px;
  font-weight: bold;
  line-height: 2.5rem;
}

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

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

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

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

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

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

.entry_button {
  display: block;
  background-color: var(--primaryColor);
  color: var(--primaryColor);
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(0 81 165 / 80%);
  width: 90%;
  margin: 24px auto 28px;
  text-align: center;
  border: none;
  
  background-color: #5cb6e7;
  
  text-shadow:
  0 0 1px #fff,
  1px 0 0 #fff,
  -1px 0 0 #fff,
  0 1px 0 #fff,
  0 -1px 0 #fff,
  1px 1px 0 #fff,
  -1px -1px 0 #fff,
  -1px 1px 0 #fff,
  1px -1px 0 #fff,
  2px 0 0 #fff,
  -2px 0 0 #fff,
  0 2px 0 #fff,
  0 -2px 0 #fff,
  2px 2px 0 #fff,
  -2px -2px 0 #fff,
  -2px 2px 0 #fff,
  2px -2px 0 #fff;
  border: 2px solid #000;
}

.entry_button:hover,
.entry_button:active,
.entry_button:focus,
.entry_button:visited {
  color: var(--primaryColor);
}

.dl_btn {
  display: block;
  background-color: var(--primaryColor);
  color: #fff;
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(152 171 255 / 80%);
  width: 90%;
  margin: 24px auto 28px;
  text-align: center;
  border: none;
  border-radius: 0;
}

.dl_btn:hover,
.dl_btn:active,
.dl_btn:focus,
.dl_btn:visited {
  background-color: var(--primaryColor);
  color: #fff;
  border: none;
}

.dl_history {
  color: #004098;
  text-decoration: underline;
  margin: 0;
  cursor: pointer;
}

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


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

.products_img_wrapper img {
  width: 100%;
}

.products_description_text_top {
  text-align: center;
  margin-bottom: 16px;
  line-height: 2.2rem;
  font-weight: bold;
  color: var(--primaryColor);
  font-size: 18px;
  line-height: 1.5;
}

.products_description_text_bottom {
  text-align: left;
  line-height: 2.2rem;
  margin-bottom: 6px;
  text-indent: -1em;
  margin-left: 1em;
}



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

.accordion_menu-btn {
  text-align: center;
  background: var(--primaryColor);
  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: flex;
  top: 50%;
  transform: translateY(-50%);
  right: 2%;
  transition: 1s;
  width: 10%;
  justify-content: center;
}

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

.accordionbox {
  padding: 0;
  margin-bottom: 20px;
}

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

.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: 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: 0px 0px 16px;
  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;
  width: 100%;
  padding: 12px;
  margin: auto auto 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: -1.3em;
  margin-left: 1.3em;
}

.shot_text_item img {
  width: 18px;
  transform: translateY(-1px);
}

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

.shot_caution {
  text-align: left;
  color: #f00;
  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;
}

.by-store {
  border: 1px solid var(--primaryColor);
  border-radius: 12px;
  padding: 16px;
  margin: auto auto 20px;
}

.by-heading {
  font-weight: bold;
}

.by-text {
  margin-bottom: 0;
}

.by-text.left {
  text-align: left;
  margin-bottom: 4px;
}

.by-text.red {
  color: #f00;
  margin-bottom: 20px;
}

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

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

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

.notes_text.mb-20 {
  margin-bottom: 20px;
}

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

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


/* 事務局 */
.inquiry {
  text-align: center;
  margin: 0;
  padding: 20px 20px 0;
  background-color: var(--primaryColor);
  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: 5px 0px 16px;
  font-size: 16px;
  font-weight: bold;
  line-height: 2.5rem;
  color: #ff0;
}

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

.inquiry_contents_wrapper dt {
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

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

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

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


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

#pageTop {
  position: fixed;
  bottom: 28px;
  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: 60px 24px 24px;
  text-align: center;
  height: auto;
  background-color: #fff;
}

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

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

.main_contents_subtitle {
  margin: 8px 5% 12px;
  padding: 8px;
  width: 90%;
  text-align: center;
  border: 2px solid var(--primaryColor);
  color: var(--primaryColor);
  font-size: 16px;
  font-weight: bold;
}

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

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

.select_prize_area label {
  display: block;
  margin-top: 18px;
  cursor: pointer;
}

.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 {
  display: block;
  background-color: var(--primaryColor);
  color: #fff;
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(152 171 255 / 80%);
  width: 90%;
  margin: 24px auto 28px;
  text-align: center;
  border: none;
}

.goto_top_btn {
  background-color: #def0ff;
  border: 1px solid #004098;
  box-shadow: 0px 6px 0px #5492e7;
  width: 90%;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin: auto auto 12px;
}

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

.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: #D80C18;
  font-size: 16px;
  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: 20px;
  font-weight: bold;
  margin-bottom: 24px;
}

.modifi_btn {
  background-color: #def0ff;
  border: 1px solid #004098;
  box-shadow: 0px 6px 0px #5492e7;
  width: 90%;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin: auto auto 12px;
  color: var(--primaryColor);
  border-radius: 0;
  padding: 12px 8px;
}

.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 8px;
  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.confirm {
  color: var(--primaryColor);
}

.form_name.enquate {
  text-indent: -2.7em;
  margin-left: 2.7em;
  width: auto;
  color: var(--primaryColor);
}

.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_name span {
  color: #f00;
}

.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 0 0;
  transform: translateY(3px);
  width: 13px;
}

.radio_button sub {
  bottom: -1.5em;
}

.form_error {
  text-align: left;
  color: #3792FF;
  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 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 30px;
  padding: 15px 15px;
  display: block;
  text-align: center;
  background: #F2F1EE;
  color: #615941;
  border: 2px solid #ADA385;
  font-weight: bold;
  font-size: 16px;
  width: 90%;
  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: flex-start;
  margin-bottom: 8px;
  text-align: left;
}



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


/* メール添付型画面 */
.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_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: #ee3258;
}

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

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

.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-color: #def0ff;
  border: 1px solid #004098;
  box-shadow: 0px 6px 0px #5492e7;
  width: 90%;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin: 32px auto 12px;
  padding: 12px 8px;
  display: block;
  color: #004098;
}




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

.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: var(--primaryColor);
  background-color: #ffff6a;
  display: block;
  padding: 12px;
  border-radius: 12px;
  margin: 8px auto;
  width: 80%;
  border: 2px solid #000;
}

.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 4px;
  background: var(--primaryColor);
  width: 100%;
  text-align: center;
  color: #FFF;
  font-size: 16px;
  font-weight: bold;
  border: 2px solid #000;
  display: block;
}



.entry_modal_btn {
  display: block;
  background-color: var(--primaryColor);
  color: var(--primaryColor);
  padding: 12px 4px;
  font-size: 20px;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(0 81 165 / 80%);
  width: 90%;
  margin: 16px auto 36px;
  text-align: center;

  background-color: #5cb6e7;
  
  text-shadow:
  0 0 1px #fff,
  1px 0 0 #fff,
  -1px 0 0 #fff,
  0 1px 0 #fff,
  0 -1px 0 #fff,
  1px 1px 0 #fff,
  -1px -1px 0 #fff,
  -1px 1px 0 #fff,
  1px -1px 0 #fff,
  2px 0 0 #fff,
  -2px 0 0 #fff,
  0 2px 0 #fff,
  0 -2px 0 #fff,
  2px 2px 0 #fff,
  -2px -2px 0 #fff,
  -2px 2px 0 #fff,
  2px -2px 0 #fff;
  border: 2px solid #000;
}

.entry_modal_btn:hover,
.entry_modal_btn:visited,
.entry_modal_btn:active,
.entry_modal_btn:focus {
  color: var(--primaryColor);
}

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

/* モーダル */
.modal.entry {
  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.entry .head {
  display: flex;
  align-items: center;
  padding: 15px 20px;
  background: var(--primaryColor);
  border-bottom: 1px solid var(--primaryColor);
  position: relative;
}

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

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

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

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

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

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

.modal-footer {
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-footer .btn.close {
  text-align: center;
  margin: 20px auto 10px;
  width: 80%;
  opacity: 0.4;
  font-weight: normal;
  background: #000000;
  color: white;
  padding: 16px 10px;
  text-decoration: none;
  border-radius: 5px;
  cursor: pointer;
  display: block;
  font-size: 16px;
}





/* 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;
  margin: 8px auto 16px;
}

.sns_login_btn {
  width: 100%;
  padding: 0;
  border: none;
}

.sns_login_btn img {
  width: 100%;
}


.entry_confirm_text {
  font-size: 16px;
  margin: 12px auto;
}

.entry_prize_name {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  color: var(--primaryColor);
}

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

.entry_use_point {
  font-weight: bold;
  color: var(--primaryColor);
  font-size: 16px;
}

.status.prize a {
  color: #004098;
  text-decoration: underline;
  margin: 0;
  cursor: pointer;
}


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


.code_copy_wrapper {
  border: 1px solid var(--primaryColor);
  text-align: center;
  margin-bottom: 32px;
}

.code_copy_heading {
  background: var(--primaryColor);
  text-align: center;
  padding: 8px;
  color: #fff;
}

.code_copy_wrapper .js-copytext {
  font-size: 22px;
  text-align: center;
  font-weight: bold;
  margin: 20px 12px 16px;
  display: block;
}

.code_copy_wrapper .js-copybtn {
  font-size: 16px;
  background: var(--primaryColor);
  padding: 8px 20px;
  margin: 10px auto 16px;
  color: #fff;
  border: none;
  width: 80%;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(152 171 255 / 80%);
}

.code_copy_caution {
  padding: 12px;
  text-align: left;
}

.instantwin-result_message {
  color: var(--primaryColor);
}

.code-limit {
  color: #e81839;
}

.get_point_btn {
  display: block;
  background-color: #e81839;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  margin: 20px auto 32px;
  padding: 12px 4px;
  width: 100%;
  box-shadow: 0px 7px 0px 0px rgb(255 162 162 / 80%);
}

.get_point_caution {
  text-align: left;
  color: #000;
  font-size: 14px;
  margin: auto auto 8px;
}

.get_point_caution a,
.get_point_caution a:hover,
.get_point_caution a:visited,
.get_point_caution a:active,
.get_point_caution a:focus {
  color: #337ab7;
  text-decoration: underline;
}

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


.gift_contact_wrapper {
  border: 1px solid #e81839;
  margin: 20px auto 36px;
}

.gift_contact {
  background-color: #e81839;
  color: #fff;
  padding: 8px 4px;
  margin: 0 auto;
}

.gift_contact_text {
  padding: 8px;
  margin-bottom: 0;
}

.contact_number {
  font-weight: bold;
}



.table>tbody>tr>td, .table>tbody>tr>th, .table>tfoot>tr>td, .table>tfoot>tr>th, .table>thead>tr>td, .table>thead>tr>th {
  border-top: 1px solid #000;
  text-align: center;
  vertical-align: middle;
}


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

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

.point_ng_btn {
  display: block;
  background-color: var(--primaryColor);
  color: #fff;
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  box-shadow: 0px 7px 0px 0px rgb(152 171 255 / 80%);
  width: 90%;
  margin: 16px auto 36px;
  text-align: center;
  border: none;
}

.point_ok_btn {
  background-color: #def0ff;
  border: 1px solid #004098;
  box-shadow: 0px 6px 0px #5492e7;
  width: 90%;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin: auto auto 12px;
  color: var(--primaryColor);
  padding: 12px 4px;
}


.campaign-term .overlay {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  background-color: rgb(0 0 0 / 50%);
  height: 100%;
  transform: translateY(-50%);
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 40px;
  font-weight: bold;
}

.campaign-term .overlay p {
  color: #fff;
  opacity: 0.9;
}


.point_error_text {
  margin-bottom: 24px;
}