/*---------------------------------------------------------
                フッター
---------------------------------------------------------*/
footer {
    position: relative;
    z-index: 1;
    padding: 145px 0 100px;
    border-radius: 50px 50px 0 0;
}

footer.green {
    background-color: #00A76B;
}

footer.black {
    background-color: #131313;
}

footer.front {
    margin-top: -143px;
}

footer.service {
    margin-top: -50px;
}

footer p.en_text {
    position: absolute;
    top: 104px;
    right: 0;
    color: #FFF;
    font-size: max(13.8vw, 80px);
    line-height: 0.55;
    letter-spacing: 0.05em;
    opacity: 0.2;
    pointer-events: none;
}

footer .inner {
    display: flex;
    flex-wrap: wrap;
    gap: 12.5vw;
    margin: 70px 5% 0 10%;
}

footer .inner .left_area {
    width: 285.7px;
    color: #FFF;
}

footer .inner .left_area .footer_logo_box {
    width: 236px;
}

footer .inner .left_area .footer_logo_box img {
    width: 100%;
}

footer .inner .left_area .company_text {
    margin-top: 36px;
}

footer .inner .left_area .company_text .name_text {
    font-size: 20px;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.06em;
}

footer .inner .left_area .company_text .adress_text {
    margin-top: 7px;
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.06em;
}

footer .inner .left_area .company_text .adress_text span {
    display: block;
    font-weight: bold;
}

footer .inner .left_area .footer_sub_menu_list {
    margin-top: 51px;
    display: flex;
    align-items: center;
    gap: 30px;
}

footer .inner .left_area .footer_sub_menu_list li a {
    color: #FFF;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.5;
    letter-spacing: 0;
    transition: 0.3s;
}

footer .inner .left_area .footer_sub_menu_list li a:hover {
    opacity: 0.7;
}

footer .left_area small {
    display: block;
    margin-top: 68px;
    color: #FFF;
    font-size: 13px;
    line-height: 1.8;
    letter-spacing: 0.05em;
}

footer .right_box {
    margin-top: 72px;
    width: calc(100% - 285.7px - 12.5vw);
}

footer .right_box h2 {
    color: #FFF;
    font-size: 36px;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 0.1em;
}

footer .right_box .tel_box {
    display: flex;
    align-items: center;
    gap: 39px;
    margin-top: 22px;
}

footer .right_box .tel_box .left {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

footer .right_box .tel_box .left a {
    display: flex;
    align-items: center;
    color: #FFF;
    font-size: 32px;
    line-height: 0.75;
    letter-spacing: 0.05em;
}

footer .right_box .tel_box .left a:nth-of-type(1) {
    gap: 13px;
}

footer .right_box .tel_box .left a:nth-of-type(2) {
    gap: 11px;
}

footer .right_box .tel_box .left a:nth-of-type(1) svg {
    width: 30px;
}

footer .right_box .tel_box .left a:nth-of-type(2) svg {
    width: 33px;
}

footer .right_box .border {
    width: 5px;
    height: 75px;
    background-color: #FFF;
}

footer .right_box .right {
    display: flex;
    flex-direction: column;
    gap: 3px;
}

footer .right_box .right p:nth-of-type(1) {
    color: #FFF;
    font-size: 20px;
    font-weight: 900;
    line-height: normal;
    letter-spacing: 0.1em;
}

footer .right_box .right p:nth-of-type(2) {
    color: #FFF;
    font-size: 28px;
    line-height: 0.85;
    letter-spacing: 0.05em;
}

footer .right_box .right p:nth-of-type(2) span {
    margin-left: 12px;
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-size: 20px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 0.1em;
}

footer .right_box .btn_box {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 73px;
    width: 483px;
}

footer .right_box .btn_box a {
    justify-content: space-between;
    width: 100%;
    font-size: 20px;
    font-weight: bold;
}

@media screen and (max-width:1350px) {
    footer .inner {
        gap: 8.5vw;
    }

    footer .right_box {
        width: calc(100% - 285.7px - 8.5vw);
    }

    footer .right_box h2 {
        font-size: max(3vw, 20px);
    }

    footer .right_box .tel_box {
        flex-direction: column;
        align-items: baseline;
        gap: 20px;
        margin-top: 35px;
    }

    footer .right_box .border {
        width: 80%;
        height: 5px;
    }
}

@media screen and (max-width:990px) {
    footer p.en_text {
        right: unset;
        left: 0;
    }

    footer .inner {
        flex-direction: column-reverse;
        margin: 70px auto 0;
        width: 85%;
    }

    footer .inner .left_area {
        width: 100%;
    }

    footer .inner .left_area .footer_sub_menu_list {
        flex-direction: column;
        align-items: flex-start;
        gap: 3px;
        margin-top: 20px;
    }

    footer .left_area small {
        text-align: right;
    }

    footer .right_box {
        margin-top: 0;
        width: 100%;
    }

    footer .right_box .border {
        width: 100%;
    }
}

@media screen and (max-width:600px) {
    footer {
        padding: 40px 0 40px;
        border-radius: 30px 30px 0 0;
    }

    footer.front {
        margin-top: -55px;
    }

    footer p.en_text {
        top: 40px;
    }

    footer .inner {
        gap: 40px;
    }

    footer .left_area small {
        margin-top: 35px;
    }

    footer .inner .left_area .footer_logo_box {
        width: 160px;
    }

    footer .inner .left_area .company_text .name_text {
        font-size: 16px;
    }

    footer .inner .left_area .footer_sub_menu_list li a {
        font-size: 14px;
    }

    footer .right_box .tel_box .left a {
        font-size: 24px;
    }

    footer .right_box .right p:nth-of-type(1) {
        font-size: 16px;
    }

    footer .right_box .right p:nth-of-type(2) {
        font-size: 20px;
    }

    footer .right_box .right p:nth-of-type(2) span {
        margin-left: 10px;
        font-size: 16px;
    }

    footer .right_box .btn_box {
        margin-top: 35px;
        width: 100%;
    }

    footer .right_box .btn_box a {
        width: 100% !important;
        gap: 0;
        font-size: 14px;
    }
}