/**
 * お問い合わせページ（入力・確認・送信完了）
 */

body.page-contact .renewal-subpage-body {
    font-family: "Noto Sans JP", "Hiragino Sans", "Meiryo", sans-serif;
}

/* ----- カラー・タイポの共通トークン ----- */
body.page-contact {
    --contact-neutral-01: #333333;
    --contact-key: #ff6243;
    --contact-line: rgba(217, 217, 217, 0.88);
    --contact-bg-muted: #f5f2f0;
    --contact-bg-white: #ffffff;
    --contact-font-body: var(--contact-neutral-01);
}

/* ----- イントロ ----- */
body.page-contact .contact-intro {
    padding-top: 8rem;
    padding-bottom: 0;
}

body.page-contact .contact-intro__frame {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 32rem;
    max-width: 100%;
}

body.page-contact .contact-intro__heading-col {
    display: flex;
    flex-direction: column;
    gap: 28rem;
    width: 100%;
}

body.page-contact .contact-intro__title-wrap {
    position: relative;
    padding: 4rem 0 4rem 28rem;
    align-self: stretch;
}

/* 左ライン：90° グラデーション */
body.page-contact .contact-intro__title-wrap::before {
    content: "";
    position: absolute;
    left: 0;
    top: 4rem;
    bottom: 4rem;
    width: 5rem;
    border-radius: 2rem;
    background: linear-gradient(90deg, #ff9143 0%, #ff6243 100%);
}

body.page-contact .contact-intro__title {
    margin: -5rem 0 0;
    font-weight: 700;
    font-size: 34rem;
    letter-spacing: 0.04em;
    line-height: 1.8;
    color: var(--contact-font-body);
}

body.page-contact .contact-intro__line {
    height: 1px;
    width: 100%;
    background-color: var(--contact-line);
}

body.page-contact .contact-intro__lead-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

body.page-contact .contact-intro__lead {
    margin: 0;
    flex: 1;
    font-weight: 400;
    font-size: 16rem;
    line-height: 1.8;
    letter-spacing: 0;
    color: var(--contact-font-body);
}

/* 確認イントロ */
body.page-contact .contact-intro--confirm {
    padding-top: 8rem;
    padding-bottom: 0;
}

body.page-contact .contact-intro--confirm .contact-intro__title {
    letter-spacing: 0.04em;
}

body.page-contact .contact-intro__lead--confirm {
    line-height: 28.8rem;
}

body.page-contact .contact-page--confirm-detail {
    padding-top: 0;
}

/* ----- 送信完了ページ本文 ----- */
body.page-contact .contact-page--thanks-complete {
    padding-top: 0;
    padding-bottom: 0;
}

body.page-contact .contact-thanks-complete {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 48rem;
    width: 100%;
    max-width: 100%;
    padding: 40rem 0 96rem;
    box-sizing: border-box;
}

body.page-contact .contact-thanks-complete__hero {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 24rem;
    position: relative;
    flex: 0 0 auto;
}

body.page-contact .contact-thanks-complete__mark {
    position: relative;
    width: 141rem;
    height: 55rem;
    flex-shrink: 0;
}

body.page-contact .contact-thanks-complete__mark-layer {
    position: absolute;
    display: block;
    pointer-events: none;
}

body.page-contact .contact-thanks-complete__mark-layer--1 {
    top: 1px;
    left: 38rem;
    width: 66rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--2 {
    top: 4rem;
    left: 40rem;
    width: 64rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--3 {
    top: 11rem;
    left: 21rem;
    width: 20rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--4 {
    top: 23rem;
    left: 10rem;
    width: 24rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--5 {
    top: 35rem;
    left: 0;
    width: 29rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--6 {
    top: 26rem;
    left: 87rem;
    width: 27rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__mark-layer--7 {
    top: 35rem;
    left: 93rem;
    width: 16rem;
    height: auto;
}

body.page-contact .contact-thanks-complete__title {
    margin: 0;
    font-weight: 700;
    font-size: 34rem;
    letter-spacing: 0.04em;
    line-height: 1.8;
    color: var(--contact-font-body);
    text-align: center;
    white-space: nowrap;
}

body.page-contact .contact-thanks-complete__body {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16rem;
    flex: 0 0 auto;
}

body.page-contact .contact-thanks-complete__text {
    margin: -1px 0 0;
    font-weight: 400;
    font-size: 16rem;
    line-height: 28.8rem;
    letter-spacing: 0.04em;
    text-align: center;
    color: var(--contact-font-body);
    max-width: min(864px, 100%);
}

body.page-contact .contact-thanks-complete__footer {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 40rem;
    width: 100%;
    align-self: stretch;
}

body.page-contact .contact-thanks-complete__cta {
    display: inline-flex;
    align-items: flex-start;
    justify-content: center;
    gap: 16rem;
}

/* 完了画面CTAは共通 c-button（primary）へ委譲。__cta ラッパーのレイアウトのみ保持。
   旧 __btn/__btn-label/__btn-icon（--contact-key=#ff6243 で primary と同色）は撤去。 */

body.page-contact .contact-thanks-complete__sub {
    margin: 0;
}

body.page-contact .contact-thanks-complete__sub-link {
    font-weight: 700;
    font-size: 16rem;
    color: var(--contact-key);
    text-decoration: underline;
}

body.page-contact .contact-thanks-complete__sub-link:hover {
    text-decoration: none;
}

@media (max-width: 767.98px) {
    body.page-contact .contact-thanks-complete {
        padding: 24rem 0 64rem;
        gap: 32rem;
    }

    body.page-contact .contact-thanks-complete__title {
        font-size: 24rem;
        white-space: normal;
        line-height: 1.5;
        padding: 0 8rem;
    }

    body.page-contact .contact-thanks-complete__text {
        text-align: left;
        padding: 0 4rem;
    }

    body.page-contact .contact-thanks-complete__footer {
        gap: 24rem;
    }

    /* SP は旧 __btn の full幅(max280) を c-button へ踏襲（PCは c-button min-width:230） */
    body.page-contact .contact-thanks-complete__cta .c-button {
        width: 100%;
        max-width: 280rem;
    }
}

/* ----- 確認本文（セクション＋パネル） ----- */
body.page-contact .contact-confirm-summary {
    display: flex;
    flex-direction: column;
    gap: 40rem;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-confirm-summary__section {
    display: flex;
    flex-direction: column;
    gap: 40rem;
    width: 100%;
}

body.page-contact .contact-confirm-summary__head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16rem;
    align-self: stretch;
    width: 100%;
    padding: 0 0 8rem;
    box-sizing: border-box;
}

body.page-contact .contact-confirm-summary__title {
    margin: -2rem 0 0;
    font-weight: 700;
    font-size: 24rem;
    letter-spacing: 0.04em;
    line-height: 43.2rem;
    color: var(--color-text-default);
}

body.page-contact .contact-confirm-summary__accent {
    display: flex;
    align-items: flex-end;
    align-self: stretch;
    width: 100%;
}

body.page-contact .contact-confirm-summary__accent-bar {
    width: 100rem;
    height: 2rem;
    flex-shrink: 0;
    background-color: var(--color-key);
}

body.page-contact .contact-confirm-summary__accent-rest {
    flex: 1;
    height: 1px;
    background-color: var(--contact-line);
}

body.page-contact .contact-confirm-summary__panel {
    display: flex;
    flex-direction: column;
    gap: 24rem;
    align-self: stretch;
    width: 100%;
    padding: 48rem 72rem;
    background-color: var(--color-bg-02);
    border-radius: 32rem;
    border: 4rem solid var(--color-white);
    box-sizing: border-box;
}

body.page-contact .contact-confirm-summary__row {
    display: flex;
    align-items: center;
    gap: 64rem;
    width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-confirm-summary__label-col {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 8rem;
    flex: 0 0 auto;
    width: auto;
    min-width: 200rem;
    max-width: min(360px, 46%);
    min-height: 48rem;
    box-sizing: border-box;
}

body.page-contact .contact-confirm-summary__marker {
    width: 8rem;
    height: 8rem;
    border-radius: 2rem;
    flex-shrink: 0;
    background: linear-gradient(90deg, var(--color-orange-01) 0%, var(--color-key) 100%);
}

body.page-contact .contact-confirm-summary__label-text {
    font-weight: 700;
    font-size: 16rem;
    line-height: 24rem;
    color: var(--color-text-default);
    flex: 0 1 auto;
    min-width: 0;
    white-space: nowrap;
}

body.page-contact .contact-confirm-summary__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 2rem 6rem;
    font-size: 10rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.02em;
    white-space: nowrap;
    writing-mode: horizontal-tb;
    color: var(--color-white);
    background-color: var(--color-key);
    border-radius: 4rem;
}

body.page-contact .contact-confirm-summary__value {
    flex: 1;
    min-width: 0;
    font-weight: 400;
    font-size: 16rem;
    line-height: 24rem;
    color: var(--color-text-default);
    word-break: break-word;
}

body.page-contact .contact-confirm-summary__value--multiline {
    line-height: 32rem;
}

body.page-contact .contact-confirm-summary__value a {
    color: var(--color-key);
    text-decoration: underline;
}

body.page-contact .contact-confirm-summary__row-line {
    align-self: stretch;
    width: 100%;
    height: 1px;
    background-color: var(--contact-line);
}

body.page-contact .contact-confirm-summary__panel > .contact-confirm-summary__row-line:last-child {
    display: none;
}

body.page-contact .contact-confirm-summary__list {
    margin: 0;
    padding-left: 1.25em;
}

/* ----- 確認画面の戻る／送信（230×56・上ブロックから 40px） ----- */
body.page-contact .contact-confirm-actions {
    margin-top: 40rem;
    width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-confirm-actions__form {
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    width: 100%;
    display: block;
}

body.page-contact .contact-confirm-actions__row {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 24rem;
    width: 100%;
    box-sizing: border-box;
}

/* 確認画面の 送信(primary)/戻る(secondary-back) は共通 c-button へ委譲。
   旧 __btn/__btn--primary/--secondary/--wrap/__btn-label/__icon は撤去。
   __row のみ保持(PC=中央寄せ横並び / SP=縦stretchで c-button が全幅化)。 */

@media (max-width: 767.98px) {
    body.page-contact .contact-confirm-summary__title {
        font-size: 20rem;
        line-height: 30rem;
        letter-spacing: 0.04em;
    }

    body.page-contact .contact-confirm-summary__panel {
        padding: 24rem;
        border-radius: 24rem;
    }

    body.page-contact .contact-confirm-summary__row {
        flex-direction: column;
        align-items: flex-start;
        gap: 12rem;
    }

    body.page-contact .contact-confirm-summary__label-col {
        flex: none;
        width: 100%;
        max-width: none;
        min-height: 0;
        flex-wrap: nowrap;
        align-items: center;
    }

    body.page-contact .contact-confirm-summary__label-text {
        white-space: normal;
        flex: 1 1 auto;
        min-width: 0;
    }

    body.page-contact .contact-confirm-summary__badge {
        flex-shrink: 0;
        align-self: center;
    }

    body.page-contact .contact-confirm-actions__row {
        flex-direction: column;
        align-items: stretch;
    }
}

/* FAQ 誘導カードは共通パーツ c-announce（components/announce.css）へ統合済み */

/* PC: お問い合わせ本体は Figma 4820:287884（Contents）の 1300px 幅 / 70 ガターに合わせる。
   共通 .container（app.css）の max-width:1200rem + padding:0 20rem だと 1440 viewport で
   1160px しか取れず、Figma の Frame 44/45/Frame 6272088（panel・announce 共に width=1300）
   と差分が出るため、works-index/products-index と同じく解除する。
   SP（<=1023.98）は共通 .container の 20px ガターを継承（contact-intro 側で 0 上書き）。 */
@media (min-width: 1024px) {
    body.page-contact .renewal-subpage-body > .container.contact-page,
    body.page-contact .renewal-subpage-body > .container.contact-intro {
        max-width: none;
        padding-left: 70rem;
        padding-right: 70rem;
        box-sizing: border-box;
    }
}

/* SP: Figma wf004 SP（3439:138224）は左右 16px ガター（Frame 6271774 x=16 / width=358）。
   グローバル .container の SP padding 0 20rem では過剰インセットになるため 16rem へ縮める。 */
@media (max-width: 1023.98px) {
    body.page-contact .renewal-subpage-body > .container.contact-page,
    body.page-contact .renewal-subpage-body > .container.contact-intro {
        padding-left: 16rem;
        padding-right: 16rem;
    }
}

/* ----- フォームエリア（カタログ／クレーム等：リニューアル前レイアウト） ----- */
body.page-contact .contact-page {
    margin-top: 40rem;
    margin-bottom: 64rem;
}

body.page-contact .contact-page form:not(.contact-form130) > h2 {
    margin: 0 0 16rem;
    font-weight: 700;
    font-size: 18rem;
    line-height: 1.6;
    letter-spacing: 0.02em;
    color: var(--contact-font-body);
}

body.page-contact .contact-page form:not(.contact-form130) > h2:not(:first-of-type) {
    margin-top: 40rem;
}

body.page-contact .contact-page .content {
    padding: 0 0 8rem;
}

body.page-contact .contact-page .content > div {
    margin-bottom: 20rem;
}

body.page-contact .contact-page form:not(.contact-form130) label {
    display: inline-block;
    margin-bottom: 8rem;
    font-size: 14rem;
    font-weight: 700;
    color: var(--contact-font-body);
}

body.page-contact .contact-page form:not(.contact-form130) input[type="text"],
body.page-contact .contact-page form:not(.contact-form130) input[type="email"],
body.page-contact .contact-page form:not(.contact-form130) input[type="tel"],
body.page-contact .contact-page form:not(.contact-form130) input[type="number"],
body.page-contact .contact-page form:not(.contact-form130) input[type="date"],
body.page-contact .contact-page form:not(.contact-form130) textarea,
body.page-contact .contact-page form:not(.contact-form130) select {
    width: 100%;
    max-width: 560rem;
    padding: 12rem 16rem;
    font-family: inherit;
    font-size: 16rem;
    line-height: 1.5;
    color: var(--contact-font-body);
    background: var(--contact-bg-white);
    border: 1px solid var(--contact-line);
    border-radius: 8rem;
}

body.page-contact .contact-page form:not(.contact-form130) textarea {
    max-width: 100%;
    min-height: 140rem;
    resize: vertical;
}

body.page-contact .contact-page form:not(.contact-form130) input:focus-visible,
body.page-contact .contact-page form:not(.contact-form130) textarea:focus-visible,
body.page-contact .contact-page form:not(.contact-form130) select:focus-visible {
    outline: 2rem solid var(--contact-key);
    outline-offset: 1px;
}

body.page-contact .contact-page form:not(.contact-form130):not(.contact-confirm-actions__form) button[type="submit"],
body.page-contact .contact-page form:not(.contact-form130) .js-zipcode-search {
    font-family: inherit;
    cursor: pointer;
}

body.page-contact .contact-page form:not(.contact-form130) .js-zipcode-search {
    margin-top: 8rem;
    margin-left: 0;
    padding: 10rem 20rem;
    font-size: 14rem;
    font-weight: 700;
    color: var(--contact-font-body);
    background: var(--contact-bg-white);
    border: 1px solid var(--contact-line);
    border-radius: 999rem;
}

body.page-contact .contact-page form:not(.contact-form130) .js-zipcode-search:hover {
    border-color: rgba(255, 98, 67, 0.45);
}

body.page-contact .contact-page form:not(.contact-form130):not(.contact-confirm-actions__form) button[type="submit"] {
    margin-top: 24rem;
    padding: 14rem 48rem;
    font-size: 16rem;
    font-weight: 700;
    color: #fff;
    background: linear-gradient(180deg, #ff9143 0%, #ff6243 100%);
    border: none;
    border-radius: 999rem;
    box-shadow: 0 2rem 8rem rgba(255, 98, 67, 0.25);
}

body.page-contact .contact-page form:not(.contact-form130):not(.contact-confirm-actions__form) button[type="submit"]:hover {
    filter: brightness(1.03);
}

body.page-contact .contact-page form:not(.contact-form130):not(.contact-confirm-actions__form) button[type="submit"]:focus-visible {
    outline: 2rem solid var(--contact-key);
    outline-offset: 2rem;
}

/* エラー・セッション（通常は .contact-form130__alert、レガシー枠は .contact-page__alert） */
body.page-contact .contact-page > .contact-form130__alert,
body.page-contact .contact-page > .contact-page__alert {
    padding: 12rem 16rem;
    border-radius: 8rem;
    background: rgba(232, 0, 0, 0.06);
    border: 1px solid rgba(232, 0, 0, 0.35);
    color: #c62828;
}

body.page-contact .contact-page > .contact-form130__alert ul,
body.page-contact .contact-page > .contact-page__alert ul {
    margin: 0;
    padding-left: 20rem;
}

body.page-contact .contact-page #form_switcher,
body.page-contact .contact-page select[name="form"] {
    max-width: 100%;
}

body.page-contact {
    --cf130-neutral-02: #787878;
    --cf130-neutral-03: #cacaca;
    --cf130-bg-panel: #f5f2f0;
    --cf130-bg-panel-border: #ffffff;
    /* ラジオ／カタログカードの選択地。区分ラジオと統一して薄オレンジ(Light_Orange02 #FCE9DD)に。 */
    --cf130-bg-radio-off: #eae1e1;
}

body.page-contact .contact-form130 {
    display: flex;
    flex-direction: column;
    gap: 40rem;
    margin: 0;
    padding: 0;
}

body.page-contact .contact-form130__visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* セクション見出し（オレンジ100px + ライン） */
body.page-contact .contact-form130__block-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16rem;
    border-bottom: 1px solid var(--contact-line);
}

body.page-contact .contact-form130__block-title {
    margin: -2rem 0 0;
    font-weight: 700;
    font-size: 24rem;
    letter-spacing: 0.04em;
    line-height: 1.8;
    color: var(--contact-font-body);
}

body.page-contact .contact-form130__block-bar {
    display: flex;
    align-items: flex-end;
    align-self: stretch;
    width: 100%;
    gap: 0;
}

body.page-contact .contact-form130__block-bar-accent {
    width: 100rem;
    height: 2rem;
    flex-shrink: 0;
    background-color: var(--contact-key);
}

body.page-contact .contact-form130__block-bar-line {
    flex: 1;
    height: 1px;
    background-color: var(--contact-line);
}

/* パネル */
body.page-contact .contact-form130__panel {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 48rem 72rem;
    background-color: var(--cf130-bg-panel);
    border-radius: 32rem;
    border: 4rem solid var(--cf130-bg-panel-border);
    box-sizing: border-box;
}

body.page-contact .contact-form130__line {
    height: 1px;
    align-self: stretch;
    background-color: var(--contact-line);
    margin: 0;
}

body.page-contact .contact-form130__line--dots {
    height: auto;
    background: none;
    margin: 8rem 0 0;
}

body.page-contact .contact-form130__dot-line-img {
    display: block;
    height: auto;
}

/* 行：ラベル + 入力 */
body.page-contact .contact-form130__row {
    display: flex;
    align-items: flex-start;
    gap: 64rem;
    padding: 16rem 0;
}

body.page-contact .contact-form130__row--field {
    align-items: center;
}

body.page-contact .contact-form130__row--stack,
body.page-contact .contact-form130__row--file,
body.page-contact .contact-form130__row--address,
body.page-contact .contact-form130__row--twin,
body.page-contact .contact-form130__row--radios {
    align-items: flex-start;
}

body.page-contact .contact-form130__label-col {
    display: flex;
    align-items: center;
    gap: 8rem;
    flex: 0 0 200rem;
    max-width: 200rem;
    min-height: 48rem;
}

body.page-contact .contact-form130__label-col--top {
    align-items: center;
    padding-top: 0;
}

body.page-contact .contact-form130__marker {
    width: 8rem;
    height: 8rem;
    border-radius: 2rem;
    flex-shrink: 0;
    background: linear-gradient(90deg, #ff9143 0%, #ff6243 100%);
}

body.page-contact .contact-form130__label-text {
    font-weight: 700;
    font-size: 16rem;
    display: inline-flex;
    align-items: center;
    line-height: 24rem;
    color: var(--contact-font-body);
    white-space: nowrap;
}

body.page-contact .contact-form130__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 6rem;
    margin-left: 4rem;
    font-size: 10rem;
    font-weight: 700;
    line-height: 15rem;
    color: #fff;
    background-color: var(--contact-key);
    border-radius: 4rem;
}

body.page-contact .contact-form130__field-col {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8rem;
}

body.page-contact .contact-form130__select-wrap {
    position: relative;
    display: block;
    width: 100%;
    max-width: 720rem;
}

body.page-contact .contact-form130__native-select {
    width: 100%;
    height: 48rem;
    padding: 12rem 40rem 12rem 16rem;
    font-family: inherit;
    font-size: 14rem;
    line-height: 21rem;
    color: var(--contact-font-body);
    background-color: #fff;
    border: none;
    border-radius: 8rem;
    appearance: none;
    -webkit-appearance: none;
}

body.page-contact .contact-form130__native-select option {
    color: #333;
}

body.page-contact .contact-form130__native-select:invalid,
body.page-contact .contact-form130__native-select option[value=""] {
    color: var(--cf130-neutral-02);
}

body.page-contact .contact-form130__select-chevron {
    position: absolute;
    right: 16rem;
    top: 24rem;
    transform: translateY(-50%);
    pointer-events: none;
    display: flex;
    align-items: center;
}

body.page-contact .contact-form130__select-chevron--muted {
    opacity: 0.35;
}

body.page-contact .contact-form130__textarea {
    width: 100%;
    max-width: 720rem;
    min-height: 160rem;
    padding: 12rem 16rem;
    font-family: inherit;
    font-size: 14rem;
    line-height: 1.6;
    color: var(--contact-font-body);
    background-color: #fff;
    border: none;
    border-radius: 8rem;
    resize: vertical;
}

body.page-contact .contact-form130__textarea::placeholder {
    color: var(--cf130-neutral-03);
}

body.page-contact .contact-form130__input {
    width: 100%;
    max-width: 720rem;
    height: 48rem;
    padding: 12rem 16rem;
    font-family: inherit;
    font-size: 14rem;
    color: var(--contact-font-body);
    background-color: #fff;
    border: none;
    border-radius: 8rem;
    box-sizing: border-box;
}

body.page-contact .contact-form130__input::placeholder {
    color: var(--cf130-neutral-03);
}

/* __input-date は c-field type=date へ移行（field.css）。本ブロック撤去。 */

body.page-contact .contact-form130__input:focus-visible,
body.page-contact .contact-form130__textarea:focus-visible,
body.page-contact .contact-form130__native-select:focus-visible {
    /* c-field と整合: focus = Light_Orange01 */
    outline: 2rem solid var(--color-light-orange-01);
    outline-offset: 1px;
}

/* ファイル */
body.page-contact .contact-form130__field-col--file {
    max-width: 876rem;
}

/* file-row/file-btn/file-input/file-hint/file-note は c-field type=file へ移行（field.css）。本ブロック撤去。 */

/* メール横並び */
body.page-contact .contact-form130__field-col--twin {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8rem 16rem;
    max-width: 100%;
}

body.page-contact .contact-form130__twin-field {
    min-width: 0;
}

@media (max-width: 767.98px) {
    body.page-contact .contact-form130__field-col--twin {
        grid-template-columns: 1fr;
    }
}

/* 住所ブロック */
body.page-contact .contact-form130__address-line {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12rem 16rem;
    width: 100%;
}

/* __zip-prefix / __input--zip / __zip-btn は c-field type=zip へ移行（field.css）。本ブロック撤去。 */

body.page-contact .contact-form130__select-wrap--pref {
    max-width: 336rem;
}

/* ラジオ（カタログ送付）。ピル本体は共通 c-field__radio（components/field.css）を使用。 */
body.page-contact .contact-form130__radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 16rem;
    align-items: center;
}

/* 送信ブロック */
body.page-contact .contact-form130__submit-block {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 24rem;
    padding-top: 8rem;
}

body.page-contact .contact-form130__privacy {
    display: flex;
    align-items: flex-start;
    gap: 10rem;
    font-size: 14rem;
    line-height: 1.6;
    cursor: pointer;
}

body.page-contact .contact-form130__privacy input {
    margin-top: 4rem;
    accent-color: var(--contact-key);
}

/* その他パネル外：点線〜同意〜送信 */
body.page-contact .contact-form130__below-other-panel {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-form130__panel-tail {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
}

body.page-contact .contact-form130__privacy-center {
    margin-top: 56rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-form130__privacy-center-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16rem;
    padding: 0 8rem;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-form130__privacy-pill {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8rem;
    min-height: 44rem;
    padding: 12rem 20rem;
    background-color: var(--cf130-bg-radio-off);
    border: 2rem solid #fff;
    border-radius: 22rem;
    cursor: pointer;
    box-sizing: border-box;
    max-width: 100%;
}

body.page-contact .contact-form130__privacy-pill-box {
    position: relative;
    flex-shrink: 0;
    width: 16rem;
    height: 16rem;
}

body.page-contact .contact-form130__privacy-pill-input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
}

body.page-contact .contact-form130__privacy-pill-marker {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16rem;
    height: 16rem;
    background: #fff;
    border-radius: 2rem;
    box-sizing: border-box;
}

body.page-contact .contact-form130__privacy-pill-tick {
    display: block;
    opacity: 0;
    transition: opacity 0.15s ease;
}

body.page-contact .contact-form130__privacy-pill-input:checked + .contact-form130__privacy-pill-marker .contact-form130__privacy-pill-tick {
    opacity: 1;
}

body.page-contact .contact-form130__privacy-pill-input:focus-visible + .contact-form130__privacy-pill-marker {
    outline: 2rem solid var(--contact-key);
    outline-offset: 2rem;
}

body.page-contact .contact-form130__privacy-pill-label {
    font-weight: 700;
    font-size: 12rem;
    letter-spacing: 0.05em;
    color: var(--contact-font-body);
    line-height: 1.5;
    text-align: left;
}

body.page-contact .contact-form130__privacy-note-wrap {
    display: flex;
    align-items: flex-start;
    gap: 4rem;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    justify-content: center;
    box-sizing: border-box;
}

body.page-contact .contact-form130__privacy-note-mark {
    flex-shrink: 0;
    margin-top: -1px;
    font-weight: 400;
    font-size: 14rem;
    line-height: 21rem;
    color: #000;
}

body.page-contact .contact-form130__privacy-note {
    flex: 1;
    min-width: 0;
    margin: 0;
    max-width: 864rem;
    width: 100%;
    font-size: 14rem;
    line-height: 21rem;
    text-align: center;
    color: #000;
}

body.page-contact .contact-form130__submit-block--solo {
    margin-top: 24rem;
    padding-top: 0;
    align-items: center;
    gap: 0;
}

body.page-contact .contact-form130__submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 16rem;
    min-height: 56rem;
    padding: 16rem 20rem 16rem 40rem;
    width: auto;
    max-width: 100%;
    font-family: inherit;
    font-size: 16rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.05em;
    background-color: var(--contact-key);
    border: 2rem solid #fff;
    border-radius: 32rem;
    box-shadow: 0 2rem 12rem rgba(255, 98, 67, 0.35);
    cursor: pointer;
    box-sizing: border-box;
}

body.page-contact .contact-form130__submit-label {
    position: relative;
    margin-top: -1px;
}

body.page-contact .contact-form130__submit-icon {
    flex-shrink: 0;
    display: block;
    filter: brightness(0) invert(1);
}

body.page-contact .contact-form130__submit:hover {
    filter: brightness(1.06);
}

body.page-contact .contact-form130__submit:focus-visible {
    outline: 2rem solid var(--contact-key);
    outline-offset: 2rem;
}

/* 「その他」パネル */
body.page-contact .contact-form130__panel--other {
    gap: 24rem;
}

body.page-contact .contact-form130__catalog-extra {
    display: flex;
    flex-direction: column;
    gap: 24rem;
    width: 100%;
}

body.page-contact .contact-form130__nest {
    display: flex;
    flex-direction: column;
    gap: 16rem;
    padding-left: 8rem;
    align-self: stretch;
    width: 100%;
}

body.page-contact .contact-form130__nest-head {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8rem;
}

body.page-contact .contact-form130__nest-title {
    font-weight: 700;
    font-size: 15rem;
    line-height: 1.5;
    color: var(--contact-font-body);
}

body.page-contact .contact-form130__sep-line {
    align-self: stretch;
    width: 100%;
    height: 1px;
    background-color: var(--contact-line);
}

body.page-contact .contact-form130__catalog-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12rem;
    width: 100%;
    max-width: 884rem;
}

body.page-contact .contact-form130__catalog-card {
    display: flex;
    align-items: center;
    gap: 8rem;
    padding: 12rem 14rem 12rem 12rem;
    background-color: #fff;
    border-radius: 16rem;
    cursor: pointer;
    box-sizing: border-box;
    min-width: 0;
}

body.page-contact .contact-form130__catalog-card:has(.contact-form130__catalog-input:checked) {
    outline: 2rem solid var(--contact-key);
    outline-offset: 0;
}

body.page-contact .contact-form130__catalog-check {
    position: relative;
    flex-shrink: 0;
    width: 16rem;
    height: 16rem;
}

body.page-contact .contact-form130__catalog-input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    margin: 0;
}

body.page-contact .contact-form130__catalog-check-ui {
    display: block;
    width: 16rem;
    height: 16rem;
    border-radius: 2rem;
    background-color: var(--cf130-bg-panel);
    box-sizing: border-box;
    border: 1px solid var(--contact-line);
}

body.page-contact .contact-form130__catalog-input:checked + .contact-form130__catalog-check-ui {
    background-color: var(--contact-key);
    border-color: var(--contact-key);
}

body.page-contact .contact-form130__catalog-input:focus-visible + .contact-form130__catalog-check-ui {
    outline: 2rem solid var(--contact-key);
    outline-offset: 2rem;
}

body.page-contact .contact-form130__catalog-card-main {
    display: flex;
    flex: 1;
    min-width: 0;
    align-items: center;
    gap: 10rem;
}

body.page-contact .contact-form130__catalog-thumb {
    width: 90rem;
    height: 124rem;
    object-fit: cover;
    border-radius: 4rem;
    flex-shrink: 0;
}

body.page-contact .contact-form130__catalog-copy {
    flex: 1;
    min-width: 0;
    font-size: 14rem;
    line-height: 1.5;
    letter-spacing: 0.04em;
    color: var(--contact-font-body);
}

body.page-contact .contact-form130__catalog-name {
    font-weight: 700;
}

body.page-contact .contact-form130__radio-group--wrap {
    flex-direction: column;
    align-items: flex-start;
}

body.page-contact .contact-form130__field-col--shipping-only {
    max-width: 100%;
}

body.page-contact .contact-form130__nest--shipping {
    margin-top: 0;
}

@media (max-width: 900px) {
    body.page-contact .contact-form130__catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 520px) {
    body.page-contact .contact-form130__catalog-grid {
        grid-template-columns: minmax(0, 1fr);
    }
}

@media (max-width: 767.98px) {
    /* イントロ（狭い画面） */
    body.page-contact .contact-intro {
        padding-top: 0;
    }

    body.page-contact .contact-intro__frame {
        align-items: flex-start;
        gap: 24rem;
    }

    body.page-contact .contact-intro__heading-col {
        gap: 14rem;
    }

    body.page-contact .contact-intro__title-wrap {
        padding: 4rem 0 4rem 16rem;
    }

    body.page-contact .contact-intro__title {
        font-size: 24rem;
        letter-spacing: 0.04em;
        line-height: 43.2rem;
    }

    body.page-contact .contact-intro__lead-wrap {
        flex-direction: column;
        padding: 0 8rem;
        gap: 8rem;
    }

    body.page-contact .contact-intro__lead {
        line-height: 32rem;
        text-align: left;
    }

    /* contact-intro__faq の SP 調整は c-announce 側（announce.css のメディアクエリ）に統合済み */

    /* フォーム SP：枠外同意など */
    body.page-contact .contact-page {
        margin-top: 24rem;
        margin-bottom: 40rem;
    }

    body.page-contact .contact-form130__privacy-pill-label {
        white-space: normal;
    }

    body.page-contact .contact-form130__privacy-note-wrap {
        justify-content: flex-start;
    }

    body.page-contact .contact-form130__privacy-note {
        text-align: left;
    }
}

@media (max-width: 1023.98px) {
    body.page-contact .contact-form130__row {
        flex-direction: column;
        align-items: stretch;
        /* 縦積み時のラベル⇄入力の空きを詰める（ご予算等で広く見える指摘・No.29 の追加調整） */
        gap: 8rem;
    }

    body.page-contact .contact-form130__label-col,
    body.page-contact .contact-form130__label-col--top {
        /* 行が縦積みのとき 200px basis は「高さ」になりタイトル〜入力の間が空く */
        flex: 0 0 auto;
        max-width: none;
        padding-top: 0;
        /* PC で入力欄(48px)とラベルを縦中央に揃えるための min-height:48rem は、
           SP の縦積みではラベル行が 48rem の箱になりラベル⇄入力の間が広く空く（No.29）。
           縦積み時はラベル高さを内容なりにする。 */
        min-height: 0;
    }

    body.page-contact .contact-form130__label-text {
        white-space: normal;
    }

    body.page-contact .contact-page form:not(.contact-form130) input[type="text"],
    body.page-contact .contact-page form:not(.contact-form130) input[type="email"],
    body.page-contact .contact-page form:not(.contact-form130) input[type="tel"],
    body.page-contact .contact-page form:not(.contact-form130) input[type="number"],
    body.page-contact .contact-page form:not(.contact-form130) input[type="date"],
    body.page-contact .contact-page form:not(.contact-form130) textarea,
    body.page-contact .contact-page form:not(.contact-form130) select {
        max-width: 100%;
    }
}

/* フォーム SP（767px 以下） */
@media (max-width: 767.98px) {
    body.page-contact .contact-form130 {
        gap: 32rem;
    }

    body.page-contact .contact-form130__block-head {
        align-items: flex-start;
        align-self: stretch;
    }

    body.page-contact .contact-form130__block-title {
        font-size: 20rem;
        letter-spacing: 0.04em;
        line-height: 30rem;
        white-space: normal;
        text-align: center;
    }

    body.page-contact .contact-form130__block-bar {
        align-self: stretch;
    }

    body.page-contact .contact-form130__panel--inquiry {
        padding: 32rem 24rem;
        border-radius: 24rem;
    }

    body.page-contact .contact-form130__panel--person {
        padding: 24rem;
        border-radius: 16rem;
    }

    body.page-contact .contact-form130__panel--other {
        gap: 16rem;
        padding: 24rem;
        border-radius: 24rem;
    }

    body.page-contact .contact-form130__row {
        gap: 16rem;
        padding: 12rem 0;
    }

    body.page-contact .contact-form130__catalog-extra {
        gap: 16rem;
    }

    body.page-contact .contact-form130__nest {
        padding-left: 0;
    }

    body.page-contact .contact-form130__catalog-extra .contact-form130__nest,
    body.page-contact .contact-form130__nest--shipping {
        padding-left: 8rem;
        padding-right: 8rem;
    }

    body.page-contact .contact-form130__catalog-grid {
        grid-template-columns: minmax(0, 1fr);
        max-width: 100%;
    }

    body.page-contact .contact-form130__catalog-card {
        width: 100%;
        max-width: 100%;
        align-self: stretch;
    }

    body.page-contact .contact-form130__field-col,
    body.page-contact .contact-form130__field-col--twin {
        max-width: 100%;
    }

    /* 「その他」パネル（狭い画面） */
    body.page-contact .contact-form130__panel--other > .contact-form130__row:first-child .contact-form130__radio-group {
        flex-direction: column;
        align-items: flex-start;
        gap: 8rem;
    }

    body.page-contact .contact-form130__panel--other .contact-form130__catalog-extra > .contact-form130__row {
        gap: 24rem;
    }

    body.page-contact .contact-form130__panel--other .contact-form130__catalog-extra .contact-form130__radio-group--wrap {
        gap: 8rem;
    }

    body.page-contact .contact-form130__panel--other .contact-form130__catalog-extra > .contact-form130__nest:first-of-type {
        gap: 12rem;
    }

    body.page-contact .contact-form130__panel--other .contact-form130__nest-title {
        font-size: 14rem;
        line-height: 21rem;
        letter-spacing: 0;
    }

    body.page-contact .contact-form130__panel--other .contact-form130__line--dots {
        margin-top: 0;
        margin-bottom: -1px;
    }

    body.page-contact .contact-form130__catalog-card-main {
        min-height: 124rem;
        align-items: center;
        gap: 10rem;
    }

    body.page-contact .contact-form130__catalog-copy {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 0;
    }

    body.page-contact .contact-form130__catalog-name {
        letter-spacing: 0.08rem;
    }

    body.page-contact .contact-form130__catalog-sub {
        display: block;
        font-weight: 400;
        font-size: 14rem;
        line-height: 21rem;
        letter-spacing: 0.04em;
    }

    body.page-contact .contact-form130__catalog-line--bold {
        display: block;
        font-weight: 700;
        font-size: 14rem;
        line-height: 21rem;
        letter-spacing: 0.04em;
    }

    body.page-contact .contact-form130__nest--shipping .contact-form130__address-line:first-of-type {
        flex-wrap: wrap;
        gap: 12rem;
        align-items: center;
    }

    /* nest--shipping の旧zipルールは c-field type=zip + catalog 上書きで代替（field.css / 本ファイル下部の catalog overrides）。本ブロック撤去。 */

    body.page-contact .contact-form130__nest--shipping .contact-form130__select-wrap--pref {
        max-width: 100%;
        width: 100%;
    }
}

/* ================================================================
   カタログ請求フォーム固有スタイル（contact-form130--catalog）
   Figma: catalog-select-PC / selected = bg03 + white border
   ================================================================ */

/* カードの基本状態：白背景＋透明ボーダーで位置を確保 */
body.page-contact .contact-form130--catalog .contact-form130__catalog-card {
    border: 2rem solid transparent;
    transition: background-color 0.12s ease, border-color 0.12s ease;
}

/* 選択状態：ベージュ背景 + 白枠 + アウトライン無効化 */
body.page-contact .contact-form130--catalog .contact-form130__catalog-card:has(.contact-form130__catalog-input:checked) {
    background-color: rgba(234, 229, 225, 1);
    border-color: #ffffff;
    outline: none;
}

/* チェックボックスUI 非選択：薄ベージュ地・ボーダーなし */
body.page-contact .contact-form130--catalog .contact-form130__catalog-check-ui {
    background-color: rgba(245, 242, 240, 1);
    border: none;
}

/* チェックボックスUI 選択：白地にオレンジチェック */
body.page-contact .contact-form130--catalog .contact-form130__catalog-input:checked + .contact-form130__catalog-check-ui {
    background-color: #ffffff;
    border-color: #ffffff;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpath d='M1.5 5.5L4 8L8.5 2.5' stroke='%23ff6243' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 10rem 10rem;
}

/* ラジオピルは共通 c-field__radio（components/field.css）を使用。 */

/* メール確認欄：縦積みレイアウト（Figma: 確認欄はラベル列分インデント） */
body.page-contact .contact-form130--catalog .contact-form130__field-col--twin {
    display: flex;
    flex-direction: column;
    gap: 8rem;
    max-width: 100%;
}

@media (min-width: 1024px) {
    body.page-contact .contact-form130--catalog .contact-form130__field-col--twin > .contact-form130__twin-field + .contact-form130__twin-field {
        box-sizing: border-box;
    }
}

/* ================================================================
   製品・サービスのご提案 / クレームフォーム固有スタイル
   ================================================================ */

/* メール確認欄：縦積み + 確認欄はラベル列分インデント */
body.page-contact .contact-form130--products-services .contact-form130__field-col--twin,
body.page-contact .contact-form130--claim .contact-form130__field-col--twin {
    display: flex;
    flex-direction: column;
    gap: 8rem;
    max-width: 100%;
}

@media (min-width: 1024px) {
    body.page-contact .contact-form130--products-services .contact-form130__field-col--twin > .contact-form130__twin-field + .contact-form130__twin-field,
    body.page-contact .contact-form130--claim .contact-form130__field-col--twin > .contact-form130__twin-field + .contact-form130__twin-field {
        box-sizing: border-box;
    }
}

/* 採用エントリー：PCモック（基本情報パネル）に合わせた余白・メール列 */
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel--person,
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel--inquiry {
    gap: 24rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel--person > .contact-form130__row,
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel--inquiry > .contact-form130__row {
    padding-top: 0;
    padding-bottom: 0;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__field-col--recruit-email-stack {
    display: flex;
    flex-direction: column;
    gap: 8rem;
    max-width: 100%;
}

@media (min-width: 768px) {
    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__field-col--recruit-email-stack > .contact-form130__twin-field + .contact-form130__twin-field {
        box-sizing: border-box;
    }
}

@media (max-width: 767.98px) {
    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel--person {
        padding: 32rem 24rem;
        border-radius: 24rem;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__field-col--recruit-email-stack > .contact-form130__twin-field + .contact-form130__twin-field {
        padding-left: 0;
    }
}

/* 採用エントリー・応募内容（エントリーシート行・DLカード／モック vgnf1） */
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__label-col--recruit-sheet {
    align-items: flex-start;
    min-height: 0;
    padding-top: 4rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-sheet-label {
    display: flex;
    align-items: flex-start;
    gap: 8rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__label-text--multiline-br {
    white-space: normal;
    line-height: 24rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-sheet-label .contact-form130__marker {
    flex-shrink: 0;
    margin-top: 8rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__field-col--recruit-sheet {
    gap: 16rem;
}

/* __file-note--recruit-sheet は c-field type=file (note は c-field__file-note 内蔵) へ移行。本ブロック撤去。 */

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-card {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 24rem 32rem;
    width: 100%;
    max-width: 720rem;
    padding: 24rem 32rem;
    box-sizing: border-box;
    background-color: #eae9e1;
    border-radius: 16rem;
    border: 2rem solid #fff;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-card-main {
    flex: 1;
    min-width: min(100%, 240px);
    display: flex;
    flex-direction: column;
    gap: 4rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-card-title {
    margin: 0;
    font-weight: 700;
    font-size: 16rem;
    letter-spacing: 0.04em;
    line-height: 1.8;
    color: var(--contact-font-body);
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-card-lead {
    margin: 0;
    font-weight: 400;
    font-size: 14rem;
    letter-spacing: 0.04em;
    line-height: 1.8;
    color: var(--contact-font-body);
}

/* ダウンロードボタン本体は共通 c-button--download に委譲。ここは配置のみ。 */
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-btn {
    flex-shrink: 0;
}

@media (max-width: 767.98px) {
    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-card {
        padding: 20rem 16rem;
        gap: 20rem;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__recruit-download-btn {
        width: 100%;
        justify-content: center;
        padding: 0 24rem;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__row--recruit-sheet {
        flex-direction: column;
        gap: 16rem;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__label-col--recruit-sheet {
        padding-top: 0;
        max-width: 100%;
        flex-basis: auto;
    }
}

/* 採用エントリー・フォーム末尾（同意〜送信／モック 71l3Z） */
body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel-tail {
    align-items: center;
    gap: 40rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-center {
    margin-top: 0;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-center-inner {
    gap: 24rem;
    padding: 0 40rem;
    border-radius: 24rem;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-pill {
    min-height: 50rem;
    padding: 16rem 20rem;
    background-color: #fff;
    border: none;
    border-radius: 25rem;
    box-shadow: none;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-pill-marker {
    background-color: var(--cf130-bg-panel);
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-pill-label {
    font-size: 14rem;
    letter-spacing: 0.04em;
    line-height: normal;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-note-wrap {
    justify-content: center;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-note {
    flex: 0 1 auto;
    text-align: center;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__submit-block {
    padding-top: 0;
    align-items: center;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__submit-block--solo {
    margin-top: 0;
}

body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__submit {
    min-width: min(100%, 246px);
    justify-content: center;
    box-shadow: none;
}

@media (max-width: 767.98px) {
    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__panel-tail {
        gap: 32rem;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-pill {
        flex-wrap: wrap;
        justify-content: center;
        text-align: center;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-pill-label {
        text-align: center;
    }

    body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__submit {
        width: 100%;
        max-width: 320rem;
        padding: 16rem 20rem;
    }
}

/* メールマガジン：お申し込み内容パネル（イントロ直下・yMTeE／採用フォームと同系） */
body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__panel--person {
    gap: 24rem;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__panel--person > .contact-form130__row {
    padding-top: 0;
    padding-bottom: 0;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__field-col--magazine-email-stack {
    display: flex;
    flex-direction: column;
    gap: 8rem;
    max-width: 100%;
}

@media (min-width: 768px) {
    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__field-col--magazine-email-stack > .contact-form130__twin-field + .contact-form130__twin-field {
        box-sizing: border-box;
    }
}

@media (max-width: 767.98px) {
    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__panel--person {
        padding: 32rem 24rem;
        border-radius: 24rem;
    }

    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__field-col--magazine-email-stack > .contact-form130__twin-field + .contact-form130__twin-field {
        padding-left: 0;
    }
}

/* メールマガジン・フォーム末尾（同意〜送信／モック qvGXG＝採用 71l3Z と同型） */
body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__panel-tail {
    align-items: center;
    gap: 40rem;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-center {
    margin-top: 0;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-center-inner {
    gap: 24rem;
    padding: 0 40rem;
    border-radius: 24rem;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-pill {
    min-height: 50rem;
    padding: 16rem 20rem;
    background-color: #fff;
    border: none;
    border-radius: 25rem;
    box-shadow: none;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-pill-marker {
    background-color: var(--cf130-bg-panel);
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-pill-label {
    font-size: 14rem;
    letter-spacing: 0.04em;
    line-height: normal;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-note-wrap {
    justify-content: center;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-note {
    flex: 0 1 auto;
    text-align: center;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__submit-block {
    padding-top: 0;
    align-items: center;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__submit-block--solo {
    margin-top: 0;
}

body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__submit {
    min-width: min(100%, 246px);
    justify-content: center;
    box-shadow: none;
}

@media (max-width: 767.98px) {
    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__panel-tail {
        gap: 32rem;
    }

    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-pill {
        flex-wrap: wrap;
        justify-content: center;
        text-align: center;
    }

    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-pill-label {
        text-align: center;
    }

    body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__submit {
        width: 100%;
        max-width: 320rem;
        padding: 16rem 20rem;
    }
}

/* =========================================
   type="date" の標準カレンダーアイコン対策
   Chrome / Safari / Edge + Firefox 対応
========================================= */

body.page-contact .contact-form130__date-wrap {
    position: relative;
}

/* input-date / __date-picker-button は c-field type=date へ移行（field.css）。本ブロック撤去。 */

/* ================================================================
   カタログ請求フォーム：左ラベル / 右内容の2カラム
   renewal-subpage.css / 既存contact CSSの影響を上書き
================================================================ */

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__panel--other {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 32rem;
    width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 32rem;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row {
    display: grid;
    grid-template-columns: 200rem minmax(0, 1fr);
    column-gap: 64rem;
    row-gap: 12rem;
    align-items: start;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__row--catalog-send,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__row--catalog-shipping {
    align-items: center;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__label-col,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row > .contact-form130__label-col {
    grid-column: 1;
    width: 200rem;
    max-width: 200rem;
    min-width: 0;
    flex: none;
    min-height: 36rem;
    padding: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__field-col,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row > .contact-form130__field-col {
    grid-column: 2;
    width: 100%;
    max-width: none;
    min-width: 0;
    flex: none;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__label-text,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__badge,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-name,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-sub,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-line {
    writing-mode: horizontal-tb;
    text-orientation: mixed;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__radio-group {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 16rem;
    width: 100%;
    max-width: 100%;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__field-col--catalog-select {
    max-width: 884rem;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12rem;
    width: 100%;
    max-width: 884rem;
    margin: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8rem;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    padding: 12rem 14rem 12rem 12rem;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-check {
    flex: 0 0 16rem;
    width: 16rem;
    height: 16rem;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-card-main {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10rem;
    flex: 1 1 auto;
    min-width: 0;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-thumb {
    flex: 0 0 90rem;
    width: 90rem;
    height: 124rem;
    object-fit: cover;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    flex: 1 1 auto;
    min-width: 0;
    font-size: 14rem;
    line-height: 1.5;
    word-break: normal;
    overflow-wrap: anywhere;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__field-col--catalog-address {
    max-width: 720rem;
    gap: 12rem;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__field-col--catalog-address .contact-form130__input,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__field-col--catalog-address .contact-form130__select-wrap {
    width: 100%;
    max-width: 100%;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__field-col--catalog-address .contact-form130__select-wrap--pref {
    max-width: 336rem;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__sep-line {
    width: 100%;
    height: 1px;
    margin: 8rem 0;
    background-color: var(--contact-line);
}

@media (max-width: 1023.98px) {
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row,
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 12rem;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__label-col,
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row > .contact-form130__label-col {
        width: 100%;
        max-width: none;
        min-height: 0;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__field-col,
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row > .contact-form130__field-col {
        width: 100%;
        max-width: 100%;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 100%;
    }
}

@media (max-width: 520px) {
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
        grid-template-columns: 1fr;
    }
}

/* catalog form の旧 __address-line--zip 上書き Block A は本ファイル下部の `.c-field--zip` 上書きへ統合（重複・撤去）。 */

/* ================================================================
   カタログ請求フォーム：左は大項目、右に小項目をネスト
================================================================ */

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout {
    display: flex;
    flex-direction: column;
    gap: 32rem;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* 左に出す大項目はこの2行だけ */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row {
    display: grid;
    grid-template-columns: 200rem minmax(0, 1fr);
    column-gap: 64rem;
    align-items: start;
    width: 100%;
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__label-col {
    grid-column: 1;
    width: 200rem;
    max-width: 200rem;
    flex: none;
    min-height: 36rem;
    padding: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__field-col {
    grid-column: 2;
    width: 100%;
    max-width: none;
    min-width: 0;
    flex: none;
    box-sizing: border-box;
}

/* 右カラム内の小項目 */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest {
    display: flex;
    flex-direction: column;
    gap: 16rem;
    width: 100%;
    max-width: 884rem;
    margin-top: 16rem;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest--shipping {
    max-width: 720rem;
}

/* 右カラム内の見出し：カタログの選択 / 送付先 */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest .contact-form130__nest-head {
    display: inline-flex;
    align-items: center;
    gap: 8rem;
    width: fit-content;
    max-width: 100%;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest .contact-form130__nest-title {
    font-weight: 700;
    font-size: 15rem;
    line-height: 1.5;
    color: var(--contact-font-body);
    white-space: nowrap;
}

/* ラジオ */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__radio-group {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 16rem;
    width: 100%;
}

/* カタログ一覧 */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12rem;
    width: 100%;
    max-width: 884rem;
    margin: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-card {
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-card-main {
    min-width: 0;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-copy {
    min-width: 0;
    word-break: normal;
    overflow-wrap: anywhere;
}

/* 送付先住所 */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest--shipping .contact-form130__input,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest--shipping .contact-form130__select-wrap {
    width: 100%;
    max-width: 100%;
}

body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest--shipping .contact-form130__select-wrap--pref {
    max-width: 336rem;
}

/* 郵便番号 + 自動入力ボタンだけ横並び（c-field type=zip 用に書き換え）*/
body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-row {
    flex-wrap: nowrap;
    gap: 12rem;
}

body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-prefix {
    flex: 0 0 auto;
}

body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-input {
    flex: 0 0 160rem;
    width: 160rem;
    max-width: 116rem;
}

body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-btn {
    flex: 0 0 auto;
    width: auto;
    margin-top: 0;
    white-space: nowrap;
}

/* SP */
@media (max-width: 1023.98px) {
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        gap: 12rem;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row > .contact-form130__label-col {
        width: 100%;
        max-width: none;
        min-height: 0;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        max-width: 100%;
    }

    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest,
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__right-nest--shipping {
        max-width: 100%;
    }
}

@media (max-width: 520px) {
    body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-grid {
        grid-template-columns: 1fr;
    }

    body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-row {
        flex-wrap: wrap;
    }

    body.page-contact .contact-form130.contact-form130--catalog .c-field--zip .c-field__zip-btn {
        flex-basis: 100%;
        width: 100%;
    }
}

/* ================================================================
   お問い合わせフォーム：項目別エラー表示
================================================================ */

body.page-contact .contact-form130__error-message {
    margin: 4rem 0 0;
    font-size: 12rem;
    font-weight: 500;
    line-height: 1.5;
    color: var(--color-alert); /* c-field と整合: Alert_Error #E80000 */
}

body.page-contact .contact-form130__input,
body.page-contact .contact-form130__textarea,
body.page-contact .contact-form130__native-select {
    box-sizing: border-box;
    border: 1px solid transparent;
}

body.page-contact .contact-form130__input.is-invalid,
body.page-contact .contact-form130__textarea.is-invalid,
body.page-contact .contact-form130__native-select.is-invalid {
    border-color: var(--color-alert);
    box-shadow: 0 0 0 1px rgba(232, 0, 0, 0.12);
}

body.page-contact .contact-form130__select-wrap:has(.contact-form130__native-select.is-invalid) {
    border-radius: 8rem;
}

body.page-contact .contact-form130__radio-group.is-invalid {
    padding: 6rem;
    border: 1px solid var(--color-alert);
    border-radius: 12rem;
}

body.page-contact .contact-form130__catalog-grid.is-invalid {
    padding: 8rem;
    border: 1px solid var(--color-alert);
    border-radius: 16rem;
}

/* file-row/file-btn の is-invalid 状態は c-field type=file (is-error) で代替。本ブロック撤去。 */

body.page-contact .contact-form130__input.is-invalid:focus-visible,
body.page-contact .contact-form130__textarea.is-invalid:focus-visible,
body.page-contact .contact-form130__native-select.is-invalid:focus-visible {
    outline: 2rem solid rgba(232, 0, 0, 0.35);
    outline-offset: 1px;
}

/* 旧 __address-line--zip グローバル上書きは c-field type=zip 既定 + catalog 上書きで代替。本ブロック撤去。 */

@media (max-width: 767.98px) {
    /* 通常お問い合わせフォーム・製品問い合わせ入力画面のカタログ選択 */
    body.page-contact .contact-form130__catalog-grid,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 12rem;
        width: 100%;
        max-width: 100%;
    }

    /* 入力画面のカタログカード */
    body.page-contact .contact-form130__catalog-card,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-card {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 8rem;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        padding: 12rem 14rem 12rem 12rem;
        box-sizing: border-box;
        border-radius: 16rem;
        background-color: #fff;
    }

    body.page-contact .contact-form130__catalog-check,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-check {
        flex: 0 0 16rem;
        width: 16rem;
        height: 16rem;
    }

    body.page-contact .contact-form130__catalog-card-main,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-card-main {
        display: flex;
        flex-direction: row;
        align-items: center;
        gap: 10rem;
        flex: 1 1 auto;
        min-width: 0;
    }

    body.page-contact .contact-form130__catalog-thumb,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-thumb {
        flex: 0 0 90rem;
        width: 90rem;
        height: 124rem;
        object-fit: cover;
        border-radius: 4rem;
    }

    body.page-contact .contact-form130__catalog-copy,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-copy {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        flex: 1 1 auto;
        min-width: 0;
        word-break: normal;
        overflow-wrap: anywhere;
    }

    body.page-contact .contact-form130__catalog-name,
    body.page-contact .contact-form130__catalog-sub,
    body.page-contact .contact-form130__catalog-line,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-name,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-sub,
    body.page-products-inquiry-input.page-contact .contact-form130__catalog-line {
        writing-mode: horizontal-tb;
        text-orientation: mixed;
    }

    .contact-form130__line--dots img {
        width: 100%;
    }
}


/* clamp一本化: SP帯(<=1023.98px)のSP値オーバーライド（旧clamp最小値＝設計SP値） */
@media (max-width: 1023.98px) {
  body.page-contact .contact-confirm-summary__panel {
    padding: 24rem 20rem;
  }
  body.page-contact .contact-confirm-summary__row {
    gap: 24rem;
  }
  /* パネル */
body.page-contact .contact-form130__panel {
    padding: 24rem 20rem;
  }
  /* 行：ラベル + 入力 */
body.page-contact .contact-form130__row {
    gap: 24rem;
  }
  body.page-contact.page-recruit-entry .contact-form130--recruit-entry .contact-form130__privacy-center-inner {
    padding: 0 16rem;
  }
  body.page-contact.page-contact-magazine .contact-form130--magazine .contact-form130__privacy-center-inner {
    padding: 0 16rem;
  }
  body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row,
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-extra-panel > .contact-form130__row {
    column-gap: 24rem;
  }
  /* 左に出す大項目はこの2行だけ */
body.page-contact .contact-form130.contact-form130--catalog .contact-form130__catalog-layout > .contact-form130__row {
    column-gap: 24rem;
  }
}
