@charset "utf-8";

.about_intro {
    position: relative;

    .w1344 {
        padding: 100rem 0 120rem;
        display: flex;
        justify-content: space-between;
        align-items: flex-start;

        @media (max-width: 1023px) {
            flex-direction: column;
            padding: 62rem 0 55rem;
            justify-content: flex-start;
            gap: 40rem;
        }

        .sec-title {
            .catch {
                margin-top: 80rem;
                font-family: var(--font-main);
                font-weight: 600;
                font-size: 40rem;
                letter-spacing: 0.08em;
                line-height: 64rem;
                color: #0368b4;

                @media (max-width: 1023px) {
                    margin-top: 40rem;
                    font-size: 22rem;
                    line-height: 40rem;
                }
            }
        }

        .col-left {
            width: 40%;

            @media (max-width: 1023px) {
                width: 100%;
            }
        }

        .col-right {
            width: 60%;
            margin-top: 106rem;

            @media (max-width: 1023px) {
                width: 100%;
                margin-top: 0;
            }

            .desc {
                p {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: max(14px, 16rem);
                    letter-spacing: 0.08em;
                    line-height: calc((32 / 16) * 1em);
                    color: #000;
                }
            }
        }
    }
}

.about_intro::after {
    content: "";
    background: url(/system_panel/uploads/images/dog02_ref.png) no-repeat center/contain;
    width: 304rem;
    height: 195rem;
    position: absolute;
    bottom: -114rem;
    left: 182rem;

    @media (max-width: 1023px) {
        width: 155rem;
        height: 100rem;
        bottom: auto;
        top: calc(100% + 12rem);
        left: 4rem;
    }
}

.about_strength {
    .w996 {
        max-width: 996rem;
        width: 90%;
        margin: 0 auto;
        padding: 120rem 0;

        .sec-title {
            margin-bottom: 80rem;
            align-items: center;
        }

        .list-contents {
            display: flex;
            flex-direction: column;
            gap: 64rem;

            @media (max-width: 1023px) {
                gap: 56rem;
            }
        }

        .item {
            display: flex;
            align-items: center;
            gap: 80rem;

            @media (max-width: 1023px) {
                flex-direction: column;
                gap: 32rem;
                align-items: flex-start;
            }

            .img {
                max-width: 300rem;
                width: 100%;

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

                img {
                    width: 100%;
                    height: auto;
                }
            }

            .text {
                .item-ttl {
                    font-family: var(--font-main);
                    font-weight: 600;
                    font-size: 32rem;
                    letter-spacing: 0.08em;
                    line-height: 56rem;
                    color: #313131;
                    margin-bottom: 40rem;

                    @media (max-width: 1023px) {
                        font-size: 22rem;
                        line-height: 40rem;
                        margin-bottom: 24rem;
                    }
                }

                .desc {
                    font-family: var(--font-main);
                    font-weight: 400;
                    font-size: max(14px, 16rem);
                    letter-spacing: 0.08em;
                    line-height: calc((32 / 16) * 1em);
                    color: #313131;
                    display: flex;
                    flex-direction: column;
                    gap: 32rem;

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

                    .bg-line {
                        font-weight: 500;
                        font-size: max(16px, 18rem);
                        background-image: linear-gradient(to top, transparent 10%, #d8effa 10%,
                                #d8effa 80%,
                                transparent 80%);
                        background-repeat: no-repeat;
                        background-size: 100% 100%;

                        @media (max-width: 1023px) {
                            font-size: 14rem;
                            line-height: 24rem;

                        }
                    }

                    .column {
                        display: flex;
                        flex-wrap: wrap;

                        @media (max-width: 1023px) {
                            flex-direction: column;
                            align-items: flex-start;
                        }
                    }

                }
            }
        }

        .item.reverse {
            flex-direction: row-reverse;

            @media (max-width: 1023px) {
                flex-direction: column;
            }
        }
    }
}

.about_service {
    .w984 {
        max-width: 984rem;
        width: 90%;
        margin: 0 auto;
        padding: 72rem 0 80rem;

        @media (max-width: 1023px) {
            padding: 60rem 0 101rem;
        }

        .sec-title {
            margin-bottom: 56rem;
            align-items: center;
        }

        .listcontents {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            grid-template-rows: auto;
            gap: 24rem;

            @media (max-width: 1023px) {
                grid-template-columns: 1fr;
                gap: 8rem;
            }

            .item {
                display: flex;
                flex-direction: column;
                gap: 8rem;
                background-color: #FFF;
                border-radius: 20px;
                border: 2px solid #0368B4;
                padding: 24rem 0 33rem;
                position: relative;
                align-items: center;

                @media (max-width: 1023px) {
                    min-height: 164rem;
                    padding: 0;
                    justify-content: center;
                }

                a {
                    position: absolute;
                    top: 0;
                    left: 0;
                    width: 100%;
                    height: 100%;
                }


                .img {
                    max-width: 120rem;

                    @media (max-width: 1023px) {
                        max-width: 89rem;
                    }

                    img {
                        width: 100%;
                        height: auto;
                    }
                }

                .item-ttl {
                    display: flex;
                    align-items: flex-end;

                    .main {
                        font-family: var(--font-main);
                        font-weight: 600;
                        font-size: 24rem;
                        letter-spacing: 0.08em;
                        color: #0368b4;

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

                    .sub {
                        font-size: max(16px, 18rem);
                        color: #0368b4;
                        font-family: var(--font-main);
                        font-weight: 600;
                        letter-spacing: 0.08em;

                        @media (max-width: 1023px) {
                            font-size: 13rem;
                        }
                    }
                }
            }

            .item::after {
                content: "";
                background: url(/system_panel/uploads/images/arrow-b.png) no-repeat center/contain;
                width: 40rem;
                height: 40rem;
                position: absolute;
                top: 0;
                bottom: 0;
                margin: auto;
                right: 32rem;

                @media (max-width: 1023px) {
                    width: 29rem;
                    height: 29rem;
                    right: 24rem;
                }
            }

            .item:hover {
                border: none;
                background:
                    repeating-linear-gradient(to right, #0368B4 0 8px, transparent 8px 16px) top,
                    repeating-linear-gradient(to right, #0368B4 0 8px, transparent 8px 16px) bottom,
                    repeating-linear-gradient(to bottom, #0368B4 0 8px, transparent 8px 16px) left,
                    repeating-linear-gradient(to bottom, #0368B4 0 8px, transparent 8px 16px) right,
                    #fff;
                background-size:
                    16px 1px, 16px 1px, 1px 16px, 1px 16px;
                background-repeat:
                    repeat-x, repeat-x, repeat-y, repeat-y;
                background-position:
                    top left, bottom left, top left, top right;
                border-radius: 8px;

                .item-ttl {
                    background-image: linear-gradient(to top,
                            #FFFAC9 16rem,
                            transparent 16rem,
                            transparent 100%);
                    background-repeat: no-repeat;
                    background-size: 100% 100%;
                }
            }

            .item:hover::after {
                background-image: url(/system_panel/uploads/images/h_arrow-b.png);
            }
        }
    }
}

.about_chara {
    .w957 {
        max-width: 957rem;
        width: 90%;
        margin: 0 auto;
        padding: 66rem 0 56rem;

        @media (max-width: 1023px) {
            padding: 105rem 0 86rem;
        }

        .box {
            border-radius: 20px;
            background: transparent;
            border: 2px solid #0368b4;
            display: flex;
            padding: 80rem 90rem 80rem 64rem;
            gap: 72rem;
            position: relative;

            @media (max-width: 1023px) {
                flex-direction: column;
                gap: 36rem;
                padding: 0 40rem 128rem 40rem;
                align-items: center;
            }

            .img {
                max-width: 191rem;
                width: 100%;
                transform-origin: center bottom;
                animation: yurayura 2s linear infinite;

                @media (max-width: 1023px) {
                    max-width: 134rem;
                    margin-top: -24rem;
                }

                img {
                    width: 100%;
                    height: auto;
                }
            }

            .text {
                max-width: 540rem;
                width: 100%;

                .box-ttl {
                    display: flex;
                    flex-direction: column;
                    margin-bottom: 12rem;

                    @media (max-width: 1023px) {
                        margin-bottom: 24rem;
                    }

                    .main {
                        font-family: var(--font-main);
                        font-weight: 600;
                        font-size: 32rem;
                        letter-spacing: 0.08em;
                        line-height: 56rem;
                        color: #313131;

                        @media (max-width: 1023px) {
                            font-size: 22rem;
                        }

                    }

                    .sub {
                        font-family: var(--font-main);
                        font-weight: 600;
                        font-size: max(14px, 16rem);
                        letter-spacing: 0.08em;
                        color: #0368b4;

                        @media (max-width: 1023px) {
                            font-size: 12rem;
                        }
                    }
                }

                .desc {
                    p {
                        font-family: var(--font-main);
                        font-weight: normal;
                        font-size: max(14px, 16rem);
                        letter-spacing: 0.08em;
                        line-height: calc((32 / 16) * 1em);
                        color: #313131;

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

                    }
                }
            }
        }

        .box::before {
            content: "";
            width: 100%;
            height: 17rem;
            border-radius: 17px 17px 0px 0px;
            background: #0368b4;
            position: absolute;
            top: 0;
            left: 0;
        }

        .box::after {
            content: "";
            background: url(/system_panel/uploads/images/chara02.png) no-repeat center/contain;
            width: 239rem;
            height: 189rem;
            position: absolute;
            top: -18rem;
            right: 35rem;

            @media (max-width: 1023px) {
                width: 129rem;
                height: 86rem;
                top: auto;
                right: 26rem;
                bottom: 19rem;
            }
        }
    }
}



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

        @media (max-width: 1023px) {
            padding: 102rem 0 77rem;
        }

        .sec-title {
            margin-bottom: 56rem;
            align-items: center;

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

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

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

            .map {
                max-width: 640rem;
                width: 100%;
                border-radius: 20px;
            }

            iframe {
                border-radius: 20px;
                border: none;
                width: 100%;
                height: 570rem;

                @media (max-width: 1023px) {
                    height: 240rem;
                }
            }

            .text {
                max-width: 630rem;
                width: 100%;

                .item {
                    display: grid;
                    grid-template-columns: 30% auto;
                    grid-template-rows: auto;
                    align-items: flex-start;
                    padding-bottom: 24rem;
                    margin-bottom: 24rem;
                    border-bottom: 1px solid #D9D9D9;



                    .ttl {
                        font-family: var(--font-main);
                        font-weight: 600;
                        font-size: max(16px, 18rem);
                        line-height: 38px;
                        text-align: left;
                        color: #313131;
                        padding-left: 24rem;
                        position: relative;
                    }

                    .ttl::after {
                        content: "";
                        position: absolute;
                        width: 8px;
                        height: 8px;
                        background-color: #e6006d;
                        border-radius: 50px;
                        top: 0;
                        bottom: 0;
                        left: 0;
                        margin: auto;
                    }

                    .detail {
                        font-family: var(--font-main);
                        font-weight: 400;
                        font-size: max(14px, 16rem);
                        line-height: calc((32 / 16) * 1em);
                        text-align: left;
                        color: #313131;

                    }
                }

                @media (max-width: 1023px) {
                    .item {
                        grid-template-columns: 1fr;
                        grid-template-rows: auto;
                        padding-bottom: 16rem;
                        margin-bottom: 16rem;

                        .ttl {
                            font-size: 16rem;
                        }

                        .detail {
                            font-size: 14rem;
                            line-height: 24rem;
                        }
                    }
                }

                .item:last-child {
                    margin-bottom: 0;
                }

                .secbtn {
                    max-width: 300px;
                    height: 64px;
                    margin-top: 80rem;

                    @media (max-width: 1023px) {
                        margin: 0 auto;
                        max-width: 309rem;
                        height: 64rem;
                        margin-top: 40rem;
                    }
                }
            }
        }
    }
}