@charset "utf-8";
.sec-contact {
  padding: var(--block-space-l) var(--side-space) var(--block-space-2l) var(--side-space);
}
.contact-info {
  padding-bottom: var(--block-space-s);
}
.contact-setup-alart {
  margin-bottom: var(--block-space-2s);
  text-align: left;
  border: 1px solid var(--red);
  line-height: var(--line-height-s);
  color: var(--red);
  padding: 1em;
}
@media print, screen and (min-width:761px) {
  .grecaptcha-badge {
    margin-bottom: 50px;
  }
  .sec-contact {
    box-sizing: content-box;
  }
}

/*--------------------------------------------------------------------------------
  入力画面
--------------------------------------------------------------------------------*/
.fm-step1 dt .key {
  font-size: var(--fs-m);
  font-weight: bold;
}
.fm-item .error-message {
  color: var(--red);
  padding-top: 0.5em;
  font-size: var(--fs-s);
  display: none;
}
.fm-item.is-err .error-message {
  display: block;
}
@media print, screen and (min-width:761px) {
  .fm-step1 .contact-info {
    line-height: var(--line-height-l);
  }
  .fm-step1 dl {
    display: flex;
    flex-wrap: wrap;
  }
  .fm-step1 dt {
    width: 15em;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .fm-step1 dt .fm-label {
    white-space: nowrap;
    margin-top: 0.25em;
  }
  .fm-step1 dd {
    width: calc(100% - 15em);
    padding-left: 2em;
  }
  .fm-step1 dt,
  .fm-step1 dd {
    padding-top: 1.25em;
  }
  .fm-step1 dt:not(:last-of-type),
  .fm-step1 dd:not(:last-of-type) {
    padding-bottom: 1.25em;
  }
  .fm-step1 dd .fm-ip,
  .fm-step1 dd .fm-textarea {
    margin-top: -0.25em;
    margin-bottom: -0.25em;
  }
}
@media screen and (max-width:760px) {
  .fm-step1 dt:first-of-type {
    padding-top: 1em;
  }
  .fm-step1 dt:not(:first-of-type) {
    padding-top: 2.5em;
  }
  .fm-step1 dt {
    padding-bottom: 0.75em;
  }
}

/*--------------------------------------------------------------------------------
  確認画面
--------------------------------------------------------------------------------*/
.fm-step2-tbl {
  width: 100%;
  min-width: 360px;
  border-collapse: collapse;
}
.fm-step2-tbl th {
  background-color: #DCDCDC;
  width: 20%;
  white-space: nowrap;
}
.fm-step2-tbl td {
  background-color: #FFF;
}
.fm-step2-tbl th,
.fm-step2-tbl td {
  padding: calc(var(--box-space-unit) * 2);
}
.fm-step2-tbl tr:not(:first-of-type) th,
.fm-step2-tbl tr:not(:first-of-type) td {
  border-top: 1px solid rgba(0,0,0,0.1);
}

/*--------------------------------------------------------------------------------
  送信完了
--------------------------------------------------------------------------------*/
@media print, screen and (min-width:641px) {
  .fm-step3 .contact-info {
    padding-bottom: var(--block-space-min);
  }
}

/*--------------------------------------------------------------------------------
  ボタン
--------------------------------------------------------------------------------*/
.fm-btn-wrap {
  margin-left: -0.5em;
  margin-right: -0.5em;
}
.fm-btn {
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: var(--block-space-m);
}
.fm-btn .p-btn {
  width: 100%;
  font-weight: bold;
}
.fm-btn--group .p-btn {
  margin: 0 0.5em;
}
.fm-btn--send {
  order: 1;
}
.fm-btn--back {
  order: 0;
}
@media print, screen and (min-width:641px) {
  .fm-btn {
    margin-left: auto;
    margin-right: auto;
  }
  .fm-btn:not(.fm-btn--group) .p-btn {
    max-width: 300px;
  }
  .fm-btn--group {
    max-width: 540px;
  }
  .fm-btn--back, .fm-btn--send {
    width: 50%;
  }
}
@media screen and (max-width:640px) {
  .fm-btn:not(.fm-btn--group) .p-btn {
    max-width: 200px;
  }
  .fm-btn--group {
    width: 100%;
  }
}

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

  フォーム部品
  
----------------------------------------------------------------------------------------------------*/
.fm-ip,
.fm-textarea {
  outline: none;
  padding: 0.5em;
  border: 1px solid rgba(0,0,0,0.15);
  background-color: #FFF;
  transition: background-color ease-out 0.1s, border-color ease-out 0.1s;
  line-height: var(--line-height-m);
}
.fm-ip:focus,
.fm-textarea:focus {
  border-color: rgba(0,0,0,0.7);
  background-color: #FFF;
}
/*
.fm-ip:focus:invalid,
.fm-textarea:focus:invalid,
*/
.fm-item.is-err .fm-ip,
.fm-item.is-err .fm-textarea {
  border-color: var(--red);
}
.fm-ip,
.fm-textarea {
  width: 100%;
}
.fm-ip-check,
.fm-ip-radio {
  cursor: pointer;
}
.fm-ip-check input,
.fm-ip-radio input {
  margin-right: 0.5em;
  margin-bottom: 0.2em;
  vertical-align: middle;
  cursor: pointer;
}
.fm-ip-check input {
  width: 1.2em;
  height: 1.2em;
}
.fm-ip-radio input {
  width: 1.3em;
  height: 1.3em;
}
.fm-ip-check input:focus:invalid,
.fm-ip-radio input:focus:invalid {
  border-color: var(--red);
  background-color: var(--red);
}
.fm-ip-group {
  list-style: none;
}
@media print, screen and (min-width:981px) {
  .fm-textarea {
    height: 300px;
  }
  .fm-ip--s {
    width: 20%;
  }
  .fm-ip--m {
    width: 40%;
  }
  .fm-ip--l {
    width: 70%;
  }
  .fm-ip-group {
    display: flex;
    flex-wrap: wrap;
  }
  .fm-ip-group li {
    padding-right: 2em;
  }
}
@media screen and (max-width:980px) {
  .fm-textarea {
    height: 200px;
  }
  .fm-ip-group li:not(:first-child) {
    padding-top: 0.5em;
  }
}
.fm-label {
  font-size: var(--fs-3s);
  font-weight: 300;
  color: #FFF;
  display: inline-block;
  line-height: 1;
  padding: 0.5em;
  margin-left: 1em;
  margin-bottom: 0.2em;
  vertical-align: middle;
}
.fm-label--required {
  background-color: var(--red);
}
.fm-label--optional {
  background-color: #AAA;
}
