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

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

********************************************************************************/
/*============================================================
 CSS変数　※サイトデザインに従い適宜設定
*============================================================*/
.page-form {
	--form-background-color: #fff;
	--form-border-radius: 8px;
	--form-border-color: #ddd;
    --form-hover-border-color: #ddd;
    --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 .block-post-content .inner {
    gap: 80px;
}
.page-form .block-post-content.section .inner > * {
    margin-bottom: 0;
}
.page-form .inner .inner {
    padding: 0;
}


/* 【フォーム】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: var(--rem14px);
    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: var(--rem12px);
    line-height: 100%;
    text-align: center;
}
/* 項目 */
.page-form #form-main .form-item dd {
    /* max-width: 640px; */
    display: flex;
    flex-direction: column;
    gap: 4px 0;
}
.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-bottom: 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-bottom: 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 {
    flex-direction: row;
    gap: 4px 12px;
    align-items: center;
}
.page-form #form-main .form-item dd.zip::before {
    content: "郵便番号";
    display: block;
    font-size: var(--rem12px);
    line-height: 160%;
}
.page-form #form-main .form-item dd.zip input {
    width: 100px;
}
.page-form #form-main .form-item dd.zip .notice {
    flex: 1;
}

/* .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;
    align-items: flex-end;
    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-item.policy,
.page-form #form-footer .policy {
    text-align: center;
}
.page-form #form-footer .policy {
    margin-bottom: 64px;
}
.page-form .form-item.policy .agreement,
.page-form #form-footer .agreement {
    align-items: center;
}
.page-form .form-item.policy .policy-link,
.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;
    color: #fff;
}

/* 非同意時処理(ボタン非活性) ※WA対応時はコメントアウトのままにしておくこと */
.page-form:not([data-wa]) .wpcf7 form:not(.agreement-checked) .btn-area .forInput {
    border-color: #D8D8D8;
    /* background-color: #D8D8D8; */
    background: #D8D8D8;    /* グラデーション用 */
    color: #fff;
}
.page-form:not([data-wa]) .wpcf7 form:not(.agreement-checked) .btn-area .forInput::after {
    display: none;
}
.page-form:not([data-wa]) .wpcf7 form:not(.agreement-checked) .btn-area .forInput.btn-confirm,
.page-form:not([data-wa]) .wpcf7 form:not(.agreement-checked) .btn-area .forInput.btn-send {
    pointer-events: none;
}
.page-form:not([data-wa]) .wpcf7 form: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); 
}
/* エラー時フォーカス移動先 */
.page-form .wpcf7 #blockskip-anchor-form {
    display: none;
    position: absolute;
    z-index: -1;
}

/* 各項目エラーメッセージリアルタイム表示解除(ボタンクリックまで非表示) */
.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-form-control-wrap:has(.error-msg) .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: var(--rem24px);
    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: var(--rem24px);
    line-height: 180%;
} */

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

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


/*============================================================
 フォーム お問い合わせ　入力画面
*============================================================*/
#page-contact #form-header {
    gap: 40px;
    margin-bottom: 40px;
}
#page-contact #form-header .reserve-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 40px;
}
#page-contact #form-header .reserve-list .tel {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-weight: 700;
    font-size: 40px;
    line-height: 150%;
}
#page-contact #form-header .reserve-list .tel a {
    text-decoration: unset;
    color: var(--common-color-accent);
}
#page-contact #form-header .reserve-list .tel::before {
    display: block;
    content: "";
    width: 40px;
    height: 40px;
    background-image: url(../images/common/icon-btn-tel.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 40px auto;
    margin-top: 8px;
}

/*============================================================
 フォーム 資料請求共通　入力画面
*============================================================*/
#page-document iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 640 / 389;
}

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
 Tablet
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
@media screen and (max-width: 1247px) {
    /*============================================================
     フォーム共通
    *============================================================*/
    .page-form #form-header .forThanks {
        font-size: var(--rem20px);
        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 #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;
    } */

}



