@charset "UTF-8";

* {
  line-height: 1.5;
  font-family: 'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans','ヒラギノ角ゴシック','游ゴシック体',YuGothic,'游ゴシック','Yu Gothic','メイリオ',Meiryo,'Noto Sans JP','ＭＳ Ｐゴシック','MS PGothic',Geneva,Arial,Verdana,sans-serif;
  font-weight: 700;
}

:root {
  --primaryColor: #1d1f85;
  --secondaryColor: #8ed3f5;
  --btnMainColor: #f00;
  --btnSubColor: #0070c0;
  --btnGoTopColor: #ff3399;
}

.primaryBtn {
  background-color: var(--btnMainColor);
  margin: 20px auto 0;
  padding: 12px 0px;
  border: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  display: block;
  width: 100%;
  text-decoration: none;
}

.secondaryBtn {
  background-color: var(--btnSubColor);
  margin: 20px auto 0;
  padding: 12px 0px;
  border: none;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  display: block;
  width: 100%;
  text-decoration: none;
}

body {
  width: 100%;
  margin: auto;
  background-color: var(--secondaryColor);;
}

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 {
  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;
  background-color: #fff;
}

.main-wrapper .nav-sp img {
  display: block;
  height: 30px;
  margin: 6px;
}

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



.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;
  background: var(--secondaryColor);
  font-family: Quicksand, 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  /* iPhoneバンドル */
  width: 100%;
  transition: all .5s ease;
  z-index: 2;
}

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

.kv img {
  width: 100%;
}

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

.block .title {
  position: relative;
  background: var(--primaryColor);
  margin: 0;
  border: 1px solid var(--primaryColor);
  padding: 8px 20px;
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  border-radius: 12px 12px 0 0;
}

.contents_wrapper {
  padding: 16px;
}

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

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


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


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

.prize_name {
  text-align: center;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  background: linear-gradient(transparent 60% , yellow 50%);
  display: inline;
}

.prize_name.a-shou {
  color: #e63078;
}

.prize_name.b-shou {
  color: #22b7d9;
}

.prize_name.c-shou {
  color: #35b158;
}

.lottery_number {
  font-size: 18px;
  font-weight: bold;
  border: 2px solid;
  display: inline-block;
  margin: 16px auto auto;
  padding: 4px 20px;
  border-radius: 100px;
}

.lottery_number.a-shou {
  color: #e63078;
  border-color: #e63078;
}

.lottery_number.b-shou {
  color: #22b7d9;
  border-color: #22b7d9;
}

.lottery_number.c-shou {
  color: #35b158;
  border-color: #35b158;
}

/* .prize_point {
  text-align: center;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.5;
  background: linear-gradient(transparent 60%, yellow 50%);
  display: inline;
} */

.prize_point {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  font-weight: 900;
  margin: 10px 0 0;
  padding: 8px 26px;
  font-size: 20px;
  color: #fff;
  letter-spacing: 0.05em;
  border-radius: 100px;
}

/* 左のポイントバッジ */
.prize_point::before{
  width: 40px;
  height: 40px;
  background: #fff;
  font-size: 22px;
  font-weight: 900;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 6px rgba(0,0,0,0.2);
}
.prize_point::after {
  content:"✦";
  position:absolute;
  right:-10px;
  top:-8px;
  font-size:20px;
  color:#ffd700;
}


.prize_point.a-shou {
  background: linear-gradient(135deg, #ff6b9a, #e63078);
  box-shadow: 0 6px 0 #d92c5c, 0 10px 20px rgba(0, 0, 0, 0.15);
}

.prize_point.a-shou::before {
  content:"5";
  color:#e63078;
}

.prize_point.b-shou {
  background: linear-gradient(135deg, #41c2df, #22b7d9);
  box-shadow: 0 6px 0 #22b7d9, 0 10px 20px rgba(0, 0, 0, 0.15);
}

.prize_point.b-shou::before {
  content:"10";
  color:#22b7d9;
}

.prize_point.c-shou {
  background: linear-gradient(135deg, #5bd37d, #35b158);
  box-shadow: 0 6px 0 #35b158, 0 10px 20px rgba(0, 0, 0, 0.15);
}

.prize_point.c-shou::before {
  content:"15";
  color:#35b158;
}


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

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

.prize_img_wrapper img {
  width: 100%;
}

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

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


.abc_warapper {
  padding: 4px;
  font-weight: bold;
  color: #fff;
  font-size: 16px;
  border-radius: 999px;
  margin: 4px auto 16px;
  outline-offset: 2px;
}

.abc_warapper.a-shou {
  background-color: #e63078;
  border: solid 1px #e63078;
  outline: solid 3px #e63078;
  margin-top: 8px;
}

.abc_warapper.b-shou {
  background-color: #22b7d9;
  border: solid 1px #22b7d9;
  outline: solid 3px #22b7d9;
}

.abc_warapper.c-shou {
  background-color: #35b158;
  border: solid 1px #35b158;
  outline: solid 3px #35b158;
}

.prize_caution_text {
  font-size: 14px;
  text-align: left;
  text-indent: -1em;
  margin: auto auto 4px 1em;
}

.entry_button {
  display:block;
  width: 100%;
  max-width:520px;
  margin:25px auto 40px;
  padding:12px 30px 12px 30px;

  background:#2f69a3;
  color:#ffd84a;
  font-weight:900;
  font-size:24px;
  text-align:center;
  text-decoration:none;

  border:4px solid #ffd84a;
  border-radius:22px;

  position:relative;

  box-shadow:0 6px 0 rgba(0,0,0,0.2);

  letter-spacing:0.05em;
}

.entry_button::after{
  content:"▶";
  position:absolute;
  right:24px;
  top:50%;
  transform:translateY(-50%);
  font-size:24px;
}

/* hover */
.entry_button:hover{
  transform:translateY(3px);
  box-shadow:0 3px 0 rgba(0,0,0,0.2);
}

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

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

.products_img_wrapper img {
  width: 100%;
}

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

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

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



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

.accordion_menu-btn {
  text-align: center;
  background: var(--primaryColor);
  font-weight: bold;
  color: #fff;
  margin: 20px auto 0;
  padding: 12px 0;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  position: relative;
  cursor: pointer;
  border-radius: 12px;
  z-index: 200;
}

.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 {
  margin-bottom: 20px;
}

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

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

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

.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: 60px 8px 1px 8px;
  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;
}

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

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

.notes_text {
  margin-bottom: 8px;
  line-height: 1.5;
  padding: 0 8px;
}

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

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


/* 事務局 */
.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: #fff;
  border: 4px solid #fff;
}

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

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

.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 {
  text-align: center;
  background-color: var(--seconryColor);
  color: var(--primaryColor);
  font-size: 12px;
  width: 100%;
  padding: 12px 0;
}

#pageTop {
  position: fixed;
  bottom: 36px;
  right: 20px;
  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;
  }
}

.copyright_link_wrapper {
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 12px 4px;
  gap: 32px;
  color: #8a8f8d;
}

.copyright_link {
  display: flex;
  justify-content: center;
  align-items: center;
}

.copyright_link .fa-angle-right {
  margin-right: 4px;
}


/* アップロードページ */
.main_contents_wrapper {
  position: relative;
  width: 92%;
  margin: 60px auto 0;
  padding: 60px 16px 20px;
  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;
}

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

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

.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 {
  margin: 12px 0px 36px;
  padding: 12px 0px;
  background-color: var(--btnMainColor);
  border: 1px solid var(--btnMainColor);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  line-height: 1.5;
}

.goto_top_btn {
  background-color: var(--btnGoTopColor);
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  margin: auto auto 10px;
}

.goto_top_btn a {
  padding: 12px 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: #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: var(--primaryColor);
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  margin: auto auto 10px;
  padding: 12px 8px;
  display: block;
  width: 100%;
  color: #fff;
  border: none;
}

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

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

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

.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: #dcf3ff;
  color: var(--primaryColor);
  border: 2px solid #3874ff;
  font-weight: bold;
  font-size: 16px;
  width: 100%;
  border-radius: 6px;
  box-shadow: 2px 2px 0px #3874ff;
}

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



/* フォーム入力確認画面 */
.form_confirm_input {
  text-align: left;
  font-size: 16px;
  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: 16px 20px;
  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: 20px 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: var(--btnMainColor);
}

/* .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;
  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;
  margin-bottom: 6px;
}

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

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

.account-name span {
  font-size: 22px;
}

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

.confirm_point {
  max-width:420px;
  margin:30px auto;
  padding:22px 20px 0;

  background:linear-gradient(135deg,#fff7d6,#ffe48a);
  border:4px solid #ffcc33;
  border-radius:20px;

  text-align:center;

  box-shadow:0 6px 0 #e6b800, 0 12px 20px rgba(0,0,0,0.15);

  position:relative;
}

/* 上バッジ */
.confirm_point::before{
  content:"あなたのポイント";
  position:absolute;
  top:-14px;
  left:50%;
  transform:translateX(-50%);
  background:#ffcc33;
  color:#8a5a00;
  font-weight:900;
  font-size:14px;
  padding:6px 14px;
  border-radius:20px;
}

.point-text{
  font-size:18px;
  font-weight:700;
  color:#8a5a00;
  line-height:1.5;
  margin-top: 10px;
}

/* ポイント数字 */
.point-text span{
  display:inline-block;
  font-size:40px;
  font-weight:900;
  color:#ff6b00;
  margin:0 6px;

  text-shadow:
    0 3px 0 #ffffff,
    0 5px 10px rgba(0,0,0,0.2);
}



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

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

.receipt_send_btn {
  display:block;
  max-width:520px;
  margin:30px auto;
  padding:6px 26px;

  background:linear-gradient(135deg,#ff9a3c,#ff7a00);
  color:#fff;
  font-size:20px;
  font-weight:900;
  text-align:center;
  text-decoration:none;

  border-radius:16px;

  box-shadow:
    0 6px 0 #d65e00,
    0 12px 20px rgba(0,0,0,0.15);

  position:relative;

  letter-spacing:0.05em;

  transition:all .15s ease;
}

/* hover */
.receipt_send_btn:hover{
  transform:translateY(3px);
  box-shadow:
    0 3px 0 #d65e00,
    0 6px 12px rgba(0,0,0,0.15);
}
/* .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 {
  display:block;
  max-width:520px;
  margin:12px auto;
  padding:14px 24px;

  background:#f3f6fb;
  color:#2f69a3;
  font-size:18px;
  font-weight:700;
  text-align:center;
  text-decoration:none;

  border:3px solid #2f69a3;
  border-radius:14px;

  box-shadow:0 3px 0 rgba(0,0,0,0.12);

  transition:all .15s ease;
}

.receipt_send_btn.history:hover{
  background:#e6eef8;
  transform:translateY(2px);
  box-shadow:0 1px 0 rgba(0,0,0,0.12);
}


/* 履歴ページ */
.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;
}


/* ポイント不足エラーページ */
.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: auto;
  padding: 12px 8px;
  background: #2004b1;
  border: 2px solid #2004b1;
  border-radius: 12px;
  box-shadow: 0px 6px 0px #a4beff;
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  display: block;
  margin-bottom: 40px;
}

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

.entry_confirm_text {
  font-size: 16px;
}

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

.entry_prize_name.a-shou {
  color: #e63078;
}

.entry_prize_name.b-shou {
  color: #22b7d9;
}

.entry_prize_name.c-shou {
  color: #35b158;
}


.entry_prize_number {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 4px;
}

.entry_prize_number.a-shou {
  color: #e63078;
}

.entry_prize_number.b-shou {
  color: #22b7d9;
}

.entry_prize_number.c-shou {
  color: #35b158;
}

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

.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;
  border: 1px solid var(--primaryColor);
  padding: 6px 0;
  border-radius: 100px;
  color: var(--primaryColor);
  margin: 24px auto;
}


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

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


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

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

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

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

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

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

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



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

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

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

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

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


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

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


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


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

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

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

.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;
  margin-bottom: 20px;
}

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

.sns_login_btn img {
  width: 100%;
}


.entry_method {
  padding: 20px 0 32px;
}


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



/* モーダルで対象商品表示 */
/* 開くボタン */
.button-open {
  display: block;
  margin: 20px auto;
  width: 100%;
  padding: 14px;
  background-color: #000;
  color: #fff;
  cursor: pointer;
  font-size: 16px;
  text-align: center;
}
/* モーダルウィンドウ */
.modal-window {
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
  height: auto;
  max-height: 95%;
  background-color: #fff;
  border-radius: 5px;
  z-index: 11;
  padding: 1.2rem;
  overflow: scroll;
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.modal-window.show {
  display: block;
  opacity: 1;
  animation: fadeInUp 0.3s ease forwards;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate(-50%, -45%);
  }
  to {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
}

/* 閉じるボタン */
.button-close {
  width: 90%;
  padding: 1em;
  background-color: #000;
  color: #fff;
  cursor: pointer;
  text-align: center;
  font-size: 14px;
  padding: 8px;
  margin: 32px auto 20px;
}
/* オーバーレイ */
.overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  width: 100%;
  height: 100%;
  z-index: 10;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.overlay.show {
  display: block;
  opacity: 1;
}

.modal-table td {
    border: 1px solid #000;
    padding: 4px;
    font-size: 12px;
}


.colabo-title {
  display: inline-block;
  background: linear-gradient(135deg, #ff3b6b, #ff3b6b);
  color: #fff;
  font-weight: 700;
  font-size: 22px;
  padding: 8px 26px;
  border-radius: 999px;
  position: relative;
  letter-spacing: 0.05em;
  box-shadow: 0 4px 0 #e66a8f, 0 6px 12px rgba(0, 0, 0, 0.15);
  margin: 25px auto 0;
  z-index: 100;
}

.colabo-title::before {
  content: "数量限定";
  position: absolute;
  top: -24px;
  left: -20px;
  background: #FFEB3B;
  color: #ff3b6b;
  font-size: 18px;
  padding: 4px 10px;
  border-radius: 6px;
  transform: rotate(-8deg);
  font-weight: bold;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
}





.campaign-head{
  display:flex;
  align-items:center;
  justify-content:space-around;
  background:#ffd1dc;
  border-radius: 10px 10px 0 0;
  padding:14px 18px;
  margin:40px 0 0;
  box-shadow:0 3px 0 rgba(0,0,0,0.15);
}

/* 第1弾バッジ */
.campaign-badge{
  background:#ff3b6b;
  color:#fff;
  font-weight:700;
  font-size:28px;
  padding:8px 16px;
  border-radius:8px;
  display:flex;
  align-items:flex-end;
  gap:3px;
  line-height:1;
}

/* 1を最大 */
.campaign-badge .num{
  font-size:46px;
  font-weight:900;
  line-height:0.9;
}

/* 日付 */
.campaign-date{
  font-size: 18px;
  font-weight: 700;
  color: #d6336c;
  text-align: left;
  line-height: 1.4;
}











.brand-title{
  background: linear-gradient(135deg, #1d1f85, #3562c4);
  color: #fff;
  font-size: 19px;
  font-weight: 700;
  text-align: center;
  padding: 12px 12px;
  margin: 50px 0 16px;
  border-radius: 8px;
  letter-spacing: 0.05em;
  position: relative;
  box-shadow: 0 4px 0 rgba(0,0,0,0.15);
}

/* 下の三角（ブランド一覧への導線） */
.brand-title::after{
  content:"";
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  bottom:-10px;
  width:0;
  height:0;
  border-left:10px solid transparent;
  border-right:10px solid transparent;
  border-top:10px solid #1f268b;
}






















.colabo-date {
  text-align: center;
  font-weight: bold;
  margin: 20px 0 20px;
  line-height: 1.2;
}

.colabo-date::first-line {
  font-size: 38px;
  color: #ff4f7a;
  letter-spacing: 0.05em;
}

.colabo-date span.num {
  font-size: 60px;
  color: #ff2e63;
  font-weight: 900;
}

/* 日付部分 */
.colabo-date small {
  display: block;
  font-size: 16px;
  color: #555;
}

/* 下の区切りライン（賞品画像の導入） */
.colabo-date::after {
  content: "";
  display: block;
  width: 120px;
  height: 6px;
  margin: 18px auto 0;
  background: linear-gradient(90deg,#ff6b9a,#ffd166,#ff6b9a);
  border-radius: 10px;
}


.colaboration_product_brand_wrapper {
  background-color: #fffcdd;
  padding: 12px;
  border-radius: 20px;
  margin-bottom: 12px;
  transform: translateY(-24px);
}


.colaboration_product_img_wrapper {
  display: flex;
  width: 100%;
  justify-content: space-between;
  background-color: #fff;
  padding: 8px;
}

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


.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  z-index: 9999;
  align-items: center;
  justify-content: center;
}

.modal-overlay.active {
  display: flex;
}

.modal-content {
  position: relative;
}

.modal-overlay img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 4px;
}

/* 閉じるボタン */
.modal-close {
  position: absolute;
  top: -10px;
  right: -10px;
  background: var(--secondaryColor);
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-size: 20px;
  cursor: pointer;
  line-height: 36px;
  text-align: center;
  color: #fff;
}


.brandlist_BG {
  background-color: #d4f1ff;
  padding: 12px;
  border-radius: 20px;
  margin-bottom: 12px;
  margin-top: 24px;
}

.brandlist_wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 20px;
}

.brandlist_wrapper a {
  width: calc(50% - 4px);
  border: 1px solid #000;
  padding: 6px;
  background-color: #fff;
}

.brandlist_wrapper a img {
  width: 100%;
}


.btn_wrapper {
  display: flex;
  width: 92%;
  justify-content: space-around;
  margin: auto;
}

.btn_wrapper .img_wrapper {
  width: 45%;
}

.btn_wrapper .img_wrapper img {
  width: 100%;
}






.section-title {
  text-align: center;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin: 0px auto;
  padding: 16px 0 0;
}

/* ===== CARD ===== */
.prize-card {
  position: relative;
  border-radius: 24px;
  padding: 0 0 28px;
  margin-bottom: 32px;
  overflow: visible;
}

/* color themes */
.prize-card.a { background: #e7317d; }
.prize-card.b { background: #12b8d7; }
.prize-card.c { background: #41b25d;margin-bottom: 0px; }

/* ===== BADGE (grade label) ===== */
.grade-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 72px;
  border-radius: 20px 20px 0 0;
}
.grade-badge span {
  color: #fff;
  font-size: 44px;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1;
}

/* ===== POINT BUBBLE ===== */
.point-bubble {
  position: absolute;
  top: 6px;
  right: -6px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 3px solid #fff;
  line-height: 1.2;
  z-index: 10;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
}
.point-bubble .pt-num {
  font-size: 32px;
  font-weight: 900;
  color: #e7317d;
  line-height: 1;
}
.point-bubble .pt-text {
  font-size: 11px;
  font-weight: 700;
  color: #e7317d;
  text-align: center;
  line-height: 1.3;
}
.prize-card.b .point-bubble .pt-num,
.prize-card.b .point-bubble .pt-text { color: #12b8d7; }
.prize-card.c .point-bubble .pt-num,
.prize-card.c .point-bubble .pt-text { color: #41b25d; }

.point-bubble { background: #fff; }

/* ===== INNER WHITE CARD ===== */
.inner-card {
  background: #fff;
  border-radius: 18px;
  margin: 0 12px;
  padding: 18px 16px 4px;
}

.prize-name {
  text-align: center;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 10px;
}
.prize-card.a .prize-name {
  color: #e7317d;
}
.prize-card.b .prize-name {
  color: #12b8d7;
}
.prize-card.c .prize-name {
  color: #41b25d;
}

/* lottery count pill */
.lottery-pill {
  display: inline-block;
  border-radius: 20px;
  padding: 4px 18px;
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  margin: 0 auto 12px;
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 12px;
}
.prize-card.a .lottery-pill { background: #e7317d; }
.prize-card.b .lottery-pill { background: #12b8d7; }
.prize-card.c .lottery-pill { background: #41b25d; }

.prize-description {
  font-size: 12px;
  color: #333;
  line-height: 1.7;
  margin-bottom: 14px;
}

.prize-img-wrapper {
  background: #f8f0e8;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 14px;
  min-height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.prize-img-wrapper img {
  width: 100%;
  height: auto;
  display: block;
}
.prize-img-wrapper .img-placeholder {
  color: #bbb;
  font-size: 13px;
  text-align: center;
  padding: 40px 20px;
}

.notes {
  font-size: 11px;
  color: #666;
  line-height: 1.8;
}

a.entry_button {
  display: block;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  border-radius: 50px;
  padding: 14px 0;
  margin: 20px auto;
  letter-spacing: 0.1em;
}
.prize-card.a a.entry_button { background: #e7317d; }
.prize-card.b a.entry_button { background: #12b8d7; }
.prize-card.c a.entry_button { background: #41b25d; }