@charset "utf-8";
/* CSS Document */
/*コンタクトフォーム*/
input[type="submit"] {
  -webkit-appearance: none;
  border-radius: 0;
}
table label {
  padding: 10px 15px;
  background-color: #f9f9f9;
  border-radius: 7px;
}
span.wpcf7-list-item {
  margin: 1.2em 0em 1.2em 1em !important;
}
label {
  cursor: pointer;
}
.sort {
  text-align: left;
  padding: 5px 25px 15px 25px !important;
}
.sort span {
  margin-top: 10px;
}

.inquiry {
  max-width: 100%;
  margin: 50px auto 0 auto;
  color: #3e3a39;
  text-align: left;
}
.contact_text {
  margin: 20px auto 5px auto;
  line-height: 2em;
  font-size: 16px;
  text-align: left;
  color: #3e3a39;
}
.contact_text-02 {
  margin: 20px auto 5px auto;
  padding: 10px;
  line-height: 2em;
  font-size: 16px;
  background-color: #f7f7f7f7;
  color: #3e3a39;
  width: 80%;
}
.contact_text a {
  text-decoration: none;
  color: #ff7bac;
}
.textsp,
.mailsp,
.wpcf7-text,
.wpcf7-validates-as-date {
  width: 100%;
  border-radius: 7px;
  border: solid 1px #b5b5b6;
  height: 3em;
}
.wpcf7-validates-as-required {
  border-radius: 7px;
  height: 3em;
  width: 100%;
  box-sizing: border-box;
}
.wpcf7-textarea {
  width: 100%;
  border-radius: 7px;
  border: solid 1px #b5b5b6;
}
.text-10 > .wpcf7-text,
.text-11 > .wpcf7-text,
.text-12 > .wpcf7-text {
  width: 60px;
  text-align: center;
}
.form-wrapper > ._container tr > td > p {
  margin: 0 10px;
  display: inline-block;
}

/*見出し欄*/
.inquiry th {
  text-align: left;
  color: #3e3a39;
  padding: 15px 25px;
  width: 180px;
  background: #f7f7f7;
  border: solid 1px #d7d7d7;
  vertical-align: middle;
}
/*通常欄*/
.inquiry td {
  border: solid 1px #d7d7d7;
  padding: 15px 25px;
}
/*横の行とテーブル全体*/
.entry-content .inquiry tr,
.entry-content table {
  border: solid 1px #d7d7d7;
}
/*必須の調整*/
.haveto {
  font-size: 7px;
  padding: 5px;
  background: #ff9393;
  color: #fff;
  border-radius: 2px;
  margin-right: 5px;
  position: relative;
  bottom: 1px;
}
/*任意の調整*/
.any {
  font-size: 7px;
  padding: 5px;
  background: #93c9ff;
  color: #fff;
  border-radius: 2px;
  margin-right: 5px;
  position: relative;
  bottom: 1px;
}
/*ラジオボタンを縦並び指定*/
.verticallist .wpcf7-list-item {
  display: block;
}
/*送信ボタンのデザイン変更*/
#formbtn {
  display: block;
  padding: 15px;
  width: 50%;
  background: #00a0e9;
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  border-radius: 37px;
  border: solid 3px #ffffff;
  margin: 25px auto 0;
  transition: 0.3s;
  letter-spacing: 3px;
}

/*送信ボタンマウスホバー時*/
#formbtn:hover {
  border: 3px solid #00a0e9;
  cursor: pointer;
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
  box-shadow: 4px 4px 10px -2px gray;
}
/*エラーメッセージ*/
.wpcf7 .wpcf7-response-output {
  margin: 10px auto 0 auto;
  padding: 8px 35px 8px 14px;
  width: 80%;
}

span.wpcf7-not-valid {
  border: 1px solid #f44522 !important;
  background-color: #fbeff3 !important;
  box-sizing: border-box;
}

span.wpcf7-not-valid-tip {
  color: #ffffff !important;
  padding: 12px 12px 12px !important;
  position: relative;
  display: block;
  background-color: #e05050;
  left: 0;
  top: 8px;
  margin-bottom: 8px;
  clear: both;
  border-radius: 5px;
  border: none;
}

span.wpcf7-not-valid-tip::after {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 30px;
  height: 0;
  width: 0;
  border: 10px solid transparent;
  border-bottom: 10px solid #e05050;
}

div.wpcf7-validation-errors {
  color: #b94a48;
  padding: 20px 16px 20px !important;
  position: relative;
  display: block;
  background-color: #f2dee6;
  left: 0;
  top: 8px;
  margin: 0 auto 8px auto;
  clear: both;
  border-radius: 5px;
  border: 1px solid #b94a48 !important;
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}

.wpcf7-mail-sent-ng {
  color: #3fad3a;
  padding: 11px 16px 10px !important;
  position: relative;
  display: block;
  background-color: #d9f7e5;
  left: 0;
  top: 8px;
  margin-bottom: 8px;
  clear: both;
  border-radius: 5px;
  border: 1px solid #3fad3a !important;
}

.wpcf7-mail-sent-ok {
  color: #3a87ad;
  padding: 11px 16px 10px !important;
  position: relative;
  display: block;
  background-color: #d9edf7;
  left: 0;
  top: 8px;
  margin-bottom: 8px;
  clear: both;
  border-radius: 5px;
  border: 1px solid #3a87ad !important;
}

.wpcf7-list-item:nth-child(3):after {
  content: "\A";
  white-space: pre;
  line-height: 2em;
}

@media (max-width: 751px) {
  .form-wrapper > ._container tr > td > p {
    margin: 0;
  }
  .inquiry {
    max-width: 100%;
  }
  .inquiry th,
  .inquiry td {
    display: block !important;
    width: 100% !important;
    border-top: none !important;
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
    padding-left: 10px;
    padding-right: 10px;
  }
  .inquiry tr:first-child th {
    border-top: 1px solid #d7d7d7 !important;
  }
  /* 必須・任意のサイズ調整 */
  .inquiry .haveto,
  .inquiry .any {
    font-size: 10px;
  }

  #formbtn {
    width: 100%;
  }
  .contact_text-02 {
    width: 100%;
  }
}
