#sec1 {
    position: relative;
    padding: 43vw 0 20vw
}

#sec1::before {
    content: "";
    position: absolute;
    inset: 43vw 0 -15vw;
    z-index: -1;
    background: url("../img/employee/sec1_patern.png") repeat center top/1000px auto
}

#sec1 .set1 {
    position: relative
}

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

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

#sec1 .set1 h2 {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 20vw 0;
    font-size: 12vw;
    line-height: 1;
    font-weight: 500;
    letter-spacing: .06em
}

#sec1 .set2 {
    position: relative;
    margin-top: 15vw
}

#sec1 .set2 h3 {
    text-align: center;
    font-size: 10vw;
    font-weight: 500;
    line-height: 1.5384615385;
    letter-spacing: .06em
}

#sec1 .set2 h3 small {
    display: block;
    font-size: 6.67vw;
    line-height: 2;
    letter-spacing: .06em
}

#sec1 .set2 .txt {
    position: relative;
    z-index: 1;
    background: url("../img/employee/sec1_line_sp.png") repeat left top/auto 40px;
    margin-top: 5vw;
    line-height: 40px
}

#sec1 .set2 .deco1 {
    position: absolute;
    top: -30vw;
    right: 5%;
    z-index: 1;
    width: 30%
}

#sec1 .set2 .deco2 {
    position: absolute;
    bottom: 5vw;
    left: -5%;
    width: 40%
}

#sec1 .set2 .deco3 {
    width: 70%;
    margin: 5vw -5% 0 auto
}

#sec1 .set3 {
    transform: rotate(5deg);
    margin: 10vw -10% 0
}

#sec1 .set3 .loop-slider .item {
    width: 50vw;
    margin: 0 1.5vw
}

@media screen and (min-width: 768px) {
    #sec1 {
        padding: 153px 0 171px
    }

    #sec1::before {
        top: 153px;
        bottom: -191px
    }

    #sec1 .set1 h2 {
        padding: 162px 0 123px;
        font-size: 80px
    }

    #sec1 .set2 {
        margin-top: 20px
    }

    #sec1 .set2::before {
        background-size: auto
    }

    #sec1 .set2 h3 {
        margin: 0 -17px 0 32px;
        font-size: 65px
    }

    #sec1 .set2 h3 small {
        font-size: 40px
    }

    #sec1 .set2 .txt {
        text-align: center;
        background: url("../img/employee/sec1_line_pc.png") repeat left top/auto 60px;
        width: 913px;
        margin: 29px auto 0;
        line-height: 60px
    }

    #sec1 .set2 .deco1 {
        top: -160px;
        right: 69px;
        width: auto
    }

    #sec1 .set2 .deco2 {
        top: 117px;
        bottom: auto;
        left: -67px;
        width: auto;
        z-index: 1;
    }

    #sec1 .set2 .deco3 {
        position: absolute;
        top: 539px;
        right: -24px;
        width: auto;
        margin: 0;
        z-index: 1;
    }

    #sec1 .set3 {
        margin-top: 314px
    }

    #sec1 .set3 .loop-slider .item {
        width: auto;
        margin: 0 8px
    }
}

@media screen and (min-width: 768px)and (max-width: 1300px) {
    #sec1 .set2 .deco1 {
        right: -30px
    }

    #sec1 .set2 .deco2 {
        top: 80px;
        width: 28.7692307692%
    }

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

    #sec1 .set2 .deco3 {
        top: 600px;
        width: 39.2307692308%
    }

    #sec1 .set2 .deco3 img {
        width: 100%;
        height: auto
    }
}

#sec2 .lead {
    background: url("../img/shared/bg1.jpg") repeat center;
    color: #fff;
    padding: 10vw 4%;
    margin-bottom: 10vw
}

#sec2 .lead h2 {
    text-align: center;
    font-size: 6vw;
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: .06em
}

#sec2 .lead h2 span {
    display: inline-block;
    letter-spacing: .06em
}

#sec2 .lead h2 .fs1 {
    position: relative;
    font-size: 10vw
}

#sec2 .lead h2 .fs1::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background: url("../img/employee/sec2_deco_ttl.png") no-repeat center/100%;
    width: 9vw;
    height: 4vw
}

#sec2 .lead h2 .fs2 {
    font-size: 7.33vw
}

#sec2 .lead .txt-en {
    position: relative;
    text-align: right;
    font-size: 4vw;
    line-height: 1;
    letter-spacing: .025em
}

#sec2 .lead .txt-en::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: #fff;
    height: 1px
}

#sec2 .lead .group-point {
    position: relative;
    display: flex;
    justify-content: space-between;
    margin-top: 10vw;
    padding-top: 38vw
}

#sec2 .lead .group-point li {
    background: #fff;
    color: #000;
    border-radius: 50%;
    width: 40vw;
    height: 40vw;
    padding-top: 9vw
}

#sec2 .lead .group-point li:nth-child(1) {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%)
}

#sec2 .lead .group-point li span {
    display: block;
    text-align: center;
    line-height: 1.8;
    letter-spacing: .06em
}

#sec2 .lead .group-point li span.en {
    font-size: 4.83vw
}

#sec2 .lead .group-point li span.jp {
    font-size: 3.5vw
}

#sec2 .set {
    position: relative;
    overflow: hidden;
    color: #fff
}

#sec2 .set::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: url("../img/shared/bg1.jpg") repeat center
}

#sec2 .set .point {
    position: relative;
    z-index: 1;
    text-align: center;
    color: #000;
    padding: 3vw 0 8vw;
    font-size: 4vw;
    font-weight: 500;
    line-height: 2.3333333333;
    letter-spacing: .06em
}

#sec2 .set .point::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    background: #000;
    height: 4px;
    width: 50%
}

#sec2 .set .point::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    z-index: -1;
    transform: translateX(-50%);
    background: #fff;
    border-radius: 50%;
    width: 90vw;
    height: 90vw
}

#sec2 .set .row {
    padding: 10vw 6%
}

#sec2 .set .row .group-txt {
    margin-top: 7vw
}

#sec2 .set .row .group-txt h3 {
    text-align: center;
    font-size: 6.73vw;
    font-weight: 500;
    line-height: 1.4583333333;
    letter-spacing: .06em
}

#sec2 .set .row .group-txt .txt {
    margin-top: 7vw
}

#sec2 .set+.set {
    margin-top: 10vw
}

#sec2 .set4 {
    background: url("../img/shared/bg1.jpg") repeat center;
    color: #fff;
    margin-top: 10vw
}

#sec2 .set4 .wrap {
    padding: 0 5% 15vw
}

#sec2 .set4 .photo {
    margin: 0 6% 0 -6%;
    height: 70vw
}

#sec2 .set4 .photo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center right;
    object-position: center right
}

#sec2 .set4 .txt-en {
    position: absolute;
    top: 0;
    right: 5%;
    z-index: 1;
    padding-top: 3vw;
    font-size: 4vw;
    height: 70vw;
    line-height: 1
}

#sec2 .set4 .txt-en::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    background: #fff;
    width: 1px
}

#sec2 .set4 .txt-en span {
    letter-spacing: .025em
}

#sec2 .set4 .group-txt {
    margin-top: 10vw
}

#sec2 .set4 .group-txt h3 {
    text-align: center;
    font-size: 7.73vw;
    font-weight: 500;
    line-height: 1.4583333333;
    letter-spacing: .06em
}

#sec2 .set4 .group-txt .txt {
    margin-top: 7vw
}

@media screen and (min-width: 768px) {
    #sec2 .wrap {
        max-width: 1303px;
        padding: 0 30px
    }

    #sec2 .lead {
        padding: 49px 0 84px;
        margin-bottom: 51px
    }

    #sec2 .lead h2 {
        font-size: 50px;
        line-height: 105px
    }

    #sec2 .lead h2 .fs1 {
        font-size: 80px
    }

    #sec2 .lead h2 .fs1::before {
        top: -11px;
        width: 76px;
        height: 32px
    }

    #sec2 .lead h2 .fs2 {
        font-size: 60px
    }

    #sec2 .lead .txt-en {
        width: 734px;
        margin: -19px auto 0;
        font-size: 20px
    }

    #sec2 .lead .txt-en::before {
        bottom: 1px
    }

    #sec2 .lead .group-point {
        max-width: 856px;
        margin: 27px auto 0;
        padding-top: 0
    }

    #sec2 .lead .group-point li {
        width: 236px;
        height: 236px;
        padding-top: 47px
    }

    #sec2 .lead .group-point li:nth-child(1) {
        position: unset;
        transform: unset
    }

    #sec2 .lead .group-point li span.en {
        font-size: 30px
    }

    #sec2 .lead .group-point li span.jp {
        font-size: 20px
    }

    #sec2 .set {
        position: relative;
        min-height: 626px;
        padding: 0 20px
    }

    #sec2 .set::before {
        top: 6px
    }

    #sec2 .set .point {
        position: absolute;
        top: -9px;
        width: 539px;
        padding: 8px 0 54px;
        font-size: 30px;
        line-height: 55px;
  
    }

    #sec2 .set .point::before {
        width: 200px;
        top: 9px
    }

    #sec2 .set .point::after {
        width: 696px;
        height: 696px
    }

    #sec2 .set .row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 20px;
        max-width: 1092px;
        margin: 0 auto;
        padding: 64px 0 20px
    }

    #sec2 .set .row .group-txt h3 {
        text-align: left;
        font-size: 48px
    }

    #sec2 .set .row .group-txt .txt {
        width: 465px;
        margin-top: 37px
    }

    #sec2 .set .row .photo {
        flex: 1;
        max-width: 420px;
        height: 500px
    }

    #sec2 .set .row .photo img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec2 .set+.set {
        margin-top: 70px
    }

    #sec2 .set:nth-of-type(even) .point {
        left: 0
    }

    #sec2 .set:nth-of-type(even) .row .photo {
        order: 2
    }

    #sec2 .set:nth-of-type(even) .row .group-txt {
        order: 1;
        margin: 164px 0 0 87px
    }

    #sec2 .set:nth-of-type(odd) .point {
        right: 0
    }

    #sec2 .set:nth-of-type(odd) .row .photo {
        order: 1
    }

    #sec2 .set:nth-of-type(odd) .row .group-txt {
        order: 2;
        margin: 146px 77px 0 0
    }

    #sec2 .set.set2 .row .group-txt .txt {
        margin-top: 15px
    }

    #sec2 .set4 {
        margin-top: 76px
    }

    #sec2 .set4 .wrap {
        max-width: 1260px;
        padding: 0 30px 78px
    }

    #sec2 .set4 .photo {
        position: absolute;
        top: 0;
        bottom: 0;
        left: calc(-50vw + 50%);
        right: calc(50% - 60px);
        margin: 0;
        height: auto
    }

    #sec2 .set4 .txt-en {
        right: 55px;
        padding-top: 13px;
        font-size: 20px;
        height: 406px
    }

    #sec2 .set4 .txt-en span {
        display: block;
        width: 20px
    }

    #sec2 .set4 .group-txt {
        width: 450px;
        padding-top: 41px;
        margin: 0 120px 0 auto
    }

    #sec2 .set4 .group-txt h3 {
        font-size: 48px
    }

    #sec2 .set4 .group-txt .txt {
        margin-top: 61px
    }
}

@media screen and (min-width: 768px) and (max-width: 1300px) {
    #sec2 .set4 .txt-en {
        right: calc(-50vw + 50% + 90px);
    }
}

#sec3 {
    background: url("../img/employee/patern1.jpg") repeat-x left bottom/auto 15px, url("../img/employee/sec3_deco1.png") no-repeat left top/100%, url("../img/employee/sec3_deco2.png") no-repeat right bottom/100%;
    padding: 15vw 0
}

#sec3 .col-r .txt {
    text-align: center;
    margin-top: 5vw;
    font-size: 4vw;
    line-height: 1;
    letter-spacing: .06em
}

#sec3 .col-l {
    margin-top: 10vw
}

#sec3 .col-l .txt-en {
    position: relative;
    text-align: right;
    font-size: 4vw;
    line-height: 1;
    letter-spacing: .025em
}

#sec3 .col-l .txt-en::before {
    content: "";
    position: absolute;
    bottom: 1px;
    left: calc(-50vw + 50%);
    right: 0;
    background: #000;
    height: 1px
}

#sec3 .col-l h2 {
    text-align: center;
    margin-top: 7vw;
    font-size: 5.33vw;
    font-weight: 500;
    line-height: 2;
    letter-spacing: .06em
}

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

#sec3 .col-l .txt li+li {
    margin-top: 5vw
}

#sec3 .col-l .btn-s1 {
    margin-top: 7vw
}

@media screen and (min-width: 768px) {
    #sec3 {
        background-size: auto;
        padding: 80px 0 120px
    }

    #sec3 .wrap {
        max-width: 1060px;
        padding: 0 30px
    }

    #sec3 .col-r {
        position: absolute;
        top: 62px;
        left: 563px;
        right: -134px
    }

    #sec3 .col-r .photo {
        height: 681px
    }

    #sec3 .col-r .photo img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec3 .col-r .txt {
        margin-top: 22px;
        font-size: 20px
    }

    #sec3 .col-l {
        width: 470px;
        margin: 0 0 0 23px
    }

    #sec3 .col-l .txt-en {
        margin-right: 148px;
        font-size: 20.5px
    }

    #sec3 .col-l h2 {
        text-align: left;
        margin: 37px 0 0 38px;
        font-size: 30px
    }

    #sec3 .col-l .txt {
        margin: 34px 0 0
    }

    #sec3 .col-l .txt li+li {
        margin-top: 40px
    }

    #sec3 .col-l .btn-s1 {
        width: 340px;
        margin: 35px auto 0
    }
}

@media screen and (min-width: 768px)and (max-width: 1400px) {
    #sec3 .col-r {
        right: calc(-50vw + 50% + 30px)
    }
}

#sec4 {
    position: relative;
    z-index: 1;
    color: #fff
}

#sec4::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: url("../img/employee/patern3.jpg") repeat center
}

#sec4 .set1 h2 {
    text-align: center;
    padding-top: 15vw;
    font-size: 10.4vw;
    font-weight: 600;
    line-height: 1;
    letter-spacing: .06em
}

#sec4 .set1 .txt-en {
    position: absolute;
    top: 0;
    right: 5%;
    height: 50vw;
    padding-top: 3vw;
    font-size: 4vw;
    line-height: 1
}

#sec4 .set1 .txt-en::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    left: 1px;
    background: #fff;
    width: 1px
}

#sec4 .set1 .txt-en span {
    letter-spacing: .025em
}

#sec4 .set1 .row {
    margin-top: 12vw
}

#sec4 .set1 .row .group-txt {
    margin-top: 8vw
}

#sec4 .set1 .row .group-txt h3 {
    text-align: center;
    font-size: 7.73vw;
    font-weight: 500;
    line-height: 1.4583333333;
    letter-spacing: .06em
}

#sec4 .set1 .row .group-txt .txt {
    margin-top: 5vw
}

#sec4 .set2 {
    margin-top: 10vw
}

#sec4 .set2 .sec4-js {
    position: relative;
    z-index: 2;
    padding: 10vw 6%;
    background: url("../img/employee/patern2.jpg") repeat center
}

#sec4 .set2 .sec4-js .slick-arrow {
    width: 10vw;
    height: 10vw
}

#sec4 .set2 .sec4-js .slick-prev {
    background: url("../img/employee/sec4_prev.png") no-repeat center/100%;
    left: 0
}

#sec4 .set2 .sec4-js .slick-next {
    background: url("../img/employee/sec4_next.png") no-repeat center/100%;
    right: 0
}

#sec4 .set2 .sec4-js .item .group-txt {
    margin-top: 5vw
}

#sec4 .set2 .sec4-js .item .group-txt h3 {
    position: relative;
    text-align: center;
    margin-bottom: 5vw;
    padding-bottom: 5vw;
    font-size: 7.73vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .06em
}

#sec4 .set2 .sec4-js .item .group-txt h3::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 4%;
    right: 4%;
    background: #fff;
    height: 1px
}

#sec4 .set2 .sec4-js .item .group-txt h3 small {
    display: block;
    font-size: 4.53vw;
    font-weight: 500;
    letter-spacing: .06em
}

@media screen and (min-width: 768px) {
    #sec4::before {
        bottom: 77px
    }

    #sec4 .set1 .wrap {
        max-width: 1260px;
        padding: 0 30px
    }

    #sec4 .set1 h2 {
        padding-top: 140px;
        font-size: 68px
    }

    #sec4 .set1 .txt-en {
        right: 50px;
        height: 345px;
        padding-top: 21px;
        font-size: 20.59px
    }

    #sec4 .set1 .txt-en span {
        display: block;
        width: 20px
    }

    #sec4 .set1 .row {
        display: flex;
        justify-content: space-between;
        max-width: 1000px;
        gap: 30px;
        margin: 66px auto 0
    }

    #sec4 .set1 .row .photo {
        margin: 5px 0 0 -60px
    }

    #sec4 .set1 .row .group-txt {
        width: 469px;
        margin-top: 0
    }

    #sec4 .set1 .row .group-txt h3 {
        font-size: 48px
    }

    #sec4 .set1 .row .group-txt .txt {
        margin-top: 18px
    }

    #sec4 .set2 {
        margin-top: 97px
    }

    #sec4 .set2 .wrap {
        max-width: 1500px
    }

    #sec4 .set2 .sec4-js {
        max-width: 1200px;
        min-height: 440px;
        margin-left: auto;
        padding: 0
    }

    #sec4 .set2 .sec4-js .slick-list {
        overflow: visible
    }

    #sec4 .set2 .sec4-js .slick-arrow {
        width: 42px;
        height: 42px;
        top: 199px;
        transition: .3s
    }

    #sec4 .set2 .sec4-js .slick-arrow:hover {
        opacity: .8
    }

    #sec4 .set2 .sec4-js .slick-prev {
        left: 36px
    }

    #sec4 .set2 .sec4-js .slick-next {
        right: 36px
    }

    #sec4 .set2 .sec4-js .item {
        display: flex !important;
        justify-content: space-between;
        gap: 30px;
        padding: 28px 125px 0 126px
    }

    #sec4 .set2 .sec4-js .item .photo {
        flex: 1;
        order: 2;
        max-width: 420px;
        height: 281px;
        margin-top: 21px
    }

    #sec4 .set2 .sec4-js .item .photo img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }

    #sec4 .set2 .sec4-js .item .group-txt {
        order: 1;
        width: 459px;
        margin-top: 0
    }

    #sec4 .set2 .sec4-js .item .group-txt h3 {
        margin-bottom: 16px;
        padding-bottom: 18px;
        font-size: 48px
    }

    #sec4 .set2 .sec4-js .item .group-txt h3::before {
        left: 30px;
        right: 30px
    }

    #sec4 .set2 .sec4-js .item .group-txt h3 small {
        font-size: 24px;
        margin-bottom: -7px
    }

    #sec4 .set2 .sec4-js .item .group-txt .txt {
        margin-top: 0px
    }
}

@media screen and (min-width: 768px)and (max-width: 1200px) {
    #sec4 .set1 .row .photo {
        flex: 1;
        max-width: 500px;
        height: 380px;
        margin-left: calc(-50vw + 50% + 30px)
    }

    #sec4 .set1 .row .photo img {
        width: 100%;
        height: 100%;
        -o-object-fit: cover;
        object-fit: cover
    }
}

@media screen and (min-width: 768px) and (max-width: 1300px) {
    #sec4 .set1 .txt-en {
        right: calc(-50vw + 50% + 90px);
    }
}

@media screen and (min-width: 768px)and (max-width: 1366px)and (max-height: 768px) {
    #sec4 .set2 .sec4-js {
        margin-left: auto;
        margin-right: auto
    }
}

#sec5 {
    background: url("../img/employee/sec5_bg.jpg") no-repeat center/cover;
    padding: 15vw 0
}

#sec5 h2 {
    text-align: center;
    font-size: 8.33vw;
    font-weight: 500;
    line-height: 2;
    letter-spacing: .06em
}

#sec5 h3 {
    text-align: center;
    margin-top: 5vw;
    font-size: 6.73vw;
    font-weight: 500;
    line-height: 1.875;
    letter-spacing: .06em
}

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

@media screen and (min-width: 768px) {
    #sec5 {
        padding: 176px 0 60px;
        margin-top: -77px
    }

    #sec5 h2 {
        font-size: 60px
    }

    #sec5 h3 {
        margin-top: 20px;
        font-size: 48px
    }

    #sec5 .txt {
        text-align: center;
        margin-top: 24px
    }
}

#sec6 {
    padding: 5vw 0 15vw
}

#sec6 h2 {
    background: url("../img/employee/sec6_deco_ttl.png") no-repeat right 5% bottom/50%;
    text-align: center;
    margin-top: 8vw;
    padding-bottom: 19vw;
    font-size: 7.73vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .06em
}

#sec6 h2 small {
    font-size: 5.33vw;
    letter-spacing: .06em
}

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

#sec6 .btn-insta {
    margin-top: 9vw
}

#sec6 .btn-insta a {
    font-family: "Noto Serif JP";
    position: relative;
    display: block;
    text-align: center;
    border: 1px solid #002c58;
    padding: 4vw 0;
    font-size: 4.5vw;
    letter-spacing: .2em
}

#sec6 .btn-insta a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 8%;
    transform: translateY(-50%);
    background: url("../img/employee/icon_insta.png") no-repeat center/100%;
    width: 8vw;
    height: 8vw
}

#sec6 .btn-insta a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 8%;
    transform: translateY(-50%);
    background: url("../img/employee/icon_arrow.png") no-repeat center/100%;
    width: 2vw;
    height: 4vw
}

@media screen and (min-width: 768px) {
    #sec6 {
        background-size: auto;
        padding: 113px 0 0
    }

    #sec6 .wrap {
        max-width: 1500px;
        padding-bottom: 110px
    }

    #sec6 .row {
        position: relative;
        z-index: 1;
        max-width: 1000px;
        margin: 0 auto
    }

    #sec6 h2 {
        background-position: right bottom;
        background-size: auto;
        width: 464px;
        margin: 0;
        padding: 0 23px 112px 0;
        font-size: 48px
    }

    #sec6 h2 small {
        font-size: 30px
    }

    #sec6 .photo {
        position: absolute;
        bottom: 0;
        right: 0
    }

    #sec6 .txt {
        width: 460px;
        margin: 58px 0 0 18px
    }

    #sec6 .btn-insta {
        width: 460px;
        margin: 30px 0 0 22px
    }

    #sec6 .btn-insta a {
        padding: 35px 0 44px 30px;
        font-size: 28px
    }

    #sec6 .btn-insta a::before {
        left: 38px;
        width: 63px;
        height: 63px
    }

    #sec6 .btn-insta a:after {
        right: 23px;
        width: 12px;
        height: 22px
    }

    #sec6 .btn-insta a:hover {
        opacity: .8
    }
}

@media screen and (min-width: 768px)and (max-width: 1200px) {
    #sec6 .photo {
        right: -130px
    }
}

#sec7 {
    background: url("../img/employee/patern1.jpg") repeat-x left top/auto 15px;
    padding-top: 15vw
}

#sec7 h2 {
    text-align: center;
    font-size: 10.4vw;
    font-weight: 500;
    line-height: 1;
    letter-spacing: .06em
}

#sec7 .btn-popup4 {
    margin-top: 5vw
}

@media screen and (min-width: 768px) {
    #sec7 {
        background-size: auto;
        padding-top: 134px
    }

    #sec7 h2 {
        font-size: 68px
    }

    #sec7 .btn-popup4 {
        margin-top: 60px
    }
}

#sec8 {
    padding-top: 15vw
}

#sec8 .box {
    position: relative;
    background: url("../img/employee/sec8_bg.jpg") no-repeat center/cover
}

#sec8 .box::before {
    content: "";
    position: absolute;
    inset: 2vw;
    border: 1px solid #e3e3e3
}

#sec8 .box .group-txt {
    padding: 0 6% 10vw
}

#sec8 .box .group-txt h2 {
    text-align: center;
    color: #fff;
    margin: 7vw 0;
    font-size: 7.67vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: .06em
}

#sec8 .box .group-txt h2 small {
    font-size: 6.33vw;
    letter-spacing: .06em
}

@media screen and (min-width: 768px) {
    #sec8 {
        padding-top: 105px
    }

    #sec8 .box {
        max-width: 800px;
        margin: 0 auto
    }

    #sec8 .box::before {
        inset: 12px
    }

    #sec8 .box .photo {
        position: absolute;
        top: -24px;
        left: -20px
    }

    #sec8 .box .group-txt {
        width: 420px;
        margin-left: auto;
        padding: 37px 15px 44px 0
    }

    #sec8 .box .group-txt h2 {
        margin: 0;
        font-size: 40px;
        line-height: 64px
    }

    #sec8 .box .group-txt h2 small {
        font-size: 30px
    }

    #sec8 .box .group-txt .btn-popup {
        margin: 17px 0 0 17px
    }
}

#sec9 {
    padding: 15vw 0
}

#sec9 .group {
    background: url(../img/shared/bg1.jpg);
    padding: 12vw 5% 15vw;
    color: #fff
}

#sec9 .group h2 {
    font-size: 7vw;
    font-weight: 500;
    letter-spacing: .06em;
    line-height: 1.5;
    text-align: center
}

#sec9 .group .btn-mail {
    margin: 8vw 5%
}

#sec9 .group .btn-mail a {
    font-family: "Noto Serif JP";
    font-size: 4vw;
    letter-spacing: .1em;
    display: block;
    padding: 4vw 0;
    color: #fff;
    background: #002c58;
    text-align: center
}

#sec9 .group .btn-mail a img {
    width: 20px;
    height: auto;
    margin-right: 10px;
    position: relative;
    top: -1px
}

#sec9 .group .tel {
    text-align: center;
    letter-spacing: .1em;
    font-size: 13px;
    line-height: 1.5
}

#sec9 .group .tel dd img {
    width: 17px;
    height: auto;
    margin-right: 6px;
    position: relative;
    top: -5px
}

#sec9 .group .tel dd span {
    font-size: 28px;
    font-weight: 700;
    letter-spacing: .1em
}

#sec9 .group .tel dd small {
    font-size: 13px;
    display: block;
    margin-top: 4px
}

@media screen and (min-width: 768px) {
    #sec9 {
        padding: 86px 0 195px
    }

    #sec9 .group {
        padding: 76px 30px 97px
    }

    #sec9 .group h2 {
        font-size: 45px;
        line-height: 80px
    }

    #sec9 .group .btn-mail {
        margin: 38px auto 29px;
        width: 426px
    }

    #sec9 .group .btn-mail a {
        font-size: 18px;
        padding: 18px 0 21px
    }

    #sec9 .group .btn-mail a img {
        width: 28px;
        margin-right: 10px;
        top: -3px;
        left: -10px
    }

    #sec9 .group .btn-mail a:hover {
        background: #1f1f1f
    }

    #sec9 .group .tel {
        font-size: 16px;
        line-height: 30px
    }

    #sec9 .group .tel dd {
        margin-top: 10px
    }

    #sec9 .group .tel dd img {
        width: 22px;
        margin-right: 3px;
        top: -11px;
        left: -5px
    }

    #sec9 .group .tel dd span {
        font-size: 40px
    }

    #sec9 .group .tel dd small {
        font-size: 16px;
        margin-top: 4px
    }
}

.remodal-close {
    background-image: url("../img/shared/close2.png");
    filter: unset
}

.remodal-recruit {
    border: 10px solid #000;
    background: #fff;
    color: #000;
    padding: 10vw 0;
    text-align: left
}

.remodal-recruit * {
    letter-spacing: .04em
}

.remodal-recruit dl {
    border-bottom: 1px solid #000;
    padding: 28px 0
}

@media screen and (min-width: 768px) {
    .remodal-recruit {
        border-width: 20px;
        max-width: 100%;
        padding: 50px 0
    }

    .remodal-recruit .remodal-close {
        margin-right: 50px
    }

    .remodal-recruit .wrap {
        max-width: 767px;
        line-height: 33px
    }

    .remodal-recruit .txt {
        margin-bottom: 26px
    }

    .remodal-recruit dl {
        padding: 0 0 20px 44px
    }

    .remodal-recruit dl+dl {
        margin-top: 20px
    }
}

html:has(.remodal-sec8.remodal-is-opened) .remodal-overlay {
    background: rgba(0, 0, 0, .5)
}

.remodal-sec8 {
    background: #fff;
    color: #000;
    padding: 5vw 0 10vw
}

.remodal-sec8 .remodal-close {
    z-index: 2;
    margin-right: 5%
}

.remodal-sec8 .group-txt {
    text-align: left;
    margin-top: 40px
}

.remodal-sec8 .group-txt * {
    letter-spacing: 0
}

.remodal-sec8 .group-txt dl {
    line-height: 22px
}

.remodal-sec8 .group-txt dl dt {
    font-size: 18px;
    font-weight: bold;
    letter-spacing: 0
}

.remodal-sec8 .group-txt dl dd {
    margin-top: 15px
}

.remodal-sec8 .group-txt dl dd p+p {
    margin-top: 15px
}

.remodal-sec8 .group-txt dl+dl {
    margin-top: 40px
}

@media screen and (min-width: 768px) {
    .remodal-sec8 {
        max-width: 1000px;
        padding: 50px 0 120px;
        margin: 50px 0
    }

    .remodal-sec8 .remodal-close {
        margin-right: 86px
    }

    .remodal-sec8 .wrap {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        padding: 0 86px 0 81px
    }

    .remodal-sec8 .photo {
        position: sticky;
        top: 20px;
        left: 0
    }

    .remodal-sec8 .group-txt {
        width: 450px;
        margin-top: 0
    }

    .remodal-sec8 .group-txt dl {
        line-height: 24px
    }

    .remodal-sec8 .group-txt dl dt {
        font-size: 20px
    }

    .remodal-sec8 .group-txt dl dd {
        margin-top: 23px
    }

    .remodal-sec8 .group-txt dl dd p+p {
        margin-top: 23px
    }

    .remodal-sec8 .group-txt dl+dl {
        margin-top: 50px
    }
}