@charset "UTF-8";
@keyframes copySlideIn1 {
  0% {
    transform: scale(0, 1);
    transform-origin: center left;
  }
  48% {
    transform: scale(1, 1);
    transform-origin: center left;
  }
  60% {
    transform: scale(1, 1);
    transform-origin: center right;
  }
  to {
    transform: scale(0, 1);
    transform-origin: center right;
  }
}
@keyframes copySlideIn2 {
  0% {
    transform: scale(1, 0);
    transform-origin: center top;
  }
  48% {
    transform: scale(1, 1);
    transform-origin: center top;
  }
  60% {
    transform: scale(1, 1);
    transform-origin: center bottom;
  }
  to {
    transform: scale(1, 0);
    transform-origin: center bottom;
  }
}
.is-op .fv__title::before {
  animation-play-state: running;
}
.is-op .fv__title > span {
  opacity: 1;
}

.main {
  color: #000;
}

.fv {
  position: relative;
}
.fv__head {
  position: relative;
}
@media (min-width: 768px) {
  .fv__head {
    margin-top: -45px;
  }
}
@media (min-width: 768px) and (max-width: 1365px) {
  .fv__head {
    margin-top: -3.29vw;
  }
}
@media (max-width: 767px) {
  .fv__head {
    margin-top: -6.33vw;
  }
}
.fv__title {
  position: relative;
  display: inline-block;
}
.fv__title::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #000;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  animation-duration: 1.5s;
  animation-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
  animation-fill-mode: forwards;
  animation-play-state: paused;
  transform-origin: center left;
  transform: scale(0, 1);
  animation-name: copySlideIn1;
}
.fv__title > span {
  opacity: 0;
  transition-delay: 0.5s;
}
.fv__title.show::before {
  animation-play-state: running;
}
.fv__title.show > span {
  opacity: 1;
}
.fv__en {
  line-height: 1;
  letter-spacing: 0.04em;
}
@media (min-width: 768px) {
  .fv__en {
    font-size: 110px;
  }
}
@media (min-width: 768px) and (max-width: 1365px) {
  .fv__en {
    font-size: 8.05vw;
  }
}
@media (max-width: 767px) {
  .fv__en {
    font-size: 14.67vw;
  }
}
@media (min-width: 768px) {
  .fv__ja {
    line-height: 38px;
    letter-spacing: 0.16em;
  }
}
@media (max-width: 767px) {
  .fv__ja {
    line-height: 34px;
    letter-spacing: 0.08em;
  }
}

@media (min-width: 768px) {
  .form {
    padding-bottom: 200px;
  }
}
@media (max-width: 767px) {
  .form {
    padding-bottom: 85px;
  }
}
@media (min-width: 768px) {
  .form__wrapper {
    max-width: 740px;
    padding: 0 20px;
  }
}
.form__p {
  letter-spacing: 0.04em;
}
@media (min-width: 768px) {
  .form__p {
    line-height: 28px;
  }
}
@media (max-width: 767px) {
  .form__p {
    line-height: 23px;
  }
}
.form__notice {
  line-height: 28px;
  letter-spacing: 0.02em;
}
@media (max-width: 767px) {
  .form__notice {
    width: 83vw;
  }
}
.form__table {
  width: 100%;
}
@media (min-width: 768px) {
  .form__table {
    display: table;
  }
}
.form__table tr {
  width: 100%;
}
@media (min-width: 768px) {
  .form__table tr {
    display: table;
  }
}
@media (max-width: 767px) {
  .form__table tr {
    display: block;
  }
}
@media (min-width: 768px) {
  .form__table th, .form__table td {
    display: table-cell;
    padding: 5px 0;
  }
}
@media (max-width: 767px) {
  .form__table th, .form__table td {
    display: block;
  }
}
.form__table th {
  font-weight: normal;
  text-align: left;
}
@media (min-width: 768px) {
  .form__table th {
    width: 170px;
    line-height: 20px;
  }
}
@media (max-width: 767px) {
  .form__table th {
    padding: 0 5px;
  }
}
@media (min-width: 768px) {
  .form__table th.vt {
    vertical-align: top;
    padding: 10px 0;
  }
}
.form__table th span.required {
  position: relative;
  display: inline-block;
}
.form__table th span.required::after {
  content: "必須";
  display: inline-block;
  position: absolute;
  background-color: #ff6554;
  color: #fff;
  border-radius: 5px;
  font-size: 14px;
  height: 20px;
  line-height: 14px;
  padding: 3px 5px;
  top: 0;
  right: -45px;
  bottom: 0;
  margin: auto;
}
.form__input {
  width: 100%;
  height: 43px;
  line-height: 43px;
  background-color: #fff;
  border: 1px solid #524742;
  border-radius: 5px;
  padding: 10px 15px;
}
@media (max-width: 767px) {
  .form__input {
    font-size: 16px;
  }
}
.form__textarea {
  width: 100%;
  background-color: #fff;
  border: 1px solid #524742;
  border-radius: 5px;
  padding: 10px 15px;
}
@media (min-width: 768px) {
  .form__textarea {
    height: 225px;
  }
}
@media (max-width: 767px) {
  .form__textarea {
    height: 297px;
  }
}
.form__select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  border: 1px solid #524742;
  border-radius: 5px;
  height: 43px;
  line-height: 43px;
  padding: 0 15px;
  cursor: pointer;
}
@media (min-width: 768px) {
  .form__select {
    width: 233px;
  }
}
@media (max-width: 767px) {
  .form__select {
    width: 100%;
  }
}
.form__select_wrap {
  position: relative;
  cursor: pointer;
}
@media (min-width: 768px) {
  .form__select_wrap {
    width: 233px;
  }
}
@media (max-width: 767px) {
  .form__select_wrap {
    width: 100%;
  }
}
.form__select_wrap::after {
  content: "";
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  margin: auto;
  width: 7px;
  height: 7px;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  transform: rotate(45deg);
}
.form__btn {
  background: transparent;
  border-radius: 100px;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  transition: filter 0.3s;
}
@media (min-width: 768px) {
  .form__btn {
    width: 700px;
    height: 70px;
    line-height: 70px;
  }
}
@media (max-width: 767px) {
  .form__btn {
    width: 100%;
    height: 67px;
    line-height: 67px;
  }
}
.form__btn:hover {
  filter: brightness(1.1);
}
.form__confirm {
  background: #b3b38b;
}
.form__send {
  background: #d4000e;
}
.form__back {
  display: block;
  width: 100%;
}
.form__tel {
  color: #838a54;
  letter-spacing: 0.12em;
}
@media (min-width: 768px) {
  .form__tel {
    line-height: 30px;
  }
}
@media (max-width: 767px) {
  .form__tel {
    line-height: 23px;
  }
}
.form__tel span {
  position: relative;
}
@media (min-width: 768px) {
  .form__tel span {
    padding-left: 27px;
  }
}
@media (max-width: 767px) {
  .form__tel span {
    padding-left: 22px;
  }
}
.form__tel span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url(../img/contact/icon_tel.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media (min-width: 768px) {
  .form__tel span::before {
    width: 22px;
    height: 29px;
  }
}
@media (max-width: 767px) {
  .form__tel span::before {
    width: 17px;
    height: 22px;
  }
}
.form__anc {
  position: relative;
  background-color: #ccccb1;
  border: 1px solid #000;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  .form__anc {
    width: 336px;
    height: 46px;
  }
}
@media (max-width: 767px) {
  .form__anc {
    width: 320px;
    height: 60px;
  }
}
.form__anc::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 15px;
  bottom: 0;
  margin: auto;
  width: 10px;
  height: 10px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: rotate(45deg);
}
.form__error {
  display: block;
  font-size: 12px;
  color: #d4000e;
}

.confirm__table {
  width: 100%;
  border-collapse: collapse;
}
@media (min-width: 768px) {
  .confirm__table {
    display: table;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
  }
}
.confirm__table tr {
  width: 100%;
}
@media (min-width: 768px) {
  .confirm__table tr {
    display: table;
  }
}
@media (max-width: 767px) {
  .confirm__table tr {
    display: block;
  }
}
@media (min-width: 768px) {
  .confirm__table tr + tr {
    border-top: 1px solid #000;
  }
}
@media (min-width: 768px) {
  .confirm__table th, .confirm__table td {
    display: table-cell;
  }
}
@media (max-width: 767px) {
  .confirm__table th, .confirm__table td {
    display: block;
  }
}
.confirm__table th {
  font-weight: normal;
  text-align: left;
}
@media (min-width: 768px) {
  .confirm__table th {
    width: 170px;
    padding: 20px 10px;
  }
}
@media (min-width: 768px) {
  .confirm__table th.vt {
    vertical-align: top;
  }
}
.confirm__table td {
  background-color: #fff;
}
@media (min-width: 768px) {
  .confirm__table td {
    padding: 20px;
  }
}
@media (max-width: 767px) {
  .confirm__table td {
    padding: 10px 15px;
  }
}/*# sourceMappingURL=contact.css.map */