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

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

.visual .txtArea{
    position: absolute;
    top: calc(10vw + 80px);
    left: 7.33vw;
}

.visual h1{
    font-size: 3.07267vw;
    font-weight: bold;
    color: #fff;
    line-height: 1.545;
    margin-bottom: 3.33vw;
}

.visual p{
    font-weight: 500;
    line-height: 1;
    color: #fff;
}

.visual p .position{
    font-size: 1.2vw;
    display: block;
    margin-bottom: 1.067vw;
}

.visual p .name{
    font-size: 3.0vw;
    margin-right: 1.33vw;
}

.visual p .en{
    font-size: 1.533vw;
}

.visual img{
    width: 100%;
}

.profile{
    width: 100%;
    max-width: 1132px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    padding: 82px 40px 135px;
}

.profile .imgArea{
    width: 19.1696%;
}

.profile .txtArea{
    width: 77.7385%;
}

.profile .txtArea h2{
    font-size: 3.1rem;
    font-weight: 500;
    line-height: 1;
    display: flex;
    align-items: baseline;
    margin-bottom: 30px;
}

.profile .txtArea h2 .en{
    font-size: 2.5rem;
    margin-left: 40px;
}

.profile .txtArea p{
    font-size: 1.8rem;
    line-height: 2.056;
    padding-right: 20px;
}

.background{
    width: 100%;
    max-width: 1500px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.background .imgArea{
    width: 50%;
}

.background .txtArea{
    width: 40%;
    margin-right: 3.33%;
    position: relative;
    padding-top: 36px;
}

.background .txtArea::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, #509cd5 0%, #a2cb3c 100%);
}

.background .txtArea h3{
    font-size: 3.6rem;
    font-weight: 500;
    line-height: 1;
    color: #3c88c1;
}

.background .txtArea h3 strong{
    font-size: 5.8rem;
    font-weight: 500;
    margin-right: 26px;
}

.background .txtArea h4{
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 1.5;
    margin-top: 118px;
    letter-spacing: 0.16em;
}

.background .txtArea p{
    font-size: 1.7rem;
    line-height: 1.9647;
    margin-top: 60px;
    letter-spacing: 0.07em;
}

.background > img{
    margin: 115px auto 0;
}

.workstyle{
    width: 100%;
    max-width: 1500px;
    padding-top: 128px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
}

.workstyle .imgArea{
    width: 43.33%;
}

.workstyle .txtArea{
    width: 50.67%;
    position: relative;
    padding: 65px 0 0 15.79%;
}

.workstyle .txtArea::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% - 167px);
    height: 1px;
    background: linear-gradient(90deg, #509cd5 0%, #a2cb3c 100%);
}

.workstyle .txtArea h3{
    font-size: 3.6rem;
    font-weight: 500;
    line-height: 1;
    color: #3c88c1;
}

.workstyle .txtArea h3 strong{
    font-size: 5.8rem;
    font-weight: 500;
    margin-right: 26px;
}

.workstyle .txtArea h4{
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 1.5;
    margin-top: 55px;
    letter-spacing: 0.16em;
}

.workstyle .txtArea p{
    font-size: 1.7rem;
    line-height: 1.9647;
    margin-top: 60px;
    letter-spacing: 0.07em;
}

.satisfying{
    width: 100%;
    max-width: 1500px;
    padding-top: 242px;
    margin: 0 auto;
    display: flex;
    align-items: center;
}

.satisfying .imgArea{
    width: 47.867%;
    margin-right: 4%;
}

.satisfying .txtArea{
    width: 36.67%;
    position: relative;
    padding-top: 40px;
}

.satisfying .txtArea::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, #509cd5 0%, #a2cb3c 100%);
}

.satisfying .txtArea h3{
    font-size: 3.6rem;
    font-weight: 500;
    line-height: 1;
    color: #3c88c1;
}

.satisfying .txtArea h3 strong{
    font-size: 5.8rem;
    font-weight: 500;
    margin-right: 26px;
}

.satisfying .txtArea h4{
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 1.5;
    margin-top: 55px;
    letter-spacing: 0.16em;
}

.satisfying .txtArea p{
    font-size: 1.7rem;
    line-height: 1.9647;
    margin-top: 60px;
    letter-spacing: 0.07em;
}

.link{
    width: 100%;
    padding: 166px 40px 0;
}

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

.link ul li{
    width: calc((100% - 83px) / 3);
    border: 2px solid #3990cf;
    padding-top: 30px;
}

.link ul li a{
    display: flex;
    flex-direction: column;
    height: 100%;
    position: relative;
}

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

.link ul li h3{
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.545;
    color: #3990cf;
    margin: 0 30px 65px;
}

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

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

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

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



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

.visual{
    padding-top: 15.625vw;
    position: relative;
}

.visual .txtArea{
    position: static;
    top: auto;
    left: auto;
}

.visual h1{
    font-size: 6vw;
    margin-bottom: 0;
    position: absolute;
    top: 26.6927vw;
    left: 5.2vw;
}

.visual p{
    position: absolute;
    bottom: 11.71875vw;
    left: 5.2vw;
}

.visual p .position{
    font-size: 3.125vw;
    margin-bottom: 1.8229167vw;
}

.visual p .name{
    font-size: 4.296875vw;
    margin: 0 0 4.167vw;
    display: block;
}

.visual p .en{
    font-size: 4.03645833vw;
}

.profile{
    padding: 13vw 5.2vw 11.71875vw;
}

.profile .imgArea{
    width: 28.2552vw;
}

.profile .txtArea{
    width: 57.6823vw;
}

.profile .txtArea h2{
    font-size: 5.078125vw;
    margin-bottom: 3.90625vw;
}

.profile .txtArea h2 .en{
    font-size: 3.90625vw;
    margin-left: 2.604167vw;
}

.profile .txtArea p{
    font-size: 2.734375vw;
    padding-right: 0;
}

.background{
    flex-direction: column;
}

.background .imgArea{
    width: 77.8645833vw;
    order: 2;
    margin-top: 13.54167vw;
}

.background .txtArea{
    width: 89.5833vw;
    margin: 0 auto;
    padding-top: 6.25vw;
    order: 1;
}

.background .txtArea h3{
    font-size: 5.20833vw;
}

.background .txtArea h3 strong{
    font-size: 9.765625vw;
    margin-right: 3.2552vw;
}

.background .txtArea h4{
    font-size: 4.55729167vw;
    margin-top: 11.71875vw;
}

.background .txtArea p{
    font-size: 3.2552vw;
    margin-top: 13.671875vw;
}

.background > img{
    margin: 17.70833vw auto 0;
    order: 3;
}

.workstyle{
    padding-top: 10.677vw;
    flex-direction: column-reverse;
}

.workstyle .imgArea{
    width: 72.395833vw;
    margin: 18.4895833vw 0 0 auto;
}

.workstyle .txtArea{
    width: 89.5833vw;
    padding: 5.9895833vw 0 0;
    margin: 0 auto;
}

.workstyle .txtArea::before{
    width: 100%;
}

.workstyle .txtArea h3{
    font-size: 5.20833vw;
}

.workstyle .txtArea h3 strong{
    font-size: 9.765625vw;
    margin-right: 3.2552vw;
}

.workstyle .txtArea h4{
    font-size: 4.55729167vw;
    margin-top: 11.71875vw;
}

.workstyle .txtArea p{
    font-size: 3.2552vw;
    margin-top: 13.671875vw;
}

.satisfying{
    padding-top: 16.9270833vw;
    flex-direction: column-reverse;
    align-items: flex-start;
}

.satisfying .imgArea{
    width: 77.8645833vw;
    margin: 17.1875vw 0 0;
}

.satisfying .txtArea{
    width: 89.5833vw;
    margin: 0 auto;
    padding-top: 5.9895833vw;
}

.satisfying .txtArea h3{
    font-size: 5.20833vw;
}

.satisfying .txtArea h3 strong{
    font-size: 9.765625vw;
    margin-right: 3.2552vw;
}

.satisfying .txtArea h4{
    font-size: 4.55729167vw;
    margin-top: 11.71875vw;
}

.satisfying .txtArea p{
    font-size: 3.2552vw;
    margin-top: 13.671875vw;
}

.link{
    padding: 20.3125vw 0 0;
}

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

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

.link ul li{
    width: 59.6354167vw;
    border: 0.26vw solid #3990cf;
    padding-top: 4.4270833vw;
}

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

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

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

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

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

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

}