@charset "utf-8";

@import url("base.css");

/***************************************************************************
 *
 * COMMON STYLE
 *
 ***************************************************************************/
.roboto {
    font-family: "Roboto Condensed", sans-serif;
}

.heebo {
    font-family: "Heebo", sans-serif;
}

body {
    background-color: #fff;
    font-size: 14px;
    font-family: "Noto Serif JP", serif;
    line-height: 1.5;
    color: #000000;
    font-weight: normal;
}

body.fixed {
    overflow: hidden;
}

.inner {
    width: 100%;
    max-width: 1182px;
    padding: 0 30px;
    margin: 0 auto;
}

/*VALIDATE CONTACT*/
.error {
    display: block;
    font-size: 12px;
    color: red;
}

/* HEADER */
#header {
    position: fixed;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    top: 0;
    left: 0;
    width: 100%;
    padding-left: 36px;
    /* background-color: rgba(244, 244, 244, 0.4); */
    background: #F4F4F4;
    z-index: 9;
}

#header.scroll {
    box-shadow: 0 0 7px rgba(0, 0, 0, 0.1);
    background: rgba(244, 244, 244, 0.8);
}

.headerBar .logo {
    width: 241px;
    margin-top: 3px;
}

.headerBar .logo img {
    width: 100%;
}

.mainMenu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: calc(100% - 255px);
}

.mainMenu .menuList {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    /* width: calc(100% - 502px); */
    margin-right: 17px;
    margin-top: -6px;
}

.mainMenu .menuList>li {
    position: relative;
}

.mainMenu .menuList>li a {
    position: relative;
    display: inline-block;
    font-size: 16px;
    font-weight: 500;
    padding: 22px 23px;
}

.mainMenu .menuList>li>a::before {
    content: "";
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 1px;
    background-color: #3A9F34;
    transition: all .3s;
}

.mainMenu .menuList>li:has(> .subMenu)>span {
    display: none;
}

.mainMenu .menuList .subMenu {
    position: absolute;
    top: 70px;
    left: 50%;
    transform: translateX(-50%);
    min-width: 250px;
    background: #fff;
    border-radius: 8px;
    z-index: 9;
    border: 1px solid #000;
    padding: 10px 20px;
    display: none;
}

.mainMenu .menuList .subMenu li {
    list-style: none;
}

.mainMenu .menuList .subMenu li a {
    display: block;
    padding: 15px 0;
    transition: all 0.2s;
    border-bottom: 1px solid rgba(0, 0, 0, 0.2);
    position: relative;
}

.mainMenu .menuList .subMenu li a:after {
    content: "";
    position: absolute;
    background: url("../images/common/arrow-menu.svg") no-repeat;
    background-size: 100%;
    top: 50%;
    right: 0;
    width: 20px;
    height: 20px;
    transform: translateY(-50%);
}

.mainMenu .menuList .subMenu li:last-child a {
    border-bottom: none;
}



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

.menuWork li {
    display: block;
    width: 159px;
}

.menuWork li:not(:last-child) a {
    border-right: none;
}

.menuWork li.orange {
    width: 159px;
}

.menuWork li a {
    display: block;
    width: 100%;
    text-align: center;
    font-size: 22px;
    color: #000000;
    background: #fff;
    border: 1px solid #ff6600;
    padding: 17px 5px 18px;
    letter-spacing: 1.5px;
    font-weight: 500;
}

.menuWork li.orange a {
    background: #ff6600;
    color: #fff;
}

.menuWork.workFull li a {
    font-size: 16px;
    padding: 22px 5px 22px;
    letter-spacing: 0;
}

.menuWork.workFull li {
    width: 160px;
}

/* MAIN */
#main {
    position: relative;
}

#main .mainPhoto {}

#main .mainPhoto img {
    aspect-ratio: 1440 / 455;
    min-height: 455px;
    object-fit: cover;
    width: 100%;
    height: 100%;
    object-position: left;
}

#main .mainWrap {
    position: absolute;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    bottom: 0;
    left: 0;
    min-width: 770px;
    background-color: #1b5b0f;
    color: #fff;
    padding: 25px 57px 34px 112px;
    overflow: hidden;
}

#main .mainWrap .mainTitle .titleEn {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 107px;
    letter-spacing: 0.3px;
    line-height: 1;
    margin-bottom: 0px;
}

#main .mainWrap .mainTitle .titleJp {
    font-size: 19px;
    font-weight: 300;
    letter-spacing: 0.9px;
    margin-left: 4px;
}

#main .mainWrap .mainSub {
    position: relative;
    font-size: 53px;
    letter-spacing: 0.9px;
    padding: 0 38px;
    margin-top: -9px;
    margin-left: 202px;
}

#main .mainWrap .mainSub::before {
    content: "";
    position: absolute;
    top: 50%;
    left: -74px;
    transform: translateY(-50%) rotate(35deg);
    width: 1px;
    height: 300px;
    background-color: #fff;
}

/* MAIN */

/* BREADCRUMB */
.breadcrumb {
    padding: 40px 0 32px;
    background: #F4F4F4;
}

.breadcrumb .listBreadcrumb {
    display: flex;
}

.breadcrumb .listBreadcrumb li+li {
    margin-left: 10px;
}

.breadcrumb .listBreadcrumb li a {
    display: block;
    width: max-content;
    font-size: 15px;
    color: #1B5B0F;
    background: url(../images/common/icon-arrow.svg) no-repeat right center/8px;
    padding-right: 20px;
    width: max-content;
}

.breadcrumb .listBreadcrumb li:last-child a {
    background: transparent;
    pointer-events: none;
    display: block;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    width: auto;
}

/* CONTENT */
#content {
    width: 100%;
}

.areaTitle {
    padding: 0 2px;
}

.areaTitle .titleEn {
    font-family: "Roboto Condensed", sans-serif;
    font-size: 90px;
    letter-spacing: 3.9px;
    color: #1b5b0f;
    margin-bottom: -7px;
}

.areaTitle .titleJp {
    font-size: 16px;
    font-weight: 400;
    color: #333333;
    letter-spacing: 0.9px;
}

.areaTitle.titleCenter {
    text-align: center;
}

.areaTitle.titleCenter .titleEn {
    font-size: 68px;
    letter-spacing: 0;
    margin-bottom: 0;
}

.areaTitle.titleCenter .titleJp {
    letter-spacing: 0;
}

/* areaContact */
.areaContact {
    background: #3A9F36;
    padding: 154px 0 301px;
}

.areaContact .inner {
    max-width: 1024px;
}

.areaContact .contactAbout {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.areaContact .contactAbout li {
    width: calc(100%/3);
    position: relative;
}

.areaContact .contactAbout li:nth-child(3n),
.areaContact .contactAbout li:last-child {}

.areaContact .contactAbout li a {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}

.areaContact .contactAbout li a:before,
.areaContact .contactAbout li a:after {
    content: "";
    position: absolute;
    transition: transform 0.5s ease;
    left: 4%;
    top: 4%;
    width: 90%;
    height: 90%;
    border-style: solid;
    border-color: #ffffff;
    z-index: 1;
    box-sizing: border-box;
}

.areaContact .contactAbout li a:before {
    border-width: 1px 0 1px 0;
    transform: scaleX(0);
}

.areaContact .contactAbout li a:after {
    border-width: 0 1px 0 1px;
    transform: scaleY(0);
}

.areaContact .contactAbout li a .aboutPhoto img {
    aspect-ratio: 137 / 137;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.areaContact .contactAbout li a .wrapAboutName {
    position: absolute;
    top: 53%;
    left: 47.6%;
    transform: translate(-50%, -50%);
    width: 100%;
}

.areaContact .contactAbout li a .wrapAboutName .aboutName {
    padding: 0 10px;
    font-size: 29px;
    font-weight: bold;
    color: #fff;
    text-align: center;
    display: block;
    margin-bottom: 10px;
}

.areaContact .contactAbout li a .wrapAboutName .arrowContact {
    width: 48px;
    height: 48px;
    margin: 0 auto;
    display: block;
}

/* end-areaContact */

/* fixFtRecruit */
.fixFtRecruit {
    background: #FF6600;
    padding: 27px 20px 20px 20px;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 4;
}

.fixFtRecruit .wrapFixRecruit {}

.fixFtRecruit .wrapFixRecruit .listFixrecruit {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1014px;
    padding: 0 30px;
    width: 100%;
    margin: 0 auto;
}

.fixFtRecruit .wrapFixRecruit .listFixrecruit li {
    width: 48.4%;
}

.fixFtRecruit .wrapFixRecruit .listFixrecruit li:nth-child(2) {}

.fixFtRecruit .wrapFixRecruit .listFixrecruit li a {
    display: block;
    padding: 23px 31px 25px 61px;
    font-size: 19px;
    text-align: center;
    color: #ffffff;
    border-radius: 40px;
    border: 2px solid #ffffff;
    letter-spacing: 2px;
    font-weight: 500;
}

.fixFtRecruit .wrapFixRecruit .listFixrecruit li a span {
    position: relative;
    padding-right: 50px;
}

.fixFtRecruit .wrapFixRecruit .listFixrecruit li a span:after {
    content: "";
    position: absolute;
    background: url("../images/common/arrow-contact.png") no-repeat;
    background-size: 100%;
    width: 35px;
    height: 35px;
    top: 51%;
    right: -1px;
    transform: translateY(-50%);
    transition: all 0.3s;
}

/* fixFtRecruit */


.scrollToTop {
    position: fixed;
    bottom: 20px;
    right: 40px;
    z-index: 10;
    display: none;
}

.scrollToTop a {
    display: block;
    border-radius: 50%;
    padding: 10px 10px 14px;
    width: 60px;
    height: 60px;
    transition: all 0.3s;
    border: 1px solid #1b5b0f;
    background: #ffffff;
}

.scrollToTop a .icon {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.scrollToTop a .icon img {
    width: 31px;
    margin: 0 auto;
}
/* FOOTER */
#footer {
    width: 100%;
    background: #fff;
    padding: 103px 0 54px 0;
    position: relative;
}

.fixFtRecruit+#footer {
    padding-bottom: 154px;
}

.boxContact {
    max-width: 1024px;
    width: 100%;
    padding: 0 30px;
    margin: 0 auto;
    position: relative;
    z-index: 3;
}

.contactWrap {
    background: #F4F4F4;
    padding: 37px 81px 67px;
    overflow: hidden;
    margin-bottom: 92px;
    margin-top: -261px;
}

#footer .contactWrap .inner {
    display: block;
}

.contactWrap .contactTitle {
    font-size: 55px;
    font-weight: bold;
    text-align: center;
    color: #1B5B0F;
    letter-spacing: 1px;
}

.contactWrap .contactList {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 25px;
}

.contactWrap .contactList li {
    width: 47.6%;
}

.contactWrap .contactList li a {
    display: block;
    padding: 27px 20px 20px 20px;
    background: #1B5B0F;
    text-align: center;
    color: #ffffff;
    height: 136px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.contactWrap .contactList li:nth-child(2) a {
    padding: 20px 21px 20px 50px;
}

.contactWrap .contactList li a .telContact {
    font-size: 40px;
    font-weight: 500;
    position: relative;
    padding: 0 0 0 51px;
    letter-spacing: 2px;
}

.contactWrap .contactList li a .telContact:before {
    content: "";
    position: absolute;
    background: url("../images/common/icon-tel-white.svg") no-repeat;
    background-size: 100%;
    width: 34px;
    height: 34px;
    top: 48%;
    transform: translateY(-50%);
    left: 0px;
}

.contactWrap .contactList li a .txtInquiry {
    font-size: 30px;
    font-weight: 500;
    position: relative;
    letter-spacing: 6.2px;
    padding: 0 67px 0 0;
}

.contactWrap .contactList li a .txtInquiry:after {
    content: "";
    position: absolute;
    background: url("../images/common/arrow-contact.png") no-repeat;
    background-size: 100%;
    width: 32px;
    height: 32px;
    top: 54%;
    right: 0;
    transform: translateY(-50%);
    transition: all 0.3s;
}

#footer .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    /* max-width: 1235px; */
    max-width: 1289px;
}

#footer .ftInfo {
    width: 246px;
    margin-top: -13px;
}

#footer .ftInfo .ftLogo {
    width: 97.7%;
    margin-bottom: 30px;
}

#footer .ftInfo .ftInquiry {
    width: 100%;
    margin-left: 6px;
}

#footer .ftInfo .ftInquiry a {
    display: block;
    width: 100%;
    text-align: center;
    color: #fff;
    background: #3a9f36;
    border-radius: 50px;
    border: 2px solid #3a9f36;
    padding: 14px 5px 17px;
}

#footer .ftInfo .ftInquiry a .icon {
    position: relative;
    display: inline-block;
    padding-right: 35px;
    letter-spacing: 1.5px;
    font-weight: 500;
}

#footer .ftInfo .ftInquiry a .icon::before {
    content: "";
    position: absolute;
    top: 53%;
    right: -5px;
    transform: translateY(-50%);
    width: 15px;
    height: 11px;
    background: url("../images/common/icon-arrow-white.svg") no-repeat center center/100%;
    transition: all .3s;
}

#footer .ftMenu {
    width: calc(100% - 366px);
}

#footer .ftMenu .menuList {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}

#footer .ftMenu .menuList>li:not(:last-child) {
    min-width: 110px;
    margin-right: 36px;
}

#footer .ftMenu .menuList .menuName {
    margin-bottom: 16px;
}

#footer .ftMenu .menuList .menuName,
#footer .ftMenu .menuList .menuName>a {
    position: relative;
    font-size: 16px;
    font-weight: 500;
}

#footer .ftMenu .menuList .listSmall li:not(:last-child) {
    margin-bottom: 15px;
}

#footer .ftMenu .menuList .listSmall li a {
    position: relative;
    display: inline-block;
    font-size: 12px;
    letter-spacing: 1.3px;
}

#footer .ftMenu .menuList .listSmall li a::before {
    content: "";
    position: absolute;
    top: 10px;
    left: -17px;
    width: 11px;
    height: 1px;
    background-color: #000;
    transition: all .3s;
}

#footer .ftMenu .menuList>li:not(:last-child) .menuName {
    margin-bottom: 21px;
}

#footer .ftMenu .menuList>li:not(:last-child) .listSmall {
    margin-left: 19px;
}

#footer .ftMenu .menuList>li:not(:last-child) .listSmall li:not(:last-child) {
    margin-bottom: 13px;
}

#footer #copyright {
    width: 100%;
    margin-top: 58px;
    margin-left: 5px;
    letter-spacing: 0;
    font-weight: 300;
}

@media (max-width: 1380px) and (min-width: 769px) {

    .headerBar .logo {
        margin-top: 0.5vw;
    }

    .menuWork.workFull li {
        width: clamp(85px, 10.3vw, 150px);
    }

    .mainMenu .menuList>li a {
        padding: 30px clamp(10px, 1.3vw, 17px);
    }
}

@media (max-width: 1300px) and (min-width: 769px) {
    #main .mainWrap {
        padding: 1.9vw 4.3vw 2.6vw 7.7vw;
        min-width: 59.2vw;
    }

    #main .mainWrap .mainTitle .titleEn {
        font-size: clamp(80px, 8.2vw, 106px);
    }

    #main .mainWrap .mainSub {
        font-size: clamp(34px, 4vw, 52px);
        margin-left: 15.3vw;
        padding: 0 2.7vw;
    }

    #main .mainWrap .mainSub::before {
        left: -6vw;
    }

}

@media (max-width: 1220px) and (min-width: 769px) {
    #footer .ftMenu {
        width: calc(100% - 316px);
    }


}

@media (max-width: 1200px) and (min-width: 769px) {
    #header {
        padding-left: 30px;
    }

    .headerBar .logo {
        width: 221px;
    }

    .mainMenu {
        width: calc(100% - 240px);
    }

    .menuWork li a {
        font-size: clamp(18px, 1.4vw, 22px);

    }

    .menuWork.workFull li a {
        font-size: clamp(14px, 1.3vw, 16px);
    }

    .mainMenu .menuList {
        margin-right: 0;
    }

    .mainMenu .menuList>li a {
        font-size: clamp(14px, 1.3vw, 16px);
    }

    .contactWrap {
        padding: 37px 6vw 67px;

    }

    .contactWrap .contactList li {
        width: 48.6%;
    }

    .contactWrap .contactList li a {
        padding: 2vw 3vw 2vw 2vw;
        height: 11.3vw;
    }

    .contactWrap .contactList li a .telContact {
        padding: 0 0 0 5vw;
        letter-spacing: 0.15vw;
        font-size: clamp(26px, 3.3vw, 40px);
    }

    .contactWrap .contactList li a .telContact:before {
        width: clamp(24px, 2.8vw, 34px);
        height: clamp(24px, 2.8vw, 34px);
    }

    .contactWrap .contactList li:nth-child(2) a {
        padding: 2vw 2vw 2vw 5.8vw;
    }

    .contactWrap .contactList li a .txtInquiry {
        padding: 0 8vw 0 0;
        letter-spacing: 0.5vw;
        font-size: clamp(20px, 2.4vw, 30px);
    }

    .contactWrap .contactList li a .txtInquiry:after {
        width: clamp(22px, 2.6vw, 32px);
        height: clamp(22px, 2.6vw, 32px);
    }

    .areaTitle .titleEn {
        /* font-size: clamp(64px, 8.1vw, 90px); */
        font-size: clamp(64px, 7.5vw, 90px);
    }

    .areaTitle.titleCenter .titleEn {
        /* font-size: clamp(50px, 6.4vw, 67px); */
        font-size: clamp(50px, 5.6vw, 67px);
    }

    .contactWrap .contactTitle {
        font-size: clamp(38px, 4.5vw, 55px);
    }

}

@media (max-width: 1170px) and (min-width: 769px) {
    #footer .ftMenu {
        width: calc(100% - 296px);
    }
}

@media (max-width: 1150px) and (min-width: 769px) {
    #footer .ftMenu .menuList>li:not(:last-child) {
        width: calc((100%/3) - 10px);
        margin-right: 10px;
        min-width: inherit;
        margin-bottom: 30px;
    }

    #footer .ftMenu .menuList>li:not(:last-child) {
        margin-right: 0;
    }

    #footer .ftMenu .menuList>li:nth-child(3n) {
        margin-right: 0;
    }
}

@media (max-width: 1050px) and (min-width: 769px) {
    #header {
        padding-left: 20px;
    }
}

@media (max-width: 1020px) and (min-width: 769px) {
    .headerBar .logo {
        width: 210px;
    }

    .mainMenu {
        width: calc(100% - 220px);
    }

}

@media (max-width: 1000px) and (min-width: 769px) {
    .areaContact .contactAbout li a .wrapAboutName .aboutName {
        font-size: 2.9vw;
    }

    .areaContact .contactAbout li a .wrapAboutName .arrowContact {
        width: 4.8vw;
        height: 4.8vw;
    }
}

@media (min-width: 981px) {
    .mainMenu {
        display: flex !important;
        height: initial !important;
    }

    body.fixed {
        overflow: initial !important;
    }
}

@media(max-width: 980px) {
    #header {
        padding: 0;
    }

    #header .headerBar {
        width: 100%;
        padding: 0 20px;
        /* background-color: rgba(244, 244, 244, 0.4); */
        /*background: #F4F4F4;*/

    }

    #header .headerBar .inner {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .wrapHamburgerSp.sp {
        display: flex;
        align-items: center;
    }

    .menuWork li a,
    .menuWork.workFull li a {
        padding: 23px 5px 24px;
    }

    .menuWork li.orange.pc a {
        display: none;
    }

    .hamburger {
        width: 50px;
        height: 50px;
        padding: 0 5px;
        z-index: 9991;
        background: transparent;
        display: flex;
        justify-content: center;
        flex-direction: column;
        text-align: center;
        cursor: pointer;
    }

    .hamburger.sp {
        display: flex;
        margin-left: 20px;
    }

    .hamburger span {
        display: block;
        height: 2px;
        width: 100%;
        background: #1B5B0F;
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: .25s ease-in-out;
        -moz-transition: .25s ease-in-out;
        transition: .25s ease-in-out;
    }

    .hamburger span:nth-child(1) {
        margin-bottom: 10px;
    }

    .hamburger span:nth-child(2) {
        opacity: 1
    }

    .hamburger span:nth-child(3) {
        margin-top: 10px;
    }

    .hamburger.open span:nth-child(1) {
        margin-bottom: -2px;
        -webkit-transform: rotate(45deg);
        -moz-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    .hamburger.open span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.open span:nth-child(3) {
        margin-top: -2px;
        -webkit-transform: rotate(-45deg);
        -moz-transform: rotate(-45deg);
        transform: rotate(-45deg);
    }

    .mainMenu {
        display: none;
        width: 100%;
        background: #ffffff;
        height: 100vh;
        padding: 0 0 100px;
        overflow-y: auto;
    }

    .mainMenu .menuList {
        display: block;
        width: 100%;
        flex-direction: column;
        padding: 0;
        margin-top: 0;
    }

    .menuWork {
        flex-direction: column;
        max-width: 370px;
    }

    .menuWork li {
        margin-bottom: 0;
    }

    #header .menuWork.workFull li,
    #header .menuWork li.orange {
        width: clamp(110px, 29vw, 200px);
    }

    #header .mainMenu .menuWork.workFull {
        margin-right: 0;
        padding: 0 5vw;
        margin-top: 30px;
    }

    #header .mainMenu .menuWork.workFull li {
        width: 50%;
    }

    #header .mainMenu .menuWork.workFull li:nth-child(2) a {
        border-width: 1px 1px 1px 0;
    }

    #header .mainMenu .menuWork.workFull li.pc {
        display: none;
    }

    #header .mainMenu .menuWork.workFull li a {
        font-size: 22px;
        border: 1px solid #ffffff;
        background: #ff6600;
        color: #fff;
        letter-spacing: 1px;
    }

    .menuWork.workFull {
        flex-direction: inherit;
        max-width: inherit;
    }

    .menuWork li a,
    .menuWork li:not(:last-child) a {
        border: 1px solid #ff6600;
    }

    .mainMenu .menuList>li.sp {
        display: block;
    }

    /* .mainMenu .menuList>li:first-child a {
        background: #1B5B0F;
        color: #ffffff;
    } */

    .mainMenu .menuList .subMenu li a {
        background: #fff;
        color: #000000;
    }

    .mainMenu .menuList>li:first-child>a::after {
        filter: brightness(0) invert(1);
    }

    .mainMenu .menuList>li a {
        font-size: 24px;
        padding: 26px 5vw;
        position: relative;
        display: block;
    }

    .mainMenu .menuList .subMenu li a {
        font-size: 20px;
    }

    .mainMenu .menuList>li>a::before {
        display: none;
    }

    .mainMenu .menuList>li:has(> .subMenu)>a {
        width: calc(100% - 88px);
    }

    .mainMenu .menuList>li:has(> .subMenu)>span {
        content: "";
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        background-size: 100%;
        width: 88px;
        aspect-ratio: 1 / 1;
        top: 0;
        right: 5vw;
        cursor: pointer;
        transition: 0.3s;
    }

    .mainMenu .menuList>li:has(> .subMenu)>span img {
        height: 30px;
        width: 30px;
    }

    .mainMenu .menuList>li.menuBr:has(> .subMenu)>span {
        transform: rotate(45deg);
    }

    .mainMenu .menuList .subMenu {
        display: none;
        opacity: 1;
        position: initial;
        visibility: initial;
        border: none;
        transform: none;
        transition: none;
        padding: 0 8vw 0;
        margin-bottom: 30px;
        margin-top: -12px;
    }

    .mainMenu .menuList .subMenu li a {
        border-bottom: none;
        padding-left: 20px;
    }

    .mainMenu .menuList .subMenu li a:after {
        background: #000000;
        width: 10px;
        height: 10px;
        right: inherit;
        left: 0;
        border-radius: 50%;
    }
}

@media (max-width: 881px) and (min-width: 769px) {
    #footer .ftInfo {
        width: 216px;
    }

    #footer .ftMenu {
        width: calc(100% - 255px);
    }
}

@media (min-width: 981px) {
    .mainMenu .menuList .subMenu li a:hover {
        color: #3A9F34;
    }
}

/* SHOW HIDE PC SP */
@media (min-width: 769px) {
    .sp {
        display: none;
    }

    .hover:hover {
        opacity: 0.6;
    }

    .scrollToTop a:hover {
        background: #3a9f36;
    }
    
    .scrollToTop a:hover .icon img {
        filter: brightness(0) invert(1);
    }

    #header .inner {
        width: auto;
        padding: 0;
    }

    .breadcrumb .listBreadcrumb li a:hover {
        text-decoration: underline;
        text-underline-offset: 4px;
    }

    .mainMenu .menuList>li>a:hover::before {
        width: 100%;
    }

    .menuWork li a:hover {
        background: #ff5722;
        color: #fff;
    }

    .menuWork li.orange a:hover,
    #header .mainMenu .menuWork.workFull li a:hover {
        background: #ff5722;
        color: #fff;
    }


    .areaContact .contactAbout li a:hover:before,
    .areaContact .contactAbout li a:hover:after {
        transform: scale(1, 1);
    }

    .contactWrap .contactList li a:hover {
        background: #FF6600;
    }

    .contactWrap .contactList li:first-child a {
        pointer-events: none;
    }

    .contactWrap .contactList li a:hover .txtInquiry:after {
        transform: translate(20px, -50%);
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a:hover {
        background: #ffffff;
        color: #FF6600;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a:hover span:after {
        transform: translate(20px, -50%);
        background: url(../images/common/arrow-ft-hover.png) no-repeat;
        background-size: 100%;
    }

    #footer .ftInfo .ftInquiry a:hover {
        background: #FF6600;
        border: 2px solid #FF6600;
    }

    #footer .ftInfo .ftInquiry a:hover .icon::before {
        right: -20px;
    }

    #footer .ftMenu .menuList a:hover {
        color: #3A9F34;
    }

    #footer .ftMenu .menuList .listSmall li a:hover:before {
        left: 0;
        width: 100%;
        background-color: rgba(57, 159, 52, 0.5);
    }

    #footer .ftMenu .menuList>li .listSmall {
        display: block !important;
    }
}

/* STYLE MOBILE */
@media (max-width: 768px) {
    .pc {
        display: none;
    }

    .inner {
        width: 100%;
        padding: 0 6%;
    }

    .scrollToTop {
        right: 10px;
    }

    .scrollToTop a {
        width: clamp(45px, 12vw, 60px);
        height: clamp(45px, 12vw, 60px);    
        padding: 12px 10px 13px;
    }

    .scrollToTop a .icon img {
        width: clamp(20px, 5.4vw, 30px);
    }

    /* MENU */
    .hamburger {
        width: clamp(35px, 10vw, 50px);
        height: clamp(35px, 10vw, 50px);
        padding: 0 5px;
        z-index: 9991;
    }

    .hamburger.sp {
        margin-left: 0;
    }

    .hamburger span {
        display: block;
        height: 2px;
        width: 100%;
    }

    .hamburger span:nth-child(1) {
        margin-bottom: 2vw;
    }

    .hamburger span:nth-child(2) {
        opacity: 1
    }

    .hamburger span:nth-child(3) {
        margin-top: 2vw;
    }

    .hamburger.open span:nth-child(1) {
        margin-bottom: -2px;
    }

    .hamburger.open span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.open span:nth-child(3) {
        margin-top: -2px;
    }

    #header .headerBar {
        padding: 0 6%;
    }

    .wrapHamburgerSp.sp {
        justify-content: flex-end;
        width: 45vw;
    }

    #header .menuWork {
        margin-right: 6vw;
    }

    #header .headerBar .inner {
        padding: 0;
    }

    .headerBar .logo {
        width: clamp(150px, 40vw, 260px);
        margin-top: 0;
    }

    #header .menuWork.workFull li {
        width: clamp(100px, 27vw, 150px);
    }

    .mainMenu .menuList>li:has(> .subMenu)>span img {
        width: clamp(30px, 8vw, 40px);
        height: clamp(30px, 8vw, 40px);
        right: 7vw;
    }

    .menuWork li a,
    .menuWork.workFull li a {
        font-size: clamp(16px, 4.3vw, 22px);
        padding: 4vw 5px;
    }

    .mainMenu {
        padding: 0 0 50vw;

    }

    .mainMenu .menuList {
        margin-right: 0;
        padding: 0;
    }

    .mainMenu .menuList>li:has(> .subMenu)>a {
        font-size: clamp(18px, 4.8vw, 24px);
        padding: 25px 25px 30px;
        width: calc(100% - 116px);
    }

    .mainMenu .menuList>li:has(> .subMenu)>span {
        background-size: 100%;
        width: 91px;
        right: 25px;
        transition: 0.3s;
    }

    .mainMenu .menuList .subMenu {
        margin-bottom: 0;
        padding: 0 10vw;
        margin-top: -9px;
    }

    .mainMenu .menuList .subMenu li {
        margin-bottom: 3vw;
    }

    .mainMenu .menuList .subMenu li a {
        padding: 0 0 0 20px;
    }

    #header .mainMenu .menuWork.workFull li a,
    .mainMenu .menuList .subMenu li a {
        font-size: clamp(16px, 4.3vw, 22px);
    }

    #header .mainMenu .menuWork.workFull {
        padding: 0 7vw;
    }

    #header .mainMenu .menuWork.workFull li a {
        padding: 4vw 5px 4vw;
    }

    .breadcrumb {
        padding: clamp(18px, 5vw, 30px);
        padding-left: 0;
        padding-right: 0;
    }

    .breadcrumb .listBreadcrumb li a {
        background-position-y: 5px;
        font-size: clamp(14px, 3.8vw, 16px);
        background-size: 8px;
    }

    #main .mainPhoto img {
        min-height: 330px;
    }

    #main .mainWrap {
        width: 100%;
        min-width: auto;
        padding: 3vw 3vw 3vw 9vw;
    }

    #main .mainWrap .mainTitle .titleEn {
        font-size: clamp(48px, 13vw, 70px);
    }

    #main .mainWrap .mainTitle .titleJp {
        font-size: clamp(14px, 3.5vw, 20px);
    }

    #main .mainWrap .mainSub {
        margin-left: 6.1vw;
        font-size: 6.3vw;
        padding: 0 4.9vw;
        margin-top: -1vw;
    }

    #main .mainWrap .mainSub::before {
        left: -1vw;
    }


    .areaTitle .titleEn {
        font-size: 10.2vw;
    }

    .areaTitle.titleCenter .titleEn {
        font-size: 8vw;
    }

    .areaTitle .titleJp {
        font-size: 3.8vw;
    }

    .areaContact {
        padding: clamp(70px, 19vw, 90px) 0 clamp(228px, 55vw, 260px);
    }

    .areaContact .inner {
        padding: 0 12%;
    }

    .areaContact .contactAbout {
        flex-direction: column;
    }

    .areaContact .contactAbout li {
        width: 100%;
    }

    .areaContact .contactAbout li a .aboutPhoto img {
        aspect-ratio: 137 / 95;
    }

    .areaContact .contactAbout li a .wrapAboutName .aboutName {
        font-size: 6.4vw;
    }

    .areaContact .contactAbout li a .wrapAboutName .arrowContact {
        width: 10vw;
        height: 10vw;
    }

    .fixFtRecruit {
        padding: 0;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit {
        padding: 0;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li {
        width: 50%;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li:not(:last-child) {
        border-right: 1px solid #fff;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a {
        padding: 4vw 2vw 4vw 2vw;
        font-size: clamp(14px, 3.8vw, 26px);
        border-radius: 0;
        border: none;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a span {
        padding-right: 9vw;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a span:after {
        top: 52%;
        width: clamp(26px, 7vw, 45px);
        height: clamp(26px, 7vw, 45px);
    }

    .boxContact {
        padding: 0 11%;
    }

    .contactWrap {
        padding: 7vw 5vw 10vw;
        margin-bottom: 14vw;
    }

    .contactWrap .contactTitle {
        font-size: 9vw;
        font-size: clamp(32px, 9vw, 36px);
    }

    .contactWrap .contactList {
        flex-direction: column;
        margin-top: 5px;
    }

    .contactWrap .contactList li {
        width: 100%;
        margin-bottom: 20px;
    }

    .contactWrap .contactList li:last-child {
        margin-bottom: 0;
    }

    .contactWrap .contactList li a {
        height: 18.9vw;
        padding: 10px 10px 10px;
    }

    .contactWrap .contactList li a .telContact {
        font-size: 6.2vw;
        padding: 0 0 0 12vw;
    }

    .contactWrap .contactList li a .telContact:before {
        width: 7vw;
        height: 7vw;
    }

    .contactWrap .contactList li a .txtInquiry {
        padding: 0 13vw 0 0;
        font-size: 4.3vw;
        letter-spacing: 0;
    }

    .contactWrap .contactList li a .txtInquiry:after {
        width: 7vw;
        height: 7vw;
    }

    .contactWrap .contactList li:nth-child(2) a {
        padding: 10px 10px 10px;
    }

    #footer {
        padding-bottom: 30px;
    }

    .fixFtRecruit+#footer {
        padding: 15vw 0 clamp(90px, 25vw, 145px);
    }

    #footer .inner {
        flex-direction: column;
    }

    #footer .ftInfo {
        margin: 0 auto 10vw;
        width: 70vw;
    }

    #footer .ftInfo .ftInquiry {
        margin-left: auto;
    }

    #footer .ftInfo .ftInquiry a .icon {
        font-size: clamp(16px, 4.3vw, 22px);
        padding-right: 30px;
        font-weight: 500;
    }

    #footer .ftInfo .ftInquiry a {
        padding: 2vw 2vw 2.4vw;
    }

    #footer .ftInfo .ftInquiry a .icon::before {
        width: clamp(19px, 5vw, 22px);
        height: clamp(15px, 4vw, 18px);
    }

    #footer .ftMenu {
        width: 100%;
        box-shadow: 0 0 0 100vmax #1B5B0F;
        -webkit-clip-path: inset(0 -100vmax);
        clip-path: inset(0 -100vmax);
    }

    #footer .ftMenu .menuList {
        background: #1B5B0F;
    }

    #footer .ftMenu .menuList .menuName {
        color: #ffffff;
    }

    #footer .ftMenu .menuList>li,
    #footer .ftMenu .menuList>li:not(:last-child) {
        min-width: initial;
        margin-right: 0;
        width: 100%;
    }

    #footer .ftMenu .menuList>li:not(:last-child) {
        padding: clamp(22.5px, 6vw, 24px) 0;
        border: 1px solid #ffffff;
        border-width: 0 0 1px 0;
    }

    #footer .ftMenu .menuList>li {
        padding: 0;
    }

    #footer .ftMenu .menuList>li .menuName,
    #footer .ftMenu .menuList .menuName>a {
        position: relative;
        font-size: 4.8vw;
        color: #ffffff;
        margin-bottom: 0;
        font-size: clamp(18px, 4.8vw, 22px);
    }

    #footer .ftMenu .menuList>li:last-child .menuName {
        padding: clamp(22.5px, 6vw, 24px) 0;
        border: 1px solid #ffffff;
        border-width: 0 0 1px 0;
    }

    #footer .ftMenu .menuList>li:last-child .menuName:last-child {
        border-width: 0;
    }

    #footer .ftMenu .menuList>li:not(:last-child) .menuName {
        margin-bottom: 0;
    }


    #footer .ftMenu .menuList>li:has(> .listSmall)>.menuName::after {
        content: "";
        position: absolute;
        background: url(../images/common/icon-toggle-menu.svg) no-repeat;
        background-size: 100%;
        top: 50%;
        transform: translateY(-50%);
        right: 0;
        transition: 0.3s;
        width: clamp(30px, 8vw, 40px);
        height: clamp(30px, 8vw, 40px);
        filter: brightness(0) invert(1);
    }

    #footer .ftMenu .menuList>li:has(> .listSmall)>.menuName.menuFooter::after {
        transform: translateY(-50%) rotate(45deg);
    }


    #footer .ftMenu .menuList>li .listSmall {
        display: none;
    }

    #footer .ftMenu .menuList>li:not(:last-child) .listSmall {
        margin: 10px 15px;
        margin-top: 15px;
    }

    #footer .ftMenu .menuList>li:not(:last-child) .listSmall li:not(:last-child) {
        margin-bottom: 15px;
    }

    #footer .ftMenu .menuList .listSmall li a {
        font-size: 3.8vw;
        padding-left: 20px;
        color: #ffffff;
        font-size: clamp(16px, 3.8vw, 20px);
    }

    #footer .ftMenu .menuList .listSmall li a::before {
        content: "";
        position: absolute;
        background: #ffffff;
        width: clamp(7px, 2.2vw, 10px);
        height: clamp(7px, 2.2vw, 10px);
        top: 9px;
        left: 0;
        border-radius: 50%;
    }

    #footer #copyright {
        margin-top: 40px;
        margin-left: 0;
        letter-spacing: 0;
        text-align: center;
        font-size: clamp(14px, 3.8vw, 16px);
    }

    #footer #copyright br {
        display: none;
    }

}

@media (max-width: 500px) {
    #footer #copyright br {
        display: block;
    }

    .fixFtRecruit .wrapFixRecruit .listFixrecruit li a {
        padding: 5vw 2vw 5vw 2vw;
    }
}

@media (max-width: 430px) {
    .mainMenu .menuList>li:has(> .subMenu)>a {
        width: calc(100% - 82px);
        padding: 25px 25px 30px;
    }

    .mainMenu .menuList>li:has(> .subMenu)>span {
        width: 82px;
        right: 0;
    }

    .mainMenu .menuList .subMenu {
        padding: 0 40px;
    }
}

@media (max-width: 375px) {
    #main .mainWrap .mainSub {
        margin-left: 6vw;
        font-size: 6vw;
    }
}