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

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

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

    --form-check-border-radius: 1px;
    --form-check-border-color: #B3B3B3;
    --form-checked-color: var(--common-color-accent);
}
.page-form:has(.form-popup) {
	--form-background-color: #FAFAFA;
	--form-border-radius: 4px;
	--form-border-color: #CACACA;
    --form-hover-border-color: var(--form-border-color);
    --form-placeholder-color: var(--common-color-notice);

    --form-check-border-radius: 1px;
    --form-check-border-color: #B3B3B3;
    --form-checked-color: var(--common-color-accent);

}


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


/* 【フォーム】formヘッダー
---------------------------------------- */
.page-form #form-header {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 0;
}
.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 #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: 7px 6px;
    /* border: solid 1px var(--common-color-attention); */
    border-radius: 4px;
    background-color: var(--common-color-attention);
    color: var(--common-color-white);
    font-weight: bold;
    font-size: var(--rem12px);
    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-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 {
    display: flex;
    flex-wrap: wrap;
    gap: 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 {
    max-width: 120px;
}
.page-form #form-main .form-item dd.zip {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
    align-items: center;
}

/* .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 .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 {
    padding: 24px 8px;
    background-color: #FCFCFC;
    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;
}

/* 非同意時処理(ボタン非活性) */
/* .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); 
}
/* エラー時フォーカス移動先 */
.page-form .wpcf7 #blockskip-anchor-form {
    display: none;
    position: absolute;
    opacity: 0;
    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 #form-main .agreement.on-error .wpcf7-checkbox {
    margin: 0 auto;
}

/* 各項目エラーメッセージ(リアルタイムバリデーション用) */
/* .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);
} */



/*============================================================
 フォーム共通　完了画面
*============================================================*/
.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-form #sec-thanks .parts-btn {
    --margin: 0 auto;
}

/*============================================================
 フォーム共通　セクション ご相談予約
*============================================================*/
.page-form #sec-reserve {
    margin-bottom: 64px;
}
.page-form #sec-reserve .block-reserve {
    padding: 32px;
    background-color: var(--common-color-background1);
    border-radius: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 21px;
}
.page-form #sec-reserve .block-reserve .image {
    width: 88px;
    height: 88px;
    border-radius: 100%;
    background-color: var(--common-color-white);
    background-image: url(../images/form/icon-form-date-time.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 50px auto;
}
.page-form #sec-reserve .block-reserve .info {
    flex: 1;
}
.page-form #sec-reserve .block-reserve .info .title {
    font-weight: bold;
    font-size: 20px;
    line-height: 180%;
    margin-bottom: 8px;
}
.page-form #sec-reserve .block-reserve .info .lead {
    font-size: 14px;
    line-height: 160%;
    margin-bottom: 16px;
}
.page-form #sec-reserve .block-reserve .info .btn-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
}


/*============================================================
 お問い合わせページ用
*============================================================*/
/* 【フォーム】formヘッダー
---------------------------------------- */
#page-contact #form-header .title {
    font-weight: bold;
    font-size: 24px;
    line-height: 180%; 
}


/*============================================================
 フォーム　popup
*============================================================*/
.page-form .form-popup .inner {
    max-width: unset;
    padding: 0;
    gap: 0;
}

.page-form .form-popup .wpcf7 form.invalid .wpcf7-response-output,
.page-form .form-popup .wpcf7 form.unaccepted .wpcf7-response-output,
.page-form .form-popup .wpcf7 form.payment-required .wpcf7-response-output,
.page-form .form-popup .wpcf7 form.sent .wpcf7-response-output {
    padding: 0;
    background-color: transparent;
    border: none;
    margin-bottom: 16px;
}

.page-form .form-popup .wpcf7 #blockskip-anchor-form,
.page-form .form-popup #form-main .on-error .error-msg {
    display: none !important;
}

.page-form .form-popup #form-main {
    margin-bottom: 24px;
}
.page-form .form-popup #form-main dl {
    gap: 16px;
}
.page-form .form-popup #form-main .form-item .col {
    gap: 6px;
}
.page-form .form-popup #form-main .form-item dt {
    font-weight: bold;
    font-size: 12px;
    line-height: 18px;
    color: #97999C;
}
.page-form .form-popup input[type="text"],
.page-form .form-popup input[type="date"],
.page-form .form-popup input[type="tel"],
.page-form .form-popup input[type="email"],
.page-form .form-popup textarea,
.page-form .form-popup select {
    padding: 8px 12px;
    height: 48px;
}
.page-form .form-popup .wpcf7-checkbox, .wpcf7-radio {
    flex-direction: row;
    gap: 24px;
}

.page-form .form-popup #form-footer .btn-area .parts-btn {
    --width: fit-content;
    --border-radius: 56px;
    --border-color: var(--common-color-accent);
    --background: var(--common-color-accent);
    --font-weight: 400;
    --color: var(--common-color-white);
    --hover-background: #DEB964;
    --hover-border-color: #DEB964;
    margin-bottom: 16px;
    background-image: none;
}
.page-form .form-popup #form-footer .contact-phone {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 16px 0;
}
.page-form .form-popup #form-footer .contact-phone .office {
    flex: 1;
    text-align: center;
}
.page-form .form-popup #form-footer .contact-phone .office .name {
    font-weight: 500;
    font-size: 14px;
    line-height: 200%;
    letter-spacing: 1.12px;
}
.page-form .form-popup #form-footer .contact-phone .office .tel {
    font-weight: bold;
    font-size: 20px;
    line-height: 180%;
    color: var(--common-color-accent);
}


/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/
 Tablet
_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/*/
@media screen and (max-width: 1024px) {
    /*============================================================
     フォーム共通
    *============================================================*/
    .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 #sec-reserve .block-reserve {
        flex-direction: column;
        align-items: center;
    }
    .page-form #sec-reserve .block-reserve .info .btn-list {
        flex-direction: column;
    }
    .page-form #sec-reserve .block-reserve .info .btn-list .parts-btn {
        width: 100%;
    }

    /*============================================================
     お問い合わせページ用
    *============================================================*/
    /* 【フォーム】formヘッダー
    ---------------------------------------- */
    #page-contact #form-header .title {
        font-weight: bold;
        font-size: 24px;
        line-height: 180%; 
    }

    /*============================================================
    フォーム　popup
    *============================================================*/
    @media screen and (max-width: 499px) {
        .page-form .form-popup #form-footer .contact-phone {
            flex-direction: column;
            width: fit-content;
            margin: 0 auto;
        }
        .page-form .form-popup #form-footer .contact-phone .office {
            flex: unset;
            max-width: 148px;
        }
    }
}



