@charset "UTF-8";
/**
 * お問い合わせページ専用スタイル
 * page-contact.php 用（独自フォーム）
 */
section.under-header {
  background-image: url(../../img/under/header-contact.png);
}

.page-contact-page .center {
  max-width: 840px;
}
.page-contact-page .contact-form {
  padding: 70px 0 100px;
  margin: 0 auto;
}
@media (max-width: 870px) {
  .page-contact-page .contact-form {
    padding-bottom: 0;
  }
}
.page-contact-page .contact-form .contact-intro {
  text-align: center;
  font-size: 24px;
  line-height: 1.8;
  color: #0F1A45;
  margin-bottom: 50px;
}
@media (max-width: 870px) {
  .page-contact-page .contact-form .contact-intro {
    font-size: 16px;
  }
}
.page-contact-page .contact-form {
  margin-bottom: 60px;
}
.page-contact-page .form-row {
  margin-bottom: 24px;
}
.page-contact-page .form-row label {
  display: block;
  font-size: 20px;
}
@media (max-width: 870px) {
  .page-contact-page .form-row label {
    font-size: 15px;
  }
}
.page-contact-page .form-row label {
  font-weight: bold;
  color: #0F1A45;
  margin-bottom: 5px;
}
.page-contact-page .form-row .required {
  color: #c00;
}
.page-contact-page .form-row input[type=text],
.page-contact-page .form-row input[type=email],
.page-contact-page .form-row input[type=tel],
.page-contact-page .form-row select,
.page-contact-page .form-row textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #ddd;
  border-radius: 6px;
  font-size: 16px;
  font-family: inherit;
  background: #fff;
  box-sizing: border-box;
  margin-top: 5px;
}
.page-contact-page .form-row select {
  appearance: auto;
  cursor: pointer;
}
.page-contact-page .form-row textarea {
  resize: vertical;
  min-height: 120px;
}
.page-contact-page .form-row-agree {
  margin-top: 28px;
  margin-bottom: 32px;
}
.page-contact-page .form-row-agree .agree-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-weight: normal;
  font-size: 14px;
  line-height: 1.6;
  justify-content: center;
}
.page-contact-page .form-row-agree .agree-label input[type=checkbox] {
  margin-top: 4px;
  flex-shrink: 0;
}
.page-contact-page .form-row-agree .agree-label a {
  color: #7b68a6;
  text-decoration: underline;
}
.page-contact-page .form-row-agree .agree-label a:hover {
  opacity: 0.85;
}
@media (max-width: 870px) {
  .page-contact-page .form-row-agree .agree-label {
    display: block;
    text-align: center;
  }
  .page-contact-page .form-row-agree .agree-label br {
    display: none;
  }
  .page-contact-page .form-row-agree .agree-label .wpcf7-form-control-wrap {
    display: inline-block;
    margin-right: 6px;
  }
  .page-contact-page .form-row-agree .agree-label input[type=checkbox] {
    display: inline-block;
    margin: 0;
    margin-bottom: 0;
  }
}
.page-contact-page .form-submit {
  text-align: center;
  margin-bottom: 93px;
}
@media (max-width: 870px) {
  .page-contact-page .form-submit {
    margin-bottom: 65px;
  }
}
.page-contact-page .form-submit input {
  padding: 13px 96px;
  border: none;
  background-color: #0F1A45;
  color: white;
  font-size: 24px;
  border-radius: 43px;
}
@media (max-width: 870px) {
  .page-contact-page .form-submit p {
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
  }
}
.page-contact-page .btn-submit {
  padding: 16px 80px;
  background: #0F1A45;
  color: #fff;
  border: none;
  border-radius: 30px;
  font-size: 16px;
  font-weight: bold;
  cursor: pointer;
  transition: opacity 0.2s;
}
.page-contact-page .btn-submit:hover {
  opacity: 0.9;
}
.page-contact-page .contact-phone {
  text-align: center;
  padding: 40px 24px;
  border-radius: 20px;
  background-image: url(../../img/contact/bg-contact.png);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  max-width: 840px;
  margin: 0 auto;
}
.page-contact-page .contact-phone-title {
  font-family: "YuGothic";
  font-style: normal;
  font-weight: 700;
  font-size: 22px;
  line-height: 180%;
  /* ボックスの高さと同一、または40px */
  text-align: center;
  letter-spacing: 0.1em;
  color: #0F1A45;
}
@media (max-width: 870px) {
  .page-contact-page .contact-phone-title {
    font-size: 16px;
  }
}
.page-contact-page .contact-phone-number {
  font-family: "Avenir";
  font-style: normal;
  font-weight: 800;
  font-size: 56px;
  line-height: 120%;
  /* ボックスの高さと同一、または101px */
  text-align: center;
  letter-spacing: 0.03em;
  color: #0F1A45;
}
@media (max-width: 870px) {
  .page-contact-page .contact-phone-number {
    font-size: 36px;
  }
}
.page-contact-page .contact-phone-hours {
  font-family: "YuGothic";
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 180%;
  text-align: center;
  letter-spacing: 0.1em;
  color: #0F1A45;
}
@media (max-width: 870px) {
  .page-contact-page .contact-phone-hours {
    font-size: 14px;
  }
}