@charset 'UTF-8';

/* ==================================================
フォームCSS
================================================== */

/* 下部固定バナー
================================================== */
.bottom_bar_js_typeNone {
  display: block;
}

/* type="number"のスピンボタンを非表示にする
================================================== */
/* Safari, Chrome 対応 */
input[type='number']::-webkit-outer-spin-button,
input[type='number']::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* FireFox 対応 */
input[type='number'] {
  -moz-appearance: textfield;
}

/* ユーザー・エージェントスタイルをリセット
================================================== */
fieldset {
  margin: 0;
  padding: 0;
}


/* 全体サイズ
================================================== */

.mw_wp_form {
  margin-bottom: 95px;
  margin-left: auto;
  margin-right: auto;
  max-width: 800px;
}

/* フォーム全体の並び
================================================== */
.form_bl_formWrapper {
  display: grid;
  margin-bottom: 3rem;
  width: 100%;
}

.form_bl_formWrapper .form_bl_fieldset {
  display: grid;
  font-size: 1.6rem;
  line-height: 1.6875;
}

.form_bl_formWrapper fieldset,
.form_bl_formWrapper legend {
  display: contents;
}

/* 入力画面のフォント */
.mw_wp_form_input .form_bl_formWrapper .form_bl_fieldset {
  font-weight: bold;
}

/* 確認画面のフォント・カラム */
.mw_wp_form_confirm .form_bl_formWrapper .form_bl_fieldset {
  align-items: center;
  font-size: 2rem;
  font-weight: normal;
  gap: 30px;
  grid-template-columns: 20% 60%;
  vertical-align: middle;
}

/* 入力画面のカラム */
.mw_wp_form_input .form_bl_formWrapper .form_bl_fieldset {
  grid-template-columns: 200px 1fr;
}

/* 項目名、ラベル */
/* 入力画面 */
.mw_wp_form_input .form_bl_formWrapper .form_bl_legend {
  display: table;
}

.mw_wp_form_input .form_bl_formWrapper .form_bl_legend > span:first-child {
  display: table-cell;
  width: 4.2rem;
}

.mw_wp_form_input .form_bl_formWrapper .form_bl_legend > span:last-child {
  display: table-cell;
  text-align: left;
}

/* 確認画面 */
.mw_wp_form_confirm .mw_wp_form .form_bl_legend {
  text-align: left;
}
/* ラベルとinput要素の縦位置を揃える場合 */
.form_bl_legend__single {
  vertical-align: middle;
}

/* 長い項目名 */
.form_bl_label_lg {
  vertical-align: middle;
}

/* 入力フィールド */
.mw_wp_form_input .form_bl_legend .form_bl_row {
  align-items: center;
  gap: 10px;
  width: 600px;
}

.mw_wp_form_confirm .form_bl_legend .form_bl_row {
  align-items: center;
  gap: 10px;
  width: unset;
}

/* 必須ラベル */
/* 入力画面 */
.mw_wp_form_input .form_el_required {
  background-color: var(--col_formBtn);
  border-radius: 6px;
  color: var(--col_white);
  font-size: 1.2rem;
  line-height: 1;
  margin-right: 5px;
  padding: 4px;
  text-align: center;
}

/* 確認画面 */
.mw_wp_form_confirm .form_el_required,
.mw_wp_form_confirm .form_el_no_required {
  display: none;
}

/* テキスト、セレクトボックス、テキストエリア */
.form_bl_text,
.form_bl_select,
.form_bl_select option {
  background-color: var(--col_formInputTxt);
  border: solid 1px var(--col_formInputTxtBorder);
  border-radius: 6px;
  font-size: 1.4rem;
  font-weight: normal;
  padding: 10px;
  text-align: left;
}

.form_bl_text::placeholder,
.form_bl_textarea::placeholder {
  color: var(--col_formInputTxtPlaceholder);
  font-size: 1.2rem;
  font-weight: bold;
}

.form_bl_text__w94,
.form_bl_text__bday {
  width: 9.4rem;
}

.form_bl_text__w100 {
  width: 10rem;
}

.form_bl_text__w160,
.form_bl_text__w160__name {
  width: 16rem;
}

.form_bl_text__w368 {
  width: 36.8rem;
}

/* テキストエリア */
.form_bl_textarea {
  background-color: var(--col_formInputTxt);
  border: solid 1px var(--col_formInputTxtBorder);
  border-radius: 6px;
  font-size: 1.4rem;
  font-weight: normal;
  height: 7rem;
  padding: 10px;
  text-align: left;
  width: 60rem;
}

/* セレクトボックス */
.form_bl_selectWrapper {
  position: relative;
}
/* 確認画面では折返しを禁止する */
.mw_wp_form_confirm .form_bl_selectWrapper {
  white-space: nowrap;
}

.form_bl_selectWrapper__w160 {
  width: 16rem;
}

.form_bl_select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  color: var(--col_formInputTxtPlaceholder);
  font-size: 1.4rem;
  font-size: 1.4rem;
  font-weight: normal;
  font-weight: bold;
  position: relative;
  width: 16rem;
}

.form_bl_selectWrapper::after {
  border-color: var(--col_gray70) transparent transparent transparent;
  border-style: solid;
  border-width: 10px 6px 0 6px;
  content: '';
  display: block;
  height: 0;
  pointer-events: none;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
}

/* 確認画面では矢印非常時 */
.mw_wp_form_confirm .form_bl_selectWrapper::after {
  display: none;
}

/* ラジオボタン */
.mw_wp_form .form_bl_radioWrapper .horizontal-item + .horizontal-item {
  margin-left: 3rem;
}

.mwform-radio-field-text {
  color: var(--col_formInputTxtPlaceholder);
  font-size: 1.2rem;
  padding-left: 3rem;
  position: relative;
}

.mwform-radio-field-text::before,
.mwform-radio-field-text::after {
  border-radius: 50%;
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.mwform-radio-field-text::before {
  background-color: var(--col_formInputTxt);
  border: solid 1px var(--col_formInputTxtBorder);
  height: 20px;
  left: 0;
  width: 20px;
}

.mwform-radio-field-text::after {
  background-color: var(--col_lightBrown);
  height: 16px;
  left: 2px;
  opacity: 0;
  width: 16px;
}

.mwform-radio-field input:checked + .mwform-radio-field-text {
  color: var(--col_mainCol);
}

.mwform-radio-field input:checked + .mwform-radio-field-text::after {
  opacity: 1;
}

/* チェックボックス */
.form_bl_checkbox ~ span {
  font-weight: bold;
}

.form_hp_visually-hidden {
  /* 要素サイズを変更しうるプロパティのリセット */
  border: 0;
  /* 要素のどの部分が表示されるかを定義するもの */
  /* 古いブラウザでは使用できない */
  clip: rect(0 0 0 0);
  /* 最近のブラウザ用
   * コンテンツを非表示にする設定  */
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  /* オーバーフローしているコンテンツを隠す */
  overflow: hidden;
  padding: 0;
  position: absolute;
  /* 誤ったコードに対処するための回避策 */
  white-space: nowrap;
  /* 可能な限り文字サイズを小さくする */
  width: 1px;
}

/* 住所：郵便番号都道府県 */
.form_bl_address .form_bl_row {
  align-items: center;
  gap: 30px;
}

/* 住所の並び */
.mw_wp_form_input .form_bl_address .form_bl_address_body {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: flex-start;
}

.mw_wp_form_confirm .form_bl_address .form_bl_address_body {
  align-items: center;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: flex-start;
  width: 100%;
}

/* 開催日程 */
.form_bl_schedule_checkbox input[type="checkbox"] {
  min-width: 24px;
}
.form_bl_schedule_checkbox > span > label {
  align-items: center;
  column-gap: 10px;
  display: flex;
}
.form_bl_schedule_checkbox > span:not(:last-of-type) {
  border-bottom: thin solid lightgray;
  padding-bottom: 2rem;
}
.form_bl_schedule {
  display: flex;
  flex-wrap: wrap;
  column-gap: 2rem;
}
.form_bl_schedule > span {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* 横並び */
.form_bl_row,
.form_bl_row_spRow {
  display: flex;
  flex-direction: row;
  gap: 10px;
  justify-content: flex-start;
}

/* 行落ち対策 */
.form_bl_row_spRow {
  gap: 10px 6px;
}

/* PC横並び・SP縦並び */
.form_bl_row_spCol {
  align-items: flex-start;
  display: flex;
  flex-direction: row;
  gap: 10px;
  justify-content: flex-start;
}

/* 縦並び */
.form_bl_column {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: flex-start;
}

/* 縦並び：確認画面：住所 */
.mw_wp_form_confirm .form_bl_address .form_bl_column {
  align-items: center;
  flex-direction: row;
  flex-shrink: 0;
  flex-wrap: nowrap;
  gap: .5em;
  justify-content: flex-start;
}

/* ボタン */
.form_bl_submit_area {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: 20px;
  justify-content: center;
  margin-bottom: 5rem;
}

.form_bl_confirm_buttonWrapper {
  position: relative;
  transition: .2s;
  transition: .4s ease-in-out;
  z-index: 1;
}

.form_bl_confirm_button {
  background-color: var(--col_formBtn);
  border: solid 3px var(--col_formBtn);
  border-radius: 50px;
  color: var(--col_white);
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1;
  padding: 20px;
  position: relative;
  text-align: center;
  transition: .2s;
  transition: .4s ease-in-out;
  width: 65.6rem;
  z-index: 2;
}

.form_bl_confirm_buttonWrapper::after {
  border-right: 3px solid var(--col_white);
  border-top: 3px solid var(--col_white);
  content: '';
  height: 20px;
  position: absolute;
  right: 3.2rem;
  top: 50%;
  transform: rotate(45deg) translateY(-50%);
  width: 20px;
  z-index: 4;
}

.form_bl_confirm_button:hover,
.form_bl_confirm_button:focus {
  background-color: var(--col_white);
  color: var(--col_formBtn);
}

.form_bl_confirm_buttonWrapper:hover::after,
.form_bl_confirm_buttonWrapper:focus::after {
  border-right: 3px solid var(--col_formBtn);
  border-top: 3px solid var(--col_formBtn);
}

/* 送信するボタン */
.mw_wp_form_confirm .form_bl_confirm_button {
  width: 46.5rem;
}

/* 戻るボタン */
.form_bl_back_button {
  background-color: var(--col_grayD6);
  border: solid 3px var(--col_grayD6);
  border-radius: 50px;
  color: var(--col_gray65);
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  padding: 20px;
  text-align: center;
  width: 17rem;
}

.form_bl_back_button:hover,
.form_bl_back_button:focus {
  background-color: var(--col_white);
}

/* 線 */
.form_bl_border {
  border-top: solid 1px var(--col_gray70);
}

.form_bl_border:last-of-type {
  border-bottom: solid 1px var(--col_gray70);
  border-top: solid 1px var(--col_gray70);
}

.mw_wp_form_confirm .form_bl_furigana_border {
  border-top: solid 1px var(--col_gray70);
}

/* パディング */
.form_bl_cellPadding,
.form_bl_cellPadding__label {
  padding: 16px 0 18px;
}

/* 複数フォームの場合のパディング：上 */
.mw_wp_form_input .form_bl_cellPadding_top {
  padding: 16px 0 10px;
}

/* 複数フォームの場合のパディング：下 */
.mw_wp_form_input .form_bl_cellPadding_bottom {
  padding: 0 0 18px;
}

/* 確認画面のパディング */
.mw_wp_form_confirm .form_bl_cellPadding,
.mw_wp_form_confirm .form_bl_cellPadding_top,
.mw_wp_form_confirm .form_bl_cellPadding_bottom {
  padding: 30px 0;
}

.mw_wp_form_confirm .form_bl_cellPadding_top + .mw_wp_form_confirm .form_bl_cellPadding_bottom {
  margin-top: -14px;
  padding: 0 0 30px;
}

.mw_wp_form_confirm .form_bl_address .form_bl_cellPadding_top,
.mw_wp_form_confirm .form_bl_address .form_bl_cellPadding_bottom {
  padding: 0;
}

/* 説明文 */
.form_bl_caption_input,
.form_bl_caption_confirm {
  color: var(--col_black);
  font-size: 1.6rem;
  font-weight: normal;
  line-height: 1.3125;
}

.form_bl_caption_input__bb,
.form_bl_caption_confirm__bb {
  border-bottom: solid 1px var(--col_gray70);
}

/* 入力画面用の説明文を、確認画面と完了画面で隠す */
.mw_wp_form_confirm .form_bl_caption_input,
.mw_wp_form_complete .form_bl_caption_input {
  display: none;
}

/* 確認画面用の説明文を、入力画面と完了画面で隠す */
.mw_wp_form_input .form_bl_caption_confirm,
.mw_wp_form_complete .form_bl_caption_confirm {
  display: none;
}

.form_bl_caption_input dl,
.form_bl_caption_confirm dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

.form_bl_caption_input dt,
.form_bl_caption_confirm dt {
  flex: 1 1 4em;
}

.form_bl_caption_input dd,
.form_bl_caption_confirm dd {
  flex: 1 1 calc(100% - 4em);
}

.form_bl_caption_input .form_bl_dList__em8 dt,
.form_bl_caption_confirm .form_bl_dList__em8 dt {
  flex: 1 1 8em;
}

.form_bl_caption_input .form_bl_dList__em8 dd,
.form_bl_caption_confirm .form_bl_dList__em8 dd {
  flex: 1 1 calc(100% - 8em);
}

.form_bl_caption_input a {
  text-decoration: underline;
}

/* 説明文（完了画面） */
.mw_wp_form_complete p {
  font-size: 1.2em;
  text-align: center;
}

/* 空のボックス　確認画面では非表示 */
.mw_wp_form_confirm .form_el_empty,
.mw_wp_form_complete .form_el_empty {
  display:none;
}

/* 強調 */
.form_el_txt_bold {
  font-size: 1.15em;
  font-weight: bold;
}

.form_el_txt_caution {
  color: var(--col_formBtn);
}

/* 縦位置：上へ */
.form_bl_verTop {
  vertical-align: top;
}


/*===============================================
●スマホ用（896px未満）
===============================================*/
@media screen and (max-width:896px) {
  /* 全体サイズ
================================================== */

  .mw_wp_form {
    width: 100%;
  }

  /* フォーム全体の並び
================================================== */
  .form_bl_formWrapper {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    width: 100%;
  }

  .form_bl_formWrapper .form_bl_fieldset {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    gap: 10px;
    justify-content: flex-start;
    padding-top: 1.6rem;
    width: 100%;
  }

  /* 入力画面のカラム */
  .mw_wp_form_input .form_bl_formWrapper .form_bl_border,
  .mw_wp_form_input .form_bl_formWrapper .form_bl_furigana_border,
  .mw_wp_form_input .form_bl_formWrapper .form_bl_legend,
  .mw_wp_form_input .form_bl_formWrapper .form_bl_input {
    width: 100%;
  }

  /* 確認画面のカラム */
  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_border,
  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_furigana_border,
  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_legend,
  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_input {
    width: 100%;
  }

  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_fieldset {
    align-items: flex-start;
  }

  /* 住所を連結して表示 */
  .mw_wp_form_confirm .form_bl_formWrapper .form_bl_address_body .form_bl_input {
    width: auto;
  }

  .form_bl_furigana {
    padding-top: .6rem;
  }

  /* 入力フィールド */
  .mw_wp_form fieldset .form_bl_row {
    width: 100%;
  }

  .form_bl_text__w94,
  .form_bl_text__w160,
  .form_bl_text__w368 {
    width: 100%;
  }

  .form_bl_text__w160__name {
    width: calc((100% - 10px) / 2);
  }

  .form_bl_input_bday > span {
    width: min(calc((100% - 6em) / 3), 9.4rem);
  }

  .form_bl_text__bday {
    width: calc(100% - 1.2em - 6px);
  }

  /* スマホでも横並び */
  .form_bl_row_spRow {
    flex: 1 1 auto;
  }

  /* PC横並び・SP縦並び */
  .form_bl_row_spCol {
    flex-direction: column;
  }

  /* ラジオボタン縦並びの場合、2つめ以降の左マージンを打ち消す */
  .mw_wp_form .horizontal-item + .horizontal-item {
    margin-left: 0 !important;
  }

  /* テキストエリア */
  .form_bl_textarea {
    width: 100%;
  }

  /* ボタン */
  .form_bl_submit_area {
    gap: 10px;
  }

  .mw_wp_form_input .form_bl_submit_area,
  .mw_wp_form_confirm .form_bl_submit_area {
    width: 100%;
  }

  .mw_wp_form_input .form_bl_submit_area {
    display: block;
  }

  .mw_wp_form_input .form_bl_confirm_buttonWrapper,
  .mw_wp_form_confirm .form_bl_confirm_buttonWrapper {
    width: 65.5%;
  }

  .mw_wp_form_input .form_bl_confirm_buttonWrapper,
  .mw_wp_form_confirm .form_bl_confirm_buttonWrapper {
    margin: 0 auto;
  }

  .mw_wp_form_confirm .form_bl_confirm_buttonWrapper {
    margin: 0;
  }

  .form_bl_confirm_button {
    width: 100%;
  }

  .form_bl_confirm_button::after {
    right: 2.2rem;
  }

  /* 送信するボタン */
  .mw_wp_form_confirm .form_bl_confirm_button {
    width: 100%;
  }

  /* 戻るボタン */
  .form_bl_back_button {
    width: 30%;
  }

  /* パディング */
  .form_bl_cellPadding {
    padding: 10px 0 18px;
  }

  .form_bl_cellPadding__label {
    padding: 0;
  }

  /* 複数フォームの場合のパディング：上 */
  .mw_wp_form_input .form_bl_cellPadding_top {
    padding: 10px 0 6px;
  }

  /* 複数フォームの場合のパディング：下 */
  .mw_wp_form_input .form_bl_cellPadding_bottom {
    padding: 10px 0 18px;
  }

  /* 確認画面のパディング */
  .mw_wp_form_confirm .form_bl_cellPadding,
  .mw_wp_form_confirm .form_bl_cellPadding_top,
  .mw_wp_form_confirm .form_bl_cellPadding_bottom {
    padding: 20px 0;
  }

  .mw_wp_form_confirm .form_bl_cellPadding_top + .mw_wp_form_confirm .form_bl_cellPadding_bottom {
    margin-top: -10px;
    padding: 0 0 20px;
  }
}
