#contactform .wrap {
  padding-top: 60px;
}
#contactform .wrap .contents {
  max-width: 840px;
}
#contactform .wrap .contents > p {
  margin-bottom: 3em;
}
#contactform .wrap .contents > p.recaptchatxt {
  font-size: 1.2rem;
  text-align: center;
  color: #666666;
  margin: 3em auto 0;
}
#contactform .wrap .contents > p.recaptchatxt a {
  color: var(--color_main);
  text-decoration: underline;
}
#contactform .wrap .contents .wpcf7-response-output {
  margin: 0 auto 2em;
}
#contactform .wrap .contents dl {
  display: grid;
  font-size: 1.6rem;
  grid-template-columns: 15em 1fr;
  grid-row-gap: 1.5em;
  margin-bottom: 20px;
}
#contactform .wrap .contents dl dt, #contactform .wrap .contents dl dd {
  line-height: 1.66;
}
#contactform .wrap .contents dl dt {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  grid-gap: 0.5em;
  padding-top: 0.66em;
}
#contactform .wrap .contents dl dt span {
  background-color: #C5C5C5;
  color: #FFFFFF;
  padding: 0.2em 0.5em 0.1em;
  font-size: 0.8em;
}
#contactform .wrap .contents dl dt span.required {
  background-color: #cc0000;
}
#contactform .wrap .contents dl dt span.small {
  display: contents;
  color: inherit;
}
#contactform .wrap .contents dl dt span.small a {
  color: var(--color_main);
}
#contactform .wrap .contents dl dd {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#contactform .wrap .contents dl dd > span {
  width: 100%;
}
#contactform .wrap .contents dl dd input[type="text"], #contactform .wrap .contents dl dd input[type="email"], #contactform .wrap .contents dl dd input[type="tel"], #contactform .wrap .contents dl dd input[type="date"], #contactform .wrap .contents dl dd input[type="number"] {
  padding: 1em;
  background-color: #f5f5f5;
  border: 1px solid #C5BFBF;
  width: 100%;
  font-size: 16px;
}
#contactform .wrap .contents dl dd.zip {
  column-gap: 0.5em;
}
#contactform .wrap .contents dl dd.zip input {
  width: 10em;
}
#contactform .wrap .contents dl dd.zip span[data-name="yourname1"] {
  margin-right: 1em;
}
#contactform .wrap .contents dl dd.zip > span {
  width: auto;
}
#contactform .wrap .contents dl dd textarea {
  padding: 0.5em;
  background-color: #f5f5f5;
  border: 1px solid #C5BFBF;
  width: 100%;
  height: 8em;
  font-size: 16px;
}
#contactform .wrap .contents dl dd p {
  font-size: 1.5rem;
  line-height: 1.5;
  color: #7B7B7B;
  margin-top: 0.5em;
}
#contactform .wrap .contents dl dd p a {
  color: var(--color_main);
  text-decoration: underline;
}
#contactform .wrap .contents dl dd .wpcf7-list-item-label a {
  color: var(--color_main);
  text-decoration: underline;
}
#contactform .wrap .contents dl dd .small {
  display: contents;
  color: inherit;
}
#contactform .wrap .contents dl dd .small a {
  color: var(--color_main);
  text-decoration: underline;
}
#contactform .wrap .contents dl dd .wpcf7-list-item {
  margin: 0 1em 0 0;
}
#contactform .wrap .contents dl dd .wpcf7-checkbox {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 10px;
}
#contactform .wrap .contents .btnwrap {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-top: 50px;
}
#contactform .wrap .contents .btnwrap input {
  font-size: 1.6rem;
  color: #FFFFFF;
  padding: 0 2.5em;
  font-weight: 600;
  border: 2px solid var(--color_main);
  display: grid;
  grid-template-columns: repeat(2, auto);
  justify-content: center;
  align-items: center;
  grid-gap: 0.66em;
  height: 4em;
  width: 100%;
  max-width: 16em;
  background-color: var(--color_main);
}
#contactform .wrap .contents .btnwrap input.wpcf7-previous {
  border: none;
  background-color: #bababa;
  color: #FFFFFF;
}
#contactform .wrap .contents .wpcf7-spinner {
  position: absolute;
  bottom: -2em;
  top: auto;
}
#contactform.thanks .wrap .contents {
  max-width: 800px;
}
#contactform.thanks .wrap .contents h2 {
  text-align: center;
}
#contactform.thanks .wrap .contents p {
  margin-bottom: 1em;
}
#contactform.thanks .wrap .contents .btn {
  margin: 30px auto 0;
  display: grid;
  width: 12em;
  background-color: var(--color_main);
  color: #FFFFFF;
  height: 3em;
  align-items: center;
  justify-content: center;
}
#contactform.confirm .wrap .contents dl dt {
  padding-top: 0;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
  border-color: var(--color_main);
}
@media screen and (max-width: 768px) {
  #contactform .wrap {
    padding-top: 30px;
  }
  #contactform .wrap .contents > p.recaptchatxt {
    font-size: min(3.4vw, 1.2rem);
  }
  #contactform .wrap .contents dl {
    font-size: 1.5rem;
    grid-template-columns: 1fr;
    grid-row-gap: 0.66em;
    margin-bottom: 15px;
  }
  #contactform .wrap .contents dl dt {
    padding-top: 0;
  }
  #contactform .wrap .contents dl dd {
    margin-bottom: 10px;
  }
  #contactform .wrap .contents dl dd input[type="text"], #contactform .wrap .contents dl dd input[type="email"], #contactform .wrap .contents dl dd input[type="tel"], #contactform .wrap .contents dl dd input[type="date"], #contactform .wrap .contents dl dd input[type="number"] {
    padding: 0.5em;
  }
  #contactform .wrap .contents dl dd textarea {
    height: 6em;
  }
  #contactform .wrap .contents dl dd p {
    font-size: 1.3rem;
  }
  #contactform .wrap .contents dl dd.zip input {
    width: 6em;
  }
  #contactform .wrap .contents dl dd .wpcf7-list-item {
    margin: 0;
  }
  #contactform .wrap .contents dl dd.detail .wpcf7-form-control {
    grid-template-columns: 1fr;
  }
  #contactform .wrap .contents dl dd.school .wpcf7-form-control {
    grid-template-columns: repeat(2, auto);
  }
  #contactform .wrap .contents .btnwrap {
    margin-top: 30px;
  }
  #contactform .wrap .contents .btnwrap input {
    font-size: 1.4rem;
    padding: 0 0.5em;
    height: 3.4em;
    max-width: 11em;
  }
  #contactform.thanks .wrap .contents .btn {
    font-size: 1.5rem;
  }
}
