#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: .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: .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: .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: .1rem .75rem .25rem;
  margin-left: .5rem;
  font-size: 12px;
  font-weight: normal;
  color: #fff;
  background: #E60012;
  border-radius: 24px
}
#page_web_contact span.optional {
  padding: .1rem .75rem .25rem;
  margin-left: .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: .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: .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: .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: .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: .75rem 25px .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: .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;
}

/*# sourceMappingURL=web_contact.min.css.map */