/* ======================================================================
 form
====================================================================== */
html, body {
  overscroll-behavior: none;
}

body {
  padding-top: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font: inherit;
}

img {
  vertical-align: bottom;
}

input,
button,
textarea,
select,
input[type=email],
input[type=password],
input[type=tel],
input[type=text] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-family: inherit;
  border-radius: 0;
  box-sizing: border-box;
  font-size: inherit;
  color: inherit;
  padding: 0;
  height: auto;
  line-height: normal;
  border: inherit;
}

a {
  color: #0000ff;
  text-decoration: underline;
}

select::-ms-expand {
  display: none;
}

label {
  cursor: pointer;
}

.bold500 {
  font-weight: 500;
}

.bold700 {
  font-weight: 700;
}

.bold900 {
  font-weight: 900;
}

.sp {
  display: none !important;
}

@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }

  .pc {
    display: none !important;
  }
}

#header {
  padding: 18px 30px;
}

@media screen and (max-width: 767px) {
  #header {
    padding: 15px;
  }
}

#header h1 {
  width: 285px;
}

@media screen and (max-width: 767px) {
  #header h1 {
    width: 193px;
  }
}

#header h1 img {
  width: 100%;
}

.form_mv {
  font-weight: 700;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #e7f5f7;
  height: 130px;
  font-size: 36px;
}

@media screen and (max-width: 1100px) {
  .form_mv {
    height: 11.8181818182vw;
    font-size: 3.2727272727vw;
  }
}

@media screen and (max-width: 767px) {
  .form_mv {
    height: 75px;
    font-size: 20px;
  }
}

.form_inner {
  font-size: 0.9090909091vw;
  letter-spacing: normal;
  text-align: left;
  margin: 0 auto;
  width: 96%;
  max-width: 1100px;
  padding-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .form_inner {
    width: 100%;
    padding-bottom: 25px;
  }
}

.form_step {
  display: flex;
  justify-content: space-between;
  background-position: 0 0;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .form_step {
    margin-top: 0;
    height: 90px;
    align-items: center;
    justify-content: center;
  }
}

.form_step._step01 {
  background-image: url(/img/form/step01.png);
}

.form_step._step02 {
  background-image: url(/img/form/step02.png);
}

.form_step._step03 {
  background-image: url(/img/form/step03.png);
}

.form_step._step04 {
  background-image: url(/img/form/step04.png);
}

.form_step._step05 {
  background-image: url(/img/form/step05.png);
}

.form_step._contact .form_step_box {
  width: 33.3333333333%;
}

.form_step._contact._step01 {
  background-image: url(/img/form/contact_step01.png);
}

.form_step._contact._step02 {
  background-image: url(/img/form/contact_step02.png);
}

.form_step._contact._step03 {
  background-image: url(/img/form/contact_step03.png);
}

.form_step_box {
  box-sizing: border-box;
  color: #FFF;
  font-weight: 700;
  width: 20%;
  padding: 9px 14px;
  font-size: 18px;
  line-height: 1.3;
}

@media screen and (max-width: 1100px) {
  .form_step_box {
    padding: 0.8181818182vw 1.2727272727vw;
    font-size: 1.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_step_box {
    font-size: 11px;
    padding: 0 0 0 10px;
  }
}

.form_step_box:nth-child(3) {
  padding: 9px 14px 9px 30px;
}

@media screen and (max-width: 1100px) {
  .form_step_box:nth-child(3) {
    padding: 0.8181818182vw 1.2727272727vw 0.8181818182vw 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_step_box:nth-child(3) {
    padding: 0 0 0 15px;
  }
}

.form_step_box:nth-child(4) {
  padding: 9px 14px 9px 40px;
}

@media screen and (max-width: 1100px) {
  .form_step_box:nth-child(4) {
    padding: 0.8181818182vw 1.2727272727vw 0.8181818182vw 3.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_step_box:nth-child(4) {
    padding: 0 0 0 20px;
  }
}

.form_step_box:last-child {
  padding: 9px 14px 9px 50px;
}

@media screen and (max-width: 1100px) {
  .form_step_box:last-child {
    padding: 0.8181818182vw 1.2727272727vw 0.8181818182vw 4.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_step_box:last-child {
    padding: 0 0 0 20px;
  }
}

.form_txt {
  margin-top: 20px;
  font-size: 18px;
  line-height: 1.5;
}

@media screen and (max-width: 1100px) {
  .form_txt {
    margin-top: 1.8181818182vw;
    font-size: 1.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_txt {
    margin: 10px 15px;
    font-size: 15px;
  }
}

.form_txt .form_required {
  transform: scale(0.8);
}

.form_txt .form_att_ttl {
  box-sizing: border-box;
  text-align: center;
  border: 2px solid #dd0000;
  margin-top: 5px;
  padding: 5px;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.3;
}

@media screen and (max-width: 1100px) {
  .form_txt .form_att_ttl {
    font-size: 2.121212122vw;
    padding: 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_txt .form_att_ttl {
    font-size: 14px;
    line-height: 1.3;
  }
}

.form_txt .form_att_ttl span {
  color: #dd0000;
  font-size: 35px;
}

@media screen and (max-width: 1100px) {
  .form_txt .form_att_ttl span {
    font-size: 3.3090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_txt .form_att_ttl span {
    font-size: 20px;
  }
}

.form_required {
  box-sizing: border-box;
  font-weight: normal;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #FFF;
  background: #ea1d1d;
  font-size: 16px;
  line-height: 25px;
  width: 54px;
  height: 25px;
  padding: 0 10px;
  margin-right: 10px;
}

@media screen and (max-width: 1100px) {
  .form_required {
    width: 7.9090909091vw;
    height: 2.2727272727vw;
    font-size: 1.4545454545vw;
    padding: 0 0.9090909091vw;
    margin-right: 5px;
  }
}

@media screen and (max-width: 767px) {
  .form_required {
    width: 50px;
    height: 20px;
    font-size: 12px;
    line-height: 19px;
    padding: 2px 7px 1px;
  }
}

.form_optional {
  box-sizing: border-box;
  font-weight: normal;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #FFF;
  background: #636363;
  font-size: 16px;
  line-height: 25px;
  width: 54px;
  height: 25px;
  padding: 0 10px;
  margin-right: 10px;
}

@media screen and (max-width: 1100px) {
  .form_optional {
    width: 7.9090909091vw;
    height: 2.2727272727vw;
    font-size: 1.4545454545vw;
    padding: 0 0.9090909091vw;
    margin-right: 5px;
  }
}

@media screen and (max-width: 767px) {
  .form_optional {
    width: 50px;
    height: 20px;
    font-size: 12px;
    line-height: 19px;
    padding: 2px 7px 1px;
  }
}

.form_ttl {
  font-weight: 700;
  text-align: center;
  background: #e7f5f7;
  font-size: 30px;
  padding: 8px;
  margin-top: 30px;
}

@media screen and (max-width: 1100px) {
  .form_ttl {
    font-size: 2.7272727273vw;
    padding: 0.7272727273vw;
    margin-top: 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_ttl {
    margin-top: 10px;
    font-size: 18px;
    padding: 4px;
  }
}

@media screen and (max-width: 767px) {
  .form_list {
    margin: 0 15px;
  }
}

.form_list+.form_ttl {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .form_list+.form_ttl {
    margin-top: 25px;
  }
}

.form_list_box {
  display: flex;
  align-items: baseline;
  margin: 30px auto 10px;
}

@media screen and (max-width: 1100px) {
  .form_list_box {
    margin: 2.7272727273vw auto 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_box {
    display: block;
    margin: 15px auto 10px;
  }
}

.form_list_box table {
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  .form_list_box table {
    width: 100%;
    border-bottom: 2px solid #cecece;
  }
}

.form_list_box table th,
.form_list_box table td {
  border: 2px solid #cecece;
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .form_list_box table th,
  .form_list_box table td {
    display: block;
    padding: 5px;
    font-size: 10px;
  }
}

@media screen and (max-width: 767px) {
  .form_list_box table th.form_list_scroll_table_box,
  .form_list_box table td.form_list_scroll_table_box {
    display: table-cell;
    width: auto;
    letter-spacing: 0.2em;
  }
}

.form_list_box table th {
  background: #f5f5f5;
  width: 30%;
}

@media screen and (max-width: 767px) {
  .form_list_box table th {
    width: 100%;
    border-bottom: none;
  }
}

@media screen and (max-width: 767px) {
  .form_list_box table td {
    width: 100%;
    border-bottom: none;
  }
}

.q_modal_icon {
  position: relative;
}

.qBox {
  margin-left: 1.5em;
}

.q_modal_icon:before {
  position: absolute;
  content: "";
  width: 14px;
  height: 14px;
  line-height: 14px;
  text-align: center;
  margin-top: 0.4em;
  background: url("../../img/estimate/modal_trigger_icon.svg") no-repeat;
  background-size: contain;
}

.form_list_ttl {
  font-weight: 700;
  font-size: 19px;
  width: 35%;
  max-width: 305px;
  display: flex;
  line-height: 1.3;
  padding-top: 5px;
}

@media screen and (max-width: 1100px) {
  .form_list_ttl {
    font-size: 1.7272727273vw;
    max-width: 27.7272727273vw;
    width: 30%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_ttl {
    font-size: 15px;
    width: 100%;
    max-width: none;
    padding-top: 0;
  }
}

@media screen and (max-width: 767px) {
  .form_list_ttl .form_required,
  .form_list_ttl .form_optional {
    margin-right: 10px;
  }
}

.form_list_ttl_txt {
  width: 230px;
}

@media screen and (max-width: 1100px) {
  .form_list_ttl_txt {
    width: 40.0909090909vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_ttl_txt {
    width: 90%;
  }
}

.form_list_ttl._none {
  text-indent: -1em;
  padding-left: 1em;
}

.form_list_desc {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  font-size: 19px;
  width: 80%;
  max-width: 850px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc {
    font-size: 1.7272727273vw;
    max-width: 77.2727272727vw;
    width: 76%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc {
    width: auto;
    max-width: none;
    font-size: 15px;
    margin: 5px 0 0 57px;
  }
}

.form_list_desc .form_list_txt._broder {
  border: 3px solid #cecece;
  padding: 5px;
  margin-bottom: 5px;
  font-size: 105%;
}

@media screen and (max-width: 767px) {
  .form_list_desc._name {
    justify-content: space-between;
  }
}

.form_list_desc._name .form_list_txt {
  width: 70px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc._name .form_list_txt {
    width: 6.3636363636vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._name .form_list_txt {
    width: 22%;
  }
}

.form_list_desc._name .form_list_label {
  margin-right: 40px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._name .form_list_label {
    margin-right: 0;
    width: 49%;
  }
}

.form_list_desc._name .form_list_input {
  width: 265px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc._name .form_list_input {
    width: 21.0909090909vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._name .form_list_input {
    width: 78%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._birthday {
    justify-content: space-between;
  }
}

.form_list_desc._birthday .form_list_label {
  margin-right: 30px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc._birthday .form_list_label {
    margin-right: 2.4545454545vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._birthday .form_list_label {
    margin-right: 0;
    width: 31%;
  }
}

.form_list_desc._birthday .form_list_select {
  width: 150px;
  margin-right: 10px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc._birthday .form_list_select {
    width: 14.6363636364vw;
    margin-right: 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._birthday .form_list_select {
    width: 100%;
    margin-right: 5px;
    padding: 3px 10px;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._nendai {
    justify-content: space-between;
  }
}

.form_list_desc._nendai .form_list_label {
  margin-right: 30px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._nendai .form_list_label {
    margin-right: 0;
    width: 100%;
  }
}

.form_list_desc._nendai .form_list_select {
  width: 220px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._nendai .form_list_select {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._companyphone .form_list_tel {
    margin: 0;
    padding-top: 0;
  }
}

.form_list_desc._mail .form_list_cap {
  margin-top: -20px;
}

@media screen and (max-width: 1100px) {
  .form_list_desc._mail .form_list_cap {
    margin-top: -1.8181818182vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._mail .form_list_cap {
    margin-top: 0;
    position: static;
  }
}

.form_list_desc._year .form_list_input {
  width: 40%;
  margin-right: 10px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._year .form_list_input {
    width: 55%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._year .form_list_address {
    margin-top: 5px;
  }
}

.form_list_desc._year .form_list_cap+.form_list_cap {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._year .form_list_cap+.form_list_cap {
    position: static;
    margin-top: 10px;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._grade {
    margin-top: 0;
    padding-top: 0;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._addressflag {
    padding-top: 20px;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._spouse .form_list_radiobox {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._spouse .form_list_label:not(:nth-child(2n)) {
    margin-right: 0;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._spouse .form_list_txt {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._info .form_list_txt {
    font-size: 11px;
    line-height: 1.3;
  }
}

.form_list_desc._info .form_list_cap {
  margin-top: 5px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._info .form_list_cap {
    position: static;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._profession .form_list_cap {
    position: static;
  }
}

.form_list_desc._number .form_list_input {
  width: 220px;
}

@media screen and (max-width: 767px) {
  .form_list_desc._number .form_list_input {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_desc._privacy .form_list_label {
    width: auto;
  }
}

.form_list_desc._company .form_list_input {
  width: 95%;
}

.form_list_label {
  display: flex;
  align-items: center;
}

.form_list input[type=email],
.form_list input[type=password] input[type=password],
.form_list input[type=tel],
.form_list input[type=text],
.form_list textarea,
.form_list select {
  border: 2px solid #cecece;
  padding: 7px 10px;
  margin: 0;
}

@media screen and (max-width: 1100px) {
  .form_list input[type=email],
  .form_list input[type=password] input[type=password],
  .form_list input[type=tel],
  .form_list input[type=text],
  .form_list textarea,
  .form_list select {
    padding: 1.0636363636vw 0.9090909091vw;
  }
}

.form_list_tel {
  display: flex;
  align-items: center;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .form_list_tel {
    position: relative;
    justify-content: space-between;
    margin-bottom: 0;
  }
}

.form_list_tel_ttl {
  width: 100px;
}

@media screen and (max-width: 767px) {
  .form_list_tel_ttl {
    width: auto;
    position: absolute;
    top: 0;
    left: 0;
  }
}

.form_list_tel input[type=tel],
.form_list_tel input[type=text] {
  width: 150px;
}

@media screen and (max-width: 1100px) {
  .form_list_tel input[type=tel],
  .form_list_tel input[type=text] {
    width: 18.1818181818vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_tel input[type=tel],
  .form_list_tel input[type=text] {
    width: 30%;
    margin: 0;
  }
}

.form_list_cap {
  font-size: 15px;
  line-height: 1.3;
}

@media screen and (max-width: 1100px) {
  .form_list_cap {
    font-size: 1.3636363636vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_cap {
    font-size: 12px;
    line-height: 1.3;
    width: 100%;
  }
}

.form_list_cap+.form_list_address {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .form_list_cap+.form_list_address {
    margin-top: 0;
  }
}

.form_list_mail {
  width: 100%;
  margin-bottom: 30px;
}

@media screen and (max-width: 1100px) {
  .form_list_mail {
    margin-bottom: 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_mail {
    margin-bottom: 5px;
  }
}

.form_list_mail_ttl {
  font-weight: 700;
  position: absolute;
  left: -200px;
  bottom: 40px;
}

@media screen and (max-width: 1100px) {
  .form_list_mail_ttl {
    left: -18.1818181818vw;
    bottom: 3.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_mail_ttl {
    position: static;
  }
}

.form_list_radio_btn {
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: 25px;
  background-image: url(/img/form/radio_off.svg);
  padding-left: 40px;
  margin-right: 50px;
}

@media screen and (max-width: 1100px) {
  .form_list_radio_btn {
    background-size: 2.2727272727vw;
    padding-left: 3.6363636364vw;
    margin-right: 4.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_radio_btn {
    background-size: 17px;
    padding-left: 25px;
    margin-right: 0;
  }
}

.form_list_radio:checked+.form_list_radio_btn {
  background-image: url(/img/form/radio_on.svg);
}

.form_list_radiobox {
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .form_list_radiobox .form_list_label {
    width: 48.5%;
    border: 2px solid #cecece;
    padding: 1px 10px;
    margin-top: 5px;
  }

  .form_list_radiobox .form_list_label:not(:nth-child(2n)) {
    margin-right: 3%;
  }
}

.form_list_radiobox .form_list_txt {
  width: 120px;
}

.form_list_check_btn {
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-size: 28px;
  background-image: url(/img/form/check_off.svg);
  padding-left: 40px;
  margin-right: 50px;
}

@media screen and (max-width: 1100px) {
  .form_list_check_btn {
    padding-left: 3.6363636364vw;
    margin-right: 4.5454545455vw;
    background-size: 2.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_check_btn {
    background-size: 17px;
    padding-left: 25px;
    margin-right: 0;
  }
}

.form_list_check:checked+.form_list_check_btn {
  background-image: url(/img/form/check_on.svg);
}

.form_list_checkbox {
  width: 100%;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

@media screen and (max-width: 767px) {
  .form_list_checkbox .form_list_label {
    width: 48.5%;
    border: 2px solid #cecece;
    background: #eeeeee;
    padding: 1px 10px;
    margin-top: 5px;
  }

  .form_list_checkbox .form_list_label:not(:nth-child(2n)) {
    margin-right: 3%;
  }
}

.form_list_checkbox .form_list_txt {
  width: 120px;
}

.form_list_checkbox._disabled {
  color: #cecece;
  pointer-events: none;
}

.form_list_select {
  background: #FFF url(/img/form/select.svg) no-repeat 95% 50%;
  background-size: 15px;
  width: 75%;
}

@media screen and (max-width: 1100px) {
  .form_list_select {
    background-size: 1.3636363636vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_select {
    background-size: 10px;
  }
}

.form_list_address {
  display: flex;
}

@media screen and (max-width: 767px) {
  .form_list_address {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address._zip .form_list_label {
    display: flex;
    flex-wrap: wrap;
  }
}

.form_list_address._zip .form_list_input {
  width: 300px;
}

@media screen and (max-width: 767px) {
  .form_list_address._zip .form_list_input {
    width: 70%;
    margin: 0;
  }
}

.form_list_address._zip .form_list_input._01 {
  width: 60px;
  margin-right: 5px;
}

@media screen and (max-width: 1100px) {
  .form_list_address._zip .form_list_input._01 {
    width: 5.4545454545vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address._zip .form_list_input._01 {
    width: 30%;
  }
}

.form_list_address._zip .form_list_input._02 {
  width: 70px;
  margin-left: 5px;
}

@media screen and (max-width: 767px) {
  .form_list_address._zip .form_list_input._02 {
    width: 38%;
  }
}

.form_list_address._zip .form_list_btn {
  color: #FFF;
  background: #636363;
  width: 120px;
  height: 39px;
  margin-left: 20px;
}

@media screen and (max-width: 1100px) {
  .form_list_address._zip .form_list_btn {
    width: 10.9090909091vw;
    height: 3.5454545455vw;
    margin-left: 1.8181818182vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address._zip .form_list_btn {
    margin: 0;
    width: 26%;
    height: 32px;
  }
}

.form_list_address:not(:last-child) {
  margin-bottom: 20px;
}

@media screen and (max-width: 1100px) {
  .form_list_address:not(:last-child) {
    margin-bottom: 2.2727272723vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address:not(:last-child) {
    margin-bottom: 5px;
  }
}

.form_list_address .form_list_txt {
  width: 160px;
}

@media screen and (max-width: 1100px) {
  .form_list_address .form_list_txt {
    width: 14.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address .form_list_txt {
    width: 100%;
  }
}

.form_list_address .form_list_input {
  width: 440px;
}

@media screen and (max-width: 1100px) {
  .form_list_address .form_list_input {
    width: 40vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address .form_list_input {
    width: 100%;
  }
}

.form_list_address .form_list_select {
  width: 370px;
}

@media screen and (max-width: 1100px) {
  .form_list_address .form_list_select {
    width: 35vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address .form_list_select {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .form_list_address .form_list_label {
    display: block;
  }
}

.form_list_family {
  display: flex;
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .form_list_family {
    margin-top: 5px;
  }
}

.form_list_family .form_list_label {
  margin-right: 30px;
}

@media screen and (max-width: 767px) {
  .form_list_family .form_list_label {
    display: block;
    padding-right: 20px;
  }
}

.form_list_family .form_list_input {
  width: 120px;
  margin: 0 10px !important;
}

@media screen and (max-width: 767px) {
  .form_list_family .form_list_input {
    width: 85px;
    margin: 0 !important;
  }
}

@media screen and (max-width: 767px) {
  .form_list_family .form_list_txt {
    display: block;
  }
}

.form_list_textarea {
  height: 200px;
}

@media screen and (max-width: 767px) {
  .form_list_textarea {
    height: 125px;
  }
}

.form_list_att {
  color: #ea1d1d;
}

@media screen and (max-width: 767px) {
  .form_list_att {
    font-size: 10px;
  }
}

.form_list_scroll {
  overflow-y: scroll;
  border: 2px solid #cecece;
  padding: 10px;
  height: 320px;
  margin: 10px 0;
}

@media screen and (max-width: 1100px) {
  .form_list_scroll {
    padding: 0.9090909091vw;
    height: 30.1818181818vw;
    margin: 0.9090909091vw 0;
  }
}

@media screen and (max-width: 767px) {
  .form_list_scroll {
    height: 220px;
    line-height: 1.5;
    margin: 5px 0;
  }
}

.form_list_scroll_ttl {
  font-size: 22px;
  font-weight: bold;
  padding: 10px 5px;
  margin-bottom: 20px;
  border-bottom: 2px;
  position: relative;
}

.form_list_scroll_ttl:before {
  z-index: 2;
  width: 120px;
  height: 5px;
  border-radius: 15px;
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #666;
}

.form_list_scroll_ttl:after {
  z-index: 1;
  width: 100%;
  height: 5px;
  border-radius: 15px;
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #d7d7d7;
}

@media screen and (max-width: 1100px) {
  .form_list_scroll_ttl {
    font-size: 2vw;
  }
}

@media screen and (max-width: 767px) {
  .form_list_scroll_ttl {
    font-size: 13px;
    margin-bottom: 5px;
  }
}

.form_list_scroll_txt {
  margin-bottom: 1em;
}

@media screen and (max-width: 767px) {
  .form_list_scroll_txt {
    font-size: 11px;
  }
}

.form_list_scroll_table {
  border: 2px solid #cecece;
}

.form_list_scroll_table_box {
  border: 2px solid #cecece;
  padding: 5px;
}

.form_list_scroll_table_box:not(:first-child) {
  width: 22%;
}

.form_list_dash {
  margin: 0 10px;
}

.form_btn {
  text-align: center;
  margin-top: 50px;
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .form_btn {
    margin: 25px 15px 0;
  }
}

.form_btn._step01 .form_btn_submit {
  width: 700px;
}

@media screen and (max-width: 1100px) {
  .form_btn._step01 .form_btn_submit {
    width: 63.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_btn._step01 .form_btn_submit {
    width: 68%;
  }
}

.form_btn._step04 {
  display: block;
}

.form_btn._step04 .form_btn_submit {
  display: block;
  margin: 0 auto;
  width: 700px;
}

@media screen and (max-width: 1100px) {
  .form_btn._step04 .form_btn_submit {
    width: 63.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_btn._step04 .form_btn_submit {
    width: 100%;
  }
}

.form_btn._confirm {
  display: block;
}

.form_btn_submit {
  transition: all 0.2s ease-in-out;
  font-weight: 700;
  color: #FFF;
  background: #ea1d1d;
  box-shadow: 8px 8px 16px 0px rgba(0, 0, 0, 0.2);
  border-radius: 12px;
  font-size: 24px;
  width: 66%;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}

@media screen and (max-width: 1100px) {
  .form_btn_submit {
    font-size: 2.1818181818vw;
    height: 6.3636363636vw;
  }
}

@media screen and (max-width: 767px) {
  .form_btn_submit {
    border-radius: 6px;
    width: 66%;
    height: 60px;
    font-size: 20px;
  }
}

.form_btn_submit:hover {
  opacity: 0.75;
}

.form_btn_submit:disabled {
  opacity: 1;
  cursor: inherit;
  background: #5b5b5b;
}

.form_btn_back {
  transition: all 0.2s ease-in-out;
  font-weight: 700;
  color: #000;
  background: #FFF url(/img/form/back.svg) no-repeat 5% 50%;
  border: 2px solid #5b5b5b;
  box-shadow: 8px 8px 16px 0px rgba(0, 0, 0, 0.2);
  border-radius: 12px;
  font-size: 24px;
  width: 30%;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 1100px) {
  .form_btn_back {
    font-size: 2.1818181818vw;
    background-size: 1.0909090909vw;
    height: 6.3636363636vw;
  }
}

@media screen and (max-width: 767px) {
  .form_btn_back {
    background-position: 10px 50%;
    background-size: 6px;
    border-radius: 6px;
    width: 30%;
    height: 60px;
    font-size: 20px;
  }
}

.form_btn_back:hover {
  opacity: 0.75;
}

.form_btn_txt {
  background: url(/img/form/next.svg) no-repeat 100% 7px;
  background-size: 6px;
  text-decoration: underline;
  padding-right: 15px;
  margin: 20px 0;
  font-size: 14px;
  display: inline-block;
}

@media screen and (max-width: 767px) {
  .form_btn_txt {
    margin: 15px 0;
  }
}

.form_btn_txt:hover {
  text-decoration: none;
}

.form_done_ttl {
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  font-size: 25px;
  margin: 20px 0 10px;
}

@media screen and (max-width: 1100px) {
  .form_done_ttl {
    font-size: 2.2727272727vw;
    margin: 1.8181818182vw 0 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_done_ttl {
    font-size: 15px;
    margin: 20px 0 10px;
  }
}

.form_done_txt {
  text-align: center;
  line-height: 1.5;
  font-size: 14px;
  margin-bottom: 20px;
}

@media screen and (max-width: 1100px) {
  .form_done_txt {
    font-size: 1.2727272727vw;
    margin-bottom: 1.8181818182vw;
  }
}

@media screen and (max-width: 767px) {
  .form_done_txt {
    font-size: 11px;
    margin-bottom: 15px;
  }
}

.form_done_txt span {
  font-size: 30px;
}

@media screen and (max-width: 1100px) {
  .form_done_txt span {
    font-size: 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_done_txt span {
    font-size: 18px;
  }
}

.form_done_txt a {
  font-size: 20px;
}

@media screen and (max-width: 1100px) {
  .form_done_txt a {
    font-size: 2.0272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_done_txt a {
    font-size: 15px;
  }
}

.add-error {
  background: #fae3e3 !important;
}

textarea[geom-cc=yellow][geom-ss=circle],
input:not([type=radio]):not([type=checkbox])[geom-cc=yellow][geom-ss=circle] {
  background: #ddecfd !important;
}

input[type=text]:disabled,
select:disabled {
  background: #eee;
}

/* ======================================================================
 form_cushion
====================================================================== */
.form_cushion {
  width: 90%;
  margin: 0 auto;
  max-width: 1100px;
  padding-bottom: 50px;
}

@media screen and (max-width: 1100px) {
  .form_cushion {
    padding-bottom: 4.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion {
    box-sizing: border-box;
    width: 100%;
    padding: 0 15px 25px;
  }
}

.form_cushion_att {
  box-sizing: border-box;
  text-align: center;
  border: 2px solid #dd0000;
  margin-top: 50px;
  padding: 5px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_att {
    margin-top: 4.5454545455vw;
    padding: 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_att {
    margin-top: 20px;
  }
}

.form_cushion_att_ttl {
  font-weight: 700;
  font-size: 26.5px;
  line-height: 1.3;
}

@media screen and (max-width: 1100px) {
  .form_cushion_att_ttl {
    font-size: 2.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_att_ttl {
    font-size: 16px;
  }
}

.form_cushion_att_ttl span {
  color: #dd0000;
  font-size: 36.4px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_att_ttl span {
    font-size: 3.3090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_att_ttl span {
    font-size: 21.2px;
  }
}

.form_cushion_att_txt {
  font-size: 18px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_att_txt {
    font-size: 1.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_att_txt {
    text-align: left;
    font-size: 16px;
    line-height: 1.3;
    margin-top: 5px;
  }
}

.form_cushion_list_box {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .form_cushion_list_box {
    margin-top: 30px;
  }
}

.form_cushion_list_ttl {
  font-weight: 700;
  text-align: center;
  border-bottom: 2px solid #8ecec7;
  font-size: 30px;
  margin-bottom: 20px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_ttl {
    font-size: 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_ttl {
    text-align: left;
    font-size: 20px;
  }
}

.form_cushion_list_flow {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow {
    display: block;
  }
}

.form_cushion_list_flow_box {
  position: relative;
  text-align: center;
  width: 20%;
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow_box {
    width: auto;
    display: flex;
    align-items: center;
    text-align: left;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow_box:not(:last-child) {
    margin-bottom: 15px;
  }
}

.form_cushion_list_flow_box:not(:last-child)::after {
  content: "";
  position: absolute;
  z-index: 1;
  display: block;
  width: 100%;
  right: -50%;
  top: 25px;
  border-top: 2px dashed #8ecec7;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_flow_box:not(:last-child)::after {
    top: 2.2727272727vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow_box:not(:last-child)::after {
    border-top: none;
    border-right: 2px dashed #8ecec7;
    width: auto;
    height: 100%;
    top: auto;
    bottom: -50%;
    right: auto;
    left: 35px;
  }
}

.form_cushion_list_flow_ttl {
  position: relative;
  z-index: 2;
  font-weight: 700;
  background: #8ecec7;
  color: #FFF;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  width: 120px;
  height: 50px;
  border-radius: 50px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_flow_ttl {
    font-size: 2vw;
    width: 10.9090909091vw;
    height: 4.5454545455vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow_ttl {
    margin: 0 10px 0 0;
    font-size: 14px;
    width: 70px;
    height: 32px;
  }
}

.form_cushion_list_flow_txt {
  font-size: 22px;
  line-height: 30px;
  margin-top: 10px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_flow_txt {
    font-size: 2vw;
    line-height: 2.7272727273vw;
    margin-top: 0.9090909091vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_flow_txt {
    font-size: 18px;
    line-height: 1.3;
    margin-top: 0;
  }
}

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

.form_cushion_list_card_img {
  width: 80px;
  margin-right: 20px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_card_img {
    width: 7.2727272727vw;
    margin-right: 1.8181818182vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_card_img {
    width: 20%;
    margin-right: 4%;
  }
}

.form_cushion_list_card_img img {
  width: 100%;
}

.form_cushion_list_card_desc {
  font-size: 25px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_card_desc {
    font-size: 2.2727272727vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_card_desc {
    font-size: 16px;
    line-height: 21px;
    width: 76%;
  }
}

.form_cushion_list_card_desc span {
  font-weight: 700;
  color: #dd0000;
}

.form_cushion_list_btn {
  width: 700px;
  margin: 0 auto;
  text-align: center;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn {
    width: 63.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn {
    width: auto;
  }
}

.form_cushion_list_btn_select {
  text-align: left;
  width: 100%;
  border: 2px solid #8ecec7;
  border-radius: 12px;
  box-shadow: 8px 8px 16px 0px rgba(0, 0, 0, 0.2);
  margin-bottom: 20px;
  font-size: 24px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn_select {
    margin-bottom: 2.8181818182vw;
    font-size: 2.1818181818vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select {
    border-radius: 6px;
  }
}

.form_cushion_list_btn_select_tgl {
  cursor: pointer;
  padding: 14px 30px;
  background: #FFF url(/img/form/plus.svg) no-repeat 96% 15px;
  border-radius: 12px;
  background-size: 40px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn_select_tgl {
    padding: 1.2727272727vw 2.7272727273vw;
    background-size: 3.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select_tgl {
    padding: 9px 20px;
    font-size: 18px;
    background-position: 94% 11px;
    background-size: 30px;
  }
}

.form_cushion_list_btn_select_tgl._active {
  background: #FFF url(/img/form/minus.svg) no-repeat 96% 15px;
  background-size: 40px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn_select_tgl._active {
    background-size: 3.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select_tgl._active {
    background-size: 30px;
    background-position: 94% 11px;
  }
}

.form_cushion_list_btn_select_box {
  display: none;
  padding: 0 30px 30px;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn_select_box {
    padding: 0 2.7272727273vw 2.7272727273vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select_box {
    padding: 0 15px 15px;
  }
}

.form_cushion_list_btn_select_box table {
  width: 100%;
  border-top: 1px solid #dbdbdb;
  margin: 0;
}

.form_cushion_list_btn_select_box table th,
.form_cushion_list_btn_select_box table td {
  width: 50%;
  font-size: 16px;
  padding: 10px 15px;
  border-bottom: 1px solid #dbdbdb;
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select_box table th,
  .form_cushion_list_btn_select_box table td {
    width: 60%;
    font-size: 14px;
  }
}

.form_cushion_list_btn_select_box table th {
  background: #f5f5f5;
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_select_box table th {
    width: 40%;
  }
}

.form_cushion_list_btn_submit {
  transition: all 0.2s ease-in-out;
  font-weight: 700;
  color: #FFF;
  background: #8ecec7 url(/img/form/arw.svg) no-repeat 96% 50%;
  background-size: 40px;
  box-shadow: 8px 8px 16px 0px rgba(0, 0, 0, 0.2);
  border-radius: 12px;
  width: 100%;
  height: 70px;
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 1100px) {
  .form_cushion_list_btn_submit {
    height: 6.3636363636vw;
    font-size: 2.1818181818vw;
    background-size: 3.6363636364vw;
  }
}

@media screen and (max-width: 767px) {
  .form_cushion_list_btn_submit {
    background-position: 94% 50%;
    font-size: 20px;
    height: 60px;
    background-size: 30px;
    border-radius: 6px;
  }
}

.form_cushion_list_btn_submit:hover {
  opacity: 0.75;
}

.form_inner .text-danger {
  font-size: 0.8em;
  width: 95%;
  margin: 4px 4px;
}

.form_inner .text-danger:before {
  width: 25px;
  margin-right: 5px;
}

.form_inner .sum-error {
  font-size: 15px;
  padding: 5px;
  margin: 5px;
  border: 2px solid var(--danger_color);
  color: var(--danger_color);
  font-weight: 900;
}

.form_inner .sum-error a {
  color: var(--danger_color);
}

.form_inner .sum-error ul {
  margin: 5px 5px 5px 20px;
}

.form_inner .sum-error ul li {
  list-style-type: disc;
  text-decoration: underline;
}

@media screen and (max-width: 767px) {
  .form_inner .sum-error {
    font-size: 2.23vw;
  }
}

@media screen and (max-width: 374px) {
  .form_inner .sum-error {
    font-size: 2.65vw;
  }
}

._block {
  display: block;
}

.mt_s {
  margin-top: 10px;
}

.mt_m {
  margin-top: 30px;
}

.mt_l {
  margin-top: 80px;
}
