
body{
    overflow-x: hidden;
}
.onetrust-pc-dark-filter{
    display: none;
}
section{
    padding: 80px 0;
    position: relative;
}

section h2{
    position: relative;
    font-size: 35px;
    text-align: center;
    color: #00B7F1;
    line-height: 1em;
    padding-bottom: 50px;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    padding-bottom: 20px;
    margin-bottom: 30px;
    font-weight: normal;
}
section h2 span{
    font-size: 30px;
    display: block;
    padding: 20px 0;
}
section h2:after{
    content: "";
    width: 35px;
    height: 3px;
    background: #00B7F1;
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 10px;
}
section h2.white{
    color: white;
}
section h2.white:after{
    background: white;
}
section p.lead{
    text-align: center;
    font-size: 24px;
    color: #222!important;
    margin-bottom: 60px;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
img.alt{
    opacity: 0;
    position:absolute;
    top: 0;
    left: 0;
}

a.bt{
    font-size: 20px;
	max-width: 336px;
    margin: auto;
    text-align: center;
}
a.bt::after {
    background: url(../images/top_new/arrow.svg) no-repeat center center / 100%;
    width: 10px;
}
a.bt:hover{
    background: #7F86A7;
}

@media(max-width:767px) {
    section{
        padding: 50px 0;
        position: relative;
    }
    section h2{
        font-size: 18px;
        padding-bottom: 20px;
        margin-bottom: 25px;
    }
    section h2 span{
        font-size: 16px;
        padding: 10px 0;
    }
    section h2:after{
        width: 17px;
    }
    section p.lead{
        font-size: 14px;
        margin-bottom: 20px;
        line-height: 1.8em;
    }
    section p.lead br{
        display: none;
    }
    section p.lead br.sp_only{
        display:inline;
    }
    section#interview p.lead br{
        display: inline;
    }
    .container{
        width: auto;
        margin: 0 20px;
    }
    a.bt{
        font-size: 14px;
        max-width: 80%;
    }
}
#kv{
    width: 100%;
    overflow-x: hidden;
    /*padding: 0;*/
    position: relative;
    /*height: 620px;
    padding-top: calc(950 / 1920 * 100%);*/
    overflow: hidden;
    background: url(../images/top_new/kv_back.webp) no-repeat center top/cover;
}
.kv-loading {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    background-color: #00B7F1;
    display: grid;
    place-content: center;
    font-size: 28px;
    color: #fff;
    font-weight: normal;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
/*.kv-img {
    display: none;
}
.kv-img.slick-initialized {
    display: block;
}*/
.kv-img{
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
}
#kv .main-title{
    font-size: 108px;
    letter-spacing: 0.2em;
    color: white;
    font-weight: normal;
    font-family:'TazuganeGothicBold';
    width: 100%;
    height: 84%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left:0.5em;
}
#kv picture.scroll{
    position: absolute;
    top: 40%;
    left: 3%;
    animation: sdl01 1.5s cubic-bezier(1, 0, 0, 1) 2s infinite;
	opacity: 0;
}

@keyframes sdl01 {
	0% {
		opacity: 0;
	  transform-origin: 0 0;
      top: 30%;
	}
	100% {
		opacity: 1;
	  transform-origin: 0 100%;
      top: 35%;
	}
  }
#kv picture {
    max-width:none;
}
#kv picture img{
    width: 100%;
}
#kv picture.line1{
    position: absolute;
    top: 10%;
    left: 50%;
    transform: translateX(-50%);
    width: 105%;
}
#kv picture.people{
    position: absolute;
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
}
#kv picture.line2{
    position: absolute;
    bottom: 9%;
    left: 0;
    width: 104%;
}

@media(max-width:924px) {
    #kv .container{
        margin: 20px 15px;
        width: auto;
    }
}
@media(max-width:767px) {
    #kv{
        /*padding-top: calc(1100 / 750 * 100%);*/
    }
    .kv-img{
        height: 95%;
        overflow: hidden;
    }
    .kv-loading{
        height:100%;
    }
    #kv picture.line1 {
        top: 17%;
    }
    #kv .main-title{
        font-size: 50px;
        left: 15px;
        height: 78%;
    }
    #kv picture.scroll{
        width: 14px;
        animation: sdl02 1.5s cubic-bezier(1, 0, 0, 1) 2s infinite;
        position: absolute;
        top: 40%;
        left: 3%;
        opacity: 0;
    }
    @keyframes sdl02 {
        0% {
            opacity: 0;
          transform-origin: 0 0;
          top: 50%;
        }
        100% {
            opacity: 1;
          transform-origin: 0 100%;
          top: 55%;
        }
      }
    
    #kv picture.people{
        bottom: 8%;
        width: 87%;
    }
}
@media (max-width: 360px){
    #kv .main-title {
        font-size: 40px;
    }
}

div.kanaeyou{
    padding: 160px 0 0 0;
}
@media(max-width:767px) {
    div.kanaeyou{
        padding: 80px 0 40px 0;
    }
    div.kanaeyou p.lead{
        padding: 0 20px;
    }
}
section ul.kanaeyou-list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 94%;
    margin: auto;
    padding-top: 50px;
}
section ul.kanaeyou-list li{
    padding: 0 14px;
    height: 100%;
}
section ul.kanaeyou-list li a{
    display: block;
	border: none;
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    background: white;
}
section ul.kanaeyou-list li a div.img{
	width: 100%;
	height: 100%;
    aspect-ratio: 5.2 / 3;
    overflow: hidden;
    position: relative;
}
section ul.kanaeyou-list li.higuchi a div.img:after {
    background: url(../images/kanaeyou/yasuyuki_higuchi_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.yamaguchi a div.img:after {
    background: url(../images/kanaeyou/yukiko_yamaguchi_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.shinya a div.img:after {
    background: url(../images/kanaeyou/nobuhiro_shinya_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.matsutomo a div.img:after {
    background: url(../images/kanaeyou/marina_matsutomo_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.shigyou a div.img:after {
    background: url(../images/kanaeyou/honoka_shigyou_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.christian a div.img:after {
    background: url(../images/kanaeyou/amedayenou_trevor_christian_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.takahashi a div.img:after {
    background: url(../images/kanaeyou/hiroki_takahashi_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.yamamoto a div.img:after {
    background: url(../images/kanaeyou/mika_yamamoto_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.yiming a div.img:after {
    background: url(../images/kanaeyou/wang_yiming_th.jpg) no-repeat center top/100%;
}
section ul.kanaeyou-list li.kinoshita a div.img:after {
    background: url(../images/kanaeyou/satoshi_kinoshita_th.jpg) no-repeat center top/100%;
}

section ul.kanaeyou-list li a div.img:after{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;
	z-index: 5;
}
section ul.kanaeyou-list li a:hover div.img:after{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}

section ul.kanaeyou-list li a span{
    display: block;
    width: 100%;
    background: white;
	z-index: 10;
    padding: 20px 0;
}
section ul.kanaeyou-list li a div.txt{
    padding: 20px;
    background-color: white;
    height: 145px;
}
section ul.kanaeyou-list li a p{
    line-height: 1.4em;
}
section ul.kanaeyou-list li a p.post{
    font-size: 14px;
    height: 3em;
    line-height: 1.2em;
}
section ul.kanaeyou-list li a p.post.sp_only{
    display: none;
}
section ul.kanaeyou-list li.christian a p.post{
    height: 2em;
}
section ul.kanaeyou-list li a p.name{
    font-size: 24px;
    padding-bottom: 0;
    font-family: 'SyntaxNextBold','TazuganeGothicBold';
}
section ul.kanaeyou-list li.christian a p.name{
    letter-spacing: -0.02em;
    line-height: 1.2em;
}
section ul.kanaeyou-list li a p.name2{
    font-size: 16px;
    /*color: #00B7F1;*/
    padding-bottom: 0;
    font-family: 'SyntaxNextBold','TazuganeGothicBold';
    position: absolute;
    bottom: 20px;
    left: 20px;
}
.bt-wrap{
    padding-top: 40px;
}

@media(min-width:1945px) {
    section ul.kanaeyou-list li.christian a p.post{
        height: 3em;
    }
    section ul.kanaeyou-list li.christian a p.name{
        line-height: 1.4em;
    }
}
@media(max-width:1270px) {
    section ul.kanaeyou-list li{
        padding: 0 6px;
    }
    section ul.kanaeyou-list li a p.post.pc_only{
        display: none;
    }
    section ul.kanaeyou-list li a p.post.sp_only{
        display: flex;
    }
}
@media(max-width:1024px) {
    section ul.kanaeyou-list li a p.post{
        font-size: 12px;
    }
    section ul.kanaeyou-list li a p.name{
        font-size: 20px;
    }
    section ul.kanaeyou-list li.christian a p.name{
        font-size: 18px;
    }
}

@media(max-width:767px) {
    p.sp_only{
        display: block;
    }
    section ul.kanaeyou-list{
        width: 90%;
        padding-top: 10px;
    }
    section ul.kanaeyou-list li a div.txt{
        padding: 10px;
    }
    section ul.kanaeyou-list li{
        padding: 0 5px;
    }
    section ul.kanaeyou-list li a p.post{
        font-size: 11px;
        height: 2.4em;
    }
    section ul.kanaeyou-list li a p.post.pc_only{
        display: none;
    }
    section ul.kanaeyou-list li a p.post.sp_only{
        display: flex;
    }
    section ul.kanaeyou-list li.christian a p.post{
        height: auto;
    }
    section ul.kanaeyou-list li.christian a p.name,
    section ul.kanaeyou-list li a p.name{
        font-size: 14px;
    }
    section ul.kanaeyou-list li.christian a p.name{
        letter-spacing: -0.04em;
    }
    section ul.kanaeyou-list li a p.name2{
        font-size: 11px;
        line-height: 1.2em;
        bottom: 10px;
        left: 10px;
    }
    section ul.kanaeyou-list li.christian a p.name2{
        letter-spacing: -0.05em;
    }
    section ul.kanaeyou-list li a div.txt{
        height: 80px;
    }
}

.slick-prev, .slick-next{
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    width: 40px;
    height: 40px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    z-index: 10;
}
.slick-next{
    right: -28px;
}
.slick-prev{
    left: -20px;
}
.slick-prev:before,
.slick-next:before{
    content: "";
    width:35px;
    height:35px;
    border-top: solid 2px white;
    border-right: solid 2px white;
    transform: rotate(45deg);
    position: absolute;
    right: 5px;
    top: 5px;
    opacity: 1;
}
.slick-prev:before{
    transform: rotate(-135deg);
}
@media(max-width:1270px) {
    .slick-prev, .slick-next{
        width: 25px;
        height: 25px;
    }
    .slick-next{
        right: -25px;
    }
    .slick-prev{
        left: -15px;
    }
    .slick-prev:before,
    .slick-next:before{
        width:25px;
        height:25px;
    }
}

@media(max-width:767px) {
    .slick-prev, .slick-next{
        width: 25px;
        height: 25px;
    }
    .slick-next{
        right: -15px;
    }
    .slick-prev{
        left: -15px;
    }
    .slick-prev:before,
    .slick-next:before{
        width:15px;
        height:15px;
    }
    
}


#come-true{
    background: url(../images/top_new/intro_back.webp) no-repeat center top/cover;
    position: relative;
    padding-top: 0;
    /* transition: all 1s ease-out; */
}
#come-true .container{
    display: flex;
    justify-content: center;
}
#come-true p.come-true{
    margin-top: -30px;
    font-size: 26px;
    color: white;
    line-height: 2em;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    letter-spacing: 0.06em;
}

@media(max-width:767px) {
    #come-true{
        padding-bottom: 0;
        background:#01B7F1 url(../images/top_new/intro_back.webp) no-repeat center bottom/120%;
        margin-top: -1px;
    }
    #come-true .container{
        position: relative;
    }
    #come-true p.come-true{
        margin-top: 0px;
        font-size: 15px;
    }
}

#project{
    background: url(../images/top_new/project_back.webp) no-repeat center top/cover;
}
#project ul.project{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 50px 0;
}
#project ul.project li{
    width: 48%;
}
#project ul.project li a{
    display: block;
}
#project ul.project li a div.img{
	width: 95%;
	height: 100%;
    position: relative;
    margin-left: 5%;
    z-index: 1;
    aspect-ratio: 5.2 / 3;
    overflow: hidden;
    position: relative;
}
#project ul.project li a div.img:after{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;
	z-index: 5;
}
#project ul.project li a:hover div.img:after{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}
#project ul.project li:nth-of-type(1) a div.img:after{
    background: url(../images/top_new/project1.jpg) no-repeat center top/100%;
}
#project ul.project li:nth-of-type(2) a div.img:after{
    background: url(../images/top_new/project2.jpg) no-repeat center top/100%;
}

#project ul.project li .txt{
    position: relative;
    width: 80%;
    background: white;
    padding: 30px 20px;
    font-size: 18px;
    margin-top: -30px;
    z-index: 10;
}
#project ul.project li .txt h3{
    font-size: 22px;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    padding-bottom: 10px;
    font-weight: normal;
}
@media(max-width:767px) {
    #project ul.project{
        padding: 20px 0;
    }
    #project ul.project li{
        width: 100%;
        margin-bottom: 30px;
    }
    #project ul.project li .txt h3{
        font-size: 15px;
    }
    #project ul.project li .txt{
        font-size: 14px;
        width: 92%;
        padding: 20px 20px;
    }
}

.job-back{
    /*background: url(../images/top_new/job_back.webp) no-repeat center top/cover;*/
}

#job{
    /*background: #F2F2F2;*/
    background: #fff;
}
.about-work-tab{
    padding-top: 50px;
}
#job .c-tab-contents{
    padding: 40px 0;
    background: none;
}
#job .c-tab-nav-item{
    width: 50%;
    padding: 0;
}
#job .c-tab-nav-item a {
    font-size: 24px;
    letter-spacing: 0;
    color: #000000;
    padding: 0 0 16px 0;
    border: none;
    border-bottom: 11px solid #fff;
    background-color: transparent;
    border-radius: 0;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
#job .c-tab-nav-item a[aria-selected=true]{
    color: #00B7F1;
    border-bottom: 11px solid #00B7F1;
}
#job ul.job-list{
    display: flex;
    flex-wrap: wrap;
    gap: 20px 1.3%;
}
#job ul.job-list li{
    width: 24%;
}
#job ul.job-list li.wide{
    width: 49.4%;
}
#job ul.job-list li a{
    display: block;
    border: 2px solid #000E4E;
    padding: 15px;
    text-align: center;
    color: #000E4E;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    position: relative;
    border-radius: 60px;
    background-color: white;
    font-size: 16px;
    line-height: 1em;
	transition: all 0.5s ease-out;
}
#job ul.job-list li a:hover{
    background: #00B7F1;
    color: white;
	transition: all 0.5s ease-out;
}
#job ul.job-list li a:after{
        content: "";
        width: 12px;
        height: 12px;
        border-top: solid 1px #00B7F1;
        border-right: solid 1px #00B7F1;
        transform: rotate(45deg) translateY(-50%);
        position: absolute;
        right: 20px;
        top: 46%;
        opacity: 1;
}
#job ul.job-list li a:hover:after{
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
}
@media(max-width:767px) {
    .about-work-tab{
        padding-top: 20px;
    }
    #job .c-tab-nav-item a {
        font-size: 16px;
        border-bottom: 4px solid #fff;
    }
    #job .c-tab-nav-item a[aria-selected=true]{
        border-bottom: 4px solid #00B7F1;
    }
    #job ul.job-list li,
    #job ul.job-list li.wide{
        width: 100%;
    }
}
#business .c-section-container{
    width: 100%;
}

#interview{
    position: relative;
    padding-top: 40px;
}
#interview .container{
    width: 662px;
    height: 662px;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    color: white;
    text-align: center;
}
#interview .container >div{
    z-index: 5;
}
#interview .container:before{
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 662px;
    height: 662px;
    border-radius: 50%;
    background: #00B7F1;
    z-index: 0;
}
#interview picture{
    width: 38%;
}
#interview picture img{
    z-index: 10;
    position: relative;
}
#interview picture.emp1{
    position: absolute;
    top: 0;
    left: 0%;
}
#interview picture.emp2{
    position: absolute;
    top: 0;
    right: 0%;
}
#interview p.lead{
    color: white!important;
    font-size: 22px;
}


#interview a.bt{
    max-width: 280px;
    margin-top: 20px;
}
@media(max-width:1669px) {
    #interview .container{
        width: 622px;
        height: 622px;
    }
    #interview .container:before{
        width: 622px;
        height: 622px;
    }
}
@media(max-width:1380px) {
    #interview picture{
        width: 35%;
    }
}
@media(max-width:1168px) {
    #interview picture{
        width: 32%;
    }
    #interview picture.emp2 {
        top: auto;
        bottom: 40px;
    }
}

@media(max-width:767px) {
    #interview{
        overflow-x: hidden;
        overflow-y: visible;
        padding-top: 300px;
        padding-bottom: 280px;
    }
    #interview .container{
        width: auto;
        height: 476px;
    }
    #interview .container:before{
        width: 476px;
        height: 476px;
        left: 50%;
        transform: translateX(-50%);
    }

    #interview p.lead{
        font-size: 14px;
    }
    #interview p.lead br{
        display: none;
    }
    #interview picture{
        width: 120%;
    }
    #interview picture.emp1{
        top: 0px;
        left: -10%;
    }
    #interview picture.emp2{
        top: auto;
        bottom: 0px;
        right: -15%;
    }
}
@media(max-width:375px) {
    #interview{
        padding-top: 270px;
        padding-bottom: 240px;
    }
    #interview picture {
        width: 110%;
    }
}

#technology{
    background: white;
}

#technology ul.tech-list{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#technology ul.tech-list li{
    width: 48%;
    margin-bottom: 40px;
}
#technology ul.tech-list li a{
    display: block;
    padding: 60px 0;
    color: white;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    position: relative;
    overflow: hidden;
    position: relative;
}

#technology ul.tech-list li a:before{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;
	z-index: 0;
}
#technology ul.tech-list li a:hover:before{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}
#technology ul.tech-list li:nth-last-of-type(1) a:before{
    background: url(../images/top_new/tech4.webp) no-repeat left center/cover;
}
#technology ul.tech-list li:nth-last-of-type(2) a:before{
    background: url(../images/top_new/tech3.webp) no-repeat left center/cover;
}
#technology ul.tech-list li:nth-last-of-type(3) a:before{
    background: url(../images/top_new/tech2.webp) no-repeat left center/cover;
}
#technology ul.tech-list li:nth-last-of-type(4) a:before{
    background: url(../images/top_new/tech1.webp) no-repeat left center/cover;
}
#technology ul.tech-list li a h3{
    background: rgba(35 190 239/0.5);
    width: 50%;
    padding: 20px;
    color: white;
    font-size: 22px;
    margin-bottom: 20px;
    z-index: 2;
    position: relative;
}
#technology ul.tech-list li a ul{
    margin-left: 50px;
    z-index: 2;
}
#technology ul.tech-list li a ul li{
    margin-bottom: 10px;
    position: relative;
    font-size: 18px;
    width: 100%;
}
#technology ul.tech-list li a ul li:before{
    content: "・";
}

@media(max-width:767px) {
    #technology ul.tech-list li{
        width: 100%;
    }
    #technology ul.tech-list li a{
        padding: 30px 0;
    }
    #technology ul.tech-list li a h3{
       font-size: 16px;
       width: 55%;
    }
    #technology ul.tech-list li a ul{
        margin-left: 20px;
    }
    #technology ul.tech-list li a ul li{
        font-size: 14px;
    }
    #technology ul.tech-list li:last-child{
        margin-bottom: 0;
    }
}

#info-graph {
   background: #F2F2F2;
    background: linear-gradient(180deg,rgba(242, 242, 242, 1) 0%, rgba(255, 255, 255, 1) 15%);
}
#info-graph .row .data h2{
    font-weight:normal;
}
#info-graph .row{
    margin-bottom: 50px;
}
#info-graph .row .data{
    width: 31.6%;
    padding: 30px;
    margin-bottom: 30px;
    background: white;
    filter: drop-shadow(0px 4px 5px rgba(0,0,0,0.1)) drop-shadow(7px 6px 6px rgba(0,0,0,0.1));
    
}
#info-graph .row .data2 > div p strong {
    font-size: 27px;
}
#info-graph .row .data7 > div img{
    padding-bottom: 15px;
}
#info-graph .row .data7 > div.row{
    padding-top: 30px;
}
#info-graph .row .data > div{
    width: 272px;
    height: 280px;
}
#info-graph .row .data13 > div {
    background-size: 90%;
}
#info-graph .row .data16 > div,
#info-graph .row .data15 > div{
    height: 260px;
}
#info-graph .data16 > div img{
    margin:20px auto 40px auto;
}
#info-graph .data15 .row p strong {
    font-size: 44px;
}
#info-graph .data16 p strong {
    font-size: 44px;
}
#info-graph .row .data8 > div p strong {
    font-size: 19px;
}
#info-graph .row .data8 > div p.y2020{
    top: 54%;
}
#info-graph .row .data8 > div p.y2021 {
    left: 34%;
    top: 20%;
}
#info-graph .data16 p, #info-graph .data15 .row p{
    padding: 0 16px;
}

#info-graph .row .data13 > div p.woman {
  position: absolute;
  left: -10%;
    top: -8%;
    text-align: center;
    font-size: 18px;
  line-height: 1.4em;
}
#info-graph .row .data13 > div p.man {
  position: absolute;
  right: -10%;
  bottom: -1%;
  text-align: center;
  font-size: 18px;
  line-height: 1.4em;
}

@media screen and (max-width: 640px) {
    #info-graph .row .data8 > div p.y2021 {
        top: 21%;
    }
}
#info-graph .row .data8 > div p.y2022 {
    left: 56%;
    top: 14%;
}
#info-graph .row .data8 > div p.y2023 {
    top: 15%;
}
#info-graph .row .data h2{
    margin-bottom: 0;
}
#info-graph .row .data h2:after{
    display: none;
}
@media(max-width:1099px) {
    #info-graph .row .data{
        width: 48%;
        margin-bottom: 20px;
    }
}

@media(max-width:767px) {
    #info-graph .row .data{
        width: 100%;
        margin-bottom: 20px;
    }
    #info-graph .row{
        margin-bottom: 20px;
    }
}

#environment{
    background:url(../images/top_new/career_back.webp) no-repeat center center/cover;
    transition: all 1s ease-out;
}
ul.environment {
    display: flex;
    justify-content:center;
    flex-wrap: wrap;
}
ul.environment  li{
    width: 45%;
    margin: 0 1%;
    background: rgba(255 255 255/1);
    filter: drop-shadow(0px 4px 5px rgba(0, 0, 0, 0.1)) drop-shadow(7px 6px 6px rgba(0, 0, 0, 0.1));
}
ul.environment  li a{
    display: block;
    color: #222;
    position: relative;
}
ul.environment li.first{
    width: 100%;
    margin-bottom: 50px;
}
ul.environment li.first a{
    display: flex;
}
ul.environment  li a div.img{
    position: relative;
    overflow: hidden;
    position: relative;
    aspect-ratio: 5.2 / 2.5;
}
ul.environment li.first div.img{
    width: 50%;
}
ul.environment  li a div.img:before{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;
	z-index: 0;
}
ul.environment li a:hover div.img:before{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}
ul.environment li:nth-of-type(1) a div.img:before{
    background: url(../images/hr/recruit_kv1.jpg) no-repeat left center/cover;
}
ul.environment li:nth-of-type(2) a div.img:before{
    background: url(../images/environment/environment/recruit_kv2.jpg) no-repeat left center/cover;
}
ul.environment li:nth-of-type(3) a div.img:before{
    background: url(../images/women/recruit_kv3.jpg) no-repeat left center/cover;
}

ul.environment  li a .txt{
    padding: 30px;
    font-size: 18px;
}
ul.environment li.first a .txt{
    width: 50%;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
ul.environment  li a .txt h3{
    font-size: 22px;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    padding-bottom: 10px;
    font-weight: normal;
}

@media(max-width:767px) {
    #environment{
        background:url(../images/top_new/career_back_sp.webp) no-repeat center center/cover;
    }
    ul.environment {
        padding-top: 20px;
    }
    ul.environment li.first,
    ul.environment  li{
        width: 100%;
        margin-bottom: 40px;
    }
    ul.environment  li a .txt{
        padding: 20px;
        font-size: 14px;
    }
    ul.environment li.first a{
        display: block;
    }
    ul.environment li.first div.img{
        width: 100%;
    }
    ul.environment li.first a .txt{
        width: 100%;
    }
    ul.environment  li a .txt h3{
        font-size: 16px;
        font-family:'SyntaxNextBold','TazuganeGothicBold';
        padding-bottom: 10px;
    }
}
@media(max-width:480px) {
}

#environment a.dei{
	display: block;
	position: relative;
	width: 50%;
	margin: 50px auto;
	padding: 30px;
    padding-top: 160px;
	color: #000E4E;
	font-weight: normal;
    font-family:'SyntaxNextBold','TazuganeGothicBold';;
	border-radius: 20px;
    font-size: 15px;
    text-align: center;
    background: white;
    overflow: hidden;
}
#environment a.dei:before{
    content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
    background: url(../images/common/dei-banner.jpg) no-repeat center 20px/100%;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;
	z-index: 0;
}
#environment a.dei:hover:before{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}

#environment a.dei div.title{
	font-size: 30px;
	font-weight: normal;
    font-family:'SyntaxNextBold','TazuganeGothicBold';;
	position: relative;
	margin-bottom: 10px;
}

@media(max-width:767px) {
    #environment a.dei{
        width: 100%;
    }
}
@media(max-width:480px) {
    #environment a.dei{
        width: 100%;
        background:white;
        padding: 20px;
        padding-top: 135px;
        font-size: 12px;
        margin: 0 auto;
    }
    #environment a.dei:before{
        background: url(../images/common/dei-banner_sp.jpg) no-repeat;
        background-position: center 20px;
        background-size: 90%;
    }
    #environment a.dei div.title{
        font-size: 16px;
    }
}

#company{
    padding: 0;
}
#company div.back{
    display: block;
    padding: 80px 0;
    position: relative;
    overflow: hidden;
}
#company div.back:before{
    content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
    background: url(../images/top_new/company.webp) no-repeat center center/cover;
	top: 0;
	left: 0;
	/*-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	-ms-transition: all .3s ease-out;
	transition: all .3s ease-out;*/
	z-index: 0;
}
/*#company a:hover:before{
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}*/

#company a.bt{
	display: block;
	min-width: 260px;
    max-width: 330px;
    margin: auto;
	color:#000E4E;
	background: white;
	padding: 15px 25px;
	border-radius: 40px;
	text-align: left;
	letter-spacing: 0.06em;
	position: relative;
	font-size: 20px;
    text-align: center;
	font-family: 'SyntaxNextBold','TazuganeGothicBold';
	transition: all 0.5s ease-out;
}
#company a.bt::after{
	content: "";
	display: block;
	position: absolute;
	background: url(../images/common/link_blue.svg) no-repeat center center/100%;
	height: 100%;
	width: 17px;
	right: 20px;
	top: 0;
}
@media (max-width: 767px) {
    #company a.bt {
        font-size: 14px;
        max-width: 80%;
    }
}
#company a.bt:hover{
	background: #7F86A7;
	transition: all 0.5s ease-out;
}

#company p.lead{
    color: white!important;
    padding-top: 20px;
    margin-bottom: 40px;
}
#company iframe{
    display: block;
    width: 640px;
    height: 359px;
    margin: 40px auto 0px auto;
    border: none!important;
}
@media(max-width:767px) {
    #company{
        background-size:480%;
    }
    #company div.back{
        padding: 40px 0;
    }
    #company p.lead{
        padding-top: 0;
    }
    #company iframe{
        width: 320px;
        height: 179px;
        margin: 20px auto;
        border: none!important;
    }
}

#news .container{
}

#news .container ul.news{
    border-top: 1px solid #01B7F1;
}
#news .container ul.news li.hidden{
    display: none;
}
.employee-more {
    text-align: center;
    padding-top: 30px;
  }
  .employee-more-button {
    font-size: 1.125rem;
    text-align: center;
    display: grid;
    place-content: center;
    place-items: center;
    gap: 5px;
    border: 0;
    background: none;
    margin: 0 auto;
    cursor: pointer;
    color: #0F55C1;
  }

.news-more-button{
    display:inline-block;
    border: 1px solid #000E4E;
    padding: 15px;
    text-align: center;
    color: #000E4E;
    position: relative;
    border-radius: 60px;
    background-color: white;
    font-size: 16px;
    line-height: 1em;
    transition: all 0.5s ease-out;
    cursor: pointer;
}
.news-more-button:hover{
    background: #000E4E;
    color: white;
    transition: all 0.5s ease-out;
}
.news-more-button::after {
    content: "";
    padding: 0;
    display: inline-block;
    width: 10px;
    height: 10px;
    border-right: 2px solid #000E4E;
    border-bottom: 2px solid #000E4E;
    transform: rotate(45deg) translateX(-2px);
    margin: 0 0px 0 12px;
}
.news-more-button:hover::after{
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
}

  @media screen and (max-width: 767px) {
    .employee-more-button {
      font-size: 0.875rem;
    }
  }
  .employee-more-button::after {
    content: "";
    padding: 0;
    display: inline-block;
    width: 10px;
    height: 10px;
    border-right: 2px solid #00B7F1;
    border-bottom: 2px solid #00B7F1;
    transform: rotate(45deg) translateX(-2px);
    margin: 0 14px 0 12px;
  }
#news .container ul.news li a{
    padding: 30px 0;
    display: flex;
    border-bottom: 1px solid #01B7F1;
    justify-content: space-between;
    flex-wrap: wrap;
}
#news .container ul.news li a:hover{
    background: #E5F7FD;
}
#news .container ul.news li a div.img{
    width: 20%;
    position: relative;
    height: auto;
    display: flex;
}
#news .container ul.news li a div.img.sp_only{
    display: none;
}
#news .container ul.news.document li a div.img{
    width: 128px;
    height: 72px;
}
#news .container ul.news li a div.img img{
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
#news .container ul.news li a div.cont{
    width: 75%;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#news .container ul.news li a div.cont span{
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
#news .container ul.news li a div.cont div.title{
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 10px;
    border-bottom: 1px dashed #CECECE;
    margin-bottom: 10px;
    width: 100%;
}
#news .container ul.news li a div.cont div.title time{
    width: 16em;
    text-align: right;
    padding-left: 1em;
    color: #919191;
    font-size: 16px;
}
#news .container ul.news li a div.cont div.title p{
    font-size: 18px;
}

#news .container ul.news li a div.cont p{
    width: 100%;
    padding-top: 20px;
}
#news .container ul.news.document li a div.cont p{
    padding-top: 0;
}

@media(max-width:767px) {
    #news .container{
        padding-bottom: 0px;
    }
    #news .container ul.news li a{
        position: relative;
        padding: 20px 0;
    }
    #news .container ul.news li a div.img.pc_only{
        display: none;
    }
    #news .container ul.news li a  div.sublead div.img.sp_only{
        display: block;
        width: 40%;
    }
    #news .container ul.news li a div.cont{
        width: 100%;
        display: block;
    }
    #news .container ul.news li a div.cont div.title{
        width: 100%;
        display: block;
        font-size: 14px;
    }
    #news .container ul.news li a div.cont div.title time{
        width:auto;
        display: block;
        text-align: left;
        padding-left: 0em;
        font-size: 14px;
    }
    #news .container ul.news li a div.cont div.sublead{
        display: flex;
        justify-content: space-between;
        padding-top: 10px;
    }
    #news .container ul.news li a div.cont div.sublead p{
        width: 58%;
        font-size: 14px;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 4;
        padding-top: 0;
        min-height: 5em;
    }
}

#talent{
    background: white;
    padding-top: 0;
}
#talent a.talent-banner{
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 30px;
    width: 100%;
    max-width: 880px;
    margin: auto;
    background:url(../images/talentcommunity/h1-bg.jpg) no-repeat right bottom/cover;
    color: white;
    letter-spacing:0;
    height: 180px;
    font-size: 40px;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
#talent a.talent-banner br.middle{
    display: none;
}
#talent a.talent-banner br.sp_only{
    display: none;
}
#talent a.talent-banner small{
    font-size: 16px;
    display: block;
    color:#00B7F1
}
@media screen and (max-width: 889px) {
    #talent a.talent-banner{
        line-height: 1.2em;
    }
    #talent a.talent-banner br.middle{
        display: inline;
    }
}

@media screen and (max-width: 767px) {
    #talent a.talent-banner {
        width: 100%;
        background-image: url(../images/talentcommunity/h1-bg-sp.png);
        font-size: 1.45rem;
        line-height: 1.75rem;
        height: 156px;
        padding: 14px;
    }
    #talent a.talent-banner br.sp_only{
        display: inline;
    }
    #talent a.talent-banner small{
        font-size: 0.75rem;
        line-height: 1.25rem;
        margin-top: 5px;
    }
  }

#sns{
    background: rgba(1 183 241/0.1);
}
#sns h2 span{
    font-size: 33px;
}
ul.sns-ic{
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    padding: 40px 0 0 0;
    margin: auto;
}

ul.sns-ic li{
    padding: 0 15px;
    display: flex;
    align-items:center;
}
ul.sns-ic li img{
    width: 50px;
    height: 50px;
}
@media(max-width:767px) {
    div.sns{
        padding: 40px 0;
    }
    ul.sns-ic{
        padding: 0;
    }
    ul.sns-ic li{
        padding: 0 10px;
    }
    ul.sns-ic li img{
        width: 40px;
    }
    ul.sns-ic li:nth-of-type(4) img{
        width: 55px;
    }
}

#gemba{
    text-align: center;
    width: 100%;
    font-size: 24px;
    line-height: 2em;
    text-align: center;
    color: #000E4D;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
}
/*#gemba img{
    width: 60%;
    display: block;
    margin: auto;
}*/
div.gemba a:hover:after{
    opacity: 1;
}
#gemba a{
    width: 60%;
    display: block;
    max-width: 600px;
    margin: 20px auto;
    position: relative;
}
#gemba a img{
    width: 100%;
}
#gemba a:after{
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 2px solid #0063CC;
    opacity: 0;
    transition: all 0.5s ease-out;
}
#gemba a:hover:after{
    opacity: 1;
}


@media(max-width:767px) {
    #gemba{
        font-size: 14px;
    }
    #gemba img{
        width: 80%;
    }
}

#entry{
    background: url(../images/top/recruit-info-bg.jpg) no-repeat center center/cover;
}
#entry h2,
#entry h2 small{
    text-align: center;
    color: white;
}
#entry div.row{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#entry div.row > div{
    width: 48%;
    padding: 30px 70px;
}
#entry div.row > div h3{
    font-size: 28px;
    padding-bottom: 30px;
    color: white;
}
#entry div.row > div ul li{
    padding-bottom: 20px;
}
#entry div.row > div ul li a.bt{
    font-size: 18px;
    font-weight: normal;
    font-family:'SyntaxNextBold','TazuganeGothicBold';
    padding: 20px 30px;
}
#entry div.row > div ul li a.bt:hover{
    background: #0063CC;
}
#entry div.row > div ul li a.bt::after{
    right: 30px;
}
#entry div.row > div ul li a.bt:hover::after{
    right:20px
}
#entry div.row > div ul li a[target="_blank"].bt:hover::after{
    right: 30px;
}
#entry p{
    padding-bottom: 20px;
    color: white;
    text-align: center;
    font-size: 12px;
}

@media(max-width:900px) {
    #entry div.row > div{
        padding: 30px 50px;
    }
}

@media(max-width:767px) {
    #entry div.row > div h3{
        font-size: 18px;
        padding-bottom: 10px;
    }
    #entry div.row > div{
        width: 90%;
        padding: 0px;
        margin: auto;
        margin-bottom: 20px;
    }
    #entry div.row > div ul li a.bt{
        font-size: 16px;
    }
}



#connecters-voice{
    padding: 0;
}

#connecters-voice .flex{
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 0px;
  }
  #connecters-voice .flex>div,
  #connecters-voice .flex>img{
    width: 550px;
    height: 346px;
    box-sizing: border-box;
  }
  #connecters-voice .flex>div{
    display: flex;
    flex-direction: column;
    justify-content: center;
     background: #E9F2F8;
     border: 3px solid white;
     padding: 40px;
     box-sizing: border-box;
  }
  #connecters-voice .flex>div .graduate-h2{
    margin-bottom: 20px;
  }
  #connecters-voice .flex>div p{
    font-size: 22px;
    padding-bottom: 30px;
    font-family: "SyntaxNextBold", "TazuganeGothicBold";
  }
  #connecters-voice .flex>div a.bt{
    max-width: 280px;
  }
  #connecters-voice .flex>img{
    margin-top: 30px;
    /*border:8px solid #E9F2F8;*/
    background: white;
    object-fit: contain;
  }
  #connecters-voice .flex>img.business{
    object-fit: cover;
  }
  @media screen and (max-width: 767px) {
    #connecters-voice{
        padding-top: 40px;
    }
    #connecters-voice .flex{
      flex-direction: column-reverse;
      margin-bottom: 30px;
    }
    #connecters-voice .flex>div,
    #connecters-voice .flex>img{
      width: 300px;
      height: 210px; 
    }
  
    #connecters-voice .flex>div{
      height: auto;
      padding: 40px;
    }
    #connecters-voice .flex>img{
      margin-right: calc(100% - 300px);
      margin-top: 0;
      border:none;
    }
    #connecters-voice .flex>div{
      margin-left: calc(100% - 300px);
    }
    #connecters-voice .flex>div a.bt{
        max-width: 100%;
        width: 100%;
    }
    #connecters-voice .flex>div p{
      font-size: 13px;
      padding-bottom: 20px;
    }
  }