/* Noto Sans CJK JP Regular
font-family: "noto-sans-cjk-jp", sans-serif;
font-weight: 400;
font-style: normal;
Noto Sans CJK JP 700
font-family: "noto-sans-cjk-jp", sans-serif;
font-weight: 700;
font-style: normal; */
/* font-family: "bahnschrift", sans-serif;
font-weight: 700;
font-style: normal; */
:root {
    --font-ja: "noto-sans-cjk-jp", sans-serif;
    --font-en: "bahnschrift", sans-serif;
    --color-main: #0e204c;
    --color-bg-blue: #e7f4fb;
    --color-green: #1b85b3;
    --max-width-main: 1140px;
}
body {
    font-family: var(--font-ja), sans-serif;
    background: #fff;
}
/* ttl_ptn */
.ttl_ptn_1 {
    margin: 0 auto;
    margin-top: -40px;
    width: calc(100% - 80px);
    @media (max-width: 600px) {
        margin-top: -32px;
        width: calc(100% - 40px);
    }
    .main {
        display: block;
        font-size: 64px;
        line-height: 1;
        font-weight: 700;
        letter-spacing: 0.08em;
        color: var(--color-main);
        @media (max-width: 600px) {
            font-size: 48px;
        }
        &.en {
            font-family: var(--font-en);
        }
    }
    .sub {
        margin-top: 1.5em;
        display: block;
        font-size: 16px;
        color: var(--color-main);
        line-height: 1.5;
        letter-spacing: 0.04em;
        @media (max-width: 600px) {
            font-size: 14px;
        }
    }
}
.ttl_ptn_2 {
    display: flex;
    justify-content: center;
    font-size: 16px;
    color: var(--color-main);
    @media (max-width: 500px) {
        font-size: 14px;
    }
    .text {
        padding: 12px 18px;
        display: block;
        border-radius: 500px;
        background: #fff;
        text-align: center;
        line-height: 1.5;
    }
    &.bg_blue {
        .text {
            background: linear-gradient(90deg, #003f85 0%, #0667d4 100%);
            color: #fff;
        }
    }
}
.ttl_ptn_3 {
    width: 100%;
    font-size: 24px;
    line-height: 2;
    text-align: center;
    color: var(--color-main);
    font-weight: 700;
    @media (max-width: 1000px) {
        font-size: 20px;
    }
    @media (max-width: 600px) {
        font-size: 18px;
    }
}
.ttl_ptn_4 {
    position: relative;
    z-index: 10;
    margin: 0 auto;
    max-width: 1267px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    text-align: center;
    .main {
        padding: 0 0.5em;
        display: block;
        font-size: 64px;
        line-height: 1;
        font-weight: 700;
        letter-spacing: 0.08em;
        color: var(--color-main);
        font-family: var(--font-en);
        background: var(--this-color-bg, #fff);
        @media (max-width: 1000px) {
            margin-top: 0.1em;
            font-size: 56px;
        }
        @media (max-width: 800px) {
            font-size: 48px;
        }
        @media (max-width: 500px) {
            margin-top: 0.3em;
            font-size: 40px;
        }
    }
    .sub {
        width: 100%;
        display: block;
        margin-top: 1.5em;
        font-size: 16px;
        color: var(--color-main);
        line-height: 1.5;
        letter-spacing: 0.04em;
        @media (max-width: 1000px) {
            font-size: 14px;
        }
        @media (max-width: 800px) {
            margin-top: 1em;
            font-size: 12px;
        }
    }
    .bd {
        position: absolute;
        top: 36px;
        left: 0;
        right: 0;
        z-index: -1;
        margin: 0 auto;
        max-width: 100%;
        height: 2px;
        width: 100%;
        background: var(--color-main);
        &::after,
        &::before {
            position: absolute;
            top: 0;
            bottom: 0;
            margin: auto;
            width: 8px;
            height: 8px;
            content: "";
            display: block;
            background: var(--color-main);
            transform: rotate(45deg);
        }
        &::before {
            left: 0;
        }
        &::after {
            right: 0;
        }
    }
}
.ttl_ptn_5 {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 4px;
    color: var(--color-main);
    font-size: 24px;
    font-weight: 700;
    @media (max-width: 600px) {
        font-size: 18px;
    }
    @media (max-width: 500px) {
        font-size: 16px;
    }
    &::before,
    &::after {
        content: "";
        display: block;
        width: 24px;
        height: 24px;
        background: url(../image/icon/alert-triangle.svg) no-repeat center center;
        background-size: contain;
        @media (max-width: 600px) {
            width: 20px;
            height: 20px;
        }
    }
}
/* lead_text */
.lead_text_ptn_1 {
    margin: 0 auto;
    margin-top: 32px;
    padding: 0 24px;

    display: flex;
    justify-content: center;
    text-align: center;
    @media (max-width: 600px) {
        padding: 0;
    }
    .text {
        padding: 24px;
        background: linear-gradient(90deg, #003f85 0%, #0667d4 100%);
        color: #fff;
        font-weight: 700;
        font-size: 40px;
        border-radius: 8px;
        letter-spacing: 0;
        line-height: 1.4;
        @media (max-width: 1000px) {
            font-size: 32px;
        }
        @media (max-width: 800px) {
            font-size: 28px;
        }
        @media (max-width: 600px) {
            font-size: 24px;
        }
    }
}
/* header_main */
.header_main {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%;
    @media (max-width: 800px) {
        position: fixed;
        height: 80px;
        background: #fff;
    }
    @media (max-width: 600px) {
        height: 58px;
    }
    &.on_scroll {
        position: fixed;
        top: -82px;
        @media (max-width: 800px) {
            top: 0;
        }
        .header_nav_menu {
            a {
                color: #101010;
                &:hover {
                    color: var(--color-main);
                }
            }
        }
    }
    .inner {
        padding-top: 10px;
        padding-right: 24px;
        padding-bottom: 10px;
        display: flex;
        justify-content: space-between;
        border-bottom: 2px solid #fff;
        @media (max-width: 800px) {
            padding: 0;
            padding-left: 24px;
            height: 100%;
            align-items: center;
            border: none;
        }
        @media (max-width: 500px) {
            padding-left: 16px;
        }
        .logo {
            padding-top: 8px;
            padding-left: 80px;
            @media (max-width: 1100px) {
                padding-left: 48px;
            }
            @media (max-width: 800px) {
                padding: 0;
            }

            a {
                img {
                    height: 46px;
                    width: auto;
                    @media (max-width: 1000px) {
                        height: 38px;
                    }
                    @media (max-width: 800px) {
                        height: 32px;
                    }
                }
            }
        }
        .cta {
            display: flex;
            justify-content: end;
            align-items: center;
            @media (max-width: 800px) {
                display: none;
            }
            .tel {
                padding-top: 4px;
                display: flex;
                @media (max-width: 900px) {
                    display: none;
                }
                .number {
                    display: flex;
                    font-size: 32px;
                    color: #fff;
                    font-family: var(--font-en);
                    font-weight: 700;
                    letter-spacing: 0;
                    .icon {
                        width: 24px;
                        svg {
                            width: 100%;
                            height: auto;
                        }
                    }
                }
                .data {
                    margin-left: 8px;
                    padding-top: 4px;
                    font-size: 8px;
                    line-height: 1.6em;
                    font-weight: 500;
                    color: #fff;
                    letter-spacing: 0;
                }
            }
            .link_btn {
                margin-left: 34px;
                height: 60px;
                display: flex;
                a {
                    height: 100%;
                    width: 98px;
                    display: flex;
                    align-items: center;
                    align-content: center;
                    justify-content: center;
                    flex-wrap: wrap;
                    font-size: 10px;
                    color: #fff;
                    background: #fff;
                    text-align: center;
                    color: #101010;
                    font-weight: 700;
                    transition: all 0.3s;
                    svg {
                        margin-bottom: 6px;
                        width: 12px;
                        height: 12px;
                        path {
                            stroke: #101010;
                            transition: all 0.3s;
                        }
                    }
                    span {
                        width: 100%;
                        display: block;
                    }
                    &:nth-of-type(2) {
                        background: #ffe75f;
                        color: #101010;
                        svg {
                            path {
                                stroke: #101010;
                            }
                        }
                        &:hover {
                            background: #101010;
                            color: #ffe75f;
                            svg {
                                path {
                                    stroke: #ffe75f;
                                }
                            }
                        }
                    }
                    &:hover {
                        background: var(--color-main);
                        color: #fff;
                        svg {
                            path {
                                stroke: #fff;
                            }
                        }
                    }
                }
            }
        }
    }
    .header_nav_menu {
        padding-right: 4px;
        @media (max-width: 1000px) {
            padding-right: 16px;
        }
        @media (max-width: 800px) {
            display: none;
        }
        > ul {
            display: flex;
            justify-content: end;
            li {
                a {
                    padding: 0 20px;
                    height: 80px;
                    display: flex;
                    align-items: center;
                    color: #fff;
                    font-weight: 700;
                    font-size: 14px;
                    line-height: 1.5;
                    letter-spacing: 0;
                    transition: all 0.3s;
                    @media (max-width: 1000px) {
                        padding: 0 12px;
                        height: 64px;
                        font-size: 13px;
                    }
                    &:hover {
                        color: var(--color-main);
                    }
                }
            }
        }
    }
    .hum_btn {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 1;
        width: 80px;
        height: 100%;
        display: none;
        align-items: center;
        justify-content: center;
        /* background: #000; */
        @media (max-width: 800px) {
            display: flex;
        }
        @media (max-width: 600px) {
            width: 64px;
        }
        &.true {
            .in {
                div {
                    &:nth-of-type(1) {
                        bottom: 0;
                        transform: rotate(45deg);
                    }
                    &:nth-of-type(2) {
                        opacity: 0;
                    }
                    &:nth-of-type(3) {
                        top: 0;
                        transform: rotate(-45deg);
                    }
                }
            }
        }
        .in {
            position: relative;
            width: 32px;
            height: 32px;
            /* background: red; */
            @media (max-width: 600px) {
                width: 24px;
                height: 24px;
            }
            div {
                position: absolute;
                left: 0;
                right: 0;
                margin: auto;
                width: 100%;
                height: 5px;
                border-radius: 2em;
                background: #ffe75f;
                transition: 0.3s;
                @media (max-width: 600px) {
                    height: 4px;
                }
                &:nth-of-type(1) {
                    top: 0px;
                    bottom: calc(100% - 5px);
                    @media (max-width: 600px) {
                        bottom: calc(100% - 4px);
                    }
                }
                &:nth-of-type(2) {
                    top: 0;
                    bottom: 0;
                }
                &:nth-of-type(3) {
                    top: calc(100% - 5px);
                    bottom: 0;
                    @media (max-width: 600px) {
                        top: calc(100% - 4px);
                    }
                }
            }
        }
    }
}
body:has(.drawer_menu.true),
html:has(.drawer_menu.true) {
    overflow: hidden;
}
/* drawer_menu */
.drawer_menu {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 998;
    padding: 100px 48px;
    width: 100%;
    height: 100%;
    background: #fff;
    overflow-y: auto;
    visibility: hidden;
    opacity: 0;
    transition: all 0.3s;
    @media (max-width: 500px) {
        padding: 100px 24px 100px 24px;
        font-size: 16px;
    }
    &.true {
        opacity: 1;
        visibility: visible;
    }
    > nav {
        > ul {
            > li {
                a {
                    padding: 1.3em 0;
                    display: block;
                    color: var(--color-main);
                    font-size: 18px;
                    line-height: 1.5em;
                    font-weight: 700;
                    @media (max-width: 500px) {
                        font-size: 16px;
                    }
                }
            }
        }
        .cta {
            margin-top: 32px;
            padding: 0 12px;
            width: 100%;
            display: flex;
            gap: 1px;
            @media (max-width: 650px) {
                display: block;
            }
            a {
                width: 100%;
                height: 64px;
                display: flex;
                flex: 1;
                align-items: center;
                justify-content: center;
                background: #000;
                font-weight: 700;
                color: #fff;
                &:nth-of-type(2) {
                    background: #ffe75f;
                    color: #101010;
                }
                svg {
                    margin-right: 8px;
                    width: 16px;
                    height: 16px;
                }
                + a {
                    @media (max-width: 650px) {
                        margin-top: 24px;
                    }
                }
            }
        }
    }
}
/* sec_fv */
.sec_fv {
    position: relative;
    z-index: 10;
    width: 100%;
    height: 880px;

    @media (max-width: 1500px) {
        height: 826px;
    }
    @media (max-width: 1200px) {
        height: 726px;
    }
    @media (max-width: 1000px) {
        height: 626px;
    }
    @media (max-width: 900px) {
        height: 586px;
    }
    @media (max-width: 800px) {
        margin-top: 80px;
        height: auto;
    }
    @media (max-width: 600px) {
        margin-top: 58px;
    }
    &::after {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        height: 100%;
        width: 100%;
        content: "";
        display: block;
        background: url(../../templates/sec_fv/img/bg_pc.svg) no-repeat;
        background-size: contain;
        background-position: top left;
    }
    .inner {
        padding-top: 149px;
        padding-left: 80px;
        @media (max-width: 1100px) {
            padding-left: 48px;
        }
        @media (max-width: 900px) {
            padding-left: 24px;
        }
        h2 {
            display: flex;
            flex-wrap: wrap;
            .sub {
                padding: 10px 24px;
                display: block;
                background: linear-gradient(90deg, #003f85 0%, #0667d4 100%);
                font-weight: 700;
                line-height: 1.4;
                border-radius: 5em;
                color: #fff;
                letter-spacing: 0;
                @media (max-width: 1000px) {
                    font-size: 14px;
                }
            }
            .main {
                margin: 0.6em 0;
                width: 100%;
                display: block;
                font-size: 40px;
                font-weight: 700;
                color: var(--color-main);
                line-height: 1.6em;
                letter-spacing: 0;
                @media (max-width: 1200px) {
                    font-size: 32px;
                }
                @media (max-width: 1000px) {
                    font-size: 28px;
                }
            }
        }
        .cont_img {
            margin-top: 16px;
            width: 708px;
            height: auto;
            @media (max-width: 1200px) {
                width: 600px;
            }
            @media (max-width: 1000px) {
                margin-top: 4px;
                width: 480px;
            }
            @media (max-width: 900px) {
                width: 440px;
            }
            img {
                width: 100%;
            }
        }
        h3 {
            position: relative;
            z-index: 10;
            margin-top: 24px;
            font-size: 24px;
            color: #004ca1;
            line-height: 2;
            letter-spacing: 0;
            @media (max-width: 1200px) {
                font-size: 23px;
            }
            @media (max-width: 1000px) {
                margin-top: 16px;
                font-size: 22px;
            }
            @media (max-width: 900px) {
                font-size: 20px;
            }
            .text {
                position: relative;
                z-index: 10;
                &::before,
                &::after {
                    position: absolute;
                    top: 0;
                    bottom: 0;
                    left: calc(100% + 4px);
                    z-index: -1;
                    margin: auto;
                    width: 35px;
                    height: 2px;
                    content: "";
                    display: block;
                    background: #004ca1;
                }
                &::after {
                    left: calc(100% + 4px + 35px);
                    z-index: 1;
                    width: 261px;
                    background: #fff;
                }
            }
        }
    }
    ul.tag_list {
        margin-top: 9px;
        max-width: 700px;
        display: flex;
        flex-wrap: wrap;
        gap: 10px 8px;
        @media (max-width: 800px) {
            margin: 0;
            max-width: initial;
            gap: 0.7vw;
        }
        li {
            padding: 8px 6px;
            font-size: 14px;
            color: #004ca1;
            border: 1px solid #004ca1;
            line-height: 1;
            letter-spacing: 0;
            background: #fff;
            font-family: var(--font-en);
            font-weight: 700;
            @media (max-width: 900px) {
                font-size: 12px;
            }
            @media (max-width: 800px) {
                font-size: 3.55vw;
            }
        }
    }
    .inner_sp {
        display: none;
        @media (max-width: 800px) {
            display: block;
            padding: 3vw;
        }
    }
    .main_image {
        position: absolute;
        top: 0;
        right: 0;
        z-index: -1;
        height: 100%;
        width: calc(100% - 320px);
        @media (max-width: 1100px) {
            width: calc(100% - 290px);
        }
        @media (max-width: 900px) {
            width: calc(100% - 242px);
        }
        @media (max-width: 800px) {
            position: static;
            width: 100%;
        }
        img {
            height: 100%;
            width: 100%;
            object-fit: cover;
            object-position: top left;
        }
    }
}
/* sec_problem */
.sec_problem {
    position: relative;
    margin-top: 146px;
    @media (max-width: 600px) {
        margin-top: 80px;
    }
    .ttl_ptn_1 {
        position: relative;
        z-index: 11;
        margin: 0 auto;
        margin-top: 0;
        margin-bottom: -69px;
        max-width: 1110px;
        @media (max-width: 600px) {
            margin-bottom: -60px;
        }
    }
    .wrap {
        position: relative;
        max-width: 1440px;
        padding: 0 150px;
        padding-top: 100px;
        padding-bottom: 108px;
        z-index: 10;
        margin: 0 auto;
        clip-path: polygon(0 0, 100% 0, 95% 100%, 0 100%);
        @media (max-width: 1400px) {
            padding: 0 40px;
            padding-top: 100px;
            padding-bottom: 108px;
            clip-path: polygon(0 0, 100% 0, 98% 100%, 0 100%);
        }
        @media (max-width: 600px) {
            padding: 80px 20px;
        }
        &::after {
            position: absolute;
            top: 0;
            left: 0;
            z-index: -2;
            width: 100%;
            height: 100%;
            display: block;
            content: "";
            background: #f6f6f6;
        }
        ul.worries_list_1 {
            margin: 0 auto;
            margin-bottom: 140px;
            padding-top: 88px;
            display: flex;
            align-items: start;
            justify-content: space-between;
            @media (max-width: 1400px) {
                gap: 32px;
                justify-content: center;
            }
            @media (max-width: 1100px) {
                gap: 16px;
            }
            @media (max-width: 900px) {
                margin-bottom: 100px;
                flex-wrap: wrap;
            }
            @media (max-width: 600px) {
                padding-top: 24px;
            }
            li {
                padding: 24px;
                width: 340px;
                max-width: 340px;
                min-height: 340px;
                display: flex;
                justify-content: center;
                flex-wrap: wrap;
                background: #fff;
                @media (max-width: 1200px) {
                    width: auto;
                }
                @media (max-width: 800px) {
                    width: 100%;
                }
                &:nth-of-type(2) {
                    margin-top: -60px;
                    @media (max-width: 900px) {
                        margin-top: initial;
                    }
                }
                figure {
                    width: var(--sec-problem-img-width, 150px);
                    img {
                        width: 100%;
                        height: auto;
                        object-fit: contain;
                    }
                }
                p {
                    width: 100%;
                    line-height: 2;
                    font-size: 24px;
                    letter-spacing: 0;
                    @media (max-width: 1000px) {
                        font-size: 20px;
                    }
                    u {
                        font-weight: 700;
                        color: #fff;
                        background: #0e204c;
                        text-decoration: none;
                    }
                }
            }
        }
        ul.worries_list_2 {
            margin-top: 62px;
            padding-right: 8px;
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 40px;
            @media (max-width: 1200px) {
                gap: 24px;
            }
            @media (max-width: 1100px) {
                margin: 0 auto;
                margin-top: 62px;
                max-width: 600px;
                margin-top: 48px;
                grid-template-columns: repeat(2, 1fr);
            }
            @media (max-width: 450px) {
                margin-left: -10px;
                margin-right: -10px;
                width: calc(100% + 20px);
                gap: 16px;
            }
            li {
                position: relative;
                z-index: 1;
                padding: 40px 12px;
                padding-top: 54px;
                min-height: 250px;
                background: #fff;
                @media (max-width: 1200px) {
                    min-height: 220px;
                }
                @media (max-width: 500px) {
                    padding: 32px 4px;
                    min-height: auto;
                }
                @media (max-width: 420px) {
                    padding: 24px 4px;
                }
                &::after {
                    position: absolute;
                    top: 10px;
                    left: 10px;
                    z-index: -1;
                    width: 100%;
                    height: 100%;
                    display: block;
                    content: "";
                    border: 1px solid #fff;
                    @media (max-width: 450px) {
                        top: 6px;
                        left: 6px;
                    }
                }
                .icon {
                    margin: 0 auto;
                    width: 32px;
                    height: 32px;
                    svg {
                        width: 100%;
                        height: 100%;
                    }
                }
                p {
                    margin-top: 40px;
                    font-size: 16px;
                    text-align: center;
                    color: var(--color-main);
                    font-weight: 700;
                    line-height: 2;
                    @media (max-width: 1200px) {
                        letter-spacing: 0;
                        font-size: 14px;
                    }
                    @media (max-width: 500px) {
                        margin-top: 24px;
                        font-size: 12px;
                    }
                    @media (max-width: 420px) {
                        margin-top: 20px;
                    }
                }
            }
        }
        .bg_1,
        .bg_2 {
            position: absolute;
            width: 55%;
            z-index: -1;
            @media (max-width: 600px) {
                width: 100%;
            }
            img {
                width: 100%;
                height: auto;
                object-fit: contain;
            }
        }
        .bg_1 {
            top: 0;
            left: 0;
        }
        .bg_2 {
            bottom: 0;
            right: 0;
        }
    }
    .next_icon {
        margin: 75px 0 60px 0;
        display: flex;
        justify-content: center;
        @media (max-width: 600px) {
            margin: 50px 0 40px 0;
        }
        svg {
            width: 126px;
            height: auto;
            @media (max-width: 600px) {
                width: 100px;
            }
        }
    }
    .lead_text_ptn_1 {
        max-width: calc(100% - 32px);
    }
}
/* sec_solution */
.sec_solution {
    margin-top: 140px;
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        padding-top: 1px;
        padding-bottom: 1px;
        max-width: var(--max-width-main);
        &::after {
            position: absolute;
            top: 0;
            left: 50%;
            z-index: -2;
            transform: translateX(-50%);
            width: 100vw;
            height: 100%;
            display: block;
            content: "";
            background: var(--color-bg-blue);
        }
        h3.ttl_ptn_3 {
            margin: 0 auto;
            margin-top: 108px;
            max-width: calc(100% - 40px);
            @media (max-width: 1000px) {
                margin-top: 80px;
            }
        }
        .ttl_ptn_2 {
            position: relative;
            z-index: 20;
        }
        .solution_list {
            margin: 0 auto;
            margin-top: 60px;
            margin-bottom: 142px;
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 58px;
            @media (max-width: 1250px) {
                padding: 0 24px;
                gap: 24px;
            }
            @media (max-width: 800px) {
                max-width: 400px;
                grid-template-columns: repeat(1, 1fr);
            }
            li {
                .no {
                    position: relative;
                    z-index: 10;
                    margin-bottom: -10px;
                    display: flex;
                    justify-content: center;
                    .text {
                        padding: 5px 8px;
                        background: var(--this-main-color);
                        border-radius: 3em;
                        font-family: var(--font-en);
                        font-size: 14px;
                        font-weight: 700;
                        color: #fff;
                        line-height: 1em;
                        letter-spacing: 0;
                    }
                }
                .in_1 {
                    position: relative;
                    padding: 40px 20px 32px 20px;
                    background: #fff;
                    border-radius: 32px 32px 0 0;
                    &::after {
                        position: absolute;
                        top: calc(100% - 0.5px);
                        right: 0;
                        left: 0;
                        width: 0;
                        height: 0;
                        margin: auto;
                        display: block;
                        border-left: 12px solid transparent;
                        border-right: 12px solid transparent;
                        border-top: 12px solid #fff;
                        content: "";
                    }

                    h4 {
                        color: var(--this-main-color);
                        text-align: center;
                        font-weight: 700;
                        line-height: 1.5;
                    }
                    figure {
                        margin-top: 24px;
                        width: 100%;
                        img {
                            width: 100%;
                            height: auto;
                        }
                    }
                }
                .in_2 {
                    padding: 32px 16px;
                    min-height: 240px;
                    color: #fff;
                    background: var(--this-main-color);
                    border-radius: 0 0 32px 32px;
                    font-size: 16px;
                    line-height: 2;
                    @media (max-width: 1100px) {
                        font-size: 14px;
                    }
                    @media (max-width: 800px) {
                        min-height: initial;
                    }
                }
                .point {
                    margin-top: 16px;
                    padding: 0 1em;
                    font-size: 10px;
                    line-height: 1.6;
                    text-align: center;
                    @media (max-width: 370px) {
                        font-size: 9px;
                    }
                }
            }
        }
        > p.btm_text {
            margin: 58px auto 36px auto;
            max-width: calc(100% - 48px);
            text-align: center;
            font-size: 24px;
            font-weight: 700;
            color: var(--color-main);
            line-height: 2;
            @media (max-width: 1000px) {
                font-size: 20px;
            }
            @media (max-width: 800px) {
                font-size: 18px;
            }
            @media (max-width: 600px) {
                font-size: 16px;
            }
        }
    }
    .next_btm {
        margin: 0 auto;
        width: 100%;
        max-width: 1440px;
        height: 80px;
        background: var(--color-bg-blue);
        clip-path: polygon(
            0 0,
            /* 左上 */ 100% 0,
            /* 右上 */ 100% 0,
            /* 右側（矢印の始まり） */ 50% 100%,
            /* 下の中央（矢印の先端） */ 0 0 /* 左側（矢印の始まり） */
        );
        @media (max-width: 900px) {
            height: 60px;
        }
        @media (max-width: 600px) {
            height: 48px;
        }
    }
}
.bg_slide {
    position: relative;
    margin-top: -240px;
    margin-bottom: -86px;
    height: 400px;
    width: 100%;
    @media (max-width: 900px) {
        margin-top: -200px;
    }
    @media (max-width: 800px) {
        margin-top: -160px;
        height: 300px;
    }
    img {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: auto;
        object-fit: contain;
        @media (max-width: 800px) {
            top: -10%;
            left: -30%;
            right: -30%;
            width: 160%;
        }
        @media (max-width: 450px) {
            top: 0;
        }
    }
}
.example_slides_wrap {
    position: relative;
    z-index: 10;
    margin-left: calc((100% - 100vw) / 2);
    width: 100vw;
    max-width: 100vw;
}
.example_slides {
    position: relative;
    width: 100%;
    overflow: initial !important;
    .swiper-wrapper {
        .swiper-slide {
            height: 100%;
            background: #fff;
            img {
                display: block;
                width: 100%;
                height: auto;
                object-fit: contain;
            }
        }
    }
    .swiper-button-prev,
    .swiper-button-next {
        top: 0;
        bottom: 0;
        margin: auto;
        height: 90px;
        @media (max-width: 500px) {
            height: 40px;
        }
        &::after {
            display: none;
        }
    }
    .swiper-button-prev {
        left: 10%;
        @media (max-width: 800px) {
            left: 3%;
        }
        @media (max-width: 500px) {
            left: 2%;
        }
    }
    .swiper-button-next {
        right: 10%;
        @media (max-width: 800px) {
            right: 3%;
        }
        @media (max-width: 500px) {
            right: 2%;
        }
    }
}
/* sec_suggestion */
.sec_suggestion {
    margin-top: 140px;
    @media (max-width: 600px) {
        margin-top: 80px;
    }
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        max-width: 1440px;
        display: flex;
        justify-content: space-between;
        @media (max-width: 820px) {
            flex-wrap: wrap;
        }
        .text_in {
            padding-left: 80px;
            padding-right: 24px;
            padding-bottom: 32px;
            width: 47%;
            @media (max-width: 1200px) {
                padding-left: 48px;
            }
            @media (max-width: 1000px) {
                padding-left: 32px;
            }
            @media (max-width: 820px) {
                padding: 0 32px 32px 48px 32px;
                width: 100%;
            }
            h2 {
                img {
                    height: 54px;
                    width: auto;
                    @media (max-width: 1350px) {
                        height: 48px;
                    }
                    @media (max-width: 600px) {
                        height: 32px;
                    }
                }
            }
            h3 {
                /* テキストグラデーション */
                margin-top: 40px;
                font-size: 32px;
                font-weight: 900;
                letter-spacing: 0.04em;
                background: linear-gradient(90deg, #0667d4 0%, #003f85 100%);
                -webkit-background-clip: text;
                -webkit-text-fill-color: transparent;
                background-clip: text;
                text-fill-color: transparent;
                @media (max-width: 1350px) {
                    font-size: 28px;
                }
                @media (max-width: 1150px) {
                    font-size: 24px;
                }
                @media (max-width: 1000px) {
                    margin-top: 32px;
                    font-size: 20px;
                }
            }
            p {
                max-width: 540px;
                margin-top: 2em;
                font-size: 24px;
                line-height: 2.25;
                letter-spacing: 0.04em;
                font-weight: 700;
                @media (max-width: 1350px) {
                    font-size: 20px;
                }
                @media (max-width: 1150px) {
                    font-size: 18px;
                }
                @media (max-width: 1000px) {
                    margin-top: 32px;
                    font-size: 16px;
                }
                @media (max-width: 900px) {
                    margin-top: 32px;
                    font-size: 14px;
                }
                @media (max-width: 820px) {
                    max-width: 100%;
                }
            }
        }
        .image {
            width: 52.7%;
            @media (max-width: 820px) {
                width: 100%;
            }
            img {
                width: 100%;
                height: auto;
            }
        }
    }
}
/* sec_cta_1 */
.sec_cta_1 {
    background: linear-gradient(90deg, #003f85 0%, #020910 100%);
    color: #fff;
    text-align: center;
    .wrap {
        position: relative;
        z-index: 10;
        padding: 60px 24px 98px 24px;
        margin: 0 auto;
        max-width: 1440px;
        width: 100%;
        @media (max-width: 500px) {
            padding: 56px 24px 64px 24px;
        }
        &::before,
        &::after {
            position: absolute;
            top: 0;
            z-index: -1;
            width: 45%;
            height: 100%;
            display: block;
            content: "";
            background-image: url("../../templates/sec_cta_1/img/bg.svg");
            background-size: contain;
            background-repeat: no-repeat;
            @media (max-width: 600px) {
                width: 80%;
            }
        }
        &::before {
            left: 0;
            background-position: left center;
            @media (max-width: 600px) {
                background-position: left top;
            }
        }
        &::after {
            right: 0;
            background-position: right center;
            @media (max-width: 600px) {
                background-position: left bottom;
            }
        }
        h2 {
            font-size: 24px;
            font-weight: 700;
            line-height: 2;
            @media (max-width: 500px) {
                font-size: 20px;
            }
        }
        > p {
            margin: 1.5em 0;
            font-size: 16px;
            line-height: 2;
            @media (max-width: 700px) {
                font-size: 14px;
            }
        }
        .lead {
            p {
                display: flex;
                align-items: end;
                justify-content: center;
                font-size: 16px;
                font-weight: 700;
                @media (max-width: 700px) {
                    font-size: 14px;
                }
                .small {
                    font-size: 0.875em;
                    line-height: 1.4;
                    text-align: right;
                    white-space: nowrap;
                }
                .no {
                    font-size: 5em;
                    color: #ffe75f;
                    font-weight: 900;
                    font-family: var(--font-en);
                    line-height: 1;
                }
                .large {
                    font-size: 2em;
                    line-height: 1.4;
                    white-space: nowrap;
                }
            }
        }
        .btn {
            margin-top: 30px;
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1px;
            @media (max-width: 700px) {
                grid-template-columns: repeat(1, 1fr);
                gap: 24px;
            }
            .in {
                display: flex;
                justify-content: end;
                @media (max-width: 700px) {
                    justify-content: center;
                }
                &:nth-of-type(2) {
                    justify-content: start;
                    @media (max-width: 700px) {
                        justify-content: center;
                    }
                    a {
                        background: #ffe75f;
                    }
                    &:hover {
                        a {
                            background: #101010;
                            color: #ffe75f;
                            .icon {
                                svg {
                                    path {
                                        stroke: #ffe75f;
                                    }
                                }
                            }
                        }
                    }
                }
                a {
                    width: 312px;
                    height: 52px;
                    display: flex;
                    align-items: center;
                    justify-content: center;
                    color: #101010;
                    font-size: 16px;
                    line-height: 2;
                    background: #fff;
                    font-weight: 700;
                    transition: all 0.3s;
                    .icon {
                        margin-right: 8px;
                        width: 16px;
                        aspect-ratio: 1;
                        svg {
                            width: 100%;
                            height: auto;
                            transform: translateY(2px);
                            transition: all 0.3s;
                            path {
                                transition: all 0.3s;
                            }
                        }
                    }
                    &:hover {
                        background: #101010;
                        color: #fff;
                        .icon {
                            svg {
                                path {
                                    stroke: #fff;
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
/* sec_point */
.sec_point {
    margin-top: 140px;
    margin-bottom: 110px;
    padding: 0 80px;
    @media (max-width: 1200px) {
        padding: 0 40px;
    }
    @media (max-width: 600px) {
        margin-top: 80px;
        margin-bottom: 80px;
        padding: 0 24px;
    }
    @media (max-width: 500px) {
        padding: 0 16px;
    }
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        max-width: var(--max-width-main);
        > h3:not([class]) {
            margin-top: 70px;
            display: grid;
            grid-template-columns: 90px calc(100% - 90px);
            @media (max-width: 1000px) {
                grid-template-columns: 80px calc(100% - 80px);
            }
            @media (max-width: 600px) {
                grid-template-columns: 56px calc(100% - 56px);
            }
            .no {
                position: relative;
                z-index: 10;
                padding-left: 20px;
                display: block;
                font-size: 48px;
                font-weight: 700;
                letter-spacing: 0.08em;
                color: var(--color-main);
                font-family: var(--font-en);
                @media (max-width: 1000px) {
                    font-size: 40px;
                }
                @media (max-width: 600px) {
                    padding-left: 12px;
                    font-size: 28px;
                }
                .icon {
                    position: absolute;
                    top: -24px;
                    left: 0;
                    z-index: -1;
                    width: 26px;
                    @media (max-width: 600px) {
                        top: -20px;
                        width: 20px;
                    }
                    icon {
                        width: 100%;
                        height: auto;
                    }
                }
            }
            .main {
                padding-top: 0.3em;
                font-size: 24px;
                font-weight: 700;
                line-height: 1.666;
                letter-spacing: 0.04em;
                color: var(--color-main);
                @media (max-width: 1000px) {
                    font-size: 20px;
                }
                @media (max-width: 600px) {
                    padding-top: 0;
                    font-size: 18px;
                }
            }
            + p {
                margin-top: 1em;
                margin-bottom: 54px;
                padding-left: 90px;
                line-height: 2;
                letter-spacing: 0.04em;
                font-size: 16px;
                font-weight: 500;
                @media (max-width: 1000px) {
                    padding-left: 80px;
                    font-size: 14px;
                }
                @media (max-width: 600px) {
                    margin-bottom: 40px;
                    padding-left: 56px;
                }
            }
        }
    }
}
/* case_list_1 */
.case_list_1 {
    position: relative;
    margin-top: 48px;
    padding: 42px 48px 70px 48px;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
    @media (max-width: 1100px) {
        padding: 42px 24px 50px 24px;
    }
    &.last {
        margin-bottom: 148px;
        @media (max-width: 600px) {
            margin-bottom: 80px;
        }
    }
    .icon_point {
        position: absolute;
        bottom: 8px;
        right: 8px;
        width: 26px;
        height: 26px;
        transform: rotate(180deg);
        svg {
            width: 100%;
            height: auto;
        }
    }
    > h4 {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 16px;
        font-weight: 700;
        color: var(--color-main);
        letter-spacing: 0.04em;
        .icon {
            margin-right: 0.5em;
            width: 1em;
            height: 1em;
            svg {
                height: 100%;
                width: auto;
            }
        }
    }
    > ul {
        margin-top: 58px;
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 40px;
        @media (max-width: 1200px) {
            gap: 24px;
        }
        @media (max-width: 1100px) {
            margin-top: 32px;
            gap: 16px;
        }
        @media (max-width: 800px) {
            grid-template-columns: repeat(1, 1fr);
            gap: 24px;
        }
        li {
            &:nth-of-type(2) {
                > h5 {
                    background: linear-gradient(90deg, var(--color-green) 0%, #003f85 100%);
                }
            }
            &:nth-of-type(3) {
                > h5 {
                    background: linear-gradient(90deg, #003f85 0%, #020910 100%);
                }
            }
            > h5 {
                padding: 5px 24px;
                background: linear-gradient(90deg, #2adbde 0%, var(--color-green) 100%);
                color: #fff;
                font-weight: 700;
                line-height: 1.8;
                @media (max-width: 1200px) {
                    padding: 5px 16px;
                }
                .sub {
                    display: flex;
                    align-items: center;
                    font-size: 12px;
                    &::before {
                        width: 24px;
                        height: 24px;
                        content: "";
                        display: block;
                        background: url(../../templates/sec_point/img/ai.svg) no-repeat center center;
                        background-size: contain;
                    }
                }
                .main {
                    display: block;
                    font-size: 14px;
                }
            }
            > ul {
                margin-top: 1.2em;
                padding: 0 1.5em;
                @media (max-width: 1200px) {
                    padding: 0 1em;
                }
                li {
                    position: relative;
                    padding-left: 1.4em;
                    font-size: 14px;
                    letter-spacing: 0.04em;
                    font-weight: 500;
                    line-height: 1.6em;
                    color: var(--color-main);
                    + li {
                        margin-top: 1em;
                    }
                    &::before {
                        position: absolute;
                        top: 0.3em;
                        left: 0;
                        width: 1em;
                        height: 1em;
                        content: "";
                        display: block;
                        background: url(../../templates/sec_point/img/check.svg) no-repeat center center;
                        background-size: contain;
                    }
                }
            }
        }
    }
}
/* three_mistakes */
.three_mistakes {
    position: relative;
    z-index: 10;
    margin-top: 60px;
    margin-bottom: 145px;
    padding: 48px 36px 60px 36px;
    box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
    overflow: hidden;
    @media (max-width: 600px) {
        margin-top: 32px;
        margin-bottom: 80px;
        padding: 48px 16px 40px 16px;
    }
    .ttl_ptn_2 {
        position: relative;
        z-index: 30;
    }
    dl.conclusion_list {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        margin-top: 64px;
        margin-bottom: 104px;
        padding-left: 10px;
        max-width: 930px;
        @media (max-width: 1000px) {
            max-width: 600px;
            padding-left: 0;
        }
        .row {
            display: grid;
            grid-template-columns: 400px calc(100% - 400px);
            align-items: center;
            @media (max-width: 1000px) {
                grid-template-columns: repeat(1, 1fr);
                gap: 8px;
            }
            + .row {
                margin-top: 32px;
            }
            dt {
                position: relative;
                padding-right: 80px;
                display: flex;
                align-items: start;
                font-size: 16px;
                font-weight: 700;
                line-height: 1.6;
                color: #101010;
                @media (max-width: 1000px) {
                    padding-right: 0;
                }
                &::before {
                    width: 24px;
                    height: 24px;
                    margin-right: 8px;
                    content: "";
                    display: block;
                    background: url(../../templates/sec_point/img/x-square.svg) no-repeat center center;
                }
                &::after {
                    position: absolute;
                    top: 0;
                    right: 32px;
                    bottom: 0;
                    margin: auto;
                    width: 60px;
                    height: auto;
                    display: block;
                    content: "";
                    background: url(../../templates/sec_point/img/arrow_pc.svg) no-repeat center center;
                    background-size: contain;
                    @media (max-width: 1000px) {
                        position: static;
                        margin-left: 16px;
                        margin-bottom: 0px;
                        height: 16px;
                        width: 16px;
                        background: url(../../templates/sec_point/img/arrow_sp.svg) no-repeat center center;
                        background-size: contain;
                    }
                }
            }
            dd {
                .in {
                    padding: 16px;
                    padding-right: 8px;
                    color: #fff;
                    font-weight: 700;
                    border-radius: 8px;
                    background: linear-gradient(90deg, #ee4c4c 0%, #ffae4a 100%);
                    @media (max-width: 600px) {
                        padding-left: 8px;
                    }
                    h5 {
                        position: relative;
                        padding-left: 28px;
                        display: flex;
                        align-items: start;
                        font-size: 24px;
                        line-height: 1.4;
                        letter-spacing: 0.04em;
                        @media (max-width: 1200px) {
                            font-size: 22px;
                        }
                        @media (max-width: 600px) {
                            font-size: 18px;
                        }
                        @media (max-width: 500px) {
                            font-size: 16px;
                        }
                        &::before {
                            position: absolute;
                            top: 6px;
                            left: 0;
                            width: 24px;
                            height: 24px;
                            content: "";
                            display: block;
                            background: url(../../templates/sec_point/img/check_2.svg) no-repeat center center;
                        }
                    }
                    p.ex {
                        margin-top: 4px;
                        padding-left: 28px;
                        font-size: 16px;
                        line-height: 1.8;
                        letter-spacing: 0.04em;
                        @media (max-width: 1200px) {
                            font-size: 14px;
                        }
                        @media (max-width: 600px) {
                            font-size: 12px;
                        }
                    }
                }
            }
        }
    }
    .icon_point {
        position: absolute;
        bottom: 10px;
        right: 10px;
        width: 26px;
        height: 26px;
        svg {
            width: 100%;
            height: 100%;
            transform: rotate(180deg);
        }
    }
}
/* approach_list */
.approach_list {
    position: relative;
    z-index: 1;
    margin-top: 42px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    @media (max-width: 1200px) {
        gap: 16px;
    }
    @media (max-width: 900px) {
        grid-template-columns: repeat(1, 1fr);
    }
    .bg_img {
        position: absolute;
        top: -240px;
        left: 0;
        z-index: -1;
        width: 100%;
        @media (max-width: 600px) {
            top: -203px;
            left: -38%;
            width: 170%;
        }
        @media (max-width: 500px) {
            top: -218px;
        }
        img {
            width: 100%;
            height: auto;
            object-fit: contain;
        }
    }
    > li {
        padding: 30px 10px 44px 10px;
        max-width: 400px;
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        border: 1px solid var(--color-main);
        background: #fff;
        @media (max-width: 900px) {
            margin: 0 auto;
        }
        h5 {
            position: relative;
            z-index: 1;
            margin-bottom: 12px;
            width: 100%;
            max-width: calc(100% - 48px);
            display: flex;
            justify-content: center;
            .text {
                position: relative;
                padding: 0 0.3em;
                background: #fff;
                font-size: 24px;
                font-weight: 700;
                color: var(--color-main);
                @media (max-width: 1200px) {
                    font-size: 22px;
                }
                @media (max-width: 1000px) {
                    font-size: 20px;
                }
            }
            &::before,
            &::after {
                position: absolute;
                top: 0;
                bottom: 0;
                z-index: -1;
                margin: auto;
                content: "";
                display: block;
            }
            &::before {
                left: -10px;
                width: calc(100% + 15px);
                height: 1px;
                background: var(--color-main);
            }
            &::after {
                right: -8px;
                /* 三角を作る */
                width: 0;
                height: 0;
                border-top: 3px solid transparent;
                border-bottom: 3px solid transparent;
                border-left: 6px solid var(--color-main);
            }
        }
        p:not([class]) {
            margin: 1.7em 0;
            padding: 4px 8px;
            font-size: 12px;
            line-height: 1.8;
            letter-spacing: 0.04em;
            color: #fff;
            background: linear-gradient(90deg, #003f85 0%, #020910 100%);
        }
        .down {
            width: 100%;
            &::before {
                content: "";
                display: block;
                width: 0;
                height: 0;
                margin: 0 auto;
                border-left: 24px solid transparent;
                border-right: 24px solid transparent;
                border-top: 14px solid #d9d9d9;
            }
        }
        p.goal {
            margin-top: 1.2em;
            padding: 0.8em 0.5em;
            width: 100%;
            max-width: calc(100% - 40px);
            font-size: 14px;
            color: #fff;
            background: linear-gradient(90deg, #2adbde 0%, #1b85b3 100%);
            text-align: center;
            line-height: 1.6em;
            font-weight: 600;
            @media (max-width: 1100px) {
                font-size: 12px;
            }
        }
    }
}
/* achievements_list_1 */
.achievements_list_1 {
    margin-bottom: 135px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 48px 40px;
    @media (max-width: 1200px) {
        grid-template-columns: repeat(1, 1fr);
        gap: 32px 0;
    }
    @media (max-width: 600px) {
        margin-bottom: 80px;
    }
    .item {
        position: relative;
        padding: 32px;
        padding-left: 0;
        min-height: 360px;
        display: flex;
        justify-content: space-between;
        box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
        @media (max-width: 800px) {
            padding: 24px;
            padding-left: 0;
            display: block;
        }
        &.clm_1 {
            grid-column: span 2;
            @media (max-width: 1200px) {
                grid-column: span 1;
            }
            .text_in {
                h4 {
                    margin-bottom: 32px;
                    font-size: 24px;
                    @media (max-width: 1200px) {
                        margin-bottom: 16px;
                        font-size: 20px;
                    }
                    @media (max-width: 600px) {
                        font-size: 16px;
                    }
                }
                p {
                    font-size: 16px;
                    @media (max-width: 1200px) {
                        font-size: 14px;
                    }
                }
            }
        }
        .text_in {
            width: 53.5%;
            @media (max-width: 800px) {
                width: 100%;
            }
        }
        .image {
            width: 46.5%;
            @media (max-width: 1200px) {
                max-height: 296px;
            }
            @media (max-width: 800px) {
                margin-top: 24px;
                width: 100%;
            }
        }
        .text_in {
            h4 {
                min-height: 76px;
                display: flex;
                align-items: start;
                font-size: 20px;
                color: #fff;
                font-weight: 700;
                @media (max-width: 1200px) {
                    font-size: 18px;
                }
                @media (max-width: 1000px) {
                    min-height: initial;
                    font-size: 20px;
                }
                @media (max-width: 600px) {
                    font-size: 16px;
                }
                .text {
                    padding: 5px 0;
                    padding-right: 40px;
                    padding-left: 24px;
                    min-height: 50px;
                    display: flex;
                    align-items: center;
                    background: linear-gradient(90deg, #003f85 0%, #0667d4 100%);
                    line-height: 1.5;
                    clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
                    @media (max-width: 500px) {
                        padding-right: 24px;
                    }
                    &.w_100 {
                        width: 100%;
                        @media (max-width: 1000px) {
                            width: auto;
                        }
                    }
                }
            }
            p {
                margin-top: 16px;
                padding: 0 24px;
                line-height: 2;
                font-size: 14px;
                @media (max-width: 800px) {
                    padding-right: 0;
                }
            }
        }
        .image {
            padding-left: 16px;
            @media (max-width: 1000px) {
                aspect-ratio: 16/9;
            }
            @media (max-width: 800px) {
                padding-left: 24px;
            }
            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }
        .icon_point {
            position: absolute;
            bottom: 8px;
            right: 8px;
            width: 26px;
            height: 26px;
            @media (max-width: 800px) {
                right: 4px;
                bottom: 4px;
                width: 22px;
                height: 22px;
            }
            svg {
                width: 100%;
                height: 100%;
                transform: rotate(180deg);
            }
        }
    }
}
/* statistics_graph */
.statistics_graph {
    margin-top: 55px;
    margin-bottom: 140px;
    display: grid;
    grid-template-columns: calc(100% - 640px) 640px;
    align-items: start;
    @media (max-width: 1100px) {
        margin-top: 40px;
        grid-template-columns: repeat(1, 1fr);
    }
    @media (max-width: 600px) {
        margin-bottom: 80px;
    }

    .text_in {
        padding-right: 54px;
        @media (max-width: 1300px) {
            padding-right: 32px;
        }
        @media (max-width: 700px) {
            padding-right: 0;
        }
        > p {
            font-size: 16px;
            line-height: 2.5;
            font-weight: 500;
            letter-spacing: 0.04em;
            color: #101010;
            @media (max-width: 1200px) {
                font-size: 14px;
            }
            @media (max-width: 1100px) {
                font-size: 16px;
            }
        }
        blockquote {
            margin-top: 50px;
            @media (max-width: 1100px) {
                margin: 32px 0;
            }
            > p {
                line-height: 2;
                font-size: 12px;
                color: #bbbbbb;
            }
        }
    }
    .graph_img {
        padding: 10px 14px;
        border: 1px solid var(--color-main);
        @media (max-width: 700px) {
            padding: 16px;
        }
        h4 {
            margin-bottom: 5px;
            line-height: 1.6;
            font-size: 16px;
            font-weight: 700;
            @media (max-width: 700px) {
                margin-bottom: 10px;
                text-align: center;
            }
        }
        .in {
            padding: 0 24px;
            display: grid;
            grid-template-columns: calc(100% - 200px) 200px;
            @media (max-width: 700px) {
                margin: 0 auto;
                padding: 0;
                max-width: 400px;
                grid-template-columns: repeat(1, 1fr);
            }

            figure {
                width: 100%;
                max-width: 350px;
                img {
                    width: 100%;
                    height: auto;
                }
            }
            ul {
                margin-top: 24px;
                padding-left: 36px;
                display: grid;
                align-items: start;
                align-content: start;
                gap: 15px;
                @media (max-width: 700px) {
                    margin-top: 16px;
                    padding-left: 30px;
                    grid-template-columns: 120px auto;
                }
                @media (max-width: 400px) {
                    padding-left: 8px;
                    gap: 15px 8px;
                }
                li {
                    display: flex;
                    align-items: center;
                    font-size: 10px;
                    font-weight: 700;
                    letter-spacing: 0;
                    line-height: 1.4;
                    &::before {
                        margin-right: 8px;
                        width: 14px;
                        height: 14px;
                        content: "";
                        display: block;
                        background: var(--color-en, #0e204c);
                        border-radius: 50%;
                    }
                }
            }
        }
    }
}
/* sec_flow */
.sec_flow {
    padding: 136px 80px 48px 80px;
    background: var(--color-bg-blue);
    @media (max-width: 1200px) {
        padding: 136px 40px 48px 40px;
    }
    @media (max-width: 700px) {
        padding: 136px 24px 48px 24px;
    }
    @media (max-width: 500px) {
        padding: 100px 16px 32px 16px;
    }
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        max-width: var(--max-width-main);
        .follow_up {
            position: relative;
            z-index: 10;
            margin-top: 70px;
            padding: 8px;
            width: calc(100% - 8px);
            min-height: 348px;
            background: #fff;
            &::after {
                position: absolute;
                top: 8px;
                left: 32px;
                z-index: -1;
                width: calc(100% - 24px);
                height: 100%;
                display: block;
                content: "";
                border: 1px solid #fff;
            }
            .sub_ttl {
                position: absolute;
                top: 8px;
                left: 8px;
                width: 200px;
                height: calc(100% - 16px);
                display: flex;
                align-items: center;
                justify-content: center;
                color: #fff;
                font-family: var(--font-en);
                font-weight: 700;
                font-size: 16px;
                background: linear-gradient(-90deg, #003f85 0%, #0667d4 100%);
                @media (max-width: 900px) {
                    position: static;
                    padding: 2em 1em;
                    width: 100%;
                    height: auto;
                }
            }
            .text_in {
                margin-left: auto;
                padding: 14px 24px;
                width: calc(100% - 200px);
                @media (max-width: 900px) {
                    width: 100%;
                }
                h3 {
                    color: #0e204c;
                    .main {
                        display: block;
                        font-size: 24px;
                        font-weight: 700;
                        line-height: 1.5;
                        @media (max-width: 900px) {
                            margin-bottom: 8px;
                            font-size: 22px;
                        }
                        @media (max-width: 500px) {
                            font-size: 20px;
                        }
                    }
                    .sub {
                        font-size: 16px;
                        line-height: 1.5;
                        font-weight: 700;
                        @media (max-width: 900px) {
                            font-size: 14px;
                        }
                    }
                }
                p {
                    margin-top: 1.5em;
                    font-weight: 500;
                    font-size: 16px;
                    color: #101010;
                    line-height: 2.5;
                    @media (max-width: 900px) {
                        font-size: 14px;
                    }
                }
            }
        }
    }
}
ul.flow_list_1 {
    margin-top: 62px;
    padding-right: 8px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px 40px;
    @media (max-width: 1100px) {
        grid-template-columns: repeat(2, 1fr);
    }
    @media (max-width: 900px) {
        gap: 24px;
    }
    @media (max-width: 600px) {
        grid-template-columns: repeat(1, 1fr);
    }
    li {
        position: relative;
        z-index: 10;
        min-height: 360px;
        padding: 8px;
        padding-bottom: 24px;
        background: #fff;
        @media (max-width: 1100px) {
            min-height: 280px;
        }
        @media (max-width: 600px) {
            min-height: auto;
        }
        &::after {
            position: absolute;
            top: 8px;
            left: 8px;
            z-index: -1;
            width: 100%;
            height: 100%;
            display: block;
            content: "";
            border: 1px solid #fff;
        }
        > h3 {
            display: flex;
            align-items: start;
            .step_no {
                padding: 4px;
                width: 60px;
                height: 60px;
                display: flex;
                justify-content: center;
                align-items: center;
                flex-wrap: wrap;
                color: #fff;
                text-align: center;
                background: linear-gradient(-90deg, #003f85 0%, #0667d4 100%);
                font-family: var(--font-en);
                font-weight: 700;
                @media (max-width: 900px) {
                    width: 52px;
                    height: 52px;
                }
                .sub {
                    width: 100%;
                    display: block;
                    font-size: 16px;
                    line-height: 1;
                    letter-spacing: 0.08em;
                    @media (max-width: 900px) {
                        font-size: 14px;
                    }
                }
                .main {
                    display: block;
                    font-size: 32px;
                    line-height: 1;
                    letter-spacing: 0.08em;
                    @media (max-width: 900px) {
                        font-size: 28px;
                    }
                }
            }
            .text {
                padding-left: 12px;
                color: #0e204c;
                .main {
                    display: block;
                    font-size: 24px;
                    font-weight: 700;
                    line-height: 1.5;
                    letter-spacing: 0.04em;
                    @media (max-width: 1200px) {
                        font-size: 22px;
                    }
                    @media (max-width: 900px) {
                        font-size: 20px;
                    }
                }
                .sub {
                    font-size: 16px;
                    line-height: 1.5;
                    letter-spacing: 0.04em;
                    @media (max-width: 900px) {
                        font-size: 14px;
                    }
                }
            }
        }
        p {
            margin-top: 1.5em;
            font-size: 16px;
            line-height: 2.5;
            letter-spacing: 0.04em;
            color: #101010;
            @media (max-width: 900px) {
                font-size: 14px;
            }
        }
    }
}
/* sec_price */
.sec_price {
    padding: 100px 80px 138px 80px;
    background: var(--color-bg-blue);
    @media (max-width: 1200px) {
        padding: 100px 40px 138px 40px;
    }
    @media (max-width: 700px) {
        padding: 100px 24px 138px 24px;
    }
    @media (max-width: 500px) {
        padding: 80px 16px 100px 16px;
    }
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        max-width: var(--max-width-main);
        .ttl_ptn_2 {
            position: relative;
            z-index: 20;
        }
    }
}
.price_table {
    margin-top: 60px;
    margin-bottom: 100px;
    background: #fff;
    border-top: 1px solid var(--color-main);
    border-left: 1px solid var(--color-main);
    @media (max-width: 800px) {
        margin-top: 48px;
    }
    @media (max-width: 600px) {
        margin-top: 40px;
    }
    .row {
        display: grid;
        grid-template-columns: 300px calc(100% - 300px);
        font-size: 16px;
        line-height: 1.8;
        @media (max-width: 1200px) {
            grid-template-columns: 220px calc(100% - 220px);
        }
        @media (max-width: 900px) {
            font-size: 14px;
        }
        @media (max-width: 800px) {
            grid-template-columns: 160px calc(100% - 160px);
        }
        @media (max-width: 500px) {
            grid-template-columns: 120px calc(100% - 120px);
            font-size: 12px;
        }
        &.large {
            font-size: 24px;
            font-weight: 700;
            @media (max-width: 1280px) {
                font-size: 20px;
            }
            @media (max-width: 900px) {
                font-size: 18px;
            }
            @media (max-width: 600px) {
                font-size: 16px;
            }
            @media (max-width: 500px) {
                font-size: 14px;
            }
            .dt {
                display: flex;
                align-items: center;
            }
            .dd {
                font-weight: 700;
            }
        }
        &.head {
            background: #ffe75f;
            font-weight: 700;
        }
        > div {
            padding: 15px;
            border-right: 1px solid var(--color-main);
            border-bottom: 1px solid var(--color-main);
        }
        .dt {
            font-weight: 700;
        }
        .dd {
            font-weight: 500;
        }
        b {
            font-weight: 700;
        }
        .red {
            color: #c20a0a;
        }
        .big {
            font-size: 1.6em;
            letter-spacing: 0.08em;
            @media (max-width: 500px) {
                font-size: 1.5em;
            }
        }
        .middle {
            font-size: 1.2em;
            letter-spacing: 0.06em;
        }
    }
}
.follow_curriculum_list {
    position: relative;
    z-index: 10;
    margin: 0 auto;
    margin-top: 78px;
    padding-right: 8px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 40px;
    @media (max-width: 1100px) {
        gap: 24px;
    }
    @media (max-width: 800px) {
        max-width: 480px;
        grid-template-columns: repeat(2, 1fr);
    }
    .bg_img {
        position: absolute;
        top: -190px;
        left: -140px;
        z-index: -1;
        width: calc(100% + 280px);
        height: auto;
        img {
            width: 100%;
            height: auto;
            object-fit: contain;
        }
    }
    li {
        position: relative;
        z-index: 10;
        padding-top: 20px;
        display: flex;
        align-items: center;
        justify-content: center;
        align-content: center;
        flex-wrap: wrap;
        aspect-ratio: 1;
        .icon {
            width: 48px;
            height: 48px;
            @media (max-width: 500px) {
                width: 40px;
                height: 40px;
            }
            svg,
            img {
                width: 100%;
                height: 100%;
            }
        }
        p {
            margin-top: 1em;
            width: 100%;
            font-weight: 700;
            font-size: 24px;
            text-align: center;
            line-height: 1.3em;
            color: #fff;
            @media (max-width: 1100px) {
                font-size: 20px;
            }
            @media (max-width: 1000px) {
                font-size: 18px;
            }
            @media (max-width: 500px) {
                font-size: 14px;
            }
        }
        .bg_image {
            position: absolute;
            top: 0;
            left: 0;
            z-index: -2;
            width: 100%;
            height: 100%;
            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }
        &::before {
            position: absolute;
            top: 8px;
            left: 8px;
            z-index: -3;
            width: 100%;
            height: 100%;
            display: block;
            content: "";
            border: 2px solid #fff;
        }
        &::after {
            position: absolute;
            top: 0;
            left: 0;
            z-index: -1;
            width: 100%;
            height: 100%;
            display: block;
            content: "";
            background: rgba(14, 32, 76, 0.5);
        }
    }
}
.point_content_1 {
    margin-top: 70px;
    background: #fff;
    h3 {
        padding: 16px 58px;
        background: #ffe75f;
        font-size: 16px;
        line-height: 1.8;
        font-weight: 700;
        @media (max-width: 800px) {
            padding: 16px 40px;
        }
    }
    .in {
        padding: 38px 58px;
        min-height: 240px;
        @media (max-width: 800px) {
            padding: 24px 40px;
        }
        p {
            font-size: 16px;
            line-height: 2.5;
            font-weight: 700;
            @media (max-width: 800px) {
                font-size: 14px;
            }
        }
    }
}
/* sec_voice */
.sec_voice {
    margin-top: 110px;
}

/* sec_faq */
.sec_faq {
    margin-top: 115px;
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        padding-top: 1px;
        padding-bottom: 100px;
        max-width: 1280px;
        @media (max-width: 600px) {
            padding-bottom: 56px;
        }
        &::after {
            position: absolute;
            top: 0;
            left: 50%;
            z-index: -2;
            transform: translateX(-50%);
            width: 100vw;
            height: 100%;
            display: block;
            content: "";
            background: var(--color-bg-blue);
        }
        .ttl_ptn_1 {
            margin-top: -40px;
            @media (max-width: 600px) {
                margin-top: -32px;
            }
        }
        .faq_list {
            margin: 0 auto;
            margin-top: 64px;
            padding: 0 40px;
            max-width: calc(1140px + 80px);
            width: 100%;
            @media (max-width: 600px) {
                margin-top: 48px;
                padding: 0 24px;
                max-width: calc(1140px + 48px);
            }
            dt {
                position: relative;
                margin-top: 8px;
                padding: 0.4em 1.5em;
                padding-right: 64px;
                padding-bottom: 1em;
                min-height: 64px;
                display: flex;
                align-items: center;
                background: var(--color-main);
                color: #fff;
                cursor: pointer;
                @media (max-width: 600px) {
                    padding-right: 48px;
                }
                .ttl {
                    padding-top: 0.2em;
                    font-weight: 700;
                    font-size: 32px;
                    line-height: 1.5;
                    font-family: var(--font-en);
                    @media (max-width: 600px) {
                        font-size: 26px;
                    }
                }
                .text {
                    padding-top: 0.55em;
                    padding-left: 0.8em;
                    font-size: 16px;
                    font-weight: 700;
                    line-height: 1.5;
                    @media (max-width: 600px) {
                        font-size: 14px;
                    }
                }
                &::after {
                    position: absolute;
                    top: 0;
                    bottom: 0;
                    right: 24px;
                    margin: auto;
                    content: "";
                    display: block;
                    /* ▼ */
                    width: 0;
                    height: 0;
                    border-left: 10px solid transparent;
                    border-right: 10px solid transparent;
                    border-top: 16px solid #fff;
                    transform: rotate(-90deg);
                    transition: transform 0.3s ease;
                    @media (max-width: 600px) {
                        right: 16px;
                        border-left: 8px solid transparent;
                        border-right: 8px solid transparent;
                        border-top: 14px solid #fff;
                    }
                }
                &.active {
                    &:after {
                        transform: rotate(0deg);
                    }
                }
            }
            dd {
                display: none;
                .text {
                    padding: 1.5em;
                    padding-left: 3.9em;
                    font-size: 16px;
                    line-height: 2.5;
                    font-weight: 700;
                    @media (max-width: 600px) {
                        padding: 1.5em 1em;
                        font-size: 14px;
                    }
                }
            }
        }
    }
}

/* sec_contact */
.sec_contact {
    margin: 145px 0;
    padding: 0 24px;
    @media (max-width:800px) {
        margin: 100px 0;
        padding: 0 16px;
    }
    @media (max-width:450px) {
        padding: 0 8px;
    }
	p{
		margin-bottom: 1em;
	}
    .wrap {
        position: relative;
        z-index: 10;
        margin: 0 auto;
        margin-top: 60px;
        max-width: var(--max-width-main);
    }
}

/* footer_main */
.footer_main {
    padding: 64px 80px;
    padding-bottom: 16px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    background: #f6f6f6;
    @media (max-width: 1150px) {
        padding: 64px 40px;
        padding-bottom: 16px;
    }
    @media (max-width: 500px) {
        padding: 64px 24px;
        padding-bottom: 16px;
    }
    h2.logo {
        @media (max-width: 980px) {
            width: 100%;
        }
        a {
            img {
                height: 46px;
                width: auto;
                @media (max-width: 500px) {
                    height: 38px;
                }
            }
        }
    }
    .content {
        @media (max-width: 980px) {
            margin-top: 48px;
            width: 100%;
        }
    }
    .cta {
        display: flex;
        justify-content: end;
        align-items: center;
        @media (max-width: 980px) {
            justify-content: start;
            flex-wrap: wrap;
        }
        @media (max-width: 780px) {
            justify-content: space-between;
        }
        .tel {
            padding-top: 4px;
            display: flex;
            @media (max-width: 700px) {
                width: 100%;
            }
            .number {
                display: flex;
                font-size: 32px;
                color: #101010;
                font-family: var(--font-en);
                font-weight: 700;
                letter-spacing: 0;
                @media (max-width: 500px) {
                    font-size: 28px;
                }
                .icon {
                    width: 32px;
                    @media (max-width: 500px) {
                        padding-top: 2px;
                        width: 24px;
                    }
                    svg {
                        width: 100%;
                        height: auto;
                    }
                }
            }
            .data {
                margin-left: 8px;
                padding-top: 4px;
                font-size: 8px;
                line-height: 1.6em;
                font-weight: 500;
                color: #101010;
                letter-spacing: 0;
            }
        }
        .link_btn {
            margin-left: 34px;
            height: 60px;
            display: flex;
            @media (max-width: 700px) {
                margin: 16px 0 0 0;
            }
            @media (max-width: 600px) {
                width: 100%;
            }
            a {
                height: 100%;
                width: 98px;
                display: flex;
                align-items: center;
                align-content: center;
                justify-content: center;
                flex-wrap: wrap;
                font-size: 10px;
                color: #fff;
                background: #101010;
                text-align: center;
                @media (max-width: 600px) {
                    width: auto;
                    flex: 1;
                }
                svg {
                    margin-bottom: 6px;
                    width: 12px;
                    height: 12px;
                }
                span {
                    width: 100%;
                    display: block;
                }
                &:nth-of-type(2) {
                    background: #ffe75f;
                    color: #101010;
                }
            }
        }
    }

    nav.footer_nav_menu {
        margin-top: 24px;
        @media (max-width: 980px) {
            margin-top: 48px;
        }
        ul {
            display: flex;
            justify-content: end;
            gap: 24px 36px;
            flex-wrap: wrap;
            @media (max-width: 980px) {
                justify-content: start;
            }
            @media (max-width: 500px) {
                gap: 24px;
            }
            li {
                a {
                    font-size: 14px;
                    color: #101010;
                    font-weight: 700;
                    @media (max-width: 500px) {
                        font-size: 12px;
                    }
                }
            }
        }
    }
    .copy {
        margin-top: 112px;
        width: 100%;
        text-align: right;
        font-size: 12px;
        font-weight: 700;
        letter-spacing: 0.04em;
        line-height: 1.8;
        @media (max-width: 980px) {
            text-align: left;
        }
    }
}
/* cta_flow_bottom */
.cta_flow_bottom {
    position: fixed;
    bottom: 16px;
    right: 0;
    z-index: 100;
    padding-top: 18px;
    padding-left: 11px;
    height: 88px;
    background: linear-gradient(90deg, var(--color-main) 0%, #2348a1 100%);
    visibility: hidden;
    opacity: 0;
    transition:
        visibility 0s linear 0.3s,
        opacity 0.3s ease;
    @media (max-width: 600px) {
        right: 0;
        left: 0;
        bottom: 16px;
        margin: auto;
        padding: 0;
        padding-bottom: 4px;
        width: 320px;
        height: 72px;
        display: flex;
        justify-content: center;
        align-items: center;
        align-content: center;
        flex-wrap: wrap;
    }
    &:hover {
        opacity: 0.8 !important;
    }
    &.active {
        visibility: visible;
        opacity: 1;
        transition:
            visibility 0s linear 0s,
            opacity 0.3s ease;
    }
    .sub {
        padding: 6px;
        padding-left: 16px;
        padding-right: 26px;
        display: flex;
        justify-content: center;
        align-items: center;
        color: #fff;
        border-radius: 3em 0 0 3em;
        background: #004ca1;
        text-align: center;
        font-size: 10px;
        font-weight: 700;
        letter-spacing: 0.01em;
        white-space: nowrap;
        @media (max-width: 600px) {
            height: 24px;
            border-radius: 5em;
        }
        svg {
            margin-right: 4px;
            width: 12px;
            height: 12px;
        }
    }
    .main {
        margin-top: 13px;
        padding-right: 6px;
        display: flex;
        justify-content: end;
        align-items: center;
        color: #ffe75f;
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 0.03em;
        white-space: nowrap;
        @media (max-width: 600px) {
            margin-top: 8px;
        }
        svg {
            margin-top: 2px;
            margin-left: 2px;
        }
    }
}
