@charset "UTF-8";
/**
 * メディアクエリ
 * @param {string} $mode - max または min
 * @param {number} $width - 設定値
 */
/**
 * メディアクエリ PC
 * @param {number} [$width:$breakpoin] - 設定値
 */
/**
 * メディアクエリ SP
 * @param {number} [$width:$breakpoin] - 設定値
 */
/**
 * メディアクエリによるIE11ハック
 */
/**
 * VW計算
 * @param {string} $property  - プロパティ
 * @param {number} $value - 基準となる値
 * @param {number} $basewidth - 基準となるウィンドウ幅
 * @param {number} [$maxwidth:0] - 拡大を停止するウィンドウ幅
 * @param {number} [$minwidth:0] - 縮小を停止するウィンドウ幅
 */
@media screen and (min-width: 1025px) {
  .p50th-special-form {
    padding-block: 120px 140px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form {
    padding-top: 18.6666666667vw;
    padding-bottom: 40vw;
  }
}
.p50th-special-form .form-head {
  text-align: center;
}
.p50th-special-form .form-head .form-title .form-title-image {
  margin-inline: auto;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-head .form-title .form-title-image {
    width: 250px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-head .form-title .form-title-image {
    width: 53.3333333333vw;
  }
}
.p50th-special-form .form-head .form-title .form-title-text {
  font-weight: 800;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-head .form-title .form-title-text {
    font-size: 40px;
    margin-top: 10px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-head .form-title .form-title-text {
    font-size: 8vw;
    margin-top: 2.6666666667vw;
  }
}
.p50th-special-form .form-head .form-head-text {
  line-height: 1.7;
  font-weight: 600;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-head .form-head-text {
    font-size: 14px;
    margin-top: 25px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-head .form-head-text {
    margin-top: 5.3333333333vw;
    padding-inline: 6.6666666667vw;
  }
}
.p50th-special-form .form-head .form-head-text small {
  display: block;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-head .form-head-text small {
    font-size: 13px;
    margin-top: 6px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-head .form-head-text small {
    font-size: 3.2vw;
    margin-top: 5.3333333333vw;
  }
}
.p50th-special-form .form-content {
  max-width: 1000px;
  margin-inline: auto;
  background-color: #fff;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content {
    padding: 100px;
    margin-top: 70px;
    border-radius: 50px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content {
    padding-block: 13.3333333333vw;
    padding-inline: 5.3333333333vw;
    margin-inline: 4vw;
    margin-top: 8vw;
    border-radius: 30px;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content:has(.form-input) {
    margin-top: 40px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content:has(.form-done) {
    padding-inline: initial;
  }
}
.p50th-special-form .form-content .form-flow {
  display: flex;
  justify-content: center;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content .form-flow {
    margin-bottom: 60px;
    gap: 120px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content .form-flow {
    margin-bottom: 16vw;
    gap: 12vw;
  }
}
.p50th-special-form .form-content .form-flow::before {
  content: "";
  display: block;
  position: absolute;
  top: 25%;
  left: 50%;
  transform: translateX(-50%);
  height: 2px;
  background-image: linear-gradient(to right, #A4BCD8 5px, transparent 5px);
  background-size: 10px 2px;
  background-repeat: repeat-x;
  background-position: left top;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content .form-flow::before {
    width: 43%;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content .form-flow::before {
    width: 52%;
  }
}
.p50th-special-form .form-content .form-flow li {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-weight: bold;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #A4BCD8;
  position: relative;
  z-index: 2;
  white-space: nowrap;
  background-color: #fff;
  box-sizing: content-box;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content .form-flow li {
    font-size: 15px;
    width: 40px;
    padding-inline: 7px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content .form-flow li {
    font-size: 4vw;
    width: 10.6666666667vw;
    padding-inline: 1.6vw;
  }
}
.p50th-special-form .form-content .form-flow li.active {
  color: #20569F;
}
.p50th-special-form .form-content .form-flow li.active span {
  background-color: #20569F;
}
.p50th-special-form .form-content .form-flow li span {
  width: 100%;
  border-radius: 50%;
  background-color: #A4BCD8;
  color: #fff;
  display: grid;
  place-content: center;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content .form-flow li span {
    height: 40px;
    margin-bottom: 10px;
    font-size: 20px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content .form-flow li span {
    height: 10.6666666667vw;
    margin-bottom: 2.6666666667vw;
    font-size: 5.3333333333vw;
  }
}
.p50th-special-form .form-content .form-btn-wrap {
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-content .form-btn-wrap {
    margin-top: 60px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-content .form-btn-wrap {
    margin-top: 10.6666666667vw;
  }
}
.p50th-special-form .form-input .input-title {
  text-align: center;
  font-weight: bold;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-title {
    font-size: 22px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-title {
    font-size: 4.5333333333vw;
  }
}
.p50th-special-form .form-input .input-text {
  text-align: center;
  font-weight: 500;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-text {
    margin-top: 10px;
    font-size: 14px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-text {
    margin-top: 3.2vw;
    line-height: 1.7;
  }
}
.p50th-special-form .form-input .error-text {
  color: #F00C0C;
  line-height: 1.75;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .error-text {
    margin-top: 10px;
    font-size: 13px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .error-text {
    margin-top: 2.6666666667vw;
    font-size: 3.4666666667vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-character {
    margin-top: 30px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-character {
    margin-top: 4.8vw;
  }
}
.p50th-special-form .form-input .input-character .character-radio {
  display: grid;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-character .character-radio {
    grid-template-columns: repeat(6, 1fr);
    gap: 15px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-character .character-radio {
    grid-template-columns: repeat(3, 1fr);
    gap: 2.6666666667vw;
  }
}
.p50th-special-form .form-input .input-character .character-label {
  border: 2px solid #ebebeb;
  border-radius: 10px;
  font-weight: 800;
  font-family: "M PLUS Rounded 1c", sans-serif;
  text-align: center;
  display: flex;
  flex-direction: column;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-character .character-label {
    font-size: 13px;
    height: 120px;
    padding-block: 12px 5px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-character .character-label {
    font-size: 2.6666666667vw;
    height: 25.3333333333vw;
    padding-top: 2.4vw;
    padding-bottom: 1.3333333333vw;
  }
}
.p50th-special-form .form-input .input-character .character-label::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border: 3px solid #20569f;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 10px;
  opacity: 0;
}
.p50th-special-form .form-input .input-character .character-label:has(.character-input:checked)::after {
  opacity: 1;
}
.p50th-special-form .form-input .input-character .character-image {
  margin-top: auto;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-character .character-image {
    padding-inline: 10px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-character .character-image {
    padding-inline: 2.1333333333vw;
  }
}
.p50th-special-form .form-input .input-mail {
  background-color: #FEFBE0;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail {
    margin-top: 60px;
    padding-block: 50px;
    padding-inline: 50px;
    border-radius: 30px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail {
    margin-top: 10.6666666667vw;
    padding-top: 9.0666666667vw;
    padding-bottom: 12vw;
    padding-inline: 5.3333333333vw;
    border-radius: 20px;
  }
}
.p50th-special-form .form-input .input-mail .mail-title {
  text-align: center;
  font-weight: bold;
  position: relative;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-title {
    font-size: 20px;
    padding-bottom: 25px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-title {
    font-size: 4.5333333333vw;
    padding-bottom: 6.6666666667vw;
    line-height: 1.5;
  }
}
.p50th-special-form .form-input .input-mail .mail-title::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-image: linear-gradient(to right, #FFC97E 5px, transparent 5px);
  background-size: 10px 2px;
  background-repeat: repeat-x;
  background-position: left top;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-wrap {
    margin-top: 25px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-wrap {
    margin-top: 6.6666666667vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-wrap a {
  text-decoration: underline;
}
.p50th-special-form .form-input .input-mail .mail-text {
  text-align: center;
}
.p50th-special-form .form-input .input-mail .mail-text p {
  font-weight: 600;
  line-height: 1.7;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-text p {
    font-size: 14px;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-note {
    margin-top: 15px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-note {
    margin-top: 5.3333333333vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-note.mail-note-top {
  display: inline-block;
  text-align: left;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-note.mail-note-bottom {
    padding-left: 150px;
  }
}
.p50th-special-form .form-input .input-mail .mail-note li {
  font-weight: 500px;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.6;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-note li {
    font-size: 11px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-note li {
    font-size: 3.2vw;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-note li:not(:first-child) {
    margin-top: 2.6666666667vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-input {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: 40px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-input {
    margin-top: 12vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-input label {
  font-weight: bold;
  color: #20569F;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-input label {
    font-size: 14px;
    gap: 5px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-input label {
    gap: 1.6vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-input label span {
  display: block;
  background-color: #20569F;
  color: #fff;
  border-radius: 2px;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-input label span {
    font-size: 10px;
    padding: 4px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-input label span {
    font-size: 2.6666666667vw;
    padding: 1.0666666667vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-input input {
  display: block;
  border-radius: 4px;
  border: 1px solid #ffc97e;
  background-color: #fff;
  width: 100%;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-input .input-mail .mail-input input {
    font-size: 14px;
    padding: 10px 14px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-input .input-mail .mail-input input {
    padding-inline: 4.8vw;
    padding-block: 3.7333333333vw;
    margin-top: 2.1333333333vw;
  }
}
.p50th-special-form .form-input .input-mail .mail-input input::-moz-placeholder {
  color: rgba(32, 86, 159, 0.3);
}
.p50th-special-form .form-input .input-mail .mail-input input::placeholder {
  color: rgba(32, 86, 159, 0.3);
}
.p50th-special-form .form-conf {
  text-align: center;
}
.p50th-special-form .form-conf dt {
  font-weight: bold;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf dt {
    font-size: 18px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf dt {
    font-size: 4.5333333333vw;
  }
}
.p50th-special-form .form-conf .conf-character dd {
  border-radius: 15px;
  border: 3px solid #20569f;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .conf-character dd {
    width: 200px;
    height: 200px;
    margin-top: 18px;
    padding-block: 20px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .conf-character dd {
    width: 32vw;
    height: 32vw;
    margin-top: 4vw;
    padding-top: 3.7333333333vw;
    padding-bottom: 2.6666666667vw;
  }
}
.p50th-special-form .form-conf .conf-character dd span {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 800;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .conf-character dd span {
    font-size: 21px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .conf-character dd span {
    font-size: 3.4666666667vw;
  }
}
.p50th-special-form .form-conf .conf-character dd img {
  margin-top: auto;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .conf-character dd img {
    padding-inline: 25px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .conf-character dd img {
    padding-inline: 2.6666666667vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .conf-mail {
    margin-top: 40px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .conf-mail {
    margin-top: 8vw;
  }
}
.p50th-special-form .form-conf .conf-mail.data-none {
  display: none;
}
.p50th-special-form .form-conf .conf-mail dd {
  font-weight: 500;
  overflow-wrap: break-word;
  line-height: 1.3;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .conf-mail dd {
    margin-top: 8px;
    font-size: 16px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .conf-mail dd {
    margin-top: 2.1333333333vw;
    font-size: 4vw;
  }
}
.p50th-special-form .form-conf .form-back-btn {
  cursor: pointer;
  display: flex;
  align-items: center;
  margin-inline: auto;
  font-family: "M PLUS Rounded 1c", sans-serif;
  color: #205599;
  font-weight: 800;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .form-back-btn {
    gap: 7px;
    margin-top: 35px;
    font-size: 18px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .form-back-btn {
    gap: 1.8666666667vw;
    margin-top: 8vw;
    font-size: 4.2666666667vw;
  }
}
.p50th-special-form .form-conf .form-back-btn span {
  text-decoration: underline;
  text-decoration-thickness: 2px; /* 線の太さ */
  text-underline-offset: 7px;
}
.p50th-special-form .form-conf .form-back-btn .form-icon-circle {
  background-color: #205599;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .form-back-btn .form-icon-circle {
    width: 44px;
    height: 44px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .form-back-btn .form-icon-circle {
    width: 8vw;
    height: 8vw;
  }
}
.p50th-special-form .form-conf .form-back-btn .form-icon-circle i::before {
  color: #fff;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-conf .form-back-btn .form-icon-circle i::before {
    font-size: 18px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-conf .form-back-btn .form-icon-circle i::before {
    font-size: 3.2vw;
  }
}
.p50th-special-form .form-done .done-text {
  font-weight: bold;
  text-align: center;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-text {
    font-size: 18px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-text {
    font-size: 4.5333333333vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns {
    margin-top: 60px;
    padding-top: 65px;
    height: 430px;
    background: url("/50th/assets/img/form/done-bg.png") no-repeat center/cover;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns {
    margin-top: 10.6666666667vw;
    padding-top: 13.3333333333vw;
    height: 110.1333333333vw;
    background: url("/50th/assets/img/form/done-bg.sp.png") no-repeat center/cover;
  }
}
.p50th-special-form .form-done .done-sns .done-sns-title {
  font-weight: 800;
  text-align: center;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns .done-sns-title {
    font-size: 30px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns .done-sns-title {
    font-size: 5.8666666667vw;
  }
}
.p50th-special-form .form-done .done-sns-link {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link {
    margin-top: 30px;
    gap: 25px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link {
    margin-top: 3.7333333333vw;
    gap: 5.3333333333vw;
  }
}
.p50th-special-form .form-done .done-sns-link li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 3px solid #20569f;
  border-radius: 10px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link li a {
    width: 94px;
    height: 94px;
    box-shadow: 3px 3px 0px 3px #20569f;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link li a {
    width: 18.9333333333vw;
    height: 18.9333333333vw;
    box-shadow: 2px 2px 0px 2px #20569f;
  }
}
@media (hover: hover) and (pointer: fine) {
  .p50th-special-form .form-done .done-sns-link li a:hover {
    transform: translate(5px, 5px);
    box-shadow: 0px 0px 0px 0px;
  }
}
.p50th-special-form .form-done .done-sns-link li a span {
  font-weight: 800;
  font-family: "M PLUS Rounded 1c", sans-serif;
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link li a span {
    margin-top: 5px;
    font-size: 9px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link li a span {
    margin-top: 1.3333333333vw;
    font-size: 2.4vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-x img {
    width: 32px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-x img {
    width: 6.4vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-line img {
    width: 48px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-line img {
    width: 10.4vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-url img {
    width: 31px;
  }
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .done-sns-link li .done-sns-url img {
    width: 5.8666666667vw;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-btn {
    display: flex;
    justify-content: center;
    gap: 30px;
  }
}
@media screen and (min-width: 1025px) {
  .p50th-special-form .form-done .done-btn a {
    margin-inline: initial;
  }
}
.p50th-special-form .form-done .text-special {
  background-color: #FC871D;
  box-shadow: 5px 5px 0px 5px #ED6D00;
}
@media screen and (max-width: 1024px) {
  .p50th-special-form .form-done .text-special {
    margin-top: 6.6666666667vw;
  }
}