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

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

********************************************************************************/
/*============================================================
 CSS変数　※サイトデザインに従い適宜設定
*============================================================*/
.page-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);

    --form-check-border-color: #B3B3B3;
    --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 {
	margin-top: 80px;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 80px;
    margin-bottom: 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.datetime-multi .cols-label {
    margin-top: 1em;
}
.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.datetime-multi .fmDatetimeReset {
    margin-top: 1em;
}
.page-form #form-main .form-item.datetime-multi .fmDatetimeReset button {
    border-radius: var(--form-border-radius);
    width: 24px;
    height: auto;
    aspect-ratio: 1;
    background-color: #fff;
    background-image: url(../images/form/icon-form-reset.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto;
}

.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(CF7 カスタム) */
.wpcf7-list-item {
    margin: 0;
}
.wpcf7-checkbox,
.wpcf7-radio {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* 項目(横並び) */
.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 {
}
.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 .wpcf7 #form-footer .btn-area .forInput .btn-confirm,
.page-form .wpcf7 #form-footer .btn-area .forInput .btn-send {
    cursor: pointer;
}

/* 確認画面用ボタン非表示 */
/* .page-form .mw_wp_form_input #form-footer .btn-area .forConfirm  {
    display: none;
} */
/* 非同意時処理(ボタン非活性) */
.page-form .wpcf7 #form-footer:not(.agreement-checked) .btn-area .forInput {
    border-color: #D8D8D8;
    background-color: #D8D8D8;
}
.page-form .wpcf7 #form-footer:not(.agreement-checked) .btn-area .forInput::after {
    display: none;
}
.page-form .wpcf7 #form-footer:not(.agreement-checked) .btn-area .forInput .btn-confirm,
.page-form .wpcf7 #form-footer:not(.agreement-checked) .btn-area .forInput .btn-send {
    pointer-events: none;
}
.page-form .wpcf7 #form-footer:not(.agreement-checked) .btn-area .forInput:hover {
    cursor: unset;
}

/* 【フォーム】CF7 機能調整
---------------------------------------- */
/* .page-form .wpcf7-response-output {
    display: none;
} */

/* ローダー */
.page-form .wpcf7 .ajax-loader,
.page-form .wpcf7 .wpcf7-spinner {
    display: none !important;
}
/* .page-form .wpcf7 .lvit-btn:has(.wpcf7-spinner) {
    overflow: visible;
    position: relative;
}
.page-form .wpcf7 .wpcf7-spinner {
    position: absolute;
    top: calc(100% + 24px);
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
} */

/* 【フォーム】エラー表示
---------------------------------------- */    
/* 総合メッセージ */
/* .page-form #form-error {
    display: none;
}
.page-form .wpcf7-form.invalid #form-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 .wpcf7 form .wpcf7-response-output {
    --form-response-color: var(--common-color-text);
    --form-response-bg: unset; 
    color: var(--form-response-color);
    border: solid 1px;
    border-color: var(--form-response-color);
    border-radius: var(--form-border-radius);
    padding: 16px;
    background-color: var(--form-response-bg);    
    margin: 0;
}
.page-form .wpcf7 form.invalid .wpcf7-response-output,
.page-form .wpcf7 form.unaccepted .wpcf7-response-output,
.page-form .wpcf7 form.payment-required .wpcf7-response-output {
    --form-response-color: var(--common-color-attention);
    --form-response-bg: var(--common-color-attention-bg); 
    margin-bottom: 80px;
}

/* 各項目エラーメッセージリアルタイム表示解除(ボタンクリックまで非表示) */
.page-form *:not(input[type="file"]) + .wpcf7-not-valid-tip,
.page-form .attached:has(input[type="file"], .error-msg) .wpcf7-not-valid-tip {
    display: none;
}

/* 各項目エラーメッセージリアルタイム表示復活(ボタンクリック後はリアルタイム表示) */
/* .page-form .wpcf7-form.invalid .wpcf7-not-valid-tip {
    display: block;
}  */

/* 各項目エラーメッセージ(カスタム処理用) */
.page-form #form-main .on-error .error-msg {
    color: var(--common-color-attention);
}
.page-form #form-main .on-error .wpcf7-form-control {
    border-color: var(--common-color-attention);
}
.page-form #form-main .on-error .wpcf7-checkbox,
.page-form #form-main .on-error .wpcf7-radio {
    padding: 16px;
    border: solid 1px var(--common-color-attention);
    border-radius: var(--form-border-radius);
    width: fit-content;
}

/* 各項目エラーメッセージ(リアルタイムバリデーション用) */
/* .page-form .wpcf7-form.invalid #form-main input.wpcf7-not-valid,
.page-form .wpcf7-form.invalid #form-main textarea.wpcf7-not-valid,
.page-form .wpcf7-form.invalid #form-main select.wpcf7-not-valid  {
    border-color: var(--common-color-attention);
}
.page-form .wpcf7-form.invalid #form-main .wpcf7-checkbox.wpcf7-not-valid,
.page-form .wpcf7-form.invalid #form-main .wpcf7-radio.wpcf7-not-valid {
    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 {
} */
/* 項目 */
/* .page-form .mw_wp_form_confirm #form-main .form-item dd {
} */
/* .page-form .mw_wp_form_confirm #form-main .form-item dd.date,
.page-form .mw_wp_form_confirm #form-main .form-item dd.time {
    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 {
	margin-top: 80px;
}

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

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



/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
 Tablet
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
@media screen and (max-width: 1128px) {
    /*============================================================
     フォーム共通
    *============================================================*/
    .page-form #form-header .forThanks {
        font-size: 20px;
        line-height: 180%;
    }
	.page-form #sec-thanks {
		margin-top: 48px;
	}
	.page-form #sec-thanks .catch {
		margin-bottom: 40px;
	}
	
    /* 【フォーム】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 #form-main .form-item.datetime-multi .cols-label,
    .page-form #form-main .form-item.datetime-multi .fmDatetimeReset {
        margin-top: 0;
    }
    
    
    /* 確認画面
    ---------------------------------------- */
    /* .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%;
    } */

}



