#sec1 {
    position: relative;
    padding-bottom: 20vw
}

#sec1:after {
    content: "";
    position: absolute;
    background: #000;
    inset: auto 0 0 19%;
    height: 17%;
    z-index: -1
}

#sec1 .bg {
    position: absolute;
    inset: 0 18% auto 0;
    z-index: -1
}

#sec1 .bg img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

#sec1 .gr1 .photo1 {
    padding: 15vw 0 0 30%
}

#sec1 .gr1 .inner h2 {
    position: relative;
    width: -moz-fit-content;
    width: fit-content;
    margin: 5vw auto;
    font-size: 6.6vw;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec1 .gr1 .inner .txt-deco1 {
    margin: -30vw 0 10vw 0;
    z-index: -1;
    position: relative
}

#sec1 .gr2 .photo2 {
    margin-right: 20%
}

#sec1 .gr2 .txt {
    margin: 5vw 0 0 20%
}

#sec1 .list-photo {
    display: flex;
    margin-top: 25vw
}

#sec1 .list-photo li {
    height: -moz-fit-content;
    height: fit-content
}

#sec1 .list-photo li:nth-child(1) {
    margin-top: -9vw
}

#sec1 .list-photo li:nth-child(2) {
    margin: 0 -10% 0 6%
}

#sec1 .list-photo li:nth-child(3) {
    margin-top: -17vw
}

#sec1 .bnr-shared {
    margin: 10vw auto 0
}

@media screen and (min-width: 1000px) {
    #sec1 {
        padding-bottom: 130px
    }

    #sec1:after {
        height: 25.67%;
        left: calc(50% - 379px)
    }

    #sec1 .bg {
        inset: 0 50% 0 0;
        height: 1755px
    }

    #sec1 .wrap {
        max-width: 1500px
    }

    #sec1 .gr1 {
        position: relative;
        z-index: 1;
        padding: 437px 0 157px
    }

    #sec1 .gr1 .photo1 {
        padding: 0;
        inset: 340px 0 0 calc(50% + 103px);
        height: 437px
    }

    #sec1 .gr1 .inner {
        position: relative;
    }

    #sec1 .gr1 .inner h2 {
        margin: 0;
        padding-left: 16.6%;
        font-size: 40px;
        line-height: 70px
    }

    #sec1 .gr1 .inner .txt-deco1 {
        margin: 0;
        position: absolute;
        inset: 53% 41.6% 0 26px;
        height: -moz-fit-content;
        height: fit-content;
        transform: translateY(-50%)
    }

    #sec1 .gr1 .inner .txt-deco1 img {
        width: 100%;
        height: auto
    }

    #sec1 .gr1 .txt-deco2 {
        position: absolute;
        inset: auto 10.1% 0 151px;
    }

    #sec1 .gr1 .txt-deco2 img {
        width: 100%;
    }

    #sec1 .gr2 {
        display: flex;
        max-width: 1070px
    }

    #sec1 .gr2 .photo2 {
        margin: -3px 0 0 0;
        height: 324px;
        width: calc(100% - 595px)
    }

    #sec1 .gr2 .photo2 img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec1 .gr2 .txt {
        width: 511px;
        margin: 90px 0 0 65px
    }

    #sec1 .list-photo {
        display: flex;
        margin: 70px 0 0 150px
    }

    #sec1 .list-photo li img {
        width: 100%;
        height: auto
    }

    #sec1 .list-photo li:nth-child(1) {
        margin-top: 0
    }

    #sec1 .list-photo li:nth-child(2) {
        margin: 6.7vw -94px 0 82px
    }

    #sec1 .list-photo li:nth-child(3) {
        margin-top: -5.1vw
    }

    #sec1 .bnr-shared {
        margin: 79px auto 0
    }
}

@media screen and (min-width: 1000px)and (max-width: 1370px) {
    #sec1 .txt-deco2 {
        margin-right: calc(-50vw + 50% + 8px)
    }

    #sec1 .txt-deco2 img {
        width: 100%;
        height: auto
    }
}

#sec2 {
    position: relative;
    padding: 15vw 0 15vw
}

#sec2::before {
    content: "";
    position: absolute;
    background: #f8f8f8;
    height: 60vw;
    inset: auto 0 0 0;
    z-index: -1
}

#sec2 .txt-js {
    position: relative;
    width: 30vw;
    height: 30vw;
    margin: -30vw 0 10vw
}

#sec2 .txt-js li {
    position: absolute;
    width: 30vw;
    height: 30vw;
    inset: 0 auto auto 0;
}

#sec2 .txt-js li.outer {
    animation: loadingSpinner 32s infinite linear
}

#sec2 .txt-js li.inner {
    animation: loadingSpinner 32s infinite linear reverse
}

#sec2 .gr-txt h2 {
    font-size: 5.7vw;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec2 .gr-txt .txt {
    margin-top: 5vw
}

#sec2 .gr-photo {
    margin-top: 10vw;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between
}

#sec2 .gr-photo dl {
    position: relative;
    width: 48%;
    margin-bottom: 4vw
}

#sec2 .gr-photo dl dt {
    position: absolute;
    font-size: 9.3vw;
    line-height: 1;
    letter-spacing: .06em;
    z-index: 1;
    color: #fff
}

#sec2 .gr-photo dl dd {
    height: 32vw
}

#sec2 .gr-photo dl dd img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

#sec2 .gr-photo dl:nth-child(1) dt {
    top: 2vw;
    left: 2vw
}

#sec2 .gr-photo dl:nth-child(2) dt {
    bottom: 2vw;
    left: 2vw
}

#sec2 .gr-photo dl:nth-child(3) dt {
    bottom: 2vw;
    right: 2vw
}

#sec2 .gr-photo dl:nth-child(4) dt {
    top: 2vw;
    right: 2vw
}

@media screen and (min-width: 1000px) {
    #sec2 {
        padding: 138px 0 425px 0;
        position: relative
    }

    #sec2::before {
        height: 600px;
        width: 78.5%
    }

    #sec2 .wrap {
        max-width: 1050px
    }

    #sec2 .txt-js {
        margin: 0;
        position: absolute;
        width: 189px;
        height: 189px;
        inset: -101px auto auto calc(50% - 475px);
    }

    #sec2 .txt-js li {
        width: 189px;
        height: 189px
    }

    #sec2 .gr-txt {
        display: flex;
        justify-content: flex-end;
    }

    #sec2 .gr-txt h2 {
        order: 2;
        font-size: 33px;
        line-height: 57px;
        margin: 68px 12px 0 0
    }

    #sec2 .gr-txt .txt {
        order: 1;
        margin: 69px 30px 0 0;
        height: 408px;
        word-break: break-all;
    }

    #sec2 .gr-photo {
        margin-top: 0;
        display: unset;
        position: absolute;
        top: 0;
        right: 50%;
        left: -24px
    }

    #sec2 .gr-photo dl {
        width: auto;
        margin-bottom: 0
    }

    #sec2 .gr-photo dl dt {
        font-size: 60px;
        line-height: 65px
    }

    #sec2 .gr-photo dl:nth-child(1) {
        position: relative;
        z-index: 1;
        margin-right: 38%
    }

    #sec2 .gr-photo dl:nth-child(1) dt {
        top: 8px;
        left: 6px
    }

    #sec2 .gr-photo dl:nth-child(1) dd {
        height: 228px
    }

    #sec2 .gr-photo dl:nth-child(2) {
        margin: -60px 0% 0 178px
    }

    #sec2 .gr-photo dl:nth-child(2) dt {
        bottom: 7px;
        left: 8px
    }

    #sec2 .gr-photo dl:nth-child(2) dd {
        height: 247px
    }

    #sec2 .gr-photo dl:nth-child(3) {
        margin: 60px 20.5% 0 88px;
        position: relative;
        z-index: 1
    }

    #sec2 .gr-photo dl:nth-child(3) dt {
        bottom: 8px;
        right: 5px
    }

    #sec2 .gr-photo dl:nth-child(3) dd {
        height: 248px
    }

    #sec2 .gr-photo dl:nth-child(4) {
        margin: -138px -29.6% 0 70.5%
    }

    #sec2 .gr-photo dl:nth-child(4) dt {
        top: 6px;
        right: 6px
    }

    #sec2 .gr-photo dl:nth-child(4) dd {
        height: 248px
    }
}

@media screen and (min-width: 1000px)and (max-width: 1120px) {
    #sec2 .gr-photo {
        left: calc(-50vw + 50% + 10px)
    }
}

#sec3 {
    position: relative;
    padding-bottom: 15vw
}

#sec3 .txt-deco {
    position: absolute;
    inset: 0 0 auto;
}

#sec3 .map {
    padding-top: 5vw
}

#sec3 .gr-line {
    position: relative
}

#sec3 .gr-line .point {
    position: absolute;
    width: 2vw;
    top: -22vw;
    left: 13%
}

#sec3 .gr-line .line {
    position: absolute
}

#sec3 .gr-line .line.line1 {
    top: -30vw;
    left: 15%;
    right: 45%
}

#sec3 .gr-line .line.line2 {
    top: -43vw;
    left: 14%;
    right: 41%
}

#sec3 .gr-line .line.line3 {
    top: -75vw;
    left: 14%;
    right: 28%
}

#sec3 .gr-line .line.line4 {
    top: -51vw;
    left: 0%;
    right: 86%
}

#sec3 h2 {
    padding-top: 10vw;
    font-size: 5.7vw;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec3 .txt {
    margin-top: 5vw
}

@media screen and (min-width: 1000px) {
    #sec3 {
        padding-bottom: 196px
    }

    #sec3 .wrap {
        max-width: 1040px;
        padding: 0 16px 0;
        box-sizing: border-box
    }

    #sec3 .txt-deco {
        max-width: 1500px;
        margin: 0 auto
    }

    #sec3 .txt-deco img {
        width: 100%;
        height: auto
    }

    #sec3 .map {
        padding-top: 0;
        position: absolute;
        inset: -93px auto auto calc(50% - 82px);
    }

    #sec3 .gr-line {
        position: relative
    }

    #sec3 .gr-line .point {
        width: auto;
        inset: 355px auto auto calc(50% + 5px);
    }

    #sec3 .gr-line .line {
        width: -moz-fit-content;
        width: fit-content;
        right: auto !important
    }

    #sec3 .gr-line .line.line1 {
        inset: 300px auto auto calc(50% + 10px);
    }

    #sec3 .gr-line .line.line2 {
        inset: 209px auto auto calc(50% + 9px);
    }

    #sec3 .gr-line .line.line3 {
        inset: -3px auto auto calc(50% + 9px);
    }

    #sec3 .gr-line .line.line4 {
        inset: 148px auto auto calc(50% - 82px);

    }

    #sec3 h2 {
        padding-top: 107px;
        font-size: 33px;
        line-height: 56px
    }

    #sec3 .txt {
        margin: 40px 0 0 4px;
        width: 419px
    }
}

#sec4 {
    background: url("../img/recruit/sec4_bg.jpg") no-repeat center/cover;
    height: 26vw
}

@media screen and (min-width: 1000px) {
    #sec4 {
        height: 400px
    }
}

#sec5 {
    padding: 13vw 0
}

#sec5 h2 {
    font-size: 5.7vw;
    text-align: center;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec5 .set {
    margin-top: 15vw;
    background: #f1f1f1;
    box-sizing: border-box;
    padding: 10vw
}

#sec5 .set .person {
    position: relative
}

#sec5 .set .person dd {
    margin-top: -10vw;
    display: flex;
    align-items: flex-end;
    justify-content: space-between
}

#sec5 .set .person dd span {
    display: block
}

#sec5 .set .person dd span:nth-child(1) {
    margin-left: -12%
}

#sec5 .set .person dd span:nth-child(2) {
    font-size: 16px;
    letter-spacing: .06em
}

#sec5 .set .info {
    margin-top: 7vw
}

#sec5 .set .info dt {
    font-size: 4vw;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec5 .set .info dd {
    margin-top: 2vw
}

@media screen and (min-width: 1000px) {
    #sec5 {
        padding: 66px 0 141px
    }

    #sec5 h2 {
        font-size: 33px;
        line-height: 61px
    }

    #sec5 .set {
        padding: 79px 76px 92px 69px;
        position: relative
    }

    #sec5 .set .person {
        width: -moz-fit-content;
        width: fit-content
    }

    #sec5 .set .person dd {
        margin-top: -43px
    }

    #sec5 .set .person dd span:nth-child(1) {
        margin-left: -36px
    }

    #sec5 .set .person dd span:nth-child(2) {
        font-size: 18px;
        line-height: 22px;
        margin-right: -3px
    }

    #sec5 .set .info {
        margin-top: 0;
        width: 443px;
        line-height: 30px
    }

    #sec5 .set .info dt {
        font-size: 20px
    }

    #sec5 .set .info dd {
        margin-top: 6px
    }

    #sec5 .set .info.info4 {
        width: 363px
    }

    #sec5 .set .info+.info {
        margin-top: 28px
    }

    #sec5 .set.set1 {
        margin-top: 68px
    }

    #sec5 .set.set1 .right {
        position: absolute;
        top: 73px;
        left: 492px
    }

    #sec5 .set.set1 .info.info4 {
        margin-top: 29px
    }

    #sec5 .set.set1 .info.info5 {
        position: absolute;
        top: 535px;
        left: 490px
    }

    #sec5 .set.set2 {
        margin-top: 82px
    }

    #sec5 .set.set2 .person {
        margin-left: auto
    }

    #sec5 .set.set2 .left {
        position: absolute;
        top: 73px;
        left: 71px
    }

    #sec5 .set.set2 .info.info4 {
        margin: 28px -9px 0 auto
    }

    #sec5 .set.set2 .info.info5 {
        position: absolute;
        top: 536px;
        left: 70px
    }
}

#sec6 {
    padding: 15vw 4% 23vw;
    position: relative
}

#sec6::before {
    content: "";
    position: absolute;
    background: #f1f1f1;
    bottom: 0;
    left: 0;
    right: 0;
    height: 90vw
}

#sec6 .wrap {
    background: #404040;
    color: #fff;
    text-align: center;
    padding: 20vw 4% 10vw
}

#sec6 .wrap::before {
    content: "";
    position: absolute;
    background: #741e2a;
    width: 2px;
    height: 14vw;
    top: -7vw;
    left: 50%;
    transform: translateX(-50%)
}

#sec6 .wrap h2 {
    font-size: 6vw;
    line-height: 1.5;
    letter-spacing: .06em
}

#sec6 .wrap .txt-1 {
    margin-top: 7vw
}

#sec6 .wrap .tel {
    line-height: 1.5;
    font-size: 4.8vw;
    letter-spacing: .06em
}

#sec6 .wrap .tel span {
    font-size: 6vw;
    letter-spacing: .06em
}

#sec6 .bnr-shared {
    margin: 10vw auto 0
}

@media screen and (min-width: 1000px) {
    #sec6 {
        padding: 0 0 120px
    }

    #sec6::before {
        height: 425px
    }

    #sec6 .wrap {
        padding: 62px 0 57px
    }

    #sec6 .wrap::before {
        height: 64px;
        top: -32px
    }

    #sec6 .wrap h2 {
        font-size: 33px;
        line-height: 56px
    }

    #sec6 .wrap .txt-1 {
        margin-top: 14px
    }

    #sec6 .wrap .tel {
        font-size: 24px;
        line-height: 36px;
        padding-left: 5px
    }

    #sec6 .wrap .tel span {
        font-size: 33px
    }

    #sec6 .bnr-shared {
        margin: 80px auto 0
    }
}