@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
.title-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
  font-size: 18px;
  gap: 1em;
  margin-bottom: 2.5em;
}
.title-group h6 {
  color: #96DFE5;
  letter-spacing: 0.2em;
  line-height: 100%;
  font-family: "libre-franklin", YuGothic, "Yu Gothic", "Yu Gothic Medium", Meiryo, sans-serif;
}
.title-group h1,
.title-group h2 {
  display: flex;
  justify-content: space-between;
}
.title-group h1::after, .title-group h1:before,
.title-group h2::after,
.title-group h2:before {
  content: "";
  display: block;
  width: 1.5em;
  height: 1.5em;
}
.title-group h1::after,
.title-group h2::after {
  background-size: contain;
  transform: rotate(30deg);
  border-right: 2px dashed #96DFE5;
  transform-origin: top right;
}
.title-group h1:before,
.title-group h2:before {
  background-size: contain;
  transform: rotate(-30deg);
  border-left: 2px dashed #96DFE5;
  transform-origin: top left;
}

body {
  background-image: url(../img/contact/contact-back-2.webp), url(../img/top/top-back-1.svg);
  background-position: bottom right, top left;
  background-repeat: no-repeat;
  background-size: 100%;
}

@media (max-width: 768px) {
  body {
    background-image: url(../img/top/top-sp-1.svg);
    background-position: top left;
    background-size: clamp(250px, 35vw, 360px);
  }
}
.contact-main {
  background: url(../img/contact/contact-back.webp) top 80px right no-repeat;
  background-size: 100%;
}

.rounded-st {
  border-radius: 42px;
}

.shadow-st {
  filter: drop-shadow(0 3px 66px rgba(43, 43, 43, 0.1));
}

.teal-point {
  display: block;
  width: 6px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #96DFE5;
}

.gre-disclaimer {
  color: #808080;
  text-align: center;
  max-width: 500px;
  margin: 0 auto;
}
.gre-disclaimer a {
  text-decoration: underline !important;
}

section.contact-top {
  width: 83%;
  max-width: 1200px;
  margin-bottom: 54px;
}
section.contact-top .top-banner {
  width: 100%;
  height: 355px;
}
section.contact-top .top-banner img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50px;
  object-fit: cover;
}

@media (max-width: 768px) {
  .contact-top {
    align-items: center;
  }
}
section.contact-info {
  padding-top: clamp(200px, 25vw, 265px);
}
section.contact-info .title-group {
  margin-bottom: 4em;
}
section.contact-info .intro-text {
  margin-bottom: 3em;
  letter-spacing: 0.1em;
  line-height: 200%;
}
section.contact-info .call {
  display: flex;
  align-items: center;
  box-sizing: border-box;
  padding: 30px clamp(36px, 14%, 90px) 30px clamp(24px, 10%, 60px);
  width: 85.6%;
  max-width: 790px;
  background-color: #ffffff;
}
section.contact-info .call-label {
  white-space: nowrap;
  font-size: 20px;
  letter-spacing: 0.1em;
}
section.contact-info .point-spacer {
  height: 100%;
  min-height: 107px;
  margin: 0 clamp(20px, 10%, 58px) 0 clamp(20px, 10%, 52px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
section.contact-info .point-spacer .teal-point:nth-child(odd) {
  display: none;
}
section.contact-info .call-info a {
  display: flex;
  align-items: center;
  margin-bottom: 5px;
  gap: 0.25em;
  font-size: clamp(2.4rem, 3vw, 4rem);
  letter-spacing: 0.14em;
  line-height: 120%;
  color: #96DFE5;
  -webkit-text-stroke: 2.5px #96DFE5;
  width: fit-content;
}
section.contact-info .call-info a img {
  width: 1.3em;
  -webkit-text-stroke: unset;
}
section.contact-info .call-info p {
  width: 100%;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  margin-left: clamp(24px, 16%, 75px);
}
@media screen and (max-width: 750px) {
  section.contact-info .call {
    flex-direction: column;
    padding: 60px clamp(36px, 10vw, 60px);
  }
  section.contact-info .point-spacer {
    flex-direction: row;
    min-height: unset;
    width: 96%;
    margin: 42px auto;
  }
  section.contact-info .point-spacer .teal-point:nth-child(odd) {
    display: block;
  }
  section.contact-info .call-info p {
    margin-left: clamp(24px, 12%, 75px);
  }
}

.contact-wrapper {
  background: url(../img/contact/contact-form-bg.webp) center no-repeat;
  background-size: contain;
}

section.contact-form {
  width: 85.6%;
  max-width: 1000px;
  margin: clamp(80px, 10vw, 115px) auto 124px;
}
section.contact-form .top-point-spacer {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 45px;
}
section.contact-form .top-point-spacer .teal-point {
  width: clamp(6px, 1vw, 11px);
}
section.contact-form .cta {
  display: flex;
  align-items: center;
  margin-bottom: clamp(45px, 6vw, 82px);
  letter-spacing: 0.1em;
  line-height: 140%;
  font-size: clamp(16px, 2vw, 23px);
  gap: 1em;
}
section.contact-form .cta img {
  width: 2.24em;
}
section.contact-form .wpcf7 {
  width: 100%;
}
section.contact-form .flex-table {
  width: 100%;
}
section.contact-form .flex-table .radio-col {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}
section.contact-form .flex-table .privacy-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: clamp(1.6rem, 1.8vw, 2.1rem);
  margin-bottom: 4.5em;
}
section.contact-form .flex-table .privacy-row dd {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.8em;
}
section.contact-form .flex-table .privacy-row .wpcf7-list-item-label {
  color: #333333;
}
section.contact-form .flex-table .privacy-row a {
  color: #eba067;
  font-size: 400;
  text-decoration: underline !important;
  -webkit-text-stroke: 1px solid #eba067;
}
@media screen and (max-width: 750px) {
  section.contact-form .top-point-spacer .teal-point:nth-child(2) {
    display: none;
  }
}

.submit-container {
  display: flex;
  align-items: center;
  text-align: center;
  margin: 0 auto 2em;
}
.submit-container p {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
  margin: 0 auto;
}
.submit-container .submit-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(320px, 70vw, 800px);
  height: clamp(40px, 7vw, 80px);
  max-width: 96%;
  padding: 0;
  border: unset;
  background-color: #DFED6D;
  color: #333333;
  font-size: clamp(2rem, 2vw, 2.7rem);
  border-radius: 48px;
}

section.annotation {
  color: #736a63;
  font-family: "Noto Sans JP", sans-serif;
  padding-bottom: clamp(160px, 20vw, 250px);
}
section.annotation .return-top {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: clamp(240px, 30vw, 378px);
  max-width: 60%;
  height: 74px;
  border-radius: 37px;
  margin: clamp(40px, 5vw, 60px);
  background-color: #E0D2CC;
}
section.annotation .return-top img,
section.annotation .return-top a {
  height: fit-content;
  display: block;
}
section.annotation .return-top img {
  width: 19px;
}
section.annotation p {
  font-size: 18px;
  margin-bottom: 1.3em;
}
section.annotation a.privacy-link {
  line-height: 95%;
  padding: 0 0.75em;
  border-left: 1px solid #736a63;
  border-right: 1px solid #736a63;
}

/*# sourceMappingURL=contact.css.map */
