@charset "UTF-8";

/*=========================================================
mv
=========================================================*/

#mv {
    position: relative;
    overflow-x: hidden;
    width: 100vw;
    height: auto;
    z-index: 0;
}

.mv__ph-area {
    position: relative;
}

.mv__ph img {
    object-fit: cover;
    object-position: left top;
    max-height: 1150px;
}

.point {
    position: absolute;
    bottom: -1px;
    width: 100%;
    background: #ffffffd2;
}

.point__largest {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%,-60%);
    width: 50%;
    max-width: 300px;
}

.point__list {
    align-items: end;
    margin: 26% auto 13%;
    width: 80%;
    max-width: 380px;
}

@media screen and (min-width:580px) {
    .point__list {
        margin: 150px auto 60px;
    }
}

.point__list--item:first-child {
    width: 20%;
    max-width: 72px;
}
.point__list--item:nth-child(2) {
    width: 30%;
    max-width: 110px;
}
.point__list--item:last-child {
    width: 26%;
    max-width: 95px;
}

/*
news
-----------------------------------------------*/

#news {
    position: absolute;
    bottom: 0;
    right: -100%;
    transform: translateY(60%);
    padding: .7em .8em .7em 2.5em;
    width: 96%;
    max-width: 350px;
    line-height: 1.2;
    border-top: solid 3px #F89C40;
    border-left:  solid 3px #F89C40;
    border-bottom:  solid 3px #F89C40;
    background: #fff;
    border-radius: 80px 0 0 80px;
    transition: 1.5s; /* アニメーションタイミング */
    cursor: pointer;
    z-index: 9990;
}

#news.is-show {
    right: 0;
}

#news.is-hidden {
    right: -100%;
}

#news .flex {
    flex-wrap: nowrap;
}

.news__cont .fc-or {
    margin-bottom: .2em;
    padding-right: .3em;
    font-size: clamp(2.4rem,2.88vw,3rem);
    font-weight: 900;
}

.news__cont .title {
    letter-spacing: 0;
}

@media screen and (max-width:340px) {
    #news {
        padding: .7em .8em .7em 1.5em;
    }
    .news__cont .fc-or {
        font-size: 110%;
    }
    .news__cont .title {
        font-size: 80%;
        letter-spacing: 0;
    }
}

.news__link {
    width: 1.2em;
    min-width: 18px;
}


/*hover*/

#news:hover .news__cont .title {
    color: #F89C40;
}

/*
entry
-----------------------------------------------*/

.mv__entry {
    padding: 70px 0 75px;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    @media screen and (max-width: 899.98px) {
        .mv__ph img {
            max-height: 130vw;
        }
    }

    .point {
        display: flex;
        justify-content: center;
        padding-right: 1.5%;
        height: 240px;
    }

    .point__largest {
        position: static;
        transform: translate(0, -40%);
        margin-right: 20px;
    }

    .point__list {
        margin: 0 0 55px;
        width: 50%;
    }
}

/*----------------------------------------------------------
    PC（画面幅900px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:900px) {

    .mv__ph-area {
        background: #e4eeff;
    }

    .mv__ph img {
        margin: 0 auto;
        object-position: left 50% top 20%;
        height: 56vw;
        max-height: 950px;
        max-width: 2100px;
    }

    .point {
        height: 17.3vw;
    }

    .point__largest {
        transform: translate(0, -35%);
        width: 22%;
    }

    .point__list {
        margin: 0 0 3.5vw;
        width: 30%;
    }

    @media screen and (min-width:1300px) {
        .point {
            height: 220px;
        }

        .point__largest {
            transform: translate(0, -40%);
            margin-right: 30px;
        }

        .point__list {
            margin: 0 0 40px 30px;
        }
    }

    @media screen and (min-width:1340px) {

        .point__largest {
            transform: translate(0, -48%);
        }
    }

    /*
    news
    -----------------------------------------------*/

    #news {
        top: 50%;
        bottom: auto;
        transform: translateY(-50%);
        padding: 1em 1.2em 1em 2.5em;
        width: 22%;
        max-width: 320px;
    }

    .news__cont .title {
        font-size: clamp(1.4rem,1.22vw,1.8rem);
    }

    .news__cont .title__wrap {
        display: flex;
        align-items: center;
        margin-bottom: .2em;
    }

    .news__cont .fc-or {
        font-size: clamp(2rem, 2.2vw, 2.8rem);
    }

    /*
    entry
    -----------------------------------------------*/

    .mv__entry {
        padding: 50px 0 60px;
    }
}

@media screen and (min-width:1366px) {
    .news__link {
        width: 2em;
    }
}


/*==========================================================
intro
==========================================================*/

/*
message
-----------------------------------------------*/

.message p {
    font-size: clamp(1.6rem,2.222vw,2rem);
    font-weight: 700;
    line-height: 2.7;
    letter-spacing: .15rem;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {
    .message p {
        text-align: center;
        line-height: 3.1;
        letter-spacing: .2rem;
    }
}

/*
vision
-----------------------------------------------*/

.vision {
    margin: 0 auto;
    padding: 40px 0 45px;
    max-width: 915px;
    border: solid 4px #FFED61;
    border-radius: 15px;
    box-shadow: 0px 3px 6px 0px #00000029;
}

.vision .inner {
    width: 87%;
}

.vision h2 {
    text-align: center;
    font-size: clamp(5.6rem,5.55vw,6.8rem);
    letter-spacing: .2em;
    line-height: 1;
}

.vision__main,
.vision__sub {
    letter-spacing: .07rem;
}

.vision__main {
    margin: 25px 0 20px;
    font-size: clamp(2rem,3.11vw,2.6rem);
    font-weight: 700;
    line-height: 1.8;
}

/*accordion common*/

.acd-check {
    display: none;
}

.acd-label {
    display: flex;
    align-items: center;
    margin: 0 auto;
    padding: .8em 1.5em;
    width: 100%;
}

.acd-label__txt {
    width: 100%;
    font-weight: 700;
    transform: translateX(1em);
}

.acd-label__arrow {
    width: 26px;
    height: 12.6px;
}

.acd-label__arrow::before,
.acd-label__arrow::after {
    bottom: 0;
    left: calc(50% - 1.75px);
    width: 3.5px;
    height: 18px;
    transform-origin: 50% calc(100% - 1.75px);
}

.acd-label__arrow::before {
    transform: rotate(50deg);
}

.acd-label__arrow::after {
    transform: rotate(-50deg);
}

.acd-cont {
    margin: 0 auto;
    padding: 0;
    height: 0;
    transition: 0.3s;
    visibility: hidden;
    opacity: 0;
}

.acd-check:checked + .acd-label + .acd-cont {
    padding: 1.1em 0 0;
    height: auto;
    visibility: visible;
    opacity: 1;
}

.acd-check:checked + .acd-label .acd-label__arrow::before,
.acd-check:checked + .acd-label .acd-label__arrow::after {
    top: 0;
    bottom: auto;
    transform-origin: 50% 1.75px;
}

/*tec-list accordion*/


.tec-list {
    margin-top: 30px;
}

.tec-list__item:not(:last-child) {
    margin-bottom: 1em;
}

.tec-list .acd-label {
    max-width: 460px;
    background: #FFED61;
    border-radius: 100vh;
}

.tec-list .acd-label__txt {
    margin-right: 1em;
    text-align: center;
    font-size: clamp(1.8rem,2vw,2rem);
    line-height: 1.3;
}

.tec-list .acd-label__arrow::before,
.tec-list .acd-label__arrow::after {
    background-color: #fff;
}

.tec-list .acd-cont {
    width: 95%;
    max-width: 430px;
}

.tec-list .acd-cont p {
    margin-bottom: .8em;
    font-size: 93%;
    line-height: 1.7;
    letter-spacing: .03rem;
}

.tec-list__item:first-child .acd-check:checked + .acd-label + .acd-cont {
    padding: 1.1em 0;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    .vision__txt-wrap {
        text-align: center;
    }
}
/*----------------------------------------------------------
    PC（画面幅900px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:900px) {

    .vision {
        padding: 40px 0 50px;
    }

    .tec-list {
        display: flex;
        justify-content: space-between;
    }

    .tec-list__item {
        width: 48.5%;
    }

    .tec-list__item:not(:last-child) {
        margin-bottom: 0;
    }

    .tec-list .acd-cont {
        width: 96%;
    }

    .tec-list__item:first-child .acd-check:checked + .acd-label + .acd-cont {
        padding: 1.1em 0 0;
    }
}


/*==========================================================
about
==========================================================*/

#about {
    position: relative;
    margin-top: 9vw;
    background-color: #FFFAD5;
    background-image: url(../img/bg-parts/shape01.png), url(../img/bg-parts/shape02.png), url(../img/bg-parts/shape01.png), url(../img/bg-parts/shape02.png);
    background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
    background-position: left -500px top 8%, right -400px top 32%, left -400px bottom 32%, right -500px bottom 20px;
    background-size: 750px, 750px, 750px, 750px;
}

#about h2 {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -33%);
    width: 92%;
    max-width: 450px;
}

.about__intro {
    margin-top: 11vw;
    font-size: clamp(1.6rem,2.6vw,2rem);
    font-weight: 600;
    line-height: 2;
}

@media screen and (min-width:430px) {
    .about__intro {
        margin-top: 13vw;
    }
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    #about {
        margin-top: 5vw;
        background-position: left -300px top 10%, right -300px top 40%, left -200px bottom 35%, right -200px bottom -50px;
    }

    #about h2 {
        width: 60%;
        max-width: 635px;
    }

    .about__intro {
        margin-top: 7vw;
        text-align: center;
    }
}

/*----------------------------------------------------------
    TABLET（画面幅900px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:900px) {

    .about__intro {
        margin-top: 10vw;
    }

    @media screen and (min-width:1080px) {
        #about {
            background-position: left -250px top 7%, right -300px top 40%, left -100px bottom 28%, right -100px bottom -200px;
            background-size: 1100px, 1100px, 1100px, 1100px;
        }

        .about__intro {
            margin-top: 110px;
        }
    }

    @media screen and (min-width:1536px) {
        #about {
            margin-top: 70px;
        }
    }
}

/*
about list
-----------------------------------------------*/

/*common*/

.about-list {
    justify-content: space-between;
    margin: 0 auto;
    max-width: 400px;
}

.about-list__item {
    position: relative;
    margin: 0 0 1em;
    width: 100%;
    height: 225px;
}

.about-list__item:last-child {
    margin-bottom: 0;
}

.about-list__item.half {
    width: 48.5%;
    height: 180px;
}

@media screen and (min-width:600px) {
    .about-list {
        max-width: 850px;
    }

    .about-list__item,
    .about-list__item.half {
        width: 48.5%;
        height: 310px;
    }

    .about-list__item.max {
        width: 100%;
    }

}
@media screen and (min-width:1080px) {
    .about-list__item {
        margin: 0 0 1.7em;
    }
}

.about-list__item--initial,
.about-list__item--opened {
    position: absolute;
    top: 0;
    left: 0;
    padding: 1.1em 1.1em 1.5em;
    width: 100%;
    height: 100%;
    border-radius: 10px;
    box-shadow: 0.25px 0.25px 30px #00000029;
    transition: .3s;
    z-index: 2;
}

.about-list__item--opened {
    overflow-y: auto;
}

@media screen and (max-width:370px) {
    .about-list__item.half .about-list__item--initial {
        padding: 1.1em .9em 1.5em;
    }
}


.target-item {
    cursor: pointer;
}

/*開く前*/

.about-list__item--initial dt,
.about-list__item--initial dd {
    text-align: center;
}

.about-list__item--initial dt {
    font-size: clamp(2rem,2.5vw,2.6rem);
    font-weight: 800;
    line-height: 1.2;
}

.about-list__item.half .about-list__item--initial dt {
    font-size: clamp(1.8rem,2.5vw,2.6rem);
}

.about-list__item--initial dd {
    width: 90%;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
}

.about-list__item--initial dd .fc-or {
    display: inline-block;
    letter-spacing: .07rem;
}

.about-list__item--initial dd:not(.about-list__item.item06 .about-list__item--initial dd),
.about-list__item--opened .txt-cont {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media screen and (max-width:360px) {
    .about-list__item--opened .txt-cont {
        position: static;
        transform: translate(0, 0);
    }
}

/*開いた後*/

.about-list__item--opened {
    background: #F89C40;
    visibility: hidden;
    opacity: 0;
}

.about-list__item--opened .txt-cont,
.about-list__item.item06 .about-list__item--initial dd {
    width: 82%;
    color: #fff;
    font-size: clamp(1.4rem,1.9vw,1.8rem);
    font-weight: 400;
    line-height: 1.7;
    letter-spacing: .03rem;
}

@media screen and (max-width:360px) {

    .about-list__item--opened .txt-cont {
        width: 100%;
    }
}


/*開閉button*/

.about-list__item .guide {
    position: absolute;
    bottom: 1.2em;
    right: 1.2em;
    padding: 0 1.8em 0 0;
    font-size: clamp(1.2rem,2vw,1.6rem);
    font-weight: 600;
    line-height: 1.3;
    z-index: 1;
}

.about-list__item--initial .guide::before,
.about-list__item--opened .guide::before {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1.5em;
    height: 1.5em;
}

.about-list__item--initial .guide::before {
    background: url(../img/about/icon-open.svg) no-repeat right center / contain;
}

.about-list__item--opened .guide {
    color: transparent;
}

.about-list__item--opened .guide::before {
    background: url(../img/about/icon-close.svg) no-repeat right center / contain;
}

/*hover時*/

.target-item .about-list__item--initial:hover {
    padding: calc(1.2em - 6px);
    border: solid 6px #F89C40;
}

.target-item .about-list__item--initial:hover .guide {
    bottom: calc(1.5em - .6em);
    right: calc(1.5em - .6em);
    transition: .3s;
}

/*click時*/

.about-list__item--initial.checked {
    visibility: hidden;
    opacity: 0;
}

.about-list__item--opened.checked  {
    visibility: visible;
    opacity: 1;
}

.op01.about-list__item--opened.checked  {
    visibility: visible;
    opacity: 1;
}

/*---- item01 ----*/

.about-list__item.item01 .about-list__item--initial {
    background:#fff url(../img/about/bg-office.svg) no-repeat center top 52% / 162px;
}

.about-list__item.item01 dd {
    font-size: clamp(3.2rem,5vw,4rem);
}

.about-list__item.item01 dd .fc-or {
    font-size: clamp(8.4rem,10.88vw,10rem);
}

@media screen and (min-width:600px) {
    .about-list__item.item01 .about-list__item--initial {
        background:#fff url(../img/about/bg-office.svg) no-repeat center top 52% / 210px;
    }
}

/*---- item02 ----*/

.about-list__item.item02 .about-list__item--initial {
    background:#fff url(../img/about/bg-care.svg) no-repeat center top 55% / 140px;
}

.about-list__item.item02 dd {
    font-size: clamp(4rem,6.2vw,5rem);
    line-height: 1.2;
}

.about-list__item.item02 dd .fc-or {
    font-size: clamp(4rem,6.2vw,5rem);
}

@media screen and (min-width:600px) {
    .about-list__item.item02 .about-list__item--initial {
        background:#fff url(../img/about/bg-care.svg) no-repeat center top 55% / 170px;
    }
}

/*---- item03 ----*/

.about-list__item.item03 .about-list__item--initial {
    background:#fff url(../img/about/bg-employee.svg) no-repeat center top 52% / 160px;
}

.about-list__item.item03 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    max-width: 280px;
    font-size: clamp(2.6rem,3.8vw,2.8rem);
    line-height: 1.2;
    transform: translate(-50%, -40%);
}

.about-list__item.item03 dd .fc-or {
    font-size: clamp(8rem,9.8vw,8.8rem);
    letter-spacing: 0;
}

@media screen and (min-width:600px) {
    .about-list__item.item03 .about-list__item--initial {
        background:#fff url(../img/about/bg-employee.svg) no-repeat center top 52% / 200px;
    }

    @media screen and (max-width:621px) {
        .about-list__item.item03 dd {
            font-size: 2.4rem;
        }

        .about-list__item.item03 dd .fc-or {
            font-size: 7.7rem;
        }
    }
}


/*---- item04 ----*/

.about-list__item.item04 .about-list__item--initial {
    background:#fff url(../img/about/bg-japan.svg) no-repeat center top 55% / 140px;
}

.about-list__item.item04 dd {
    font-size: clamp(3.2rem,5vw,4rem);
}

.about-list__item.item04 dd .fc-or {
    font-size: clamp(8.4rem,10.88vw,10rem);
}

@media screen and (min-width:600px) {
    .about-list__item.item04 .about-list__item--initial {
        background:#fff url(../img/about/bg-japan.svg) no-repeat center top 55% / 180px;
    }
}

/*---- item05 ----*/

.about-list__item.item05 {
    height: 440px;
}

.about-list__item.item05 .about-list__item--initial {
    background:#fff url(../img/about/bg-cocoruku.svg) no-repeat center top 20% / 135px;
}

.about-list__item.item05 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    transform: translate(-50%, 0);
}

.about-list__item.item05 dd {
    font-size: clamp(2.8rem,5.2vw,5.2rem);
    font-weight: 800;
    line-height: 1.25;
}
.about-list__item.item05 dd .fc-or {
    font-size: clamp(3.2rem,6vw,6rem);
    font-weight: 900;
}

@media screen and (min-width:600px) {
    .about-list__item.item05 {
        height: 330px;
    }

    .about-list__item.item05 .about-list__item--initial {
        background:#fff url(../img/about/bg-cocoruku.svg) no-repeat center top 55% / 185px;
    }

    .about-list__item.item05 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
        transform: translate(-50%, -45%);
    }
}

/*---- item06 ----*/

.about-list__item.item06 {
    height: auto;
}

/*開く前*/

.about-list__item.item06 .about-list__item--initial {
    position: relative;
    background:#fff;
}

.about-list__item.item06 .about-list__item--initial dd {
    margin: 0 auto;
    width: 100%;
}

.op-list__item--btn {
    position: relative;
}

.op-list__item--btn::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2.52em;
    background: #ffffffd2;
    border-radius: 0 0 14px 14px;
}

.op-list__item--btn .guide {
    bottom: 5%;
    left: 50%;
    transform: translateX(-49%);
    right: inherit;
    padding: 0 1.5em 0 0;
    color: #333;
    font-size: clamp(1.6rem, 2.4vw, 2rem);
    font-weight: 700;
    line-height: 1.2;
    z-index: 1;
}

.op-list__item--btn .guide::before {
    width: 1.19em;
    height: 1.19em;
}

.op-name {
    letter-spacing: .04rem;
}

/*開いた後*/

.about-list__item.item06 dl.txt-cont {
    transform: translate(-50%, -55%);
}

.about-list__item.item06 dl.txt-cont dt {
    margin-bottom: .8em;
    font-size: 2.6rem;
    font-weight: 600;
}

.about-list__item.item06 dl.txt-cont dd {
    text-align: left;
}

.op-list__item {
    margin-top: 15px;
    width: 47.5%;
}

.op-list__item--btn {
    box-shadow: 0.2px 1px 5px #00000017;
    border-radius: 24px;
    transition: .3s;
}

/*hover時*/
.target-item .op-list__item--btn:hover {
    border: solid 5px #F89C40;
    transition: .3s;
}
.op-list__item--btn:hover::after {
    border-radius: 0 0 18px 18px;
}

@media screen and (min-width:600px) {
    .op-list__item {
        width: 24%;
    }

    @media screen and (max-width:1079.98px) {
        /*hover時*/
        .op-list__item--btn:hover::after {
            border-radius: 0 0 16px 16px;
        }
    }

    .about-list__item.item06 dl.txt-cont {
        width: 88%;
    }
}
@media screen and (min-width:768px) {
    .about-list__item.item06 .about-list__item--initial dd {
        width: 97%;
    }
    .op-list__item {
        width: 23%;
    }
}

/*---- item07 ----*/

.about-list__item.item07 .about-list__item--initial {
    background:#fff url(../img/about/bg-time.svg) no-repeat center top 70% / 100px;
}

.about-list__item.item07 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    font-size: clamp(2.4rem,4.5vw,4rem);
    transform: translate(-50%, -42%);
}

.about-list__item.item07 dd .fc-or {
    font-size: clamp(8.6rem, 13vw, 12rem);
}

@media screen and (max-width:354px) {
    .about-list__item.item07 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
        transform: translate(-50%, -25%);
    }
}

@media screen and (min-width:600px) {
    .about-list__item.item07 .about-list__item--initial {
        background:#fff url(../img/about/bg-time.svg) no-repeat center top 60% / 180px;
    }
}

/*---- item08 ----*/

.about-list__item.item08 .about-list__item--initial {
    background:#fff url(../img/about/bg-calendar.svg) no-repeat center top 60% / 80px;
}

.about-list__item.item08 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    font-size: clamp(2.4rem,4.45vw,3.8rem);
    transform: translate(-50%, -42%);
}

.about-list__item.item08 dd .fc-or {
    font-size: clamp(8rem, 12.55vw, 11rem);
}

.about-list__item--initial .guide.link::before {
    width: 1.3em;
    height: 1.3em;
    background: url(../img/about/icon-link.svg) no-repeat right center / contain;
}

/*click時*/
.about-list__item.item08 .about-list__item--initial.checked {
    visibility: inherit;
    opacity: 1;
}

@media screen and (min-width:600px) {
    .about-list__item.item08 .about-list__item--initial {
        background:#fff url(../img/about/bg-calendar.svg) no-repeat center top 55% / 160px;
    }
}

/*---- item9 ----*/

.about-list__item.item9 .about-list__item--initial {
    background:#fff url(../img/about/bg-human.svg) no-repeat center top 70% / 80px;
}

.about-list__item.item9 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    font-family: initial;
    font-size: clamp(4rem,7.5vw,6rem);
    transform: translate(-50%, -40%);
}

.about-list__item.item9 dd .fc-or {
    position: relative;
    font-size: clamp(8rem,12.55vw,11rem);
    line-height: 1.25;
    transform: translateY(15%);
}

.about-list__item.item9 dd .fc-or:last-child {
    padding-left: .07em;
}

.about-list__item.item9 dd .fc-or::before {
    position: absolute;
    top: -3.5%;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    color: #333;
    font-size: clamp(1.6rem,3.3vw,2.6rem);
    font-weight: 800;
}

.about-list__item.item9 dd .fc-or:first-child::before {
    content: "男性";
}

.about-list__item.item9 dd .fc-or:last-child::before {
    content: "女性";
}

@media screen and (min-width:600px) {
    .about-list__item.item9 .about-list__item--initial {
        background:#fff url(../img/about/bg-human.svg) no-repeat center top 60% / 150px;
    }

    .about-list__item.item9 dd {
        transform: translate(-50%, -60%);
    }

    .about-list__item.item9 dd .fc-or:first-child {
        padding-right: .06em;
    }
    .about-list__item.item9 dd .fc-or:last-child {
        padding-left: .11em;
    }

    .about-list__item.item9 dd .fc-or::before {
        top: 40%;
        transform: translateX(0);
    }
    .about-list__item.item9 dd .fc-or:first-child::before {
        left: -100%;
    }
    .about-list__item.item9 dd .fc-or:last-child::before {
        content: "女性";
        left: auto;
        right: -100%;
    }
}

/*---- item10 ----*/

.about-list__item.item10 .about-list__item--initial {
    background:#fff url(../img/about/bg-travel.svg) no-repeat center top 70% / 110px;
}

.about-list__item.item10 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    font-size: clamp(2.4rem,4.5vw,4rem);
    transform: translate(-50%, -34%);
}

.about-list__item.item10 dd .fc-or {
    font-size: clamp(8.6rem, 13vw, 12rem);
}

@media screen and (max-width:598.98px) {
    .about-list__item.item10 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
        transform: translate(-50%, -25%);
    }
}

@media screen and (min-width:600px) {
    .about-list__item.item10 .about-list__item--initial {
        background:#fff url(../img/about/bg-travel.svg) no-repeat center top 60% / 200px;
    }
}

/*---- item11 ----*/

.about-list__item.item11 .about-list__item--initial {
    background:#fff url(../img/about/bg-memo.svg) no-repeat right 44% top 60% / 140px;
}

.about-list__item.item11 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    font-size: clamp(2.6rem,5vw,5.4rem);
    line-height: 1.2;
    font-weight: 800;
}

.about-list__item.item11 dd .fc-or {
    padding: 0 .06em;
    font-size: clamp(8rem,13vw,11rem);
    letter-spacing: 0;
}

/*click時*/
.about-list__item.item11 .about-list__item--initial.checked {
    visibility: inherit;
    opacity: 1;
}

@media screen and (min-width:600px) {
    .about-list__item.item11 .about-list__item--initial {
        background:#fff url(../img/about/bg-memo.svg) no-repeat right 48% top 60% / 185px;
    }
}

/*---- item12 ----*/

.about-list__item.item12 .about-list__item--initial {
    background:#fff;
}

.about-list__item.item12 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
    width: 85%;
    transform: translate(-50%, -35%);
}

@media screen and (min-width:600px) {
    .about-list__item.item12 dd:not(.about-list__item.item06 .about-list__item--initial dd) {
        width: 80%;
        max-width: 580px;
        transform: translate(-50%, -40%);
    }
}



/*==========================================================
main-cont
==========================================================*/

#main-cont {
    position: relative;
}

.tabs {
    margin-top: 3em;
    background-color: #FFFEF8;
}

/*どちらかを選択してください*/
.prompt {
    position: absolute;
    top: -3em;
    left: 50%;
    transform: translateX(-50%);
    justify-content: center;
    flex-wrap: nowrap;
    padding: .7em;
    width: 100%;
    background: #ffffffa8;
    z-index: 1;
}
.prompt p {
    text-align: center;
    color: #5A3B16;
    font-size: clamp(1.8rem,1.33vw,2rem);
    font-weight: 700;
    line-height: 1.4;
}
.prompt::before,
.prompt::after  {
    content: "";
    width: .9em;
    height: .9em;
    background: url(../img/main-cont/select-arrow.svg) no-repeat left center / contain;
}
.prompt::before {
    margin-right: .9em;
}
.prompt::after {
    margin-left: .9em;
    transform: scale(-1, 1);
}

/*
tab operation
-----------------------------------------------*/

/*ラジオボタンを全て消す*/
input[name="tab-item"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
.tab-cont {
    display: none;
    padding-top: 70px;
    width: 100%;
    overflow: hidden;
}

/*選択されているタブのコンテンツのみを表示*/
#tab01:checked~#ng-cont,
#tab02:checked~#mc-cont {
    display: block;
}

/*
tab label style -- standard
-----------------------------------------------*/

.tab-item {
    display: block;
    position: relative;
    width: 50%;
    transition: all 0.2s ease;
}

/*------- tab ph area -------*/

.tab-item__ph-area {
    position: relative;
    height: 63vw;
    max-height: 300px;
    overflow: hidden;
}

label[for="tab01"] .tab-item__ph-area {
	background: #ffe3c9;
}

label[for="tab02"] .tab-item__ph-area {
    background: #daefff;
}

.tab-item__ph-area::before {
    position: absolute;
    top: 5px;
    left: 50%;
    transform: translateX(-50%);
    color: #ffffffa6;
    font-size: clamp(2.6rem,6.66vw,18rem);
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    z-index: 0;
}

label[for="tab01"] .tab-item__ph-area::before {
    content: "NEW GRADUATE";
}
label[for="tab02"] .tab-item__ph-area::before {
    content: "MID-CAREER";
}

.tab-item__ph {
    position: absolute;
    top: 8%;
    left: 50%;
    transform: translateX(-50%);
    width: 130%;
    max-width: 350px;
    opacity: .9;
}

/*------- tab title area -------*/

.tab-item__title {
    padding: .7em;
    text-align: center;
    font-size: clamp(1.8rem,3.33vw,4.4rem);
    font-weight: 800;
    line-height: 1.3;
    background: #fff;
}

label[for="tab01"] .tab-item__title {
    color: #ffbb77;
    border:  solid .2em #ffbb77;
}

label[for="tab02"] .tab-item__title {
    color: #8cbaf3;
    border:  solid .2em #8cbaf3;
}

/*
tab label style -- checked
-----------------------------------------------*/

/*------- tab ph area -------*/

input#tab01:checked + label[for="tab01"] .tab-item__ph-area {
    background: #ffc17e;
}

input#tab02:checked + label[for="tab02"] .tab-item__ph-area {
    background: #9dd6ff;
}

input#tab01:checked + label[for="tab01"] .tab-item__ph,
input#tab02:checked + label[for="tab02"] .tab-item__ph {
    opacity: 1;
}

/*------- tab title area -------*/

input#tab01:checked + label[for="tab01"] .tab-item__title,
input#tab02:checked + label[for="tab02"] .tab-item__title {
    color: #fff;
}

input#tab01:checked + label[for="tab01"] .tab-item__title {
    background: #F89C40;
    border:  solid .2em #F89C40;
}

input#tab02:checked + label[for="tab02"] .tab-item__title {
    background: #5594EA;
    border:  solid .2em #5594EA;
}

/*arrow*/

input#tab01:checked + label[for="tab01"]::after,
input#tab02:checked + label[for="tab02"]::after {
    content: "";
    display: block;
    position: absolute;
    bottom: -4.95vw;
    clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
    width: 100%;
    height: 5vw;
}

input#tab01:checked + label[for="tab01"]::after{
    background-color: #F89C40;
}

input#tab02:checked + label[for="tab02"]::after {
    background: #5594EA;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    .tab-item__ph-area {
        height: 45vw;
        max-height: 435px;
    }

    .tab-item__ph {
        width: 97%;
        max-width: 450px;
    }
}

/*----------------------------------------------------------
    TABLET（画面幅900px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:900px) {

    .tabs {
        margin-top: .8em;
    }

    .prompt {
        top: 3.8%;
        padding: .7em .6em;
        width: 20%;
        max-width: 270px;
        border-radius: 35px;
    }

    .prompt p {
        width: 77%;
        max-width: 190px;
    }

    @media screen and (max-width:1080px) {
        .prompt {
            width: 20%;
        }

        .prompt p {
            font-size: 1.5rem;
            letter-spacing: 0;
        }
    }

    .prompt::before {
        margin-right: .2em;
    }
    .prompt::after {
        margin-left: .2em;
    }
}

@media screen and (min-width:1400px) {

    .prompt {
        top: 4.4%;
    }

    .prompt::before,
    .prompt::after {
        width: 1.2em;
    }

    .tab-item__ph-area {
        max-height: 500px;
    }

    .tab-item__ph {
        top: 15%;
        max-width: 500px;
    }

    input#tab01:checked + label[for="tab01"]::after,
    input#tab02:checked + label[for="tab02"]::after {
        bottom: -69.5px;
        height: 70px;
    }
}

/*
tab content
-----------------------------------------------*/

.jump-list__item {
    margin-bottom: 1em;
    text-align: center;
    font-size: clamp(2.2rem,2.8vw,2.6rem);
    line-height: 1.3;
}

.jump-list__item:last-child {
    margin-bottom: 0;
}

.jump-list__arrow {
    margin-left: .2em;
    top: -.1em;
    width: 26px;
    height: 12.6px;
}

.jump-list__arrow::before,
.jump-list__arrow::after {
    bottom: 0;
    left: calc(50% - 1.75px);
    width: 3px;
    height: 16px;
    transform-origin: 50% calc(100% - 1.5px);
}

.jump-list__arrow::before {
    transform: rotate(50deg);
}

.jump-list__arrow::after {
    transform: rotate(-50deg);
}

#ng-cont .jump-list__arrow::before,
#ng-cont .jump-list__arrow::after {
    background-color: #F89C40;
}

#mc-cont .jump-list__arrow::before,
#mc-cont .jump-list__arrow::after {
    background-color: #5594EA;
}

/*
common
-----------------------------*/

.interview,
.flow,
.entry {
    padding-top: 65px;
}

#ng-cont h3,
#mc-cont h3 {
    text-align: center;
    font-size: clamp(3.2rem,5.55vw,4.8rem);
    font-weight: 900;
    line-height: 1.6;
}

#mc-cont h3 {
    color: #5594EA;
}

#ng-cont h4 {
    color: #e45b00;
}

.fc-navy {
    color: #1C4280;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {
    .tab-cont {
        padding-top: 100px;
    }

    .interview,
    .flow,
    .entry {
        padding-top: 110px;
    }
}

/*----------------------------------------------------------
    TABLET（画面幅900px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:900px) {

    .tab-cont {
        padding-top: 140px;
    }

    .jump-list {
        display: flex;
        justify-content: space-between;
        margin: 0 auto;
        max-width: 900px;
    }

    .jump-list__item {
        margin-bottom: 0;
    }
}

/*
interview
-----------------------------*/

.interview {
    margin: 0 auto;
    max-width: 910px;
}

.interview h3 + p {
    font-size: clamp(1.6rem,2.88vw,2.2rem);
}

.interview h3 + p br {
    display: none;
}

@media screen and (min-width:450px) {
    #ng-cont .interview h3 + p {
        text-align: center;
    }

    .interview h3 + p br {
        display: block;
    }
}
@media screen and (min-width:768px) {
    #mc-cont .interview h3 + p {
        text-align: center;
    }
}

.staff01 {
    padding-top: 45px;
}
.staff02 {
    padding-top: 60px;
}

.staff-intro__ph {
    margin: 0 auto;
    max-width: 430px;
}

.staff-intro__txt-wrap {
    position: relative;
    margin: -50px auto 0;
    width: 100%;
    max-width: 275px;
    height: 275px;
    text-align: center;
    line-height: 1.5;
    border-radius: 100vh;
    z-index: 1;
}

#ng-cont .staff-intro__txt-wrap {
    background: #fff397;
}

#mc-cont .staff-intro__txt-wrap {
    background: #BFEEFF;
}

.staff-intro__txt-wrap .num,
.staff-intro__txt-content {
    position: absolute;
    left: 50%;
    width: 100%;
}

.staff-intro__txt-wrap .num {
    top: -.85em;
    transform: translateX(-50%);
    font-size: clamp(6rem,7.77vw,8.4rem);
}

.staff-intro__txt-content {
    top: 50%;
    transform: translate(-50%, -51%);
}

.staff-intro__txt-wrap .num,
.staff-intro__txt-wrap .name {
    font-weight: 900;
    letter-spacing: .5rem;
}

.staff-intro__txt-wrap .name {
    margin-bottom: .05em;
    font-size: clamp(3.7rem,4vw,5.4rem);
}

.staff-intro__txt-wrap .name span {
    font-size: clamp(1.4rem,1.66vw,2rem);
    letter-spacing: .05rem;
    font-weight: 500;
}

.staff-intro__txt-wrap .occupation {
    font-size: clamp(2.2rem,2.55vw,3rem);
    font-weight: 700;
}

.staff-intro__txt-wrap .occupation span {
    margin-left: .5em;
    padding: .1em 1.2em;
    color: #333;
    font-size: clamp(1.4rem,1.66vw,2rem);
    font-weight: 500;
    background: #fff;
    border-radius: 5px;
}

.staff-intro__txt-wrap .graduation,
.staff-intro__txt-wrap .join {
    font-size: clamp(1.6rem,1.66vw,2rem);
}

.staff-intro__txt-wrap .graduation {
    display: inline-block;
    margin: 1.1em auto .7em;
    padding: .65em 0;
    width: 205px;
    background-image: linear-gradient(to right, #fff 3px, transparent 3px), linear-gradient(to right, #fff 3px, transparent 3px);
    background-position: left top, left bottom;
    background-size: 8px 3px;
    background-repeat: repeat-x;
}

.interview__content h4 {
    padding-bottom: .25em;
    font-size: 2rem;
    line-height: 1.5;
}

#ng-cont .interview__content h4 {
    border-bottom: solid 1px #F89C40;
}

#mc-cont .interview__content h4 {
    border-bottom: solid 1px #5594EA;
}

.interview__content--01 {
    margin-top: 30px;
}

.interview__content--02,
.interview__content--03 {
    margin-top: 35px;
}

/*schedule*/

.schedule-img {
    margin: 50px auto 30px;
    max-width: 400px;
}

.schedule-txt {
    margin: 20px auto 0;
    max-width: 500px;
}

.schedule-txt dt {
    justify-content: flex-start;
    margin-top: .8em;
}

.schedule-time {
    margin-right: .5em;
    padding: 0 .2em 0 .5em;
    width: 21.5%;
    min-width: 98px;
    max-width: 107px;
    color: #fff;
    font-size: clamp(1.8rem,3.55vw,2rem);
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: .08rem;
}

.ls-shrink {
    letter-spacing: .03rem;
}

#ng-cont .outside-h {
    background: #FFE839;
}
#ng-cont .working-h {
    background: #F89C40;
}

#mc-cont .outside-h {
    background: #87D8F5;
}
#mc-cont .working-h {
    background: #5594EA;
}

.schedule-item {
    font-size: clamp(1.6rem,2.99vw,1.8rem);
}

.schedule-txt dd {
    font-size: clamp(1.4rem,2.55vw,1.6rem);
}

/*
flow
-----------------------------*/

.flow-chart {
    margin: 0 auto;
    width: 100%;
    max-width: 400px;
}

@media screen and (min-width:430px) and (max-width:767.98px) {
    .flow-chart {
        width: 90%;
    }
}

/*
entry
-----------------------------*/

.entry p {
    text-align: center;
    font-size: clamp(1.6rem,3vw,2.4rem);
    line-height: 1.6;
}

.entry .btn-wrap {
    margin: 0 auto;
    max-width: 500px;
}

.entry .btn-wrap a:first-child {
    margin-top: 30px;
}
.entry .btn-wrap a:last-child {
    margin-top: 20px;
}

.requirements-btn {
    margin: 0 auto;
    width: 100%;
    max-width: 430px;
    padding: 1.3em .8em;
    text-align: center;
    background: #fff;
    border-radius: 8px;
    border: solid 6px #BFEEFF;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}

.requirements-btn span {
    display: inline-block;
    padding-right: 1.3em;
    font-size: 2.6rem;
    font-weight: 700;
    letter-spacing: .1rem;
    line-height: 1.3;
    background: url(../img/main-cont/mc_link-icon.svg) no-repeat right center / .9em;
    transform: translateX(1%);
}

#mc-cont .entry-btn {
    width: 100%;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    /*
    interview
    -----------------------------*/

    .staff01 {
        padding-top: 80px;
    }
    .staff02 {
        padding-top: 160px;
    }

    .staff-intro {
        display: flex;
        position: relative;
    }

    .staff-intro__ph {
        position: absolute;
        top: 50%;
        transform: translateY(-52%);
        width: 62%;
        max-width: 565px;
    }

    .staff02 .staff-intro__ph {
        right: 0;
    }

    .staff-intro__txt-wrap {
        margin: 0 0 0 auto;
        width: 37vw;
        height: 37vw;
        max-width: 350px;
        max-height: 350px;
    }

    .staff02 .staff-intro__txt-wrap {
        margin: 0 auto 0 0;
    }

    .staff-intro__txt-wrap .num {
        top: -0.8em;
    }

    .interview__content--01 {
        margin-top: 60px;
    }

    .interview__content h4 {
        text-align: center;
    }

    /*schedule*/

    .schedule-img {
        margin: 50px auto 0;
    }

    #ng-cont .staff01 .schedule-img {
        width: 90%;
        max-width: 750px;
        transform: translateX(4%);
    }
    #ng-cont .staff02 .schedule-img {
        width: 93%;
        max-width: 780px;
        transform: translateX(2%);
    }

    #mc-cont .staff01 .schedule-img {
        max-width: 820px;
    }
    #mc-cont .staff02 .schedule-img {
        width: 92%;
        max-width: 740px;
        transform: translateX(3%);
    }

    /*
    flow
    -----------------------------*/

    .flow-chart {
        margin-top: 10px;
        max-width: 100%;
    }

    /*
    entry
    -----------------------------*/

    .entry .btn-wrap {
        max-width: 590px;
    }

    .entry .btn-wrap a:first-child {
        margin-top: 50px;
    }
    #mc-cont .entry .btn-wrap a:first-child {
        margin-top: 35px;
    }
    .entry .btn-wrap a:last-child {
        margin-top: 30px;
    }

}

/*----------------------------------------------------------
    PC（画面幅1080px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:1080px) {

    /*
    interview
    -----------------------------*/
    .staff-intro__txt-wrap {
        max-width: 375px;
        max-height: 375px;
    }
}



/*==========================================================
faq
==========================================================*/

#faq h2 {
    text-align: center;
    font-size: clamp(2.4rem,3.5vw,2.6rem);
}

.faq-list {
    margin: 30px auto 0;
    width: 100%;
    max-width: 785px;
    line-height: 1.6;
}

.faq-list__item:not(:last-child) {
    margin-bottom: 1em;
}

.faq-list .acd-label {
    padding: .6em .2em .6em 1.1em;
    border-bottom: solid 1px #bbbbbb;
    background: url(../img/qa/q-icon.png) no-repeat left .2em center / 1.3em;
}

.faq-list .acd-label__txt {
    margin-right: 2em;
}

.faq-list  .acd-label__arrow::before,
.faq-list  .acd-label__arrow::after {
    left: calc(50% - 1.5px);
    width: 3px;
    height: 16px;
    transform-origin: 50% calc(100% - 1.5px);
    background-color: #F89C40;
}

.faq-list .acd-cont {
    font-weight: 400;
    background: url(../img/qa/a-icon.png) no-repeat left .2em top 1.3em / 1.3em;
}

@media screen and (min-width:443px) {
    .faq-list .acd-cont {
        background: url(../img/qa/a-icon.png) no-repeat left .2em center / 1.3em;
    }
}

.faq-list__item .acd-check:checked + .acd-label + .acd-cont {
    padding: .9em 0 .8em 2.1em;
}

.faq-list .pdf {
    padding-right: 1.2em;
    display: inline-block;
    color: #F89C40;
    font-weight: 500;
    text-decoration: underline;
    background: url(../img/qa/pdf-icon.svg) no-repeat right center / 1.1em;
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    .faq-list__item:not(:last-child) {
        margin-bottom: 1.2em;
    }

    .faq-list .acd-label {
        padding: 1.1em .2em 1.1em 1.1em;
        border-bottom: solid 2px #bbbbbb;
    }

    .faq-list__item .acd-check:checked + .acd-label + .acd-cont {
        padding: 1.4em 0 1.4em 2.1em;
    }
}



/*==========================================================
closing
==========================================================*/

.closing {
    background: url(../img/bg-parts/stripe.svg) repeat left top / 2em;
}

.closing-copy {
    margin-bottom: 30px;
    text-align: center;
    color: #5A3B16;
    font-size: clamp(2.4rem,4vw,3rem);
    font-weight: 900;
    letter-spacing: .1em;
}

.closing-txt {
    margin-bottom: 50px;
    color: #251b18;
    font-weight: 600;
    line-height: 2.4;
    letter-spacing: .07em;
}

@media screen and (min-width:601px) {
    .closing-txt {
        text-align: center;
    }
}

/*----------------------------------------------------------
    TABLET（画面幅768px以上で読み込む）
-----------------------------------------------------------*/
@media screen and (min-width:768px) {

    .closing-copy {
        letter-spacing: .12em;
    }

    .closing-txt {
        line-height: 3;
        letter-spacing: .1em;
    }
}


