@charset "UTF-8";
/* =====================================
	index
===================================== */

.visual{
    position: relative;
    padding-top: 80px;
}

.visual h1{
    position: absolute;
    bottom: 7vw;
    left: 5.33vw;
    line-height: 1;
    letter-spacing: 0;
}

.visual h1 span{
    display: table;
    background: #fff;
    padding: 0.4vw 0.67vw 0.67vw;
    font-size: 3.867vw;
    font-weight: 500;
    margin-top: 0.933vw;
}

.visual h1 small{
    display: inline-block;
    background: #fff;
    padding: 0.67vw;
    font-size: 1.448vw;
    font-weight: bold;
    margin-top: 1.6vw;
}

.visual img{    
    width: 100%;
}

.about{
    width: 100%;
    max-width: 1300px;
    padding: 190px 40px 158px;
    margin: 0 auto;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
}

.about .imgArea{
    width: 45.082%;
}

.about .txtArea{
    width: 50%;
}

.about .txtArea h2{
    color: #3b7e9b;
    font-size: 2.0rem;
    line-height: 1;
    font-weight: bold;
    margin-bottom: 48px;
}

.about .txtArea h2 span{
    display: block;
    font-size: 9.0rem;
    margin-bottom: 10px;
}

.about .txtArea h3{
    color: #d41e18;
    font-size: 2.6rem;
    line-height: 1;
    font-weight: bold;
    margin-bottom: 32px;
}

.about .txtArea p{
    font-size: 1.6rem;
    line-height: 2.0875;
    font-weight: 500;
    margin-bottom: 36px;
}

.workstyle{
    width: 100%;
    background: url("../img/index/bg01.png") center;
    background-size: cover;
    padding: 100px 40px 158px;
}

.workstyle .ttlArea{
    width: 100%;
    max-width: 1290px;
    margin: 0 auto 58px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.workstyle .ttlArea h2{
    color: #fff;
    font-size: 2.0rem;
    line-height: 1;
    font-weight: bold;
}

.workstyle .ttlArea h2 span{
    display: block;
    font-size: 9.0rem;
    margin-bottom: 10px;
}

.workstyle img{
    margin: 0 auto;
}

.interview{
    width: 100%;
    padding: 120px 40px 0;
}

.interview .ttlArea{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto 58px;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}

.interview .ttlArea h2{
    color: #7dd8c3;
    font-size: 2.0rem;
    line-height: 1;
    font-weight: bold;
}

.interview .ttlArea h2 span{
    display: block;
    font-size: 9.0rem;
    margin-bottom: 10px;
}

.interview ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    gap: calc(83px / 2);
}

.interview ul li{
    width: calc((100% - 83px) / 3);
    border-radius: 20px;
    overflow: hidden;
}

.interview ul li a{
    padding-top: 32px;
    display: flex;
    flex-direction: column;
    height: 100%;
    position: relative;
    color: #fff;
}

.interview ul li:nth-child(1) a{
    background: #3b7e9b;
}

.interview ul li:nth-child(2) a{
    background: #5cb2af;
}

.interview ul li:nth-child(3) a{
    background: #ddb06f;
}

.interview ul li a::before{
    content: "";
    position: absolute;
    bottom: 17px;
    right: 17px;
    background: url("../img/common/icon02.svg");
    background-size: contain;
    width: 38px;
    height: 38px;
}

.interview ul li h3{
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.545;
    margin: 0 30px 65px;
}

.interview ul li p{
    font-size: 3.5rem;
    font-weight: 500;
    line-height: 1;
    margin: 0 30px 44px;
}

.interview ul li p .position{
    font-size: 1.8rem;
    margin-bottom: 20px;
    display: block;
}

.interview ul li p .en{
    font-size: 2.5rem;
    font-weight: normal;
    margin-top: 14px;
    display: block;
}

.interview ul li img{
    margin-top: auto;
}

section.position{
    width: 100%;
    padding: 136px 40px 0;
}

section.position h2{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto 58px;
    color: #3b7e9b;
    font-size: 2.0rem;
    line-height: 1;
    font-weight: bold;
}

section.position h2 span{
    display: block;
    font-size: 9.0rem;
    margin-bottom: 10px;
}

section.position ul{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

section.position ul li{
    width: 49.6875%;
    border-radius: 20px;
    overflow: hidden;
}

section.position ul li a{
    font-size: 2.0rem;
    line-height: 1;
    font-weight: bold;
    color: #fff;
    display: block;
}

section.position ul li:nth-child(1) a{
    background: #5cb2af;
}

section.position ul li:nth-child(2) a{
    background: #f76e6e;
}

section.position ul li a span{
    background: url("../img/common/icon02.svg") center left 16px no-repeat;
    padding: 26px 0 26px 72px;
    display: block;
}




@media screen and (max-width: 768px) {

.visual{
    padding-top: 15.625vw;
}

.visual h1{
    bottom: 4.5573vw;
    left: 4.948vw;
}

.visual h1 span{
    padding: 1.7vw 1.953125vw 1.953125vw;
    font-size: 6.25vw;
    margin-top: 1.953125vw;
}

.visual h1 small{
    padding: 1.953125vw;
    font-size: 2.34vw;
    margin-top: 3.2552vw;
}

.about{
    padding: 14.0625vw 5.20833vw 13.28125vw;
    flex-direction: column-reverse;
    align-items: flex-start;
}

.about .imgArea{
    width: 100%;
}

.about .imgArea img{
    width: 81.38020833vw;
    margin: 0 0 2.9948vw auto;
}

.about .imgArea a{
    margin: 0 0 0 auto;
    display: table !important;
}

.about .txtArea{
    width: 100%;
    
}

.about .txtArea h2{
    font-size: 3.2552vw;
    margin-bottom: 8.854167vw;
}

.about .txtArea h2 span{
    font-size: 11.71875vw;
    margin-bottom: 2vw;
}

.about .txtArea h3{
    font-size: 4.9479167vw;
    margin-bottom: 4.167vw;
}

.about .txtArea p{
    font-size: 3.3854167vw;
    line-height: 1.5077;
    margin-bottom: 15.625vw
}

.workstyle{
    background: url("../img/index/sp/bg01.png");
    background-size: 100% auto;
    padding: 11.198vw 4.55729vw 9.895833vw;
    position: relative;
}

.workstyle .ttlArea{
    margin: 0 auto 7.8125vw;
}

.workstyle .ttlArea h2{
    font-size: 3.2552vw;
}

.workstyle .ttlArea h2 span{
    font-size: 11.71875vw;
    margin-bottom: 2vw;
}

.workstyle > a{
    /*margin: 9.5vw 0 0 auto;*/
    display: table !important;
    position: absolute;
    bottom: 26.8vw;
    right: 8vw;
}

.interview{
    padding: 18.229167vw 0 0;
}

.interview .ttlArea{
    margin: 0 5.20833vw 13.8020833vw;
}

.interview .ttlArea h2{
    font-size: 3.2552vw;
}

.interview .ttlArea h2 span{
    font-size: 11.71875vw;
    margin-bottom: 2vw;
}

.interview .wrap{
    width: 100%;
    overflow-x: scroll;
}

.interview ul{
    width: 201.5629101vw;
    max-width: inherit;
    padding: 0 5.20833vw;
    gap: 6.12vw;
}

.interview ul li{
    width: 59.6354167vw;
}

.interview ul li a::before{
    bottom: 2.21354167vw;
    right: 2.21354167vw;
    width: 5.6vw;
    height: 5.6vw;
}

.interview ul li h3{
    font-size: 3.29427vw;
    margin: 0 3.90625vw 9.765625vw;
}

.interview ul li p{
    font-size: 5.24088vw;
    margin: 0 3.90625vw 7.552vw;
}

.interview ul li p .position{
    font-size: 2.6953125vw;
    margin-bottom: 3.645833vw;
}

.interview ul li p .en{
    font-size: 3.7434895833vw;
    margin-top: 2.34375vw;
}

.interview > a{
    margin: 9.5vw 5.20833vw 0 auto;
    display: table !important;
}

section.position{
    padding: 26.5625vw 5.20833vw 0;
}

section.position h2{
    font-size: 3.2552vw;
    margin-bottom: 10.9375vw;
}

section.position h2 span{
    font-size: 11.71875vw;
    margin-bottom: 2vw;
}

section.position ul{
    flex-wrap: wrap;
    gap: 3.90625vw;
}

section.position ul li{
    width: 100%;
    border-radius: 2.604167vw;
}

section.position ul li a{
    font-size: 2.845vw;
}

section.position ul li a span{
    background: url("../img/common/icon02.svg") center left 2.474vw no-repeat;
    background-size: 5.46875vw auto;
    padding: 3.3854167vw 0 3.3854167vw 10.4167vw;
}

}