@charset "utf-8";


.new_cn {
	width:100vw;
	margin: 0 auto 40px;
	border-top: 0.5px #999 solid;
	border-bottom: 0.5px #999 solid;
}


/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.topLoading {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    background: #fff;
    z-index: 9999;
}
.topLoading .loadingInner {
    width: 100%;
    height: 100%;
    opacity: 0;
    background: url("../images/top/top_bg_loading.jpg") no-repeat center center / cover;
    transition: 0.5s;
}
.topLoading .loadingInner.show {
  opacity: 0;
  animation: topLoadingFadeIn forwards 0.5s;
}

@keyframes topLoadingFadeIn {
  100% {
    opacity: 1;
  }
}
.topLoading .loadingTtl {
    width: 658px;
    display: none;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}
.loading {
    display: none !important;
}
.mainVisual {
    width: 100%;
    height: calc(100vh - 120px);
	max-height: 780px;
    position: relative;
    overflow: hidden;
}
.mainVisual .mainImg {
   /* width: 20000px;*/
    height: 100%;
	display: flex;
}
.mainVisual .mainImg img {
	width: auto;
	max-width: inherit;
	height: 100%;
	will-change: transform;
}
.mainVisual .mainImg.on img:first-child {
	-webkit-animation: loop 300s -150s linear infinite;
	animation: loop 300s -150s linear infinite;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	will-change: transform;
}
.mainVisual .mainImg.on img + img {
	-webkit-animation: loop2 300s linear infinite;
	animation: loop2 300s linear infinite;
}
@-webkit-keyframes loop {
	0% {
		-webkit-transform: translateX(100%);
		-ms-transform: translateX(100%);
		transform: translateX(100%);
	}
	to {
		-webkit-transform: translateX(-100%);
		-ms-transform: translateX(-100%);
		transform: translateX(-100%);
	}
}
@keyframes loop {
	0% {
		-webkit-transform: translateX(100%);
		-ms-transform: translateX(100%);
		transform: translateX(100%);
	}
	to {
		-webkit-transform: translateX(-100%);
		-ms-transform: translateX(-100%);
		transform: translateX(-100%);
	}
}
@-webkit-keyframes loop2 {
	0% {
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
		transform: translateX(0);
	}
	to {
		-webkit-transform: translateX(-200%);
		-ms-transform: translateX(-200%);
		transform: translateX(-200%);
	}
}
@keyframes loop2 {
	0% {
		-webkit-transform: translateX(0);
		-ms-transform: translateX(0);
		transform: translateX(0);
	}
	to {
		-webkit-transform: translateX(-200%);
		-ms-transform: translateX(-200%);
		transform: translateX(-200%);
	}
}
.mainVisual .imgTxt {
    width: 455px;
    position: absolute;
    left: 60px;
    top: 40px;
}
#main .content {
    width: 1280px;
    position: relative;
    z-index: 1;
}
#main .newsBox {
    margin-bottom: 85px;
}
#main .newsBox .content {
    padding: 25px 0;
    background: #fcd4d6;
}
#main .newsBox h2 {
    padding: 10px 20px;
    width: 303px;
    display: flex;
    align-items: center;
    text-align: center;
    font-weight: 700;
    letter-spacing: 0.05em;
    box-sizing: border-box;
    border-right: 1px solid #9fa0a0;
	font-size: 2rem;
}
#main .newsBox h2 span {
    width: 100%;
    display: block;
}
#main .newsBox .newsList {
    box-sizing: border-box;
    padding: 0 80px;
    width: 970px;
}
#main .newsBox .newsList li {
    font-size: 1.65rem;
    line-height: 2;
}
#main .newsBox .newsList li .time {
    margin-bottom: 3px;
    display: block;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.15em;
}
#main .newsBox .newsList li a {
    display: block;
    letter-spacing: 0.05em;
}
#main .newsBox .newsList li a::after {
    margin-left: 10px;
    width: 17px;
    height: 9px;
    display: inline-block;
    background: url("../images/common/arrow_01_black.svg") no-repeat center center / 100% 100%;
    content: '';
}
#main .carbide,.diaedge {
  margin-bottom: 168px;
  position: relative;
}
#main .carbide::before {
    width: 292px;
    height: 344px;
    position: absolute;
    left: 0;
    bottom: 51px;
    background: url("../images/top/top_img_carbide01.jpg") no-repeat left top / 100% auto;
    content: '';
}
#main .carbide::after {
    width: 304px;
    height: 348px;
    position: absolute;
    right: 0;
    bottom: 53px;
    background: url("../images/top/top_img_carbide02.jpg") no-repeat left top / 100% auto;
    content: '';
}
#main .diaedge img {
  width: 360px;
  margin-top: 10px;
  position: relative;
}

#main .carbide .headLine03, .diaedge .headLine03{
    margin-bottom: 44px;
    line-height: 1.53;
    letter-spacing: 0.1em;
}

#main .carbide p, .diaedge p {
    margin-bottom: 26px;
    text-align: center;
    letter-spacing: 0.1em;
    line-height: 2.75;
}
#main .carbide p .redTxt, .diaedge p .redTxt {
    color: #e60012;
    font-weight: 700;
}
#main .comBtn.en a {
    padding: 13px 30px 10px 21px;
    text-align: center;
    font-size: 1rem;
    letter-spacing: 0.15em;
}
#main .comBtn.en a::after {
    right: 10px;
}
#main .products {
    margin-bottom: 91px;
	padding: 0 20px;
}
#main .products .headLine03::after {
    left: 0;
    transform: translateX(0);
}
#main .products .linkList {
    width: 100%;
    order: 1;
}
#main .products .linkList::after {
    width: 410px;
    content: '';
}
#main .products .linkList li {
    width: 410px;
}
#main .products .linkList li a {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    display: block;
    color: #fff;
}
#main .products .linkList li .photo {
    overflow: hidden;
}
#main .products .linkList li .photo img {
    width: 100%;
}
#main .products .linkList li .textBox {
    padding: 33px 40px 30px;
    background: #e60012;
}
#main .products .linkList li .textBox .ttl {
    margin-bottom: 19px;
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: 0.1em;
}
#main .products .linkList li .textBox .text {
    margin-bottom: 23px;
    font-size: 1.4rem;
    line-height: 1.86;
    letter-spacing: 0;
}
#main .products .linkList li .textBox .btn {
    padding: 14px 30px 11px 20px;
    width: 130px;
	position: relative;
    text-align: center;
    color: #e60012;
    font-family: 'Josefin Sans', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.15em;
    background: #fff;
}
#main .products .linkList li .textBox .btn::after {
	width: 17px;
	height: 9px;
	position: absolute;
	right: 15px;
	top: 50%;
	background: url("../images/common/arrow_01_red.svg") no-repeat center center / 100% 100%;
	content: '';
	transform: translateY(-50%);
}
#main .products .comBtn {
    margin: 13px 33px 0;
}
#main .movie {
    margin-bottom: 127px;
    padding: 136px 0 90px;
    background: url("../images/top/top_bg_movie.jpg") no-repeat center top / cover;
}
#main .movie .headLine03 {
    color: #fff;
}
#main .movie .slickBox {
    padding: 0 90px;
    position: relative;
}
#main .movie .movieList li {
    box-sizing: border-box;
    padding: 0 10px;
    float: left;
    vertical-align: top;
}
#main .movie .movieList li .movieBox {
    margin-bottom: 14px;
    width: 100%;
    padding-bottom: 56.25%;
    position: relative;
}
#main .movie .movieList li .movieBox iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
#main .movie .movieList li p {
    text-align: center;
    color: #fff;
    font-weight: 700;
    font-size: 2.2rem;
    letter-spacing: 0.1em;
}
#main .movie .arrowList li {
    margin-top: -22px;
    position: absolute;
    top: 50%;
    cursor: pointer;
    transform: translateY(-50%);
}
#main .movie .arrowList .prev {
    left: 40px;
    transform: translateY(-50%) rotate(180deg);
}
#main .movie .arrowList .next {
    right: 40px;
}
#main .movie .arrowList li img {
    width: 23px;
    height: 40px;
}
#main .movie .youTube {
    margin-top: 75px;
}
#main .movie .youTube a {
    display: inline-block;
    font-size: 1.4rem;
	font-weight: 500;
    letter-spacing: 0.05em;
    color: #fff;
}
#main .movie .youTube a:hover {
    color: #E60012;
}
#main .movie .youTube a img {
    margin: 0 11px 1px 10px;
    vertical-align:top;
}
#main .company {
    margin-bottom: 124px;
}
#main .company .headLine03 {
    width: 100%;
}

/*2022.08 SNSアイコン挿入時に修正*/

#main .company .btnList_bgc {
  background-color: #f6f6f2;
  order: 1;
}

#main .company .btnList {
  width: 87%;
  margin: 0 auto;
  
}

#main .company .btnList li {
    width: 25%;
    box-sizing: border-box;
    border-bottom: 1px solid #fff;
    border-right: 1px solid #fff;
}
#main .company .btnList li:nth-child(4n) {
    border-right: none;
}
#main .company .btnList li a {
    display: block;
    position: relative;
    overflow: hidden;
}
#main .company .btnList li img {
    width: 100%;
}
#main .company .btnList li .txt {
    padding: 8px 18px 11px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    text-align: center;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    background: #e60012;
}
#main .company .comBtn {
    margin-bottom: 59px;
}
#main .company .comBtn a {
    background-position: right 9px center;
}
#main .news .content {
    width: 1080px;
}
#main .news .comNewsList {
    margin-bottom: 50px;
}
@media all and (min-width: 897px) {
    #main .newsBox .newsList li a::after {
        transition: 0.3s;
    }
	#main .newsBox .newsList li a:hover {
		text-decoration: underline;
	}
    #main .newsBox .newsList li a:hover::after {
        transform: translateX(10px)
    }
    #main .comBtn.en a:hover::after {
        right: 5px;
    }
    #main .products .linkList li .photo img {
        transition: 0.3s;
    }
    #main .products .linkList li a:hover .photo img {
        transform: scale(1.2);
    }
    #main .products .linkList li a .textBox .btn {
        transition: 0.3s;
    }
	#main .products .linkList li .textBox .btn::after {
		transition: right ease-in-out 0.3s;
	}
	#main .products .linkList li a:hover .textBox .btn {
		color: #fff;
		background-color: #000;
	}
	#main .products .linkList li a:hover .textBox .btn::after {
		right: 5px;
		background-image: url("../images/common/arrow_01_white.svg");
	}
    #main .movie .arrowList li:hover {
        opacity: 0.7;
    }
    #main .company .btnList li img {
        transition: 0.3s;
    }
    #main .company .btnList li a:hover img {
        transform: scale(1.2);
    }
}
@media all and (max-width: 896px) {
    .topLoading .loadingInner {
        background-image: url("../images/top/top_bg_loading_sp.jpg");
    }
    .topLoading .loadingTtl {
        width: 248px;
    }
    .mainVisual {
        height: calc(100vh - 60px);
		max-height: 50vh;
    }
    .mainVisual .imgTxt {
        width: 170px;
        left: 10px;
        top: 10px;
    }
    #main .content {
        width: auto;
    }
    #main .newsBox {
        margin-bottom: 0;
    }
    #main .newsBox .content {
        margin: 0;
        padding: 27px 20px 33px;
        display: block;
    }
    #main .newsBox h2 {
        margin-bottom: 10px;
        padding: 0 0 12px;
        width: auto;
        text-align: left;
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        border-right: none;
        border-bottom: 1px solid #9fa0a0;
    }
    #main .newsBox .newsList {
        padding: 0;
        width: auto;
    }
    #main .newsBox .newsList li {
        display: block;
        font-size: 1.3rem;
        line-height: 1.7;
    }
    #main .newsBox .newsList li .time {
        margin-bottom: 7px;
        width: auto;
        letter-spacing: 0.05em;
    }
    #main .newsBox .newsList li a {
        width: auto;
        letter-spacing: 0.05em;
    }
    #main .newsBox .newsList li a::after {
        margin-left: 8px;
        width: 11px;
        height: 7px;
    }
    #main .carbide {
        margin-bottom: 53px;
        padding-top: 134px;
    }
    #main .diaedge {
        margin-bottom: 53px;
        padding-top: 10px;
    }
    #main .diaedge img {
        width: 240px;
        margin-top: 10px;
        position: relative;
    }
    #main .carbide::before {
        width: 192px;
        height: 107px;
        top: 0;
        bottom: auto;
        background-image: url("../images/top/top_img_carbide01_sp.jpg");
        content: '';
    }
    #main .carbide::after {
        width: 118px;
        height: 142px;
        bottom: -75px;
        background-image: url("../images/top/top_img_carbide02_sp.jpg");
    }
    #main .carbide .headLine03, .diaedge .headLine03 {
        margin: 0 5px 21px;
        letter-spacing: 0.07em;
        line-height: 1.5;
    }
    #main .carbide p, .diaedge p {
        margin-bottom: 22px;
        text-align: left;
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        line-height: 2.28;
    }
    #main .comBtn.en {
        max-width: 160px;
    }
    #main .comBtn.en a::after {
        right: 9px;
    }
    #main .products {
        margin-bottom: 31px;
		padding: 0;
    }
    #main .products .content {
        display: block;
    }
    #main .products .headLine03 {
        margin-bottom: 30px;
    }
    #main .products .headLine03::after {
        left: 50%;
        transform: translateX(-50%);
    }
    #main .products .linkList {
        margin-bottom: 30px;
        display: block;
    }
    #main .products .linkList::after {
        display: none;
    }
    #main .products .linkList li {
        margin-bottom: 20px;
        width: auto;
    }
    #main .products .linkList li:last-child {
        margin-bottom: 0;
    }
    #main .products .linkList li .textBox {
        padding: 27px 29px 30px;
    }
    #main .products .linkList li .textBox .ttl {
        margin-bottom: 11px;
        font-size: 1.6rem;
    }
    #main .products .linkList li .textBox .text {
        margin-bottom: 25px;
        font-size: 1.2rem;
        line-height: 2;
        letter-spacing: 0;
    }
    #main .products .linkList li .textBox .btn {
        margin: 0 auto;
        width: 110px;
        background-position: right 10px center;
        background-size: 11px 7px;
    }
    #main .products .comBtn {
        margin: 0 auto;
    }
    #main .movie {
        margin-bottom: 53px;
        padding: 25px 0 27px;
        background-image: url("../images/top/top_bg_movie_sp.jpg");
    }
    #main .movie .headLine03 {
        margin-bottom: 28px;
    }
    #main .movie .slickBox {
        padding: 0 40px;
    }
    #main .movie .movieList li {
        padding: 0;
    }
    #main .movie .movieList li .movieBox {
        margin-bottom: 12px;
    }
    #main .movie .movieList li p {
        font-size: 1.6rem;
    }
    #main .movie .arrowList li {
        margin-top: -16px;
    }
    #main .movie .arrowList .prev {
        left: 15px;
    }
    #main .movie .arrowList .next {
        right: 15px;
    }
    #main .movie .arrowList li img {
        width: 12px;
        height: 20px;
    }
    #main .movie .youTube {
        margin-top: 28px;
    }	
    #main .movie .youTube a {
        font-size: 1.1rem;
        letter-spacing: 0.1em;
    }
    #main .movie .youTube a img {
        margin: -6px 11px 1px 0;
  }
    #main .company {
        margin-bottom: 50px;
        display: block;
    }
    #main .company .headLine03 {
        margin-bottom: 30px;
    }
    #main .company .btnList {
        margin-bottom: 30px;
        width: auto;
        margin-right: -1px;
    }
    #main .company .btnList li {
        width: 50%;
    }
    #main .company .btnList li:nth-child(2n) {
        border-right: 1px solid #fff;
    }
    #main .company .btnList li .txt {
        padding: 3px 6px 4px;
        font-size: 1rem;
        letter-spacing: 0.05em;
    }
    #main .company .comBtn {
        margin-bottom: 0;
    }
    #main .news .content {
        margin: 0 10px;
        width: auto;
    }
    #main .news .headLine03 {
        margin-bottom: 30px;
    }
    #main .news .comNewsList {
        margin-bottom: 29px;
    }
}
