@charset "utf-8";

/* topBg */
.topBg{
    margin-top: 169px;
    position: relative;
    min-height: 600px;
}
.topBg .bgBox{
    position: absolute;
    top: 0;
    left: calc(50% - 960px);
}
.secCmnTit {
    padding-top: 0;
}
.secCmnTit .tit {
    letter-spacing: 10px;
    margin-right: -13px;
    margin-top: -50px;
    z-index: 10;
}
.secCmnTit .txt {
    font-weight: bold;
}
.secCmnTit .spanTit::before{
    position: absolute;
    content: "";
    width: 53px;
    height: 42px;
    left: -18px;
    top: 10px;
}
.secCmnTit .spanTit.lazyloaded::before{
   background: url(../img/index/iconTit02.png) center top / cover;
}

@media only screen and (max-width:767px){
    .topBg{
        margin-top: 73px;
        min-height:auto;
    }
    .topBg .bgBox{
        position: static;
    }
    .secCmnTit .tit {
        margin-top: 36px;
        margin-right: 0;
        letter-spacing: 3.5px;
    }
    .secCmnTit .spanTit::before{
        width: 20px;
        height: 17px;
        left: -10px;
        top: 0px;
    }
    .secCmnTit .spanTit.lazyloaded::before{
       background: url(../img/index/iconTit02_sp.png) center top / cover;
    }
    .secCmnTit .txt {
        letter-spacing: 2.5px;
    }
}


/* secLink */
.secLink{
    margin-top: 230px;
    position: relative;
}
.secLink .titBox{
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 76px 0 98px;
}
.secLink .tit{
    font-size: 28px;
    font-weight: bold;
    color: #1f85ba;
    letter-spacing: 3px;
}
.secLink .spanTit{
    position: relative;
    height: 28px;
    display: block;
}
.secLink .spanTit::before,
.secLink .spanTit::after{
    position: absolute;
    content: "";
    width:30px ;
    height: 1px;
    top: 13px;
    background: #1f85ba;
}
.secLink .spanTit.right::before,
.secLink .spanTit.right::after{
    background: #16c45c;
}
.secLink .spanTit::before{
    left: -48px;
}
.secLink .spanTit::after{
    right: -46px;
}
.secLink .wrapper{
    width: 1290px;
    margin: 0 auto;
    max-width: calc(100% - 40px);
}
.secLink .list{
    display: flex;
    justify-content: space-between;
    margin-top: 78px;
    position: relative;
}
.secLink .list::before,
.secLink .list::after{
    position: absolute;
    content: "";
    width: 800px;
    height: 800px;
    border-radius: 50%;
    opacity: 0.051;
    top: calc(50% - 380px);
}
.secLink .list::before{
    background-color: rgb(31, 133, 186);
    left: -105px;
}
.secLink .list::after{
    background-color: rgb(22, 196, 92);
    right: -105px;
}
.secLink .item{
    width: 410px;
    height: 160px;
}
.secLink .inner{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    text-decoration: none;
    font-size: 24px;
    color: #1f85ba;
    border-radius: 5px;
    letter-spacing: 3px;
    box-shadow: 0px 0px 20px 5px rgba(0, 0, 0, 0.05);
    position: relative;
    z-index: 1;
    background: #fff;
}
.secLink .item:nth-child(2) .inner{
    color: #0ac8ba;
}
.secLink .item:nth-child(3) .inner{
    color: #16c45c;
}
.secLink .spanNumber{
    font-size: 22px;
    margin-right: 10px;
    color: rgba(31, 133, 186, 0.4);
}
.secLink .item:nth-child(2) .spanNumber{
    color: rgba(10, 200, 186, 0.4);
}
.secLink .item:nth-child(3) .spanNumber{
    color: rgba(22, 196, 92, 0.4);
}

/* 240730追記 */
.secLink .boxGroup{
    width: 310px;
    height: 80px;
    border: solid 1px #222;
    margin: 80px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    border-radius: 5px;
    z-index: 10;
    position: relative;
}
.secLink .boxGroup::after{
    position: absolute;
    content: "";
    width: 880px;
    height: 80px;
    left: calc(50% - 440px);
    top: -81px;
}
.secLink .boxGroup.lazyloaded::after{
    background: url(../img/service/imgBoxGroup.png) center top no-repeat;
}
@media only screen and (max-width:767px){
    .secLink{
        margin-top: 88px;
    }
    .secLink .titBox{
        display: block;
        padding: 0;
    }
    .secLink .tit{
        font-size: 18px;
       text-align: center;
        letter-spacing: 1px;
    }
    .secLink .titEng{
        width: 139px;
        margin: 0 auto;
    }
    .secLink .spanTit{
        height: 17px;
        display: inline-block;
    }
    .secLink .spanTit::before,
    .secLink .spanTit::after{
        width:20px ;
        top: 7.5px;
    }
    .secLink .spanTit::before{
        left: -29px;
    }
    .secLink .spanTit::after{
        right: -28px;
    }
    .secLink .wrapper{
        width: 100%;
        margin: 0 auto;
        max-width: none;
    }
    .secLink .list{
        display: block;
        margin-top: 0px;
       padding: 50px 0;
    }
    .secLink .list::before,
    .secLink .list::after{
        width: 335px;
        height:335px;
    }
    .secLink .list::before{
        left: calc(50% - 167.5px);
        top: calc(50% - 290px);
    }
    .secLink .list::after{
        right:unset;
        left: calc(50% - 167.5px);
        top: calc(50% - 50px);
    }
    .secLink .item{
        width: 265px;
        height: 74px;
        margin: 0 auto;
    }
    .secLink .item:nth-child(n+2){
        margin-top: 20px;
    }
    .secLink .inner{
        font-size: 16px;
        letter-spacing: 3px;
    }
    .secLink .spanNumber{
        font-size: 15px;
        margin-right: 0px;
    }
    /* 240730追記 */
    .secLink .boxGroup{
        width: 165px;
        height: 46px;
        margin: 132px auto 0;
    }
    .secLink .boxGroup img{
        height: 11px;
        width: auto;
    }
    .secLink .boxGroup::before{
        position: absolute;
        content: "";
        width: 89.334vw;
        max-width: 335px;
        height: 40px;
        border: solid 1px #ccc;
        border-top: none;
        top: -60px;
    }
    .secLink .boxGroup::after{
        width: 1px;
        height: 20px;
        left: calc(50% - 0.5px);
        top: -21px;
        background: #ccc;
    }
    .secLink .boxGroup.lazyloaded::after{
        background: #ccc;
    }
}
@media only screen and (max-width:360px){
    .secLink .list::before,
    .secLink .list::after{
        width: 300px;
        height:300px;
    }
    .secLink .list::before{
        left: calc(50% - 150px);
    }
    .secLink .list::after{
        left: calc(50% - 150px);
    }
}

/* secList */
.secList{
    margin-top: 395px;
}
.secList .item{
    position: relative;
    background: #f4f9fb;
    z-index: 10;
}
.secList .item:nth-child(1){
    padding-bottom: 10px;
}
.secList .item:nth-child(2){
    background: #f3fcfb;
}
.secList .item:nth-child(3){
    background: #f3fcfb;
}
.secList .item:nth-child(n+2){
    /* margin-top: 205px; */
    padding-top: 205px;
}
.secList .item:nth-child(1)::before{
    position: absolute;
    content: "";
    width: 100%;
    height: 300px;
    left: 0;
    top: -300px;
    background-image: -moz-linear-gradient( 90deg, rgb(244,249,251) 0%, rgba(244,249,251,0) 100%);
    background-image: -webkit-linear-gradient( 90deg, rgb(244,249,251) 0%, rgba(244,249,251,0) 100%);
    background-image: -ms-linear-gradient( 90deg, rgb(244,249,251) 0%, rgba(244,249,251,0) 100%);
    z-index: -1;
}
.secList .item:nth-child(2)::before{
    position: absolute;
    content: "";
    width: 100%;
    height: 300px;
    left: 0;
    top: -205px;
    top: 0;
    z-index: -1;
}
.secList .item:nth-child(2).lazyloaded::before{
    background:url(../img/service/iconItem01.gif) center top / cover ;
}
.secList .item:nth-child(3)::before{
    position: absolute;
    content: "";
    width: 100%;
    height: 300px;
    left: 0;
    top: -205px;
    top: 0;
    z-index: -1;
}
.secList .item:nth-child(3).lazyloaded::before{
    background:url(../img/service/iconItem02.gif) center top / cover ;
}
.secList .item:nth-child(3)::after{
    position: absolute;
    content: "";
    width: 100%;
    height: 300px;
    left: 0;
    bottom: -300px;
    z-index: 1;
}
.secList .item:nth-child(3).lazyloaded::after{
    background:url(../img/service/iconItem03.gif) center top / cover ;
}
.secList .titBox{
    display: flex;
    align-items: center;
    margin-left: -7px;
}
.secList .number{
    font-size: 100px;
    color: rgba(31, 133, 186, 0.4);
    letter-spacing: 10px;
}
.secList .item:nth-child(2) .number{
    color: rgba(10, 200, 186, 0.4);
}
.secList .item:nth-child(3) .number{
    color: rgba(22, 196, 92, 0.4);
}
.secList .boxTit{
    font-size: 38px;
    font-weight: bold;
    margin-left: 16px;
    letter-spacing: 9px;
    margin-top: 5px;
}
.secList .flexBox{
    position: relative;
    min-height: 680px;
    display: flex;
    align-items: flex-start;
    margin-top: 74px;
}
.secList .flexBox.centerBox{
    align-items: center;
}
.secList .flexBox.box02{
    flex-direction: row-reverse;
    margin-top: 120px;
}
.secList .txtBox{
    background: #fff;
    box-shadow: 0px 0px 4.85px 0.15px rgba(0, 0, 0, 0.2);
    width: 800px;
    padding: 60px 85px 54px 60px;
    position: relative;
    z-index: 1;
    margin-top: 70px;
}
.secList .flexBox.centerBox .txtBox{
    margin-top: 0;
}
.secList .iconBox{
    display: flex;
    align-items: center;
}
.secList .icon{
    font-size: 13px;
    font-weight: bold;
    background: #1f85ba;
    width: 100px;
    height: 34px;
    border-radius: 17px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    margin-right: 10px;
}
.secList .icon.eng{
    width: 112px;
    background: #16c45c;
}
.secList .tit{
    font-size: 28px;
    font-weight: bold;
    margin-top: 15px;
    letter-spacing: 3.5px;
}
.secList .iconBox + .tit{
    margin-top: 35px;
}
.secList .spanTit{
    position: relative;
}
.secList .spanTit::before{
    position: absolute;
    content: "";
    width: 27px;
    height: 21px;
    left: -10px;
    top: -10px;
}
.secList .spanTit.lazyloaded::before{
    background: url(../img/service/iconTit01.png) center top / cover;
}
.secList .item:nth-child(2) .spanTit.lazyloaded::before{
    background: url(../img/service/iconTit02.png) center top / cover;
}
.secList .item:nth-child(3) .spanTit.lazyloaded::before{
    background: url(../img/service/iconTit03.png) center top / cover;
}
.secList .txt{
    font-size: 16px;
    line-height: 2.25;
    margin-top: 17px;
}
.secList .rightImg{
    position: absolute;
    content: "";
    top: 0;
    right: calc(50% - 960px);
}
.secList .flexBox.box02 .rightImg{
    right: unset;
    left: calc(50% - 960px);
}
@media only screen and (max-width:767px){
    .secList{
        margin-top:48px;
    }
    .secList .item{
        padding-bottom: 5px;
    }
    .secList .item:nth-child(n+2){
        /* margin-top: 50px; */
        padding-top: 50px;
    }
    .secList .item:nth-child(1)::before{
        height: 21.335vw;
        left: 0;
        top: -80px;
    }
    .secList .item:nth-child(2)::before{
        height: 21.335vw;
        top: -53px;
        top: 0;
    }
    .secList .item:nth-child(2).lazyloaded::before{
        background:url(../img/service/iconItem01_sp.gif) center top / cover ;
    }
    .secList .item:nth-child(3)::before{
        height: 21.335vw;
        top: -53px;
        top: 0;
    }
    .secList .item:nth-child(3).lazyloaded::before{
        background:url(../img/service/iconItem02_sp.gif) center top / cover ;
    }
    .secList .item:nth-child(3)::after{
        height: 28.8vw;
        bottom: -108px;
        z-index: -1;
    }
    .secList .item:nth-child(3).lazyloaded::after{
        background:url(../img/service/iconItem03_sp.gif) center top / cover ;
    }
    .secList .titBox{
        display: block;
        margin-left: 13px;
    }
    .secList .number{
        font-size: 30px;
        letter-spacing:3px;
    }
    .secList .boxTit{
        font-size: 18px;
        margin-left: 0px;
        letter-spacing: 2.5px;
        margin-top: 13px;
    }
    .secList .flexBox{
        min-height: auto;
        flex-direction: column-reverse;
        margin-top: 29px;
    }
    .secList .flexBox.centerBox{
        align-items: flex-start;
    }
    .secList .flexBox.box02{
        flex-direction: column-reverse;
        margin-top: 40px;
    }
    .secList .txtBox,.secList .flexBox.centerBox .txtBox{
        width: 91.045%;
        height: auto;
        padding: 20px 20px 13px;
        margin: -30px auto 0;
    }
    .secList .iconBox{
        display: flex;
        align-items: center;
    }
    .secList .icon{
        font-size: 11px;
        width: 90px;
        height: 26px;
        border-radius: 13px;
        margin-right: 5px;
    }
    .secList .icon.eng{
        width:101px;
    }
    .secList .icon img{
        width: 75px;
        height: auto;
    }
    .secList .tit{
        font-size: 16px;
        margin-top: 10px;
        letter-spacing: 0.5px;
    }
    .secList .iconBox + .tit{
        margin-top: 25px;
    }
    .secList .spanTit::before{
        width: 20px;
        height: 16px;
        left: -4px;
        top: -9px;
    }
    .secList .txt{
        font-size: 12px;
        line-height: 2.16;
        margin-top: 11px;
    }
    .secList .rightImg{
        position:static;
    }
   
}
@media only screen and (max-width:374px){
    .secList .item:nth-child(1)::before {
        top: -75px;
    }
    .secList .item:nth-child(3)::after {
        bottom: -103px;
    }
}
@media only screen and (max-width:359px){
    .secList .item:nth-child(1)::before {
        top: -65px;
    }
    .secList .item:nth-child(3)::after {
        bottom: -90px;
    }
}


.secContact .contactBox{
    position: relative;
    z-index: 10;
}
.internal .secContact {
    padding-top: 100px;
}
@media only screen and (max-width:767px){
    .secContact .contactCover::before {
       display: none;
    }
    .internal .secContact {
        padding-top: 66px;
    }
}
.secList .item:nth-child(3)::after{
    display: none;
}
/* 240731 */
.internal .secContact.lazyloaded{
    background: url(../img/index/imgbackContact.jpg) center top no-repeat #fff;
}
.secContact .contactCover.lazyloaded::before{
    display: none;
}
@media only screen and (max-width:767px){
    .internal .secContact.lazyloaded{
        background-image: url(../img/index/imgbackContact_sp.jpg);
        background-size: 100% auto;
        background-position-y: 2px;
    }
    .secContact .contactCover.lazyloaded::before{
        display: none;
    } 
}
/* ▼260202 */
.secLink .list{
    z-index: 10;
}
@media only screen and (min-width:768px){
    .secLink{
        margin-top: 70px;
    }
    .secLink .list::before,
    .secLink .list::after{
        top: calc(50% - 480px);
    }
    .secLink .titBox{
        padding-top: 153px;
    }
    .secLink .boxGroup::after{
        top: auto;
        bottom: calc(0% - 81px);
        transform: rotate(180deg);
    }
    .secLink .boxGroup{
        margin-top: 28px;
        z-index: 11;
    }
    .secList{
        margin-top: 445px;
    }
    .secLink .boxGroup.type_sp{
        display: none;
    }
}
@media only screen and (max-width:767px){
    .secLink .boxGroup.type_pc{
        display: none;
    }
    .secLink{
        margin-top: 18px;
    }
    .secLink .boxGroup{
        margin-top: 0px;
    }
    .secLink .boxGroup::after{
        top: auto;
        bottom: calc(0% - 21px);
    }
    .secLink .boxGroup::before{
        top: auto;
        bottom: calc(0% - 60px);
        transform: rotate(180deg);
    }
    .secLink .titBox{
        margin-top: 130px;
    }
    .secList{
        margin-top: 116px;
    }
}