@charset "UTF-8";
/*
$4ewsColor: 
    /*col01: #238561,
  col02: #67a2b7,
  col03: #d2843e,
  col04: #cf775b,
  col05: #cf9942,
  col06: #926c28,
  col07: #cc7175,
  col08: #608ea1,
  col09: #5b609a,
  col10: #487390,
  col11: #4e9386,
  col12: #79a153,
  col13: #817499
);
*/
#header_nav > li.category_index.delay {
  pointer-events: none;
}

/**/
#flow {
  position: relative;
}
#flow .inner {
  position: relative;
}
@media screen and (min-width: 769px) {
  #flow .inner {
    padding: 5rem 0 3rem !important;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  #flow .inner {
    padding: 8rem 0 !important;
  }
}

#flow .general_txt {
  position: relative;
}
@media screen and (min-width: 769px) {
  #flow .general_txt {
    text-align: center;
  }
}

#thanks_section .arrow_link,
#flow .arrow_link {
  position: relative;
}
@media screen and (min-width: 769px) {
  #thanks_section .arrow_link,
  #flow .arrow_link {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    margin: 3rem auto 0;
    width: 36rem;
  }
}
@media screen and (max-width: 768px) {
  #thanks_section .arrow_link,
  #flow .arrow_link {
    margin-top: 4rem;
  }
}

@media screen and (min-width: 769px) {
  #thanks_section .arrow_link {
    margin-top: 3rem !important;
  }
}
@media screen and (max-width: 768px) {
  #thanks_section .arrow_link {
    margin-top: 4rem !important;
  }
}

#flow .arrow_link > div {
  position: relative;
}
@media screen and (min-width: 769px) {
  #flow .arrow_link > div {
    text-align: left;
  }
}
@media screen and (min-width: 769px) {
  #flow .arrow_link a:nth-of-type(2) {
    margin-top: 1rem !important;
  }
}
@media screen and (max-width: 768px) {
  #flow .arrow_link a:nth-of-type(2) {
    margin-top: 2rem !important;
  }
}

#flow_list {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media screen and (min-width: 769px) {
  #flow_list {
    width: 40rem;
    margin: 5rem auto 0;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  #flow_list {
    width: 67rem;
    margin: 8rem auto 0;
    text-align: center;
  }
}

.thanks_flow #flow_list {
  margin: 0 auto !important;
}

#flow_list::before {
  content: "";
  position: absolute;
  background: #e2e2e2;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  #flow_list::before {
    left: 4rem;
    top: 2.9rem;
    width: 32rem;
    height: 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  #flow_list::before {
    left: 6rem;
    top: 5.9rem;
    width: 55rem;
    height: 0.4rem;
  }
}

#flow_list li {
  position: relative;
}
@media screen and (min-width: 769px) {
  #flow_list li {
    width: 13rem;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  #flow_list li {
    width: 22.3rem;
    text-align: center;
  }
}

#flow_list li span {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  margin: 0 auto;
  font-weight: 500;
  color: #aaaaaa;
}
@media screen and (min-width: 769px) {
  #flow_list li span {
    border: #e2e2e2 0.4rem solid;
    background: #fff;
    width: 6rem;
    height: 6rem;
    line-height: 3.75em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  #flow_list li span {
    border: #e2e2e2 0.8rem solid;
    background: #fff;
    width: 12rem;
    height: 12rem;
    line-height: 3.75em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
  }
}

#flow_list li p {
  position: relative;
  text-align: center;
  font-weight: 500;
  color: #8b8b8b;
}
@media screen and (min-width: 769px) {
  #flow_list li p {
    margin-top: 2rem;
    line-height: 1.5em;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  #flow_list li p {
    line-height: 1;
    font-size: 2.8rem;
    margin-top: 3rem;
    letter-spacing: 0.05em;
  }
}

#flow_list li.current span {
  background: #0068b2;
  color: #fff !important;
}
@media screen and (min-width: 769px) {
  #flow_list li.current span {
    border: #0068b2 0.4rem solid;
  }
}
@media screen and (max-width: 768px) {
  #flow_list li.current span {
    border: #0068b2 0.4rem solid;
  }
}

#flow_list li.current p {
  color: #0068b2 !important;
}

/**/
#form_section {
  position: relative;
  width: 100%;
  overflow: hidden;
}
#form_section .inner {
  padding: 0 !important;
}

#required_txt {
  position: relative;
  font-weight: 400;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #required_txt {
    width: 98rem;
    margin: 0 auto;
    line-height: 2em;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 768px) {
  #required_txt {
    line-height: 1.5em;
    font-size: 2.8rem;
    letter-spacing: 0.05em;
    padding-bottom: 4rem;
  }
}

#required_txt span,
.required_icon {
  position: relative;
  display: inline-block;
  background: #ad0000;
  color: #fff;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #required_txt span,
  .required_icon {
    line-height: 2.154em;
    font-size: 1.3rem;
    letter-spacing: 0.05em;
    padding: 0 1rem;
    margin-right: 0.5rem;
    border-radius: 0.2rem;
    transform: translateY(-0.1rem);
  }
}
@media screen and (max-width: 768px) {
  #required_txt span,
  .required_icon {
    line-height: 1.616em;
    font-size: 2.6rem;
    letter-spacing: 0.05em;
    padding: 0 1rem;
    margin-right: 1rem;
    border-radius: 0.2rem;
    transform: translateY(-0.1rem);
  }
}

.required_icon {
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .required_icon {
    margin-right: 0;
    position: absolute;
    top: 3.5rem;
    right: 4rem;
    transform: translateY(-0.9rem);
  }
}
@media screen and (max-width: 768px) {
  .required_icon {
    margin-right: 0;
    position: absolute;
    top: 0rem;
    right: 0rem;
  }
}

#form_section dl {
  position: relative;
}
@media screen and (min-width: 769px) {
  #form_section dl {
    width: 98rem;
    margin: 0 auto;
    display: table;
    border-bottom: #d0d0d0 1px solid;
  }
}
@media screen and (max-width: 768px) {
  #form_section dl {
    width: 100%;
    display: block;
    border-bottom: #d0d0d0 1px solid;
    padding: 4rem 0;
  }
}

@media screen and (min-width: 769px) {
  #form_section dl:nth-of-type(1) {
    border-top: #d0d0d0 1px solid;
  }
}
@media screen and (max-width: 768px) {
  #form_section dl:nth-of-type(1) {
    border-top: #d0d0d0 1px solid;
  }
}

#form_section dt {
  position: relative;
  vertical-align: top;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #form_section dt {
    display: table-cell;
    width: 32rem;
    padding: 2.5rem 0;
  }
}
@media screen and (max-width: 768px) {
  #form_section dt {
    display: block;
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  #form_section dt:has(.required_icon) {
    padding-right: 13rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dt:has(.required_icon) {
    padding-right: 15rem;
  }
}

#form_section dt p {
  position: relative;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #form_section dt p {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  #form_section dt p {
    line-height: 1.313em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
  }
}

#form_section dt .cap {
  position: relative;
  display: block;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #form_section dt .cap {
    line-height: 2em;
    font-size: 1.4rem;
    letter-spacing: 0em;
  }
}
@media screen and (max-width: 768px) {
  #form_section dt .cap {
    line-height: 1.7em;
    font-size: 2.8rem;
    letter-spacing: 0.05em;
    padding-top: 0.5rem;
  }
}

#form_section dd {
  position: relative;
  zoom: 1;
  overflow: hidden;
  vertical-align: top;
  text-align: left;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #form_section dd {
    padding: 2.5rem 0;
    display: table-cell;
    width: 66rem;
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd {
    display: block;
    width: 100%;
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
    padding: 2rem 0 0;
  }
}

#form_section dd div.radio_set,
#form_section dd div.checkbox {
  width: 100% !important;
  margin: 0 !important;
}

@media screen and (min-width: 769px) {
  #form_section dd .radio_set {
    padding: 0 0 1rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .radio_set {
    padding: 0 0 2rem;
  }
}

#form_section dd .radio_set:last-of-type {
  padding: 0 0 0rem !important;
}

#form_section dd .horizontal-item {
  position: relative;
  display: block;
  width: 100% !important;
  margin: 0 !important;
}
@media screen and (min-width: 769px) {
  #form_section dd .horizontal-item {
    padding: 0 0 1rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .horizontal-item {
    padding: 0 0 2rem;
  }
}

#form_section dd .horizontal-item:last-of-type {
  padding: 0 0 0rem !important;
}

#form_section dd .parts {
  position: relative;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #form_section dd .parts {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    padding: 0 0 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .parts {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
    padding: 0 0 1rem;
  }
}

#form_section dd .cap {
  position: relative;
  display: block;
  color: #8a8a8a;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #form_section dd .cap {
    line-height: 2em;
    font-size: 1.4rem;
    letter-spacing: 0em;
    margin-top: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .cap {
    line-height: 1.429em;
    font-size: 2.8rem;
    letter-spacing: 0.05em;
    margin-top: 1.2rem;
  }
}

@media screen and (min-width: 769px) {
  #form_section dd .cap.mgn {
    margin-top: 2rem;
    padding-bottom: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .cap.mgn {
    margin-top: 4rem;
    padding-bottom: 1.2rem;
  }
}

@media screen and (min-width: 769px) {
  #form_section dd .cap.textarea_cap {
    margin-top: -0.5rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd .cap.textarea_cap {
    margin-top: 0rem;
  }
}

#form_section dd input::placeholder,
#form_section dd textarea::placeholder {
  font-family: "Noto Sans", sans-serif;
  color: #cccccc;
}

section .post_code_set {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media screen and (min-width: 769px) {
  section .post_code_set {
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 768px) {
  section .post_code_set {
    padding-bottom: 4rem;
  }
}

section .post_code_box {
  position: relative;
}
@media screen and (min-width: 769px) {
  section .post_code_box {
    width: 20rem;
  }
}
@media screen and (max-width: 768px) {
  section .post_code_box {
    width: 33rem;
  }
}

section .search_box {
  position: relative;
}
@media screen and (min-width: 769px) {
  section .search_box {
    margin-left: 2rem;
    padding-top: 1rem;
  }
}
@media screen and (max-width: 768px) {
  section .search_box {
    margin-left: 4rem;
    padding-top: 1.6rem;
  }
}

section a.icon_window {
  position: relative;
  overflow: hidden;
  display: inline-block;
  color: #0068b2;
  text-decoration: underline;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  section a.icon_window {
    line-height: 1.25em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  section a.icon_window {
    line-height: 1.7em;
    font-size: 2.8rem;
    letter-spacing: 0.05em;
  }
}

@media screen and (min-width: 769px) {
  section a.icon_window:hover {
    text-decoration: none;
  }
}

section a.icon_window::after {
  content: "";
  transition: ease-out 0.2s all;
  position: relative;
  display: inline-block;
}
@media screen and (min-width: 769px) {
  section a.icon_window::after {
    width: 0.96rem;
    height: 0.96rem;
    background: url(../../common/img/icon_window_b.svg) center center no-repeat;
    background-size: contain;
    transform: translateY(0.1rem);
    margin-left: 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  section a.icon_window::after {
    width: 1.92rem;
    height: 1.92rem;
    background: url(../../common/img/icon_window_b.svg) center center no-repeat;
    background-size: contain;
    transform: translateY(0.1rem);
    margin-left: 1rem;
  }
}

select {
  /* 初期化 */
  position: relative;
  appearance: none;
  -moz-appearance: none;
  -webkit-appearance: none;
  color: #000;
  background-color: #fff;
  border: 1px solid #333;
  width: 100%;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  select {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    height: 5rem;
    line-height: 5rem;
    padding: 0 1rem;
  }
}
@media screen and (max-width: 768px) {
  select {
    line-height: 1.7em;
    font-size: 2.8rem;
    letter-spacing: 0.05em;
    height: 8rem;
    line-height: 8rem;
    padding: 0 2rem;
  }
}

.select_area div {
  position: relative;
}

.select_area div::before {
  position: absolute;
  margin-top: -10px;
  content: "";
  right: 15px;
  width: 12px;
  height: 12px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(135deg);
  transition: ease 0.4s all;
  z-index: 10;
}
@media screen and (min-width: 769px) {
  .select_area div::before {
    top: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .select_area div::before {
    top: 4rem;
  }
}

.select_area div::after {
  position: absolute;
  top: 1px;
  content: "";
  right: 1px;
  width: 36px;
  height: 100%;
  z-index: 9;
}

#form_section dd input[type=text],
#form_section dd input[type=tel],
#form_section dd input[type=email] {
  color: #333;
  background-color: #fff;
  border: 1px solid #d0d0d0;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #form_section dd input[type=text],
  #form_section dd input[type=tel],
  #form_section dd input[type=email] {
    line-height: 3.125em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    width: 100%;
    height: 5rem;
    padding: 0 1rem;
    border-radius: 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd input[type=text],
  #form_section dd input[type=tel],
  #form_section dd input[type=email] {
    line-height: 3.125em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
    width: 100%;
    height: 10rem;
    padding: 0 2rem;
    border-radius: 0.6rem;
  }
}

#form_section dd textarea {
  color: #333;
  background-color: #fff;
  border: 1px solid #d0d0d0;
  width: 100%;
  padding: 1rem;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #form_section dd textarea {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    border-radius: 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  #form_section dd textarea {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
    border-radius: 0.6rem;
  }
}

#form_section dd input[type=text]:focus,
#form_section dd input[type=tel]:focus,
#form_section dd input[type=email]:focus,
#form_section dd textarea:focus,
#form_section dd select:focus {
  color: #333;
  border-color: #0068b2;
  outline: 0;
}

input[type=checkbox] {
  display: inline-block;
  margin-right: 0;
}

input[type=checkbox] + label {
  position: relative;
  display: inline-block;
  margin-right: 0;
  font-weight: 400;
  cursor: pointer;
}

@media screen and (min-width: 769px) {
  #policy input[type=checkbox] + label {
    line-height: 1.6em;
    font-size: 2rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  #policy input[type=checkbox] + label {
    line-height: 1.6em;
    font-size: 4rem;
    letter-spacing: 0.05em;
  }
}

#policy input[type=checkbox] {
  display: none;
  margin: 0;
}

#policy input[type=checkbox] + label {
  padding: 0 0 0 40px;
}

#policy input[type=checkbox] + label.hankaku {
  padding: 0 0 0 50px;
}

#policy input[type=checkbox] + label::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  box-sizing: border-box;
  display: block;
  background: #FFF;
}
@media screen and (min-width: 769px) {
  #policy input[type=checkbox] + label::before {
    width: 2.5rem;
    height: 2.5rem;
    margin-top: -1.3rem;
    border-radius: 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  #policy input[type=checkbox] + label::before {
    width: 5rem;
    height: 5rem;
    margin-top: -2.5rem;
    border-radius: 0.6rem;
  }
}

#policy input[type=checkbox] + label::before {
  border: 1px solid #d0d0d0;
}

#policy input[type=checkbox]:checked + label::after {
  content: "";
  position: absolute;
  top: 50%;
  box-sizing: border-box;
  display: block;
}

#policy input[type=checkbox]:checked + label::after {
  transform: rotate(-45deg);
}
@media screen and (min-width: 769px) {
  #policy input[type=checkbox]:checked + label::after {
    left: 0.3rem;
    width: 2.6rem;
    height: 1.6rem;
    margin-top: -1.5rem;
    border-left: 0.4rem solid #ad0000;
    border-bottom: 0.4rem solid #ad0000;
  }
}
@media screen and (max-width: 768px) {
  #policy input[type=checkbox]:checked + label::after {
    left: 0.6rem;
    width: 5.2rem;
    height: 3.2rem;
    margin-top: -2.8rem;
    border-left: 0.8rem solid #ad0000;
    border-bottom: 0.8rem solid #ad0000;
  }
}

input[type=radio] {
  display: inline-block;
  margin-right: 0px;
}

label input[type=radio] + span {
  position: relative;
  display: inline-block;
  margin-right: 40px;
  font-weight: 400;
  cursor: pointer;
  min-height: 30px;
}
@media screen and (min-width: 769px) {
  label input[type=radio] + span {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  label input[type=radio] + span {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.01em;
    white-space: nowrap;
  }
}

input[type=radio] {
  display: none;
  margin: 0;
}

label input[type=radio] + span {
  padding: 0 0 0 36px;
}

label input[type=radio] + span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  box-sizing: border-box;
  display: block;
  width: 24px;
  height: 24px;
  margin-top: -12px;
  background: #FFF;
}

label input[type=radio] + span::before {
  border: #E6E6E6 solid 1px;
  border-radius: 24px;
}

label input[type=radio] + span::before {
  border: #333333 solid 1px;
}

label input[type=radio]:checked + span::after {
  content: "";
  position: absolute;
  top: 50%;
  box-sizing: border-box;
  display: block;
}

label input[type=radio]:checked + span::after {
  left: 4px;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  background: #E32F2F;
  border-radius: 16px;
}

@media screen and (min-width: 769px) {
  .wpcf7-not-valid-tip {
    padding: 1rem 0;
  }
}
@media screen and (max-width: 768px) {
  .wpcf7-not-valid-tip {
    padding: 2rem 0;
  }
}

.wpcf7-not-valid-tip {
  color: #E32F2F;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .wpcf7-not-valid-tip {
    line-height: 1.7em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  .wpcf7-not-valid-tip {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
  }
}

#policy {
  position: relative;
  text-align: center;
  width: 100%;
}
@media screen and (min-width: 769px) {
  #policy {
    padding: 5rem 0 0;
  }
}
@media screen and (max-width: 768px) {
  #policy {
    padding: 8rem 0 0;
  }
}

#policy .policy_ttl {
  position: relative;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #policy .policy_ttl {
    line-height: 1.4em;
    font-size: 2rem;
    letter-spacing: 0.05em;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 768px) {
  #policy .policy_ttl {
    line-height: 1.5em;
    font-size: 4rem;
    letter-spacing: 0.05em;
    padding-bottom: 2rem;
  }
}

@media screen and (min-width: 769px) {
  #policy a.icon_window {
    margin-right: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  #policy a.icon_window {
    line-height: 1.7em;
    font-size: 3.2rem;
    margin-right: 1rem;
    transform: translateY(1.6rem);
  }
}

@media screen and (max-width: 768px) {
  #policy .general_txt {
    text-align: justify;
    text-justify: inter-ideograph;
  }
}

@media screen and (min-width: 769px) {
  #policy .general_txt a {
    transform: translateY(0.4rem);
  }
}

#policy div {
  position: relative;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #policy div {
    padding: 3rem 0 0;
  }
}
@media screen and (max-width: 768px) {
  #policy div {
    padding: 4rem 0 0;
  }
}

.btn_set {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 769px) {
  .btn_set {
    margin: 3rem auto 0;
    gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .btn_set {
    flex-wrap: wrap;
    gap: 2rem;
    margin: 4rem auto 0;
  }
}

@media screen and (min-width: 769px) {
  .btn_set.confirm_btn {
    margin: 5rem auto 0;
  }
}
@media screen and (max-width: 768px) {
  .btn_set.confirm_btn {
    margin: 8rem auto 0;
  }
}

.submitButton {
  position: relative;
  display: block;
  background: #0068b2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  transition: ease-out 0.6s all;
  opacity: 1;
  pointer-events: auto;
}
@media screen and (min-width: 769px) {
  .submitButton {
    border: #0068b2 0.2rem solid;
    width: 38rem;
    height: 7.5rem;
    padding: 0 2rem;
    border-radius: 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  .submitButton {
    border: #0068b2 0.4rem solid;
    width: 67rem;
    height: 14rem;
    padding: 0 4rem;
    border-radius: 0.6rem;
    order: 1;
  }
}

.submitButton.non_act {
  opacity: 0.5;
  pointer-events: none !important;
}

.submitButton input {
  width: 100%;
  height: 100%;
  border: 0;
  background-color: transparent;
  text-align: center;
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Noto Sans", sans-serif;
  font-weight: 500;
  transition: ease-out 0.6s all;
}
@media screen and (min-width: 769px) {
  .submitButton input {
    line-height: 1;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  .submitButton input {
    line-height: 1;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
  }
}

.submitButton .arrow {
  position: absolute;
  display: block;
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  .submitButton .arrow {
    right: 2rem;
    width: 3rem;
    height: 3rem;
    border: #fff 0.1rem solid;
  }
}
@media screen and (max-width: 768px) {
  .submitButton .arrow {
    right: 4rem;
    width: 4.5rem;
    height: 4.5rem;
    border: #fff 0.2rem solid;
  }
}

.submitButton .arrow::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transition: ease-out 0.2s all;
}
@media screen and (min-width: 769px) {
  .submitButton .arrow::before {
    background: url(../../common/img/icon_arrow_w.svg) center center no-repeat;
    background-size: 0.64rem auto;
    transform: translateX(0.1rem);
  }
}
@media screen and (max-width: 768px) {
  .submitButton .arrow::before {
    background: url(../../common/img/icon_arrow_w.svg) center center no-repeat;
    background-size: 0.96rem auto;
    transform: translateX(0.1rem);
  }
}

.submitButton:hover {
  background: #fff;
}

.submitButton:hover input {
  color: #0068b2;
}

.submitButton:hover .arrow {
  background: #0068b2;
  border-color: #0068b2 !important;
}

/*
.error{
        @include mq(pc) {
		padding: divceil(40, 10, rem) 0;
        }
    @include mq(sp) {
		padding: divceil(40, 10, rem) 0;
    } 	
}

.error_messe{
	color:#E32F2F;
	@include fw(Regular);
        @include mq(pc) {
        @include tbmag(16, 16*1.7, pc);
        letter-spacing: 0.05em;
        }
    @include mq(sp) {
    @include tbmag(32, 32*1.7, sp);
        letter-spacing: 0.05em;
    } 	
}
*/
.backBtn {
  position: relative;
  display: block;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0;
  transition: ease-out 0.6s all;
}
@media screen and (min-width: 769px) {
  .backBtn {
    border: #0068b2 0.2rem solid;
    width: 38rem;
    height: 7.5rem;
    padding: 0 2rem;
    border-radius: 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  .backBtn {
    border: #0068b2 0.4rem solid;
    width: 67rem;
    height: 14rem;
    padding: 0 4rem;
    border-radius: 0.6rem;
    order: 2;
  }
}

.backBtn input,
.backBtn a {
  width: 100%;
  height: 100%;
  border: 0;
  background-color: transparent;
  text-align: center;
  color: #0068b2;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Noto Sans", sans-serif;
  font-weight: 500;
  transition: ease-out 0.6s all;
}
@media screen and (min-width: 769px) {
  .backBtn input,
  .backBtn a {
    line-height: 1;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  .backBtn input,
  .backBtn a {
    line-height: 1;
    font-size: 3.2rem;
  }
}

.backBtn .arrow {
  position: absolute;
  display: block;
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  .backBtn .arrow {
    left: 2rem;
    width: 3rem;
    height: 3rem;
    border: #0068b2 0.1rem solid;
  }
}
@media screen and (max-width: 768px) {
  .backBtn .arrow {
    left: 4rem;
    width: 4.5rem;
    height: 4.5rem;
    border: #0068b2 0.2rem solid;
  }
}

.backBtn .arrow::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transition: ease-out 0.2s all;
}
@media screen and (min-width: 769px) {
  .backBtn .arrow::before {
    background: url(../../common/img/icon_arrow_gr.svg) center center no-repeat;
    background-size: 0.64rem auto;
    transform: translateX(-0.1rem) rotate(-180deg);
  }
}
@media screen and (max-width: 768px) {
  .backBtn .arrow::before {
    background: url(../../common/img/icon_arrow_gr.svg) center center no-repeat;
    background-size: 0.96rem auto;
    transform: translateX(-0.2rem) rotate(-180deg);
  }
}

/*
.backBtn:hover{
    background:$key_color;
}
.backBtn:hover input{
    color:#fff;
}
.backBtn:hover .arrow{
    background: #fff;
    border-color: $key_color !important;
}
*/
@media screen and (min-width: 769px) {
  .backBtn:hover a,
  .backBtn:hover input {
    opacity: 0.6;
  }
}

/**/
#thanks_section {
  position: relative;
  width: 100%;
  overflow: hidden;
}
#thanks_section .inner {
  padding: 0 !important;
}
@media screen and (min-width: 769px) {
  #thanks_section .inner {
    text-align: center;
  }
}

#thanks_section h2 {
  position: relative;
  text-align: center;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #thanks_section h2 {
    line-height: 1.5em;
    font-size: 2.2rem;
    letter-spacing: 0.05em;
    padding: 0 0 2rem;
  }
}
@media screen and (max-width: 768px) {
  #thanks_section h2 {
    line-height: 1.5em;
    font-size: 4rem;
    letter-spacing: 0em;
    padding: 0 0 3rem;
  }
}

.note {
  color: #ad0000;
}
@media screen and (min-width: 769px) {
  .note {
    padding-top: 3rem;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .note {
    padding-top: 4rem;
  }
}

dd label {
  position: relative;
  width: 100% !important;
  display: block;
}

input[type=checkbox] {
  display: inline-block;
  margin-right: 0px;
}

label input[type=checkbox] + span {
  position: relative;
  display: inline-block;
  font-weight: 400;
  cursor: pointer;
}
@media screen and (min-width: 769px) {
  label input[type=checkbox] + span {
    line-height: 2em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
    margin-right: 4rem;
    min-height: 3.2rem;
  }
}
@media screen and (max-width: 768px) {
  label input[type=checkbox] + span {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.01em;
    white-space: nowrap;
    margin-right: 8rem;
    min-height: 5.4rem;
  }
}

input[type=checkbox] {
  display: none;
  margin: 0;
}

@media screen and (min-width: 769px) {
  label input[type=checkbox] + span {
    padding: 0 0 0 4rem;
  }
}
@media screen and (max-width: 768px) {
  label input[type=checkbox] + span {
    padding: 0 0 0 8rem;
  }
}

label input[type=checkbox] + span::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  box-sizing: border-box;
  display: block;
  background: #FFF;
}
@media screen and (min-width: 769px) {
  label input[type=checkbox] + span::before {
    width: 2.5rem;
    height: 2.5rem;
    margin-top: -1.3rem;
    border-radius: 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  label input[type=checkbox] + span::before {
    width: 5rem;
    height: 5rem;
    margin-top: -2.5rem;
    border-radius: 0.6rem;
  }
}

label input[type=checkbox] + span::before {
  border: 1px solid #d0d0d0;
}

label input[type=checkbox]:checked + span::after {
  content: "";
  position: absolute;
  top: 50%;
  box-sizing: border-box;
  display: block;
}

label input[type=checkbox]:checked + span::after {
  transform: rotate(-45deg);
}
@media screen and (min-width: 769px) {
  label input[type=checkbox]:checked + span::after {
    left: 0.3rem;
    width: 2.6rem;
    height: 1.6rem;
    margin-top: -1.5rem;
    border-left: 0.4rem solid #ad0000;
    border-bottom: 0.4rem solid #ad0000;
  }
}
@media screen and (max-width: 768px) {
  label input[type=checkbox]:checked + span::after {
    left: 0.6rem;
    width: 5.2rem;
    height: 3.2rem;
    margin-top: -2.8rem;
    border-left: 0.8rem solid #ad0000;
    border-bottom: 0.8rem solid #ad0000;
  }
}

@media screen and (min-width: 769px) {
  .wpcf7-not-valid-tip {
    padding: 1rem 0;
  }
}
@media screen and (max-width: 768px) {
  .wpcf7-not-valid-tip {
    padding: 2rem 0;
  }
}

.wpcf7-not-valid-tip {
  color: #E32F2F;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .wpcf7-not-valid-tip {
    line-height: 2em;
    font-size: 1.6rem;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 768px) {
  .wpcf7-not-valid-tip {
    line-height: 1.7em;
    font-size: 3.2rem;
    letter-spacing: 0.05em;
  }
}

.wpcf7-list-item {
  position: relative;
  display: block !important;
}
@media screen and (min-width: 769px) {
  .wpcf7-list-item {
    margin-top: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .wpcf7-list-item {
    margin-top: 2rem;
  }
}

.wpcf7-list-item:first-of-type {
  margin-top: 0rem;
}