@charset "UTF-8";
@font-face {
  font-family: "NotoSansRe";
  src: url(/contact/fonts/NotoSansJP/Regular.woff) format("woff");
  font-display: swap;
}

@font-face {
  font-family: "NotoSansBo";
  src: url(/contact/fonts/NotoSansJP/Bold.woff) format("woff");
  font-display: swap;
}

.contact h1 {
  margin-bottom: 80px;
  font-family: "NotoSansBo";
  color: #606060;
  font-size: 36px;
  text-align: center;
}

@media (max-width: 767px) {
  .contact h1 {
    margin-bottom: 40px;
    font-size: 30px;
  }
}

.contact .flow {
  margin-bottom: 80px;
  text-align: center;
}

@media (max-width: 767px) {
  .contact .flow {
    margin-bottom: 40px;
  }
}

.contact .txt-area {
  margin-bottom: 40px;
}

.contact .txt-area p {
  margin-bottom: 40px;
}

.contact .txt-area ul {
  padding-left: 24px;
}

.contact .txt-area ul li {
  padding-left: 4px;
  color: #001D70;
  list-style: disc;
}

.contact .txt-area ul li:not(:last-child) {
  margin-bottom: 16px;
}

.contact .txt-area ul li span {
  color: #333;
}

.contact .txt-area.thanks {
  text-align: center;
}

.contact .agree {
  margin: 0 auto 40px;
  padding-bottom: 20px;
  width: 780px;
  text-align: center;
  border: 1px solid #CCC;
  border-radius: 8px;
  overflow: hidden;
}

@media (max-width: 870px) {
  .contact .agree {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .contact .agree {
    padding-bottom: 10px;
  }
}

.contact .agree > p {
  margin-bottom: 20px;
  padding: 20px;
  line-height: 1;
  background-color: #F2F2F2;
}

@media (max-width: 801px) {
  .contact .agree > p {
    line-height: 1.5;
  }
}

@media (max-width: 767px) {
  .contact .agree > p {
    padding-top: 10px;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }
}

@media (max-width: 510px) {
  .contact .agree > p {
    text-align: left;
  }
}

@media (min-width: 801px) {
  .contact .agree > p br {
    display: none;
  }
}

@media (max-width: 800px) {
  .contact .agree > p br {
    display: inline-block;
  }
}

@media (max-width: 510px) {
  .contact .agree > p br {
    display: none;
  }
}

.contact .agree.check p {
  text-align: center;
}

.contact .agree input {
  margin-right: 8px;
  vertical-align: middle;
}

.contact .agree + p {
  margin-bottom: 40px;
}

.contact .required {
  display: inline-block;
  margin-right: 4px;
  padding: 2px;
  color: #FFF;
  font-size: 14px;
  font-weight: normal;
  line-height: 1;
  background-color: #BF272D;
}

.contact table {
  margin-bottom: 40px;
  table-layout: fixed;
  width: 100%;
  border-top: 1px solid #587DC4;
}

.contact table th,
.contact table td {
  padding: 18px;
  vertical-align: top;
}

.contact table th {
  width: 260px;
  min-width: 260px;
  text-align: left;
  background-color: #EDF7F9;
  border-bottom: 1px solid #91B9F2;
}

.contact table th .required {
  float: right;
  margin-right: 0;
}

.contact table td {
  width: calc(100% - 260px);
  border-bottom: 1px solid #E6E6E6;
}

.contact table td input + span {
  display: inline-block;
  margin-left: 8px;
}

.contact table td div:not(:last-of-type) {
  margin-bottom: 8px;
}

.contact table td label:not(:last-of-type) {
  margin-right: 32px;
}

@media (max-width: 767px) {
  .contact table tr, .contact table th, .contact table td {
    display: block;
    width: 100%;
  }
}

.contact label {
  cursor: pointer;
}

@media (max-width: 767px) {
  .contact label {
    display: block;
  }
  .contact label:not(:last-child) {
    margin-bottom: 8px;
  }
}

.contact label input[type="checkbox"],
.contact label input[type="radio"] {
  display: none;
}

.contact label input[type="checkbox"] + span,
.contact label input[type="radio"] + span {
  position: relative;
  padding-left: 26px;
}

.contact label input[type="checkbox"] + span::before, .contact label input[type="checkbox"] + span::after,
.contact label input[type="radio"] + span::before,
.contact label input[type="radio"] + span::after {
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.contact label input[type="checkbox"] + span::before,
.contact label input[type="radio"] + span::before {
  content: '';
  display: inline-block;
  margin-right: 8px;
  vertical-align: text-top;
}

.contact label input[type="checkbox"]:checked + span::after,
.contact label input[type="radio"]:checked + span::after {
  display: block;
}

.contact label input[type="checkbox"] + span::before {
  width: 16px;
  height: 16px;
  border: 1px solid #000;
  border-radius: 4px;
}

.contact label input[type="checkbox"] + span::after {
  top: calc(50% - 1px);
  font-size: 16px;
  line-height: 1;
}

.contact label input[type="checkbox"]:checked + span::after {
  content: '✔';
  width: 18px;
  color: #587DC4;
}

.contact label input[type="radio"] + span::before {
  width: 16px;
  height: 16px;
  border: 1px solid #000;
  border-radius: 16px;
}

.contact label input[type="radio"] + span::after {
  width: 12px;
  height: 12px;
  background-color: #587DC4;
  border-radius: 16px;
}

.contact label input[type="radio"]:checked + span::after {
  content: '';
  left: 3px;
}

.contact input[type="text"],
.contact input[type="tel"],
.contact input[type="email"],
.contact select {
  padding: 8px;
}

.contact textarea {
  height: 150px;
}

.contact .zip input:first-of-type {
  width: 60px;
}

.contact .zip input:last-of-type {
  width: 80px;
}

.contact .address input {
  width: 100%;
}

.contact .small {
  width: 400px;
}

@media (max-width: 870px) {
  .contact .small {
    width: calc(100% - 6em);
  }
}

.contact .x-small {
  width: 200px;
}

@media (max-width: 870px) {
  .contact .x-small {
    width: calc(100% - 6em);
  }
}

.contact .middle {
  width: 640px;
}

@media (max-width: 1104px) {
  .contact .middle {
    width: calc(100% - 6em);
  }
}

.contact .large {
  width: 100%;
}

.contact .input-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.contact .input-box > div:first-child {
  padding-top: 6px;
  width: 80px;
  min-width: 80px;
}

.contact .input-box > div:last-child {
  width: calc(100% - 80px);
}

@media (max-width: 870px) {
  .contact .input-box > div:last-child {
    width: calc(100% - 80px);
  }
  .contact .input-box > div:last-child input {
    width: 100%;
  }
}

.contact .email > div:first-of-type {
  margin-bottom: 8px;
}

.contact .btn-area {
  text-align: center;
}

.contact .btn-area button,
.contact .btn-area.thanks a {
  position: relative;
  display: inline-block;
  margin: 0 auto;
  padding: 20px 0;
  width: 190px;
  color: #587DC4;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  background-color: #FFF;
  border: 1px solid #CCC;
  border-radius: 8px;
  -webkit-transition-duration: 0.4s;
          transition-duration: 0.4s;
  cursor: pointer;
}

.contact .btn-area button:hover,
.contact .btn-area.thanks a:hover {
  color: #FFF;
  background-color: #3B7BCA;
}

@media (max-width: 480px) {
  .contact .btn-area button,
  .contact .btn-area.thanks a {
    width: 80%;
  }
}

.contact .btn-area button::after,
.contact .btn-area.thanks a::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 50%;
  -webkit-transform: translateY(50%);
          transform: translateY(50%);
  right: 16px;
  width: 6px;
  height: 10px;
  background-image: url(/contact/images/common/com_ic01.svg);
  background-size: 100% auto;
  background-position: 0 0;
  background-repeat: no-repeat;
}

.contact .btn-area button:hover::after,
.contact .btn-area.thanks a:hover::after {
  background-image: url(/contact/images/common/com_ic01_hover.svg);
}

.contact .btn-area button.back,
.contact .btn-area.thanks a.back {
  margin-right: 32px;
}

@media (max-width: 480px) {
  .contact .btn-area button.back,
  .contact .btn-area.thanks a.back {
    margin-right: 0;
    margin-bottom: 16px;
  }
}

.contact .btn-area button.back::after,
.contact .btn-area.thanks a.back::after {
  right: 0;
  left: 16px;
  background-image: url(/contact/images/common/com_ic02.svg);
}

.contact .btn-area button.back:hover::after,
.contact .btn-area.thanks a.back:hover::after {
  background-image: url(/contact/images/common/com_ic02_hover.svg);
}

.contact .btn-area.thanks a {
  width: 220px;
}

.contact .chk-txt {
  margin-bottom: 40px;
}

.contact .error-wrap {
  margin-top: 8px;
}

.contact .error-wrap .error {
  position: relative;
  display: inline-block;
  padding: 4px 8px 4px 32px;
  color: #BF272D;
  background-color: #FFD9DB;
}

.contact .error-wrap .error img {
  position: absolute;
  top: 6px;
  left: 8px;
}
/*# sourceMappingURL=contact.css.map */