html {
  font-size: 10px;
}
@media screen and (min-width: 768px) and (max-width: 1140px) {
  html {
    font-size: 0.8771929825vw;
  }
}
@media screen and (max-width: 450px) {
  html {
    font-size: 2.380952381vw;
  }
}

.ft_e {
  font-family: "bodoni-urw", serif;
}

.g_ft {
  font-family: "noto-sans", sans-serif;
  font-weight: 400;
}

i, em {
  font-style: normal;
}

@media screen and (min-width: 768px) {
  .u_visible_sp {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .u_visible_pc {
    display: none;
  }
}
.low {
  background: #E6E6E2;
  padding: 22rem 0 11.5rem;
  color: #231815;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  .low {
    padding: 12rem 0 7rem;
  }
}

.u_inner {
  width: 90rem;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .u_inner {
    width: auto;
    margin: 0 2rem;
  }
}

.c_ttl {
  text-align: center;
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: 0.02em;
  margin-bottom: 4rem;
}
.c_ttl i {
  font-weight: 400;
  display: block;
  font-size: 4.6rem;
  letter-spacing: 0.07em;
  line-height: 1;
  margin-bottom: 0.5em;
  position: relative;
  padding-bottom: 0.4em;
}
.c_ttl i:before {
  content: "";
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 0;
  border-bottom: solid 1px #707070;
  width: 1em;
}
.form input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
}
.form input[readonly], .form textarea[readonly], .form select[readonly] {
  border: none !important;
  background: #fff;
}
.form .lead {
  line-height: 1.78;
  font-size: 1.6rem;
  margin-bottom: 6rem;
}
@media screen and (min-width: 768px) {
  .form .lead {
    text-align: center;
  }
}
.form .step {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: #D9D9D9;
  margin: 5rem 0 7rem;
}
.form .step li:nth-child(1) {
  background: #666564;
  color: #fff;
}
.form .step li:nth-child(2):before {
  background: #D9D9D5;
}
.form .step li:nth-child(3) {
  background: #F2F2EE;
}
.form .step.b {
  background: #666564;
}
.form .step.b li:nth-child(1) {
  background: #F2F2EE;
  color: #231815;
}
.form .step.b li:nth-child(1):before {
  background: #F2F2EE;
}
.form .step.b li:nth-child(2) {
  color: #fff;
}
.form .step.b li:nth-child(2):before {
  background: #666564;
}
.form .step.b li:nth-child(3) {
  background: #D9D9D5;
}
.form .step.c {
  background: #F2F2EE;
}
.form .step.c li:nth-child(1) {
  background: #D9D9D5;
  color: #231815;
}
.form .step.c li:nth-child(1):before {
  background: #D9D9D5;
}
.form .step.c li:nth-child(2):before {
  background: #F2F2EE;
}
.form .step.c li:nth-child(3) {
  background: #666564;
  color: #fff;
}
.form .step li {
  font-size: 1.5rem;
  font-weight: 500;
  height: 5rem;
  color: #808080;
  width: 33.33%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .form .step li {
    font-size: 1.3rem;
    padding-left: 1em;
    height: 7rem;
    width: 30%;
  }
  .form .step li:nth-child(2) {
    width: 33%;
    padding-left: 1.7em;
  }
  .form .step li:nth-child(3) {
    width: 37%;
  }
}
.form .step li:before {
  content: "";
  position: absolute;
  background: #666564;
  height: 100%;
  right: 0.1rem;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  width: 1.8rem;
  top: 0;
  z-index: 1;
  -webkit-clip-path: polygon(100% 50%, 0 0, 0 100%);
          clip-path: polygon(100% 50%, 0 0, 0 100%);
}
.form .step li:nth-child(3):before {
  content: none;
}
.form table {
  width: 100%;
  margin-top: 5.5rem;
  border-top: solid 1px #D9D7D5;
}
.form th {
  text-align: left;
  position: relative;
  padding-top: 3em;
  font-weight: bold;
  width: 25rem;
  font-size: 1.7rem;
}
.form th em {
  color: #fff;
  padding: 0.25em 0.5em 0.1em;
  font-size: 1.6rem;
  background: #987B69;
  font-weight: 400;
  font-size: 1.2rem;
  position: absolute;
  right: 4rem;
  border-radius: 0.2rem;
  font-family: "noto-sans", sans-serif;
}
@media screen and (max-width: 767px) {
  .form th em {
    right: 0;
  }
}
.form th em.b {
  color: #666564;
  background: transparent;
  border: solid 1px #666564;
}
.form tr > * {
  vertical-align: top;
  font-size: 1.5rem;
  border-bottom: solid 1px #D9D7D5;
}
@media screen and (max-width: 767px) {
  .form tr > * {
    float: left;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .form th {
    border-bottom: none;
  }
}
.form td {
  padding: 2em 0;
  font-weight: 400;
  font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
  .form td {
    padding: 0.8em 0 2em;
    font-size: 1.3rem;
  }
}
.form td input[type=text], .form td input[type=email], .form td input[type=tel], .form td textarea, .form td select {
  width: 100%;
  border: solid 1px #E6E6E6;
  padding: 1em 1em 0.8em;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .form td input[type=text]::-webkit-input-placeholder, .form td input[type=email]::-webkit-input-placeholder, .form td input[type=tel]::-webkit-input-placeholder, .form td textarea::-webkit-input-placeholder, .form td select::-webkit-input-placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]::-moz-placeholder, .form td input[type=email]::-moz-placeholder, .form td input[type=tel]::-moz-placeholder, .form td textarea::-moz-placeholder, .form td select::-moz-placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]:-ms-input-placeholder, .form td input[type=email]:-ms-input-placeholder, .form td input[type=tel]:-ms-input-placeholder, .form td textarea:-ms-input-placeholder, .form td select:-ms-input-placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]::-ms-input-placeholder, .form td input[type=email]::-ms-input-placeholder, .form td input[type=tel]::-ms-input-placeholder, .form td textarea::-ms-input-placeholder, .form td select::-ms-input-placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]::placeholder, .form td input[type=email]::placeholder, .form td input[type=tel]::placeholder, .form td textarea::placeholder, .form td select::placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]:-ms-input-placeholder, .form td input[type=email]:-ms-input-placeholder, .form td input[type=tel]:-ms-input-placeholder, .form td textarea:-ms-input-placeholder, .form td select:-ms-input-placeholder {
    font-size: 1rem;
  }
  .form td input[type=text]::-ms-input-placeholder, .form td input[type=email]::-ms-input-placeholder, .form td input[type=tel]::-ms-input-placeholder, .form td textarea::-ms-input-placeholder, .form td select::-ms-input-placeholder {
    font-size: 12rem;
  }
}
.form td div {
  padding: 1.4rem 0;
}
.form td small {
  display: block;
  font-size: 1.2rem;
  margin: 1em 0 0.4em;
}
.form td textarea {
  height: 15em;
}
.form td .name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  white-space: nowrap;
  gap: 0 1.5em;
}
@media screen and (min-width: 768px) {
  .form td .name input {
    width: 13em;
    margin: 0 1em;
  }
}
@media screen and (max-width: 767px) {
  .form td .name label {
    width: 50%;
  }
  .form td .name input {
    width: calc(100% - 2em);
    margin-left: 1em;
  }
}
.form .formError {
  padding-top: 0.3em;
  color: #b94a48;
  font-size: 1.6rem;
}
.form input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #FFFBF8 inset;
}
.form .doui {
  text-align: center;
  font-size: 1.5rem;
  margin-top: 6rem;
}
.form .doui small {
  display: block;
  font-size: 1.2rem;
  color: #AB4100;
  margin-top: 0.6em;
}
.form .check input[type=checkbox] {
  position: absolute;
  opacity: 0;
}
.form .check input[type=checkbox]:checked + span:after {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0.35em;
  background: #036EB7;
  border-right: 0.3rem solid #fff;
  border-bottom: 0.3rem solid #fff;
  left: 0.45em;
  top: 0.45em;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 0.8rem;
  height: 1.2rem;
  background: none;
}
.form .check input[type=checkbox] + span {
  position: relative;
  padding-left: 2.2em;
  cursor: pointer;
  height: 2em;
  display: inline-block;
  line-height: 2;
}
.form .check input[type=checkbox] + span:before {
  content: "";
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  left: 0;
  width: 1.4em;
  height: 1.4em;
  background: #666564;
  border-radius: 0.2rem;
  border: solid 1px #C9C9C9;
}
.form label.error {
  color: #AB4100;
  display: block;
  font-size: 1.2rem;
  margin-top: 0.7em;
  display: block;
  font-family: "noto-sans", sans-serif;
  font-weight: 400;
}
.form .btn {
  margin-top: 6rem;
  text-align: center;
}
.form .btn ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .form .btn {
    margin-top: 3.5rem;
  }
}
.form .btn.b {
  /*display: none;*/
}
.form .btn li {
  width: 40rem;
}
@media screen and (max-width: 767px) {
  .form .btn li {
    width: 100%;
  }
}
.form .btn input {
  cursor: pointer;
  width: 100%;
  border: none;
  background: #666564;
  color: #fff;
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 8rem;
  border-radius: 0.2rem;
}
@media screen and (max-width: 767px) {
  .form .btn input {
    font-size: 1.5rem;
  }
}
.form .btn #back {
  color: #231815;
  background-color: #CAC7C5;
}
.form td .label {
  display: none;
}
.form .ttl {
  text-align: center;
  font-size: 2.4rem;
  letter-spacing: 0.02em;
}
.form .ttl.b {
  display: none;
}
.form.confirm .doui {
  display: none;
}
.form.confirm .note {
  display: none;
}
.form.confirm th {
  padding: 2em 0;
}
.form.confirm .ttl.a {
  display: none;
}
.form.confirm .ttl.b {
  display: block;
}
.form.confirm td * {
  display: none;
}
.form.confirm td .label {
  display: block;
}
.form.confirm td .label br {
  display: block;
}

.thanks {
  text-align: center;
}
.thanks .ttl {
  margin-bottom: 1em;
}
.thanks .msg {
  font-size: 1.6rem;
  line-height: 2.1875;
}
.thanks .btn {
  margin-top: 4.5rem;
}
.thanks .btn span {
  font-weight: bold;
}

#powered_by_me {
  color: #999;
  display: block;
  text-align: right;
  margin-top: 3rem;
  font-size: 10px;
}

form .alert-danger {
  color: #AB4100;
  margin-top: 0.5em;
}

#error_message {
  color: #AB4100;
  text-align: center;
  border: 1px solid #AB4100;
  line-height: 2;
  margin-top: 2em;
}