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

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

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

.visual h1{
    font-size: 2.4vw;
    font-weight: bold;
    line-height: 1.545;
    margin-bottom: 2vw;
}

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

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

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

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

.visual img{
    width: 100%;
}

.profile{
    width: 100%;
    padding: 82px 40px 135px;
}

.murata .profile{
    background: #3b7e9b;
}

.takemae .profile{
    background: #5cb2af;
}

.nakagawa .profile{
    background: #ddb06f;
}

.profile .wrap{
    width: 100%;
    max-width: 1132px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: row-reverse;
}

.profile .imgArea{
    width: 14.2857143%;
}

.profile .txtArea{
    width: 80.893%;
}

.profile .txtArea h2{
    font-size: 3.0rem;
    font-weight: 500;
    line-height: 1;
    color: #fff;
    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;
    color: #fff;
    letter-spacing: 0.09em;
}

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

.background .imgArea{
    width: 50%;
}

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

.background .txtArea h3{
    font-size: 2.5rem;
    font-weight: 500;
    line-height: 1;
    display: flex;
    align-items: center;
}

.murata .background .txtArea h3{
    color: #3b7e9b;
}

.takemae .background .txtArea h3{
    color: #5cb2af;
}

.nakagawa .background .txtArea h3{
    color: #ddb06f;
}

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

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

.murata .background .txtArea h4{
    color: #3b7e9b;
}

.takemae .background .txtArea h4{
    color: #5cb2af;
}

.nakagawa .background .txtArea h4{
    color: #ddb06f;
}

.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: 1360px;
    padding: 194px 40px 0;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.workstyle h3{
    font-size: 2.5rem;
    font-weight: 500;
    line-height: 1;
    width: 100%;
    display: flex;
    align-items: center;
    margin-bottom: 32px;
}

.murata .workstyle h3{
    color: #3b7e9b;
}

.takemae .workstyle h3{
    color: #5cb2af;
}

.nakagawa .workstyle h3{
    color: #ddb06f;
}

.workstyle h3 strong{
    font-size: 5.0rem;
    font-weight: bold;
    margin-right: 26px;
}

.workstyle .imgArea{
    width: 39.375%;
}

.workstyle .txtArea{
    width: 50.46875%;
    margin-right: 1.5625%;
}

.workstyle .txtArea h4{
    font-size: 3.0rem;
    font-weight: bold;
    line-height: 1.7;
    letter-spacing: 0.16em;
    margin-top: -0.5em;
}

.murata .workstyle .txtArea h4{
    color: #3b7e9b;
}

.takemae .workstyle .txtArea h4{
    color: #5cb2af;
}

.nakagawa .workstyle .txtArea h4{
    color: #ddb06f;
}

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

.satisfying{
    width: 100%;
    margin-top: 136px;
}

.satisfying .wrap{
    width: 100%;
    max-width: 1500px;
    margin: 0 auto;
    display: flex;
    flex-direction: row-reverse;
}

.murata .satisfying{
    background: #3b7e9b;
}

.takemae .satisfying{
    background: #5cb2af;
}

.nakagawa .satisfying{
    background: #ddb06f;
}

.satisfying .imgArea{
    width: 50%;
}

.satisfying .txtArea{
    width: 50%;
    padding: 146px 3.67% 160px 9.33%;
}

.satisfying .txtArea h3{
    font-size: 2.5rem;
    font-weight: 500;
    line-height: 1;
    color: #fff;
    display: flex;
    align-items: center;
}

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

.satisfying .txtArea h4{
    font-size: 3.0rem;
    font-weight: bold;
    color: #fff;
    line-height: 1.7;
    margin-top: 55px;
    letter-spacing: 0.16em;
}

.satisfying .txtArea p{
    font-size: 1.7rem;
    line-height: 1.9647;
    color: #fff;
    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: 1280px;
    margin: 0 auto;
    gap: calc(83px / 2);
}

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

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

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

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

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

.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;
    margin: 0 30px 65px;
}

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

.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: 23vw;
    left: 5.2vw;
}

.visual p{
    position: absolute;
    bottom: 8vw;
    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;
    display: block;
}

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

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

.background{
    flex-direction: column;
    padding-top: 15.1vw;
}

.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: 16.677vw 0 0;
    flex-direction: column-reverse;
}

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

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

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

.workstyle h3{
    font-size: 5.20833vw;
    order: 1;
    width: 89.5833vw;
    margin: 0 auto;
}

.workstyle 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{
    margin-top: 17.70833vw;
}

.satisfying .wrap{
    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: 0;
}

.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: 201.5629101vw;
    max-width: inherit;
    padding: 0 5.20833vw;
    gap: 6.12vw;
}

.link ul li{
    width: 59.6354167vw;
    border-radius: 2.67vw;
}

.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 5.729167vw;
}

.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;
}

}