@charset "utf-8";

.about_sec01 {
    .intro {
        margin-bottom: 80rem;

        .desc {
            p {
                font-family: var(--font-main);
                font-weight: 400;
                font-size: 32rem;
                line-height: 46rem;
                color: #fff;

                @media (max-width: 1023px) {
                    font-size: 16rem;
                    line-height: 32rem;
                }

                @media (max-width: 900px) {
                    text-align: center;
                }
            }
        }
    }

    .list {
        display: flex;
        flex-direction: column;
        gap: 80rem;
        margin-bottom: 79rem;

        @media (max-width: 900px) {
            gap: 40rem;
            margin-bottom: 95rem;
        }



        .item {
            display: flex;
            gap: 40rem;
            position: relative;
            z-index: 5;

            @media (max-width: 900px) {
                flex-wrap: wrap;
                gap: 5rem 30rem;
            }

            .item-img {
                max-width: 381rem;
                width: 100%;

                @media (max-width: 900px) {
                    max-width: 175rem;
                }

            }

            .item-desc {
                display: flex;
                flex-direction: column;
                align-items: flex-start;

                @media (max-width: 900px) {
                    padding-left: 54rem;
                }

                .num {
                    font-family: var(--font-en);
                    font-weight: 400;
                    font-size: 56rem;
                    color: #fff;
                    margin-bottom: 24rem;

                    @media (max-width: 900px) {
                        font-size: 28rem;
                        margin-bottom: 0;
                    }
                }

                .item-ttl {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: 32rem;
                    color: #fff;
                    margin-bottom: 24rem;

                    @media (max-width: 900px) {
                        font-size: 24rem;
                        margin-bottom: 17rem;

                    }
                }

                .sub-title {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: 24rem;
                    color: #fff;
                    margin-bottom: 22rem;

                    @media (max-width: 900px) {
                        font-size: 18rem;
                        margin-bottom: 17rem;
                    }
                }

                .desc {
                    p {
                        font-family: var(--font-main);
                        font-weight: 400;
                        font-size: 16rem;
                        line-height: 30rem;
                        color: #fff;

                        @media (max-width: 900px) {
                            font-size: 14rem;
                            line-height: 20rem;
                        }
                    }
                }
            }

            .circle {
                width: 27rem;
                height: 27rem;
                border-radius: 50px;
                border: 2px solid #FFF;
                background-color: var(--tangaroa);

                @media (max-width: 900px) {
                    width: 20rem;
                    height: 20rem;

                }
            }

            .circle::after {
                content: "";
                position: absolute;
                top: 0;
                left: 12rem;
                width: 2px;
                height: calc(100% + 80rem);
                background-color: #FFF;
                z-index: -1;

                @media (max-width: 900px) {
                    left: 10rem;
                    height: calc(100% + 40rem);
                }
            }
        }

        .item:last-of-type {
            .circle::after {
                height: 70%;

                @media (max-width: 900px) {
                    height: 90%;
                }
            }

            .circle::before {
                content: "";
                position: absolute;
                top: 70%;
                left: 12rem;
                width: 2px;
                height: calc(100% + 80rem);
                background: url(/system_panel/uploads/images/dash.svg) no-repeat top/contain;
                z-index: -1;

                @media (max-width: 900px) {
                    height: calc(100% + 40rem);
                    left: 10rem;
                    top: 70%;
                }
            }
        }
    }
}

.infinite-scroll {
    .img01 {

        margin-right: 47rem;

        @media (max-width: 900px) {
            max-width: 291rem;
            margin-right: 24rem;
        }
    }

    .img02 {
        margin-right: 74rem;
        margin-top: auto;

        @media (max-width: 900px) {
            max-width: 201rem;
            margin-right: 38rem;
        }
    }

    .img03 {
        margin-right: 53rem;

        @media (max-width: 900px) {
            max-width: 151rem;
            margin-right: 24rem;
        }
    }

    .img04 {
        margin-right: 45rem;
        margin-top: auto;

        @media (max-width: 900px) {
            max-width: 200rem;
            margin-right: 38rem;
        }
    }

    .track {
        height: 432rem;

        @media (max-width: 900px) {
            height: 220rem;
        }
    }
}

.pickup {
    .w1344 {
        padding: 80rem 0 120rem;

        .intro {
            margin-bottom: 80rem;

            .desc {
                font-family: var(--font-main);
                font-weight: 400;
                font-size: 32rem;
                line-height: calc((46 / 32) * 1em);
                text-align: center;
                color: #fff;

                @media (max-width: 900px) {
                    font-size: 18rem;
                }
            }
        }

        .box {
            background-color: #FFF;
            position: relative;

            .sub {
                position: absolute;
                top: 0;
                left: 0;
                font-family: var(--font-en);
                font-weight: 400;
                font-size: 45rem;
                color: #000;

                @media (max-width: 900px) {
                    margin-top: -10rem;
                }
            }

            .inner {
                padding: 63rem 40rem;

                @media (max-width: 900px) {
                    padding: 64rem 19rem 32rem;
                }

                .column {
                    display: flex;
                    gap: 91rem;
                    align-items: center;

                    @media (max-width: 900px) {
                        flex-direction: column-reverse;
                        gap: 24rem;
                    }

                    .box-img {
                        max-width: 533rem;
                        width: 100%;

                        @media (max-width: 900px) {
                            max-width: none;
                        }
                    }

                    .box-head {
                        .main {
                            font-family: var(--font-main);
                            font-weight: 400;
                            font-size: 24rem;
                            line-height: calc((35 / 24) * 1em);
                            color: #000;
                            margin-bottom: 32rem;

                            @media (max-width: 900px) {
                                font-size: 18rem;
                                margin-bottom: 20rem;
                            }
                        }

                        .desc {
                            margin-bottom: 40rem;

                            p {
                                font-family: var(--font-main);
                                font-weight: 400;
                                font-size: 16rem;
                                line-height: calc((24 / 16) * 1em);
                                color: #000;

                                @media (max-width: 900px) {
                                    font-size: 14rem;
                                }
                            }
                        }

                        .yajibtn {
                            .linktext {
                                color: #000;
                            }
                        }
                    }
                }
            }
        }
    }
}

.about_greeting {
    .w1344 {
        padding-bottom: 80rem;

        .main-title {
            font-family: var(--font-main);
            font-weight: 400;
            font-size: 32rem;
            color: #fff;
            padding-bottom: 24rem;
            position: relative;
            display: inline-block;
            margin-bottom: 40rem;

            @media (max-width: 900px) {
                font-size: 18rem;
                padding-bottom: 8rem;
                margin-bottom: 19rem;
            }
        }


        .main-title::after {
            content: "";
            position: absolute;
            bottom: 0;
            right: 0;
            width: 416rem;
            height: 1px;
            background-color: #FFF;
        }


        .column {
            display: flex;
            gap: 80rem;

            @media (max-width: 900px) {
                flex-direction: column;
                gap: 40rem;
            }
        }

        .imgwrap {
            max-width: 411rem;
            width: 100%;

            @media (max-width: 900px) {
                max-width: 312rem;
                margin: 0 auto;
            }
        }

        .textwrap {
            max-width: 853rem;
            width: 100%;

            @media (max-width: 900px) {
                max-width: 312rem;
                margin: 0 auto;
            }

            .main {
                font-family: var(--font-main);
                font-weight: 400;
                font-size: 24rem;
                line-height: calc((35 / 24) * 1em);
                color: #fff;
                margin-bottom: 24rem;

                @media (max-width: 900px) {
                    font-size: 20rem;
                }
            }

            .desc {
                margin-bottom: 40rem;

                p {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: 16rem;
                    line-height: calc((38 / 16) * 1em);
                    color: #fff;

                    @media (max-width: 900px) {
                        font-size: 14rem;
                    }
                }
            }

            .name {
                font-family: var(--font-main);
                font-weight: 400;
                font-size: 32rem;
                text-align: right;
                color: #fff;

                @media (max-width: 900px) {
                    font-size: 24rem;
                    text-align: center;
                }
            }
        }
    }
}

.about_history {
    .w1344 {
        .main-title {
            font-family: var(--font-main);
            font-weight: 400;
            font-size: 32rem;
            color: #fff;
            padding-bottom: 24rem;
            position: relative;
            display: inline-block;
            margin-bottom: 80rem;

            @media (max-width: 900px) {
                font-size: 18rem;
                padding-bottom: 8rem;
                margin-bottom: 40rem;
            }
        }


        .main-title::after {
            content: "";
            position: absolute;
            bottom: 0;
            right: 0;
            width: 416rem;
            height: 1px;
            background-color: #FFF;
        }

        .sec-body {
            display: flex;
            flex-direction: column;
            gap: 32rem;

            .item {
                display: grid;
                grid-template-columns: 15% 1fr;
                gap: 127rem;
                padding-bottom: 32rem;
                border-bottom: 1px solid #FFF;

                @media (max-width: 900px) {
                    display: flex;
                    flex-direction: column;
                    gap: 16rem;
                }

                .ttl {
                    font-family: var(--font-main);
                    font-weight: 900;
                    font-size: 18rem;
                    color: #fff;
                }

                .detail {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: 18rem;
                    line-height: 26rem;
                    color: #fff;
                }
            }
        }
    }
}