@charset "UTF-8";
/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
---
# ベース
    - reset
    - Layout

# ユーティリティ
    - contents

# モジュール
    - フォーム
	- 必須
	- ラジオボタン
	- 電話番号
  - 注釈
  - 希望日時
  - チェックボックス
  - ボタン

# ページ
	- 確認画面
  - 完了画面
  - エラー
---
--------------------------------------------------------------*/
:root {
  --color-accent: #E0721B;
  --color-black: #333;
  --color-main: #feeab4;
  --color-white: #fff;
  --font-body: "Poppins", "Zen Kaku Gothic New", sans-serif;
  --form-gray: #ccc;
}

/*
#  ベース - reset
--------------------------------------------------------------*/
.m-form input[type=radio] {
  display: none;
}
.m-form input[type=submit],
.m-form input[type=button],
.m-form input[type=reset],
.m-form input[type=checkbox],
.m-form select,
.m-form textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: none;
  border-radius: 0;
  box-shadow: none;
  margin: 0;
  outline: none;
  padding: 0;
}
.m-form input[type=radio]:checked + .mwform-radio-field-text::after {
  opacity: 1;
  transform: scale3d(1, 1, 1);
}
.m-form input,
.m-form select,
.m-form textarea {
  border-radius: 0;
  box-sizing: border-box;
  font-size: clamp(11px, 1.1vw, 1rem);
  letter-spacing: 0;
  padding: 0.75em 1.25em;
  width: 100%;
  line-height: 1.5;
}
.m-form ::-moz-placeholder {
  color: var(--form-gray);
  font-family: sans-serif;
}
.m-form ::placeholder {
  color: var(--form-gray);
  font-family: sans-serif;
}
.m-form td {
  display: block;
}

/*
#  ベース - layout
--------------------------------------------------------------*/
.wid600 {
  margin: auto;
  max-width: 600px;
  width: 100%;
}
@media (max-width: 480px) {
  .wid600 {
    padding: 0 20px;
  }
}

/*
#  ユーティリティ - contents
--------------------------------------------------------------*/
.u-form__row_wid375 {
  max-width: 360px;
}

.u-form__row_wid360 {
  max-width: 360px;
}

.u-display_inline-block {
  display: inline-block;
}

/*
#  モジュール - フォーム
--------------------------------------------------------------*/
.entry-content .m-form__intro {
  font-size: 1rem;
}
.entry-content .m-form {
  font-size: 1rem;
}
.entry-content .m-form > table {
  border: 0;
  line-height: 2;
  margin: 5rem 0;
  width: 100%;
}
.entry-content .m-form .m-form__row {
  display: block;
}
.entry-content .m-form .m-form__row + .m-form__row {
  margin-top: 4rem;
}
.entry-content .m-form > th,
.entry-content .m-form > td {
  border: 0;
  display: block;
  padding: 0;
}
.entry-content .m-form .m-form__label {
  display: block;
  font-size: 1.125rem;
  font-weight: bold;
  margin-bottom: 1.5rem;
  padding-left: 1rem;
  position: relative;
}
.entry-content .m-form .m-form__label::before {
  background: #feeab4;
  content: "";
  height: 1.25rem;
  left: 0;
  position: absolute;
  top: 8px;
  width: 5px;
}

/*
#  モジュール - 必須
--------------------------------------------------------------*/
.m-form__require {
  background: var(--color-accent);
  border-radius: 0.25rem;
  color: var(--color-white);
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 500;
  margin-left: 1rem;
  padding: 0.125rem 0.5rem 0;
  position: relative;
  top: -2px;
}

/*
#  モジュール - ラジオボタン
--------------------------------------------------------------*/
.m-form .mwform-radio-field label {
  font-weight: 500;
}
.m-form .mwform-radio-field-text {
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding: 0 0 0 2.5rem;
  position: relative;
}
.m-form .mwform-radio-field-text::before {
  border: 1px solid var(--form-gray);
  border-radius: 50%;
  content: "";
  height: 28px;
  left: 0;
  position: absolute;
  top: 0;
  width: 28px;
}
.m-form .mwform-radio-field-text::after {
  background: var(--color-accent);
  border-radius: 50%;
  content: "";
  display: block;
  height: 18px;
  left: 6px;
  opacity: 0;
  position: absolute;
  top: 6px;
  transform: scale3d(0.3, 0.3, 1);
  transition: transform 0.2s ease-in-out, opacity 0.2s ease-in-out;
  width: 18px;
}

.mw_wp_form .m-form .vertical-item + .vertical-item {
  margin-top: 1.5rem;
}

/*
# モジュール - 電話番号
--------------------------------------------------------------*/
.m-form .mwform-tel-field,
.m-form .mwform-zip-field {
  align-items: center;
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.m-form .mwform-tel-field input[type=text],
.m-form .mwform-zip-field input[type=text] {
  width: 27.8333333333%;
}

/*
# モジュール - 注釈
--------------------------------------------------------------*/
.m-form__note {
  font-size: 1rem;
  font-weight: normal;
  margin-left: -1rem;
}
.m-form__note::before {
  content: "※";
  margin-right: 0.5em;
}

/*
# モジュール - 希望日
--------------------------------------------------------------*/
.m-form dl + dl {
  margin-top: 1.5rem;
}
.m-form dt {
  font-weight: 500;
  margin-bottom: 1rem;
}
.m-form dd {
  display: flex;
  justify-content: space-between;
}
.m-form .m-form__selectwrap input {
  background: transparent;
  cursor: pointer;
  line-height: 18px;
  padding-right: 3em;
  position: relative;
}

.m-form__selectwrap {
  position: relative;
  width: 46.5%;
  font-family: sans-serif;
}
.m-form__selectwrap::after {
  position: absolute;
}
.m-form__selectwrap.m-form__selectwrap_date::after {
  content: url(../img/icon-calendar.svg);
  line-height: 16px;
  right: 1em;
  top: calc(50% - 8px);
}
.m-form__selectwrap.m-form__selectwrap_select::after {
  border-bottom: 2px solid #999;
  border-right: 2px solid #999;
  content: "";
  height: 6px;
  right: 1.25em;
  top: calc(50% - 5.65px);
  transform: rotate(45deg);
  width: 6px;
}

body > .ui-datepicker {
  display: none;
}

.ui-datepicker {
  background: var(--color-white);
  border: 1px solid var(--form-gray);
  box-sizing: border-box;
  color: #3b4043;
  font-weight: 500;
  max-width: 279px;
  padding: 0.75rem 1rem;
  position: absolute;
  top: 0;
  width: 100%;
}
.ui-datepicker-header {
  align-items: flex-end;
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.625rem;
  width: 100%;
}
.ui-datepicker-next, .ui-datepicker-prev {
  color: #999;
  cursor: pointer;
  font-size: 0.625rem;
  font-weight: bold;
  line-height: 1;
}
.ui-datepicker-next {
  order: 1;
}
.ui-datepicker-title {
  align-items: baseline;
  display: flex;
  line-height: 1.5;
}
.ui-datepicker-year {
  color: #707f89;
  font-size: 0.5625rem;
  order: 1;
}
.ui-datepicker-year::after {
  content: ".";
}
.ui-datepicker-month {
  font-size: 1.125rem;
  font-weight: bold;
  order: 2;
}
.ui-datepicker .ui-icon {
  font-size: 1rem;
}
.ui-datepicker-calendar {
  width: 100%;
}
.ui-datepicker-calendar thead {
  margin-bottom: 0.35rem;
}
.ui-datepicker-calendar th {
  color: #999;
  font-weight: 500;
  text-align: center;
}
.ui-datepicker-calendar th.ui-datepicker-week-end:first-of-type {
  color: #EB5F60;
}
.ui-datepicker-calendar span {
  font-size: 0.75rem;
  line-height: 1.5;
}
.ui-datepicker-calendar td {
  background: var(--color-main);
  border: 1px solid var(--color-white);
}
.ui-datepicker-calendar td.ui-state-disabled {
  background: #f6f6f6;
}
.ui-datepicker-calendar td.ui-datepicker-today .ui-state-highlight {
  border: 1px solid var(--color-accent);
}
.ui-datepicker-calendar td:not(.ui-datepicker-unselectable):hover {
  background: var(--color-accent);
  color: var(--color-white);
}
.ui-datepicker .ui-state-default {
  box-sizing: border-box;
  color: inherit;
  display: block;
  font-size: 0.5625rem;
  font-weight: 500;
  line-height: 1.4;
  padding: 0.375rem;
  text-align: center;
}

/*
# モジュール - 希望時間
--------------------------------------------------------------*/
.m-form__select {
  color: var(--form-gray);
}
.m-form__select option:first-child {
  display: none;
}

.easy-select-box {
  border: 1px solid var(--form-gray);
  border-radius: 0;
  box-sizing: border-box;
  cursor: pointer;
  font-family: sans-serif;
  font-size: clamp(11px, 1.1vw, 1rem);
  letter-spacing: 0;
  position: relative;
  width: 100% !important;
}

.esb-displayer {
  display: block;
  line-height: 18px;
  padding: 0.75em 3em 0.75em 1.25em;
}
.esb-displayer:hover {
  -ms-filter: "alpha(opacity=80)";
  filter: alpha(opacity=80);
  opacity: 0.8;
}
.esb-displayer.-default {
  color: var(--form-gray);
}

.esb-dropdown {
  background: #fff;
  border: 1px solid var(--form-gray);
  display: none;
  left: -1px;
  max-height: 200px;
  overflow: auto;
  position: absolute;
  top: 42px;
  width: 100% !important;
  z-index: 999;
}

.esb-item {
  color: var(--color-black);
  cursor: default;
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.9357rem 2.5em;
}
.esb-item:hover {
  background: var(--color-main);
  text-decoration: none;
}

/*
# モジュール - チェックボックス
--------------------------------------------------------------*/
.m-form input[type=checkbox] {
  cursor: pointer;
  margin-right: 10px;
  position: relative;
  width: 32px;
}
.m-form .mwform-checkbox-field-text {
  cursor: pointer;
  line-height: 2;
  position: relative;
}
.m-form input[type=checkbox]::before {
  background-color: #fff;
  border: 1px solid var(--form-gray);
  border-radius: 0;
  content: "";
  height: 30px;
  position: absolute;
  top: 0;
  width: 30px;
}
.m-form input[type=checkbox]::after {
  border-bottom: 2px solid var(--color-accent);
  border-right: 2px solid var(--color-accent);
  content: "";
  height: 12px;
  left: 11px;
  opacity: 0;
  position: absolute;
  top: 6px;
  transform: rotate(45deg);
  width: 7px;
}
.m-form input[type=checkbox]:checked::after {
  opacity: 1;
}

.mwform-checkbox-field label {
  display: flex;
  justify-content: flex-start;
}

.m-form__privacy {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 0.625rem;
}
.m-form__privacy .mwform-checkbox-field {
  margin-right: 0.625rem;
}

/*
# モジュール - ボタン
--------------------------------------------------------------*/
.m-form__submit {
  cursor: pointer;
  margin-top: 3.5rem;
  text-align: center;
}

.m-form input[type=submit].m-form__btn {
  border: none;
  border-radius: 5px;
  font-family: var(--font-body);
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.5;
  max-width: 280px;
  padding: 1rem;
  text-align: center;
  width: 100%;
  font-size: 1.125rem;
}

.m-form input[type=submit].m-form__submitbtn {
  background: var(--color-accent);
  color: var(--color-white);
}

.m-form__back {
  margin-top: 2rem;
  text-align: center;
}

.m-form input[type=submit].m-form__backbtn {
  background: var(--color-white);
  border: 2px solid currentColor;
  color: var(--color-accent);
}

/*
# ページ - 確認画面
--------------------------------------------------------------*/
.p-confirm .m-form__note {
  display: none;
}
.p-confirm .m-form__selectwrap.m-form__selectwrap_date::after,
.p-confirm .m-form__selectwrap.m-form__selectwrap_select::after {
  display: none;
}
.p-confirm .m-form__selectwrap {
  width: -moz-fit-content;
  width: fit-content;
}
.p-confirm .m-form dd {
  gap: 1rem;
  justify-content: flex-start;
}
.p-confirm .m-form__privacy {
  display: none;
}

/*
# ページ - 完了画面
--------------------------------------------------------------*/
.m-form-thanks__heading {
  text-align: center;
  margin-bottom: 2rem;
  font-size: 2rem;
  color: var(--color-accent);
}

.p-thanks .m-form__note {
  margin-left: 0;
  font-size: 0.9375rem;
}

@media screen and (max-width: 480px) {
  .m-form input,
  .m-form select,
  .m-form textarea {
    font-size: 1rem;
  }
  .m-form dd {
    flex-direction: column;
  }
  .m-form__require {
    margin-left: 0.5rem;
  }
  .m-form__selectwrap_select {
    margin-top: 0.75rem;
  }
  .m-form__selectwrap_select .easy-select-box {
    font-size: 1rem;
  }
  .m-form-thanks__heading {
    font-size: 1.9375rem;
  }
  .m-form-thanks__desc {
    margin-bottom: 2rem;
  }
  .m-form__selectwrap {
    width: 100%;
  }
  .entry-content .m-form > table {
    margin: 3rem 0;
  }
  .entry-content .m-form .m-form__row + .m-form__row {
    margin-top: 3rem;
  }
  .entry-content .m-form .m-form__label {
    margin-bottom: 1rem;
  }
  .mw_wp_form .m-form .vertical-item + .vertical-item {
    margin-top: 1rem;
  }
}
/*
# ページ - エラー
--------------------------------------------------------------*/
.error-message {
  display: none;
}

.mw_wp_form_error .error-message {
  color: #EB5F60;
  display: block;
}

.mw_wp_form .error {
  font-size: 88%;
  color: #EB5F60;
  display: inline-block;
  border: 1px solid #EB5F60;
  border-radius: 5px;
  line-height: 1;
  padding: 0.5rem;
  margin-top: 0.25rem;
}

.js-open-area .mwform-radio-field {
  margin-top: 1.5rem;
}

.open-area1, .open-area2, .open-area3 {
  background-color: #f2f2f2;
  padding: 1.5rem;
  margin-top: 0.5em;
  margin-bottom: 1em;
}
.open-area1 select,
.open-area1 .mwform-radio-field-text::before, .open-area2 select,
.open-area2 .mwform-radio-field-text::before, .open-area3 select,
.open-area3 .mwform-radio-field-text::before {
  background-color: #fff;
}
.open-area1 input[type=text], .open-area1 select, .open-area2 input[type=text], .open-area2 select, .open-area3 input[type=text], .open-area3 select {
  max-width: 320px;
  margin-left: 0.5em;
}
.open-area1 label, .open-area2 label, .open-area3 label {
  display: block;
  text-align: left;
}
.open-area1 label:not(:last-child), .open-area2 label:not(:last-child), .open-area3 label:not(:last-child) {
  margin-bottom: 0.75em;
}
.open-area1 .mwform-radio-field label, .open-area2 .mwform-radio-field label, .open-area3 .mwform-radio-field label {
  display: inline-block;
  margin-left: 0.5em;
}
.open-area1 .select__wrapper, .open-area2 .select__wrapper, .open-area3 .select__wrapper {
  position: relative;
}
.open-area1 .select__wrapper::after, .open-area2 .select__wrapper::after, .open-area3 .select__wrapper::after {
  position: absolute;
  border-bottom: 2px solid #999;
  border-right: 2px solid #999;
  content: "";
  height: 6px;
  right: 1.25em;
  top: calc(50% - 5.65px);
  transform: rotate(45deg);
  width: 6px;
}
.open-area1 .select__wrapper select, .open-area2 .select__wrapper select, .open-area3 .select__wrapper select {
  color: #333;
}

.mw_wp_form_confirm .select__wrapper::after {
  display: none;
}

@media screen and (max-width: 767px) {
  .open-area1, .open-area2, .open-area3 {
    padding: 1rem 1rem 2rem;
  }
  .open-area1 input[type=text], .open-area1 select, .open-area2 input[type=text], .open-area2 select, .open-area3 input[type=text], .open-area3 select {
    margin: 0;
  }
}
@media screen and (max-width: 469px) {
  .open-area1 .select__wrapper::after, .open-area2 .select__wrapper::after, .open-area3 .select__wrapper::after {
    top: calc(50% - 5.65px + 1.25em);
  }
}/*# sourceMappingURL=form.css.map */