@charset "UTF-8";
section.contact {
  margin: clamp(3.75rem, 8vw, 9.375rem) 0;
}
section.contact .inner {
  width: 90%;
  margin: 0 auto;
}
section.contact .inner.max960 {
  max-width: 960px;
}
section.contact p.section_info {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 1.1875rem;
}
@media print, screen and (min-width: 1280px) {
  section.contact p.section_info {
    line-height: 2.4;
  }
}
section.contact .tel_contact {
  margin-top: clamp(3.125rem, 6vw, 6.25rem);
  border: 0.625rem solid #e6e6e6;
  border-top: none;
}
section.contact .tel_contact h2 {
  color: #00896d;
  font-size: 1.375rem;
  text-align: center;
  background-color: #e6e6e6;
  padding: 0.5em 0;
}
section.contact .tel_contact ul {
  position: relative;
  padding: clamp(3.125rem, 6vw, 6.25rem) 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.5rem 0;
}
@media print, screen and (min-width: 480px) {
  section.contact .tel_contact ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0 min(8vw, 5rem);
  }
}
@media print, screen and (min-width: 768px) {
  section.contact .tel_contact ul {
    gap: 0 calc(2 * clamp(3.75rem, 7vw, 7.5rem));
  }
}
section.contact .tel_contact ul::before {
  content: "";
  width: 50%;
  height: 1px;
  background-color: #333;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media print, screen and (min-width: 480px) {
  section.contact .tel_contact ul::before {
    width: 1px;
    height: 5rem;
  }
}
section.contact .tel_contact ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.9375rem;
}
@media print, screen and (min-width: 1024px) {
  section.contact .tel_contact ul li {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
section.contact .tel_contact ul li::before {
  content: "";
  width: 1.5625rem;
  aspect-ratio: 1/1;
  background: url(../contact/img/icon_tel.svg) center/contain no-repeat;
}
section.contact .tel_contact ul li .office p {
  font-size: 1.0625rem;
  font-weight: bold;
}
section.contact .tel_contact ul li .office p a {
  font-size: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  section.contact .tel_contact ul li .office p a[href^=tel] {
    pointer-events: none;
  }
}
section.contact .tel_contact ul li .office p small {
  display: block;
  font-size: 0.9375rem;
  font-weight: 400;
}
section.contact .mail_contact {
  margin-top: clamp(3.75rem, 8vw, 9.375rem);
}
section.contact .mail_contact h2 {
  color: #00896d;
  font-size: 1.375rem;
  text-align: center;
  background-color: #cce7e2;
  padding: 0.5em 0;
}
section.contact form {
  margin-top: clamp(3.125rem, 6vw, 6.25rem);
}
section.contact form .input_list dl + dl {
  margin-top: 2.5rem;
}
section.contact form .input_list dl dt {
  font-size: 1.0625rem;
  border-left: 0.1875rem solid #00965b;
  padding-left: 0.9375rem;
}
section.contact form .input_list dl dt.required::after {
  content: "※";
  color: #dc1c24;
  margin-left: 0.5em;
}
section.contact form .input_list dl dd {
  margin: 0.625rem 0 0 0.9375rem;
  border: 1px solid #b3b3b3;
}
section.contact form .input_list dl dd input,
section.contact form .input_list dl dd textarea {
  display: block;
  width: 100%;
  font-size: 1.125rem;
  border: none;
  padding: 0.8em 1em;
  cursor: pointer;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
section.contact form .input_list dl dd input:hover,
section.contact form .input_list dl dd textarea:hover {
  background-color: rgba(0, 137, 109, 0.1);
}
section.contact form .input_list dl dd textarea {
  min-height: 12.5rem;
  field-sizing: content;
}
section.contact form .privacy_check {
  margin-top: clamp(1.875rem, 4vw, 3.75rem);
  background-color: #f2f2f2;
  padding: 1.5625rem 5%;
}
@media print, screen and (min-width: 768px) {
  section.contact form .privacy_check {
    padding: 3.125rem 5% 1.875rem;
  }
}
section.contact form .privacy_check p {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: bolder;
}
section.contact form .privacy_check p a {
  color: #29abe2;
  text-decoration: underline;
}
section.contact form .privacy_check label {
  margin: 1.5625rem auto 0;
  width: 100%;
  max-width: 45.9375rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(5vw, 1.5625rem);
  font-size: 1.125rem;
  font-weight: bold;
  background-color: #fff;
  padding: 0.625rem 0;
  cursor: pointer;
}
section.contact form .privacy_check label:hover {
  text-decoration: underline;
}
section.contact form .privacy_check label input {
  width: 1.2em;
  aspect-ratio: 1/1;
  accent-color: #00896d;
}
section.contact form .btn_area {
  margin-top: clamp(3.75rem, 8vw, 9.375rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.25rem clamp(1.875rem, 4vw, 3.75rem);
}
section.contact form .btn_area button {
  width: 80%;
  max-width: 25rem;
  color: #fff;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(4vw, 1.25rem);
  border-radius: 0.625rem;
  border: none;
  padding: 1.15em 0;
  cursor: pointer;
}
@media print, screen and (min-width: 480px) {
  section.contact form .btn_area button {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
section.contact form .btn_area button[type=reset], section.contact form .btn_area button[type=button] {
  background-color: #808080;
}
section.contact form .btn_area button[type=submit] {
  background-color: #00896d;
}
section.contact form .btn_area button::after {
  content: "";
  width: 1em;
  aspect-ratio: 1/1;
  -webkit-mask: url(../contact/img/icon-arrow.svg) center/contain no-repeat;
          mask: url(../contact/img/icon-arrow.svg) center/contain no-repeat;
  background-color: #fff;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
section.contact form .btn_area button:hover::after {
  position: relative;
  left: 0.5em;
}
section.contact.confirm label,
section.contact.confirm input,
section.contact.confirm textarea {
  pointer-events: none;
}
section.contact.thanks .btn_area {
  margin-top: clamp(2.5rem, 5vw, 5rem);
}
section.contact.thanks .btn_area a {
  margin: 0 auto;
}/*# sourceMappingURL=contact.css.map */