@charset "utf-8";

/* ========================================
// foundation - 変数定義・基本設定
// ======================================== */
/* variable - 変数定義 */
:root {
    /* root-size */
    font-size: min(1.25vw, 16px);

    /* color */
    --color--black-primary: #000000;
    --color--black-secondary: #3C3C3C;
    --color--black-tertiary: #777777;

    --color--gray-primary: #9A9A9A;
    --color--gray-secondary: #E1E1E1;

    --color--white-primary: #FFFFFF;
    --color--white-secondary: #F6F5F5;

    --color--orange-primary: #FF7500;
    --color--orange-secondary: #FF9D00;
    --color--orange-tertiary: #FFEEDE;

    --color--yellow-primary: #F7D72F;
    --color--yellow-secondary: #FFF7CC;
    --color--yellow-tertiary: #FFFCED;

    --color--green-primary: #00BCB0;
    --color--green-secondary: #00DACD;

    --color--pink--primary: #F35660;

    --color--base-primary: var(--color--white-primary);
    --color--base-secondary: var(--color--yellow-tertiary);
    --color--base-tertiary: var(--color--yellow-secondary);

    --color--font-primary: var(--color--black-secondary);

    --color--main-primary: var(--color--orange-primary);
    --color--main-secondary: var(--color--yellow-primary);

    --color--accent-primary: linear-gradient(to right, var(--color--green-primary), var(--color--green-secondary));

    /* header-size */
    --header-size--medium: 6.75rem;

    /* section-size */
    --section-size--medium: 6.25rem;

    /* container-rate */
    --container-rate--small: 62.5%;
    --container-rate--medium: 78.125%;
    --container-rate--large: 90%;

    /* container-size */
    --container-size--small: 50rem;
    --container-size--medium: 62.5rem;
    --container-size--large: 72rem;

    /* font-family */
    --font-family--jp: YakuHanJP, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'Noto Sans JP', Meiryo, sans-serif;
    --font-family--en: 'DIN Alternate', Arial, sans-serif;

    /* icon */
    --icon--page: url('../images/icon_page.svg');
    --icon--quotation: url('../images/icon_quotation.svg');
    --icon--arrow: url('../images/icon_arrow.svg');
    --icon--link-external: url('../images/icon_link-external.svg');
    --icon--tel: url('../images/icon_tel.svg');
}

@media (width < 768px) {
    :root {
        font-size: max(12px, 4.26666666vw);
        --header-size--medium: 2.625rem;
        --section-size--medium: 3.125rem;
        --container-rate--small: 90.66666666%;
        --container-rate--medium: 90.66666666%;
        --container-rate--large: 90.66666666%;
        --container-size--small: 21.25rem;
        --container-size--medium: 21.25rem;
        --container-size--large: 21.25rem;
    }
}

/* base - 基本設定 */
html,
body {
    color: var(--color--font-primary);
    font-family: var(--font-family--jp);
    -webkit-font-smoothing: antialiased;
    font-weight: 700;
    letter-spacing: .03em;
    line-height: 1.5;
    overflow-x: clip;
}

img {
    block-size: auto;
    inline-size: 100%;
}

a {
    color: var(--color--green-primary);
    text-decoration: underline;
    text-underline-offset: .125rem;
}

a[target="_blank"] {
    &::after {
        aspect-ratio: 1;
        background-color: var(--color--green-primary);
        content: '';
        display: inline-block;
        inline-size: 1.25rem;
        mask-image: var(--icon--link-external);
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: contain;
        vertical-align: text-bottom;
    }
}

@media (any-hover: hover) {
    a:hover {
        text-decoration: none;
    }
}

strong {
    font-weight: unset;
}

.scroll-hint-icon {
    z-index: 100;
}

/* ========================================
// layout - レイアウトの設定
// ======================================== */
/* section - セクション */
.l-section {
    padding-block: var(--section-size--medium);
}

.l-section__header {
    display: grid;
    row-gap: 2.5rem;
}

@media (width < 768px) {
    .l-section__header {
        row-gap: 1.875rem;
    }
}

.l-section__body {
    display: grid;
    margin-block-start: 3.75rem;
    row-gap: 3.75rem;
}

@media (width < 768px) {
    .l-section__body {
        margin-block-start: 2.5rem;
        row-gap: 2.5rem;
    }
}

.l-section__footer {
    margin-block-start: 3.125rem;
}

@media (width < 768px) {
    .l-section__footer {
        margin-block-start: 2.5rem;
    }
}

/* container - コンテナ */
.l-container {
    inline-size: var(--container-rate--medium);
    margin-inline: auto;
    max-inline-size: var(--container-size--medium);
}

.l-container.-small {
    inline-size: var(--container-rate--small);
    max-inline-size: var(--container-size--small);
}

.l-container.-large {
    inline-size: var(--container-rate--large);
    max-inline-size: var(--container-size--large);
}

/* header - ヘッダー */
.l-header {
    background-color: var(--color--base-primary);
    block-size: var(--header-size--medium);
    box-shadow: 0 .25rem .25rem color-mix(in srgb, var(--color--black-primary) 10%, transparent);
    inline-size: 100%;
    inset-block-start: 0;
    inset-inline-start: 0;
    position: fixed;
    z-index: 1000;
}

.l-header__container {
    align-items: center;
    block-size: 100%;
    display: flex;
    justify-content: space-between;
}

.l-header__logo-link {
    align-items: center;
    display: flex;
    padding-block-end: .5rem;
    transition: .15s ease opacity;

    img {
        inline-size: 20rem;
    }
}

@media (width < 768px) {
    .l-header__logo-link {
        padding-block-end: .125rem;

        img {
            inline-size: 10rem;
        }
    }
}

@media (any-hover: hover) {
    .l-header__logo-link:hover {
        opacity: 50%;
    }
}

.l-header__nav {
    align-items: center;
    column-gap: 1.625rem;
    display: flex;
}

@media (width < 768px) {
    .l-header__button {
        display: none;
    }
}

/* main - メインコンテンツ */
.l-main {
    padding-block-start: var(--header-size--medium);
}

/* footer - フッター */
.l-footer {
    padding-block: 2.25rem;
}

@media (width < 768px) {
    .l-footer {
        padding-block: 3.125rem;
    }
}

.l-footer__container {
    display: flex;
    justify-content: space-between;

    &::before {
        background-color: var(--color--gray-secondary);
        content: '';
        display: flex;
        inline-size: .125rem;
        order: 2;
    }
}

@media (width < 768px) {
    .l-footer__container {
        flex-direction: column-reverse;
        row-gap: 1.25rem;

        &::before {
            block-size: .0625rem;
            inline-size: 100%;
        }
    }
}

.l-footer__company {
    display: flex;
    flex-direction: column;
    order: 1;
    row-gap: .5rem;
}

.l-footer__company-name {
    font-size: 1.5rem;
    letter-spacing: 0;
}

@media (width < 768px) {
    .l-footer__company-name {
        font-size: 1rem;
        text-align: center;
    }
}

.l-footer__company-address {
    letter-spacing: 0;
}

@media (width < 768px) {
    .l-footer__company-address {
        font-size: .875rem;
        font-weight: 400;
        text-align: center;
    }
}

.l-footer__service {
    align-items: center;
    column-gap: 1.25rem;
    display: flex;
    order: 3;
}

@media (width < 768px) {
    .l-footer__service {
        flex-direction: column;
        row-gap: .875rem;
    }
}

.l-footer__service-logo {
    display: grid;
    padding-block-end: .5rem;

    img {
        inline-size: 20rem;
    }
}

@media (width < 768px) {
    .l-footer__service-logo {
        padding-block-end: 0;

        img {
            inline-size: 12.5rem;
        }
    }
}

.l-footer__service-description {
    font-size: .875rem;
    letter-spacing: 0;
}

@media (width < 768px) {
    .l-footer__service-description {
        font-weight: 400;
        text-align: center;
    }
}

/* ========================================
// component - 共通パーツの設定
// ======================================== */
/* heading - セクション見出し */
.c-heading__lv2 {
    display: grid;
    font-size: 2.25rem;
    justify-items: center;
    row-gap: 1rem;
    text-align: center;

    &::before {
        aspect-ratio: 1;
        background-color: var(--color--main-primary);
        background-image: var(--icon--page);
        background-position: center;
        background-repeat: no-repeat;
        background-size: 2.5rem;
        border-radius: 50%;
        content: '';
        display: block;
        inline-size: 3.5rem;
    }

    strong {
        color: var(--color--main-primary);
        font-size: 2.5rem;
    }
}

@media (width < 768px) {
    .c-heading__lv2 {
        font-size: 1.5rem;
        line-height: 1.375;
        row-gap: .5rem;

        &::before {
            background-size: 1.75rem;
            inline-size: 2.5rem;
        }

        strong {
            font-size: unset;
        }
    }
}

/* lead - セクションリード文 */
.c-lead {
    font-size: 1.125rem;
    line-height: 1.75;
    text-align: center;

    strong {
        color: var(--color--main-primary);
    }
}

@media (width < 768px) {
    .c-lead {
        font-size: 1rem;
        line-height: 1.5;
    }
}

/* button - ボタン */
.c-button {
    align-items: center;
    background-image: linear-gradient(to right, #ff7500, #f88118);
    block-size: 3.625rem;
    border-radius: calc(3.625rem / 2);
    box-shadow: 0 .125rem .125rem color-mix(in srgb, #ff7500 80%, transparent);
    color: var(--color--base-primary);
    display: flex;
    font-size: 1.125rem;
    inline-size: 16.75rem;
    justify-content: center;
    letter-spacing: .18em;
    padding-block: .5rem;
    padding-inline: calc(1rem + .5rem) .5rem;
    position: relative;
    text-decoration: none;

    &::before {
        block-size: calc(100% - .375rem);
        border: solid .125rem var(--color--base-primary);
        border-radius: inherit;
        content: '';
        inline-size: calc(100% - .375rem);
        inset-block-start: 50%;
        inset-inline-start: 50%;
        position: absolute;
        translate: -50% -50%;
        z-index: 1;
    }

    &>* {
        position: relative;
        z-index: 2;
    }

    span {
        align-items: center;
        column-gap: 1.5rem;
        display: flex;

        &::after {
            aspect-ratio: 1;
            background-color: var(--color--base-primary);
            content: '';
            display: inline-block;
            flex-shrink: 0;
            inline-size: 1.5rem;
            mask-image: var(--icon--arrow);
            mask-position: center;
            mask-repeat: no-repeat;
            mask-size: contain;
        }
    }
}

@media (any-hover: hover) {
    .c-button:hover {
        background-image: linear-gradient(to right, #b35300, #793800);
        box-shadow: 0 .125rem .125rem color-mix(in srgb, #ff7500 25%, transparent);
    }
}

@media (768px <=width) {
    .c-button.-large {
        block-size: 6.5rem;
        border-radius: calc(6.5rem / 2);
        box-shadow: 0 .25rem .25rem color-mix(in srgb, #ff7500 80%, transparent);
        font-size: 2.25rem;
        inline-size: 30.875rem;
        padding-inline: calc(1.875rem + .5rem) .5rem;

        &::before {
            block-size: calc(100% - .75rem);
            inline-size: calc(100% - .75rem);
        }

        span {
            column-gap: 2.5rem;

            &::after {
                inline-size: 2.5rem;
            }
        }
    }
}

@media (width < 768px) {
    .c-button.-large {
        inline-size: 100%;
    }
}

@media (any-hover: hover) {
    .c-button.-large:hover {
        box-shadow: 0 .25rem .25rem color-mix(in srgb, #008F87 25%, transparent);
    }
}

.c-button.-campaign {
    block-size: 4rem;
    border-radius: calc(4rem / 2);
    box-shadow: unset;
    font-size: 1.375rem;
    inline-size: 100%;
    letter-spacing: .05em;

    &::before {
        content: none;
    }

    span {
        column-gap: 1rem;

        &::after {
            inline-size: 1.75rem;
        }
    }
}

@media (width < 768px) {
    .c-button.-campaign {
        block-size: 3rem;
        font-size: 1rem;

        span {
            &::after {
                inline-size: 1.25rem;
            }
        }
    }
}

@media (any-hover: hover) {
    .c-button.-campaign:hover {
        box-shadow: unset;
    }
}

/* tel - 電話リンク */
.c-tel {
    inline-size: fit-content;
    text-align: center;
}

.c-tel__copy {
    font-size: 1.375rem;
    font-weight: 600;
    letter-spacing: 0;
}

@media (width < 768px) {
    .c-tel__copy {
        font-size: 12px;
        width: 100%;
        text-align: center;
    }
}

.c-tel__link {
    align-items: center;
    color: var(--color--main-primary);
    column-gap: .25rem;
    display: flex;
    font-size: 2.1875rem;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1.25;
    text-decoration: none;

    &::before {
        aspect-ratio: 1;
        background-color: var(--color--main-primary);
        content: '';
        display: inline-block;
        flex-shrink: 0;
        inline-size: 2.875rem;
        mask-image: var(--icon--tel);
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: contain;
    }
}

@media (width < 768px) {
    .c-tel__link {
        font-size: .75rem;
        line-height: 1.5;
        justify-content: center;

        &::before {
            inline-size: 1rem;
        }
    }
}

.c-tel.-large {
    .c-tel__copy {
        color: var(--color--base-primary);
        font-size: 1.875rem;
        letter-spacing: .05em;
        line-height: 1.125;
    }

    .c-tel__link {
        color: var(--color--base-primary);
        column-gap: .75rem;
        font-size: 2.75rem;

        &::before {
            background-color: var(--color--base-primary);
            inline-size: 3.25rem;
        }
    }
}

@media (width < 768px) {
    .c-tel.-large {
        .c-tel__copy {
            display: block;
            font-size: 1.375rem;
            letter-spacing: 0;
        }

        .c-tel__link {
            column-gap: .5rem;
            font-size: 1.875rem;
            letter-spacing: .03em;

            &::before {
                inline-size: 2rem;
            }
        }
    }
}

/* action - CTAセクション */
.c-action {
    background-color: var(--color--main-primary);
    padding-block: 3.25rem 2.75rem;
}

@media (768px <=width) {
    .c-action__container {
        display: grid;
        gap: 2.375rem 1.25rem;
        grid-template-columns: 1fr auto;
        position: relative;
    }

    .c-action__balloon {
        align-items: center;
        aspect-ratio: 1;
        background-color: var(--color--base-primary);
        border: solid .75rem var(--color--main-secondary);
        border-radius: 50%;
        display: flex;
        inline-size: 12.5rem;
        inset-block-start: calc((3.25rem + 2.75rem) * -1);
        inset-inline-start: -3.875rem;
        justify-content: center;
        position: absolute;
        z-index: 2;

        &::before {
            aspect-ratio: 1;
            border: solid .375rem var(--color--main-primary);
            border-radius: inherit;
            content: '';
            inline-size: 100%;
            inset-block-start: 0;
            inset-inline-start: 0;
            position: absolute;
            z-index: 1;
        }
    }

    .c-action__balloon-copy {
        font-size: 2rem;
        line-height: 1.125;
        padding-block-start: .125rem;
        position: relative;
        text-align: center;
        z-index: 2;

        &>strong {
            color: var(--color--main-primary);
            font-size: 3rem;
        }
    }

    .c-action__title {
        align-items: baseline;
        background-color: var(--color--base-primary);
        border-radius: .5rem;
        column-gap: .25rem;
        display: flex;
        font-size: 2.25rem;
        grid-column: 1 / 3;
        justify-content: center;
        line-height: 1;
        padding-block: .625rem .875rem;
        padding-inline-start: 8rem;
    }

    .c-action__title-main {
        align-items: baseline;
        display: inline-flex;

        strong {
            align-items: baseline;
            background-image:
                radial-gradient(circle at calc(100% - .3125rem) calc(100% - .3125rem), var(--color--main-secondary) .3125rem, transparent .3125rem),
                radial-gradient(circle at .3125rem calc(100% - .3125rem), var(--color--main-secondary) .3125rem, transparent .3125rem),
                linear-gradient(to bottom, var(--color--base-primary) calc(100% - .625rem), transparent calc(100% - .625rem)),
                linear-gradient(to right, transparent .3125rem, var(--color--main-secondary) .3125rem, var(--color--main-secondary) calc(100% - .3125rem), transparent calc(100% - .3125rem));
            color: var(--color--main-primary);
            column-gap: .25rem;
            display: inline-flex;
            font-size: 2.5rem;

            span {
                font-size: 3.5rem;
            }
        }
    }
}

@media (width < 768px) {
    .c-action__balloon {
        background-color: var(--color--base-primary);
        border: solid .375rem var(--color--main-secondary);
        border-radius: 1rem;
        padding-block: .25rem;
        padding-inline: .25rem;
        position: relative;
        text-align: center;

        &::before {
            block-size: 100%;
            border: solid .25rem var(--color--main-primary);
            border-radius: calc(1rem - .375rem);
            content: '';
            inline-size: 100%;
            inset-block-start: 0;
            inset-inline-start: 0;
            position: absolute;
            z-index: 1;
        }

        &>* {
            position: relative;
            z-index: 2;
        }
    }

    ::-webkit-full-page-media,
    :future,
    :root .c-action__balloon {
        padding-block: .0625rem .375rem;
    }

    .c-action__balloon-copy {
        font-size: 2rem;
        line-height: 1.125;
        text-align: center;

        &>strong {
            color: var(--color--main-primary);
            font-size: 2.5rem;
        }
    }

    .c-action__title {
        align-items: center;
        color: var(--color--base-primary);
        display: flex;
        flex-direction: column;
        letter-spacing: 0;
        line-height: 1.375;
        margin-block-start: 1rem;
        row-gap: .125rem;
        text-align: center;
    }

    .c-action__title-sub {
        background-image:
            radial-gradient(circle at calc(100% - .1875rem) calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
            radial-gradient(circle at .1875rem calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
            linear-gradient(to bottom, var(--color--main-primary) calc(100% - .375rem), transparent calc(100% - .375rem)),
            linear-gradient(to right, transparent .1875rem, var(--color--main-secondary) .1875rem, var(--color--main-secondary) calc(100% - .1875rem), transparent calc(100% - .1875rem));
        box-decoration-break: clone;
        -webkit-box-decoration-break: clone;
        font-size: 2.25rem;
    }

    .c-action__title-main {
        align-items: center;
        display: inline-flex;
        flex-direction: column;
        font-size: 2.5rem;
        row-gap: .125rem;

        &>strong {
            background-image:
                radial-gradient(circle at calc(100% - .1875rem) calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
                radial-gradient(circle at .1875rem calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
                linear-gradient(to bottom, var(--color--main-primary) calc(100% - .375rem), transparent calc(100% - .375rem)),
                linear-gradient(to right, transparent .1875rem, var(--color--main-secondary) .1875rem, var(--color--main-secondary) calc(100% - .1875rem), transparent calc(100% - .1875rem));
            box-decoration-break: clone;
            -webkit-box-decoration-break: clone;
            font-size: inherit;

            &>span {
                font-size: 3.5rem;
                line-height: 1;
            }
        }

        &>span {
            background-image:
                radial-gradient(circle at calc(100% - .1875rem) calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
                radial-gradient(circle at .1875rem calc(100% - .1875rem), var(--color--main-secondary) .1875rem, transparent .1875rem),
                linear-gradient(to bottom, var(--color--main-primary) calc(100% - .375rem), transparent calc(100% - .375rem)),
                linear-gradient(to right, transparent .1875rem, var(--color--main-secondary) .1875rem, var(--color--main-secondary) calc(100% - .1875rem), transparent calc(100% - .1875rem));
            box-decoration-break: clone;
            -webkit-box-decoration-break: clone;
        }
    }
}

.c-action__tel {
    display: grid;
    justify-items: center;
    row-gap: .5rem;
}

.c-action__tel-list {
    display: flex;
    gap: .375rem;
    inline-size: 100%;
    justify-content: space-between;
}

.c-action__tel-item {
    background-color: var(--color--main-secondary);
    border-radius: calc(1.875rem / 2);
    flex-grow: 1;
    font-size: 1.125rem;
    letter-spacing: 0;
    padding-block: .125rem .0625rem;
    text-align: center;
}

.c-action__button {
    margin-block-start: auto;
}

@media (width < 768px) {
    .c-action {
        padding-block: 1.875rem 3.125rem;
    }

    .c-action__container {
        position: relative;
    }

    .c-action__tel {
        margin-block-start: 1.5rem;
        row-gap: .25rem;
    }

    .c-action__tel-item {
        font-size: .75rem;
        padding-block: .0625rem;
    }

    .c-action__button {
        margin-block-start: 1.875rem;
    }
}

/* contact-form - フォーム */
.c-contact-form {
    background-color: var(--color--base-primary);
    border-radius: .5rem;
    box-shadow: 0 .25rem 1rem color-mix(in srgb, var(--color--black-primary) 8%, transparent);
    display: grid;
    grid-template-rows: auto 1fr;
    padding-block: 2.5rem 3rem;
    padding-inline: 3rem;
    row-gap: 1.5rem;
}

@media (width < 768px) {
    .c-contact-form {
        border-radius: .375rem;
        padding-block: 2rem;
        padding-inline: 1.25rem;
    }
}

.c-contact-form__title {
    display: grid;
    font-weight: 600;
    row-gap: .25rem;
    text-align: center;
}

.c-contact-form__title-sub {
    align-items: center;
    color: var(--color--accent-primary);
    column-gap: .5rem;
    display: flex;
    justify-content: center;

    &::before,
    &::after {
        background-color: var(--color--accent-primary);
        block-size: 1rem;
        content: '';
        inline-size: .0625rem;
        translate: 0 .0625rem;
    }

    &::before {
        rotate: -30deg;
    }

    &::after {
        rotate: 30deg;
    }
}

@media (width < 768px) {
    .c-contact-form__title-sub {
        font-size: .875rem;
    }
}

.c-contact-form__title-main {
    font-size: 1.75rem;
    text-decoration: underline;
    text-decoration-color: var(--color--utility-marker);
    text-decoration-skip-ink: none;
    text-decoration-thickness: .75rem;
    text-underline-offset: -.25rem;
}

@media (width < 768px) {
    .c-contact-form__title-main {
        font-size: 1.5rem;
        text-decoration-thickness: .5rem;
        text-underline-offset: -.125rem;
    }
}

.c-contact-form__group {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    margin-block-end: auto;
    gap: 1.75rem 2.5rem;

    &>* {
        grid-column: span 2;
    }

    &>.-half {
        grid-column: span 1;
    }
}

@media (width < 768px) {
    .c-contact-form__group {
        gap: 1.25rem 1rem;
        grid-template-columns: unset;

        &>* {
            grid-column: unset;
        }

        &>.-half {
            grid-column: unset;
        }
    }
}

.c-contact-form__field {
    display: grid;
    row-gap: .5rem;
}

.c-contact-form__header {
    align-items: center;
    column-gap: .625rem;
    display: flex;
}

.c-contact-form__label {
    font-weight: 600;
}

.c-contact-form__regulation {
    background-color: var(--color--gray-primary);
    border-radius: .125rem;
    color: var(--color--base-primary);
    font-size: .75rem;
    padding-block: .0625rem;
    padding-inline: .625rem;
}

.c-contact-form__field:has([required]) {
    .c-contact-form__regulation {
        background-color: var(--color--main-primary);
    }
}

.c-contact-form__body {
    display: grid;
}

.c-contact-form__input {
    background-color: var(--color--white-secondary);
    block-size: 2.625rem;
    border-radius: .25rem;
    color: var(--color--font-primary);
    cursor: pointer;
    font-size: 1rem;
    font-weight: 400;
    padding-block: 0;
    padding-inline: 1rem;

    &::placeholder {
        color: var(--color--gray-primary);
    }
}

@media (width < 768px) {
    .c-contact-form__input {
        font-size: max(16px, 1rem);
    }
}

.c-contact-form__validation {
    color: var(--color--utility-invalid);
    font-size: .75rem;
    line-height: var(--line-height--sm);
    margin-block-start: .25rem;

    &:empty {
        block-size: 0;
        margin-block-start: 0;
    }
}

.c-contact-form__acceptance {
    text-align: center;
}

.c-contact-form__acceptance-copy {
    font-weight: 400;

    a[target="_blank"] {
        color: var(--color--font-primary);

        &::after {
            content: none;
        }
    }
}

@media (width < 768px) {
    .c-contact-form__acceptance-copy {
        font-size: .75rem;
    }
}

.c-contact-form__acceptance-input {
    appearance: auto;
}

.c-contact-form__submit {
    display: flex;
    justify-content: center;
}

.c-contact-form__submit-label {
    &:has(:disabled) {
        opacity: .4;
        pointer-events: none;
    }
}

.c-contact-form__submit-input {
    cursor: pointer !important;
    letter-spacing: inherit;
}

/* ========================================
// project - 各セクションの設定
// ======================================== */
/* mv - メインビジュアル */
.p-mv {
    background-image:
        linear-gradient(to bottom,
            color-mix(in srgb, var(--color--base-primary) 100%, transparent) 0%,
            color-mix(in srgb, var(--color--base-tertiary) 100%, transparent) 100%);
    padding-block: 3.125rem 3.75rem;
    position: relative;
}

.video_banner {
    position: relative;
    width: 100%;
    height: 100vh;
    /* hoặc bất kỳ chiều cao bạn cần */
    overflow: hidden;
}

.video_bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1;
}

.p-mv::before {
    /* background-image: url('../images/image_background%402x.png'); */
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    block-size: 100%;
    content: '';
    inline-size: 100%;
    inset-block-start: 0;
    inset-inline-start: 0;
    opacity: 40%;
    position: absolute;
    z-index: 1;
}

.p-mv>* {
    position: relative;
    z-index: 2;
}

@media (width < 768px) {
    .p-mv {
        padding-block: 1.875rem 3.125rem;

        &::before {
            /* background-image: url('../images/sp-image_background%402x.png'); */
        }
    }
}

.p-mv__container {
    display: grid;
    gap: 2.5rem 3.5rem;
    grid-template-columns: 12.5rem 1fr 12.5rem;
    grid-template-rows: auto 1fr auto auto;
    max-inline-size: 54.6875rem;
    place-items: center;
}

@media (width < 768px) {
    .p-mv__container {
        gap: 1.25rem 0;
        grid-template-columns: unset;
        grid-template-rows: unset;
        max-inline-size: unset;
    }
}

.p-mv__copy {
    display: grid;
    grid-column: 1 / 4;
    grid-row: 1 / 3;
    /* grid-template-columns: subgrid; */
    grid-template-rows: subgrid;
    place-items: center;
}

@media (width < 768px) {
    .p-mv__copy {
        grid-column: unset;
        grid-row: unset;
        grid-template-columns: unset;
        grid-template-rows: unset;
        row-gap: 1.25rem;
    }
}

.p-mv__copy-sub {
    align-items: baseline;
    display: inline-flex;
    font-size: 3rem;
    grid-column: 1 / 4;
    grid-row: 1 / 2;
    line-height: 1.25;

    strong {
        background-image: url('https://dekirukun-dx.com/images/lp/hp-dekirukun/mv/image_copy-marker.svg');
        background-position: center bottom;
        background-repeat: no-repeat;
        background-size: contain;
        position: relative;
    }
}

@media (width < 768px) {
    .p-mv__copy-sub {
        font-size: 1.25rem;
        line-height: 1.5;
        grid-column: unset;
        grid-row: unset;
    }
}

.p-mv__copy-main {
    align-items: center;
    color: var(--color--main-primary);
    column-gap: 2rem;
    display: grid;
    font-size: 5.5rem;
    grid-column: 3 / 3;
    grid-row: 2 / 3;
    grid-template-columns: auto 1fr;

    span {
        border-block: solid .125rem var(--color--main-primary);
        letter-spacing: .03em;
        line-height: 1;
        padding-block: .875rem;
        writing-mode: vertical-rl;
    }
}

@media (width < 768px) {
    .p-mv__copy-main {
        column-gap: 1.25rem;
        font-size: 3.5rem;
        grid-column: unset;
        grid-row: unset;

        span {
            padding-block: .5rem;
        }

        img {
            inline-size: 8.5rem;
        }
    }
}

::-webkit-full-page-media,
:future,
:root .p-mv__copy-main {
    span {
        padding-block: .625rem 1.125rem;
    }
}

@media (width < 768px) {

    ::-webkit-full-page-media,
    :future,
    :root .p-mv__copy-main {
        span {
            padding-block: .3125rem .6875rem;
        }
    }
}

.p-mv__price {
    align-items: center;
    column-gap: 1rem;
    display: flex;
    grid-column: 1 / 4;
    grid-row: 3 / 4;
}

@media (width < 768px) {
    .p-mv__price {
        column-gap: .25rem;
        grid-column: unset;
        grid-row: unset;
    }
}

.p-mv__price-label {
    background-color: var(--color--main-primary);
    border-radius: .375rem;
    color: var(--color--base-primary);
    font-size: 2.75rem;
    line-height: 1.25;
    padding-block: .3125rem .3125rem;
    padding-inline: 1rem;
}

@media (width < 768px) {
    .p-mv__price-label {
        border-radius: .1875rem;
        font-size: 1.125rem;
        padding-block: .25rem;
        padding-inline: .5rem;
    }
}

::-webkit-full-page-media,
:future,
:root .p-mv__price-label {
    padding-block: .25rem .5rem;
}

@media (width < 768px) {

    ::-webkit-full-page-media,
    :future,
    :root .p-mv__price-label {
        padding-block: .1875rem .25rem;
    }
}

.p-mv__price-copy {
    color: var(--color--main-primary);
    font-size: 3.5rem;
    line-height: 1;

    strong {
        font-size: 4.5rem;
    }
}

@media (width < 768px) {
    .p-mv__price-copy {
        font-size: 1.5rem;

        strong {
            font-size: 1.75rem;
        }
    }
}

::-webkit-full-page-media,
:future,
:root .p-mv__price-copy {
    translate: 0 -.25rem;
}

@media (width < 768px) {

    ::-webkit-full-page-media,
    :future,
    :root .p-mv__price-copy {
        translate: 0 -.125rem;
    }
}

.p-mv__image {
    display: grid;
    grid-column: 1 / 4;
    grid-row: 2 / 3;
    grid-template-columns: subgrid;
    grid-template-rows: subgrid;
    place-items: center;
}

@media (width < 768px) {
    .p-mv__image {
        display: flex;
        flex-direction: column;
        grid-column: unset;
        grid-row: unset;
        grid-template-columns: unset;
        grid-template-rows: unset;
        row-gap: .5rem;
    }
}

.p-mv__image-list {
    display: grid;
    grid-row: 2 / 3;
    row-gap: .5rem;

    &:nth-of-type(1) {
        grid-column: 1 / 2;
    }

    &:nth-of-type(2) {
        grid-column: 3 / 4;
    }
}

@media (width < 768px) {
    .p-mv__image-list {
        display: flex;
        grid-row: unset;
        row-gap: unset;

        &:nth-of-type(1) {
            grid-column: unset;
        }

        &:nth-of-type(2) {
            grid-column: unset;
        }
    }
}

.p-mv__image-item {
    border: solid .25rem var(--color--base-primary);
    border-radius: .5rem;
    box-shadow: 0 .25rem 1rem color-mix(in srgb, var(--color--main-primary) 16%, transparent);
    overflow: clip;
}

@media (width < 768px) {
    .p-mv__image-item {
        border: solid .125rem var(--color--base-primary);
        border-radius: .25rem;
        box-shadow: unset;
    }
}

.p-mv__button {
    display: grid;
    grid-column: 1 / 4;
    grid-row: 4 / 5;
    inline-size: 100%;
    justify-items: center;
}

@media (width < 768px) {
    .p-mv__button {
        grid-column: unset;
        grid-row: unset;
    }
}

/* introduction - お手頃価格で高品質なホームページを制作します！ */
.p-introduction {
    /* background-image:
        linear-gradient(
            to bottom,
            color-mix(in srgb, var(--color--base-primary) 60%, transparent) 0%,
            color-mix(in srgb, var(--color--base-primary) 60%, transparent) 100%
        ),
        url('../images/introduction/image_background%402x.png'); */
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
}

@media (768px <=width) {
    .p-introduction {
        position: relative;

        &::before,
        &::after {
            aspect-ratio: 1;
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            content: '';
            inline-size: 17.5rem;
            inset-block-start: 0;
            position: absolute;
            z-index: 1;
        }

        &::before {
            background-image: url('../images/introduction/image_illustration-01%402x.png');
            inset-inline-start: 0;
        }

        &::after {
            background-image: url('../images/introduction/image_illustration-02%402x.png');
            inset-inline-end: 0;
        }

        &>* {
            position: relative;
            z-index: 2;
        }
    }
}

.p-introduction__list {
    display: grid;
    gap: 3.75rem 1.25rem;
    grid-template-columns: repeat(4, 1fr);
}

@media (width < 768px) {
    .p-introduction__list {
        gap: 1.25rem .625rem;
        grid-template-columns: repeat(2, 1fr);
    }
}

/* problem - こんなお悩みありませんか？ */
.p-problem {
    background-color: var(--color--base-secondary);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    position: relative;

    &::after {
        background-color: var(--color--base-secondary);
        background-position: center top;
        background-repeat: no-repeat;
        background-size: 100% 100%;
        block-size: var(--section-size--medium);
        content: '';
        inline-size: 100%;
        inset-block-end: calc(var(--section-size--medium) * -1);
        inset-inline-start: 0;
        position: absolute;
        z-index: 1;
    }

    &>* {
        position: relative;
        z-index: 2;
    }
}

.p-problem__body {
    padding-block-end: 3.75rem;
    position: relative;
}

@media (width < 768px) {
    .p-problem__body {
        padding-block-end: 1.25rem;
    }
}

.p-problem__list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.25rem;
    justify-content: center;
}

@media (width < 768px) {
    .p-problem__list {
        gap: .625rem;
    }
}

.p-problem__item {
    align-items: center;
    background-color: var(--color--gray-primary);
    border-radius: .5rem;
    display: flex;
    inline-size: calc((100% - (1.25rem * 2)) / 3);
    justify-content: center;
    min-block-size: 12.5rem;
    padding-block: .5rem;
    padding-inline: .5rem;
    position: relative;

    &::before {
        aspect-ratio: 1;
        background-color: var(--color--black-tertiary);
        mask-image: var(--icon--quotation);
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: contain;
        content: '';
        inline-size: 2.25rem;
        inset-block-start: -.875rem;
        inset-inline-start: 1.25rem;
        position: absolute;
        z-index: 1;
    }
}

@media (width < 768px) {
    .p-problem__item {
        border-radius: .25rem;
        inline-size: calc((100% - .625rem) / 2);
        min-block-size: 7.5rem;

        &::before {
            inline-size: 1.25rem;
            inset-block-start: -.5rem;
            inset-inline-start: .625rem;
        }
    }
}

.p-problem__item-copy {
    color: var(--color--base-primary);
    font-size: 1.375rem;
    text-align: center;
}

@media (width < 768px) {
    .p-problem__item-copy {
        font-size: .875rem;
        line-height: 1.375;
    }
}

.p-problem__image {
    aspect-ratio: 33 / 53;
    inline-size: 8.25rem;
    inset-block-end: 0;
    position: absolute;
    z-index: 1;

    &:nth-of-type(1) {
        inset-inline-start: 0;
    }

    &:nth-of-type(2) {
        inset-inline-end: 0;
    }
}

@media (width < 768px) {
    .p-problem__image {
        inline-size: 4.5rem;
    }
}

/* solution - こんなお悩みありませんか？ */
.p-solution {
    padding-block-start: calc(var(--section-size--medium) * 2);
}

.p-solution__list {
    display: grid;
    row-gap: 1.25rem;
}

@media (width < 768px) {
    .p-solution__list {
        row-gap: 1rem;
    }
}

.p-solution__item {
    background-color: #fff7cc;
    border-radius: .5rem;
    display: grid;
    gap: 1.25rem 3.75rem;
    grid-template-columns: 5rem 1fr 1fr;
    grid-template-rows: auto 1fr;
    overflow: clip;
    padding-block: 3.75rem;
    padding-inline-end: 3.75rem;
}

@media (width < 768px) {
    .p-solution__item {
        border-radius: .25rem;
        gap: 1rem;
        grid-template-columns: unset;
        grid-template-rows: auto auto 1fr;
        padding-block: 1.5rem;
        padding-inline: 1.25rem;
    }
}

.p-solution__item-header {
    display: grid;
    grid-column: 1 / 3;
    grid-row: 1 / 3;
    grid-template-columns: subgrid;
    grid-template-rows: subgrid;
}

@media (width < 768px) {
    .p-solution__item-header {
        column-gap: .75rem;
        grid-column: unset;
        grid-row: unset;
        grid-template-columns: 3.25rem 1fr;
        grid-template-rows: unset;
    }
}

.p-solution__item-number {
    align-items: center;
    background-color: var(--color--main-primary);
    block-size: calc(100% + (3.75rem * 2));
    color: var(--color--base-primary);
    display: flex;
    flex-direction: column;
    font-family: var(--font-family--en);
    font-size: .875rem;
    grid-column: 1 / 2;
    grid-row: 1 / 3;
    letter-spacing: .09em;
    line-height: 1.25;
    margin-block-start: -3.75rem;
    padding-block: 2.75rem;
    padding-inline-start: .09em;
    text-align: center;
    text-transform: uppercase;

    span {
        font-size: 3rem;
        letter-spacing: .06em;
        line-height: 1;
        padding-inline-start: .03em;
    }
}

@media (width < 768px) {
    .p-solution__item-number {
        block-size: 100%;
        border-radius: .25rem;
        font-size: .625rem;
        grid-column: unset;
        grid-row: unset;
        justify-content: center;
        margin-block-start: unset;
        padding-block: unset;

        span {
            font-size: 2rem;
        }
    }
}

.p-solution__item-title {
    align-self: end;
    font-size: 1.75rem;
    grid-column: 2 / 3;
    grid-row: 1 / 2;

    strong {
        color: var(--color--main-primary);
    }
}

@media (width < 768px) {
    .p-solution__item-title {
        font-size: 1.25rem;
        grid-column: unset;
        grid-row: unset;
        letter-spacing: 0;
        margin-block-start: unset;

        &::before {
            font-size: 1.75rem;
            inline-size: 3.125rem;
            inset-block-start: -.5rem;
            inset-inline-start: 1.625rem;
        }
    }
}

.p-solution__item-description {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    line-height: 1.75;
}

@media (width < 768px) {
    .p-solution__item-description {
        font-size: .875rem;
        grid-column: unset;
        grid-row: unset;
    }
}

.p-solution__item-image {
    background-color: var(--color--base-tertiary);
    border-radius: .5rem;
    display: grid;
    grid-column: 3 / 4;
    grid-row: 1 / 3;
    place-items: center;
}

@media (width < 768px) {
    .p-solution__item-image {
        border-radius: .375rem;
        grid-column: unset;
        grid-row: unset;
    }
}

/* works - 様々な業界の制作実績があります！ */
.p-works {
    background-color: var(--color--base-secondary);
}

@media (768px <=width) {
    .p-works {
        position: relative;

        &::before {
            aspect-ratio: 1;
            background-image: url('../images/works/image_illustration%402x.png');
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            content: '';
            inline-size: 17.5rem;
            inset-block-start: 0;
            inset-inline-end: 0;
            position: absolute;
            z-index: 1;
        }

        &>* {
            position: relative;
            z-index: 2;
        }
    }
}

.p-works__list {
    display: grid;
    gap: 3.75rem 1.25rem;
    grid-template-columns: repeat(4, 1fr);
}

@media (width < 768px) {
    .p-works__list {
        gap: 1.875rem .625rem;
        grid-template-columns: repeat(2, 1fr);
    }
}

.p-works__item {
    display: grid;
    grid-row: span 2;
    grid-template-rows: subgrid;
    row-gap: 1.25rem;
}

@media (width < 768px) {
    .p-works__item {
        row-gap: .625rem;
    }
}

.p-works__item-title {
    background-color: var(--color--main-secondary);
    border-radius: .25rem;
    display: grid;
    line-height: 1.25;
    padding-block: .6875rem .75rem;
    padding-inline: 1rem;
    place-items: center;
    text-align: center;
}

@media (width < 768px) {
    .p-works__item-title {
        font-size: .875rem;
        padding-block: .5rem;
        padding-inline: .5rem;
    }
}

.p-works__information {
    background-color: var(--color--base-tertiary);
    border-radius: .5rem;
    display: grid;
    padding-block: 2.5rem 3.75rem;
    padding-inline: 3.75rem;
    row-gap: 1.875rem;
}

@media (width < 768px) {
    .p-works__information {
        padding-block: 1.5rem 1.875rem;
        padding-inline: 1.25rem;
        row-gap: 1.25rem;
    }
}

.p-works__information-title {
    align-items: center;
    column-gap: .25rem;
    display: flex;
    font-size: 1.5rem;
    justify-content: center;
    line-height: 1.25;
    text-align: center;
}

.p-works__information-title::before {
    aspect-ratio: 1;
    background-color: var(--color--main-secondary);
    content: '';
    inline-size: 2.25rem;
    mask-image: url('../images/icon_building.svg');
    mask-position: center;
    mask-repeat: no-repeat;
    mask-size: contain;
}

@media (width < 768px) {
    .p-works__information-title {
        font-size: 1rem;
    }

    .p-works__information-title::before {
        inline-size: 1.5rem;
    }
}

.p-works__information-list {
    display: grid;
    gap: .5rem;
    grid-template-columns: repeat(6, 1fr);
}

@media (width < 768px) {
    .p-works__information-list {
        gap: .375rem;
        grid-template-columns: repeat(3, 1fr);
    }
}

.p-works__information-item {
    background-color: var(--color--base-primary);
    border: solid .1875rem var(--color--main-secondary);
    border-radius: .375rem;
    display: grid;
    line-height: 1.25;
    min-block-size: 3.75rem;
    padding-block: .25rem;
    padding-inline: .75rem;
    place-items: center;
    text-align: center;
}

@media (width < 768px) {
    .p-works__information-item {
        border: solid .125rem var(--color--main-secondary);
        border-radius: .25rem;
        font-size: .75rem;
        min-block-size: 3.125rem;
        padding-inline: .25rem;
    }
}

.p-works__information-guide {
    align-items: center;
    display: grid;
    grid-column: 4 / 7;
    line-height: 1.25;
    text-align: right;
}

@media (width < 768px) {
    .p-works__information-guide {
        font-size: .75rem;
        grid-column: 1 / 4;
    }
}

/* comparison - 他サービスとの比較 */
@media (768px <=width) {
    .p-comparison {
        position: relative;

        &::before {
            aspect-ratio: 1;
            background-image: url('../images/comparison/image_illustration%402x.png');
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            content: '';
            inline-size: 17.5rem;
            inset-block-start: 0;
            inset-inline-start: 0;
            position: absolute;
            z-index: 1;
        }

        &>* {
            position: relative;
            z-index: 2;
        }
    }
}

.p-comparison__table {
    inline-size: 100%;
}

@media (width < 768px) {
    .p-comparison__table {
        inline-size: 36.25rem;
    }
}

.p-comparison__table-body {
    display: grid;
    gap: .1875rem;
    grid-template-columns: 17.6% 31.5% 1fr 1fr;
    padding-block-end: .25rem;
}

@media (width < 768px) {
    .p-comparison__table-body {
        grid-template-columns: 15.52% 1fr 1fr 1fr;
        padding-block-end: .125rem;
    }
}

.p-comparison__table-row {
    display: grid;
    grid-column: span 4;
    grid-template-columns: subgrid;
}

.p-comparison__table-header {
    display: grid;
    font-size: 1.125rem;
    line-height: 1.25;
    min-block-size: 5rem;
    padding-block: .5rem;
    padding-inline: .5rem;
    place-items: center;
    text-align: center;

    &[data-comparison-column="main"] {
        background-color: var(--color--main-primary);
        color: var(--color--base-primary);

        img {
            max-inline-size: 15rem;
            padding-block-end: .25rem;
        }
    }

    &[data-comparison-column="other"] {
        background-color: var(--color--gray-primary);
        color: var(--color--base-primary);
    }

    &:is(.p-comparison__table-row:first-child > :nth-child(2)) {
        border-radius: .5rem 0 0 0;
    }

    &:is(.p-comparison__table-row:first-child > :last-child) {
        border-radius: 0 .5rem 0 0;
    }
}

@media (width < 768px) {
    .p-comparison__table-header {
        font-size: .75rem;
        min-block-size: 3rem;

        &[data-comparison-column="main"] {
            img {
                max-inline-size: unset;
            }
        }

        &[data-comparison-column="other"] {
            font-size: .875rem;
        }

        &:is(.p-comparison__table-row:first-child > :nth-child(2)) {
            border-radius: .375rem 0 0 0;
        }

        &:is(.p-comparison__table-row:first-child > :last-child) {
            border-radius: 0 .375rem 0 0;
        }
    }
}

.p-comparison__table-data {
    display: grid;
    font-size: 1.125rem;
    line-height: 1.25;
    min-block-size: 5rem;
    place-items: center;
    position: relative;
    text-align: center;

    &[data-comparison-column="topic"] {
        background-color: var(--color--main-secondary);
        padding-block: .5rem;
        padding-inline: .5rem;
    }

    &[data-comparison-column="main"] {
        background-color: var(--color--base-primary);
        color: var(--color--main-primary);
        font-size: 1.5rem;

        &::after {
            block-size: calc(100% + .1875rem);
            border-inline: solid .25rem var(--color--main-primary);
            content: '';
            inline-size: 100%;
            inset-block-start: -.1875rem;
            inset-inline-start: 0;
            position: absolute;
            z-index: 1;
        }

        &>* {
            position: relative;
            z-index: 2;
        }

        &:is(.p-comparison__table-row:last-child > *) {
            &::after {
                block-size: calc(100% + .1875rem + .25rem);
                border-block-end: solid .25rem var(--color--main-primary);
            }
        }

        strong {
            font-size: 2.5rem;
        }
    }

    &[data-comparison-column="other"] {
        background-color: var(--color--white-secondary);
        font-size: 1.25rem;
    }

    &[data-comparison-emphasis] {
        background-color: var(--color--base-tertiary);
    }

    &:is(.p-comparison__table-row:nth-child(2) > :first-child) {
        border-radius: .5rem 0 0 0;
    }

    &:is(.p-comparison__table-row:last-child > :first-child) {
        border-radius: 0 0 0 .5rem;
    }

    &:is(.p-comparison__table-row:last-child > :last-child) {
        border-radius: 0 0 .5rem 0;
    }
}

@media (width < 768px) {
    .p-comparison__table-data {
        font-size: .75rem;
        min-block-size: 3rem;

        &[data-comparison-column="topic"] {
            letter-spacing: 0;
            padding-block: .25rem;
            padding-inline: 0;
        }

        &[data-comparison-column="main"] {
            font-size: 1rem;

            &::after {
                border-inline: solid .125rem var(--color--main-primary);
            }

            &:is(.p-comparison__table-row:last-child > *) {
                &::after {
                    block-size: calc(100% + .1875rem + .125rem);
                    border-block-end: solid .125rem var(--color--main-primary);
                }
            }

            strong {
                font-size: 1.5rem;
            }
        }

        &[data-comparison-column="other"] {
            font-size: .875rem;
        }

        &:is(.p-comparison__table-row:nth-child(2) > :first-child) {
            border-radius: .375rem 0 0 0;
        }

        &:is(.p-comparison__table-row:last-child > :first-child) {
            border-radius: 0 0 0 .375rem;
        }

        &:is(.p-comparison__table-row:last-child > :last-child) {
            border-radius: 0 0 .375rem 0;
        }
    }
}

/* flow - ご利用の流れ */
@media (768px <=width) {
    .p-flow {
        position: relative;

        &::before {
            aspect-ratio: 1;
            background-image: url('../images/flow/image_illustration%402x.png');
            background-position: center;
            background-repeat: no-repeat;
            background-size: contain;
            content: '';
            inline-size: 17.5rem;
            inset-block-start: 0;
            inset-inline-end: 0;
            position: absolute;
            z-index: 1;
        }

        &>* {
            position: relative;
            z-index: 2;
        }
    }
}

.p-flow__list {
    counter-reset: flow__item-counter;
    display: grid;
    gap: .625rem;
    grid-template-columns: repeat(5, 1fr);
    padding-block-start: 2rem;
}

@media (width < 768px) {
    .p-flow__list {
        gap: 1.25rem;
        grid-template-columns: unset;
        padding-block-start: .625rem;
    }
}

.p-flow__item {
    background-color: var(--color--base-primary);
    border: solid .25rem var(--color--main-secondary);
    border-radius: .5rem;
    counter-increment: flow__item-counter;
    display: grid;
    grid-row: span 3;
    grid-template-rows: subgrid;
    justify-items: center;
    padding-block: 3.25rem 2.5rem;
    padding-inline: 1rem;
    position: relative;
    row-gap: 1rem;
}

@media (width < 768px) {
    .p-flow__item {
        border: solid .1875rem var(--color--main-secondary);
        padding-block: 2rem 1.25rem;
        padding-inline: .5rem;
        row-gap: .75rem;
    }
}

.p-flow__item-image {
    inline-size: 5.5rem;
}

@media (width < 768px) {
    .p-flow__item-image {
        grid-row: 3 / 4;
        inline-size: 4rem;
    }
}

.p-flow__item-title {
    align-self: center;
    font-size: 1.25rem;
    line-height: 1.25;
    text-align: center;

    &::before {
        aspect-ratio: 1;
        background-color: var(--color--main-secondary);
        border-radius: 50%;
        content: counter(flow__item-counter, decimal-leading-zero);
        display: grid;
        font-family: var(--font-family--en);
        font-size: 2rem;
        inline-size: 4rem;
        inset-block-start: -2rem;
        inset-inline-start: 50%;
        letter-spacing: .06em;
        line-height: 1.25;
        padding-inline-start: .06em;
        place-items: center;
        position: absolute;
        text-align: center;
        translate: -50% 0;
    }
}

@media (width < 768px) {
    .p-flow__item-title {
        font-size: 1.125rem;

        &::before {
            font-size: 1.25rem;
            inline-size: 2.5rem;
            inset-block-start: -1.25rem;
        }
    }
}

@media (width < 768px) {
    .p-flow__item-description {
        font-size: .875rem;
        text-align: center;
    }
}

/* faq - よくあるご質問 */
.p-faq__list {
    counter-reset: faq__item-counter;
    display: grid;
    row-gap: 1.25rem;
}

@media (width < 768px) {
    .p-faq__list {
        row-gap: .5rem;
    }
}

.p-faq__item {
    border-radius: .5rem;
    counter-increment: faq__item-counter;
    overflow: clip;
}

@media (width < 768px) {
    .p-faq__item {
        border-radius: .375rem;
    }
}

.p-faq__item-visible {
    cursor: pointer;
    display: block;

    &::-webkit-details-marker {
        display: none;
    }
}

.p-faq__item-question {
    align-items: center;
    background-color: var(--color--base-primary);
    column-gap: 1.25rem;
    display: grid;
    font-size: 1.5rem;
    grid-template-columns: auto 1fr auto;
    padding-block: 1.125rem;
    padding-inline: 1.75rem;

    &::before {
        color: var(--color--main-primary);
        content: 'Q' counter(faq__item-counter);
        font-family: var(--font-family--en);
        font-size: 3rem;
        letter-spacing: .06em;
        line-height: 1;
    }

    &::after {
        aspect-ratio: 2 / 1;
        background-color: var(--color--main-secondary);
        clip-path: polygon(100% 0, 0 0, 50% 100%);
        content: '';
        display: inline-block;
        inline-size: 2rem;
        transition: .3s ease scale;
    }

    &:is(.-opened[data-faq-details] *)::after {
        scale: 1 -1;
    }
}

@media (width < 768px) {
    .p-faq__item-question {
        column-gap: .75rem;
        font-size: 1rem;
        line-height: 1.375;
        padding-block: .75rem;
        padding-inline: 1rem;

        &::before {
            font-size: 2rem;
        }

        &::after {
            inline-size: 1rem;
        }
    }
}

.p-faq__item-answer {
    background-color: var(--color--base-tertiary);
    display: block;
    font-size: 1.125rem;
    padding-block: 1.5rem;
    padding-inline: 1.75rem;
}

@media (width < 768px) {
    .p-faq__item-answer {
        font-size: .875rem;
        padding-block: .75rem;
        padding-inline: 1rem;
    }
}

/* contact - 無料相談フォーム */
.p-contact {
    box-shadow: 0 .25rem .875rem color-mix(in srgb, var(--color--black-secondary) 10%, transparent);
}

.p-contact__container {
    box-shadow: 0 .25rem .875rem color-mix(in srgb, var(--color--black-secondary) 25%, transparent);
    padding-block: 3.125rem;
    padding-inline: 6.25rem;
}

@media (width < 768px) {
    .p-contact__container {
        padding-block: 1.875rem;
        padding-inline: 1rem;
    }
}

.p-contact__header {
    row-gap: .375rem;
}

.p-contact__description {
    font-size: .875rem;
    font-weight: 400;
    text-align: center;
}

/* ========================================
// utility - 頻出CSSをクラスに設定
// ======================================== */
/* padding-block */
.u-pbs-0 {
    padding-block-start: 0 !important;
}

.u-pbe-0 {
    padding-block-end: 0 !important;
}

/* margin-block */
.u-mbs-0 {
    margin-block-start: 0 !important;
}

.u-mbe-0 {
    margin-block-end: 0 !important;
}

/* background-color */
.u-bg-primary {
    background-color: var(--color--base-primary);
}

.u-bg-secondary {
    background-color: var(--color--base-secondary);
}

.u-bg-tertiary {
    background-color: var(--color--base-tertiary);
}

.u-bg-quaternary {
    background-color: var(--color--main-secondary);
    background-image:
        linear-gradient(to bottom,
            color-mix(in srgb, var(--color--main-secondary) 70%, transparent) 0%,
            color-mix(in srgb, var(--color--main-secondary) 70%, transparent) 100%),
        url('../images/common/image_background-particle%402x.png');
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
}

@media (width < 768px) {
    .u-bg-quaternary {
        background-image:
            linear-gradient(to bottom,
                color-mix(in srgb, var(--color--main-secondary) 70%, transparent) 0%,
                color-mix(in srgb, var(--color--main-secondary) 70%, transparent) 100%),
            url('../images/common/sp-image_background-particle%402x.png');
    }
}

/* text-align */
.u-text-start {
    text-align: start;
}

.u-text-center {
    text-align: center;
}

.u-text-end {
    text-align: end;
}

/* align-items */
.u-items-start {
    align-items: start;
    display: flex;
}

.u-items-center {
    align-items: center;
    display: flex;
}

.u-items-end {
    align-items: end;
    display: flex;
}

/* justify-content */
.u-justify-start {
    display: flex;
    justify-content: start;
}

.u-justify-center {
    display: flex;
    justify-content: center;
}

.u-justify-end {
    display: flex;
    justify-content: end;
}

/* object-fit */
.u-object-cover {
    img {
        block-size: 100%;
        inline-size: 100%;
        object-fit: cover;
    }
}

/* wbr */
.u-wbr {
    overflow-wrap: break-word;
    word-break: keep-all;
}

/* display */
@media (768px <=width) {
    .u-desktop-hidden {
        display: none;
    }
}

@media (width < 768px) {
    .u-mobile-hidden {
        display: none;
    }
}

/* notice */
.u-notice {
    font-size: .75rem;
    font-weight: 400;
    padding-inline-start: 1em;
    position: relative;

    &::before {
        content: '※';
        inset-block-start: 0;
        inset-inline-start: 0;
        position: absolute;
    }
}

@media (width < 768px) {
    .u-notice {
        font-size: .625rem;
    }
}


/*! CSS Used from: https://www.centered.co.jp/css/common/base.css?250213-120951 ; media=all */
@media all {
    .l-content-base {
        width: 95%;
        max-width: 1200px;
        padding: 0;
        margin-inline: auto;
    }
}

/*! CSS Used from: https://www.centered.co.jp/css/common/common.css?250219-134353 ; media=all */
@media all {
    .m-cta-04 {
        padding-block: 60px 35px;
        position: relative;
    }

    .m-cta-04:before,
    .m-cta-04:after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    .m-cta-04:before {
        z-index: -1;
    }

    .m-cta-04:after {
        z-index: -2;
        background-color: var(--ver01-main-color-red);
    }

    .m-cta-04-ttl {
        font-size: clamp(28px, calc(32 / 1280 * 100vw), 32px);
        line-height: calc(48 / 32);
        letter-spacing: .04em;
        font-weight: 700;
        color: #fff;
        margin-block: calc((1em - 1lh) / 2);
        text-align: center;
    }

    .m-cta-04-ttl .ib {
        display: inline-block;
    }

    .m-cta-04-wrap {
        display: grid;
        grid-template-columns: repeat(2, 365px);
        align-items: center;
        justify-content: center;
        gap: 0 clamp(30px, calc(40 / 1280 * 100vw), 40px);
        margin-top: 30px;
    }

    .m-cta-04-btn {
        box-sizing: border-box;
        text-decoration: none;
        width: 100%;
        border-radius: 999px;
        background-color: var(--ver01-main-color-white);
        border: 1px solid var(--ver01-main-color-white);
        display: block;
        position: relative;
        transition: background-color 0.3s ease 0s, color 0.3s ease 0s;
        overflow: hidden;
    }

    .m-cta-04-btn:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-image: linear-gradient(135deg, #2A2A2A 50%, transparent 50%);
        background-position: 100%;
        background-size: 300%;
        transition: background-position 0.4s ease 0s;
    }

    .btn--red:before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-image: linear-gradient(135deg, #fea633 50%, transparent 50%);
        background-position: 100%;
        background-size: 300%;
        transition: background-position 0.4s ease 0s;
    }


    .m-cta-04-btn:hover::before {
        background-position: 0;
    }

    .m-cta-04-btn {
        text-decoration: unset;
        background-color: #fff;
    }

    .m-cta-04-btn:hover {
        text-decoration: unset;
    }

    .m-cta-04-tel {
        color: #fff;
        cursor: pointer;
    }

    .m-cta-04-btn span {
        box-sizing: border-box;
        font-size: 20px;
        line-height: calc(31 / 20);
        letter-spacing: 0.04em;
        font-weight: 700;
        color: #2A2A2A;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        height: 69px;
        position: relative;
        z-index: 1;
        padding-left: 15px;
        padding-bottom: 1px;
    }



    .m-cta-04-btn span::before,
    .m-cta-04-btn span::after {
        content: '';
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }

    .m-cta-04-btn span::before {
        left: 40px;
        z-index: 1;
        width: 8px;
        aspect-ratio: 8 / 16;
        mask-position: center;
        mask-repeat: no-repeat;
        mask-size: contain;
        mask-image: url(../images/icn_arrow_right.svg);
        background-color: var(--ver01-main-color-white);
        transition: background-color 0.3s ease 0s;
        background-color: #fff;
    }

    .m-cta-04-btn span::after {
        left: 30px;
        width: 27px;
        aspect-ratio: 27 / 27;
        border-radius: 50%;
        background-color: currentColor;
    }

    .m-cta-04-btn:hover span {
        color: var(--ver01-main-color-white);
    }

    .m-cta-04-btn:hover span::before {
        background-color: #2A2A2A;
    }

    .btn--red span {
        color: #fea633;
    }

    .btn--red:hover span::before {
        background-color: #fea633;
    }

    .btn--red:hover span::after {
        background-color: #fff
    }

    .btn--red:hover span {
        color: #fff;
    }


    .m-cta-04-btn:hover span::after {
        transform: translateY(-50%) scale(0.85);
    }

    .m-cta-04-tel {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 10px;
        margin-top: 25px;
    }

    .m-cta-04-tel-tag {
        font-size: 13px;
        line-height: calc(22 / 13);
        letter-spacing: 0.04em;
        font-weight: 700;
        color: #ff7500;
        background-color: #fff;
        padding-inline: 5px;
    }

    .m-cta-04-tel-num {
        font-family: 'Montserrat', sans-serif;
        font-size: 28px;
        line-height: calc(34 / 28);
        letter-spacing: normal;
        font-weight: 600;
        color: var(--ver01-main-color-white);
    }

    .m-cta-04-tel-time {
        font-size: 14px;
        line-height: calc(32 / 14);
        letter-spacing: 0.04em;
        font-weight: 400;
        color: var(--ver01-main-color-white);
    }
}


/*! CSS Used fontfaces */
@font-face {
    font-family: 'Montserrat';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUQjIg1_i6t8kCHKm459WxRxC7mw9c.woff2) format('woff2');
    unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
    font-family: 'Montserrat';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUQjIg1_i6t8kCHKm459WxRzS7mw9c.woff2) format('woff2');
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
    font-family: 'Montserrat';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUQjIg1_i6t8kCHKm459WxRxi7mw9c.woff2) format('woff2');
    unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

@font-face {
    font-family: 'Montserrat';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUQjIg1_i6t8kCHKm459WxRxy7mw9c.woff2) format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'Montserrat';
    font-style: italic;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUQjIg1_i6t8kCHKm459WxRyS7m.woff2) format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUSjIg1_i6t8kCHKm459WRhyzbi.woff2) format('woff2');
    unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUSjIg1_i6t8kCHKm459W1hyzbi.woff2) format('woff2');
    unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUSjIg1_i6t8kCHKm459WZhyzbi.woff2) format('woff2');
    unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
    unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/montserrat/v29/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

a.m-cta-04-btn[target="_blank"] {
    &::after {
        aspect-ratio: unset;
        background-color: unset;
        content: '';
        display: unset;
        inline-size: unset;
        mask-image: unset;
        mask-position: unset;
        mask-repeat: unset;
        mask-size: unset;
        vertical-align: unset;
    }
}

@media (width < 768px) {
    .m-cta-04-wrap {
        grid-template-columns: repeat(1, 100%);
        gap: 10px;
    }
}

.circle_grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    justify-items: center;
    padding: 20px;
}

.circle_item {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
}

.circle_content {
    width: 80%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.circle_content span {
    font-size: 16px;
    color: #000000;
    width: 100%;
    text-align: center;
    min-height: 50px;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.circle_content strong {
    font-size: 30px;
    color: #FF7500;
    width: 100%;
    text-align: center;
}

@media (max-width: 768px) {
    .circle_grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .mobile-none {
        display: none !important;
    }
}

.responsive-support {
    padding: 0px;
}

.l-inner {
    margin-left: auto;
    margin-right: auto;
    max-width: 1240px;
    padding-left: 20px;
    padding-right: 20px;
}

.responsive-support__title {
    margin-bottom: 23px;
    position: relative;
}

.c-ttl-06 {
    font-size: 20px;
    font-weight: 900;
    letter-spacing: -.025em;
    line-height: 1.4;
    width: 100%;
    text-align: center;
}

.u-c-orange {
    color: #f36c12 !important;
}

.u-c-gray {
    color: #666;
}

@media print,
screen and (min-width: 768px) {
    .u-sm-max {
        display: none !important;
    }
}

.responsive-support__title .big {
    font-size: 24px;
}

.u-relative {
    position: relative;
}

.responsive-support__desc {
    font-size: 14px;
    font-weight: 500;
    width: calc(100%);
    padding: 0px 110px;
    text-align: center;
    line-height: 26px;
    margin-bottom: 50px;
}

.u-fw-900 {
    font-weight: 900 !important;
}

.responsive-support__image {
    bottom: -84px;
    position: absolute;
    right: 0px;
    width: 100px;
}

.responsive-support__image img {
    width: 100px;
}

.responsive-support__block,
.responsive-support__btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.responsive-support__block,
.responsive-support__btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.responsive-support__btn {
    background: linear-gradient(to right, #ff7500, #f88118);
    border-radius: 0;
    color: #fff;
    font-size: 26px;
    font-weight: 900;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 10px 40px;
    position: relative;
}

.card {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    gap: 31px;
    justify-content: center;
    margin-top: 42px;
}

.card__title {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -.04em;
    line-height: 1.4479166667;
    margin-bottom: 20px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}

.card__title .small {
    font-size: 2.4rem;
}

.u-c-orange {
    color: #f36c12 !important;
}

.u-relative {
    position: relative;
}

.card__title img {
    position: absolute;
    right: -23px;
    top: -7px;
    width: 20px;
}

.card__title .small {
    font-size: 18px;
}

.u-object-fit-cover {
    object-fit: cover;
}

.card__image {
    height: 392px;
    width: 200px;
}

.card__item--main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 70px;
}

.card__title-inner {
    display: inline-block;
    padding-top: 18px;
    position: relative;
}

.card__item-dots {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 8px;
    gap: 4px;
    position: absolute;
    top: 4px;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100%;
}

.card__item-icon {
    font-size: 5rem;
    margin-bottom: 54px;
}

.fa,
.fa-brands,
.fa-duotone,
.fa-light,
.fa-regular,
.fa-solid,
.fa-thin,
.fab,
.fad,
.fal,
.far,
.fas,
.fat {
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: var(--fa-display, inline-block);
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
}

.fa-solid,
.fas {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
}

.card__content-inner {
    background-color: #fff7cc;
    border-radius: 20px;
    margin: 0 auto;
    max-width: 320px;
    padding: 42px 31px 31px;
    position: relative;
}

.c-lead-02 {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.448;
}

.card__content-title {
    background: linear-gradient(to right, #ff7500, #f88118);
    border-radius: 100px;
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 35px;
    left: 50%;
    min-width: 233px;
    position: absolute;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0 15px;
    top: -18px;
    white-space: nowrap;
}

.card__content-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 2px;
}

.card__content-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 10px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.448;
}

.card__item-text {
    font-size: 26px;
}

.card__item-icon {
    font-size: 36px;
    width: 100%;
    text-align: center;
    color: #ff7500
}

@media (width < 768px) {

    .l-inner {
        padding: 0px;
    }

    .c-ttl-06 {
        font-size: 14px;
    }

    .responsive-support__title .big {
        font-size: 18px;
    }

    .responsive-support__title {
        margin-bottom: 10px;
    }

    .responsive-support__desc {
        padding: 0px;
        margin-bottom: 10px;
    }

    .responsive-support__image img {
        display: none;
    }

    .responsive-support__btn {
        font-size: 16px;
        padding: 5px;
    }

    .card {
        flex-direction: column;
        gap: 5px;
        margin-top: 0px;
    }

    .card__item {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        margin-top: 20px;
    }
}

.card--new .card__item {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 20px;
    padding: 20px;
}
.card--new .card__item .card__image {
    width: unset;
    height: unset;
}
.card--new .card__item .card__image img {
    width: 220px;
}

@media (width < 768px) {
    .card--new .card__item .card__image .card__title {
        width: 100%;
    }
    .card--new .card__item {
        margin-top: 0px;
    }
    .card--new .card__item .u-sm-max {
        display: none !important;
    }
}
#link-solution{
    position: relative;
}
#link-solution:before {
    border-color: var(--color--main-primary) transparent transparent;
    border-style: solid;
    border-width: 70px 100px 0;
    content: "";
    height: 0;
    left: 50%;
    position: absolute;
    top: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 0;
}
@media (width < 768px) {
    #link-solution:before {
        border-width: 40px 50px 0;
    }
}