@charset "utf-8";
:root {
  --contact-w : min(100%, 890px);
  --contact-icon-left : 70px;
}

.contact-tel-inner {
  width: var(--contact-w);
  padding: 0 var(--side-padding);
  margin: 0 auto;
  display: flex;
  gap: 40px;
  align-items: center;
}
@media screen and (width <= 768px) {
  .contact-tel-inner {
    flex-flow: column;
    gap: 3.9vw;
  }
}

.contact-tel-icon {
  margin-left: var(--contact-icon-left);
  width: 112px;
  aspect-ratio: 1 / 1;
}
@media screen and (width <= 768px) {
  .contact-tel-icon {
    margin-left: 0;
    width: clamp(80px, 60.916px + 5.089vw, 100px);
  }
}

.contact-tel-text {
  & h2 {
    font-size: 24px;
    margin-top: -0.5em;
  }
  & a {
    display: block;
    margin-top: .3em;
    font-family: var(--font-family-din);
    font-size: 30px;
    font-weight: 700;
    line-height: 1;
    color: var(--color-main);
    pointer-events: none;
  }
  & p {
    margin-top: .5em;
    font-size: 18px;
    line-height: 1;
  }
}
@media screen and (width <= 768px) {
  .contact-tel-text {
    & h2 {
      font-size: clamp(20px, 16.183px + 1.018vw, 24px);
    }
    & a {
      font-size: clamp(22px, 16.275px + 1.527vw, 28px);
      pointer-events: initial;
    }
    & p {
      font-size: clamp(16px, 14.092px + 0.509vw, 18px);
    }
  }
}

.contact-form {
  width: var(--contact-w);
  padding: 0 var(--side-padding);
  margin: 200px auto 0;
}
@media screen and (width <= 768px) {
  .contact-form {
    margin-top: 13.02vw;
  }
}

.contact-form-inner {
  padding: 90px 20px 90px 0;
  background-color: #f6f6f6;
}
@media screen and (width <= 768px) {
  .contact-form-inner {
    padding: 7.81vw 3.90vw;
  }
}

.contact-form-title {
  padding-left: var(--contact-icon-left);
  display: flex;
  gap: 40px;
  align-items: center;
}
@media screen and (width <= 768px) {
  .contact-form-title {
    padding-left: 0;
    flex-flow: column;
    gap: 3.9vw;
  }
  .contact-form-icon {
    margin-left: 0;
    width: clamp(80px, 60.916px + 5.089vw, 100px);
  }
}

.contact-form-text {
  & h2 {
    font-size: 24px;
    margin-top: -0.5em;
  }
  & p {
    margin-top: .8em;
    font-size: 18px;
    & a:hover {
      color: var(--color-main);
      text-decoration: underline;
    }
  }
}
@media screen and (width <= 768px) {
  .contact-form-text {
    & h2 {
      font-size: clamp(18px, 14.183px + 1.018vw, 22px);
    }
    & p {
      font-size: clamp(14px, 12.092px + 0.509vw, 16px);
    }
  }
}

.contact-form-wrap {
  width: min(100%, 600px);
  padding: 0 var(--side-padding);
  margin: 130px auto 0;
}
@media screen and (width <= 768px) {
  .contact-form-wrap {
    width: 100%;
    padding: 0;
    margin-top: 10.41vw;
  }
}

#contactForm {
  & label {
    display: block;
    margin-top: 40px;
    font-weight: 600;
    &:first-of-type {
      margin-top: 0;
    }
    & span {
      margin-left: 0.8em;
      font-size: 12px;
      color: var(--color-main);
      &.note {
        font-weight: 400;
        color: var(--color-text);
      }
    }
  }
  & input, & textarea {
    width: 100%;
    padding: 10px;
    border: 1px solid #aaa;
    border-radius: 5px;
  }
  & .agreement {
    margin-top: 30px;
    font-weight: 400;
    & input {
      width: unset;
    }
    & a:hover {
      color: var(--color-main);
      text-decoration: underline;
    }
  }
}
@media screen and (width <= 768px) {
  #contactForm {
    & label {
      margin-top: 5.2vw;
    }
    & input, & textarea {
      font-size: 16px;
    }
    & .agreement {
      margin-top: 3.9vw;
    }
  }
}

.button-group {
  margin-top: 90px;
  display: flex;
  gap: 2em;
  justify-content: center;
  & button, a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: min(100%, 232px);
    margin: 0 auto;
    padding: 15px;
    border: 1.5px solid var(--color-main);
    border-radius: 9999px;
    background-color: var(--color-white);
    color: var(--color-main);
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    transition: all var(--transition-time) ease-out;
    z-index: 1;
    overflow: hidden;
    & > span {
      position: relative;
      width: 17px;
      height: 17px;
      margin: 0 .5em;
      background-color: var(--color-main);
      border-radius: 50%;
      transition: background-color var(--transition-time) ease-out;
      &::after {
        position: absolute;
        content: "";
        top: 1px;
        left: 1px;
        width: 15px;
        height: 15px;
        background-color: var(--color-white);
        mask-image: url(/assets/img/common/cmn_more_arrow.svg);
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: cover;
        transition: background-color var(--transition-time) ease-out;
      }
    }
    &::after {
      background: var(--color-main);
      position: absolute;
      content: "";
      top: 0;
      left: 0;
      width: 100%;
      height: 100px;
      transform-origin: left top;
      transform: skewY(-20deg) scale(1, 0);
      transition: var(--transition-time) ease-out;
      z-index: -1;
    }
    &:hover {
      border-color: var(--color-white);
      color: var(--color-white);
      &::after {
        transform: skewY(-10deg) scale(1, 1);
      }
      & > span {
        background-color: var(--color-white);
        &::after {
          background-color: var(--color-main);
        }
      }
    }
  }
  & a._back {
    & > span::after {
      transform: rotate(180deg);
    }
  }
}
@media screen and (width <= 768px) {
  .button-group {
    margin-top: 10.41vw;
    flex-wrap: wrap;
    flex-flow: column-reverse;
  }
}

.contact-footer {
  padding: 200px 0;
}
@media screen and (width <= 768px) {
  .contact-footer {
    padding: 13.02vw 0;
  }
}

.contact-footer-inner {
  width: var(--contact-w);
  padding: 0 var(--side-padding);
  margin: 0 auto;
  & p {
    padding: .5em;
    font-size: 18px;
    color: var(--color-main);
    text-align: center;
    border: solid 1px var(--color-main);
  }
}
@media screen and (width <= 768px) {
  .contact-footer-inner {
    & p {
      font-size: clamp(14px, 12.092px + 0.509vw, 16px);
    }
  }
}

.errmsg {
  color: #db0101;
}

/*** confirm ***/
.contact-form-wrap._confirm {
  margin-top: 60px;
  width: min(100%, 700px);
}
@media screen and (width <= 768px) {
  .contact-form-wrap._confirm {
    margin-top: 6.51vw;
    width: 100%;
  }
}

.contact-confirm-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
  & dt {
    width: 10em;
    font-weight: 700;
    text-align: right;
  }
  & dd {
    width: calc(100% - 11em);
  }
}
@media screen and (width <= 768px) {
  .contact-confirm-list {
    gap: 0 1em;
    & dt {
      width: 100%;
      text-align: left;
      margin-top: 1.5em;
    }
    & dd {
      width: 100%;
    }
  }
}

/*** thanks ***/
.contact-form-inner._thanks {
  padding: 90px 20px;
}
@media screen and (width <= 768px) {
  .contact-form-inner._thanks {
    padding: 7.81vw 3.90vw;
  }
}

.thanks-text {
  margin: 60px auto;
  width: min(100%, 700px);
}
@media screen and (width <= 768px) {
  .thanks-text {
    margin: 6.51vw auto;
    width: 100%;
  }
}

.thanks-btn {
  & a {
    margin: 0 auto;
  }
}