@charset "UTF-8";
/* 変数の定義
--------------------------------------------------*/
/* 色の定義
--------------------------------------------------*/
/* 色のクラス
--------------------------------------------------*/
.white {
  color: #fff;
}

.black {
  color: #000;
}

.blue {
  color: #2953ED;
}

.orange {
  color: #D56300;
}

/* フォントの定義
--------------------------------------------------*/
html,
body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
table,
tr,
th,
td,
a,
figure {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6;
  color: #000;
}

body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
a,
table,
tr,
th,
td,
figure {
  font-size: 1.6rem;
}
@media screen and (max-width: 999px) {
  body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
a,
table,
tr,
th,
td,
figure {
    font-size: 1.4rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Noto Sans JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-weight: 700;
  color: #000;
}

/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 共通
--------------------------------------------------*/
body {
  word-break: break-word;
}

a {
  transition-duration: 0.3s;
  -webkit-animation-timing-function: cubic-bezier(0.83, 0, 0.17, 1);
          animation-timing-function: cubic-bezier(0.83, 0, 0.17, 1);
}

span {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
}

section {
  position: relative;
  z-index: 1;
}

span.word {
  display: inline-block;
}

/* 404
--------------------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* ---------- Contact Main ---------- */
.contact-main {
  background: #fff;
  /* 左固定の入力ステップ */
}
.contact-main .contact-main-inner {
  width: calc(100% - 14.2857vw);
  margin-inline: auto;
  padding: 7.1428vw 0;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-main-inner {
    width: 90%;
    padding: 60px 0;
  }
}
.contact-main .contact-grid {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 60px;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.contact-main .form-steps {
  align-self: start;
  position: -webkit-sticky;
  position: sticky;
  top: 100px;
  height: -webkit-max-content;
  height: -moz-max-content;
  height: max-content;
  /* 左カラム中央に縦ラインを敷く（四角を線で繋ぐ） */
}
@media screen and (max-width: 768px) {
  .contact-main .form-steps {
    position: relative;
    top: 0;
  }
}
.contact-main .form-steps .step-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 30px;
  background: #F5F6F9;
  padding: 45px;
  position: relative;
}
@media screen and (max-width: 768px) {
  .contact-main .form-steps .step-list {
    padding: 20px;
  }
}
.contact-main .form-steps .step-list.list_en li {
  font-size: 16px;
}
.contact-main .form-steps .step-list::before {
  content: "";
  position: absolute;
  left: 55px;
  transform: translateX(-50%);
  top: 66px;
  bottom: 59px;
  width: 2px;
  background: #B6B6B6;
  z-index: 0;
}
@media screen and (max-width: 768px) {
  .contact-main .form-steps .step-list::before {
    left: 30px;
    top: 30px;
    bottom: 30px;
  }
}
.contact-main .form-steps .step-list li {
  display: grid;
  grid-template-columns: 20px 1fr;
  align-items: center;
  gap: 10px;
  position: relative;
  z-index: 1;
  color: #B6B6B6;
  font-weight: 700;
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  .contact-main .form-steps .step-list li {
    font-size: 16px;
  }
}
.contact-main .form-steps .step-list li::before {
  content: "";
  width: 15px;
  height: 15px;
  background: #B6B6B6;
  z-index: 1;
  justify-self: center;
}
.contact-main .form-steps .step-list li.current {
  color: #041C2B;
}
.contact-main .form-steps .step-list li.current::before {
  background: #2953ED;
}
.contact-main .lead {
  margin-bottom: 60px;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .contact-main .lead {
    font-size: 16px;
    margin-bottom: 30px;
  }
}
.contact-main .contact-form form {
  width: 100%;
}
.contact-main .contact-form .form-row {
  display: grid;
  gap: 10px;
  margin-bottom: 30px;
  /* Safari(WebKit)のplaceholderにも同じ指定を適用 */
  /* Safariのnumberスピンボタン・search装飾除去（使われていても無害） */
  /* SafariのAutofill背景色対策 */
}
.contact-main .contact-form .form-row.privacy {
  align-items: center;
  gap: 12px;
}
.contact-main .contact-form .form-row .field-head {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 18px;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-row .field-head {
    font-size: 16px;
  }
}
.contact-main .contact-form .form-row .badge {
  display: inline-block;
  width: 39px;
  height: 17px;
  font-size: 12px;
  line-height: 17px;
  text-align: center;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-row .badge {
    font-size: 10px;
  }
}
.contact-main .contact-form .form-row .badge.required {
  background: #2953ED;
  color: #fff;
}
.contact-main .contact-form .form-row .badge.optional {
  background: #B6B6B6;
  color: #fff;
}
.contact-main .contact-form .form-row .badge.badge_en {
  width: 70px;
}
.contact-main .contact-form .form-row label {
  font-weight: 700;
  color: #041C2B;
}
.contact-main .contact-form .form-row label .req {
  color: #D56300;
  margin-left: 4px;
}
.contact-main .contact-form .form-row input,
.contact-main .contact-form .form-row textarea,
.contact-main .contact-form .form-row select {
  width: 100%;
  border: 1px solid #B6B6B6;
  padding: 16px 20px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
  background: #fff;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none; /* Safariネイティブ装飾を無効化 */
  border-radius: 0;
  box-shadow: none;
  outline: none;
  font-family: "Noto Sans JP", serif;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-row input,
.contact-main .contact-form .form-row textarea,
.contact-main .contact-form .form-row select {
    font-size: 14px;
    padding: 16px 10px;
  }
}
.contact-main .contact-form .form-row input::-moz-placeholder, .contact-main .contact-form .form-row textarea::-moz-placeholder {
  color: #B6B6B6;
  font-weight: 500;
  font-size: 16px;
}
.contact-main .contact-form .form-row input::placeholder,
.contact-main .contact-form .form-row textarea::placeholder {
  color: #B6B6B6;
  font-weight: 500;
  font-size: 16px;
}
.contact-main .contact-form .form-row input::-webkit-input-placeholder,
.contact-main .contact-form .form-row textarea::-webkit-input-placeholder {
  color: #B6B6B6;
  font-weight: 500;
  font-size: 16px;
}
.contact-main .contact-form .form-row textarea {
  resize: vertical;
}
.contact-main .contact-form .form-row .select-wrap {
  position: relative;
}
.contact-main .contact-form .form-row .select-wrap::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  background: url(../img/common/arrow.svg) no-repeat center center/contain;
  pointer-events: none;
}
.contact-main .contact-form .form-row .select-wrap select {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  color: #000;
  font-family: "Noto Sans JP", "Noto Sans CJK JP", sans-serif;
  font-weight: 500;
}
.contact-main .contact-form .form-row input[type=number]::-webkit-outer-spin-button,
.contact-main .contact-form .form-row input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.contact-main .contact-form .form-row input[type=search]::-webkit-search-decoration,
.contact-main .contact-form .form-row input[type=search]::-webkit-search-cancel-button {
  -webkit-appearance: none;
}
.contact-main .contact-form .form-row input:-webkit-autofill,
.contact-main .contact-form .form-row input:-webkit-autofill:hover,
.contact-main .contact-form .form-row input:-webkit-autofill:focus {
  -webkit-text-fill-color: inherit;
  -webkit-transition: background-color 9999s ease-in-out 0s;
  transition: background-color 9999s ease-in-out 0s;
  box-shadow: 0 0 0px 1000px #fff inset;
}
.contact-main .contact-form .form-row.privacy .policy-label a[href] {
  color: #041C2B;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  -webkit-text-decoration-color: #2953ED;
          text-decoration-color: #2953ED;
  font-weight: 700;
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-row.privacy .policy-label a[href] {
    font-size: 16px;
  }
}
.contact-main .contact-form .form-row.privacy .policy-label a[href]:hover {
  color: #2953ED;
}
.contact-main .contact-form .form-row.privacy .policy-label .policy-icon {
  width: 15px;
  height: 15px;
  margin: 0 6px;
  translate: 0 2px;
  display: inline-block;
  vertical-align: middle;
}
.contact-main .contact-form .form-row.privacy .checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  cursor: pointer;
}
.contact-main .contact-form .form-row.privacy .checkbox .error {
  position: absolute;
  top: 30px;
  word-break: auto-phrase;
  white-space: nowrap;
  font-weight: 400;
}
.contact-main .contact-form .form-row.privacy .mwform-checkbox-field {
  width: 20px;
  height: 20px;
  display: inline-block;
  pointer-events: none;
}
.contact-main .contact-form .form-row.privacy input[type=checkbox] {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 1px solid #B6B6B6;
  border-radius: 0;
  padding: 0;
  margin: 0;
  background-color: white;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.contact-main .contact-form .form-row.privacy input[type=checkbox]::after {
  content: "";
  position: absolute;
  left: 6px;
  top: 2px;
  width: 6px;
  height: 12px;
  border: 2px solid #fff;
  border-top: 0;
  border-left: 0;
  transform: rotate(45deg);
}
.contact-main .contact-form .form-row.privacy input[type=checkbox]:checked {
  background: #2953ED;
  border-color: #2953ED;
}
.contact-main .contact-form .form-row.privacy .checkbox-label {
  font-size: 18px;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-row.privacy .checkbox-label {
    font-size: 16px;
  }
}
.contact-main .contact-form .form-actions {
  margin-top: 20px;
  padding: 0;
}
@media screen and (max-width: 768px) {
  .contact-main .contact-form .form-actions {
    margin-top: 10px;
  }
}
.contact-main .contact-form .form-actions input[type=submit] {
  background: none;
  color: #fff;
  border: none;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  width: 100%;
  height: 100%;
  text-align: left;
  padding-left: 24px;
}
.contact-main .contact-form .form-actions .arrow {
  position: absolute;
  right: 24px;
  transition: all 0.2s ease;
}
.contact-main .contact-form .form-actions:hover .arrow {
  right: 0;
}
.contact-main .contact-form .back_btn {
  display: none;
}

/* ---------- お問い合わせ確認画面 ---------- */
.mw_wp_form_preview .contact-main .form-steps .step-list .current {
  color: #B6B6B6;
}
.mw_wp_form_preview .contact-main .form-steps .step-list .current::before {
  background: #B6B6B6;
}
.mw_wp_form_preview .contact-main .form-steps .step-list .current_second {
  color: #041C2B;
}
.mw_wp_form_preview .contact-main .form-steps .step-list .current_second::before {
  background: #2953ED;
}
.mw_wp_form_preview .lead {
  display: none;
}
.mw_wp_form_preview .select-wrap::after {
  display: none;
}
.mw_wp_form_preview .contactbtn_wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  -moz-column-gap: 30px;
       column-gap: 30px;
}
.mw_wp_form_preview .contact-main .contact-form .form-row.privacy {
  display: none;
}
.mw_wp_form_preview .contact-main .contact-form .back_btn {
  display: inline-flex;
  background-color: #B6B6B6;
}
.mw_wp_form_preview .contact-main .contact-form .back_btn::before {
  background-color: #2953ED;
}
.mw_wp_form_preview .contact-main .contact-form .back_btn:hover .arrow {
  right: 44px;
}

#contact {
  display: none;
}
/*# sourceMappingURL=contact.css.map */