@charset "utf-8";

.home #header_wrap {
	background: transparent;
}

.home #header_area {
	/*margin: 10px auto 0;*/
}

.home #header_wrap.smallhead #header_area {
	margin: 0 auto;
}

.home #logo img.logo_black {
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}

.home .smallhead #logo img.logo_black {
	opacity: 1;
}

.home #header_wrap .menu_link {
	color: #fff !important;
	text-shadow: 0 0 20px rgba(29, 54, 71, 0.15);
}

.home #header_wrap.smallhead .menu_link {
	color: #222 !important;
}





/*---------------------------------------------------------
	Top 共通
---------------------------------------------------------*/

.top_link_btn{
	display: inline-block;
	text-decoration:none;
}
.top_link_btn_in{
	display: flex;
    justify-content: flex-start;
    align-items: center;
}
.top_link_circle{
	position: relative;
    display: inline-block;
    border-radius: 50%;
	font-family: 'Roboto', sans-serif;
	font-size:2.2rem;
	font-weight:700;
	letter-spacing:0;
	color:#2B5872;
}
.top_link_txt{
	position:relative;
	display: inline-block;
	margin-right:20px;
	font-family: 'Roboto', sans-serif;
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: 0;
    color: #2B5872;
}
.top_link_txt:before{
	content:"";
	position:absolute;
	bottom:-2px;
	left:0;
	background:#D4D4D4;
	width:100%;
	height:1px;
}
.top_link_txt:after{
	content:"";
	position:absolute;
	bottom:-2px;
	left:0;
	background:#2B5872;
	width:73%;
	height:1px;
}
.top_link_circle{
	position: relative;
    display: inline-block;
    border-radius: 50%;
	/*width:122px;
	height:122px;*/
	width:128px;
	height:128px;
}
.top_link_circle:before{
	 position: absolute;
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid #2B5872;
    border-radius: 50%;
    box-sizing: border-box;
    top: 50%;
    left: 50%;
    transition: all 1.5s cubic-bezier(.23,1,.32,1),border .3s ease;
    transform: translate(-50%,-50%);
	width:122px;
	height:122px;
}

.top_link_circle:after{
	position: absolute;
    content: '';
	width:15px;
    height: 15px;
    background: url(../img/arrow_blue.svg) center center/100% auto no-repeat;
    transform: translate(-50%,-50%);
    top: 50%;
    left: 50%;
}
.top_link_circle svg{
	position: absolute;
    display: block;
    width: auto;
    height: auto;
    top: 0;
    left: 0;
    transition: opacity .3s cubic-bezier(.23,1,.32,1);
    transform: rotate(-90deg);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    opacity: 0;
	/*width: calc(110 / var(--width) * 100vw);
    height: calc(110 / var(--width) * 100vw);*/
}

.top_link_circle svg circle{
	fill: transparent;
	stroke: #fff;
	stroke-width: 1px;
    transition: stroke-dashoffset .7s cubic-bezier(.23,1,.32,1);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
	stroke-dasharray: 346px;
    stroke-dashoffset: 346px;
}
a.top_link_btn:hover svg, a:hover .top_link_circle svg {
    opacity: 1;
}
 a:hover .top_link_circle::before {
    width:122px;
    height:122px;
    opacity: 0;
}
a:hover .top_link_circle svg circle,a.top_link_circle:hover svg circle{
	stroke-dashoffset: 0;
}
.top_link_circle svg circle{
	stroke: #2B5872;
}



/*  ボタン白  */

.top_link_btn_in.white .top_link_txt{
	color:#fff;
}
body.show-bg .about_area .top_link_btn_in.white .top_link_txt, 
body.show-bg .technology_head .top_link_btn_in.white .top_link_txt{
	color:#2B5872;
}
.top_link_btn_in.white .top_link_txt:before{
	background:#fff;
}
body.show-bg .top_link_btn_in.white .top_link_txt:before{
	background:#D4D4D4;
}
.top_link_btn_in.white .top_link_circle:before{
	border:1px solid #fff;
}
body.show-bg .about_area .top_link_btn_in.white .top_link_circle:before, 
body.show-bg .technology_head .top_link_btn_in.white .top_link_circle:before{
	border:1px solid #2B5872;
}
.top_link_btn_in.white .top_link_circle svg circle{
	stroke:#fff;
}
body.show-bg .about_area .top_link_btn_in.white .top_link_circle svg circle, 
body.show-bg .technology_head .top_link_btn_in.white .top_link_circle svg circle{
	stroke:#2B5872;
}
.top_link_btn_in.white .top_link_circle:after{
	background: url(../img/arrow_white.svg) center center/100% auto no-repeat;
}
body.show-bg .about_area .top_link_btn_in.white .top_link_circle:after, 
body.show-bg .technology_head .top_link_btn_in.white .top_link_circle:after{
	background: url(../img/arrow_blue.svg) center center/100% auto no-repeat;
}

/*---------------------------------------------------------
	Top
---------------------------------------------------------*/

.home main {
	letter-spacing: 0.12em;
}

#index_wrap {
	position: relative;
	width: 100%;
}

#index_main {
	/*background: #000000;*/
	position: relative;
	overflow: hidden;
}

#index_main .mv_img{
	height:100vh;
}

#index_main img{
	display: block;
    width: 100%;
    height: 100%!important;
	object-fit:cover;
	vertical-align:bottom;
	position: fixed;
	z-index: -1;
}

.mv_copy{
	position:absolute;
	left:11.9%;
	bottom: calc(50% - 176px);
	color:#fff;
}

.mv_copy h1{
	font-size:6.0rem;
	line-height:1.5;
	letter-spacing:0.02em;
}

.mv_copy .mv_copy_en{
	font-family: 'Roboto', sans-serif;
	display:block;
	font-size:2.0rem;
	letter-spacing:0;
	margin-top:20px;
}


.scroll{
	font-family: 'Roboto', sans-serif;
    font-size: 1.5rem;
    letter-spacing: 0;
    line-height: 16px;
    color: #fff;
    writing-mode: vertical-rl;
    position: absolute;
    bottom:110px;
    right: 20px;
    padding-bottom: 153px;
}

.scroll::before,
.scroll::after {
    content: '';
    position: absolute;
    bottom: 0;
    right: 1px;
    left: 0;
    width: 1px;
    height: 145px;
    margin: auto;
}

.scroll::before {
    background: #333;
}

.scroll::after {
    background: #fff;
    animation: scroll 3s infinite;
}

@keyframes scroll {
    0% {
        bottom: 145px;
        height: 0;
    }

    20% {
        bottom: 0;
        height:145px;
    }

    100% {
        height: 0;
    }
}

/*----------------
	mv ピン止めnews
--------------------*/
.mv_news{
	position:absolute;
	bottom:30px;
	right:85px;
	max-width: 500px;
	display:inline-block;
}
.mv_news_link{
	display:flex;
	color:#fff;
	text-decoration:none;
}

.mv_news_txt{
	margin-right:18px;
	letter-spacing: 0.05em;
}
.mv_news .news_cate{
	display:inline-block;
	padding:0 15px 1px;
	border:1px solid #fff;
	border-radius:15px;
	font-size: 1.2rem;
    margin-left: 5px;
}
.mv_news .news_title{
	display:block;
	margin-top:5px;
	font-size: 2rem;
}

.mv_news .top_link_circle{
	width:85px;
	height:85px;
}
.mv_news .top_link_circle:before{
	width:81px;
	height:81px;
}

.mv_news a:hover .top_link_circle::before {
	width:81px;
	height:81px;
}

.mv_news .top_link_circle:after{
	top: calc(50% - 7px);
    left: calc(50% - 7px);
    transform: rotate(-45deg);
}

/**/

.top_ttl {
	position: relative;
	display: inline-block;
	margin-bottom: 50px;
}


.top_ttl h2 {
	font-size: 1.7rem;
	font-weight: bold;
	letter-spacing: 0.05em;
}

.top_ttl h2::before {
	display: block;
	content: attr(data-txt)'';
	font-family: 'Michroma', sans-serif;
	font-size: 6.8rem;
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height:1.3;
	color: #2B5872;
}

.home .top_catch{
	font-size:2.8rem;
	font-weight:500;
	letter-spacing:0;
	line-height:1.5;
	margin-bottom:45px;
}
.home main p{
	line-height:2.0;
}

/*----------------
	about
--------------------*/

#index_about{
	padding:285px 0 150px 0;
	/*background:#dbdbdb;*/
}

.about_area{
	max-width:1240px;
	display:flex;
	flex-wrap:wrap;
	padding:0 20px;
	margin:0 auto;
	/*color:#fff;*/
}

.about_area .top_ttl{
	margin-bottom:35px;
}

.about_area {
	letter-spacing:0.05em;
}

.about_txt{
	width:50%;
	margin-top:100px;
}

.about_img{
	width:46%;
	margin-left:4%;
}
.about_img img{
	width:100%;
}

.about_area .top_catch,.about_area .top_ttl h2,.about_area .top_ttl h2::before, 
.technology_head .top_catch,.technology_head .top_ttl h2,.technology_head .top_ttl h2::before {
	color:#fff;
}

body.show-bg .about_area .top_catch, 
body.show-bg .technology_head .top_catch {
	color:#222;
}
body.show-bg .about_area .top_ttl h2::before,
body.show-bg .technology_head .top_ttl h2::before{
	color:#2B5872;
}
body.show-bg .about_area .top_ttl h2,
body.show-bg .technology_head .top_ttl h2{
	color:#222;
}

.about_area p, .technology_head p{
	color:#fff;
	margin-bottom:50px;
}
body.show-bg .about_area p, body.show-bg .technology_head p{
	color:#222;
}
/*----------------
	Technology
--------------------*/

#index_technology{
	position:relative;
	/*padding:50px 0 635px 0;*/
	padding:50px 0 220px 0;
}

.technology_head{
	max-width:1240px;
	padding:0 20px;
	margin:0 auto 110px auto;
}

.technology_contents{
	position:relative;
}

.technology_item_area{
	max-width:1240px;
	padding:20px 20px 0 20px ;
	margin:0 auto;
}
.technology_item{
	width:45%;
	margin-left:auto;
	/*padding:60px 0 40px 0;*/
	padding:35px 0 25px 0;
	border-bottom:1px solid #ccc;
}

.technology_item_in{
	display:flex;
	flex-wrap:wrap;
	justify-content: space-between;
    align-items: center;
	/*margin-bottom:35px;*/
	margin-bottom:25px;
}

.technology_contents_ttl span{
	display:block;
	font-family: 'Poppins', sans-serif;
	font-size:2.0rem;
	font-weight:500;
	letter-spacing:0;
	color:#2B5872;
}
.technology_contents_ttl h3{
	/*font-size:3.8rem;*/
	font-size:3.2rem;
	font-weight:500;
	line-height:1.2;
	letter-spacing:0.05em;
	color:#2B5872;
}
.technology_contents_ttl h3::after {
    display: block;
    content: attr(data-txt)'';
    font-family: 'Poppins', sans-serif;
    font-size: 2.0rem;
    font-weight: 500;
    letter-spacing: 0;
	color:#222;
	margin-top:14px;
}

.technology_head p{
	margin-bottom:50px;
}


.technology_img{
	position:absolute;
	top:0;
	left:0;
	width:50%;
	height:1210px;
}
.technology_img img{
	transition: .5s ease;
	position:absolute;
	top:0;
	left:0;
	display: block;
    max-width: 100%;
	opacity: 0;
	height:100%;
	object-fit:cover;
}
.technology_img img.is-show {
    transition: .5s ease;
    transform: none;
    opacity: 1;
    z-index: 2;
}

.content_wrap_bg::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
    opacity: 0;
    transition: all 0.5s ease 0s;
    background: #fff;
    z-index: -1;
}
.content_wrap_bg.show-bg::before {
    opacity: 1;
}

/*----------------
	product
--------------------*/

#index_product{
	background: url(../img/index_product_bg.jpg) no-repeat center/cover;
	padding:120px 0 160px 0;
}
.product_area{
	max-width:1480px;
	margin:auto;
	padding:0 20px;
}
.product_head{
	max-width:1200px;
	margin:0 auto 50px auto;
}

.product_head_ttl{
	display:flex;
	flex-wrap:wrap;
	align-items: center;
	justify-content: space-between;
	margin-bottom:40px;
}
.product_head_ttl .top_ttl{
	margin-bottom:0;
}

/* 	
 	swiperここから 	*/

.swiper-wrapper {
	width: 100%;
	/*height: 250px;*/
	height:100%;
}

.swiper-slide {
	width: 100%;
	height: 100%;
}
.all_slide_controls {
	margin-top: 35px;
    position: relative;
    text-align: right;
}
.all_slide_controls ._bar {
    background: rgba(29, 43, 59, 0.08);
    width: calc(100% - 200px);
    height: 2px;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.all_slide_controls .swiper-scrollbar-drag {
    background: #0E5DA8;
}

/*ページネーション*/
.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  color: #000;
}

.swiper-scrollbar-drag{
	cursor:pointer;
}


.swiper-container{
	position: relative;
	width: calc(720px + 50vw);
    /*margin-top: 45px;*/
    padding-right: 60px;
	padding-bottom: 50px;
}
.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    box-sizing: content-box;
}


.home .swiper-container .swiper-scrollbar{
	background: rgba(29, 43, 59, 0.08);
	max-width:1200px;
    width: calc(100% - 200px);
    position: absolute;
   /* left: 0;*/
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

.swiper-slide a{
    position: relative;
    display: block;
	height:420px;
	text-decoration:none;
	color: #fff;
	overflow: hidden;
}

.swiper-slide a:after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	top: 0;
	/*background: url(https://gokansoichiro.com/wp/wp-content/themes/gds/images/blog/google-earth-view-6202.jpg) no-repeat center center;*/
	-webkit-background-size: cover;
	-moz-background-size: cover;
	-ms-background-size: cover;
	background-size: cover;
	-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: -1;
}
.swiper-slide.vacuum a:after{
	background: url(../img/top_product_img_01.jpg) no-repeat center/cover;
}
.swiper-slide.sanitary a:after{
	background: url(../img/top_product_img_02.jpg) no-repeat center/cover;
}
.swiper-slide.industrial a:after{
	background: url(../img/top_product_img_03.jpg) no-repeat center/cover;
}
.swiper-slide.chemical a:after{
	background: url(../img/top_product_img_04.jpg?20230908) no-repeat center/cover;
}
.swiper-slide.piping a:after{
	background: url(../img/top_product_img_05.jpg?20230908) no-repeat center/cover;
}
.swiper-slide.other a:after{
	background: url(../img/top_product_img_06.jpg?20230908) no-repeat center/cover;
}
.swiper-slide a:hover:after {
	opacity: .8;
	-moz-transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
}










.product_item{
	display: flex;
    align-content: space-between;
    flex-direction: column;
	justify-content: space-between;
    height: 100%;
	padding:30px 25px 25px 48px;
}

.product_ttl span{
	display:inline-block;
	font-family: 'Poppins', sans-serif;
	font-size:2.0rem;
	font-weight:500;
	letter-spacing:0;
}
.product_ttl h3{
	font-size:3.2rem;
	font-weight:500;
	letter-spacing:0.05em;
}
.product_ttl h3:after{
	display: block;
    content: attr(data-txt)'';
    font-family: 'Roboto', sans-serif;
    font-size:2.0rem;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.0;
}

.product_item .top_link_btn_in{
	justify-content: flex-end;
}
.product_item .top_link_circle{
	width:45px;
	height:45px;
}
.swiper-slide a:hover .top_link_circle::before{
	width:43px;
	height:43px;
}
.product_item .top_link_circle:before{
	width:43px;
	height:43px;
}



/*----------------
	info
--------------------*/
.info_content{
	display:flex;
	flex-wrap:wrap;
	position: relative;
}
.info_box{
	position:relative;
	width:33.3333%;
	color:#fff;
	text-decoration:none;
	transition: opacity .3s ease;
	z-index:1;
}
.info_box_in{
	display:flex;
	flex-direction: column;
    justify-content: space-between;
	padding:85px 50px 50px 70px;
	height:560px;
}

.info_content .top_ttl h2{
	
}
.info_content .top_ttl h2::before{
	font-size:5.0rem;
	color:#fff;
	margin-bottom:10px;
}
.info_content .top_link_btn_in{
	justify-content: flex-end;
}
.info_content .top_link_txt:before,.info_content .top_link_txt:after{
	content:none;
}


.info_bg{
	position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
	z-index:-1;
}
.info_bg img{
	display:block;
	width:100%;
	height:100%!important;
	object-fit:cover;
	
}

.info_box_zoom {
    background: rgba(0,0,0,.5);
    overflow: hidden;
}
.info_box_zoom, .info_box_zoom li {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 0;
}
.info_box_zoom_bg {
    z-index: 1;
}
.info_box_zoom_bg, .info_box_zoom_bg img, .info_box_zoom_bg::after {
    position: absolute;
    width: 100%;
    height: 100%!important;
    top: 0;
    left: 0;
}
.info_box_zoom_bg img {
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: left center;
    object-position: left center;
    z-index: 0;
}
.info_box_zoom_bg, .info_box_zoom_bg img, .info_box_zoom_bg::after {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}
.info_content.is-hover.is-equipment .info_box:nth-of-type(2),
.info_content.is-hover.is-equipment .info_box:nth-of-type(3),
.info_content.is-hover.is-recruit .info_box:nth-of-type(1),
.info_content.is-hover.is-recruit .info_box:nth-of-type(3),
.info_content.is-hover.is-company .info_box:nth-of-type(1), 
.info_content.is-hover.is-company .info_box:nth-of-type(2) 
{
    opacity: .3;
}
.info_content.is-hover.is-equipment .info_box_zoom li:nth-child(1), .info_content.is-hover.is-recruit .info_box_zoom li:nth-child(2), .info_content.is-hover.is-company .info_box_zoom li:nth-child(3) {
    transition: 5s linear,opacity .3s ease,z-index 0s;
    transform: scale(1.1);
    opacity: 1;
}
.info_content.is-hover .info_box_in .info_bg {
    opacity: 0;
}
.info_box_zoom li:nth-child(2), .info_box_zoom li:nth-child(3) {
    transition: opacity .5s ease,z-index 0s;
    opacity: 0;
}
.info_content::before {
    position: absolute;
    display: block;
    content: '';
    width: 1px;
    height: 100%;
    background: #fff;
    top: 0;
    left: 33.3333%;
    transition: opacity .3s ease;
    opacity: 0;
	z-index: 1;
}
.info_content::after {
    position: absolute;
    display: block;
    content: '';
    width: 1px;
    height: 100%;
    background: #fff;
    top: 0;
    left: 66.6666%;
    transition: opacity .3s ease;
    opacity: 0;
}
.info_content.is-hover::before {
    opacity: .3;
}
.info_content.is-hover::after {
    opacity: .3;
}
/*----------------
	news
--------------------*/
#index_news {
	padding: 100px 0 110px 0;
	position: relative;
	z-index: 1;
	background:#fff;
}

.news_area {
	display: flex;
	flex-wrap: wrap;
	max-width: 1240px;
	display: flex;
	flex-wrap: wrap;
	margin: auto;
	padding: 0 20px;
}

.news_head {
	position: relative;
	width:21.25%;
	margin-right:2.75%;
}

.news_content {
	position: relative;
	width:76%;
}

.news_item {
	border-bottom: 1px solid #ccc;
}
.news_item:first-child{
	border-top: 1px solid #ccc;
}

.news_link {
	display: flex;
	flex-wrap: wrap;
	/*align-items: center;*/
	text-decoration: none;
	color: #222;
	padding: 25px 0;
	transition: all 0.3s;
}


.news_link:hover {
	color: #2B5872;
}

.news_link .news_date {
	display: block;
	letter-spacing:0.05em;
	width: 90px;
	margin-right: 30px;
}

.news_link .news_cate {
	display: block;
	font-weight: 500;
	letter-spacing: 0;
	min-width: 85px;
	margin-right: 20px;
	display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 2.26rem;
    padding: 0 1.2rem;
    font-size: 1.2rem;
    color: #2B5872;
    border: 1px solid rgba(43, 88, 114, 0.5);
    border-radius: 15px;
}

.news_link .news_title {
	/* font-size: 1.6rem;
	font-weight: bold; 
	letter-spacing: 0.1em;*/
	width: calc(100% - 225px);
	letter-spacing:0.05em;
}



@media screen and (max-width:767px) {

	#toggle a span, #toggle a::before, #toggle a::after{
		background:#fff;
	}

	.home #header_wrap .menu_link {
		text-shadow: none;
	}

	.home #header_wrap.smallhead .menu_link {
		color: #fff !important;
	}

	/*----------------
		Top 共通
	-----------------*/
	
	.top_ttl{
		margin-bottom:30px;
	}
	.top_ttl h2{
		font-size:1.4rem;
	}
	.top_ttl h2::before{
		font-size:4.0rem;
	}
	.home .top_catch{
		font-size:2.0rem;
		margin-bottom:20px;
	}
	
	.top_link_txt{
		font-size:1.8rem;
	}
	.top_link_circle{
		width: 80px;
    	height: 80px;
	}
	.top_link_circle:before{
		width: 78px;
    	height: 78px;
	}
	a:hover .top_link_circle::before{
		width: 80px;
    	height: 80px;
	}
	
	
	
	
	#index_main .mv_img{
		
	}
	
	.mv_copy{
		left:30px;
		right:20px;
		bottom:45%;
	}

	.mv_copy h1{
		font-size:3.2rem;
	}
	
	.mv_copy .mv_copy_en{
		font-size:1.4rem;
		margin-top:10px;
	}
	

	.scroll{
		bottom:40px;
	}
	
	
	
	/*----------------
		mv ピン止めnews
	--------------------*/
	.mv_news{
		right:0;
		left:0;
		 width: 100%;
   		 padding: 0 40px 0 30px;
	}
	.mv_news_link{
		justify-content: space-between;
	}
	.mv_news .news_title{
		font-size: 1.6rem;
	}
	
	/*----------------
		about
	--------------------*/
	
	#index_about{
		padding:100px 0 70px 0;
	}
	
	.about_txt{
		width:100%;
		margin-top:0;
	}
	.about_img{
		width:100%;
		margin-left:0;
		margin-top:20px;
	}
	
	.about_area p{
		margin-bottom:20px;
	}

	
	/*----------------
		Technology
	--------------------*/
	#index_technology{
		padding:40px 0 80px 0;
	}
	.technology_head {
		margin-bottom:20px;
	}
	.technology_head p{
		margin-bottom:20px;
	}
	
	.technology_item{
		width:100%;
		padding:30px 0 30px 0;
	}
	.technology_item:first-child{
		border-top:1px solid #ccc;
	}
	
	
	.technology_item_in{
		margin-bottom:20px;
	}
	.technology_contents_ttl span{
		font-size:1.6rem;
	}
	.technology_contents_ttl h3{
		font-size:3.0rem;
	}
	.technology_contents_ttl h3::after{
		font-size:1.6rem;
		margin-top:8px;
	}
	
	
	.technology_item_sp{
		margin-bottom:20px;
	}
	
	/*----------------
		Product
	--------------------*/
	
	#index_product{
		padding:60px 0 100px 0;
	}
	
	.product_head_ttl .top_ttl{
		margin-bottom:10px;
	}
	.product_head_ttl{
		margin-bottom:20px;
	}
	
	
	.product_item{
		padding:20px 20px 20px 30px;
	}
	
	
	
	.swiper-container{
		width: 106.2%;
	}
	.home .swiper-container .swiper-scrollbar{
		width:calc(100% - 20px);
	}
	
	
	
	.swiper-slide a{
		height:300px;
	}
	
	.product_ttl h3{
		font-size:2.2rem;
	}
	.product_ttl h3:after{
		font-size:1.6rem;
	}
	
	
	/*----------------
		info
	--------------------*/
	.info_box{
		width:100%;
	}
	.info_box_in{
		padding:40px 20px 40px 20px;
		height:300px;
	}
	
	.info_content .top_ttl h2::before{
		font-size: 4.0rem;
	}
	
	
	.info_content::before{
		width:100%;
		height:1px;
		top:300px;
		left:0;
	}
	.info_content:after{
		width:100%;
		height:1px;
		top:600px;
		left:0;
	}

	/*----------------
		news
	--------------------*/
	#index_news {
		padding: 50px 0 60px;
	}


	.news_head {
		width: 100%;
		margin-right:0;
	}

	.news_content {
		width: 100%;
	}

	.news_list{
		margin-bottom:20px;	
	}
	
	.news_link {
		padding: 15px 0;
		align-items: center;
	}

	.news_link .news_date {
		font-size: 1.3rem;
		line-height: 24px;
		width: auto;
		margin-right:15px;
	}

	.news_link .news_cate {
		/*width: 110px;*/
		width:auto;
		font-size: 1.1rem;
		margin-right:0;
	}

	.news_link .news_title {
		width: 100%;
		padding-top: 2px;
	}

	.news_content .link_btn {
		text-align: center;
	}

	.news_content .link_btn a {
		margin-bottom: 0;
	}


}