@charset "UTF-8";
:root{
  --main-color: #00833E;
}

/*````````````````````````````````````````*/
@media only screen and (min-width: 769px) {
/*````````````````````````````````````````*/

/*================*/
section.pagetitle {
}
section.pagetitle>.inner {
}
/*----*/
section.pagetitle .area-ttl {
    padding: 110px 0 100px 0;
}
section.pagetitle .sectioning-title h2 span.main{
    width: 360px;
    aspect-ratio: 362/50;
}
section.pagetitle .sectioning-title h2 span.main b{
    background-image: url(/recruit/img/char_title_recruit.svg);
}

/*================*/
.box-ttl h3 {
    display: flex;
    justify-content: space-between;
    flex-wrap: nowrap;
    align-items: stretch;
    position: relative;
}
.box-ttl h3 span.main {
    width: 280px;
    font-size: 36px;
    font-weight: 400;
    letter-spacing: 0.08em;
}
.box-ttl.new h3 span.sub {
    width: 192px;
    aspect-ratio: 192/16;
    margin: 10px -10px 0 0;
}
.box-ttl.new h3 span.sub b {
    background-image: url(/recruit/img/char_title_new.svg);
}
.box-ttl.experienced h3 span.sub {
    width: 268px;
    aspect-ratio: 268/16;
    margin: 19px 0 0 0;
}
.box-ttl.experienced h3 span.sub b {
    background-image: url(/recruit/img/char_title_experienced.svg);
}
.box-ttl h3 i.line {
    position: absolute;
    left: 280px;
    top: 26px;
    height: 1px;
    background-color: rgba(160, 160, 160, 1);
}
.box-ttl h3 i.line {
    width: 380px;
}
/*----*/
.requirementCategory{
    padding-top: 64px;
}
.requirementCategory-info{
    padding: 25px 0 20px 0;
}
.requirementCategory-info p{
    font-size: 22px;
    line-height: 1.63;
    letter-spacing: 0.04em;
}
.requirementCategory-info p.ymd {
    color: #A9A9A9;
    font-weight: 700;
}
.requirementCategory-info p.txt {
}
/*----*/
.requirementCategory-toDetail{
    margin-top: 30px;
}
.requirementCategory-items{
    display: flex;
    column-gap: 19px;
}
.requirementCategory-item{
    width: 50%;
}
.guideline a{
    display: flex;
}
.guideline-caption{
    padding: 35px 41px;
    width: 67.35%;
    background-color: var(--main-color);
}
.guideline-caption .text-ja{
    font-size: 21px;
    font-weight: 700;
    color: #fff;
}
.guideline-caption .text-en{
    display: block;
    margin-top: 14px;
    font-size: 15px;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.6);
}
.guideline-img{
    width: 32.65%;
}
.requirementCategory-item{
    position: relative;
}
.requirementCategory-item i{
    position: absolute;
    left: 41px;
    bottom: 33px;
    width: 60px;
    aspect-ratio: 60 / 20;
    overflow: hidden;
}
.requirementCategory-item i b{
    position: absolute;
    top: 0;
    left: -30px;
    width: 100%;
    height: 100%;
    -webkit-transition-property: left, right;
    transition-property: left, right;
    -webkit-transition-duration: 0.2s;
    transition-duration: 0.2s;
    -webkit-transition-timing-function: linear;
    transition-timing-function: linear;
}
.requirementCategory-item i b > svg{
    stroke: #fff;
}
.requirementCategory-item a:hover  i b{
    left: 0;
}
/*================*/
.corporate-profile{
    display: flex;
    column-gap: 19px;
    padding-top: 65px;
}
.corporate-profile a{
}
.corporate-profile .border-button.bb-type1 p{
    padding-top: 15px;
    padding-left: 48px;
    text-align: left;
    text-indent: 0;
}
.border-button p span.corporate-profile-ttl{
    position: relative;
    width: 282px;
    font-size: 21px;
    line-height: 1.5;
    font-weight: 700;
    color: var(--main-color);
}
.border-button p span.corporate-profile-ttl-en{
    display: block;
    margin-top: 9px;
    font-size: 15px;
    font-weight: 700;
    color: #B6B6B6;
}
.border-button p span.corporate-profile-ttl:after{
    content: '';
    position: absolute;
    top: 7px;
    right: -31px;
    display: block;
    width: 18px;
    height: 18px;
    background: url(/common/img/ico_pdf_red.png) no-repeat center;
    background-size: contain;
}
.corporate-profile .border-button.bb-type1{
    width: 50%;
    height: 100px;
}
.corporate-profile .border-button.bb-type1 p i{
    top: 38px;
}
/*================*/
.contact{
    position: relative;
    margin-top: 90px;
    height: 305px;
    background: url(/recruit/img/bg_contact.png) no-repeat top center;
    background-size: cover;
}
.contact-inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.contact-ttl{
    font-size: 24px;
    text-align: center;
    line-height: 1.6;
    font-weight: 500;
    color: #fff;
}
.contact-info{
    margin-top: 10px;
    text-align: center;
}
.contact-info-tel{
    font-size: 36px;
    font-weight: 500;
    color: #fff;
}
.contact-info-receptiontime{
    margin-top: 10px;
    font-size: 16px;
    font-weight: 700;
    color: #fff;
}
.contact-mailto.bb-type3{
    margin-top: 12px;
    width: 430px;
}
.contact-mailto.bb-type3 a{
    position: relative;
    display: block;
    border-radius: 40px;
}
.contact-mailto.bb-type3 p:before {
    content: '';
    display: block;
    position: absolute;
    top: 52%;
    left: 42px;
    transform: translateY(-50%);
    width: 22px;
    height: 15px;
    background: url(/common/img/ico_mail_white.png) no-repeat center;
    background-size: contain;
}
.contact-mailto.bb-type3 p span{
    font-size: 16px;
    font-weight: 500;
}


/*````````````````````````````````````````*/
} @media only screen and (max-width: 768px) {
/*````````````````````````````````````````*/

/*================*/
section.pagetitle {
}
section.pagetitle>.inner {
}
/*----*/
section.pagetitle .area-ttl {
    padding: 17vw 0 15vw 0;
}
section.pagetitle .sectioning-title h2 span.main{
    width: 56vw;
    aspect-ratio: 362/50;
}
section.pagetitle .sectioning-title h2 span.main b{
    background-image: url(/recruit/img/char_title_recruit.svg);
}

/*================*/
.box-ttl h3 {
    position: relative;
}
.box-ttl h3 span {
    display: block;
}
.box-ttl h3 span.main {
    font-size: 6.7vw;
    font-weight: 400;
    letter-spacing: 0.08em;
}
.box-ttl h3 span.sub {
    margin: 1.67vw 0 0 0;
}
.box-ttl.new h3 span.sub {
    width: 34.13vw;
}
.box-ttl h3 span.sub {
    width: 47.73vw;
}
.box-ttl.new h3 span.sub {
    aspect-ratio: 192/16;
}
.box-ttl.new h3 span.sub b {
    background-image: url(/recruit/img/char_title_new.svg);
}
.box-ttl.experienced h3 span.sub {
    aspect-ratio: 268/16;
}
.box-ttl.experienced h3 span.sub b {
    background-image: url(/recruit/img/char_title_experienced.svg);
}
.box-ttl h3 i.line {
    display: none;
}
/*----*/
.structure-container{
    width: 90vw;
}
.requirementCategory{
    padding-top: 12vw;
}
.requirementCategory-info{
    padding: 7vw 0 6vw 0;
}
.requirementCategory-info p{
    font-size: 5.07vw;
    line-height: 1.58;
    letter-spacing: 0.03em;
}
.requirementCategory-info p.ymd {
    color: #A9A9A9;
    font-weight: 700;
}
.requirementCategory-info p.txt {
}
/*----*/
.requirementCategory-toDetail{
    margin-top: 8.86vw;
}
.requirementCategory-items{
    display: flex;
    flex-direction: column;
    row-gap: 5.33vw;
}
.requirementCategory-item{
    width: 100%;
}
.guideline a{
    display: flex;
}
.guideline-caption{
    padding: 2.67vw 5.33vw;
    width: 67.35%;
    background-color: var(--main-color);
}
.guideline-caption .text-ja{
    font-size: 4.27vw;
    font-weight: 700;
    color: #fff;
}
.guideline-caption .text-en{
    display: block;
    margin-top: 2.13vw;
    font-size: 3.2vw;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.6);
}
.guideline-img{
    width: 32.65%;
}
.requirementCategory-item{
    position: relative;
}
.requirementCategory-item i{
    position: absolute;
    left: 5.33vw;
    bottom: 6.13vw;
    width: 12vw;
    aspect-ratio: 60 / 20;
    overflow: hidden;
}
.requirementCategory-item i b{
    position: absolute;
    top: 0;
    left: -30%;
    width: 100%;
    height: 100%;
}
.requirementCategory-item i b > svg{
    stroke: #fff;
    stroke-width: 1.2;
}
/*================*/
.corporate-profile{
    display: flex;
    flex-direction: column;
    row-gap: 2.4vw;
    padding-top: 5.33vw;
}
.corporate-profile .border-button.bb-type1 p{
    padding-top: 2.67vw;
    padding-left: 9.07vw;
    text-align: left;
    text-indent: 0;
}
.border-button p span.corporate-profile-ttl{
    position: relative;
    width: 44vw;
    font-size: 4.27vw;
    line-height: 1.75;
    letter-spacing: 0;
    font-weight: 700;
    color: var(--main-color);
}
.border-button p span.corporate-profile-ttl-en{
    display: block;
    margin-top: 0.8vw;
    font-size: 3.2vw;
    font-weight: 700;
    color: #B6B6B6;
}
.border-button p span.corporate-profile-ttl:after{
    content: '';
    position: absolute;
    top: 1.8vw;
    right: -7.87vw;
    display: block;
    width: 5.07vw;
    height: 5.07vw;
    background: url(/common/img/ico_pdf_red.png) no-repeat center;
    background-size: contain;
}
.corporate-profile .border-button.bb-type1{
    width: 100%;
    height: 20.27vw;
}
.corporate-profile .border-button.bb-type1 p i{
    top: 7.47vw;
}
/*================*/
.structure .structure-container.full{
    margin: 0;
    width: 100vw;
}
.contact{
    position: relative;
    margin-top: 12.53vw;
    height: 71.2vw;
    background: url(/recruit/img/bg_contact.png) no-repeat top  left 83%;
    background-size: cover;
}
.contact-inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.contact-ttl{
    font-size: 5.33vw;
    text-align: center;
    line-height: 1.6;
    font-weight: 500;
    color: #fff;
}
.contact-info{
    margin-top: 2.67vw;
    text-align: center;
}
.contact-info-tel{
    font-size: 8.53vw;
    font-weight: 500;
    color: #fff;
}
.contact-info-receptiontime{
    margin-top: 2.67vw;
    font-size: 3.73vw;
    font-weight: 700;
    color: #fff;
}
.contact-mailto.bb-type3{
    margin-top: 3.2vw;
    width: 89.33vw;
}
.contact-mailto.bb-type3 a{
    position: relative;
    display: block;
    /* border-radius: 40px; */
}
.contact-mailto.bb-type3 p:before {
    content: '';
    display: block;
    position: absolute;
    top: 52%;
    left: 5.07vw;
    transform: translateY(-50%);
    width: 5.87vw;
    height: 4vw;
    background: url(/common/img/ico_mail_white.png) no-repeat center;
    background-size: contain;
}
.contact-mailto.bb-type3 p span{
    font-size: 4.27vw;
    font-weight: 500;
}

/*````````````````````````````````````````*/
} /* end of @media */
/*````````````````````````````````````````*/

