@charset "UTF-8";
/********************************************************************************

page-form.css　フォームページ関連css

********************************************************************************/
/*============================================================
 CSS変数 for mw_wp_form　※サイトデザインに従い適宜設定
*============================================================*/
.mw_wp_form {
	--form-background-color: #FAFAFA;
	--form-border-radius: 8px;
	--form-border-color: #F0F0F0;
    --form-hover-border-color: var(--form-border-color);
    --form-placeholder-color: var(--common-color-notice);

    --form-check-border-radius: 1px;
    --form-check-border-color: var(--common-color-notice);
    --form-checked-color: var(--common-color-main);
}


/*============================================================
 フォーム共通　
*============================================================*/
.page-form form {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 80px;
}
.page-form .inner {
    gap: 80px;
}

/* 【ステップ】
---------------------------------------- */
.page-form #sec-step {
}
.page-form #sec-step .box-step {
	display: flex;
	flex-wrap: wrap;
    justify-content: center;
    gap: 56px;
}
.page-form #sec-step .box-step .step {
    width: 64px;
    height: 56px;
    padding: 6px 12px;
    background-color: #F9F9F9;
    border-radius: 6px;
    font-weight: bold;
    font-size: 12px;
    line-height: 140%;
    text-align: center;
    position: relative;
}
.page-form #sec-step .box-step .step:not(:last-child):after {
    content: "";
    display: block;
    width: 56px;
    height: 56px;
    background-image: url(../images/form/icon-form-step-arrow.svg);
    background-repeat: no-repeat;
    background-size: 8px auto;
    background-position: center;
    position: absolute;
    top: 0;
    right: -56px;
}
.page-form #sec-step .box-step .step span {
    font-size: 16px;
    line-height: 160%;
}

/* アクティブ切り替え */
.page-form .mw_wp_form_input #sec-step .box-step .step-1,
.page-form .mw_wp_form_confirm #sec-step .box-step .step-2,
.page-form .mw_wp_form_complete #sec-step .box-step .step-3 {
    color: #fff;
    background-color: var(--common-color-main);
}

/* 【フォーム】formヘッダー
---------------------------------------- */
.page-form #form-header {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 80px;
}
.page-form #form-header .forInput {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 16px;
}
.page-form #form-header .lead a {
    text-decoration: underline;
}
/* リード表示切替 */
.page-form .mw_wp_form_input #form-header .forConfirm {
    display: none;
}
/* 画像 */
.page-form #form-header .image {
    text-align: center;
}


/* 【フォーム】form詳細
---------------------------------------- */
.page-form #form-main {
}
.page-form #form-main dl {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 40px 0;
}
.page-form #form-main .form-item {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 16px;
}
/* 項目名 */
.page-form #form-main .form-item dt {
    font-weight: bold;
    font-size: 16px;
    line-height: 160%;
}
.page-form #form-main .form-item dt.form-valid {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}
.page-form #form-main .form-item dt.form-valid::after {
    content: "必須";
    display: inline-block;
    padding: 5px 11px;
    border: solid 1px var(--common-color-attention);
    color: var(--common-color-attention);
    font-weight: bold;
    font-size: 12px;
    line-height: 100%;
    text-align: center;
}
/* 項目 */
.page-form #form-main .form-item dd {
    /* max-width: 640px; */
}
.page-form #form-main .form-item dd.full {
    max-width: 100%;
}
.page-form #form-main .form-item dd.small {
    max-width: 400px;
}
.page-form #form-main .form-item dd.name {
    max-width: 300px;
}
.page-form #form-main .form-item dd.date,
.page-form #form-main .form-item dd.time {
    /* max-width: 240px; */
    width: 320px;
}

.page-form #form-main .form-item dd.zip:not(:last-child) {
    margin-bottom: 16px;
}
.page-form #form-main .form-item dd.zip > *:not(.notice) {
    display: inline-block;
}
.page-form #form-main .form-item dd.zip input {
    max-width: 100px;
}
/* datepickerカスタム */
.ui-datepicker .ui-datepicker-title select.ui-datepicker-year,
.ui-datepicker .ui-datepicker-title select.ui-datepicker-month {
    height: auto;
    padding: 0 4px;
    background-position: right 4px center;
    display: inline-block;
}
.ui-datepicker .ui-datepicker-title select.ui-datepicker-year {
    width: 68px;
    margin: 0 4px 4px 0;
}
.ui-datepicker .ui-datepicker-title select.ui-datepicker-month {
    width: 68px;
    margin: 0 0 4px 24px;
}

/* checkbox, radio(MW WP FORM カスタム) */
#form-main .form-item .vertical-item,
#form-main .form-item .horizontal-item {
    margin: 0;
}
.page-form #form-main .form-item .choices-item-wrap {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 16px;
}
.page-form #form-main .form-item .choices-item-wrap[data-type="col"]  {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    flex-direction:unset;
}
/* 項目(横並び) */
.page-form #form-main .form-item .cols {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
}
.page-form #form-main .mw_wp_form_input .form-item .cols .cols-label {
    padding: 16px 0 0 0;
}
.page-form #form-main .form-item .col {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 16px;
}

/* 【フォーム】同意・ボタン操作エリア
---------------------------------------- */
.page-form #form-footer {
    text-align: center;
}
/* 同意エリア */
.page-form #form-footer .policy {
    text-align: center;
    margin-bottom: 64px;
}
.page-form #form-footer .agreement {
    margin-bottom: 16px;
}
.page-form #form-footer .policy .policy-link {
    text-decoration: underline;
}
/* ボタン操作エリア */
.page-form #form-footer .btn-area  {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 32px;
}
/* 確認画面用ボタン非表示 */
.page-form .mw_wp_form_input #form-footer .btn-area .btn-confirm  {
    display: none;
}
/* 非同意時処理(ボタン非活性) */
.page-form .mw_wp_form_input #form-footer:not(.agreement-checked) .btn-area .btn-input {
    border-color: #D8D8D8;
    background-color: #D8D8D8;
}
.page-form .mw_wp_form_input #form-footer:not(.agreement-checked) .btn-area .btn-input::after {
    display: none;
}
.page-form .mw_wp_form_input #form-footer:not(.agreement-checked) .btn-area .btn-input .form-confirm {
    pointer-events: none;
}
.page-form .mw_wp_form_input #form-footer:not(.agreement-checked) .btn-area .btn-input:hover {
    cursor: unset;
}

/* 【フォーム】エラー表示
---------------------------------------- */
/* 総合メッセージ */
.page-form #form-error {
    display: none;
}
.page-form #form-error.on-error {
    display: block;
    color: var(--common-color-attention);
    border: solid 1px var(--common-color-attention);
    border-radius: var(--form-border-radius);
    padding: 16px;
    background-color: var(--common-color-attention-bg);
}
/* 各項目エラーメッセージ */
.page-form #form-main .error-area {
    display: none;
}
.page-form #form-main .on-error .error-area {
    display: block;
}
.page-form #form-main .on-error input,
.page-form #form-main .on-error textarea,
.page-form #form-main .on-error select  {
    border-color: var(--common-color-attention);
}
.page-form #form-main .on-error .choices-item-wrap {
    padding: 16px;
    border: solid 1px var(--common-color-attention);
    border-radius: var(--form-border-radius);
    width: fit-content;
}
.page-form #form-main .error {
    color: var(--common-color-attention);
}


/*============================================================
 フォーム共通　確認画面
*============================================================*/
/* 【フォーム】formヘッダー
---------------------------------------- */
/* リード表示切替 */
.page-form .mw_wp_form_confirm #form-header .forInput {
    display: none;
}
.page-form .mw_wp_form_confirm #form-header .forConfirm {
    font-weight: 700;
    font-size: 24px;
    line-height: 180%;
}

/* 【フォーム】form詳細
---------------------------------------- */
/* 項目名 */
.page-form .mw_wp_form_confirm #form-main .form-item dt {
    /* font-weight: normal; */
}
/* 項目 */
.page-form .mw_wp_form_confirm #form-main .form-item dd {
    /* font-weight: bold; */
}
.page-form .mw_wp_form_confirm #form-main .form-item dd.date,
.page-form .mw_wp_form_confirm #form-main .form-item dd.time {
    /* max-width: 240px; */
    width: fit-content;
}

/* 注釈 */
.page-form .mw_wp_form_confirm #form-main .form-item .notice {
    display: none;
}

/* 【フォーム】同意・ボタン操作エリア
---------------------------------------- */
/* 同意エリア*/
.page-form .mw_wp_form_confirm #form-footer .policy {
    display: none;
}


/*============================================================
 フォーム共通　完了画面
*============================================================*/
.page-form .mw_wp_form_complete #sec-form {
    margin-bottom: 80px;
}
.page-form .mw_wp_form_complete #form-header .forThanks {
    font-weight: 700;
    font-size: 24px;
    line-height: 180%;
}
/* 入力・確認画面時 非表示 */
.page-form #sec-thanks {
}

.page-form #sec-thanks .catch {
    max-width: 800px;
    margin: 0 auto;
}

.page-form #sec-thanks .message {
    font-size: 16px;
    line-height: 200%;
    margin-bottom: 64px;
}



/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
 Tablet
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
@media screen and (max-width: 1024px) {
    /*============================================================
     フォーム共通
    *============================================================*/
    .page-form #form-header .forThanks {
        font-size: 20px;
        line-height: 180%;
    
    }
    /* 【フォーム】form詳細
    ---------------------------------------- */
    /* 項目 */
    .page-form #form-main .form-item dd.date,
    .page-form #form-main .form-item dd.time {
        width: 300px;
    }
}



/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
 SP
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
@media screen and (max-width: 767px) {
    /*============================================================
     フォーム共通
    *============================================================*/
    /* 【フォーム】form詳細
    ---------------------------------------- */
    /* 項目(横並び) */
    .page-form #form-main .form-item .cols {
        flex-direction: column;
    }
    .page-form #form-footer .policy .agreement input[type=checkbox] + span {
        padding-left: 32px;
        text-align: left;
    }
    
    /* 確認画面
    ---------------------------------------- */
    .page-form .mw_wp_form_confirm #form-main .form-item.datetime-multi .cols {
        flex-direction: row;
    }

    /* 完了画面
    ---------------------------------------- */
    /* font-size 62÷512=0.115 */
    /* .page-form #sec-thanks .catch {
        font-size: min(62px, calc(100vw * 0.115)); 
        line-height: 120%;
    } */

}



