@charset "utf-8";

/* ----------------------------------
  各ページ カバー背景 共通 ここから
-------------------------------------*/
.kv-common {
	background:  linear-gradient(to right, #0f3dd7 0%, #06cad1 100%);
}

/* ----------------------------------
  各ページ カバー写真 ここまで
-------------------------------------*/

/* ----------------------------------
  共通 メインコンテンツ ここから
-------------------------------------*/

h2{
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	color: #222;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.85;
	letter-spacing: 0.075em;
	font-feature-settings: "palt";
	text-align: justify;
}

/* 余白調整 */
.mt3 {
	margin-top: 3.0rem;
}
.mt6 {
	margin-top: 6.0rem;
}
.mt10 {
	margin-top: 10.0rem;
}
.mb1 {
	margin-bottom: 1.0rem;
}
.mb3 {
	margin-bottom: 3.0rem;
}
.mb6 {
	margin-bottom: 6.0rem;
}
.mb10 {
	margin-bottom: 10.0rem;
}
.pt05 {
	padding-top: 0.5rem;
}
.pt10 {
	padding-top: 10.0rem;
}
.pb10 {
	padding-bottom: 10.0rem;
}
.margin5 {
	margin: 2.0rem;
}
.padding2 {
	padding: 2.0rem;
}
/* cate 余白 */
#cate1,#cate2,#cate3,#cate4,#cate5 {
	margin-bottom: 10.0rem;
}

/* レイアウト */
.contents_inner {
	max-width: 1200px;
	margin: 0 auto;
 	padding: 6.0rem 6.0rem 0;
}

.technology_inner {
	max-width: 1200px;
	margin: 0 auto;
}

.contents_title {
	font-size: 3.6rem;
	text-align: center;
	font-weight: bold;
	color: rgb(31, 80, 187);
	margin-bottom: 6.0rem;
}

.contents_title span {
	font-size: 2.6rem;
	color: #000;
}

.contents_head {
	color: #000;
	line-height: 1.5;
	font-size: 2.8rem;
	font-weight:bold;
	letter-spacing: 0.075em;
	display: inline;
	background: linear-gradient(transparent 70%, #87fd97 70%);
}

.contents_text {
	color: #000;
	line-height: 1.5;
	font-size: 2.0rem;
}

/* カテゴリ */
.contents_cate {
  display: table;
  table-layout: fixed;
  list-style-type: none;
  margin: 10.0rem 0;
  width: 100%;
  height: 100%;
}

.contents_cate_list{
	display: table-cell;
	vertical-align: middle;
	border-right: 1px solid rgba(0, 0, 0, .0);
	word-wrap: break-word;
	height: 100%;
	padding: 1.0rem;
}

.contents_cate_list:first-child{
	border-left: 1px solid #fff;
}

.contents_cate_list a{
	display: inline-block;
	vertical-align: middle;
	padding: 1em;
	width: 100%;
	height: 100%;
	color: #000;
	text-decoration: none;
	text-align: center;
	background: #fff;
  	background-size: 200% 100%;
  	border: 1px solid #000;
	box-sizing: border-box;
	font-weight: bold;
}

.contents_cate_list a:hover {
	color: #fff;
	background: #000;
	background-position: 100% 0;
}

.overlap {
  margin-bottom: 10.0rem;
  background: #fff;
}

.overlap_inner {
  width: min(100%, 1200px);
  margin: 0 auto;
  display: flex;
  flex-direction: row-reverse; /* ← これで左右逆転 */
  align-items: center;
  position: relative;
}

.overlap_image-box {
  width: 55%;
  position: relative;
  z-index: 2;
}

.overlap_image-box img {
  width: 100%;
  display: block;
  border-radius: 4px;
}

.overlap_text-box {
  width: 45%;
  background: #f5f5f5;
  padding: 60px 50px;
  margin-right: -20px; /* ← 画像と重なる調整 */
  border-radius: 6px;
  position: relative;
  z-index: 1;
  box-shadow: 0 10px 25px rgba(0,0,0,0.08);
}

.overlap_text-box h2,
.contents_inner h2{
  font-size: 3.0rem;
  font-weight: bold;
  color: rgb(15, 58, 150);
  margin-bottom: 3.0rem;
}

.overlap_text-box p {
  font-size: 1.7rem;
  line-height: 1.8;
  margin-bottom: 35px;
}

.heading {
  padding: 0 .7em;
  border-left: 5px solid #d02550;
  color: #333333;
}

/* 仕様・詳細 */
.contents_details {
  position: relative;
  display: block;
  /* max-width: 1000px; */
  margin: 0;
  z-index: 0;
  background-color: #fff;
}

.technology_details {
	position: relative;
	display: block;
    max-width: 1000px;
    margin: 6.0rem;
    padding: 40px 64px;
    z-index: 0;
	border: 1px solid #a80218;
    background-color: #fff;
}

.details_heading {
	font-size: 2.6rem;
	font-weight: bold;
	padding: 0 .7em;
    border-left: 5px solid #2561d0;
    color: #333333;
	margin-bottom: 3.0rem;
}

.details_category {
	color: #000;
	line-height: 1.5;
	font-size: 2.0rem;
	font-weight:bold;
	letter-spacing: 0.075em;
	display: inline;
	background: linear-gradient(transparent 70%, #fdd487 70%);
}

.details_text {
	color: #000;
	line-height: 1.5;
	font-size: 2.0rem;
	margin: 1.0rem 0 2.0rem;

}

.details_text span {
	overflow-wrap: break-word;
  	word-break: break-word;
}

/* 要素2枚 横並び */
.details_box {
    display: flex;
    justify-content: center;
    margin: 0 auto;
}
.details_item1 {
    width: 50%;
    height: auto;
    display: flex;
    align-items: center;
}
.details_item2 {
    width: 50%;
    height: auto;
}
.details_item1 img,
.details_item2 img {
    width: 100%;
    height: auto;
}

/* 要素1枚 中央 */
.details_item3 {
    width: 100%;
    height: auto;
}
.details_item3 img {
    width: 100%;
    height: auto;
}

/* 動画 2枚並び */
.details_item4 {
    width: 50%;
    height: auto;
    display: block;
    align-items: center;
}
video {
	filter: drop-shadow(0px 0px rgba(0,0,0,0));
	outline: none;
	border: none;
}
.details_item4 video{
    width: 100%;
    height: auto;
}
.details_item5 {
    width: 50%;
    height: auto;
	display: flex;
    align-items: center;
}
.details_item6 {
    padding: 0 50px;
    border-radius: 6px;
}

/* テーブル */
.details_table {
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
}
.details_table th, .details_table td {
	font-size: 2.2rem;
	border: 2px solid #c14d53;
	font-weight: bold;
	padding: 0.4em;
}
.details_table thead th {
	font-size: 2.6rem;
	font-weight: bold;
	background-color: #dfadb0;
	color: #000;
	border: 2px solid #c14d53;
	border-right: 2px solid #c14d53;
	border-bottom: 2px solid #c14d53;
}
.details_table thead th:last-of-type {
	border-right: 2px solid #c14d53;
}
.details_table tbody th {
	font-size: 2.2rem;
	color: #000;
	font-weight: bold;
}

.contents_button { /* ボタン */
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 250px;
    margin:0 auto;
    padding: .9em 2em;
    overflow: hidden;
    border: 1px solid #000;
    border-radius: 5px;
    background-color: #fff;
    color: #000;
    font-size: 1em;
}
.contents_button:hover {
    background-color: transparent;
    color: #fff;
}
.contents_button::before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 0;
    height: 100%;
    background-color: #000;
    content: '';
    transition: width .3s ease;
}
.contents_button:hover::before {
    width: 100%;
}

/* ----------------------------------
  共通 メインコンテンツ ここまで
-------------------------------------*/

/* ----------------------------------
  お知らせ ここから
-------------------------------------*/
.top_news{
	position: relative;
	overflow: visible;
}

.news_contents_inner{
	max-width:960px;
	position:relative;
	margin:0 auto;
	border-radius: 10px;
}

.news-list {
	list-style-type: none;
	padding-left: 0;
}

.news-list .news-list-item h2:hover{
	color: #64CCBF;
}

.news-list-item time {
	display: inline-block;
	margin-bottom: 1rem;
	color: #333333;
	padding-left: 3rem;
}
.news-list-item h2 {
	padding: 0 3rem;
}
.news-list-item .news-title {
	font-size: 1.6rem;
	font-weight: 800;
	font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
}

.item_hover{
	transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
    transform: translateY(0);
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.item_hover:hover{
	transform: translateY(-5px);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.news-link {
  display: block;
  text-decoration: none;
  color: inherit;
  padding: 2rem 0;
  margin: 5px 0;
  border: 1px solid #e5e5e5;
}

.news-list h2{
	color: #000;
}

.category{
	display: inline-block;
	text-align: center;
	color: #fff;
	font-size: 1.6rem;
	min-width: 12.0rem;
	border-radius: 5px;
	margin-left: 5px;
}

.color1{/* お知らせ */
	background-color: #136FFF;
}

.color2{/* トピックス */
	background-color: #0ecc27;
}

.color3{/* プレスリリース */
	background-color: orangered;
}

.color4{/* イベント */
	background-color: #e4bb05;
}

.arrow svg{
	position: absolute;
	right: 2%;
	top: 50%;
}

#nw1, #nw2, #nw3, #nw4, #nw5, #nw6, #nw7, #nw8{
	padding-top:20rem;
	margin-top:-20rem;
}

.news_bg{
	background-color: #F5F7FA;
}

/* Pagenation ここから */
.page_list {
    margin-bottom: 20px;
}

.page_list li {
  display: none !important; /* 初期は非表示 */
}

.page_list li.on {
  display: block !important;
}

.pagination .number > a.active {
    background-color: #000;
    color: #fff;
}

.pagination {
    width: 70%;
	margin: 50px auto;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content:center;
    gap: 5px;
}

.pagination .number {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 5px;
}

.pagination a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
	color: #000;
    background-color: #ffffff;
    border: solid 1px #333;
    border-radius: 50%;
}
/* Pagenation ここまで */

/* filter ここから */
.news_filter-buttons {
  margin: 6.0rem 0;
  text-align: center;
}

.news_filter-buttons button {
	display: inline-block;
    width: 120px;
    margin: 0 10px;
    padding: 10px 5px;
    font-weight: bold;
    cursor: pointer;
    border: 1px solid #000;
    background-color: #fff;
}

.news_filter-buttons button:hover {
  background-color: #1597CC;
  color: #fff;
}
/* filter ここまで */

/* お知らせ記事 ここから */
.news_article_box {
	display: flex;
	justify-content: flex-start;
}

.news_article picture {
	width: 100%;
	height: auto;
}

.news_article picture img{
	width: 100%;
}

.news_article_heading {
    border-bottom: 3px solid #f2f2f2;
}

.news_article_heading span {
    display: inline-block;
    position: relative;
    padding: 0 .4em .2em;
    color: #333333;
}

.news_article_heading span::before {
    position: absolute;
    bottom: -3px;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: #25d097;
    content: '';
}

.news_content_date {
	margin-left: 1px;
	margin-right: 1.0rem;
	color: #222;
	font-family: "droid-sans", sans-serif;
	font-weight: 400;
	font-style: normal;
}

.day_color {
	color: rgb(201, 17, 17);
}

.contents_text a{
	color: #000;
}

.contents_text a:hover{
	color: #25d097;
}

.news_flex_item{
	width: 100%;
	display: flex;
	justify-content: center;
}

.news_flex_item picture {
	padding: 1.0rem;
}
/* お知らせ記事 ここまで */

/* トップへ戻る ここから */
.return_btn,
.return_btn_top{
	text-align: center;
}
.return_btn_top {
    margin-top: 10.0rem;
    padding-bottom: 6.0rem;
}
.return_btn a,
.return_btn_top a{
	font-size: 1.6rem;
	color: #000;
	border: 1px solid #000;
    display: inline-block;
    font-weight: bold;
    margin: 0 auto;
    padding: 1rem 4rem;
}
.return_btn a:hover{
	color: #fff;
	border: 1px solid #000;
	background-color: #000;
}
.return_btn_top a:hover{
	color: #fff;
	border: 1px solid #000;
	background-color: #000;
}
.return_btn i{
	padding-right: 5px;
}
/* トップへ戻る ここまで */

/* ----------------------------------
  お知らせ ここまで
-------------------------------------*/

/* ----------------------------------
  製品情報・技術情報 トップ共通 ここから
-------------------------------------*/
.service_page{
  position: relative;
  margin-top: 6.0rem;
}
.service_page_inner{
  max-width: 1200px;
  margin: 0 auto;
}
.service_page_bg{
	margin-bottom: 6.0rem;
}

/* 見出し ここから */
.service_page_heading {
	display: flex;
    border-bottom: 4px solid #ddd6d6;
	margin: 0 2.0rem;
  	align-items: center;
  	justify-content: space-between;
}
.service_page_heading span {
    display: inline-block;
    position: relative;
    padding: 0 .4em .2em;
    color: #333333;
	font-size: 2.6rem;
	font-weight: bold;
}
.service_page_heading a{
	font-size: 1.6rem;
	font-weight: bold;
	padding: 0 .4em .2em;
	color: #000;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.service_page_heading a:hover{
	transform: translateY(-2px);
	-webkit-transform: translateY(-2px);
}
.service_page_heading span::before {
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 100px;
    height: 4px;
    background-color: #0062a8;
    content: '';
}
/* 見出し ここまで */

/* 一覧 */
.service_page_wrap{
   display:flex;
   flex-wrap:wrap;
   list-style:none;
   margin:0;
   padding:0;
}
.service_page_item{
   width:21%;
   margin:2%;
}
.service_page_item img{
   width: 100%;
}
.service_page_item h3{
	color: #333;
	font-size: 1.8rem;
	font-family: 'Noto Sans JP', 'YuGothic', 'Yu Gothic', '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', 'Meiryo', 'Microsoft YaHei', sans-serif;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.service_page_item h3:hover{
	transform: translateY(-2px);
	-webkit-transform: translateY(-2px);
}

/* ----------------------------------
  製品情報・技術情報 トップ共通 ここまで
-------------------------------------*/

/* ----------------------------------
  コラム ここから
-------------------------------------*/
.column_inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
}
.page_list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

/* filter ボタン ここから */
.column_filter-buttons {
  margin: 6.0rem 0;
  text-align: center;
}
.column_filter-buttons button {
  display: inline-block;
  width: 120px;
  margin: 10px;
  padding: 10px 5px;
  font-weight: bold;
  cursor: pointer;
  border: 1px solid #1597CC;
  background-color: #fff;
  border-radius: 5px;
}
.column_filter-buttons button:hover {
  background-color: #1597CC;
  color: #fff;
}/* filter ボタン ここまで */

/* ----------------------------------
  コラム ここまで
-------------------------------------*/

/* ----------------------------------
  タブレット ここから
-------------------------------------*/
@media (min-width: 768px) and (max-width: 1024px) {

	/* 共通 ここから */
	.contents_inner {
		padding: 6.0rem 1.0rem 0;
	}
	.contents_cate_list a {
		padding: 0.5em;
	}
	/* 共通 ここまで */

	/* お知らせ ここから */
	.news_filter-buttons button {
		margin: 0;
		padding: 5px 0;
	}
	/* お知らせ ここまで */

}

/* ----------------------------------
  タブレット ここまで
-------------------------------------*/

/* ----------------------------------
  スマートフォン ここから
-------------------------------------*/
@media (max-width: 767px) {

	/* 共通メインコンテンツ ここから */
	.contents_inner {
		padding: 0 3.0rem;
	}

	.overlap_inner {
		display: block;
	}

	.overlap_text-box h2, .contents_inner h2 {
		font-size: 2.6rem;
		margin-top: 6.0rem;
	}

	.contents_head {
		font-size: 2.4rem;
	}

	.contents_details {
		margin: 0 3.0rem;
		padding: 30px 30px;
	}

	.contents_text {
		font-size: 1.8rem;
	}

	.contents_cate {
		padding: 8.0rem 0 0;
	}

	.overlap_image-box img {
		width: 90%;
		margin: 0 auto;
	}

	.details_heading {
		font-size: 2.2rem;
	}

	.details_category {
		font-size: 1.8rem;
	}

	.details_text {
		font-size: 1.6rem;
	}

	.details_box {
		display: block;
	}

	.details_item1 {
		width: 100%;
        margin: 0 auto;
        margin-bottom: 3.0rem;
	}

	.details_item2 {
		width: 100%;
	}

	.details_item4 {
		width: 100%;
	}

	.details_item5 {
		width: 100%;
	}

	.details_item6 {
		margin-bottom: 40px;
		padding: 0;
	}

	.details_item2 img {
		margin-bottom: 1.0rem;
	}

	.details_table {
		width: 100%;
		border-collapse: collapse;
		text-align: left;
	}

	.details_table tbody th{
		background: #dfadb0;
		color:#000;
	}

	.details_table colgroup {
		display: none; /* 横幅指定を無効化 */
	}

	.details_table thead {
		display: none; /* 見出しを非表示（縦持ちにするため） */
	}

	.details_table tr {
		display: block;
		width: 100%;
		margin-bottom: 15px;
		border: 1px solid #ccc;
		padding: 10px;
		box-sizing: border-box;
	}

	.details_table td, .details_table th {
		display: block;
		width: 100%;
		text-align: left;
		padding: 6px;
		box-sizing: border-box;
		border: 0;
		border-bottom: 2px solid #c14d53;
	}

	/* data-label の内容を前に表示する */
	.details_table td::before{
		content: attr(data-label);
		color: #000;
		font-weight: bold;
		display: inline-block;
		width: 20%;
		min-width: 4em;
	}

	/* th（設備名）には出ないように調整 */
	.details_table th::before {
		content: "";
	}

	.details_table th, .details_table td {
		display: block;
		border: 0;
		border-bottom: 2px solid #c14d53;
	}

	.overlap_image-box,
	.overlap_text-box {
		width: 100%;
	}

	.overlap_image-box {
		margin-bottom: 3.0rem;
	}

	.overlap_text-box {
		margin: -40px 0 0 0;
		padding: 40px 25px;
	}

	/* 共通メインコンテンツ ここまで */

	/* お知らせ ここから */
	.news_content_title {
		font-size: 1.8rem;
	}

	.news-list-item time {
        padding-left: 2rem;
    }

    .news-list-item h2 {
        padding: 0 7rem 0 2rem;
    }

	.news-list-item .news-title {
        font-size: 1.4rem;
    }

    .news_content_date{
        margin-bottom: 4px;
    }

    .news_content_text {
        margin-bottom: 30px;
        padding-bottom: 30px;
    }

	.return_btn a {
		font-size: 1.2rem;
		padding: 0.6rem 3rem;
	}

	.return_btn_top {
		margin-top: 6.0rem;
		padding-bottom: 6.0rem;
	}

	.news_flex_item {
		display: block;
	}

	.news_flex_item picture {
		padding: 0;
	}
	/* お知らせ ここまで */
	
}

@media (max-width: 486px) {

	/* 共通メインコンテンツ ここから */
	.contents_cate {
		display: none;
	}

	.contents_details {
		margin: 0 1.0rem;
		padding: 20px;
  	}

	.contents_inner {
    	padding: 6.0rem 1.0rem 0;
  	}

	.technology_inner {
        padding: 0 1.0rem;
    }

	.contents_inner h2 {
   		margin-top: 20px;
  	}

	.overlap {
		padding: 6.0rem 0 0;
	}

	.accordion_title {
		font-size: 1.6rem;
	}

	.details_item2 {
        margin-bottom: 0;
    }

	.details_item6 {
        margin-top: 40px;
    }

	.padding2 {
		padding: 0;
	}

	.details_table tbody th {
		font-size: 2.0rem;
	}

	.details_table td, .details_table th {
        font-size: 1.7rem;
    }

	.details_table td::before {
        width: 40%;
    }

	.details_table .td_width::before {
		width: 100%;
	}
	/* 共通メインコンテンツ ここまで */

	/* お知らせ ここから */
	.top_news {
        width: 100%;
    }

	.news_contents_inner {
        padding: 1.5rem 2rem 0;
        margin: 0 auto 10.0rem;
        border: 0;
        border-radius: 0;
    }

	.news_filter-buttons button {
        margin: 5px;
    }

	.news_filter-buttons {
		margin: 0 0 4.0rem;
		text-align: center;
	}

	.pagination {
		width: 100%;
	}

	h4.top_news_title {
        font-size: 2.6rem;
    }

    .category {
        font-size: 1.4rem;
    }

    h4.top_news_text {
        font-size: 1.2rem;
    }
	/* お知らせ ここまで */

  	/* 製品情報・技術情報 トップ ここから */
	.service_page_wrap{
		display:block;
	}

	.service_page_item {
        width: 80%;
		padding: 10px;
        margin: 3rem auto;
    }

	.service_page_heading {
		margin: 0 2.0rem;
	}

	.service_page_heading span {
		font-size: 2.0rem;
	}
	
	.service_page_heading a {
		font-size: 1.4rem;
	}
	/* 製品情報・技術情報 トップ ここまで */

	/* コラム ここから */
	.column_filter-buttons button {
		width: 100px;
		padding: 5px 5px;
	}
	/* コラム ここまで */

}

/* ----------------------------------
  スマートフォン ここまで
-------------------------------------*/