@charset "utf-8";
/*-----------------------------------------------
    header
-----------------------------------------------*/
#header .boxLogo{
    display: flex;
    align-items: center;
    gap: 2rem;
}
#header .boxLogo .txt{
    font-size: var(--pcFS13);
}
@media only screen and (max-width:1780px){
    #header .boxLogo .txt{
        font-size: var(--pcFS12);
        line-height: var(--pcLH12_18);
    }
    #header .boxLogo .brSp{
        display: block;
    }
}
@media only screen and (max-width:1215px){
    /* boxLogo */
    #header .boxLogo{
        gap: 0.5rem;
        align-items: flex-start;
        flex-direction: column;
    }
    #header .boxLogo .txt{
        text-align: center;
        font-size: var(--spFS10);
        line-height: var(--spLH10_15);
    }
}
/*-----------------------------------------------
    secHero
-----------------------------------------------*/
.secHero{
    position: relative;
	overflow: hidden;
}
/* swiper-slide */
.secHero .swiper-slide{
	height: 93rem;
    max-height: 100vh;
	position: relative;
	overflow: hidden;
	background-color: var(--whiteColor);
}
.secHero .swiper-slide .img{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
.secHero .swiper-slide-active .img,
.secHero .swiper-slide-duplicate-active .img,
.secHero .swiper-slide-prev .img{
	animation: zoomUp 11s linear 0s 1 normal both;
	-webkit-animation: zoomUp 11s linear 0s 1 normal both;
}
@keyframes zoomUp {
	0% {
		transform: scale(1);
		-webkit-transform: scale(1);
	}
	100% {
		transform: scale(1.15);
		-webkit-transform: scale(1.15);
	}
}
@-webkit-keyframes zoomUp {
	0% {
		transform: scale(1);
		-webkit-transform: scale(1);
	}
	100% {
		transform: scale(1.15);
		-webkit-transform: scale(1.15);
	}
}
@media only screen and (max-width:1215px){
	.secHero .swiper-slide{
        max-height: none;
        height: 66.7rem;
	}
}

/* secHeroTit */
.secHeroTit{
    position: absolute;
    bottom: 8.4rem;
    right: 0;
    left: 0;
    margin: auto;
    z-index: 1;
    display: flex;
    align-items: center;
}
.secHeroTit .wrapper{
    position: relative;
}
.secHeroTit .txt{
    font-size: var(--pcFS46);
    line-height: var(--pcLH46_80);
    letter-spacing: var(--pcLS46_100);
    color: var(--whiteColor);
    font-style: italic;
}
@media only screen and (max-width:1215px){
    .secHeroTit{
        top: 12rem;
        bottom: auto;
        right: auto;
        width: 100%;
    }
    .secHeroTit .wrapper{
        left: 3rem;
    }
    .secHeroTit .wrapper .img{
        width: 10.6rem;
    }
}

/* secHeroNews */
.secHeroNews{
    position: absolute;
    bottom: 5rem;
    right: 5rem;
    z-index: 2;
}
.secHeroNews .link{
    width: 56rem;
    background-color: var(--blackColor_50);
    color: var(--whiteColor);
    border-radius: 1rem;
    padding: 3.8rem 9rem 3.8rem 5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.secHeroNews .link .txt{
    color: var(--grayColor);
    font-size: var(--pcFS16);
    line-height: var(--pcLH16_28);
    letter-spacing: var(--pcLS16_50);
}
.secHeroNews .link .tit{
    font-size: var(--pcFS18);
    line-height: var(--pcLH18_28);
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    overflow: hidden;
    max-height: calc(var(--pcFS18) * var(--pcLH18_28) * 2);
}
@media only screen and (max-width:1215px){
    .secHeroNews{
        bottom: 1rem;
        right: 0;
        left: 0;
        margin: auto;
    }
    .secHeroNews .link{
        width: 100%;
        border-radius: 0.8rem;
        padding: 1.4rem 8rem 1.4rem 2rem;
    }
    .secHeroNews .link .txt{
        font-size: var(--spFS11);
        line-height: var(--spLH11_15);
        letter-spacing: var(--spLS11_50);
    }
    .secHeroNews .link .tit{
        font-size: var(--spFS12);
        line-height: var(--spLH12_18);
        max-height: calc(var(--spFS12) * var(--spLH12_18) * 2);
    }
}

/*-----------------------------------------------
    secConcept
-----------------------------------------------*/
.secConcept{
    position: relative;
    background: calc(52% + 31rem) bottom / 30.1rem 14.3rem no-repeat,var(--whiteColor);
    padding-bottom: 14rem;
}
.secConcept.lazyloaded{
    background-image: url(../img/index/bgConcept.png);
}
.secConcept::before,
.secConcept::after{
    position: absolute;
    content: '';
    margin: auto;
    display: block;
    width: 61.4rem;
    height: 36rem;
    background: right top / cover no-repeat;
}
.secConcept::before{
    top: 0;
    right: 0;
}
.secConcept::after{
    bottom: 0;
    left: 0;
    width: 46.2rem;
    height: 27.2rem;
}
.secConcept.lazyloaded::before{
    background-image: url(../img/index/bgConceptTop.png);
}
.secConcept.lazyloaded::after{
    background-image: url(../img/index/bgConceptBottom.png);
}
.secConcept .wrapper{
    padding: 14rem 0 0 14rem;
}
.secConcept .txtTit{
    font-size: var(--pcFS80);
    letter-spacing: var(--pcLS80_100);
    font-style: italic;
    margin-left: -2rem;
}
.secConcept .txt{
    position: relative;
    font-size: var(--pcFS22);
    line-height: var(--pcLH22_50);
    font-weight: bold;
    margin-top: 4.3rem;
    font-style: italic;
    z-index: 1;
}
.secConcept .txt .in{
    display: block;
}
.secConcept .in + .in{
    margin-top: 2.8rem;
}
@media only screen and (max-width:1215px){
    .secConcept{
        background: calc(20% + 15.5rem) bottom/ 15.4rem 7.5rem no-repeat;
        padding-bottom: 16rem;
    }
    .secConcept::before{
        width: 20.4rem;
        height: 12rem;
    }
    .secConcept::after{
        width: 15.3rem;
        height: 9rem;
    }
    .secConcept.lazyloaded::before{
        background-image: url(../img/index/bgConceptTop_sp.png);
    }
    .secConcept.lazyloaded::after{
        background-image: url(../img/index/bgConceptBottom_sp.png);
    }
    .secConcept .wrapper{
        flex-direction: column;
        padding: 8.5rem 0 0 0;
    }
    .secConcept .img{
        position: relative;
        width: 12.6rem;
        margin: 0 0 0 4rem;
    }
    .secConcept .txtTit{
        font-size: var(--spFS45);
        letter-spacing: var(--spLSSTit);
        margin-left: -0.8rem;
        position: relative;
        z-index: 1;
    }
    .secConcept .txt{
        font-size: var(--spFS13);
        line-height: var(--spLH13_24);
        margin-top: 2.3rem;
        font-style: inherit;
    }
    .secConcept .in + .in{
        margin-top: 1rem;
    }
}
@media only screen and (max-width:360px){
    .secConcept .img {
        margin: 0 0 0 1rem;
    }
    .secConcept{
        background: calc(20% + 14rem) bottom/ 14rem 6.8rem no-repeat;
    }
}
/* secTicker */
.secTicker{
    position: absolute;
    bottom: 29rem;
    left: 0;
    overflow: hidden;
    z-index: 1;
}
.secTicker .boxTicker {
    display: flex;
}
.secTicker .itemTicker:nth-child(odd) {
    animation: loop 80s -40s linear infinite;
    backface-visibility: hidden;
    will-change: transform;
    transform: translate3d(0, 0, 0);
}
.secTicker .itemTicker:nth-child(even) {
    animation: loop2 80s linear infinite;
}
@keyframes loop {
    0% {
        transform: translateX(100%);
    }
    to {
        transform: translateX(-100%);
    }
}
@keyframes loop2 {
    0% {
        transform: translateX(0);
    }
    to {
        transform: translateX(-200%);
    }
}
@media only screen and (max-width:767px){
    .secTicker{
        display: none;
        bottom: -4rem;
    }
    .secTicker .imgTicker{
        width: 170rem;
        height: auto;
    }
}

/*-----------------------------------------------
    secBusiness
-----------------------------------------------*/
.secBusiness{
    background-color: var(--gray_lightColor);
    padding: 14rem 0;
}
.secBusiness .boxList{
    counter-reset: number 0;
    margin-top: 5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 4rem;
}
.secBusiness .boxList .item{
    width: calc((100% - 11.999rem) / 4);
    display: flex;
    align-items: center;
    justify-content: center;
}
.secBusiness .boxList .linkBtn{
    position: relative;
    width: 100%;
    border-radius: 5rem;
    display: block;
    overflow: hidden;
    color: var(--whiteColor);
}
.secBusiness .boxList .boxTxt{
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-direction: column;
    text-align: center;
    padding-bottom: 3.5rem;
}
.secBusiness .boxList .txtJp{
    font-size: var(--pcFS24);
    line-height: var(--pcLH24_36);
    letter-spacing: var(--pcLHW24_80);
    min-height: calc(var(--pcFS24) * var(--pcLH24_36) * 2);
    font-weight: bold;
    display: flex;
    align-items: center;
}
.secBusiness .boxList .txtEng{
    position: absolute;
    top: 2.5rem;
    left: 3rem;
    font-size: var(--pcFS12);
}
.secBusiness .boxList .txtEng::before{
    position: absolute;
    counter-increment: number 1;
    content: counter(number,decimal-leading-zero);
    left: -0.5rem;
    top: 0;
    margin: auto;
    z-index: 2;
    font-size: var(--pcFS40);
    white-space: nowrap;
}
.secBusiness .txtEng span{
    margin-top: 4.5rem;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-style: italic;
}
.secBusiness .boxList .img{
    position: relative;
    border-radius: 5rem;
    overflow: hidden;
}
.secBusiness .boxList .img::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 20rem;
    background: linear-gradient(to top, var(--blackColor_50), transparent);
}
.secBusiness .secCmnBtn .boxBtn {
    width: 30rem;
    margin: 0;
}
@media only screen and (max-width:1215px){
    .secBusiness{
        padding: 7.5rem 0;
    }
    .secBusiness .boxList{
        margin-top: 2.6rem;
        justify-content: space-between;
        gap: 0.5rem 1%;
    }
    .secBusiness .boxList .item{
        width: 49.278%;
    }
    .secBusiness .boxList .item.w100{
        width: 100%;
    }
    .secBusiness .boxList .linkBtn{
        border-radius: 0.8rem;
    }
    .secBusiness .boxList .boxTxt{
        padding-bottom: 1.8rem;
    }
    .secBusiness .boxList .txtJp{
        font-size: var(--spFS15);
        line-height: var(--spLH15_20);
        letter-spacing: var(--spLS15_0);
        min-height: calc(var(--spFS15) * var(--spLH15_20) * 2);
    }
    .secBusiness .item:first-child .txtJp{
        letter-spacing: var(--spLSW15_50);
        min-height: auto;
    }
    .secBusiness .boxList .txtEng{
        top: 0.8rem;
        left: 1.5rem;
        font-size: var(--spFS10);
        padding: 0.4rem 0 0 2.2rem;
        text-align: left;
        font-weight: lighter;
    }
    .secBusiness .item:first-child .txtEng{
        padding-top: 0.7rem;
    }
    .secBusiness .boxList .txtEng::before{
        left: -0.5rem;
        font-size: var(--spFS22);
    }
    .secBusiness .txtEng span{
        display: inline-block;
        margin-top: 0;
        writing-mode: unset;
        text-orientation: unset;
        transform: scale(0.9) translateY(0.1rem) translateX(-0.6rem);
    }
    .secBusiness .boxList .img{
        border-radius: 1rem;
    }
    .secBusiness .boxList .img::after {
        height: 60%;
    }
    .secBusiness .secCmnBtn .boxBtn {
        width: 20.5rem;
        margin-top: 2.5rem;
    }
    .secBusiness .secCmnBtn .link {
        padding-left: 3rem;
    }
}

/*-----------------------------------------------
    secSustainability
-----------------------------------------------*/
.secSustainability{
    padding: 19rem 0 36rem;
    background: right bottom / cover no-repeat;
}
.secSustainability.lazyloaded{
    background-image: url(../img/index/bgSustainability.jpg);
}
.secSustainability .wrapper{
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
}
.secSustainability .boxCmnTit{
    justify-content: flex-start;
    flex-direction: column;
    align-items: flex-start;
}
.secSustainability .imgTit{
    margin: -1rem 0 1.5rem;
}
.secSustainability .secCmnBtn{
    margin-top: 4.5rem;
}
/* boxMainTxt */
.secSustainability .boxMainTxt{
    width: 51%;
}
.secSustainability .boxMainTxt .txt{
    font-size: var(--pcFS20);
    line-height: var(--pcLHW20_46);
    letter-spacing: var(--pcLS20_50);
    font-weight: bold;
}
.secSustainability .boxMainTxt .in{
    display: block;
}
.secSustainability .in + .in{
    margin-top: 1.7rem;
}
@media only screen and (max-width:1215px){
    .secSustainability{
        padding: 8rem 0 16.4rem;
    }
    .secSustainability .wrapper{
        align-items: flex-start;
        flex-direction: column;
    }
    .secSustainability .boxCmnTit{
        display: contents;
    }
    .secSustainability .tit{
        order: 1;
    }
    .secSustainability .imgTit{
        width: 12.5rem;
        margin-bottom: 0.5rem;
    }
    .secSustainability .secCmnBtn{
        order: 3;
        margin: 3rem auto 0;
    }
    /* boxMainTxt */
    .secSustainability .boxMainTxt{
        order: 2;
        width: 100%;
        margin-top: 3rem;
    }
    .secSustainability .boxMainTxt .txt{
        font-size: var(--spFS13);
        line-height: var(--spLH13_24);
        letter-spacing: var(--spLS13_0);
    }
    .secSustainability .in + .in{
        margin-top: 1rem;
    }
}
@media only screen and (max-width:767px){
    .secSustainability.lazyloaded{
        background-image: url(../img/index/bgSustainability_sp.jpg);
    }
}

/*-----------------------------------------------
    secNews
-----------------------------------------------*/
.secNews{
    margin-top: 14rem;
}
.secNews .boxNews{
    margin-top: 5rem;
    position: relative;
    display: flex;
    justify-content: space-between;
    /* align-items: flex-start; */
}
.secNews .cmnStickyMenu{
    position: relative;
    width: 20%;
}
/* secNewsTabContainer */
.secNews .secNewsTabContainer{
    width: 73.718%;
}
.secNewsTabContainer .boxListMain{
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}
.secNewsTabContainer .boxListMain .item{
    width: 100%;
    border-bottom: 1px solid var(--grayColor);
}
.secNewsTabContainer .boxListMain .item:nth-child(n+4){
    display: none;
}
.secNewsTabContainer .boxListMain .item:last-child{
    border-bottom: none;
}
.secNewsTabContainer .boxListMain .link{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 4rem 0;
}
.secNewsTabContainer .item:first-child .link{
    padding-top: 0;
}
/* boxImg */
.secNewsTabContainer .boxImg {
    width: 19rem;
    border-radius: 3rem;
}
.secNewsTabContainer .boxImg.category4 {
    opacity: 0 !important;
}
.secNewsTabContainer .secCmnTabContents:nth-child(5) .boxImg {
    display: none;
}
.secNewsTabContainer .img {
    aspect-ratio: 190 / 140;
}
/* boxTxt */
.secNewsTabContainer .boxTxt{
    padding-right: 6rem;
    width: calc(100% - (19rem + 4rem));
}
.secNewsTabContainer .secCmnTabContents:nth-child(5) .boxTxt {
    width: 100%;
}
.secNews .boxInfo{
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
    gap: 0.8rem;
}
.secNews .txtDate{
    font-size: var(--pcFS18);
    line-height: var(--pcLH18_28);
    letter-spacing: var(--pcLS18_50);
    font-weight: bold;
    color: var(--gray_darkColor);
}
.secNewsTabContainer .tit{
    font-size: var(--pcFS20);
    line-height: var(--pcLH20_30);
    letter-spacing: var(--pcLS20_50);
    font-weight: bold;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
/* isCircleArrow */
.secNewsTabContainer .isCircleArrow:before,
.secNewsTabContainer .isCircleArrow:after{
    top: -4rem;
}
/* boxMoreLink */
.boxMoreLink{
    position: relative;
    z-index: 1;
    width: 100%;
    margin: 1rem auto 0;
}
.boxMoreLink.moreView{
    display: none;
}
.boxMoreLink .moreLink{
    position: relative;
    width: 100%;
    min-height: 9rem;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--gray_lightColor);
    box-shadow: 0 1px 0 0 var(--blackColor_15);
    font-size: var(--pcFS20);
    border-radius: 1rem;
    padding: 2rem 4.2rem;
    transition: 0.4s ease-out;
}
.secNews .cmnStickyMenu{
    height: auto;
}
@media only screen and (max-width:1215px){
    .secNews{
        margin-top: 7.5rem;
    }
    .secNews .boxNews{
        margin-top: 2.5rem;
        flex-direction: column;
    }
    .secNews .cmnStickyMenu{
        width: 92%;
    }
    .secNews .secNewsTabContainer{
        width: 86.67%;
    }
    .secNewsTabContainer .boxListMain{
        margin-top: 1.5rem;
        border-top: 1px solid var(--grayColor);
    }
    .secNewsTabContainer .link{
        padding: 3rem 0!important;
    }
    /* boxImg */
    .secNewsTabContainer .boxImg {
        width: 10rem;
        border-radius: 1.5rem;
    }
    /* boxTxt */
    .secNewsTabContainer .boxTxt{
        padding-right: 0;
        width: calc(100% - (10rem + 1.5rem));
    }
    .secNews .boxInfo{
        margin-bottom: 0.5rem;
        gap: 0.5rem;
    }
    .secNews .txtDate{
        font-size: var(--spFS12);
        line-height: var(--spLH12_18);
        letter-spacing: var(--spLS12_0);
    }
    .secNewsTabContainer .tit{
        font-size: var(--spFS14);
        line-height: var(--spLH14_20);
        letter-spacing: var(--spLS14_0);
        white-space: normal;
        text-overflow: inherit;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        line-clamp: 2;
        overflow: hidden;
        max-height: calc(var(--spFS14) * var(--spLH14_20) * 2);
    }
    /* isCircleArrow */
    .secNewsTabContainer .isCircleArrow:after{
        top: 2.5rem;
        bottom: auto;
        right: 0;
    }
    /* boxMoreLink */
    .boxMoreLink{
        margin-top: 0;
    }
    .boxMoreLink .moreLink{
        min-height: 5.6rem;
        font-size: var(--spFS14);
        border-radius: 0.8rem;
        padding: 2rem 4.2rem;
    }
}

/*-----------------------------------------------
    secCompany
-----------------------------------------------*/
.secCompany{
    margin-top: 20rem;
    padding: 14rem 0 20rem;
    background-color: var(--bgColor);
}
.secCompany .boxCompany{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 5rem;
}
/* boxImg */
.secCompany .boxImg{
    position: relative;
    width: 65rem;
}
.secCompany .boxImg .imgTit{
    position: absolute;
    top: 5rem;
    left: 5rem;
}
/* boxTxt */
.secCompany .boxTxt{
    position: relative;
    width: calc(100% - (65rem + 11rem));
    z-index: 1;
    mix-blend-mode: multiply;
}
.secCompany .boxTxt .txt{
    font-size: var(--pcFS20);
    line-height: var(--pcLHW20_46);
    letter-spacing: var(--pcLS20_50);
    font-weight: bold;
}
.secCompany .boxTxt .in{
    display: block;
}
.secCompany .in + .in{
    margin-top: 1.7rem;
}
.secCompany .boxTxt .img{
    margin: 6rem auto 0;
    width: 68rem;
    text-align: center;
}
.secCompany .secCmnBtn{
    width: 30rem;
    margin: 5rem auto 0;
}
@media only screen and (max-width:1215px){
    .secCompany{
        margin-top: 8rem;
        padding: 7.5rem 0;
    }
    .secCompany .boxCompany{
        flex-direction: column;
        margin-top: 2.5rem;
    }
    /* boxImg */
    .secCompany .boxImg{
        position: relative;
        width: 100%;
    }
    .secCompany .boxImg .imgTit{
        top: -2rem;
        left: auto;
        right: 1.5rem;
        width: 5rem;
    }
    /* boxTxt */
    .secCompany .boxTxt{
        width: 94%;
        margin: 2rem auto 0;
    }
    .secCompany .boxTxt .txt{
        font-size: var(--spFS13);
        line-height: var(--spLH13_24);
        letter-spacing: var(--spLS13_0);
    }
    .secCompany .in + .in{
        margin-top: 1.5rem;
    }
    .secCompany .boxTxt .img{
        max-width: 29.5rem;
        margin-top: 2rem;
        width: 100%;
    }
    .secCompany .secCmnBtn{
        width: 20.5rem;
        margin-top: 2.5rem;
    }
}

/*-----------------------------------------------
    secRecruit
-----------------------------------------------*/
.secRecruit{
    margin-top: 14.5rem;
}
.secRecruit .bgRecruit{
    margin-top: 5.5rem;
    padding: 9.4rem 0;
    background: center bottom / 100% no-repeat;
}
.secRecruit.lazyloaded .bgRecruit{
    background-image: url(../img/index/bgRecruit.jpg);
}
.secRecruit .boxImgTit{
    width: 17.7rem;
}
.secRecruit .boxList{
    display: flex;
    justify-content: center;
    gap: 2rem;
    margin-top: 3rem;
}
.secRecruit .is_white .link{
    border-color: var(--mainColor);
}
.secRecruit .item:last-child{
    margin-left: 1rem;
}
@media only screen and (max-width:1215px){
    .secRecruit{
        margin-top: 8rem;
    }
    .secRecruit .bgRecruit{
        margin-top: 2.5rem;
        padding: 0 0 6.4rem;
        background-size: contain;
    }
    .secRecruit.lazyloaded .bgRecruit{
        background-image: url(../img/index/bgRecruit_sp.jpg);
    }
    .secRecruit .boxImgTit{
        width: 8rem;
        margin-left: 2.5rem;
    }
    .secRecruit .boxList{
        flex-wrap: wrap;
        gap: 2rem 1.2%;
        margin-top: 1.4rem;
    }
    .secRecruit .item:not(:last-child){
        width: 46.38%;
    }
    .secRecruit .secCmnBtn .boxBtn{
        width: 100%;
    }
    .secRecruit .item:last-child{
        margin-left: 0;
        width: 14.5rem;
    }
}