/*TOP*/
.top .main {
    position: relative;
}
.top .main:before{
    content: '';
    position: absolute;
    top: 54px;
    left: 130px;
    width: 534px;
    height: 873px;
    background: url(/img/top/main_bg.webp) no-repeat;
}
.top .main .inner{
    position: static;
    min-height: 960px;
    padding: 0 75px;
    box-sizing: border-box;
}
.top .main h1{
    position: relative;
    padding: 220px 0 80px;
    font-size: 70px;
    font-weight: bold;
}
.top .main .img{
    position: absolute;
    top: 190px;
    right: 0;
    width: 845px;
    height: 580px;
}
.top .main .img p{
  position: absolute;
  top: 0;
  left: 0;
    width: 100%;
  height: auto;
    border-radius: 40px 0 0 40px;
    overflow: hidden;
    inset: 0;
}
.top .main .img p[data-visible="true"] {
  z-index: 2;
  clip-path: inset(0 0 0 0);
}
.top .main .img p[data-visible="false"] {
  z-index: 1;
}
.top .main .img p.is-exit {
  clip-path: inset(0 0 0 100%);
  transition: clip-path 1s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
  z-index: 3;
}
/*
@media screen and (max-width: 1700px) {
    .top .main h1{
        font-size: 4.1vw;
    }
    .top .main .img{
    width: 49.7vw;
    height: 34.1vw;
    }
}
*/

.top .main .btn {
    position: relative;
    width: 343px;
}
.top .main .btn a{
    height: 70px;
    font-size: 20px;
    font-weight: bold;
}
.top .main .scroll {
    position: absolute;
    bottom: 75px;
    left: 0;
    right: 0;
    max-width: 1516px;
    margin: 0 auto;
}
.top .main .scroll span {
    position: relative;
    top: 0;
    left: 75px;
    display: block;
    width: 130px;
    height: 130px;
    padding: 20px;
    border: 3px solid #000000;
    border-radius: 100%;
    font-size: 18px;
    font-weight: bold;
    box-sizing: border-box;
    text-align: center;
}
.top .main .scroll span:after {
    content: '';
    display: block;
    width: 39px;
    height: 39px;
    margin: 20px auto 0;
    background: url(/img/top/ico01.webp) no-repeat;
}

.top .pbox{
    margin-top: 130px;
}

.top .service .pbox{
    padding-top: 110px;
}
.top .service .img{
    position: absolute;
    top: -60px;
    right: -75px;
}
.top .service .mo{
    position: relative;
    height: 690px;
    margin: 150px 0 25px;
    padding-top: 30px;
    padding-left: 950px;
    box-sizing: border-box;
}
.top .service .mo h3{
    font-size: var(--fs28);
    font-weight: bold;
}
.top .service .mo ul{
    margin-top: 70px;
}
.top .service .mo li{
    width: 360px;
    margin-bottom: 20px;
}
.top .service .mo li a{
    height: 60px;
}
.top .service .mo .detail{
    display: none;
    position: absolute;
    top: 0;
    left: -145px;
    width: 1000px;
    height: 687px;
    border-radius: 40px;
    background: #fff;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
.top .service .mo .detail:nth-child(1){
    display: block;
}
.top .service .mo .detail .ttl{
    margin: 25px 75px 0;
    font-size: var(--fs28);
    font-weight: bold;
}
.top .service .mo .detail .txt{
    margin: 25px 75px 0;
    font-size: var(--fs18);
    font-weight: bold;
}

.pbox .started{
    position: relative;
    margin-bottom: 50px;
    padding-top: 80px;
}
.pbox .started .box{
    width: 950px;
}
.pbox .started .box p{
    font-size: var(--fs22);
    font-weight: bold;
}
.pbox .started .box p.btn{
    width: 520px;
    margin-top: 40px;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
.pbox .started .box p.btn a{
    height: 70px;
}
.pbox .started .movie{
    position: absolute;
    top: 105px;
    right: 0;
    width: 680px;
    overflow: hidden;
}
.pbox .started .movie p{
    position: relative;
    z-index: 5;
}
.pbox .started .movie p{
    opacity: 0;
    transition: opacity 0.3s ease;
}
.pbox .started .movie.act:before{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
}
#player {
    display: none;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 680px;
    height: 690px;
}
#player video{
    width: 100%;
    height: 100%;
}
.act #player {
    display: block;
}
.pbox .started .box li{
    position: relative;
    display: flex;
    align-items: center;
    min-height: 2.8em;
    margin-bottom: 54px;
    padding-left: 90px;
    font-size: var(--fs28);
    font-weight: bold;
    line-height: 1.4;
}
.pbox .started .box .num{
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
    font-size: var(--fs12);
    font-weight: bold;
    text-align: center;
}
.pbox .started .box .num span {
    font-size: 50px;
    font-weight: bold;
    line-height: 1;
}

.top .plan .ttl2{
    padding-top: 30px;
}

.top .interview {
    margin-bottom: 100px;
}
.top .interview .list{
    display: flex;
    flex-wrap: wrap;
    column-gap: 80px;
}
.top .interview .list li{
    width: 450px;
    margin-bottom: 40px;
    padding-bottom: 65px;
    background: #fff;
    border-radius: 40px;
}
.top .interview .list li .ttl{
    margin: 25px 35px 0;
    font-size: var(--fs18);
    font-weight: bold;
}
.top .interview .list li .name{
    margin: 25px 35px 0;
    font-size: var(--fs16);
}
.top .interview .linkBtn{
    width: 280px;
    margin: 0 auto;
}

.top .clients .box{
    position: relative;
    width: 300px;
    height: 280px;
    margin-left: 75px;
    padding: 15px 30px 0;
    border-radius: 40px;
    box-sizing: border-box;
    background: #fff;
    z-index: 2;
}
.top .clients .box .ttl2{
    margin-bottom: 30px;
}
.top .clients .box .linkBtn{
    width: 230px;
}
.top .clients .box .linkBtn a{
    height: 40px;
    padding: 0 30px 0 10px;
    font-size: 14px;
}
.top .clients .box .linkBtn a:after{
    right: 10px;
}

.top .clients .slide {
    width: 1360px;
    margin: -280px 0 0 75px;
}
.top .clients .slide ul{
    text-align: center;
}
.top .clients .slick-list{
    overflow: visible;
}
.top .clients .slide li{
    float: left;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 300px;
    height: 280px;
    margin-right: 40px;
    border-radius: 40px;
    box-sizing: border-box;
    background: #fff;
    opacity: 1;
    transition: opacity 0.5s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
    transition-delay: 200ms;
}
.top .clients .slide li.slick-current{
    opacity: 0;
}

.top .vision .pbox{
    min-height: 642px;
    padding-right: 825px;
}
.top .vision h3{
    font-size: var(--fs28);
    font-weight: bold;
}
.top .vision p{
    margin-top: 50px;
    font-size: var(--fs18);
}
.top .vision .img{
    position: absolute;
    top: -50px;
    right: 130px;
    margin: 0;
}
.top .vision .linkBtn{
    width: 260px;
}

.top .news{
    margin-top: 100px;
    overflow: hidden;
}
.top .news h2{
    position: absolute;
    top: 0;
    left: 0;
}
.top .news .category{
    position: absolute;
    top: 210px;
    left: 0;
    width: 227px;
}
.top .news .category li{
    margin-bottom: 20px;
}
.top .news .category li a{
    height: 54px;
    font-size: 18px;
    font-weight: bold;
}
.top .news .box{
    float: right;
    width: 1150px;
    padding: 90px 75px 70px;
    background: #fff;
    border-radius: 40px;
    box-sizing: border-box;
    overflow: hidden;
}
.top .news .box dl {
margin: 0 0 24px;
padding: 0 0 20px;
text-align: left;
border-bottom: 1px solid #ccc;
}

.top .news .box dl dt {
font-size: var(--fs14);
font-weight: 200;
}

.top .news .box dl dt .lbb {
display: inline-block;
width: 140px;
margin: 0 0 0 10px;
padding: 7px 0 6px;
color: #fff;
font-size: var(--fs10);
text-align: center;
vertical-align: baseline;
background: #000;
border-radius: 20px;
    font-family: 'Poppins', sans-serif;
}
.top .news .box dl dt .kind {
display: inline-block;
width: 140px;
margin: 0 0 0 10px;
padding: 7px 0 6px;
font-size: var(--fs10);
text-align: center;
vertical-align: baseline;
background: #FFE545;
border-radius: 20px;
    font-family: 'Poppins', sans-serif;
}
.top .news .box dl dd {
margin: 16px 0 0;
font-size: var(--fs18);
}
.top .news .box dd p {
margin: -10px 0 0;
}
.top .news .box dd p a {
padding: 0 18px 0 0;
font-size: var(--fs18);
font-weight: 500;
background: url("/img/ico_arw_03.png") no-repeat right center;
}
.top .news .box p.linkBtn {
    float: right;
    width: 280px;
    margin-top: 40px;
}

.top .innovace .pbox{
    min-height: 474px;
    padding-top: 70px;
}
.top .innovace .pbox .img {
    position: absolute;
    top: 75px;
    right: -90px;
}

.top .recruit .pbox{
    min-height: 642px;
    padding-top: 70px;
}
.top .recruit .img {
    position: absolute;
    top: 100px;
    right: 75px;
}
.top .recruit .linkBtn {
    width: 280px;
    margin-top: 40px;
}


@media screen and (max-width: 767px) {
.top .main{
    margin-bottom: 60px;
}
.top .main .inner{
    min-height: 1em;
    padding: 0;
}
.top .main:before{
    top: 10px;
    left: inherit;
    right: 30px;
    width: 110px;
    height: 180px;
    background-size: contain;
}
.top .main h1{
    margin: 0 0 20px 20px;
    padding: 60px 0 0;
    font-size: 27px;
}
.top .main .img{
    position: relative;
    top: 0;
    left: 0;
    margin: 0 0 0 20px;
    width: 94.6vw;
    height: 64vw;
    border-radius: 30px 0 0 30px;
}
.top .main .btn{
    width: 230px;
    margin: 20px auto 0;
}
.top .main .btn a{
    height: 46px;
    font-size: 16px;
}

.top .service .pbox{
    padding-top: 30px;
    padding-bottom: 30px;
}
.top .service .img{
    display: none;
}
.top .service .mo{
    height: auto;
    margin: 0;
    padding: 0;
}
.top .service .mo ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 20px;
}
.top .service .mo li{
    width: 48%;
}
.top .service .mo li a{
    height: 45px;
    padding: 0 25px 0 10px;
    font-size: 13px;
}
.top .service .mo li a:after{
    right: 10px;
}
.top .service .mo h3{
    margin-top: 20px;
}
.top .service .mo .wrap{
    width: 320px;
    margin: 20px auto 0;
    padding-left: 15px;
    padding-bottom: 30px;
}
.top .service .mo .stop{
    width: 40px;
    margin: 0 auto;
}
.top .service .mo .stop.on{
    opacity: .7;
}
.top .service .mo .wrap .slick-arrow{
    position: absolute;
    bottom: -38px;
    width: 35px;
    height: 35px;
    font-size: 0;
    border: none;
    z-index: 2;
}
.top .service .mo .wrap .slick-prev{
    left: 70px;
    background: url("/img/top/btn_back.png") no-repeat right center;
}
.top .service .mo .wrap .slick-next{
    right: 70px;
    background: url("/img/top/btn_next.png") no-repeat right center;
}
.top .service .mo .slick-list{
    overflow: visible;
}
.top .service .mo .slick-track{
  display: flex;
}
.top .service .mo .slick-slide{
  height: auto;
}
.top .service .mo .detail{
    position: relative;
    display: block;
    top: 0;
    left: 0;
    width: 290px;
    height: auto;
    margin: 0 10px;
    padding: 12px 12px 90px;
    filter: none;
    border-radius: 20px;
    box-sizing: border-box;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
.top .service .mo .detail img{
    border-radius: 25px;
}
.top .service .mo .detail .ttl{
    margin: 15px 0 0;
    font-size: 18px;
}
.top .service .mo .detail .txt{
    margin: 5px 0 0;
    font-size: 14px;
}
.top .service .mo .detail .linkBtn{
    position: absolute;
    bottom: 30px;
    left: 0;
    right: 0;
    width: 256px;
    margin: 20px auto 0;
}
.top .service .mo .detail .linkBtn a{
    justify-content: center;
}

.top .pbox{
    margin-top: 0;
}


.pbox .started{
    position: relative;
    margin-bottom: 30px;
    padding-top: 30px;
}
.pbox .started .box{
    width: auto;
}
.pbox .started .box p{
    font-size: 14px;
    font-weight: bold;
}
.pbox .started .box p.btn{
    width: 300px;
    margin-top: 30px;
    filter: none;
}
.pbox .started .box p.btn a{
    height: 54px;
    font-size: 18px;
}
.pbox .started .movie{
    position: relative;
    top: 0;
    right: 0;
    width: 280px;
    height: auto;
    margin: 0 auto 30px;
}
.pbox .started .movie p{
    opacity: 1;
    transition: none;
}
.pbox .started .movie.act p{
    opacity: 0;
    transition: opacity 0.3s ease;
}
#player {
    position: absolute;
    top: 0;
    left: 0;
    width: 280px;
    height: 284px;
    margin: -1px;
}
.pbox .started .box li{
    position: relative;
    display: flex;
    align-items: center;
    min-height: 2.8em;
    margin-bottom: 54px;
    padding-left: 50px;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
}
.pbox .started .box .num{
    position: absolute;
    top: 0;
    left: 0;
    width: 42px;
    font-size: var(--fs12);
    font-weight: bold;
    text-align: center;
}
.pbox .started .box .num span {
    font-size: 30px;
    font-weight: bold;
    line-height: 1;
}

.top .plan .ttl2{
    text-align: left;
}
.ttl2.txtc:after{
    margin: 0;
}
.top .plan .pbox{
    padding-bottom: 15px;
}
.top #wrapper .plan .lead{
    margin-bottom: 20px;
    text-align: left;
}

.top .interview{
    margin: 0 15px 20px;
    padding-bottom: 30px;
}
.top .interview .list li{
    max-width: 400px;
    width: auto;
    margin: 0 auto 20px;
    padding-bottom: 30px;
    border-radius: 35px;
    overflow: hidden;
}
.top .interview .list li .ttl{
    margin: 15px 15px 0;
}
.top .interview .list li .name{
    margin: 15px 15px 0;
}
.top .interview .linkBtn{
    width: 160px;
    margin: 0 auto;
}

.top .clients{
    margin-bottom: 70px;
}
.top .clients .box{
    height: auto;
    margin: 0 ;
    padding: 0 15px;
    background: none;
}
.top .clients .slide{
    position: relative;
    width: 100%;
    margin: 0;
}
.top .clients .slide ul{
    width: 200px;
    margin: 0 auto;
}
.top .clients .slide li{
    width: 200px;
    height: 165px;
    padding: 0 20px;
    border-radius: 25px;
}
.top .clients .slide li.slick-current{
    opacity: 1;
}
.top .clients .slick-arrow{
    position: absolute;
    bottom: -58px;
    width: 35px;
    height: 35px;
    font-size: 0;
    border: none;
}
.top .clients .slick-prev{
    left: 15px;
    background: url("/img/top/btn_back.png") no-repeat right center;
}
.top .clients .slick-next{
    right: 15px;
    background: url("/img/top/btn_next.png") no-repeat right center;
}
.top .clients .stop {
    width: 40px;
    margin: 20px auto 0;
    text-align: center;
}
.top .clients .stop.on {
    opacity: .7;
}
.top .clients .slide .slick-dots {
    width: 320px;
    margin: 20px -60px 0;
    text-align: center;
    overflow: hidden;
}
.top .clients .slide .slick-dots li{
    float: none;
    display: inline-block;
    width: 15px;
    height: 15px;
    margin: 0 8px 15px;
    padding: 0;
    background: #fff;
}
.top .clients .slick-dots li.slick-active{
    background: #000;
}
.top .clients .slick-dots li button{
    width: 15px;
    height: 15px;
    font-size: 0;
    border: none;
    background: none;
}
.top .clients .linkBtn{
    width: 160px;
    margin: 20px auto 0;
}

.top .vision .pbox{
    padding-top: 30px;
    padding-right: 15px;
}
.top .vision p{
    margin-top: 20px;
}
.top .vision .img{
    position: relative;
    top: 0;
    right: 0;
    margin-top: 20px;
    margin-bottom: -80px;
}
.top .vision .linkBtn{
    width: 160px;
}

.top .news h2{
    position: relative;
    top: 0;
    left: 0;
}
.top .news .category{
    position: relative;
    top: 0;
    left: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: auto;
    margin: 0 15px;
}
.top .news .category li{
    min-width: 105px;
}
.top .news .category li a{
    padding: 0 5px;
    font-size: 14px;
}

.top .news{
    margin-bottom: 60px;
}
.top .news h2{
    margin: 0 15px 20px;
}
.top .news .box{
    float: none;
    width: auto;
    margin: 0 15px;
    padding: 40px 15px;
    border-radius: 25px;
}
.top .news .box dl dt br{
    display: none;
}
.top .news .box dl dt .kind{
    width: 100px;
    padding: 5px 0 4px;
}
.top .news .box p.linkBtn{
    float: none;
    width: 160px;
    margin: 30px auto 0;
}

.top .innovace .pbox{
    min-height: 1em;
    padding-top: 30px;
}
.top .innovace .pbox .img{
    position: relative;
    top: 0;
    right: 0;
    margin-top: 30px;
}

.top .recruit .pbox{
    min-height: 1em;
    padding-top: 30px;
}
.top .recruit .pbox .img{
    position: relative;
    top: 0;
    right: 0;
    margin: 30px -30px 0;
}
.top .recruit .linkBtn{
    width: 160px;
    margin: 40px auto 0;
}

}

/*service*/
body.service .main .pbox{
    padding-top: 80px;   
}
.service .swrap{
    position: relative;
    min-height: 500px;
    margin-top: 70px;
}
.service .swrap + .swrap{
    margin-top: 80px;
}
.service .swrap .box{
    float: right;
    width: 580px;
    padding-top: 50px;
}
.service .swrap.imgr .box{
    float: none;
}
.service .swrap h2{
    position: relative;
    padding-top: 12px;
    font-size: var(--fs36);
    font-weight: bold;
    line-height: 1.3;
}
.service .swrap h2 .en{
    position: relative;
    top: -15px;
    font-size: var(--fs18);
}
.service .swrap h2:after{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 27px;
    height: 4px;
    background: #000000;
}
.service .swrap .box p{
    font-size: var(--fs18);
    line-height: 1.8;
}
.service .swrap .img{
    position: absolute;
    top: 0;
    left: -140px;
    width: 866px;
}
.service .swrap.imgr .img{
    left: inherit;
    right: -140px;
}
.service .swrap .box .linkBtn{
    width: 280px;
    margin-top: 40px;
}

@media screen and (max-width: 767px) {
    body.service .main .pbox{
        padding-top: 40px;
    }
    .service .swrap{
        margin-top: 20px;
        min-height: 1em;
    }
    .service .swrap + .swrap{
        margin-top: 40px;
        min-height: 1em;
    }
    .service .swrap .box{
        float: none;
        width: 100%;
        padding-top: 30px;
    }
    .service .swrap h2{
        margin-bottom: 10px;
    }
    .service .swrap h2 .en{
        top: -5px;
    }
    .service .swrap .img,
    .service .swrap.imgr .img{
        position: relative;
        top: 0;
        left: 0;
        right: 0;
        width: 100%;
        margin-bottom: 10px;
    }
    .service .swrap .box .linkBtn{
        margin: 20px auto 0;
    }
}

.main .serviceLink{
    padding-top: 64px;
}
.main .serviceLink ul{
    display: flex;
    flex-wrap: wrap;
    column-gap: 87px;
    margin-top: 20px;
}
.main .serviceLink ul li{
    width: 394px;
    text-align: center;
}
.main .serviceLink ul li p{
    font-size: var(--fs14);
    font-weight: bold;
}
.main .serviceLink ul li span{
    font-size: var(--fs22);
    font-weight: bold;
}
.main .serviceLink ul li img{
    margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
    .main .serviceLink{
        padding-top: 30px;
    }
    .main .serviceLink ul li{
        width: 100%;
    }
    .main .serviceLink ul li + li{
        margin-top: 25px;
    }
}

/*plan*/

body.plan .main .pbox{
    padding-top: 80px;   
}
body.plan .pbox .lead{
    margin-bottom: 30px;
}

@media screen and (max-width: 767px) {
    body.plan .main .pbox{
        padding-top: 40px;
    }
}


/*Results*/

body.results .pNav ul{
    display: flex;
    max-width: 1516px;
    margin: 0 auto;
    text-align: center;
}
body.results .pNav li{
    width: 500px;
    margin-left: 60px;
    border-radius: 20px 20px 0 0;
    background: #EEEEEE;
}
body.results .pNav li .en{
    font-weight: 900;
}
body.results .pNav li.act{
    background: #FFFFFF;
}
body.results .pNav li a{
    position: relative;
    display: block;
    height: 90px;
    padding-top: 8px;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.3;
    box-sizing: border-box;
}
body.results .pNav li a .en{
    font-size: var(--fs36);
}
body.results .pNav li a:before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.results .main .tabwrap{
    padding-top: 80px;
    padding-bottom: 270px;
}

body.results .list {
    display: flex;
    flex-wrap: wrap;
    column-gap: 78px;
}
body.results .list li {
    position: relative;
    width: 400px;
    height: 360px;
    margin-top: 120px;
}
body.results .list li a {
    display: block;
    padding: 90px 30px 30px;
    height: 100%;
    border-radius: 20px;
    background: #F8F8F8;
    box-sizing: border-box;
}
body.results .list p {
    margin-bottom: 1em;
    font-size: var(--fs16);
    line-height: 1.8;
}
body.results .list a .ico {
    position: absolute;
    top: -60px;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 93px;
    height: 30px;
    background: #FFE544;
    border-radius: 15px;
    text-align: center;
    font-size: 12px;
}
body.results .list a .ico img {
    margin-right: 5px;
}
body.results .list li a .img {
    position: absolute;
    top: -150px;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 170px;
    height: 130px;
    background: #fff;
    border-radius: 20px;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.results .list li a .img img {
    width: 135px;
    height: 95px;
    object-fit: cover;
}
body.results .list p.ttl {
    min-height: 3.6em;
    font-size: var(--fs18);
    font-weight: bold;
}

body.results div.list {
    margin-top: -80px;
}
body.results .list .box {
    position: relative;
    width: 400px;
    height: 465px;
    margin-top: 120px;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.results .list .box a {
    display: block;
    padding: 60px 30px 30px;
    height: 100%;
    border-radius: 20px;
    background: #fff;
    box-sizing: border-box;
}
body.results .list .box a .ico {
    top: 0;
    left: 30px;
    border-radius: 0 0 6px 6px;
}
body.results .list .box p.ttl {
    min-height: 5.4em;
}

@media screen and (max-width: 767px) {
    body.results .pNav ul{
        margin: 0 30px;
        justify-content: space-between;
    }
    body.results .pNav ul li{
        width: 48%;
        margin: 0;
    }
    body.results .pNav ul li a{
        height: 70px;
        font-size: 14px;
    }
    body.results .main .tabwrap{
        padding-bottom: 180px;
    }
    body.results .list li{
        margin-top: 100px;
        height: auto;
    }
    body.results .list li:first-child{
        margin-top: 0;
    }
    body.results .list li a{
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 20px;
    }
    body.results div.list{
        margin-bottom: -20px;
    }
    body.results .list .box {
        margin-top: 20px;
        margin-bottom: 30px;
        height: auto;
    }
    body.results .list p.ttl,
    body.results .list .box p.ttl{
        min-height: 1em;
    }
    body.results .list p:last-child{
        margin-bottom: 0;
    }
}


body.results .detail {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding-bottom: 270px;
}
body.results .detail .main{
    width: 820px;
}
body.results .detail .main .img{
    position: absolute;
    top: -60px;
    right: 125px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 563px;
    height: 433px;
    margin: 0;
    background: #fff;
    border-radius: 40px;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.results .detail .main .img img{
    width: 310px;
    height: 218px;
    object-fit: cover;
}
body.results .detail .main .info{
    min-height: 370px;
    padding: 25px 140px 0 0;
}
body.results .detail .main .info h2{
    margin-bottom: 20px;
    font-size: var(--fs28);
    font-weight: bold;
}
body.results .detail .main .info .com{
    font-size: var(--fs18);
    font-weight: bold;
}
body.results .detail .main .info table{
    width: 100%;
    margin-top: 60px;
    border-bottom: 1px solid #CCCCCC;
}
body.results .detail .main .info th,
body.results .detail .main .info td{
    width: 220px;
    padding: 22px 10px;
    border-top: 1px solid #CCCCCC;
    font-size: var(--fs16);
    font-weight: normal;
    box-sizing: border-box;
}
body.results .detail .main .info th{
    width: 120px;
    text-align: center;
}
body.results .detail .main .bg{
    margin-top: 85px;
    padding: 50px;
    border-radius: 40px;
    background: #F8F8F8;
}
body.results .detail .main .bg dt{
    margin-bottom: 25px;
}
body.results .detail .main .bg dd + dt{
    margin-top: 50px;
}
body.results .detail .main .bg dt .line{
    position: relative;
    padding: 0 5px;
    font-size: var(--fs18);
    font-weight: bold;
    z-index: 2;
}
body.results .detail .main .bg dt .line:before{
    content: '';
    position: absolute;
    bottom: -5px;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    height: 18px;
    background: #FFE544;
    z-index: -1;
}
body.results .detail .main .bg dd{
    position: relative;
    margin-top: 10px;
    padding-left: 25px;
    font-size: var(--fs16);
    line-height: 1.8;
}
body.results .detail .main .bg dd:before{
    position: absolute;
    top: 0.8em;
    left: 5px;
    content: '';
    width: 6px;
    height: 6px;
    background: #000;
    border-radius: 100%;
}
body.results .detail h3{
    margin-top: 75px;
    padding-left: 15px;
    border-left: 7px solid #FFE544;
    font-size: var(--fs22);
    font-weight: bold;
}
body.results .detail h4{
    margin-top: 35px;
    font-size: var(--fs18);
    font-weight: bold;
    line-height: 1.8;
}
body.results .detail p{
    margin-top: 20px;
    font-size: var(--fs16);
    line-height: 1.8;
}
body.results .detail p.linkBtn{
    width: 280px;
    margin: 60px auto 0;
}
body.results .detail .linkBtn a{
    padding: 0 30px;
    justify-content: center;
}
body.results .detail .linkBtn a:after{
    display: none;
}
body.results .detail ul.btn{
    margin: 60px auto 0;
    text-align: center;
}
body.results .detail ul .linkBtn{
    display: inline-block;
    width: 280px;
    margin: 0 20px;
}
body.results .detail .side{
    width: 448px;
    padding-top: 430px;
}
body.results .detail .box h3{
    margin-bottom: 30px;
}
body.results .detail .box{
    margin-top: 20px;
    border-bottom: 1px solid #CCCCCC;
}
body.results .detail .box a{
    position: relative;
    display: block;
    min-height: 95px;
    padding: 0 0 20px 155px;
    overflow: hidden;
}
body.results .detail .box a p{
    margin: 0;
}
body.results .detail .box .img{
    position: absolute;
    top: 0;
    left: 0;
    width: 135px;
    height: 95px;
}
body.results .detail .box .img img{
    border: 1px solid #CCCCCC;
}
body.results .detail .box ul{
    margin-top: 30px;
}
body.results .detail .box li{
    float: left;
    width: 49%;
    margin-right: 1%;
    font-size: var(--fs14);
}

body.results .dlbox {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 1366px;
    height: 252px;
    margin: -275px auto 0;
    padding: 0 60px 0 90px;
    background: #fff;
    border-radius: 30px;
    box-sizing: border-box;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.results .dlbox dl {
    text-align: center;
}
body.results .dlbox dl dt {
    margin-bottom: 10px;
    font-size: var(--fs28);
    font-weight: bold;
}
body.results .dlbox dl dd p{
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.results .dlbox dl dd a{
    width: 618px;
    height: 70px;
    font-size: var(--fs20);
    font-weight: bold;
}

@media screen and (max-width: 767px) {
    body.results .detail{
        padding-bottom: 180px;
    }
    body.results .detail .main{
        width: auto;
    }
    body.results .detail .main .img{
        top: 30px;
        left: 15px;
        width: 133px;
        height: 102px;
        border-radius: 20px;
    }
    body.results .detail .main .img img{
        width: 106px;
        height: 75px;
    }
    body.results .detail .main .info{
        padding: 160px 0 0;
        min-height: 1em;
    }
    body.results .detail .main .info table{
        margin-top: 40px;
        border-bottom: none;
    }
    body.results .detail .main .bg{
        margin-top: 30px;
        padding: 20px 15px;
        border-radius: 20px;
    }
    body.results .detail h3{
        margin-top: 40px;
    }
    body.results .detail h3.spfix{
        font-size: 16px;
    }
    body.results .detail p.linkBtn{
        width: 160px;
        margin-top: 30px;
    }
    body.results .detail ul .linkBtn{
        width: 200px;
        margin-top: 30px;
    }
    body.results .detail .linkBtn a{
        padding: 0 20px;
    }
    body.results .detail ul.btn{
        margin: 0;
    }
    body.results .detail .side{
        width: auto;
        padding-top: 50px;
    }
    body.results .detail .box .img{
        width: 93px;
        height: 66px;
    }
    body.results .detail .box a{
        padding-left: 110px;
    }
    body.results .detail .box ul{
        margin-top: 10px;
    }
    body.results .detail .box li{
        float: none;
        width: auto;
    }
    body.results .detail .main .info tr {
        display: flex;
        flex-wrap: wrap;
    }
    body.results .detail .main .info th{
        width: 38%;
        font-size: 14px;
    }
    body.results .detail .main .info td{
        width: 62%;
        font-size: 14px;
    }
    body.results .dlbox{
        position: relative;
        display: block;
        width: auto;
        height: auto;
        margin: -190px 30px 50px;
        padding: 70px 10px 45px;
    }
    body.results .dlbox dt{
        position: absolute;
        top: 20px;
        width: 100%;
        text-align: center;
    }
    body.results .dlbox dd{
        margin: 20px 10px 0;
    }
    body.results .dlbox dl dd p{
        filter: none;
    }
    body.results .dlbox dl dd a{
        width: auto;
        height: 54px;
    }
}

body.about .pnav {
    position: relative;
    max-width: 1516px;
    margin: 0 auto 100px;
}
body.about .ttl2 {
    padding-top: 75px;
    font-size: var(--fs18);
}
body.about .ttl2 .en{
    display: inline-block;
    margin-bottom: -12px;
    font-size: var(--fs56);
}
body.about .main p{
    font-size: var(--fs18);
    font-weight: bold;
    line-height: 1.8;
}
body.about .main .ttl3{
    position: relative;
    padding-bottom: 15px;
    text-align: center;
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .main .ttl3:after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.about .pnav ul{
    max-width: 850px;
}
body.about .pnav li{
    display: inline-block;
    min-height: 35px;
    
    margin-bottom: 12px;
    margin-right: 75px;
    padding-left: 42px;
    background: url(/img/cmn/img_anc01.png) no-repeat;
}
body.about .pnav li a{
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .aboutbox01{
    width: 525px;
    min-height: 540px;
}
body.about .aboutbox01 .img{
    position: absolute;
    top: -60px;
    right: 75px;
}
body.about .aboutbox01 p.lead{
    margin-bottom: 50px;
    font-size: var(--fs28);
    line-height: 1.5;
}
body.about .aboutbox02{
    display: flex;
    justify-content: space-between;
}
body.about .aboutbox02 .box{
    width: 620px;
    padding-top: 45px;
}
body.about .aboutbox02 p{
    margin-top: 15px;
}
body.about .aboutbox02 .box .name{
    text-align: right;
}
body.about .aboutbox02 .box .name span{
    font-size: var(--fs22);
}
body.about .aboutbox03{
    display: flex;
    justify-content: space-between;
    margin-top: 65px;
}
body.about .aboutbox03 .box{
    width: 630px;
}
body.about .aboutbox03 .box .ttl3{
    margin: 35px 0;
}
body.about .aboutbox04 table{
    width: 100%;
    border-bottom: 1px solid #CCCCCC;
}
body.about .aboutbox04 th,
body.about .aboutbox04 td{
    padding: 35px;
    font-size: var(--fs18);
    border-top: 1px solid #CCCCCC;
}
body.about .aboutbox04 th{
    position: relative;
    width: 215px;
    text-align: center;
}
body.about .aboutbox04 td{
    padding-left: 85px;
}
body.about .aboutbox04 th:after{
    content: '';
    position: absolute;
    top: 20px;
    bottom: 20px;
    right: 0;
    width: 1px;
    background: #FFE545;
    margin: auto;
}
body.about .aboutbox05{
    display: flex;
    margin-top: 60px;
    padding: 50px 0;
    background: #F7F7FA;
    border-radius: 40px;
}
body.about .aboutbox05 .box{
    position: relative;
    width: 430px;
    text-align: center;
}
body.about .aboutbox05 .box h3{
    margin-bottom: 30px;
}
body.about .aboutbox05 .box + .box{
    width: 900px;
}
body.about .aboutbox05 .box + .box:before{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 1px;
    height: 100%;
    background :#CCCCCC;
}
body.about .aboutbox05 .box h4{
    margin: 35px 0 10px;
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .aboutbox05 .box p + p{
    margin-top: 35px;
}
body.about .aboutbox06 {
    margin-top: 100px;
}
body.about .aboutbox06 h3{
    position: relative;
    padding-top: 10px;
    text-align: center;
    font-size: var(--fs36);
    font-weight: bold;
}
body.about .aboutbox06 h3 .en{
    position: relative;
    top: -25px;
    display: inline-block;
    font-size: var(--fs18);
    font-weight: bold;
}
body.about .aboutbox06 h3:after{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.about .aboutbox06 ul{
    margin-top: 10px;
    text-align: center;
}
body.about .aboutbox06 ul li{
    display: inline-block;
    margin: 0 40px;
}
body.about .aboutbox07{
    width: 1366px;
    margin: 80px auto -275px;
    padding: 45px 0 65px;
    background: #fff;
    border-radius: 40px;
    text-align: center;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.about .aboutbox07 h3{
    font-size: var(--fs28);
    font-weight: bold;
}
body.about .aboutbox07 p{
    margin-top: 20px;
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .aboutbox07 p.linkBtn{
    width: 280px;
    margin: 40px auto 0;
}
body.about #anc04{
    margin-top: 300px;
}
body.about .aboutbox08 ul{
    display: flex;
    justify-content: space-between;
    margin-top: 85px;
}
body.about .aboutbox08 li{
    position: relative;
    width: 400px;
    text-align: center;
    font-size: var(--fs18);
    font-weight: bold;
}
body.about .aboutbox08 ul .name{
    display: inline-block;
    margin: 20px 0 15px;
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .aboutbox09 {
    position: relative;
    margin: -170px 0 0 605px;
    padding-left: 45px;
    border-left: 3px solid #FEE545;
}
body.about .aboutbox09:after{
    content: '';
    position: absolute;
    bottom: 0;
    left: -3px;
    width: 3px;
    height: 40px;
    margin: auto 0;
    background: #fff;
}
body.about .aboutbox09 h3{
    position: absolute;
    left: -140px;
    width: 140px;
    margin-top: -18px;
    font-size: 40px;
    font-weight: bold;
    z-index: 4;
}
body.about .aboutbox09 h3:after{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: -10px;
    width: 25px;
    height: 25px;
    margin: auto 0;
    border-radius: 100%;
    background: #FEE545;
}
body.about .aboutbox09 ul{
    margin-bottom: 50px;
}
body.about .aboutbox09 ul:last-child{
    margin-bottom: -5px;
}
body.about .aboutbox09 li{
    margin-bottom: 5px;
    font-size: var(--fs18);
}
body.about .aboutbox09 li .num{
    font-size: var(--fs18);
    font-weight: bold;
}
body.about .aboutbox10{
    display: flex;
    flex-wrap: wrap;
    column-gap: 80px;
}
body.about .aboutbox10 .box{
    position: relative;
    width: 400px;
    height: 360px;
    margin-top: 60px;
    padding-top: 30px;
    background: #F8F8F8;
    border-radius: 20px;
    text-align: center;
    box-sizing: border-box;
}
body.about .aboutbox10 .box h3,
body.about .aboutbox10 .box .txt1{
    position: relative;
    font-size: var(--fs28);
    font-weight: bold;
}
body.about .aboutbox10 .box p{
    position: relative;
    font-size: var(--fs22);
    font-weight: bold;
}
body.about .aboutbox10 .box .num{
    font-size: 100px;
    font-weight: bold;
    line-height: 1;
}
body.about .aboutbox10 .box .txt2{
    font-size: 50px;
    font-weight: bold;
    line-height: 1.1;
}
body.about .aboutbox10 .box .wrap{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 25px;
}
body.about .aboutbox10 .ico1 h3,
body.about .aboutbox10 .ico2 h3,
body.about .aboutbox10 .ico3 h3{
    margin-bottom: 90px;
}
body.about .aboutbox10 .ico3 .num{
    display: inline-block;
    margin-bottom: 20px;
}
body.about .aboutbox10 .ico4 h3,
body.about .aboutbox10 .ico5 h3,
body.about .aboutbox10 .ico6 h3{
    margin-bottom: 120px;
}
body.about .aboutbox10 .ico1:before{
    position: absolute;
    top: 17px;
    left: 0;
    right: 0;
    content: '';
    width: 150px;
    height: 164px;
    margin: 0 auto;
    background: url(/company/img/img_data01.png) no-repeat;
}
body.about .aboutbox10 .ico2:before{
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    content: '';
    width: 317px;
    height: 80px;
    margin: 0 auto;
    background: url(/company/img/img_data02.png) no-repeat;
}
body.about .aboutbox10 .ico3:before{
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    content: '';
    width: 127px;
    height: 95px;
    margin: 0 auto;
    background: url(/company/img/img_data03.png) no-repeat;
}
body.about .aboutbox10 .ico4:before{
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    content: '';
    width: 101px;
    height: 110px;
    margin: 0 auto;
    background: url(/company/img/img_data04.png) no-repeat;
}
body.about .aboutbox10 .ico5:before{
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    content: '';
    width: 73px;
    height: 114px;
    margin: 0 auto;
    background: url(/company/img/img_data05.png) no-repeat;
}
body.about .aboutbox10 .ico6:before{
    position: absolute;
    top: 85px;
    left: 0;
    right: 0;
    content: '';
    width: 112px;
    height: 113px;
    margin: 0 auto;
    background: url(/company/img/img_data06.png) no-repeat;
}
@media screen and (max-width: 767px) {
    body.about .ttl2{
        padding-top: 30px;
    }
    body.about .ttl2.txtc{
        text-align: left;
    }
    body.about .ttl2.txtc:after{
        margin: 0;
    }
    body.about .aboutbox01{
        width: auto;
        min-height: 1em;
    }
    body.about .aboutbox01 p.lead{
        margin-bottom: 25px;
    }
    body.about .aboutbox01 .img{
        position: relative;
        top: 0;
        right: 0;
        margin-bottom: 15px;
    }
    body.about .aboutbox02{
        display: block;
    }
    body.about .aboutbox01 p,
    body.about .aboutbox02 p{
        font-weight: normal;
    }
    body.about .aboutbox02 .box{
        width: auto;
        padding-top: 0;
    }
    body.about .aboutbox03{
        display: block;
        margin-top: 0;
    }
    body.about .aboutbox03 .box{
        width: auto;
        margin-top: 40px;
    }
    body.about .aboutbox03 .box .ttl3{
        margin: 30px 0 15px;
    }
    body.about .aboutbox04 th{
        width: 100px;
        padding: 10px 0;
        font-size: 14px;
    }
    body.about .aboutbox04 td{
        padding: 10px 15px;
        font-size: 14px;
    }
    body.about .aboutbox04 th:after{
        top: 10px;
        bottom: 10px;
    }
    body.about .aboutbox05{
        display: block;
        margin-top: 30px;
        padding: 20px 0;
    }
    body.about .aboutbox05 .box{
        width: auto;
    }
    body.about .aboutbox05 .box + .box{
        width: auto;
        margin: 35px 20px 0;
        padding-top: 35px;
        border-top: 1px solid #CCCCCC;
        text-align: left;
    }
    body.about .aboutbox05 .box + .box:before{
        display: none;
    }
    body.about .aboutbox06{
        margin-top: 50px;
    }
    body.about .aboutbox06 h3 .en{
        top: -10px;
    }
    body.about .aboutbox06 ul{
        margin: 0 -15px;
    }
    body.about .aboutbox06 ul li{
        margin: 20px 5px 0;
    }
    body.about .aboutbox06 ul li img{
        height: 40px;
    }
    body.about .aboutbox07{
        width: auto;
        padding: 30px 20px;
    }
    body.about .aboutbox07 p{
        text-align: left;
        font-size: 16px;
    }
    body.about .aboutbox07 p.linkBtn{
        width: 160px;
        margin-top: 25pxW;
    }
    body.about .aboutbox08 ul{
        display: block;
        margin: 0;
    }
    body.about .aboutbox08 ul li{
        width: auto;
        margin-top: 40px;
    }
    body.about .aboutbox08 ul .name{
        margin-bottom: 0;
    }
    body.about .aboutbox09{
        margin: 0 0 0 100px;
        padding-left: 30px;
    }
    body.about .aboutbox09 h3{
        width: 100px;
        left: -100px;
        margin-top: -10px;
        font-size: 28px;
    }
    body.about .aboutbox09 h3:after{
        right: -8px;
        width: 20px;
        height: 20px;
    }
    body.about .aboutbox09 ul{
        margin-bottom: 30px;
    }
    body.about .aboutbox09:after{
        height: 100px;
    }
    body.about .aboutbox09 ul:last-child{
        position: relative;
    }
    body.about .aboutbox09 ul:last-child:after{
        content: '';
        position: absolute;
        top: 10px;
        bottom: 0;
        left: -33px;
        width: 3px;
        height: 100%;
        margin: auto 0;
        background: #fff;
    }
    body.about .aboutbox10{
        display: block;
    }
    body.about .aboutbox10 .box{
        width: auto;
        height: auto;
        margin-top: 20px;
        padding-bottom: 20px;
    }
    body.about .aboutbox10 .box .num{
        font-size: 78px;
    }
    body.about .aboutbox10 .ico1:before{
        height: 130px;
        background-size: auto 100%;
        background-position: center;
    }
    body.about .aboutbox10 .ico2:before{
        top: 70px;
        height: 63px;
        background-size: auto 100%;
        background-position: center;
    }
    body.about .aboutbox10 .ico3:before{
        top: 60px;
        height: 74px;
        background-size: auto 100%;
        background-position: center;
    }
    body.about .aboutbox10 .ico4:before{
        height: 86px;
        background-size: auto 100%;
        background-position: center;
    }
    body.about .aboutbox10 .ico5:before,
    body.about .aboutbox10 .ico6:before{
        height: 88px;
        background-size: auto 100%;
        background-position: center;
    }
}

body.news #wrapper,
body.topics #wrapper,
body.press #wrapper,
body.media #wrapper {
    overflow: visible;
}
@media screen and (min-width: 768px) {
body.news .ttl1,
body.topics .ttl1,
body.press .ttl1,
body.media .ttl1 {
    margin-top: 0;
    padding-top: 50px;   
}
}

.news .kindMenu {
    padding-top: 75px;
    position: sticky;
    top: 140px;
    background: #fff;
    z-index: 10;
}
.news .kindMenu .link2{
    display: flex;
}
.news .kindMenu .link2 .linkBtn{
    display: block;
    width: 227px;
    margin-right: 24px;
}
.news .kindMenu .link2 .linkBtn a{
    justify-content: center;
    padding: 0 30px;
}
.news .kindMenu .link2 .linkBtn a:after{
    display: none;
}
.news .kindMenu .link2 .act{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 54px;
    width: 227px;
    margin-right: 24px;
    padding: 0 30px;
    border-radius: 30px;
    background: #FFE545;
    font-size: var(--fs18);
    font-weight: bold;
    box-sizing: border-box;
    z-index: 3;
}
.news .kindMenu select{
    position: absolute;
    top: 75px;
    right: 90px;
    width: 146px;
    height: 54px;
    background-color: #fff;
    border: none;
    border-bottom: 2px solid #000;
    border-radius: 0;
    color: #000;
    font-size: var(--fs22);
}
.news .list {
    width: 1000px;
    margin: 60px auto 0;
    border-top: 1px solid #CCCCCC;
}
.news .list dl{
    display: none;
    padding: 43px 35px;
    border-bottom: 1px solid #CCCCCC;
    overflow: hidden;
}
.news .list dt{
    position: relative;
    float: left;
    width: 295px;
    margin-right: 60px;
    font-size: var(--fs14);
}
.news .list dt .kind,
.news .list dt .lbb{
    position: absolute;
    top: -5px;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 140px;
    height: 30px;
    background: #FFE545;
    border-radius: 20px;
    font-size: var(--fs12);
}
.news .list dd{
    font-size: var(--fs18);
    font-weight: bold;
    overflow: hidden;
}

.news .newsdetail{
    max-width: 1000px;
    margin: 0 auto;
    padding-top: 100px;
}
.news .newsdetail h2{
    margin-bottom: 40px;
    padding-bottom: 10px;
    border-bottom: 2px solid #000;
    font-size: var(--fs28);
    font-weight: bold;
}
.news .newsdetail h2 br{
    display: block;
}
.news .newsdetail h2 .date{
    font-size: var(--fs18);
    font-weight: bold;
}
.news .newsdetail h3{
    margin-bottom: 25px;
    padding-left: 30px;
    border-left: 8px solid #000;
    font-size: var(--fs22);
    font-weight: bold;
}
.news .newsdetail .ctBox02{
    margin-top: 40px;
}
.news .newsdetail p{
    margin-top: 30px;
    font-size: var(--fs16);
    line-height: 1.8;
}
.news .newsdetail p.bold{
    font-weight: bold;
}
.news .newsdetail .ctBox03{
    margin-top: 90px;
    padding-top: 30px;
    border-top: 2px solid #000;
}
.news .newsdetail p.linkBtn{
    width: 280px;
    margin: 0 auto;
}
.news .newsdetail p.linkBtn a{
    padding: 0 30px;
    justify-content: center;
}
.news .newsdetail p.linkBtn a:after{
    display: none;
}
@media screen and (max-width: 767px) {
    .news .kindMenu{
        position: relative;
        top:0;
        padding-top: 25px;
    }
    .news .kindMenu .link2{
        flex-wrap: wrap;
        justify-content: space-between;
        margin: 0 20px;
    }
    .news .kindMenu .link2 .act,
    .news .kindMenu .link2 .linkBtn{
        width: 130px;
        height: 40px;
        margin: 0 0 12px;
    }
    .news .kindMenu .link2 .act,
    .news .kindMenu .link2 .linkBtn a{
        padding: 0;
    }
    .news .kindMenu select{
        position: relative;
        top: 0;
        right: 0;
        width: 130px;
        margin: 0 20px;
    }
    .news .list{
        width: auto;
        margin-top: 24px;
        margin-bottom: -20px;
    }
    .news .list dl{
        padding: 15px;
    }
    .news .list dl dt{
        float: none;
        width: 266px;
        margin: 0;
        font-size: 14px;
    }
    .news .list dl dd{
        margin-top: 12px;
    }

    .news .newsdetail{
        padding-top: 60px;
    }
    .news .newsdetail h2{
        font-size: 18px;
        margin-bottom: -15px;
    }
    .news .newsdetail h3{
        padding-left: 15px;
    }
    .news .newsdetail .ctBox02{
        margin-top: 30px;
    }
    .news .newsdetail .ctBox03{
        margin-top: 30px;
    }
}

.contact .main .pbox p{
    text-align: center;
    font-size: var(--fs22);
    font-weight: bold;
}
.contact .main .pbox p.lead{
    padding-top: 120px;
}
.contact .main .pbox .btn{
    width: 343px;
    margin: 50px auto 0;
}
.contact .main .pbox .submit02{
    margin: 50px auto 0;
}
.contact .main .pbox .btn a{
    height: 70px;
    font-size: var(--fs20);
    font-weight: bold;
}
.contact .linkList{
    display: flex;
    flex-wrap: wrap;
    width: 946px;
    margin: 0 auto;
    padding-top: 30px;
    column-gap: 52px;
}
.contact .linkList li{
    width: 280px;
    margin-top: 45px;
}

.contact .formbox {
	display: flex;
	padding: 90px 0 0;
	justify-content: space-between;
	text-align: left;
}
.contact .formbox h2{
	position: relative;
    margin-bottom: 45px;
    padding-bottom: 20px;
	font-size: var(--fs18);
	font-weight: bold;
}
.contact .formbox h2 .en{
	display: inline-block;
	margin-bottom: -10px;
	font-size: var(--fs56);
	font-weight: bold;
}
.contact .formbox h2:after{
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 50px;
	height: 4px;
	background: #000000;
}
.contact .formbox .text {
	width: 525px;
	margin-top: -20px;
	margin-right: 30px;
}
.contact .formbox .text p{
    text-align: left;
	margin-top: 20px;
	font-size: var(--fs18);
	font-weight: bold;
    line-height: 1.8;
}
.contact .formbox .text p.note{
	font-weight: normal;
}
.contact .formbox .text .line{
    margin-top: 55px;
    padding-top: 20px;
    border-top: 1px solid #CCCCCC;
}
.contact .formbox .text .line h3{
	font-size: var(--fs14);
	font-weight: bold;
}
.contact .formbox .text .line h3 span{
	font-size: var(--fs20);
	font-weight: bold;
}
.contact .formbox .text .line p{
	font-size: var(--fs16);
	font-weight: normal;
}

.contact .formbox .bgarea{
	width: 795px;
	padding: 80px 20px;
	background: #F5F5F5;
	border-radius: 40px;
	box-sizing: border-box;
}
.contact .formbox p{
	font-size: var(--fs16);
}
.contact .formbox h3{
	width: 580px;
	margin: 0 auto 50px;
	font-size: var(--fs28);
	font-weight: bold;
}
.contact .formbox .text h3{
    width: auto;
}
.contact .formbox dl{
	width: 580px;
	margin: -10px auto 0;
}
.contact .formbox dl + h3{
	margin-top: 60px;
}
.contact .formbox dt,
.contact .formbox dd{
	font-size: var(--fs16);
}
.contact .formbox dt{
	margin-top: 35px;
}
.contact .formbox dd{
	margin-top: 10px;
}
.contact .formbox dd input[type=text],
.contact .formbox dd input[type=tel],
.contact .formbox dd textarea{
	width: 100%;
	height: 58px;
	padding: 0 20px;
	border: 1px solid #CCCCCC;
	border-radius: 6px;
	box-sizing: border-box;
	font-size: var(--fs16);
}
.contact .formbox dd textarea{
    height: 150px;
    padding: 20px;
}
.contact .formbox dd select{
	width: 157px;
	height: 58px;
	padding: 0 20px;
	margin-right: 15px;
	border: 1px solid #CCCCCC;
	border-radius: 6px;
	box-sizing: border-box;
	color: #000;
	font-size: var(--fs16);
}
.contact .formbox dd label {
    display: inline-block;
    margin: 5px 20px 5px 0;
}
.contact .formbox dd label input {
    width: 14px;
    height: 14px;
    margin: 0 5px 2px 0;
}
.contact .formbox dd .knowTxt{
	font-size: var(--fs12);
}
.contact .formbox dd input.code{
	width: 157px;
	margin-right: 10px;
	vertical-align: middle;
}
.contact .formbox dd img{
	vertical-align: middle;
}
.contact .formbox dd .sample{
	display: inline-block;
	position: relative;
}
.contact .formbox dd .sample p{
	display: none;
	position: absolute;
    top: -20px;
    left: 10px;
    padding: 10px;
    background: #fff;
    width: 200px;
    margin: 0;
    border-radius: 6px;
}
.contact .formbox .bgarea p{
	width: 580px;
	margin: 20px auto 0;
    text-align: left;
	font-size: var(--fs16);
    font-weight: normal;
}
.contact .formbox p label{
	font-size: var(--fs16);
}
.contact .formbox p input{
	vertical-align: middle;
}
.contact .formbox p.btn {
	margin-top: 75px;
	text-align: center;
}
.contact .formbox p.btn input,
.contact .formbox .submit02 input{
	width: 280px;
	height: 54px;
	margin: 0 auto;
	text-align: center;
	background: #000000;
	border-radius: 27px;
	border: none;
	color: #fff;
	font-size: var(--fs18);
	font-weight: bold;
}
.contact .formbox p a{
	text-decoration: underline;
}
.contact.complete .pbox {
    padding-top: 45px;
}
.contact.complete .pbox p {
    margin-top: 30px;
}

@media screen and (max-width: 767px) {
    .contact.complete .pbox {
        padding-top: 10px;
    }
    .contact.complete .pbox .txtc{
        text-align: center;
    }
    .contact #wrapper .main .pbox p.lead{
        margin-bottom: 30px;
        padding-top: 25px;
        text-align: center;
        font-size: 18px;
        line-height: 1.8;
    }
    .contact .main .pbox .btn,
    .contact .main .pbox .submit02{
        width: auto;
        margin-top: 35px;
    }
    .contact .main .pbox .btn a{
        height: 50px;
    }
    .contact .main .pbox p{
        text-align: left;
        font-size: 14px;
    }
    .contact .linkList{
        width: 314px;
        margin: 0 auto;
        padding-top: 10px;
        column-gap: 18px;
    }
    .contact .linkList li{
        width: 148px;
        margin-top: 18px;
    }

.contact .formbox{
    display: block;
    padding-top: 25px;
}
.contact .formbox h2{
	margin-bottom: 20px;
}
.contact .formbox .text{
	width: 100%;
    margin: 0;
}
.contact .formbox .text p.note{
	margin-top: 10px;
}
.contact .formbox .bgarea{
    width: auto;
	margin-top: 20px;
	padding: 20px;
    border-radius: 20px;
}
.contact .formbox dl{
	width: 100%;
}
.contact .formbox h3{
	width: auto;
    margin-bottom: 20px;
}
.contact .formbox dl + h3{
	margin-top: 30px;
}
.contact .formbox dt{
	margin-top: 20px;
}
.contact .formbox dd{
	margin-top: 5px;
}
.contact .formbox dd input{
	height: 42px;
	padding: 0 10px;
}
.contact .formbox dd select,
.contact .formbox dd input.code{
	width: 100px;
	height: 42px;
	padding: 0 10px;
}
.contact .formbox .bgarea p{
	width: auto;
	margin-top: 20px;
}
.contact .formbox p.btn input,
.contact .formbox .submit02 input{
	height: 40px;
}
.contact .formbox .submit02 input{
    margin-bottom: 20px;
}
.contact .formbox dd .sample p{
    top: -150px;
    left: -90px;
}
}


/*L.B.B.Cloudの事業領域*/
body.business .pnav {
    position: relative;
    max-width: 1516px;
    margin: 0 auto 40px;
}
body.business .ttl2 {
    padding-top: 75px;
    font-size: var(--fs18);
}
body.business .ttl2 .en{
    display: inline-block;
    margin-bottom: -12px;
    font-size: var(--fs56);
}
body.business .main p{
    font-size: var(--fs18);
    font-weight: bold;
    line-height: 1.8;
}
body.business .main .ttl3{
    position: relative;
    padding-top: 15px;
    text-align: center;
    font-size: var(--fs36);
    font-weight: bold;
    line-height: 1.3;
}
body.business .main .ttl3 .en{
    position: relative;
    top: -15px;
    font-size: var(--fs18);
    font-weight: bold;
}
body.business .main .ttl3:after{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.business .pnav ul{
    max-width: 850px;
}
body.business .pnav li{
    display: inline-block;
    min-height: 35px;
    margin-bottom: 12px;
    margin-right: 75px;
    padding-left: 42px;
    background: url(/img/cmn/img_anc01.png) no-repeat;
}
body.business .pnav li a{
    font-size: var(--fs22);
    font-weight: bold;
}
body.business .businessbox01{
    width: 525px;
    min-height: 540px;
}
body.business .businessbox01 .img{
    position: absolute;
    top: -60px;
    right: 75px;
    background: #EEEEEE;
    border-radius: 40px;
}
body.business .businessbox01 p.lead{
    margin-bottom: 50px;
    font-size: var(--fs28);
    line-height: 1.5;
}
body.business .businessbox02 {
    margin-top: 115px;
}
body.business .businessbox02 ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 20px;
}
body.business .businessbox02 li{
    width: 400px;
}
body.business .businessbox02 p{
    font-size: var(--fs16);
    font-weight: normal;
}
body.business .businessbox02 p.img{
    margin-bottom: 25px;
}
body.business .businessbox02 p.ttl{
    margin-bottom: 20px;
    text-align: center;
    font-size: var(--fs18);
    font-weight: bold;
}
body.business .businessbox03 {
    margin-top: 130px;
}
body.business .businessbox03 .box{
    position: relative;
    min-height: 350px;
    margin-top: 45px;
    padding-left: 685px;
}
body.business .businessbox03 .box h4{
    position: relative;
    display: flex;
    align-items: center;
    height: 66px;
    margin-bottom: 40px;
    padding-left: 95px;
    font-size: var(--fs18);
    font-weight: bold;
}
body.business .businessbox03 .box h4 .num{
    position: absolute;
    top: 0;
    left: 0;
    font-size: 50px;
    font-weight: bold;
    line-height: 1;
}
body.business .businessbox03 .box h4 .num span{
    display: block;
    font-size: var(--fs12);
    font-weight: bold;
}
body.business .businessbox03 .box p{
    font-size: var(--fs16);
    font-weight: normal;
}
body.business .businessbox03 .box p.img{
    position: absolute;
    top: 0;
    left: 0;
    width: 630px;
}
body.business .businessbox03 .box ul{
    margin-top: 30px;
}
body.business .businessbox03 .box ul li{
    display: inline-block;
    padding: 5px 24px;
    height: 32px;
    margin-right: 15px;
    background: #FFE544;
    border-radius: 26px;
    text-align: center;
    font-size: var(--fs14);
    box-sizing: border-box;
}
body.business .businessbox03 .box .linkBtn{
    width: 330px;
    margin-top: 35px;
}

body.business #anc03 {
    margin-top: 280px;
}
body.business .businessbox04 {
    width: 1366px;
    margin: 120px auto -150px;
    padding: 65px 0 80px;
    background: #fff;
    border-radius: 40px;
    text-align: center;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.business .businessbox04 .line{
    position: relative;
    padding: 0 5px;
    font-size: var(--fs22);
    font-weight: bold;
    z-index: 2;
}
body.business .businessbox04 .line:before{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    height: 12px;
    background: #FFE544;
    z-index: -1;
}
body.business .businessbox04 ul{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 1068px;
    margin: 60px auto 0;
}
body.business .businessbox04 li{
    width: 480px;
}

body.business .payment {
    margin-top: 115px;
    text-align: center;
}
body.business .payment h3{
    position: relative;
    display: inline-block;
    min-height: 30px;
    margin-bottom: 50px;
    padding: 0 35px;
    font-size: var(--fs22);
    font-weight: bold;
}
body.business .payment h3:before{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 18px;
    height: 30px;
    margin: auto 0;
    background: url(/solutions/img/img_h3_01.png) no-repeat;
}
body.business .payment h3:after{
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    width: 18px;
    height: 30px;
    margin: auto 0;
    background: url(/solutions/img/img_h3_02.png) no-repeat;
}
body.business .payment p{
    margin-top: 40px;
    font-size: var(--fs14);
    font-weight: normal;
}

body.business .connectedlead {
    padding-top: 75px;
}
body.business .connectedbox01 {
    margin-top: 80px;
}
body.business .connectedbox01 h2{
    position: relative;
    padding-bottom: 15px;
    text-align: center;
    font-size: var(--fs22);
    font-weight: bold;
}
body.business .connectedbox01 h2:after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000000;
}

body.business .connectedbox01 .list {
    display: flex;
    flex-wrap: wrap;
    column-gap: 78px;
}
body.business .connectedbox01 .list li {
    position: relative;
    width: 400px;
    margin-top: 120px;
}
body.business .connectedbox01 .list li .inner {
    position: relative;
    display: block;
    padding: 65px 30px 30px;
    height: 100%;
    border-radius: 20px;
    background: #F8F8F8;
    box-sizing: border-box;
}
body.business .connectedbox01 .list p {
    font-size: var(--fs16);
    font-weight: normal;
    line-height: 1.8;
}
body.business .connectedbox01 .list .ico img {
    margin-right: 5px;
}
body.business .connectedbox01 .list li .img {
    position: absolute;
    top: -60px;
    left: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 170px;
    height: 100px;
    background: #fff;
    border-radius: 20px;
    filter: drop-shadow(0 3px 5px rgba(0, 0, 0, 0.25));
}
body.business .connectedbox01 .list li .img img {
    width: 135px;
    height: 65px;
    object-fit: cover;
}
body.business .connectedbox01 .list p.ttl {
    margin-bottom: 10px;
    font-size: var(--fs18);
    font-weight: bold;
}
body.business .connectedbox01 .list p.ttl2 {
    margin: 0 0 10px;
    padding: 0;
    font-size: var(--fs14);
    font-weight: bold;
}
body.business .connectedbox01 .list p.ttl2:after {
    display: none;
}
body.business .connectedbox01 .list p.ttl2 span {
    font-size: 13px;
    font-weight: normal;
}

body.business .aibox01{
    position: relative;
    padding-top: 606px;
}
body.business .aibox01 .img {
    position: absolute;
    top: -65px;
    margin: 0;
}

@media screen and (max-width: 767px) {
    body.business .ttl2{
        margin-bottom: 15px;
        padding-top: 25px;
        padding-bottom: 15px;
    }
    body.business .businessbox01{
        width: auto;
        min-height: 1em;
    }
    body.business .businessbox01 p.lead{
        margin-bottom: 30px;
    }
    body.business .businessbox01 .img{
        position: relative;
        top: 0;
        right: 0;
        margin-bottom: 10px;
    }
    body.business .main .ttl3 .en{
        top: -5px;
    }
    body.business .businessbox02{
        margin-top: 55px;
    }
    body.business .businessbox02 ul{
        margin-top: 0;
    }
    body.business .businessbox02 li{
        margin-bottom: 20px;
    }
    body.business .businessbox02 li p{
        text-align: left;
    }
    body.business .businessbox02 .txtc li p{
        text-align: center;
    }
    body.business .businessbox02 li p.img{
        text-align: center;
    }
    body.business .businessbox03{
        margin-top: 45px;
    }
    body.business .businessbox03 .ttl3{
        margin-bottom: -10px;
    }
    body.business .businessbox03 .box{
        margin-top: 30px;
        padding-left: 0;
    }
    body.business .businessbox03 .box p.img{
        position: relative;
        width: auto;
        margin-bottom: 15px;
    }
    body.business .businessbox03 .box h4{
        height: 45px;
        margin-bottom: 20px;
        padding-left: 55px;
    }    
    body.business .businessbox03 .box h4 .num{
        text-align: center;
        font-size: 30px;
    }
    body.business .businessbox03 .box p{
        font-size: 14px;
    }
    body.business .businessbox03 .box ul{
        margin-top: 15px;
    }
    body.business .businessbox04{
        width: auto;
        margin-top: 45px;
        padding: 25px 0;
    }
    body.business .businessbox04 ul{
        display: block;
        width: auto;
        margin: 0 20px;
    }
    body.business .businessbox04 li{
        width: auto;
        margin-top: 20px;
    }
    body.business #anc03{
        margin-top: 180px;
    }
    body.business .payment{
        margin-top: 30px;
    }
    body.business .payment h3{
        margin-bottom: 0;
        padding: 0 20px;
    }
    body.business .payment p{
        margin-top: 20px;
    }

    body.business .aibox01{
        padding-top: 30px;
    }
    body.business .aibox01 .img{
        position: relative;
        top: 0;
        margin-top: 35px;
    }
    body.business .businessbox01 p.connectedlead{
        padding-top: 30px;
    }
    body.business .connectedbox01{
        margin-top: 50px;
    }
    body.business .connectedbox01 .list li{
        margin-top: 80px;
    }
    body.business .connectedbox01 .list li .img{
        top: -45px;
        width: 135px;
        height: 80px;
    }
    body.business .connectedbox01 .list li .img img{
        width: 110px;
        height: 54px;
    }
    body.business .main p.lead + .plannav {
        margin-top: 20px;
    }
}

/*request*/
body.request h2{
    position: relative;
    margin-top: 120px;
    padding-top: 15px;
    text-align: center;
    font-size: var(--fs36);
    font-weight: bold;
    line-height: 1.3;
}
body.request h2 .en{
    position: relative;
    top: -15px;
    font-size: var(--fs18);
    font-weight: bold;
}
body.request h2:after{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.request .main .pbox{
    padding-top: 1px;
}
body.request .requestbox01{
    width: 836px;
    margin: 40px auto 0;
}
body.request .requestbox01 ul{
    display: flex;
    justify-content: space-between;
}
body.request .requestbox01 li{
    width: 375px;
    height: 375px;
    padding-top: 45px;
    background: #F8F8F8;
    border-radius: 40px;
    text-align: center;
    box-sizing: border-box;
}
body.request .requestbox01 li .ttl{
    margin-bottom: 25px;
    font-size: var(--fs18);
    font-weight: bold;
}
body.request .requestbox01 li .linkBtn{
    width: 280px;
    margin: 45px auto 0;
}
body.request .requestbox02 {
    margin-top: 20px;
}
body.request .requestbox02 p{
    font-size: var(--fs22);
    font-weight: bold;
}
body.request .requestbox02 ul{
    display: flex;
    flex-wrap: wrap;
    column-gap: 95px;
    margin-top: 60px;
}
body.request .requestbox02 li{
    width: 270px;
}
body.request .requestbox02 li p{
    margin-bottom: 10px;
    font-size: var(--fs12);
    font-weight: bold;
}
body.request .requestbox02 li p.ttl{
    font-size: var(--fs16);
    font-weight: normal;
}
@media screen and (max-width: 767px) {
    body.request h2{
        margin-top: 30px;
    }
    body.request h2 .en{
        top: -5px;
    }
    body.request .requestbox01{
        width: auto;
        margin: 0;
    }
    body.request .requestbox01 ul{
        display: block;
    }
    body.request .requestbox01 li{
        width: auto;
        height: auto;
        margin-top: 20px;
        padding: 20px 0;
    }
    body.request .requestbox01 li .linkBtn{
        width: 200px;
        margin-top: 20px;
    }
    body.request .requestbox01 + h2{
        font-size: 20px;
    }
    body.request .requestbox02 ul{
        width: auto;
        margin: 0;
    }
    body.request .requestbox02 li{
        margin: 20px auto 0;
    }
}



/*faq*/
body.faq .faqsearch p{
    text-align: center;
    font-size: var(--fs28);
    font-weight: bold;
}
body.faq .faqsearch p.search {
    position: relative;
    width: 764px;
    margin: 20px auto 70px;
}
body.faq .faqsearch p.search input[type=text]{
    width: 764px;
    height: 58px;
    padding: 0 70px 0 30px;
    border: 2px solid #000000;
    border-radius: 6px;
    font-size: var(--fs16);
    box-sizing: border-box;
}
body.faq .faqsearch p.search input[type=image]{
    position: absolute;
    top: 4px;
    right: 4px;
}
body.faq #wrapper{
    overflow: visible;
}
@media screen and (min-width: 768px) {
body.faq .ttl1 {
    margin-top: 0;
    padding-top: 50px;   
}
}
body.faq .category{
    display: flex;
    column-gap: 15px;
    padding-top: 64px;
    position: sticky;
    top: 140px;
    background: #fff;
    z-index: 10;
}
body.faq .category li{
    width: 215px;
}
body.faq .category li a{
    padding: 0 10px;
    justify-content: center;
}
body.faq .category li a:after {
    display: none;
}
body.faq h2{
    position: relative;
    padding-top: 90px;
    padding-bottom: 15px;
    text-align: center;
    font-size: var(--fs22);
    font-weight: bold;
    line-height: 1.3;
}
body.faq h2:after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 27px;
    height: 4px;
    margin: 0 auto;
    background: #000;
}
body.faq .ico1:before,
body.faq .ico2:before,
body.faq .ico3:before,
body.faq .ico4:before,
body.faq .ico5:before,
body.faq .ico6:before{
    content: '';
    display: inline-block;
    width: 26px;
    height: 26px;
    margin-right: 10px;
    vertical-align: middle;
}
body.faq .ico1:before{
    background: url(/faq/img/img_faq01.png) no-repeat;
}
body.faq .ico2:before{
    background: url(/faq/img/img_faq02.png) no-repeat;
}
body.faq .ico3:before{
    background: url(/faq/img/img_faq03.png) no-repeat;
}
body.faq .ico4:before{
    background: url(/faq/img/img_faq04.png) no-repeat;
}
body.faq .ico5:before{
    background: url(/faq/img/img_faq05.png) no-repeat;
}
body.faq .ico6:before{
    background: url(/faq/img/img_faq06.png) no-repeat;
}
body.faq .faqBox dl{
    width: 1000px;
    margin: 40px auto 0;
    border-bottom: 1px solid #CCCCCC;
}
body.faq .faqBox dt{
    position: relative;
    padding: 23px 85px;
    border-top: 1px solid #CCCCCC;
    font-size: var(--fs16);
}
body.faq .faqBox dt:after {
	display: block;
	content: '';
	position: absolute;
	top: 33px;
	right: 20px;
	width: 22px;
	height: 0;
	border-bottom: 2px solid #000;
	vertical-align: top;
}
body.faq .faqBox dt:before {
	display: block;
	content: '';
	position: absolute;
	top: 33px;
	right: 20px;
	width: 22px;
	height: 0;
	border-bottom: 2px solid #000;
	transform: rotateZ(-90deg);
	vertical-align: top;
}
body.faq .faqBox dt.open:before {
	display: none;
}
body.faq .faqBox dd{
    position: relative;
    display: none;
    padding: 23px 85px;
    font-size: var(--fs16);
    line-height: 1.8;
}
body.faq .faqBox dl .ico{
    position: absolute;
    top: 10px;
    left: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: #F5F5F5;
    border-radius: 100%;
    font-size: var(--fs16);
}
body.faq .faqBox dl dd .ico{
    background: #FFE6E6;
}
@media screen and (max-width: 767px) {
    body.faq .faqsearch {
        margin: 0 30px;
    }
    body.faq .faqsearch p{
        text-align: left;
        font-size: 18px;
    }
    body.faq .faqsearch p.search{
        width: 100%;
        margin-bottom: 25px;
    }
    body.faq .faqsearch p.search input[type=text]{
        width: 100%;
        height: 38px;
    }
    body.faq .faqsearch p.search input[type=image]{
        top: 3px;
        right: 3px;
        width: 32px;
        height: 32px;
    }
    body.faq .category {
        width: 314px;
        position: relative;
        top: 0;
        flex-wrap: wrap;
        column-gap: 14px;
        padding-top: 30px;
    }
    body.faq .category li{
        width: 150px;
        margin-bottom: 10px;
    }
    body.faq .category li a{
        padding: 0 10px 0 8px;
        justify-content: flex-start;
    }
    body.faq .ico1:before, body.faq .ico2:before, body.faq .ico3:before, body.faq .ico4:before, body.faq .ico5:before, body.faq .ico6:before{
        width: 22px;
        height: 22px;
        margin-right: 5px;
        background-size: contain;
    }
    body.faq h2{
        padding-top: 40px;
    }
    body.faq .faqBox dl{
        width: auto;
        margin-top: 30px;
    }
    body.faq .faqBox dt,
    body.faq .faqBox dd{
        padding-right: 45px;
        padding-left: 50px;
    }
    body.faq .faqBox dl .ico{
        left: 0;
        width: 40px;
        height: 40px;
    }
    body.faq .faqBox dt:before,
    body.faq .faqBox dt:after{
        right: 10px;
    }

}
