@charset "utf-8";
/* CSS Document */

/* ==============================
  サイドのエントリーボタン
============================== */
.entry-here {
    position: fixed;
    z-index: 99;
    top: 11.7vw;
    right: 0;
    background-color: #000;
    color: #FFF;
    padding: 2.08em 0.24em 2em 0.29em;
    box-sizing: border-box;
    border-radius: 0.4em 0 0 0.4em;
    font-size: min(1.9vw, 2.5rem);
}
.entry-here a {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    color: #FFF;
}
.entry-here p {
    writing-mode: vertical-lr;
    line-height: 1;
    letter-spacing: 0.16em;
}
.entry-here p.jp-text {
    font-size: min(1vw, 1.4rem);
    margin-top: 4.6em;
    margin-right: 0.3em;
}
@media print, screen and (max-width: 768px) {
    .entry-here {
        top: 30.3vw;
        padding: 3.7vw 2.9vw 3.7vw 1.6vw;
        border-radius: 1.3vw 0 0 1.3vw;
        font-size: 4.4vw;
    }
    .entry-here p.jp-text {
        display: none;
    }
}

/* ==============================
 content-title
============================== */
.content_title-wrap .title-item h4 {
    font-size: min(3.125vw, 4rem);
    font-weight: 700;
    margin-top: 88px;
}
.content_title-wrap .title-item .lead {
    margin-top: 30px;
    width: 859px;
}
@media print, screen and (max-width: 1799px) {
    .content_title-wrap .title-item {
        width: 51.1%;
    }
    .content_title-wrap .title-item h4 {
        font-size: min(3.125vw, 4rem);
        font-weight: 700;
        margin-top: 6.875%;
    }
    .content_title-wrap .title-item .lead {
        margin-top: 2.34%;
        width: 100%;
    }
}

@media print, screen and (max-width: 768px) {
    .content_title-wrap .title-item {
        width: 94.667vw;
    }
    .content_title-wrap .title-item h4 {
        font-size: 7.4vw;
    }
    .content_title-wrap .title-item .lead {
        margin-top: 5.8vw;
    }
}

/* ==============================
  共通
============================== */
.sec-content {
    width: 89.06%; /* 1140px */
    max-width: 1140px;
    margin: 0 auto;
    padding-top: 9.375%;
    /*padding-top: 120px;*/
}
.sec-title span {
    font-size: min(1.875vw,2.4rem);
    font-weight: bold;
    line-height: 1;
    color: #0053FF;
}

.sec-title .title {
    font-size: min(7.03vw, 8rem);
    font-weight: bold;
    line-height: 1;

    margin-top: 2.34%; /* 30px */
}

.sec-title .text {
    font-size: min(1.406vw, 1.8rem);
    line-height: 1.8;

    margin-top: 2.34%; /* 30px */
}
@media screen and (min-width: 1280px) {
    .sec-content {
        padding-top: 120px;
    }
}
@media print, screen and (max-width: 768px) {
    .sec-content {
        width: 95.2vw;
        max-width: none;
        padding: 19.333vw 0 2vw;
    }

    .sec-title span {
        font-size: 4vw;
    }

    .sec-title .title {
        font-size: 10.6vw;
        line-height: 1.28;

        margin-top: 2.6vw;
    }

    .sec-title .text {
        font-size: 3.467vw;
        line-height: 2;

        margin-top: 6.667vw;
    }

}

/* ==============================
  求める人物像
============================== */
#wingrit_culture .sec-title .title {
    font-size: min(3.125vw, 4rem);
}
#wingrit_culture .sec-content-item-wrap {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-column-gap: 2.57vw; /* 33px */
    grid-row-gap: 2.187vw; /* 28px */
    margin-top: 1.6%;
    padding-bottom: 10.5%;
}
#wingrit_culture .sec-content-item-wrap .sec-content-item {
    position:relative;
    z-index: 0;
    /* min-height: 233px; */
}
#wingrit_culture .sec-content-item-wrap .sec-content-item::after {
    content: "";
    display: block;
    background: #0053FF;
    width: 100%;
    height: 100%;
    position: absolute;
    right: -2.5%;
    bottom: -4%;
    z-index: -1;
}
#wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner {
    background-color: #FFF;
    border: 1px solid #0053FF;
    padding: 12.8% 8.5% 19.4% 8.5%;
    box-sizing: border-box;
    height: 18.203vw;
}
#wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner h4 {
    font-size: min(2.18vw,2.8rem);
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
}
#wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner p {
    font-size: min(1.25vw, 1.6rem);
    line-height: 1.75;
    margin-top: 3.4%; /* 12px */
    color: #0053FF;
    text-align: justify; /* 両端揃え */
    text-justify: inter-ideograph;/* 両端揃えの種類 */
}
@media screen and (min-width: 1280px) {
    #wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner {
        height: 223px;
        padding: 45px 11.95px 27px 17.32px;
    }
}
@media print, screen and (max-width: 768px) {
    #wingrit_culture .sec-title .title {
        font-size: 7.46vw;
        line-height: 1.07;
        letter-spacing: 0.05em;
    }
    #wingrit_culture .sec-content-item-wrap {
        display: flex;
        flex-direction: column;
        margin-top: 6.6vw;
        padding-bottom: 21.3vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item {
        width: 92.533vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item + .sec-content-item {
        margin-top: 5.24vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner {
        padding: 3.6vw 7.4vw 4.9vw 9.3vw;
        height: auto;
        min-height: 25.02vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item::after {
        right: -2.1vw;
        bottom: -1.9vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner h4 {
        font-size: 5.3vw;
    }
    #wingrit_culture .sec-content-item-wrap .sec-content-item .item-inner p {
        font-size: 3.2vw;
    }
}

/* ==============================
  ナビゲーション
============================== */
.navigation-wrap {
    background-color: #EEE;
    width: 100%;
    padding: 1.4% 0;
}
.navigation-wrap ul {
    display: flex;
    justify-content: center;
    align-items: center;
}
.navigation-wrap ul li + li {
    margin-left: 3.9%;
}
.navigation-wrap ul li a {
    position: relative;
    color: #000;
    text-decoration: none;
    font-size: min(1.25vw, 1.6rem);
    font-weight: 700;
    padding-right: 1.43em;
}
.navigation-wrap ul li a::after {
    content: "";
    position: absolute;
    top: 33%;
    right: 0;
    border: 6px solid transparent;
    border-top: 7px solid #0053FF;
}
@media print, screen and (max-width: 768px) {
    .navigation-wrap {
        padding: 2.2vw 0;
    }
    .navigation-wrap ul {
        flex-direction: column;
        width: 80.1vw;
        margin: 0 auto;
    }
    .navigation-wrap ul li {
        width: 100%;
        border-bottom: 1px solid #C7C7C7;
        padding: 2.6vw 0;
    }
    .navigation-wrap ul li + li {
        margin-left: 0;
    }
    .navigation-wrap ul li:last-of-type {
        border-bottom: none;
    }
    .navigation-wrap ul li a {
        font-size: 3.4vw;
        padding-right: 0;
        display: flex;
        justify-content: space-between;
    }
    .navigation-wrap ul li a::after {
        border: 1.2vw solid transparent;
        border-top: 2vw solid #0053FF;
    }

}

/* ==============================
  JOB
============================== */
#job .sec-content-item {
    display: grid;
    grid-template-columns: 45.08% 45.35%;
    grid-template-rows: repeat(2, auto);
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    margin-top: 8.3%;
    justify-content: space-between;
}
#job .sec-content-item .image {
    grid-area: 1 / 1 / 3 / 2;
    position: relative;
    /* width: 45.08%; */
    aspect-ratio: 514 / 295;
    margin-left: 2.7%;
    z-index: 0;
}
#job .sec-content-item .image::after {
    content: "";
    display: block;
    background: #0053FF;
    width: 100%;
    height: 100%;
    position: absolute;
    left: -2.7%;
    bottom: -4%;
    z-index: -1;
}
#job .sec-content-item .text {
    width: 45.35%;
}
#job .sec-content-item h4 {
    grid-area: 1 / 2 / 2 / 3;
    font-size: min(2.18vw,2.8rem);
    font-weight: 700;
    line-height: 1.5;
    color: #0053FF;
}
#job .sec-content-item p {
    grid-area: 2 / 2 / 3 / 3;
    font-size: min(1.406vw, 1.8rem);
    line-height: 1.88;
    margin-top: 2.2%;
    text-align: justify; /* 両端揃え */
    text-justify: inter-ideograph;/* 両端揃えの種類 */
}

#job .members {
    margin-top: 8.3%;
    background-color: #000;
}
#job .members a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    color:#FFF;
    text-decoration: none;
}
#job .members a .image {
    width: 35%;
}
#job .members a .text {
    width: 65%;
    box-sizing: border-box;
    padding-left: 7.6%;
}
#job .members a .text h3 {
    font-size: min(1.56vw, 2rem);
    font-weight: 700;
}
#job .members a .text h2 {
    font-size: min(2.81vw, 3.6rem);
    font-weight: 700;
    margin-top: 1.7%;
}

#job + .image-wrap {
    margin: 9.9% 0 0;
}
@media print, screen and (max-width: 768px) {

    #job .sec-content-item {
        display: flex;
        flex-direction: column;
        margin-top: 10.6vw;
    }
    #job .sec-content-item + .sec-content-item {
        margin-top: 14.6vw;
    }
    #job .sec-content-item .image {
        width: 86.13vw;
        aspect-ratio: 646 / 371;
        margin-top: 4.533vw;
        margin-left: 0;
        order: 2;
    }
    #job .sec-content-item .image::after {
        left: -2.8vw;
        bottom: -2.8vw;
    }
    #job .sec-content-item h4 {
        font-size: 5.3vw;
        order: 1;
    }
    #job .sec-content-item p {
        font-size: 3.4vw;
        line-height: 2;
        margin-top: 9.4vw;
        order: 3;
    }



    #job .members {
        margin-top: 16vw;
    }
    #job .members a .image {
        width: 53.3vw;
    }
    #job .members a .text {
        width: 41.3vw;
        padding-left: 3.06vw;
    }
    #job .members a .text h3 {
        font-size:2.6vw;
    }
    #job .members a .text h2 {
        font-size: 4.8vw;
        margin-top: 1.7vw;
    }

    #job + .image-wrap {
        margin: 10.6vw 0 0;
    }
}

/* ==============================
  GRADE
============================== */
#grade .grade-wrap {
    margin-top: 3.125%;
    background-color: #EEE;
    padding: 3% 3.75% 2.3%;
    margin-bottom: 1.4%;
}
#grade .grade-wrap .grade-item {
    background-color: #FFF;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0.9em;
    box-sizing: border-box;
    font-size: min(1.4vw, 1.8rem);
    margin-right: 0;
    margin-left: auto;
}
#grade .grade-wrap .grade-item + .grade-item {
    margin-top: 0.8%;
}

/*6.シニア・マネージャー*/
#grade .grade-wrap .grade-item:first-of-type {
    width: 65.6%;
}
/*5.マネージャー*/
#grade .grade-wrap .grade-item:nth-of-type(2) {
    width: 72.4%;
}
/*4.リーダー*/
#grade .grade-wrap .grade-item:nth-of-type(3) {
    width: 79.3%;
}
/*3.シニアスタッフ*/
#grade .grade-wrap .grade-item:nth-of-type(4) {
    width: 86.2%;
}
/*2.スタッフ*/
#grade .grade-wrap .grade-item:nth-of-type(5) {
    width: 93.1%;
}
/*1.アソシエイト*/
#grade .grade-wrap .grade-item:last-of-type {
    width: 100%;
}

#grade .grade-wrap .grade-item h4 {
    font-weight: 700;
    line-height: 1.5;
    min-width: 12.05em;
}
#grade .grade-wrap .grade-item:first-of-type h4 {
    width: 15.6em;
}

#grade .grade-wrap .grade-item p {
    color: #0053FF;
    border-left: 1px solid #0053FF;
    font-size: min(1.09vw, 1.4rem);
    padding-left: 1.5em;
}

#grade .grade-wrap + p {
    line-height: 1.8;
    font-size: min(1.4vw, 1.8rem);
}
@media print, screen and (max-width: 768px) {
    #grade .grade-wrap {
        margin-top: 6.66vw;
        padding: 4vw 2.2vw;
        margin-bottom: 5vw;
    }
    #grade .grade-wrap .grade-item {
        flex-direction: column;
        align-items: flex-start;
        padding: 1.7vw;
        font-size: 4vw;
    }
    #grade .grade-wrap .grade-item + .grade-item {
        margin-top: 2vw;
    }


    /*6.シニア・マネージャー*/
    #grade .grade-wrap .grade-item:first-of-type {
        width: 100%;
    }
    /*5.マネージャー*/
    #grade .grade-wrap .grade-item:nth-of-type(2) {
        width: 100%;
    }
    /*4.リーダー*/
    #grade .grade-wrap .grade-item:nth-of-type(3) {
        width: 100%;
    }
    /*3.シニアスタッフ*/
    #grade .grade-wrap .grade-item:nth-of-type(4) {
        width: 100%;
    }
    /*2.スタッフ*/
    #grade .grade-wrap .grade-item:nth-of-type(5) {
        width: 100%;
    }
    /*1.アソシエイト*/
    #grade .grade-wrap .grade-item:last-of-type {
        width: 100%;
    }

    #grade .grade-wrap .grade-item h4 {
        min-width: 100%;
    }
    #grade .grade-wrap .grade-item:first-of-type h4 {
        width: 100%;
    }

    #grade .grade-wrap .grade-item p {
        border-left: none;
        font-size: 3.2vw;
        padding-left: 8.4vw;
    }

    #grade .grade-wrap + p {
        font-size: 3.2vw;
    }
}

/* ==============================
  VOICE
============================== */
#voice .sec-content {

}

#voice .sec-title {
    width: 100%;
    margin-bottom: 3.125%;
}
#voice .voice-wrap {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-column-gap: 40.39px;
    grid-row-gap: 22px;
}
#voice .voice-item {
    border: 1px solid #000;
    box-sizing: border-box;
    padding: 7.12% 9.54% 8.55%; /* 25px 33.5px 30px*/
}
#voice .voice-item p {
    font-size: min(1.25vw, 1.6rem);
    line-height: 1.75;
    text-align: justify; /* 両端揃え */
    text-justify: inter-ideograph;/* 両端揃えの種類 */
}
#voice .voice-item p.about {
    font-size: min(1.4vw, 1.8rem);
    line-height: 1.5;
    font-weight: 600;
    margin-top: 3em;
}
#voice .voice-item p.about span {
    display: block;
    font-size: min(1.25vw, 1.6rem);
    font-weight: 500;
}
@media print, screen and (max-width: 768px) {
    #voice .sec-content {
        flex-direction: column;
    }

    #voice .sec-title {
        margin-bottom:6.66vw;
    }
    #voice .voice-wrap {
        grid-template-columns: repeat(1, 1fr);
        grid-row-gap: 2.933vw;
    }
    #voice .voice-item {
        width: 100%;
        padding: 3.8vw 3.6vw;
        background-color: #FFFFFF;
    }
    #voice .voice-item p {
        font-size: 3.2vw;
    }
    #voice .voice-item p.about {
        font-size: 3.7vw;
        margin-top: 3vw;
    }
    #voice .voice-item p.about span {
        font-size: 3.2vw;
        display: inline-block;
        margin-left: 1.08em;
    }
}

/* ==============================
  COMPANY
============================== */
#company .box-wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.9vw; /* 12px */
    margin-top: 3.13%; /* 40px */
}
#company .box-wrap .box-item {
    background: #EEEEEE;
}
#company .box-wrap .box01,
#company .box-wrap .box02,
#company .box-wrap .box03 {
    width: 32.63%; /* 372px */
}
#company .box-wrap .box04,
#company .box-wrap .box05,
#company .box-wrap .box06 {
    padding: 2.72% 3.68% 4.74%; /* 31px 42px 54px */
    width: 100%;
}
#company .box-wrap .box-item .title {
    font-size: min(1.875vw,2.4rem);
    font-weight: bold;
    color: #0053FF;
    text-align: center;
}
#company .box-wrap .box01 .title,
#company .box-wrap .box02 .title,
#company .box-wrap .box03 .title {
    padding: 14.52% 0 0; /* 54px */
}
#company .box-wrap .box01 .detail .text {
    font-size: min(3.455vw,4.423rem);
    font-weight: bold;
    text-align: center;
    margin-top: 20.7%; /* 77px */
}

#company .box-wrap .box01 .detail .text span {
    font-size: min(7.752vw, 9.923rem);
}

#company .box-wrap .box02 .detail .img-wrap {
    width: 76.08%; /* 283px */
    margin: 17.74% auto 14.46% 9.14%; /* 66px auto 53.8px 34px */
}

#company .box-wrap .box03 .detail .img-wrap {
    width: 70.16%; /* 261px */
    margin: 17.74% auto 14.46%; /* 66px auto 53.8px */
}

#company .box-wrap .box04 .text,
#company .box-wrap .box05 .text {
    font-size: min(1.25vw, 1.6rem);
    font-weight: 500;
    line-height: 1.5;
    margin-top: 1.93%; /* 22px */
}

#company .box-wrap .box06 .detail ul {
    margin-top: 1.93%;
    display: block;
    column-count: 3;
    column-gap: 9.9%;
    font-size: min(1.4vw, 1.8rem);
    font-weight: 500;
    line-height: 1.8;
}
#company .box-wrap .box06 .detail ul li {
    break-inside: avoid;
    page-break-inside: avoid;
    width: 18.11em;
}
#company .box-wrap .box06 .detail ul li:nth-of-type(n + 11) {
    width: 15.66em;
}


@media screen and (min-width: 1280px) {
    #company .box-wrap {
        gap: 0.5vw;
    }
    #company .box-wrap .box01,
    #company .box-wrap .box02,
    #company .box-wrap .box03 {
        width: 370px;
    }
}
@media print, screen and (max-width: 768px) {
    #company .box-wrap {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(5, auto);
        grid-column-gap: 2.667vw;
        grid-row-gap: 2.933vw;
        margin-top: 6.667vw;
    }
    #company .box-wrap .box01 {
        grid-area: 1 / 1 / 2 / 3;
        width: auto;
    }
    #company .box-wrap .box02 {
        grid-area: 2 / 1 / 3 / 2;
        width: auto;
    }
    #company .box-wrap .box03 {
        grid-area: 2 / 2 / 3 / 3;
        width: auto;
    }
    #company .box-wrap .box04 {
        grid-area: 3 / 1 / 4 / 3;
        width: auto;
    }
    #company .box-wrap .box05 {
        grid-area: 4 / 1 / 5 / 3;
        width: auto;
    }
    #company .box-wrap .box06 {
        grid-area: 5 / 1 / 6 / 3;
        width: auto;
    }
    #company .box-wrap .box04,
    #company .box-wrap .box05,
    #company .box-wrap .box06 {
        padding: 8.667vw 6.133vw 8.8vw;
        box-sizing: border-box;
    }
    #company .box-wrap .box-item .title {
        font-size: 4vw;
        line-break: 1.3;
    }
    #company .box-wrap .box01 .title,
    #company .box-wrap .box02 .title,
    #company .box-wrap .box03 .title {
        padding: 4.6vw 0 0;
    }
    #company .box-wrap .box01 .detail .text {
        font-size: 5.897vw;
        margin: 3.133vw auto 4.267vw;
    }

    #company .box-wrap .box01 .detail .text span {
        font-size: 13.231vw;
    }

    #company .box-wrap .box02 .detail .img-wrap {
        width: 37.84vw;
        margin: 6.533vw auto 3.379vw 3.067vw;
    }

    #company .box-wrap .box03 .detail .img-wrap {
        width: 34.92vw;
        margin: 6.533vw auto 3.441vw;
    }

    #company .box-wrap .box04 .text,
    #company .box-wrap .box05 .text {
        font-size: 3.2vw;
        line-break: 1.55;
        margin-top: 6.133vw;
    }

    #company .box-wrap .box06 .detail ul {
        margin-top: 6.13vw;
        column-count: 2;
        column-gap: 0;
        font-size: 3.2vw;
        width: 88vw;
    }
    #company .box-wrap .box06 .detail ul li,
    #company .box-wrap .box06 .detail ul li:nth-of-type(n + 11) {
        width: auto;
        text-indent: -1em;
        padding-left: 1em;
    }
}

/* ==============================
  WORK STYLE
============================== */
#work_style {
    max-width: 1280px;
    margin: 0 auto;
}
#work_style .sec-content {
    width: 94.6%;
    max-width: 1211px;
    margin: 0 0 0 auto;
}
#work_style .column-wrap {
    position: relative;
    margin-top: 3.125%;
}
#work_style .column-item {
    width: 50.7%;
}
#work_style .column-item:last-of-type {
    width: 41.5%;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}
#work_style .column-item:last-of-type::after {
    content: "";
    display: block;
    background: #0053FF;
    width: 100%;
    height: 100%;
    position: absolute;
    left: -5.3%;
    top: 5.62%;
    z-index: -1;
}

#work_style .column-item .work_style-box {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: 1.953vw;
    grid-row-gap: 2.266vw;
}
#work_style .work_style-box .work_style-item {
    background-color: #EEE;
    box-sizing: border-box;
    text-align: center;
    min-height: 22.734vw;
    padding: 15.51% 0 17.48%;
}
#work_style .work_style-box .work_style-item p.title {
    font-size: min(2.18vw, 2.8rem);
    font-weight: bold;
    color: #0053FF;
}
#work_style .work_style-box .work_style-item p.text {
    font-family: "Noto Sans JP", sans-serif;;
    font-size: min(6.55vw, 8.339rem);
    margin-top: 5.6%;
    font-weight: bold;
}
#work_style .work_style-box .work_style-item p.text span {
    font-size: min(2.4vw, 3.14rem);
}

#work_style .column-wrap + h6 {
    color: #0053FF;
    font-size: min( 2.18vw, 2.8rem);
    font-weight: bold;
    margin-top: 8.3%;
}
#work_style .work_style-image-wrap {
    width: 93.6%;
    margin-top: 3.125%;
}
@media screen and (min-width: 1280px) {
    #work_style .work_style-box .work_style-item {
        min-height: 291px;
    }
    #work_style .column-item .work_style-box {
        grid-column-gap: 25px;
        grid-row-gap: 29px;
    }
}
@media print, screen and (max-width: 768px) {
    #work_style {
        max-width: auto;
    }
    #work_style .sec-content {
        width: 97.3vw;
        max-width: auto;
    }
    #work_style .column-wrap {
        margin-top: 6.6vw;
    }
    #work_style .column-item {
        width: 94.6vw;
    }
    #work_style .column-item:last-of-type {
        width: 80.1vw;
        position: relative;
        margin-top: 6.6vw;
        margin-right: 0;
        margin-left: auto;
    }
    #work_style .column-item:last-of-type::after {
        left: -2.8vw;
        top: 3.2vw;
    }
    #work_style .column-item .work_style-box {
        grid-column-gap: 2.6vw;
        grid-row-gap: 2.6vw;

        padding: 6.08vw 0 6.86vw;
    }
    #work_style .work_style-box .work_style-item p.title {
        font-size: 3.7vw;
    }
    #work_style .work_style-box .work_style-item p.text {
        font-size: 11.1vw;
        margin-top: 1.74vw;
        font-weight: 700;
    }
    #work_style .work_style-box .work_style-item p.text span {
        font-size: 4.19vw;
    }

    #work_style .column-wrap + h6 {
        font-size: 4vw;
        margin-top: 14.76vw;
    }
    #work_style .work_style-image-wrap {
        width: 94.6vw;
        margin-top: 4.9vw;
    }

}



/* ==============================
  画像スライドエリア
============================== */
@keyframes slide-left {
  from {
    transform: translateX(0);
    -webkit-transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
  }
}
@-webkit-keyframes slide-left {
  from {
    transform: translateX(0);
    -webkit-transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
    -webkit-transform: translateX(-100%);
  }
}
.slide-image-wrap {
    margin-top: 10.9%;
    display: flex;
    flex-wrap: nowrap;
    overflow: hidden;
}

.slide-image-items {
    display: flex;
    flex-shrink: 0; /* アニメーション中に縮まないようにする */
    animation: slide-left 50s linear 0.5s infinite normal both running;
}

.slide-image-item {
    width: auto;
    height: 30.703vw;
}

.slide-image-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
@media screen and (min-width: 1280px) {
    .slide-image-wrap {
        margin-top: 140px;
    }
}
@media print, screen and (max-width: 768px) {
    .slide-image-wrap {
        margin-top: 8vw;
    }
    .slide-image-item {
        width: auto;
        height: 52.4vw;
    }
    .slide-image-item img {
        width: auto;
    }

}


/* ==============================
  WELFARE
============================== */
#welfare .sec-content {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
}
#welfare .sec-title {
    width: 100%;
    margin-bottom: 3.9%;
}
#welfare .sec-content-item {
    width: 22.2%;
    box-sizing: border-box;
}
#welfare .sec-content-item:nth-of-type(n + 6) {
    margin-top: 4.3%;
}

#welfare .sec-content-item h4 {
    color: #0053FF;
    font-weight: 700;
    text-align: center;
    font-size: min(1.875vw, 2.4rem);
}
#welfare .sec-content-item p {
    font-size: min(1.25vw, 1.6rem);
    line-height: 1.75;
    text-align: justify; /* 両端揃え */
    text-justify: inter-ideograph;/* 両端揃えの種類 */
}

#welfare .sec-content-item img {
    display: block;
    width: 52.7%;
    margin: 10.2% auto;
}
@media print, screen and (max-width: 768px) {
    #welfare .sec-content {
    }
    #welfare .sec-title {
        margin-bottom: 6.6vw;
    }
    #welfare .sec-content-item {
        width: 42vw;
        margin: 0 2.6vw;
    }
    #welfare .sec-content-item:nth-of-type(n + 2) {
        margin-top: 7.3vw;
    }

    #welfare .sec-content-item h4 {
        font-size: 3.2vw;
    }
    #welfare .sec-content-item p {
        font-size: 3.2vw;
    }

    #welfare .sec-content-item img {
        width: 17.8vw;
        margin: 3.4vw auto;
    }
}


/* ==============================
  RECRUITMENT TYPE
============================== */
#recruitment_type .sec-title .title {
    margin-bottom: 3.125%;
}

#recruitment_type .sec-content-item {
    border: 1px solid #000;
}
#recruitment_type .sec-content-item + .sec-content-item {
    margin-top: 1.3%;
}

#recruitment_type .sec-content-item h4 {
    background-color: #000;
    color: #FFF;
    font-size: min(1.56vw, 2rem);
    width: 18.5em;
    padding: 0.5em 1.6em;
    box-sizing: border-box;
}
#recruitment_type .sec-content-item p {
    font-size: min(1.25vw, 1.6rem);
    line-height: 1.75;
    margin: 1.5em 2.3em;
}
@media print, screen and (max-width: 768px) {
    #recruitment_type .sec-title .title {
        line-height: 1.2;
        margin-bottom: 6.6vw;
    }
    #recruitment_type .sec-content-item + .sec-content-item {
        margin-top: 3.3vw;
    }

    #recruitment_type .sec-content-item h4 {
        font-size: 3.7vw;
        width: 100%;
        padding: 1.3vw 4.2vw;
    }
    #recruitment_type .sec-content-item p {
        font-size: 2.9vw;
        margin: 1.8vw 3.05vw 2.6vw;
    }
}

/* ==============================
  FLOW
============================== */
#flow .flow-wrap {
    margin-top: 3.36%; /* 43px*/
}
#flow .flow-item {
    position: relative;
    background-color: #F3F3F3;
    display: flex;
    justify-content: flex-start;
}
#flow .flow-item::after {
    content: "";
    position: absolute;
    bottom: -1.8em;
    right: 0;
    left: 0;
    border-left: 1.86em solid transparent;
    border-right: 1.86em solid transparent;
    border-top: 1.27em solid black;
    margin: 0 auto;
    width: 0;
    height: 0;
    font-size: min(1.4vw, 1.8rem);
}
#flow .flow-item:last-of-type:after {
    display: none;
}
#flow .flow-item + .flow-item {
    margin-top: 3.2%;
}
#flow .flow-item h4 {
    font-size: min(2.1vw, 2.8rem);
    font-weight: 700;
    line-height: 1.5;
    color: #FFF;
    background-color: #000;
    display: inline-flex;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    width: 28.59%;
    padding: 0.75em 1.25em 0.5em 1.03em;
    box-sizing: border-box;
}
#flow .flow-item h4 span {
    font-size: min(1.4vw, 1.8rem);
}
#flow .flow-item p {
    font-size: min(1.4vw, 1.8rem);
    line-height: 1.8;
    font-weight: 400;
    display: inline-flex;
    align-items: center;
    padding: 1.05em 1.3em 0.9em;
}

#flow .flow-item:last-of-type h4{
    width: 100%;
}
@media print, screen and (max-width: 768px) {
    #flow .flow-item {
    }
    #flow .flow-item::after {
        bottom: -3.4vw;
        border-left: 2.8vw solid transparent;
        border-right: 2.8vw solid transparent;
        border-top: 3vw solid black;
    }
    #flow .flow-item + .flow-item {
        margin-top: 4vw;
    }
    #flow .flow-item h4 {
        font-size: 3.7vw;
        width: 27.08vw;
        min-width: 27.08vw;
        padding: 4.8vw 2.4vw;
    }
    #flow .flow-item h4 span {
        font-size: 3.2vw;
    }
    #flow .flow-item p {
        font-size: 3.2vw;
        padding: 2.5vw 2vw;
    }
}

/* ==============================
  FAQ
============================== */
#faq .faq-wrap {
    margin-top: 3.125%;
}
#faq .faq-wrap .faq-item {
    position: relative;
    border-top: 1px solid #E4E4E4;
    font-size: min(1.4vw, 1.8rem);
    padding: 0 1.5em 0 1.3em;
    box-sizing: border-box;
}
#faq .faq-wrap .faq-item:hover {
    background: #F1F1F1;
}
#faq .faq-wrap .faq-item::before,
#faq .faq-wrap .faq-item::after {
    content: "";
    position: absolute;
    top: 1.76em;
    right: 1.3em;
    width: 1.16em;
    height: 2px;
    background-color: #000;
}
#faq .faq-wrap .faq-item::after {
    transition: transform 0.3s ease;
}
#faq .faq-wrap .faq-item.close::after {
    transform: rotate(90deg);
}
#faq .faq-wrap .faq-item p {
    max-height: 1000px;
    opacity: 1;
    overflow: hidden;
    transition: max-height 0.3s ease, opacity 0.3s ease, padding 0.3s ease;
}
#faq .faq-wrap .faq-item.close p {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
}

#faq .faq-wrap .faq-item h4,
#faq .faq-wrap .faq-item p {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding: 0.83em 0;
    box-sizing: border-box;
}
#faq .faq-wrap .faq-item h4::before,
#faq .faq-wrap .faq-item p::before {
    color: #0053FF;
    font-size: min(12.5vw, 3.2rem);
    font-weight: 700;
    margin-right: 0.875em;
}
#faq .faq-wrap .faq-item h4 {
    font-weight: 700;
    cursor: pointer;
}
#faq .faq-wrap .faq-item h4::before {
    content: "Q";
}
#faq .faq-wrap .faq-item p {
    color: #0053FF;
    margin-left: 2.71em;
    font-weight: 400;
}
#faq .faq-wrap .faq-item p::before {
    content: "A";
}
@media print, screen and (max-width: 768px) {
    #faq .faq-wrap {
        margin-top: 6.6vw;
    }
    #faq .faq-wrap .faq-item {
        font-size: 3.2vw;
        padding: 0 2vw 0 3vw;
    }
    #faq .faq-wrap .faq-item::before,
    #faq .faq-wrap .faq-item::after {
        content: "";
        position: absolute;
        top: 5.1vw;
        right: 3vw;
        width: 0.87em;
        height: 2px;
        background-color: #000;
    }

    #faq .faq-wrap .faq-item h4,
    #faq .faq-wrap .faq-item p {
        padding: 2.4vw 1em 2vw 0;
        box-sizing: border-box;
    }
    #faq .faq-wrap .faq-item h4::before,
    #faq .faq-wrap .faq-item p::before {
        font-size: 5.3vw;
        margin-right: 0.7em;
    }
    #faq .faq-wrap .faq-item p {
        font-size:3.2vw;
        padding: 1.7vw 0;
    }
}

/* ==============================
  WANTEDLY
============================== */
#wantedly {
    width: 89%;
    max-width: 1140px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: #F3F3F3;
    margin:12.8% auto 0;
    box-sizing: border-box;
    padding: 3.5% 2.1% 3% 2.3%;
}
#wantedly img {
    width: 30.8%;
    height: auto;
}
#wantedly p {
    font-size: min(1.4vw, 1.8rem);
    font-weight: 500;
    margin: 0 auto 0 1.29em;
}

#wantedly .btn a {
    width: 11.22em;
}
@media screen and (min-width: 1280px) {
    #wantedly {
        margin-top: 165px;
        padding: 40px 51.16px 35px 27.84px;
    }
}
@media print, screen and (max-width: 768px) {
    #wantedly {
        display: grid;
        grid-template-columns: 46.9vw 40.47vw;
        grid-template-rows: repeat(2, auto);
        grid-column-gap: 0px;
        grid-row-gap: 0px;
        width: 94.6vw;
        max-width: none;
        margin:20vw auto 0;
        padding: 6.8vw 3.12vw 6.2vw 2.5vw;
    }
    #wantedly img {
        width: 100%;
        grid-area: 1 / 1 / 2 / 2;
    }
    #wantedly p {
        font-size: 3.2vw;
        margin: 0;
        grid-area: 2 / 1 / 3 / 2;
        text-align: center;
    }

    #wantedly .btn a {
        width: 100%;
        padding: 2.2vw 0 2.2vw 4.16em;
        grid-area: 1 / 2 / 3 / 3;
    }
}



/* ==============================
  採用エントリー
============================== */
#entry {
    width: 89%;
    max-width: 1140px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: #000;
    margin:12.8% auto 0;
    color: #FFF;
    box-sizing: border-box;
    padding: 3.5% 4.3% 3.8% 5.2%;
}
#entry .sec-title {
}
#entry .sec-title h3 {
    font-size: min(1.87vw, 2.4rem);
    font-weight: 700;
    line-height: 1.5;
}
#entry .sec-title h2 {
    font-size: min(7.03vw, 9rem);
    font-weight: 700;
    line-height: 1;
    margin-top: 0.7%;
}
#entry .sec-title p {
    font-size: min(1.4vw, 1.8rem);
    margin-top: 0.7%;
}
#entry .btn a {
    width: 12.97em;
    background-color: #FFF;
    color: #000;
}
#entry .btn a::before {
    background-color: #000;
}
@media screen and (min-width: 1280px) {
    #entry {
        margin-top: 165px;
        padding: 40px 50.48px 44px 60px;
    }
}
@media print, screen and (max-width: 768px) {
    #entry {
        position: relative;
        width: 94.6vw;
        margin:20vw auto 0;
        padding: 5.2vw 3.12vw 3.7vw 4.1vw;
    }
    #entry .sec-title {
    }
    #entry .sec-title h3 {
        font-size: 3.2vw;
    }
    #entry .sec-title h2 {
        font-size: 10.6vw;
        margin-top: 0;
    }
    #entry .sec-title p {
        font-size: 3.2vw;
        margin-top: 0.9vw;
    }
    #entry .btn {
        position: absolute;
        top: 8.1vw;
        right: 3.12vw;
    }
    #entry .btn a {
        width: 40.47vw;
        padding: 2.2vw 0 2.2vw 4.16em;
        background-color: #FFF;
        color: #000;
        font-weight: 700;
    }
    #entry .btn a::before {
        background-color: #000;
    }
}
