@charset "UTF-8";

* {
  line-height: 2rem;
}

body {
  width: 100%;
  margin: auto;
  /* background-image: url(../img/img_section_background.png); */
  background-color: #000;
}

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 auto 10px;
}

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

.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: 92%;
  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;
  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: 12px;
  right: 12px;
  z-index: 999;
}

#pageTop .fa-arrow-alt-circle-up {
  display: inline-block;
  z-index: 999;
  font-size: 48px;
  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 12px;
  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: 1.5;
}

.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: 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: #5bc146;
}

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

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

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

/* .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 {
  border: 2px solid #4c4c4c ;
  color: #4c4c4c  !important;
}

/* 履歴ページ */
.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: 18px;
  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: 12px;
  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: 70%;
  margin: auto;
  /* box-shadow: 0 6px 0px 0 rgb(131 172 127); */
  background-color: #3F51B5;
  border-radius: 100px;
}

.detail_btn a {
  font-size: 16px;
  font-weight: 700;
  line-height: 16px;
  letter-spacing: 0.4px;
  padding: 16px 4px;
  display: block;
  color: #fff;
}

.entry_btn {
  /* width: 80%;
  margin: 24px auto auto;
  border: 1px solid #5bc146;
  border-radius: 20px;
  box-shadow: 0 2px 4px 0 rgba(248, 231, 28, 0.48);
  background-color: #5bc146; */
  width: 70%;
  margin: 24px auto auto;
  /* border: 2px solid #f00; */
  background-color: #ffe8e8;
  /* box-shadow: 0 6px 0px 0px rgb(255, 207, 188); */
  border-radius: 100px;
  border: 2px solid #f00;
}

.entry_btn a {
  /* font-size: 16px;
  font-weight: 700;
  line-height: 16px;
  letter-spacing: 0.4px;
  padding: 10px 0;
  display: block;
  color: #fff; */
  font-size: 16px;
  font-weight: 700;
  line-height: 16px;
  padding: 16px 4px;
  display: block;
  color: #f00;
  text-decoration: none;
}

.point_ng_btn {
  background-color: #d8004a;
  color: #fff;
  border: none;
  display: block;
  width: 88%;
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  margin: 8px auto 24px;
}

.point_ok_btn {
  background-color: #5bc146;
  color: #fff;
  border: none;
  display: block;
  width: 88%;
  padding: 12px 4px;
  font-size: 16px;
  font-weight: bold;
  margin: 12px auto 38px;
}

.oubo_btn {
  width: 100%;
  margin: 12px auto auto;
  border: 2px solid #000;
  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;
}

.oubo_btn a span {
  color: #ff0;
}

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

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

/* .main-wrapper .main-visual .campaign-term .block .caution {
  position: relative;
  margin: 0px 0px 12px 16px;
  padding: 0px 16px;
  color: #000;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  line-height: 20px;
  letter-spacing: 0.8px;
  text-align: left;
}

.main-wrapper .main-visual .campaign-term .block .caution.red {
  color: #f00;
}




.main-wrapper .main-visual .campaign-term .title-01 {
  position: relative;
  margin: 12px 0px 14px;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 32px;
  letter-spacing: 0.2px;
}

.main-wrapper .main-visual .campaign-term .title-02 {
  line-height: 24px;
  font-weight: bold;
  margin-bottom: 16px;
} */

/* レシート確認 */
/* .main-wrapper .content .box#recipt {
  margin-top: 50px;
}

.main-wrapper .content .box.sub_area#recipt {
  margin-top: 30px;
}

.main-wrapper .content .box#recipt .row {
  margin: 0;
}

.main-wrapper .content .box#recipt .title {
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  height: auto;
  background-color: #ff5c7d;
  color: #fff;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 16px;
  font-weight: 800;
  line-height: 56px;
  letter-spacing: 1.6px;
}

.main-wrapper .content .box#recipt .campaign-recipt img {
  position: relative;
  margin: 12px 0px 0px 0px;
  padding: 0;
  width: 100%;
  height: auto;
}

.main-wrapper .content .box #recipt .campaign-apply {
  position: relative;
  background-color: #000;
}

.main-wrapper .content .box #recipt .campaign-apply img {
  position: relative;
  margin: 12px 0px 0px 0px;
  padding: 0;
  width: 100%;
  height: auto;
}

.main-wrapper .content .box#recipt p.description {
  text-align: center;
  margin: 0px 0px 15px 0px;
  position: relative;
  color: #000;
  font-size: 15px;
  font-weight: bold;
  line-height: 24px;
  letter-spacing: 0.6px;
}

.main-wrapper .content .box#recipt p.description span {
  font-size: 19px;
}

.main-wrapper .content .box#recipt p.description-02 {
  text-align: left;
  margin-top: 0px;
  position: relative;
  color: rgb(40, 50, 60);
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 13px;
  font-weight: bold;
  line-height: 24px;
  margin-bottom: 8px;
}



.main-wrapper .content .box#recipt p.description-04 {
  text-align: left;
  color: #D80C18;
  font-size: 14px;
  font-weight: bold;
  line-height: 22px;
}



.main-wrapper .content .box#recipt p.description-06 {
  text-align: left;
  color: #000;
  font-size: 14px;
  line-height: 22px;
  letter-spacing: 0.2px;
  margin-left: 22px;
  padding-right: 40px;
  font-weight: bold;
}

.main-wrapper .content .box#recipt .form-item input {
  margin: 0px 2px;
  padding: 0;
  display: inline;
}

.main-wrapper .content .box#recipt .form-item p {
  position: relative;
  color: rgb(40, 50, 60);
  font-size: 12px;
  font-weight: bold;
  line-height: 24px;
  margin-bottom: 16px;
}

.main-wrapper .content .box#recipt p.text {
  text-align: left;
  position: relative;
  color: #000;
  font-size: 13px;
  line-height: 24px;
}


.main-wrapper .content .box#recipt p.confirm img {
  width: auto;
  height: 16px;
}

.main-wrapper .content .box#recipt .apply {
  margin: 12px 5% 12px;
  padding: 12px 0px;
  background-color: #ee3258;
  border: 2px solid #ff6584;
  border-radius: 100px;
  box-shadow: 0px 6px 0px #ffa4bd;
  width: 90%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 26px;
}

.main-wrapper .content .box#recipt .apply02 {
  margin: 12px 0px 12px;
  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;
  line-height: 26px;
} */

/* エラーページ */
/* .main-wrapper .content .box.error#point {
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}

.main-wrapper.point .reset-password {
  margin-top: 80px;
  margin-bottom: 26px;
}

.main-wrapper .content .box#point p.text {
  text-align: center;
  margin: 0 0 20px;
  color: #000;
  font-size: 14px;
  font-weight: bold;
  line-height: 24px;
} */

/***************
　コンテンツ部分の指定-02（sp)
***************/
/* .main-wrapper .content .box {
  position: relative;
  padding: 80px 32px 16px 32px;
  text-align: center;
  height: auto;
  background-color: #fff;
}



.main-wrapper .content #signin .title,
.main-wrapper .content .box#point p.title {
  position: absolute;
  top: 0;
  left: 0;
  text-align: center;
  height: auto;
  background-color: #ff5c7d;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 56px;
  letter-spacing: 1.6px;
}

.main-wrapper .content #signin .apply,
.main-wrapper .content .box#point .apply,
.main-wrapper .content .box.login .login-btn {
  margin: 12px 0px;
  padding: 12px 0px;
  background-color: #000000;
  border: 1px solid #000000;
  width: 100%;
  text-align: center;
  color: #FFF;
  font-size: 16px;
  font-weight: 800;
  line-height: 24px;
}



.main-wrapper .content #signin .text {
  text-align: left;
  color: #000;
  font-size: 13px;
  line-height: 20px;
} */

/***************
　コンテンツ部分の指定-03（sp)
***************/
/* .main-wrapper .content .menu {
  position: relative;
  margin: 8px 16px;
}

.main-wrapper .content .menu .menu-btn img {
  width: 100%;
}

.main-wrapper .content .menu .accordionbox {
  background: #fff;
}

.main-wrapper .content .menu .accordionbox .title {
  text-align: center;
  margin: 0;
  padding: 14px 6px;
  background-color: #ff5c7d;
  color: #fff;
  font-size: 20px;
  font-weight: 800;
  line-height: 22px;
  letter-spacing: 1.2px;
}

.main-wrapper .content .menu .accordionbox .title2 {
  text-align: center;
  color: #D80C18;
  font-size: 18px;
  font-weight: 800;
  line-height: 26px;
  letter-spacing: 1.2px;
} */

/* ログインフォーム周り */

/* .main-wrapper .content .menu .accordionbox .accordionlist {
  margin-bottom: 12px;
}

.main-wrapper .content .menu .accordionbox .accordionlist dt {
  display: block;
  margin: 12px 0px 0px 0px;
  padding: 0 10px;
  position: relative;
}

.main-wrapper .content .menu .accordionbox .accordionlist dt .menu-btn {
  text-align: center;
  background: #ff5c7d;
  font-weight: bold;
  color: #fff;
  margin: 0 auto;
  padding: 10px 0;
  letter-spacing: 0.2em;
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.main-wrapper .content .menu .accordionbox .accordionlist dt .menu-btn .menu_text {
  width: 90%;
}





.main-wrapper .content .menu .accordionbox .accordionlist dt:first-child {
  border-top: none !important;
}

.main-wrapper .content .menu .accordionbox .accordionlist dt .menu-title {
  padding-left: 10px;
  float: left;
}

.main-wrapper .content .menu .accordionbox .accordionlist dt .menu-title p {
  text-align: left;
  color: rgb(20, 30, 40);
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 14px;
  font-weight: 800;
  line-height: 40px;
}



.main-wrapper .content .menu .accordionbox .accordionlist .child .title1 {
  text-align: center;
  margin: 6px 0px;
  color: #000;
  font-size: 20px;
  font-weight: 800;
  line-height: 26x;
}



.main-wrapper .content .menu .accordionbox .accordionlist .child .title3 {
  text-align: center;
  background-color: #B8E1E8;
  color: #575748;
  font-size: 16px;
  font-weight: 800;
  line-height: 32px;
  letter-spacing: 0.8px;
}



.sub-title {
  text-align: center;
  color: #000;
  font-size: 16px;
  font-weight: 800;
  line-height: 24px;
  letter-spacing: 0.2px;
}

.menu .sub-title3 {
  text-align: left;
  color: #000;
  font-size: 16px;
  line-height: 20px;
  padding: 0px 35px 0px 35px;
  word-break: normal;
}

.menu .caution {
  margin: 0px 0px 20px 6px;
  padding: 0 12px;
  text-align: left;
  color: #000;
  font-size: 16px;
  line-height: 22px;
  letter-spacing: 0.8px;
  word-break: break-all;
}

.menu .caution.target_product {
  padding: 0 30px;
} */

/***************
　コンテンツ部分の指定-04（sp)
***************/

/* .main-wrapper .content .menu .accordionbox .accordionlist .child .box .row .description-03 {
  text-align: center;
  color: #000;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 14px;
  font-weight: 800;
  line-height: 18px;
  letter-spacing: 0.8px;
}

.main-wrapper .content .menu .accordionbox .accordionlist .child .box .row .description-04 {
  text-align: left;
  color: #FF2626;
  font-size: 14px;
  font-weight: 800;
  line-height: 20px;
  letter-spacing: 0.8px;
} */

/***************
  サイドメニュー部分の指定
***************/
/* .overlay {
  display: none;
  content: '';
  visibility: hidden;
  position: fixed;
  top: 0;
  right: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: transparent;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
  z-index: 3;
}

.overlay p {
  position: fixed;
  right: 20px;
  color: #fff;
  font-size: 48px;
  font-weight: 80;
  text-align: center;
  line-height: 48px;
}

.overlay::after {
  visibility: hidden;
  position: fixed;
  top: 40%;
  right: 0;
  display: block;
  width: 100%;
  height: 50px;
  color: rgba(255, 255, 255, 0);
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}

.side-open .overlay {
  visibility: visible;
  cursor: pointer;
  background: rgba(20, 30, 34, 0.8);
}

.side-open .overlay::after {
  visibility: visible;
  color: rgba(255, 255, 255, 0.4);
}

.side-menu {
  display: none;
  position: fixed;
  top: 0;
  right: 0;
  width: 240px;
  height: 100%;
  padding-top: 100px;
  text-align: left;
  font-size: 13px;
  background: #555555;
  z-index: 1;
}

.side-menu ul {
  list-style: none;
  padding: 0;
}

.side-menu ul li {
  height: 48px;
  border-bottom: 0.5px solid rgba(200, 210, 214, 0.4);
}

.side-menu ul .close {
  margin: 0px 0px 0px 0px;
  padding: 40px 0px;
  width: 100%;
  height: 76px;
  border: none;
  color: #fff !important;
  opacity: 1.0 !important;
  text-align: center;
}

.side-menu ul .close a {
  position: relative;
  display: inline !important;
  margin: 0px 0px 0px 0px;
  padding: 16px 64px;
  background-color: #f8f8fa;
  color: #fff !important;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 13px;
  text-align: center;
  letter-spacing: 1px;
}

.side-menu ul li img {
  margin: 16px 0px 16px 40px;
  padding: 0px;
  height: 48px;
}

.side-menu ul li a {
  position: relative;
  display: inline !important;
  margin: 0px 0px 0px 40px;
  padding: 0;
  text-align: left;
  color: #fff;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 13px;
  font-weight: 800;
  line-height: 48px;
}

.side-menu-btn {
  cursor: pointer;
  z-index: 4;
  color: #000;
}

.side-menu-btn:hover {
  color: #000;
}

.side-open .main-wrapper,
.side-open .overlay {
  -webkit-transform: translate3d(-240px, 0, 0);
  transform: translate3d(-240px, 0, 0);
  background-color: #222222;
}



.box .form-item-03 input {
  width: 100%;
  text-align: left;
  color: rgb(20, 30, 40);
  background-color: #f4f4f4;
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  font-size: 13px;
  font-weight: 800;
  line-height: 24px;
  border: 0;
  border: solid 1px rgb(230, 232, 234);
  border-radius: 2px;
} */

/* ラジオボタン部分 */

/* .winning_prize {
  margin: 20px 0px 12px 0px;
  width: 100%;
  text-align: center;
  font-size: 16px;
  font-weight: 800;
  line-height: 24px;
}

.winner_information_title {
  width: 100%;
  text-align: left;
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}

.winner_information_text {
  margin: 0px 0px 12px 0px;
  width: 100%;
  text-align: left;
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}

.winner_information_caution {
  margin: 0px 0px 10px 6px;
  text-align: left;
  color: #000;
  font-size: 14px;
  line-height: 22px;
  letter-spacing: 0.8px;
  word-break: break-all;
}

.complete_text {
  margin: 0px 0px 12px 0px;
  width: 100%;
  text-align: left;
  font-size: 14px;
  font-weight: 800;
  line-height: 24px;
}


.textarea_wrapper textarea {
  width: 100%;
  resize: vertical;
}



.preview img {
  width: 100%;
}

oduct {
  padding: 0 28px;
}


.radio_button {
  text-align: left;
} */

/* フォーム周り */
/* .main-wrapper .content .box#recipt .title2 {
  margin: 5px 0px 0px 0px;
  text-align: center;
  color: #003187;
  font-size: 16px;
  font-weight: 800;
  line-height: 20px;
  letter-spacing: 1.2px;
}







.main-wrapper .content .about-us .description-02 {
  text-align: left;
  color: #fff;
  font-size: 14px;
  line-height: 20px;
  letter-spacing: 1.2px;
}


.form-item-03 {
  text-align: left;
  font-size: 16px;
  font-weight: bold;
}











/* パスワード再登録 */
/* .re-pw-register {
  margin: 80px 0 20px;
}

.box.re-pw-register .form-item-01 {
  font-size: 16px;
}

.box.re-pw-register .form-item-02 {
  font-size: 18px;
  font-weight: bold;
}

.main-wrapper .content #signin.re-pw-register .text {
  font-size: 14px;
  line-height: 24px;
}

.main-wrapper .content #signin.re-pw-register input {
  width: 100%;
} */

/* 賞品応募完了ページ */
/* .main-wrapper .content .box#recipt .point {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 12px;
}
.main-wrapper .content .box#point .point {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 12px;
} */


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

/* 履歴ページ */
/* .point_application th {
  text-align: center;
  vertical-align: middle !important;
}

.point_application td.status {
  text-align: center;
  vertical-align: middle !important;
}

.point_application td.status.prize {
  text-align: left;
}

.point_application .history-date {
  max-width:120px;
} */

/* インスタントウインの画像 */


.table tr th {
  text-align: center;
  vertical-align: middle !important;
}

.table tr td {
  text-align: center;
  vertical-align: middle !important;
}