.p-contact {
  color: #4a3f35;
  font-weight: 400;
  padding: 80px 0;

  & .sp-only {
    display: none;
  }

  & .wpcf7-not-valid-tip {
    font-size: 1.4rem;
    margin-top: 8px;
  }

  & .wpcf7-response-output {
    display: none;
  }

  & .wpcf7-spinner {
    display: none;
  }
}

.p-contact-form {
  background-color: #ffffff;
  border-radius: 20px;
  box-shadow: 0 15px 35px rgba(139, 117, 88, 0.15),
    0 5px 15px rgba(74, 63, 53, 0.08);
  margin: 0 auto;
  max-width: 750px;
  overflow: hidden;
}

.c-contact-ttl {
  background: linear-gradient(135deg, #d4a574 0%, #b8956a 100%);
  color: #ffffff;
  padding: 40px 30px;
  text-align: center;

  & > h2 {
    font-size: 3.5rem;
    margin-bottom: 8px;
    font-weight: 700;
  }

  & > p {
    font-size: 1.6rem;
    opacity: 0.9;
  }
}

.c-contact-form {
  padding: 40px 35px;

  & > p {
    color: #666666;
    font-size: 1.5rem;
    margin-bottom: 35px;
    text-align: center;
  }
}

.c-contact-form-hidden {
  height: 0;
  overflow: hidden;
}

.c-contact-form-input,
.c-contact-form-radio {
  margin-bottom: 25px;
}

.c-contact-form-input input,
.c-contact-form-textarea textarea {
  background: #fefcf9;
  border: 2px solid #e8dcc6;
  border-radius: 10px;
  display: block;
  font-size: 1.5rem;
  padding: 14px 18px;
  width: 100%;

  &::placeholder {
    opacity: 0.9;
  }
}

.c-contact-form-label {
  align-items: center;
  color: #5d4e41;
  display: flex;
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 8px;

  & > span {
    align-items: center;
    background: #e67e22;
    border-radius: 3px;
    color: #ffffff;
    display: flex;
    font-size: 1.1rem;
    height: 18px;
    justify-content: center;
    margin-left: 6px;
    width: 34px;
  }
}

.c-contact-form-radio {
  .wpcf7-form-control {
    display: flex;
    flex-direction: column;
    gap: 10px;
  }

  & .wpcf7-list-item {
    display: block;
    margin: 0;

    & > label {
      align-items: center;
      background: #fefcf9;
      border: 2px solid #e8dcc6;
      border-radius: 10px;
      cursor: pointer;
      display: flex;
      font-size: 1.4rem;
      padding: 12px 16px;
      position: relative;
      transition-duration: 0.3s;
      transition-timing-function: ease-in-out;

      &:has(input:checked) {
        background: linear-gradient(135deg, #d4a574, #b8956a);
        border-color: #d4a574;
        box-shadow: 0 4px 15px rgba(212, 165, 116, 0.3);
        color: #ffffff;
        transform: translateX(2px);

        &::after {
          background-color: #ffffff;
        }

        &::before {
          background-color: #d4a574;
          border-color: #ffffff;
        }
      }

      &::after,
      &::before {
        aspect-ratio: 1 / 1;
        border-radius: 50%;
        content: "";
        transition-duration: 0.3s;
        transition-timing-function: ease-in-out;
      }

      &::after {
        left: calc(16px + ((14px + 2px * 2) / 2));
        position: absolute;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 8px;
      }

      &::before {
        border: 2px solid #c7a882;
        display: block;
        margin-right: 12px;
        width: 14px;
      }

      & > span {
        display: block;

        &::after,
        &::before {
          content: none;
        }
      }
    }
  }
}

.c-contact-form-submit {
  & input {
    align-items: center;
    background: linear-gradient(135deg, #d4a574 0%, #b8956a 100%);
    border-radius: 50px;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    font-size: 1.6rem;
    font-weight: 700;
    height: 56px;
    justify-content: center;
    margin: 0 auto;
    transition-duration: 0.3s;
    transition-timing-function: ease-in-out;
    width: 276px;

    @media (any-hover: hover) {
      &:hover {
        transform: scale(0.95);
      }
    }
  }
}

.c-contact-form-textarea {
  margin-bottom: 30px;

  & textarea {
    resize: none;
  }
}

@media screen and (max-width: 767px) {
  .p-contact {
    padding: 64px 0;

    & .sp-only {
      display: block;
    }

    & .wpcf7-not-valid-tip {
      font-size: 1.12rem;
      margin-top: 6.4px;
    }
  }

  .p-contact-form {
    border-radius: 16px;
    box-shadow: 0 12px 28px rgba(139, 117, 88, 0.15),
      0 4px 12px rgba(74, 63, 53, 0.08);
    max-width: none;
    width: 90%;
  }

  .c-contact-ttl {
    padding: 32px 24px;

    & > h2 {
      font-size: 2.8rem;
      margin-bottom: 6.4px;
    }

    & > p {
      font-size: 1.28rem;
    }
  }

  .c-contact-form {
    padding: 32px 28px;

    & > p {
      font-size: 1.2rem;
      margin-bottom: 28px;
    }
  }

  .c-contact-form-input,
  .c-contact-form-radio {
    margin-bottom: 20px;
  }

  .c-contact-form-input input,
  .c-contact-form-textarea textarea {
    border: 1.6px solid #e8dcc6;
    border-radius: 8px;
    font-size: 1.2rem;
    padding: 11.2px 14.4px;
  }

  .c-contact-form-label {
    font-size: 1.12rem;
    margin-bottom: 6.4px;

    & > span {
      border-radius: 2.4px;
      font-size: 0.88rem;
      height: 14.4px;
      margin-left: 4.8px;
      width: 27.2px;
    }
  }

  .c-contact-form-radio {
    .wpcf7-form-control {
      gap: 8px;
    }

    & .wpcf7-list-item {
      & > label {
        border: 1.6px solid #e8dcc6;
        border-radius: 8px;
        font-size: 1.12rem;
        padding: 9.6px 12.8px;

        &:has(input:checked) {
          box-shadow: 0 3.2px 12px rgba(212, 165, 116, 0.3);
          transform: translateX(1.6px);
        }

        &::after {
          left: calc(12.8px + ((11.2px + 1.6px * 2) / 2));
          width: 6.4px;
        }

        &::before {
          border: 1.6px solid #c7a882;
          margin-right: 9.6px;
          width: 11.2px;
        }
      }
    }
  }

  .c-contact-form-submit {
    & input {
      border-radius: 40px;
      font-size: 1.28rem;
      height: 44.8px;
      width: 220.8px;
    }
  }

  .c-contact-form-textarea {
    margin-bottom: 24px;
  }
}
