/* ------------------------------
 width: all
------------------------------ */
main {
  padding-top: 150px;
}
main section {
  width: 1200px;
  margin: 0 auto;
  padding: 100px 0;
  background-image: url(../../images/preregister/s0201.webp);
  background-size: 200% auto;
  background-position: center center;
}
main section + section {
  margin-top: 100px;
}
main section.s01 .wrapper .mypage {
  max-width: 980px;
  margin: 0 auto;
  color: #fff;
  opacity: 0;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
  -webkit-transition: opacity 0.35s ease, -webkit-transform 0.35s ease;
  transition: opacity 0.35s ease, -webkit-transform 0.35s ease;
  transition: opacity 0.35s ease, transform 0.35s ease;
  transition: opacity 0.35s ease, transform 0.35s ease, -webkit-transform 0.35s ease;
}
main section.s01 .wrapper .mypage .mypage_head {
  margin-bottom: 36px;
}
main section.s01 .wrapper .mypage .mypage_head .mypage_label {
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: #ffd400;
}
main section.s01 .wrapper .mypage .mypage_head h1 {
  margin: 0 0 16px;
  font-size: 40px;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #fff;
  text-shadow: 0 0 18px rgba(246, 211, 107, 0.35), 0 3px 0 rgba(0, 0, 0, 0.75);
}
main section.s01 .wrapper .mypage .mypage_head p {
  margin: 0;
  font-size: 15px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.82);
}
main section.s01 .wrapper .mypage .mypage_status {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr) 22px minmax(0, 1fr);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-bottom: 38px;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card {
  position: relative;
  overflow: hidden;
  min-height: 170px;
  padding: 28px 28px 24px;
  border: 1px solid #555;
  background-color: #000;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card p {
  position: relative;
  z-index: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 0 14px;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.08em;
  color: #000;
  background-color: #ffd400;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card .mypage_medal_value {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  gap: 6px;
  margin-bottom: 10px;
  line-height: 1.1;
  color: #fff;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card .mypage_medal_value .mypage_medal_num {
  display: inline-block;
  font-family: "clother", sans-serif;
  font-size: 52px;
  line-height: 1;
  letter-spacing: -2px;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card .mypage_medal_value .mypage_medal_unit {
  display: inline-block;
  font-size: 20px;
  line-height: 1;
  color: #fff;
}
main section.s01 .wrapper .mypage .mypage_status .mypage_status_card > span {
  position: relative;
  z-index: 1;
  display: block;
  font-size: 13px;
  line-height: 1.7;
  color: #fff;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block {
  margin-top: 30px;
  padding: 32px 34px;
  border: 1px solid #555;
  background-color: #000;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block h2 {
  margin: 0 0 12px;
  padding-bottom: 12px;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.5;
  border-bottom: 1px solid #555;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_block_text {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 1.8;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list {
  display: -ms-grid;
  display: grid;
  gap: 22px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item label {
  display: block;
  margin-bottom: 8px;
  font-size: 15px;
  font-weight: 500;
  color: #fff;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item label span {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 7px;
  font-size: 11px;
  line-height: 1.4;
  color: #fff;
  background-color: #8e1111;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input,
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select {
  width: 100%;
  padding: 13px 14px;
  font-size: 15px;
  line-height: 1.6;
  color: #fff;
  background-color: #222;
  outline: none;
  border: none !important;
  font-weight: 400 !important;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input::-webkit-input-placeholder, main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.42);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input::-moz-placeholder, main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select::-moz-placeholder {
  color: rgba(255, 255, 255, 0.42);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input:-ms-input-placeholder, main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select:-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.42);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input::-ms-input-placeholder, main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.42);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input::placeholder,
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select::placeholder {
  color: rgba(255, 255, 255, 0.42);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #ffd400 50%), linear-gradient(135deg, #ffd400 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item p {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.62);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate .mypage_birthdate_field {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate select {
  width: auto;
  min-width: 96px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate .is_month select,
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate .is_day select {
  min-width: 76px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate .mypage_birthdate_unit {
  font-size: 14px;
  color: #fff;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item .mypage_birthdate_note.is_minor {
  color: #ffcf5b;
  font-weight: 500;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
  padding: 18px 20px;
  background: rgba(255, 255, 255, 0.045);
  border: 1px solid rgba(225, 176, 75, 0.28);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_campaign_status p {
  margin: 0 0 4px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.68);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_campaign_status strong {
  display: block;
  font-size: 18px;
  font-weight: 500;
  color: #ffd400;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_x_link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 150px;
  padding: 11px 18px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 50px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_x_link:hover {
  -webkit-filter: brightness(1.06);
          filter: brightness(1.06);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 16px;
  margin-top: 34px;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_save_btn,
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_logout_btn {
  min-width: 180px;
  padding: 12px 30px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
  cursor: pointer;
  -webkit-transition: -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-filter 0.2s ease;
  transition: -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-filter 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-filter 0.2s ease;
  border: none !important;
  outline: none;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_save_btn {
  border: 1px solid #ffd400 !important;
  background-color: #ffd400;
  color: #000;
  font-weight: bold;
  display: block;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_save_btn:hover {
  -webkit-filter: brightness(1.06);
          filter: brightness(1.06);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_logout_btn {
  border: 1px solid #666 !important;
  color: #fff;
  background-color: #000;
  font-weight: bold;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_logout_btn:hover {
  border-color: rgba(246, 211, 107, 0.55);
}
main section.s01 .wrapper .mypage .mypage_form .mypage_message {
  min-height: 1.7em;
  margin: 18px 0 0;
  font-size: 14px;
  line-height: 1.7;
  text-align: center;
  color: #ffd400;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_message.is_error {
  color: #ff5b5b;
}
main section.s01 .wrapper .mypage .mypage_form .mypage_message.is_success {
  color: #ffd400;
}
body.is_page_ready main section.s01 .wrapper .mypage {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/* ------------------------------
 width < $width-1
------------------------------ */
@media screen and (max-width: 860px) {
  main {
    padding: 60px 20px 0;
  }
  main section {
    width: 100%;
    margin: 0 auto;
    padding: 50px 20px;
    background-size: cover;
  }
  main section + section {
    margin-top: 50px;
  }
  main section.s01 .wrapper .mypage .mypage_head {
    margin-bottom: 28px;
    text-align: left;
  }
  main section.s01 .wrapper .mypage .mypage_head .mypage_label {
    font-size: 12px;
  }
  main section.s01 .wrapper .mypage .mypage_head h1 {
    font-size: 24px;
  }
  main section.s01 .wrapper .mypage .mypage_head p {
    font-size: 14px;
  }
  main section.s01 .wrapper .mypage .mypage_status {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 24px;
  }
  main section.s01 .wrapper .mypage .mypage_status .mypage_status_card {
    min-height: 150px;
    padding: 22px 18px;
  }
  main section.s01 .wrapper .mypage .mypage_status .mypage_status_card .mypage_medal_value .mypage_medal_num {
    font-size: 38px;
  }
  main section.s01 .wrapper .mypage .mypage_status .mypage_status_card .mypage_medal_value .mypage_medal_unit {
    font-size: 18px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block {
    margin-top: 24px;
    padding: 22px 18px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block h2 {
    font-size: 18px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_block_text {
    margin-bottom: 20px;
    font-size: 13px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list {
    gap: 20px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item label {
    font-size: 14px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item input,
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_form_list .mypage_form_item select {
    padding: 12px;
    font-size: 16px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign {
    display: block;
    padding: 16px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_campaign_status {
    margin-bottom: 14px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_block .mypage_campaign .mypage_x_link {
    width: 130px;
    min-width: 0;
    padding: 5px 0;
    font-size: 14px;
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_actions {
    display: block;
    margin-top: 28px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_save_btn,
  main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_logout_btn {
    width: 160px;
    margin: 0 auto;
    min-width: 0;
    padding: 11px 0;
    font-size: 14px;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_actions .mypage_logout_btn {
    margin: 20px auto 0 !important;
    display: block !important;
  }
  main section.s01 .wrapper .mypage .mypage_form .mypage_message {
    font-size: 13px;
    text-align: left;
  }
}