/* page_request_contact */

.contact_fv_area img,
.contact_content_section img {
  width: 100%;
}

.contact_content_section_img1 {
  margin: 5% 0;
}

.contact_content_section_img2 {
  margin-bottom: 5%;
}

.form_post_title {
  display: none;
}

@media (max-width: 767px) {
  .contact_content_section_img2 {
    margin-bottom: 0%;
    margin-top: 15%;
  }
}

#page_web_contact .contact__desc {
  position: relative;
  padding-bottom: 2rem;
  margin: 2rem 0;
}

@media (min-width: 768px) {
  #page_web_contact .contact__desc {
    padding-top: 0;
    margin: 0 0 4rem;
  }
}

#page_web_contact .contact__desc::after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 0;
  margin-top: 0;
  content: "";
  background-color: #e6e6e6;
  border-top: 1px solid #e6e6e6;
}

@media (min-width: 768px) {
  #page_web_contact .contact__desc::after {
    margin-top: -2rem;
    border-top: 1px solid #e6e6e6;
  }
}

#page_web_contact .contact__desc > h2 {
  position: relative;
  margin-top: 4rem;
  margin-bottom: 1rem;
  counter-reset: number 0;
}

#page_web_contact .contact__desc > h2::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0;
  margin-top: 0;
  content: "";
  background-color: #e6e6e6;
  border-top: 1px solid #e6e6e6;
}

@media (min-width: 768px) {
  #page_web_contact .contact__desc > h2::before {
    margin-top: -2rem;
    border-top: 1px solid #e6e6e6;
  }
}

#page_web_contact .contact__desc > h2 span {
  font-size: 1.5rem;
  color: #cc1d2c;
  letter-spacing: 0.5px;
}

#page_web_contact .contact__desc > h2 ~ p {
  margin-left: 0;
}

#page_web_contact .contact__desc > h2 ~ p + h3 {
  margin-top: 1rem;
}

#page_web_contact .contact__desc > h2 ~ p span {
  color: #e60012;
}

#page_web_contact .contact__desc > h2:last-of-type ~ p {
  margin-left: 0;
}

#page_web_contact .contact__desc .smallTitle {
  position: relative;
  padding-top: 0.25rem;
  padding-left: 2.5rem;
  margin-bottom: 1rem;
}

#page_web_contact .contact__desc .smallTitle span {
  margin-top: 1rem;
  color: #000;
}

#page_web_contact .contact__desc .smallTitle span::before {
  position: absolute;
  top: 0;
  left: 0;
  padding: 5.5px 7px;
  font-family: "Roboto";
  font-size: 1rem;
  line-height: 1.3125;
  color: #fff;
  content: counter(number, decimal-leading-zero) " ";
  counter-increment: number 1;
  background-color: #e60012;
  border-radius: 2px;
}

#page_web_contact .contact__desc .smallTitle ~ p:not(h2 + p),
#page_web_contact .contact__desc .smallTitle ~ ol {
  margin-left: 2rem;
}

#page_web_contact .page_contact__mail {
  margin-top: 2rem;
}

#page_web_contact .page_contact__mail ::-webkit-input-placeholder {
  color: #b3b3b3;
}

#page_web_contact .page_contact__mail ::-moz-placeholder {
  color: #b3b3b3;
}

#page_web_contact .page_contact__mail :-ms-input-placeholder {
  color: #b3b3b3;
}

#page_web_contact .page_contact__mail ::-ms-input-placeholder {
  color: #b3b3b3;
}

#page_web_contact .page_contact__mail ::placeholder {
  color: #b3b3b3;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail {
    margin-top: 2rem;
  }
}

@media (max-width: 767px) {
  #page_web_contact .page_contact__mail {
    margin-right: -1rem;
    margin-left: -1rem;
  }
}

#page_web_contact .page_contact__mail dt {
  margin-top: 1rem;
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail dt {
    margin-top: 1.5rem;
  }
}

#page_web_contact .page_contact__mail dt:first-of-type {
  margin-top: 0;
}

#page_web_contact span.required {
  padding: 0.1rem 0.75rem 0.25rem;
  margin-left: 0.5rem;
  font-size: 12px;
  font-weight: normal;
  color: #fff;
  background: #e60012;
  border-radius: 24px;
}

#page_web_contact span.optional {
  padding: 0.1rem 0.75rem 0.25rem;
  margin-left: 0.5rem;
  font-size: 12px;
  font-weight: normal;
  color: #fff;
  background: #6d6d6d;
  border-radius: 24px;
}

#page_web_contact .page_contact__mail dd.double {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-column-gap: min(5.33%, 20px);
  -moz-column-gap: min(5.33%, 20px);
  column-gap: min(5.33%, 20px);
}

#page_web_contact .page_contact__mail dd.double .wpcf7-form-control-wrap {
  width: 100%;
}

@media (max-width: 767px) {
  #page_web_contact
    .page_contact__mail
    dd.double
    .wpcf7-form-control-wrap:not(:last-of-type) {
    margin-bottom: 1rem;
  }

  #page_web_contact .date_form {
    width: 100%;
  }
}

#page_web_contact .page_contact__mail input:not([type="checkbox"]),
#page_web_contact .page_contact__mail textarea,
#page_web_contact .page_contact__mail--scrl,
#page_web_contact .page_contact__mail--check {
  display: block;
  width: 100%;
  padding: 0.75rem 25px;
  overflow: hidden;
  font-size: 14px;
  border: 1px solid #000000;
  border-radius: 8px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: black;
}

#page_web_contact .page_contact__mail--lead {
  padding-top: 0.5rem;
  font-size: 14px;
  color: #e60012;
}

#page_web_contact .page_contact__mail--scrl div {
  height: 220px;
  overflow-y: scroll;
}

#page_web_contact .page_contact__mail--scrl div h3 {
  font-weight: bold;
}

#page_web_contact .page_contact__mail--scrl div h4 {
  margin-top: 1.2rem;
  margin-bottom: 0.2rem;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail--scrl div {
    height: 150px;
  }
}

#page_web_contact .page_contact__mail--scrl div::-webkit-scrollbar {
  width: 10px;
}

#page_web_contact .page_contact__mail--scrl div::-webkit-scrollbar-track {
  background-color: none;
}

#page_web_contact .page_contact__mail--scrl div::-webkit-scrollbar-thumb {
  background-color: #e60012;
  border-radius: 10px;
}

#page_web_contact .page_contact__mail--check {
  padding: 0;
  margin-top: 0.5rem;
  margin-bottom: 2rem;
  border: none;
}

#page_web_contact .page_contact__mail--check .wpcf7-list-item {
  position: relative;
  display: block;
  width: 100%;
  margin-left: 0;
}

#page_web_contact .page_contact__mail--check label {
  width: 100%;
  padding: 0.75rem 25px 0.75rem 50px;
  display: flex;
  justify-content: center;
}

#page_web_contact .page_contact__mail--check input {
  top: calc(50% - 13px) !important;
  left: calc(50% - 138px) !important;
}

#page_web_contact .page_contact__mail--check.multiple {
  padding-right: 0;
  padding-left: 0;
  margin-bottom: 0;
  border: none;
  border-radius: 0;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail--check.multiple .wpcf7-form-control {
    gap: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}

#page_web_contact .page_contact__mail--check.multiple .wpcf7-list-item {
  width: 48%;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail--check.multiple .wpcf7-list-item {
    width: 160px;
  }
}

#page_web_contact
  .page_contact__mail--check.multiple
  .wpcf7-list-item:not(:last-of-type) {
  margin-bottom: 1rem;
}

#page_web_contact .page_contact__mail--check.multiple .wpcf7-list-item label {
  position: relative;
  font-size: 14px;
  font-weight: bold;
  color: #000000;
  border: 1px solid #000000;
  border-radius: 8px;
  cursor: pointer;
  background-color: #efefef;
  padding: 12px 16px;
  justify-content: flex-start;
}

#page_web_contact .page_contact__mail--check.multiple input[type="checkbox"] {
  border-radius: 50%;
}

@media (max-width: 767px) {
  #page_web_contact .page_contact__mail--check {
    margin-bottom: 1rem;
  }
}

/* 同意のチェックボックス */
#page_web_contact .page_contact__mail--check input[type="checkbox"] {
  position: absolute;
  width: 24px;
  height: 24px;
  font-size: 16px;
  text-align: center;
  border: 1px solid #000000;
  border-radius: 5px;
  cursor: pointer;
}

#page_web_contact
  .page_contact__mail--check
  input[type="checkbox"]:checked::before {
  position: absolute;
  top: -1px;
  left: -1px;
  width: 24px;
  height: 24px;
  content: "";
  background-color: #e60012;
  border-radius: 4px;
  background-image: url(/assets/img/common/check_mark.png);
  background-size: 75% 75%;
  background-repeat: no-repeat;
  background-position: center;
}

#page_web_contact .page_contact__mail input[type="submit"] {
  color: #fff;
  text-align: center;
  background: #e60012;
  border: none;
  border-radius: 32px;
  padding: 18px 24px;
  font-size: 18px;
}

#page_web_contact .page_contact__mail--flex:after {
  content: "";
  position: absolute;
  background-image: url(/app/wp-content/themes/otakaraya/assets/img/common/icon_arrow_white01.png);
  background-size: contain;
  width: 20px;
  height: 20px;
  right: 24px;
}

#page_web_contact .page_contact__mail input[type="reset"] {
  text-align: center;
}

@media (max-width: 767px) {
  #page_web_contact .page_contact__mail input[type="reset"] {
    margin-top: 1rem;
  }
}

#page_web_contact .page_contact__mail textarea {
  height: 160px;
  resize: vertical;
}

#page_web_contact .page_contact__mail--flex {
  position: relative;
}

@media (min-width: 768px) {
  #page_web_contact .page_contact__mail--flex {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 48% !important;
    margin: auto;
  }
}

#page_web_contact .page_contact__select {
  position: relative;
  display: block;
  width: 100%;
}

#page_web_contact .page_contact__select::after {
  position: absolute;
  top: 18px;
  right: 20px;
  z-index: 10;
  display: inline-block;
  width: 12px;
  height: 12px;
  content: "";
  border: solid rgba(0, 0, 0, 0) 7px;
  border-top: solid 12px #e60012;
}

#page_web_contact .page_contact__select select {
  width: 100%;
  padding: 0.75rem 25px;
  overflow: hidden;
  font-size: 14px;
  color: #545454;
  border: 1px solid #e6e6e6;
  border-radius: 24px;
  outline: none;
}

#page_web_contact .page_contact__files-lead {
  font-size: 14px;
  color: #000000;
  padding: 4px 0;
}

.wpcf7-file {
  padding: 6px 0 !important;
  border: none !important;
  pointer-events: none;
}

.wpcf7-file::file-selector-button {
  background-color: #efefef;
  padding: 10px 20px;
  cursor: pointer;
  border-radius: 8px;
  pointer-events: all;
  border: solid 1px black;
  transition: opacity 0.3s ease;
  margin-right: 10px;
  font-weight: bold;
  font-size: 16px;
}

.wpcf7-file::file-selector-button:hover {
  opacity: 0.6;
}

.page_contact__mail--check .wpcf7-not-valid-tip {
  text-align: center;
}

.page_contact__mail--check {
  display: flex;
  flex-direction: column;
}

.page_contact__mail--check label {
  display: flex;
  align-items: center;
  margin-bottom: 5px;
}

input.wpcf7-form-control.wpcf7-date.wpcf7-validates-as-date {
  max-width: 320px;
  height: 48px;
  background-image: url(/app/wp-content/themes/otakaraya/assets/img/common/calendar_icon.png);
  background-repeat: no-repeat;
  background-size: 32px 32px;
  background-position: calc(100% - 10px) center;
  cursor: pointer;
}

input.wpcf7-form-control.wpcf7-date.wpcf7-validates-as-date::-webkit-calendar-picker-indicator {
  opacity: 0;
}

.multiple input[type="checkbox"] {
  opacity: 0;
  visibility: hidden;
  position: absolute;
}

.multiple .wpcf7-list-item-label {
  display: inline-block;
  position: relative;
  padding-left: 30px;
  cursor: pointer;
}

.multiple .wpcf7-list-item-label::before {
  position: absolute;
  width: 24px;
  height: 24px;
  font-size: 16px;
  text-align: center;
  border: 1px solid #000000;
  border-radius: 24px;
  cursor: pointer;
  top: -1px;
  left: -1px;
  background-color: white;
}

.multiple input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
  position: absolute;
  width: 24px;
  height: 24px;
  font-size: 16px;
  text-align: center;
  border: 1px solid #000000;
  border-radius: 24px;
  cursor: pointer;
  top: -1px;
  left: -1px;
  background-color: white;
}

.multiple input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
  position: absolute;
  top: 4px;
  left: 4px;
  width: 14px;
  height: 14px;
  content: "";
  background-color: #e60012;
  border-radius: 24px;
  background-repeat: no-repeat;
  background-position: center;
  border: none;
}

.watch_model_name {
  display: none;
}

.recaptcha_text {
  width: fit-content;
  margin: auto;
  margin-top: 30px;
}
