@charset "utf-8";
@import "anime.css";

/*
------------
recruit.css
------------
*/
/* page_container */
#page_container {
    background: #F5F5F7;
    padding: 0 0 150px 0;
}
@media only screen and (max-width: 768px) {
    #page_container {
        padding: 0 0 80px 0;
    }
}
/* tit_area */
#tit_area {
    background-image: url(../../images/content/recruit/titBg.webp);
    background-repeat: no-repeat;
    background-position: right top;
    background-size: cover;
}
@media only screen and (max-width: 768px) {
    #tit_area {
        background-image: url(../../images/content/recruit/titBgSP.webp);
    }
}
/* tab_area */
#tab_area {
    margin: 125px 0 0 0;
}
#tab_area ul {
    width: calc(100vw * 1200 / 1500);
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#tab_area ul li {
    width: 50%;
    height: 60px;
    font-size: 2.2rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #304751;
    border: 1px solid #304751;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: all .3s ease;
}
#tab_area ul li:hover {
    background: #304751;
    color: #fff;
}
#tab_area ul li.current {
    background: #304751;
    color: #fff;
    position: relative;
    cursor: default;
}
#tab_area ul li.current::before {
    content: "";
    width: 16px;
    height: 8px;
    background: #304751;
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    clip-path: polygon(100% 0, 0 0, 50% 100%);
}
#tab_area ul li:nth-child(1) {
    border-radius: 10px 0 0 10px;
}
#tab_area ul li:nth-child(2) {
    border-radius: 0 10px 10px 0;
}
@media only screen and (max-width: 768px) {
    #tab_area {
        margin: 50px 0 0 0;
    }
    #tab_area ul {
        width: 90vw;
        max-width: 90vw;
    }
    #tab_area ul li {
        height: 40px;
        font-size: 1.6rem;
    }
}
/* filter_area */
#filter_area {
    margin: 60px 0 0 0;
}
#filter_area .inner {
    width: calc(100vw * 1200 / 1500);
    max-width: 1200px;
    margin: 0 auto;
    font-feature-settings: "palt";
}
#filter_area .inner dl {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
}
#filter_area .inner dl:not(:first-child) {
    margin: 30px 0 0 0;
}
#filter_area .inner dl dt {
    width: 15rem;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
}
#filter_area .inner dl dd {
    width: calc(100% - 15rem);
}
#filter_area .inner dl.occupation dd ul {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 10px 20px;
}
#filter_area .inner dl.occupation dd ul li {
    width: 160px;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    font-weight: 500;
    text-align: center;
}
#filter_area .inner dl.occupation dd ul li a {
    display: block;
    border: 1px solid #304751;
    border-radius: 4px;
    color: #304751;
    padding: 10px 0;
    transition: all .3s ease;
}
#filter_area .inner dl.occupation dd ul li a:hover {
    background: #304751;
    color: #fff;
}
#filter_area .inner dl.occupation dd ul li.current {
    background: #304751;
    color: #fff;
    padding: 10px 0;
     border-radius: 4px;
}
#filter_area .inner dl.ck_box dd ul {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 20px;
}
#filter_area .inner dl.ck_box dd ul li {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    align-items: center;
    gap: 7px;
}
#filter_area .inner dl.ck_box dd ul li label {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    color: #304751;
    font-weight: 500;
}
@media only screen and (max-width: 768px) {
    #filter_area {
        margin: 25px 0 0 0;
    }
    #filter_area .inner {
        width: 90vw;
        max-width: 90vw;
    }
    #filter_area .inner dl {
        display: block;
    }
    #filter_area .inner dl:not(:first-child) {
        margin: 35px 0 0 0;
    }
    #filter_area .inner dl dt {
        width: 100%;
    }
    #filter_area .inner dl dd {
        width: 100%;
        margin: 13px 0 0 0;
    }
    #filter_area .inner dl.occupation dd ul {
        justify-content: space-between;
        gap: 10px 0;
    }
    #filter_area .inner dl.occupation dd ul li {
        width: calc(100% / 2 - 8px);
    }
    #filter_area .inner dl.ck_box dd ul {
        flex-wrap: wrap;
        gap: 15px 35px;
    }
}
/* job_list */
#job_list {
    margin: 100px 0 0 0;
    position: relative;
}
#job_list .inner {
    width: calc(100vw * 1200 / 1500);
    max-width: 1200px;
    margin: 0 auto;
    font-feature-settings: "palt";    
}
#job_list .inner h3 {
    display: block;
    font-size: 3.8rem;
    font-weight: 600;
    color: #304751;
    letter-spacing: 0.1em;
    position: relative;
}
#job_list .inner h3::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #BAC1C5;
    position: absolute;
    bottom: -20px;
    left: 0;
}
#job_list .inner h3::after {
    content: "";
    width: 80px;
    height: 3px;
    background: #304751;
    position: absolute;
    bottom: -21px;
    left: 0;
}
#job_list .inner h3.second {
    margin: 100px 0 0 0;
}
#job_list .inner .list {
    margin: 65px 0 0 0;
}
#job_list .inner .list p.empty {
    font-size: 2.4rem;
    font-weight: 600;
    letter-spacing: 0.1em;
}
#job_list .inner .list article:not(:first-child) {
    margin: 30px 0 0 0;
}
#job_list .inner .list article .head {
    background: #fff;
    border: 1px solid #fff;
    border-radius: 10px;
    cursor: pointer;
    padding: 30px 80px 30px 30px;
    position: relative;
    transition: all .3s ease;
}
#job_list .inner .list article.active .head {
    border-radius: 10px 10px 0 0;
}
#job_list .inner .list article .head:hover {
    border: 1px solid #304751;
}
#job_list .inner .list article.active .head:hover {
    border: 1px solid #fff;
}
#job_list .inner .list article .head::after {
    content: "";
    width: 27px;
    height: 14px;
    background-image: url(../../images/global/arrow_down_b.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%);
    z-index: 1;
    transition: all .3s ease;
}
#job_list .inner .list article.active .head::after {
    transform: translateY(-50%) rotate(-180deg);
}

#job_list .inner .list article .head ul.tag {
    display: flex;
    justify-content: flex-start;
    gap: 5px;
}
#job_list .inner .list article .head ul.tag li {
    text-align: center;
    padding: 4px 14px;
    border: 1px solid #304751;
    color: #304751;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    border-radius: 4px;
}
#job_list .inner .list article .head ul.tag li:nth-child(1) {
    background: #304751;
    color: #fff;
}
#job_list .inner .list article .head h4 {
    font-size: 2.4rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.5;
    margin: 15px 0 0 0;
    text-align: justify;
}
#job_list .inner .list article .head p.lead {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6;
    margin: 10px 0 0 0;
    text-align: justify;
}
#job_list .inner .list article .head p.area {
    font-size: 1.6rem;
    font-weight: 500;
    color: #304751;
    letter-spacing: 0.1em;
    margin: 20px 0 0 0;
    position: relative;
    padding: 0 0 0 25px;
}
#job_list .inner .list article .head p.area::before {
    content: "";
    width: 16px;
    height: 20px;
    background-image: url(../../images/global/ico_area.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
#job_list .inner .list article .content::before {
    content: "";
    width: calc(100% - 60px);
    height: 1px;
    background: #BAC1C5;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}
#job_list .inner .list article .content {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: all .3s ease;
    background: #fff;
    border-radius: 0 0 10px 10px;
    padding: 0 30px;
    position: relative;
}
#job_list .inner .list article.active .content {
    opacity: 1;
    padding: 50px 30px 75px 30px;
}
#job_list .inner .list article .content .item:not(:first-child) {
    margin: 80px 0 0 0;
}
#job_list .inner .list article .content .item h5 {
    font-size: 2.4rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    position: relative;
}
#job_list .inner .list article .content .item h5::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #304751;
    position: absolute;
    bottom: -15px;
    left: 0;
}
#job_list .inner .list article .content .item h5::after {
    content: "";
    width: 80px;
    height: 3px;
    background: #304751;
    position: absolute;
    bottom: -16px;
    left: 0;
}
#job_list .inner .list article .content .item p.lead {
    margin: 50px 0 0 0;
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6;
    text-align: justify;
}
#job_list .inner .list article .content .item .element dl {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
}
#job_list .inner .list article .content .item .element dl dt {
    width: 18rem;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.6;
    padding: 0 20px;
}
#job_list .inner .list article .content .item .element dl dd {
    width: calc(100% - 18rem);
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6;
    text-align: justify;
    padding: 0 20px;
}
#job_list .inner .list article .content .item .element dl dd p:not(:first-child) {
    margin: 30px 0 0 0;
}
#job_list .inner .list article .content .item.information .element {
    margin: 40px 0 0 0;
}
#job_list .inner .list article .content .item.information .element dl {
    padding: 25px 0;
    border-top: 1px solid #BAC1C5;
}
#job_list .inner .list article .content .item.information .element dl:last-child {
    border-bottom: 1px solid #BAC1C5;
}
#job_list .inner .list article .content .item.requirements .element {
    margin: 60px 0 0 0;
}
#job_list .inner .list article .content .item.requirements .element dl {
    border-bottom: 1px solid #BAC1C5;
}
#job_list .inner .list article .content .item.requirements .element dl dt {
    border-top: 1px solid #BAC1C5;
    padding: 20px;
}
#job_list .inner .list article .content .item.requirements .element dl dd {
    border-top: 1px solid #BAC1C5;
    padding: 20px;
}
#job_list .inner .list article .content p.entry {
    margin: 65px 0 0 0;
    text-align: center;
}
#job_list .inner .list article .content p.entry a {
    background: #E61900;
    border: 1px solid #E61900;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    border-radius: 300px;
    padding: 15px 90px 15px 70px;
    transition: all .3s ease;
}
#job_list .inner .list article .content p.entry a span {
    position: relative;
}
#job_list .inner .list article .content p.entry a span::before {
    content: "";
    width: 13px;
    height: 13px;
    background-image: url(../../images/global/ico_blank_white.svg);
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: absolute;
    top: 50%;
    right: -20px;
    transform: translateY(-50%);
    transition: all .3s ease;
}
#job_list .inner .list article .content p.entry a:hover {
    background: #fff;
    color: #E61900;
}
#job_list .inner .list article .content p.entry a:hover span::before {
    background-image: url(../../images/global/ico_blank_red.svg);
}
@media only screen and (max-width: 768px) {
    #job_list {
        margin: 80px 0 0 0;
    }
    #job_list .inner {
        width: 90vw;
        max-width: 90vw;
    }
    #job_list .inner h3 {
        font-size: 3.2rem;
    }
    #job_list .inner h3.second {
        margin: 80px 0 0 0;
    }
    #job_list .inner .list {
        margin: 50px 0 0 0;
    }
    #job_list .inner .list p.empty {
        line-height: 1.3;
    }
    #job_list .inner .list article .head {
        padding: 25px 30px;
    }
    #job_list .inner .list article .head::after {
        width: 16px;
        height: 8px;
        top: auto;
        bottom: 25px;
        right: 20px;
        transform: translateY(0);
    }
    #job_list .inner .list article .head ul.tag li {
        padding: 4px 12px;
    }
    #job_list .inner .list article .content::before {
        width: calc(100% - 40px);
    }
    #job_list .inner .list article .content {
        padding: 0 20px;
    }
    #job_list .inner .list article.active .content {
        padding: 40px 20px 65px 20px;
    }
    #job_list .inner .list article .content .item p.lead {
        margin: 45px 0 0 0;
    }
    #job_list .inner .list article .content .item .element dl {
        display: block;
    }
    #job_list .inner .list article .content .item .element dl dt {
        width: 100%;
        padding: 0;
    }
    #job_list .inner .list article .content .item .element dl dd {
        width: 100%;
        padding: 0;
        margin: 10px 0 0 0;
    }
    #job_list .inner .list article .content .item .element dl dd p:not(:first-child) {
        margin: 25px 0 0 0;
    }
    #job_list .inner .list article .content .item.requirements .element {
        margin: 50px 0 0 0;
    }
    #job_list .inner .list article .content .item.requirements .element dl dt {
        padding: 15px 0 0 0;
    }
    #job_list .inner .list article .content .item.requirements .element dl dd {
        border-top: none;
        padding: 0 0 15px 0;
        margin: 10px 0 0 0;
    }
    #job_list .inner .list article .content p.entry {
        margin: 50px 0 0 0;
    }
    #job_list .inner .list article .content p.entry a {
        padding: 15px 70px 15px 50px;
    }
}