@charset "utf-8";

.pb40 {
	padding-bottom: 40px !important;
}

.img-100 {
	width: 100%;
	height: auto;
}
dt,dd {
	font-size: 16px;
}

.h-100 {
	height: 100%;
}


nav.default {
	border: 0;
}

ul.default {
	font-size: 16px;
	padding-left: 1em;
}
ul.default li {
	list-style: disc outside;
}
ul.default li + li {
	margin-top: 10px;
}

.cursor-progress {
	cursor : progress !important;
}


@media (min-width: 768px) {
	.new-wrap .col-sm-15 {
	  width: 20%;
	  flex: 0 0 20%;
	}
  }
  @media (min-width: 992px) {
	.new-wrap .col-md-15 {
	  width: 20%;
	  flex: 0 0 20%;
	}
  }
  @media (min-width: 1200px) {
	.new-wrap .col-lg-15 {
	  width: 20%;
	  flex: 0 0 20%;
	}
  }
  .new-wrap .col-15{
	width: 20%;
	flex: 0 0 20%;
  }



/*ヘッダーナビのプルダウン。コムスキャンテクノページで使用*/
.pulldown-parent {
	position: relative;
}
.pulldown-children {
	display: none;
	position: absolute;
	top: 45px;
	width: 250px;
	background-color: #f5f5f5;
	z-index: 999;
	box-shadow: 0 0 5px rgba(0,0,0,.3);
}
.pulldown-parent:hover .pulldown-children {
	display: block;
}
.pulldown-children li a {
	display: block;
	padding: 1em;
}
.pulldown-children li a:hover {
	background-color: #fcfcfc;
}


.menu-btn{
	position: absolute !important;
}
.overlay{
	position: relative;
}
.overlay::after{
	content: "";
	transition: 0.5s;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
}
.overlay.active::after{
	bottom: 0;
	background: rgba(0,0,0,0.3);
	z-index: 1;
}
.overlay.fixed{
	margin-top: 65px;
}
.new-wrap p:not(.new-page-anchor-menu){
	margin-bottom: 20px;
	font-size: 16px;
}
.new-wrap p:not(.new-page-anchor-menu).mb_non {
  margin-bottom: 0;
}
.new-wrap p:not(.new-page-anchor-menu).mb_non.t2 {
  margin-top: 20px;
}
.new-wrap *{
	text-transform: none;
	line-height: 1.5;
}
.new-wrap a{
	transition: 0.5s;
}
.new-wrap .bread{
	padding-top: 0;
}
.new-wrap .bread .container{
	padding: 0;
}
.new-wrap .bread ul li{
	font-size: 13px;
}
.new-wrap nav{
	display: block;
	position: static;
	background: transparent;
}
.new-wrap .anchor-point{
	position: relative;
	top: -80px;
	height: 0;
}
.new-contact-form{
	width: 100%;
	max-width: 894px;
	margin: auto;
}
.new-contact-form.contact-page{
	justify-content: center;
}
.new-contact-form.contact-page .pic{
	margin-bottom: 20px;
	text-align: center;
}
.text-large{
	font-size: 18px !important;
}
@media (min-width: 768px){
	.new-contact-form.contact-page .pic{
		width: 130px;
		margin-bottom: 0;
	}
	.new-contact-form.contact-page .text{
		width: calc(100% - 130px);
		padding-right: 30px;
	}
	.text-large{
		font-size: 1.8rem !important;
	}
}
@media (min-width: 992px){
	.overlay.fixed{
		margin-top: 135px;
	}
	.overlay.no-submenu.fixed{
		margin-top: 65px;
	}
	.overlay.no-anchor-area.fixed{
		margin-top: 65px;
	}
	.new-wrap .anchor-point{
		top: -210px;
	}
}

/* ページナビゲーション */
.new-page-title{
	padding: 10px 0 !important;
	font-size: 16px;
	font-weight: bold;
	color: #105fad;
}
.new-page-title.healthcare {  
  padding-top: 60px !important;
  margin: 0 -15px 10px;
  background: url(../images/header_healthcare.jpg) no-repeat center / cover;
}
.new-page-title.healthcare .t_img {
  font-size: 0;
  line-height: 1em;
  margin: -5px 0 5px;
}
@media (min-width: 992px){
  .new-page-title.healthcare {
    height: 168px;
    margin: 0 calc(50% - 50vw) 10px;
  }
}
@media (max-width: 768px){
  .new-page-title.healthcare {
    height: 96px;
  }
  .new-page-title.healthcare .t_img {
    font-size: 0;
    line-height: 1em;
    margin: -15px 0 5px;
  }
  .new-page-title.healthcare .t_img img {
    width: auto;
    height: 12px;
  }
}
.new-page-title span.t {
  display: block;
  line-height: 1em;
  width: 100%;
  padding: 0 15px;
  margin: auto;
}
.new-page-navi{
	margin-top: 20px;
}
.new-page-navi-list{
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	width: 100%;
}
.new-page-navi-item{
	width: 33.33333333%;
	height: 36px;
	border: 1px solid #c1c1c1;
}

.new-page-navi-item a{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	background: #f5f5f5;
	padding: 4px;
	font-size: 10px;
	color: #105fad;
	font-weight: bold;
	text-align: center;
}
.new-page-navi-item.active a{
	background: #c1c1c1;
}
@media (min-width: 576px){
	.new-page-title{
		padding: 3rem 0 !important;
		font-size: 3.4rem;
	}  
	.new-page-navi-item{
		height: 5rem;
	}
	.new-page-navi-item a{
		font-size: 12px;
	}
}
@media (max-width: 768px){
  .new-page-title span.t {
    font-size: 16px !important;
  }
}
@media (min-width: 992px){
	#header nav {
		height: 47px;
	}
	#header nav .container.fixed {
		position: fixed;
		top:0;
		width: 100%;
		background-color: #ecf0f3;
		z-index: 9999;
		border-bottom: 1px solid #cbcbcb;
	}
	#header nav .container.fixed .nav_v2 {
		max-width:1170px;
		margin: 0 auto;
		height: 45px;
	}
	#header nav .container.fixed .nav_v2 div {
		height: 44px;
	}
	#header nav .container.fixed .nav_v2 .gMenu {
		border-bottom-width: 0;
	}
	.pc-new-page-navi.fixed{
		position: fixed;
		top: 0;
		left: calc(50% - 470px);
		z-index: 5;
		width: 940px;
		background: #fff;
	}
	.pc-new-page-navi.navi-offset.fixed {
		top:45px;
	}
	.new-page-title{
		padding-top: 5rem !important;
	} 
  .new-page-title span.t {
    display: block;
    font-size: 36px;
    line-height: 1em;
    width: 940px;
    padding: 0;
    margin: auto;
  }
	.new-page-navi{
		margin-top: 10px;
		margin-bottom: 25px;
		border: 0;
	}
	.new-page-navi-item{
		width: 16.6666666666667%;
		border: 0;
		border-right: 1px solid #c1c1c1;
	}
    
    /* ナビゲーションが7つの時 */
    .new-page-navi-list .nav-7 {
		width: 14.2857%;
	}
    .new-page-navi-list .nav-7 a {
        letter-spacing: -0.01em !important;
	}
     /* ナビゲーションが5つの時 */
	 .new-page-navi-list .nav-5 {
		width: 20%;
	}
	.new-page-navi-item:first-child{
		border-left: 1px solid #c1c1c1;
	}
	.new-page-navi-item a{
		flex-direction: row;
		background: #fff;
		padding: 0 10px;
		font-size: 15px;
	}
	.new-page-navi-item a:hover,
	.new-page-navi-item.active a{
		border-bottom: 5px solid #105fad;
		background: #fff;
	}
}
@media only screen and (max-width:1199px) {
	.new-page-navi-item a{
		font-size: 13px;
        letter-spacing: -0.01em !important;
	}

}
@media (min-width: 1200px){
  
  .new-page-title span.t {
    display: block;
    width: 1140px;
    margin: auto;
  }
  
	.pc-new-page-navi.fixed{
		width: 1140px;
		left: calc(50% - 570px);
	}
}
@media (max-width: 991px){
	.new-style-header .container{
		width: 100%;
		max-width: none;
		padding: 0;
	}
	.new-page-header,
	.new-wrap .bread .container{
		padding: 0 15px;
	}
}

.new-page-title_back {
  position: absolute;
  left: calc(50% - 50vw);
  top: 0;
  z-index: -1;
  width: calc(100% + 50vw);
  height: 130px;    
}
.new-page-title_back.healthcare {
  background: url(../images/header_healthcare.jpg) no-repeat 50% 0 / cover;
}

/* ---------------------------------------

	解決事例

--------------------------------------- */
.new-case-solution-list h4 {
	font-size: 1.8rem;
	color: #115FAD;
	padding-bottom: .25em;
	margin-bottom: .5em;
	border-bottom: 1px solid #115FAD;

}
.new-case-solution-list dt {
	float: left;
	width: 7em;
	color: #115fad;
}
.new-case-solution-list dd {
	padding-left: 7em;
}


/* ---------------------------------------

	資料一覧リスト

--------------------------------------- */

.new-downloads-list li {
	border-bottom: 1px solid #ddd;
	padding: 1em 0;
}
.new-downloads-list li:first-child {
	border-top: 1px solid #ddd;
}

/* ---------------------------------------

	文中問い合わせエリア

--------------------------------------- */
.new-topic-contact {
}
.new-topic-contact-content {
	text-align: center;
}
.new-topic-contact-content h4 {
	font-size: 2rem;
	margin-bottom: 2rem;
}
.new-topic-contact-content p.phone {
	margin-bottom: 0;
}
.new-topic-contact-content p.phone a {
	font-size: 3rem;
	font-weight: bold;	
	color: #115FAC;
}

.new-topic-contact-content .cc-btn a {
	display: block;
	background-color: #115FAC;
	margin: 0 auto;
	border-radius: 5px;
	padding: 1em 2rem;
	width: 80%;

	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
}
@media (min-width: 768px){
	.new-topic-contact-content .cc-btn a {
		width: 60%;
	}
}


/* ---------------------------------------

	フッターお問い合わせエリア

--------------------------------------- */
.new-footer-contact {
	background-color: rgb(232, 243, 254);
	border-top: 1px solid #eee;
}
.new-footer-contact-content {
	padding: 4rem 0;
	text-align: center;
}
.new-footer-contact-content h4 {
	font-size: 2rem;
	margin-bottom: 2rem;
}
.new-footer-contact-content p.phone {
	margin-bottom: 0;
}
.new-footer-contact-content p.phone a {
	font-size: 3rem;
	font-weight: bold;	
	color: #115FAC;
}

.new-footer-contact-content .cc-btn a {
	display: block;
	background-color: #115FAC;
	margin: 0 auto;
	border-radius: 5px;
	padding: 1.5rem;
	width: 80%;
	max-width: 300px;
	color: #fff;
	font-size: 2rem;
	font-weight: bold;
}






/* ページ内リンクリスト */
.new-page-anchor-area{
	position: relative;
	z-index: 2;
	background: #fff;
}
.new-page-anchor-area.fixed{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
}
.new-page-anchor-box{
	display: flex;
	align-items: center;
	width: 100%;
	box-shadow: 0px 8px 10px -10px #aaa;
	padding: 10px 15px;
	background: #fff;
	color: #105fad;
	font-weight: bold;
	position: relative;
	z-index: 2;
}
.new-page-anchor-title{
	width: calc(100% - 70px);
	font-size: 14px;
	line-height: 1;
}
.new-page-anchor-title .upper-text{
	display: block;
	margin-bottom: 5px;
	font-size: 10px;
}
.new-page-anchor-menu{
	width: 50px;
	margin-left: auto;
	font-size: 10px;
	text-align: center;
}
.new-page-anchor-menu:hover{
	cursor: pointer;
}
.new-page-anchor-menu i{
	font-size: 20px;
	transition: 0.5s;
}
.new-page-anchor-menu.active i{
	transform: rotate(90deg);
}
.new-page-anchor-list{
	height: 0;
	background: #fff;
	padding: 0 15px;
	opacity: 0;
	overflow: hidden;
	transition: 0.5s;
}
.new-page-anchor-list.active{
	height: auto;
	opacity: 1;
	padding: 10px 15px 0;
}
.new-page-anchor-item{
	padding: 10px 0;
	border-bottom: 1px solid #eeeeee;
}
.new-page-anchor-item:last-child{
	border-bottom: 0;
}
.new-page-anchor-item a{
	display: block;
	position: relative;
	padding-right: 4rem;
}
.new-page-anchor-item a::after{
	content: "\f101";
	display: block;
	position: absolute;
	right: 0;
	top: calc(50% - 18px);
	font-family: FontAwesome;
	font-size: 24px;
	color: #115fad;
}

.sns_button:hover{
	opacity: 0.8;
}

@media (min-width: 992px){
	.new-page-anchor-area.fixed{
		position: static;
	}
	.new-page-anchor-box{
		display: none;
	}
	.new-page-anchor-list{
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		height: auto;
		opacity: 1;
		background: #f0f4f6;
		padding: 1rem 3.5rem;
	}
  .new-page-anchor-list.white {
    background: #fff;
    padding-left: 0 !important;
  }
	.new-page-anchor-item{
		margin-right: 4rem;
		padding: 0.5rem 0;
		border: 0;
	}
	.new-page-anchor-item:last-child{
		margin-right: 0;
	}
	.new-page-anchor-item a{
		display: inline;
		padding: 0;
		color: #115fad;
	}
	.new-page-anchor-item a::after{
		content: none;
	}
	.new-page-anchor-item a:hover{
		opacity: 0.7;
	}
}

/* section関連 */
.new-top-common{
	padding-top: 4rem;
	padding-bottom: 6rem;
}
.new-section-common{
	padding-bottom: 7rem;
}
.relative-content .border-content-box{
	padding: 5rem 0;
}
.border-content-box{
	border-bottom: 1px solid #d2d2d2;
}
.border-content-box:first-child{
	border-top: 1px solid #d2d2d2;
}
.topic-box + .topic-box{
	padding-top: 5rem;
}

/* タイトル関連 */
/* .new-page-sectioin クラスは使わないでください。見つけ次第、.new-page-section クラスに書き換えること */
.new-page-sectioin,
.new-page-section,
.new-section-title,
.new-section-title-plain,
.new-section-lead,
.new-section-lead-mb,
.new-section-sublead,
.new-topic-title,
.mro-magazine-content h2,
.mro-magazine-content h3 {
	color: #115fad;
	font-weight: bold;
}

/* .new-page-sectioin クラスは使わないでください。見つけ次第、.new-page-section クラスに書き換えること */
.new-page-sectioin,
.new-page-section {
	margin-bottom: 10px;
	font-size: 2.8rem;
}

/* .new-page-sectioin クラスは使わないでください。見つけ次第、.new-page-section クラスに書き換えること */
.new-page-sectioin span,
.new-page-section span {
	font-size: 2.2rem;
}

.new-section-title,
.new-section-title-plain,
.mro-magazine-content h2 {
	margin-bottom: 25px;
	background: #f0f4f6;
	padding: 2rem 2.5rem !important;
	font-size: 2.2rem;
}
.new-section-title-plain {
	background-color: #fff;
	padding: 0 !important;
}
.mro-magazine-content h2 {
	margin-top: 5rem;
}
.new-section-lead,
.new-section-lead-mb,
.mro-magazine-content h3 {
	margin-bottom: 10px;
	padding: 0;
	font-size: 18px;
}
.new-section-lead-mb,
.mro-magazine-content h3 {
	margin-bottom: 3rem;
}
.new-section-sublead {
	margin-bottom: 10px;
	padding: 0;
	font-size: 16px;
}
.new-section-sublead::before {
	content: '●';
}
.new-topic-title{
	margin-bottom: 20px;
	font-size: 2rem;
}

.mro-magazine-content .mro-magazine-top{
	background-color: #f0f4f6;
	text-align: center;
	padding: 1rem 0;
	margin-bottom: 25px;
}

.mro-magazine-top h2 {
	font-size: 2rem;
	margin-bottom: 2rem;
	margin-top: 2rem;
}

.mro-magazine-top .link-btn a{
	display: block;
    background-color: #115FAC;
    margin: 0 auto;
    border-radius: 5px;
    padding: 1.5rem;
    width: 80%;
    max-width: 300px;
    color: #fff;
    font-size: 2rem;
    font-weight: bold;
}

@media (min-width: 768px){
	/* .new-page-sectioin クラスは使わないでください。見つけ次第、.new-page-section クラスに書き換えること */
	.new-page-sectioin,
	.new-page-section {
		font-size: 3.2rem;
	}

		/* .new-page-sectioin クラスは使わないでください。見つけ次第、.new-page-section クラスに書き換えること */
        .new-page-sectioin span,
		.new-page-section span {
        font-size: 2.6rem;
    }
    
	.new-section-lead{
		font-size: 20px;
	}
}

/* リンクボタン */
.button-parent{
	height: 100%;
}
.new-link-button{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 100%;
	height: 100%;
	max-width: 555px;
	border: 1px solid #b5b5b5;
	box-shadow: -3px 3px 6px -1px rgba(0,0,0,0.15);
	/* padding: 2.5rem 6rem 2.5rem 3rem; */
	padding: 2rem 4rem 2rem 2.5rem;
	text-align: center;
	font-size: 16px;
	color: #000000;
}
.new-link-button.heigh{
	padding: 3rem 4rem 3rem 2.5rem;
}
.new-link-button::after{
	content: "\f101";
	display: block;
	position: absolute;
	/* right: 2.5rem; */
	right: 1.5rem;
	top: calc(50% - 2.25rem);
	font-family: FontAwesome;
	font-size: 3rem;
	color: #115fad;
}
.new-link-button:hover{
	box-shadow: none;
	background: #fafafa;
}

.new-link-button.btn-nest {
	padding: 2rem 2.5rem;
	/*background-color: rgb(231, 244, 255);*/
}
.new-link-button.btn-nest::after {
	content: '';
}
.new-link-button.btn-nest::before {
	content: '';
	display: block;
	border: 20px solid #115fad;
	border-right-color: transparent;
	border-bottom-color: transparent;
	position: absolute;
	left: 0;
	top:0;
}
.new-link-button.btn-nest.btn-nest-primary::before {
	border: 20px solid #00a040;
	border-right-color: transparent;
	border-bottom-color: transparent;

}

.new-link-button.btn-nest .btn-nest-text {
	font-weight: bold;
	text-indent: -.25em;
}

.new-link-button.btn-nest .btn-nest-button {
	/*background-color: #115fad;*/
	border-radius: 5px;
	/*color: #fff;*/
	font-size: 2rem;
	font-weight: bold;
	color: #115fad;
	line-height: 1;

}
.new-link-button.btn-nest .btn-nest-button::after {
    content: "\f101";
	font-family: FontAwesome;
	margin-left: .25em;
	font-size: 1.5em;
	position: relative;
	top: 1px;
}
.new-link-button.h-90 {
	height: 90px!important;
}
/* 画像が並ぶリスト */
.new-img-item{
	margin-bottom: 30px;
}
.back .new-img-item {
  background-color: #eaeaea;
}
/* 画像リスト　キャプション付リンク */
.new-img-link figcaption::before{
	content: "\f0da";
	display: inline-block;
	padding-right: 10px;
	font-family: FontAwesome;
	color: inherit;
	font-size: 26px;
	vertical-align: middle;
}
.new-img-item a:hover{
	opacity: 0.7;
}

/* table */
.new-table-wrap{
	overflow-x: auto;
}
.scroll-table,
.new-table{
	width: 100%;
}

.new-table caption {
	caption-side: bottom;
	font-size: 12px;
}

.new-table th,
.new-table td{
	font-size: 14px;
}
.new-table .symbol-text{
	font-size: 18px;
}
.scroll-table th,
.scroll-table td{
	display: table-cell;
	padding: 12px;
	white-space: nowrap;
}

.table-style-small th,
.table-style-small td{
	font-size: 12px;
	padding: 8px;
}

.table-style-simple th,
.table-style-simple td{
	border: 1px solid #d2d2d2;
	font-weight: normal;
}
.table-style-simple thead th{
	background: #eeeeee;
	font-weight: bold;
	text-align: center;
}
.table-style-simple td{
	text-align: center;
}

@media (min-width: 992px){
	.scroll-table th,
	.scroll-table td{
		white-space:normal;
	}
}
@media (min-width: 992px){
	.table-style-simple{
		table-layout: fixed;
	}
}
/*  ----------------- リンク付きBOX ----------------- */

.link-box + .link-box {
	margin-top: 6rem;
}
@media (min-width: 768px){
	.link-box + .link-box {
		margin-top: 0;
	}
}

.link-box-inner {
	height:100%;
	position: relative;
	padding-bottom: 4em;
}
.link-box-nav {
	position: absolute !important;
	bottom: 0;
	top: auto !important;
	left: 0;
	right: 0;
	border-top: 1px solid #cbcbcb !important;
    border-bottom: 1px solid #cbcbcb !important;
	height: 4em;
	display: flex;
	
}
.link-box-nav a {
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all .5s;
}
.link-box-nav a:hover {
	background-color: #fafafa;
}



/*  ----------------- ご利用の流れ的なコンテンツ ----------------- */

.flow-content {

}
.flow-content dt {
	font-size: 1.6rem;
	color: #115fad;
}
.flow-content dd {
	margin-top: 10px;
	border: 1px solid #999999;
	padding: 1.5em;
	border-radius: 10px;

}
.flow-content dd *:last-child {
	margin-bottom: 0;
}

.flow-content dd + dt::before {
	display: block;
	content: '▼';
	font-size: 3rem;
	text-align: center;
}

/*  ----------------- 関連ページリンク ----------------- */
.relative-page{
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
}
.relative-page a{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
}
.relative-page a:hover{
	background: rgba(255,255,255,0.3);
}
.relative-page .new-img-item{
	margin-bottom: 2rem;
}

.relative-page .new-img-item img {
    border: 1px solid #ccc;
}

@media (min-width: 992px){
	.relative-page .new-img-item{
		min-height: 90px;
	}
}
@media (min-width: 1200px){
	.relative-page .new-img-item{
		min-height: 110px;
	}
}



/* 画像なしタイプ( ex: バリ取りロボットシステム 最下部など）*/

.relative-content .border-link .relative-page-text {
    font-size: 1.6rem!important;
    background-color: #fff;
    border: 1px solid #115fad;
    
}
.relative-content .border-link a {
    box-shadow: -3px 3px 6px -1px rgb(0 0 0 / 15%);
}
.relative-content .border-link a:hover {
    box-shadow: none;
}

.relative-page-text{
	display: flex;
	align-items: center;
	position: relative;
	height: 100%;
	margin-bottom: 0 !important;
	background: #eeeeee;
	padding: 15px 5.5rem 15px 2rem;
	color: #1b1b1b;
	font-size: 14px !important;
}
.relative-page-text::after{
	content: "\f061";
	display: block;
	position: absolute;
	right: 1.5rem;
	top: calc(50% - 2.25rem);
	font-family: FontAwesome;
	color: #115fad;
	font-size: 3rem;
}




/* ===== mogool以外のお問い合わせ ===== */
.new-wrap #contact .w80 {
    display: block;
}

.new-wrap #contact .container.contents {
    padding: 0 15px 30px;
}

.new-wrap .tw100 {
    width: 100%;
}

.new-wrap .cover {
    height: auto;
}

.new-wrap .film-flow li {
    height: auto;
    padding: 5px;
}

.arrow-box-area .arrow-box {
    background-color: #BBCCDD;
    color: #5D6E7F;
    text-align: center;
    font-weight: bold;
    padding: 10px;
    border-radius: 8px;
}

.arrow-box-area .arrow-btm {
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid #BBCCDD;
    margin: 20px auto;
}

.catalog-box .catalog-title {
    margin-bottom: 10px;
    color:  #115FAD;
}

.icon_flex .flex5 .subMenu2 .cover {
    height: 100%;
}

.table-2column th {
    font-weight: bold;
    color: #115fad;
}

.table-2column th,.table-2column td {
    padding: 12px;
    display: block;
    border-bottom: none;
    font-size: 1.2rem;
}

.table-2column tr:last-of-type td {
    border-bottom: 1px solid #d2d2d2;
}

.table-2column td{
    text-align: left;
}

.request-box {
    font-size: 1.8rem;
    font-weight: bold;
/*
    padding: 20px 10px;
    border: 2px solid #115FAC;
    box-shadow: 3px 3px 15px #ccc;
*/
}

.request-box li {
    padding-bottom: 15px;
}

.request-box li::before {
    content: '●';
    color: #115FAC;
    padding-right: 5px;
}

.request-box li:last-child {
    padding-bottom: 0;
}

@media (min-width: 768px){
	.table-2column th,.table-2column td {
        display: table-cell;
        border-bottom: 1px solid #d2d2d2;
    }

    .table-2column td{
        text-align: center;
    }
}

.topic-box .maintenance-flow {
    background-color: #eee;
    padding: 15px;
}

.bg-none {
    background-color: #fff;
    padding-left: 0!important;
}

.caption-box {
    position: relative;
    padding: 30px 10px;
    border: 3px solid #105fad;
}

.caption-box .caption-title {
    position: absolute;
    width: 100%;
    text-align: center;
    top: 0;
    left: 0;
}

.caption-box .new-section-sub{
    padding: 0 1em;
    display: inline-block;
    margin: 0;
    background-color: #fff;
    transform: translateY(-50%);
/*    transform: translateY(-50%) translateX(1em);*/
    color: #105fad;
}

.caption-box .caption-box-list li {
    padding-bottom: 20px;
}

.caption-box .caption-box-list li:last-child {
    padding-bottom: 0;
}

.round-bg-gray {
	border: 2px solid #ddd;
	background-color: #f5f5f5;
	border-radius: 20px;
	padding: 2em;
}
/* curation */

/* ハッシュタグリスト */
.curation-terms li {
	display: inline-block;
	margin: 0 1em .5em 0;
	background-color: #f0f4f6;
	border-radius: 5px;
	font-size: 11px;
}
.curation-terms li:hover {
	background-color:  #d3e1e9;
}
.curation-terms li a {
	padding: .5em 1em;
	display: inline-block;
}

/* メインカラムとサイドカラムのレイアウト*/
.curation-main,
.curation-sidebar {
	text-align: justify;
	padding-left: 15px;
	padding-right: 15px;
	margin-bottom: 5em;
}

@media (min-width: 992px){
	.curation-main,
	.curation-sidebar {
		padding-left: 0;
		padding-right: 0;
	}
}


/* 記事ページ */
.curation-main-date {
	margin-top: 3em;
	margin-bottom: .5em !important;
}
.curation-main-title {
	margin-bottom: 1em;
	padding-top: 0;
	font-size: 18px;
	color: #105fad;
}

.curation-main-terms {
	margin-bottom: 4.5em;
}


.curation-p,
.curation-ul {
	line-height: 1.8;
}


.curation-p {
	font-size: 14px !important;
}
.curation-p {
	margin-bottom: 3em !important;
}
.curation-ul {
	padding: 3em;
	border-radius: 20px;
	background-color: #f0f4f6;
	font-size: 12px;
	font-weight: bold;
	margin-bottom: 3em;
}
.curation-ul li {
	list-style: disc;
}
.curation-ul li + li {
	margin-top: 1em;
}
@media (min-width: 768px){
	.curation-main-title {
		font-size: 24px;
	}
	.curation-ul {
		font-size: 16px;
	}
	.curation-p {
	font-size: 18px !important;
	}
}


/*記事ページ下の「次へ」「前へ」のリンク*/
.curation-main-nav {
	border-top: 1px solid #5D6E7F;
	padding-top: 3em;
	margin: 5em 0 3em;
	display: flex;
	flex-wrap: wrap;
}
.curation-main-next,
.curation-main-prev,
.curation-main-back {
	display: flex;
	align-items: center;
	font-size: 16px;
}

.curation-main-next span,
.curation-main-prev span {
	/*display: none;*/
}
.curation-main-next {
	padding-right: 10px;
	justify-content: flex-start;
}

.curation-main-prev {
	padding-left: 10px;
	justify-content: flex-end;
}

.curation-main-back {
	padding: 0 10px;
	border-left: 1px solid #5D6E7F;
	border-right: 1px solid #5D6E7F;
	justify-content: center;
	white-space: nowrap;
}
@media (min-width: 768px){
	.curation-main-next span,
	.curation-main-prev span {
		display: inline;
	}
	.curation-main-next:after,
	.curation-main-prev:before {
		display: none !important;
	}
}

.curation-main-next i,
.curation-main-prev i {
	flex: 0 1 30px;
	font-size: 200%;
	vertical-align: sub;
}
.curation-main-prev i {
	margin-left: 10px;
}
.curation-main-next i {
	margin-right: 10px;
}

.curation-sidebar-title {
	margin-bottom: .5em;
	border-bottom: 1px solid #115fad;
	font-size: 18px;
}

/*サイドバー*/
.curation-sidebar-articles {
	margin-bottom: 3em;
}
.curation-sidebar-article {
	border-bottom: 1px dotted #5D6E7F;
	padding: .5em 0;
}
.curation-sidebar-article a {
	display: flex;
	align-items: center;
}
.curation-sidebar-article-thumbnail {
	flex: 0 0 50px;
	margin-right: 10px;
}
.curation-sidebar-article-title {
	font-size: 11px !important;
	margin-bottom: 0 !important;
}
.curation-sidebar-parent-category > a {
	display: block;
	padding-bottom: .5em;
	font-weight: bold;
	border-bottom: 1px dotted #5D6E7F;
}
.curation-sidebar-parent-category {
	margin-top: 1em;
}
.curation-sidebar-child-categories {
	margin-top: .5em;
	font-size: 11px;
}

/* アーカイブページ */
.curation-main-articles-title {
	margin-top: 2em;
	margin-bottom: 2em;
	padding-top: 0;
	font-size: 18px;
	color: #105fad;
}

.curation-main-article {
	margin-bottom: 3em;
}
.curation-main-article-thumbnail {	
}
.curation-main-article-thumbnail .sp {
	margin-bottom: .5em;
}
.curation-main-article-thumbnail .pc {
	display: none;
}
.curation-main-article-date {
	font-size: 11px !important;
	margin-bottom: .5em !important;
}
.curation-main-article-title {
	margin-bottom: .5em;
	padding-top: 0;
	font-size: 16px;
}
.curation-main-article-title a {
	color: #105fad;
}
.curation-main-article-title a:hover {
	color: #0d98d8;
}
.curation-main-article-terms {
	margin-bottom: .5em;
}
.curation-main-article-terms li a {
	padding: .25em .5em;
}
.curation-main-article-description {
	font-size: 12px !important;
	margin-bottom: .5em !important;
}
.curation-main-article-more {
	text-align: right;
}
@media (min-width: 567px){
	.curation-main-article {
		display: flex;
	}
	.curation-main-article-thumbnail {
		margin-right: 10px;
		flex: 0 0 30%;
	}
	.curation-main-article-thumbnail .sp {
		display: none;
	}
	.curation-main-article-thumbnail .pc {
		display: block;
	}
	.curation-main-article-more {
		border: 0;
	}
}
@media (min-width: 768px){
	.curation-main-articles-title {
		margin-top: 0;
		font-size: 24px;
	}
}
@media (min-width: 992px) {
	.curation-main-article-thumbnail {
		flex: 0 0 25%;
	}

}

/* ページネーション */
.pagenation {
    margin: 1em 0;
}
.pagenation:after, .pagenation ul:after {
    clear: both;
    content: ".";
    display: block;
    height: 0;
    visibility: hidden;
}
.pagenation ul {
	margin: 0;
	text-align: center;
}
.pagenation li {
    display: inline-block;
    list-style: none outside none;
    margin-left: 3px;
}
.pagenation li:first-child {
    margin-left: 0;
}
.pagenation li.active {
    background-color: #999999;
    border-radius: 3px;
    color: #FFFFFF;
    cursor: not-allowed;
    padding: 10px 20px;
}
.pagenation li a {
    background: none repeat scroll 0 0 #CCCCCC;
    border-radius: 3px;
    color: #FFFFFF;
    display: block;
    padding: 10px 20px;
    text-decoration: none;
    text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.2);
}
.pagenation li a:hover {
    background-color: #444444;
    color: #FFFFFF;
    opacity: 0.8;
    transition-duration: 500ms;
    transition-property: all;
    transition-timing-function: ease;
}

.border-color{
	border: 2px solid #115fad;
	border-radius: 5px;
	padding: 20px 10px;
}
.d-flex .border-color {
	width: 100%;
}
.border-top{
	border-top: 1px solid #eee;
}
.border-top.relative-content{
	padding-top: 4rem;
}
.color-inherit{
	color: inherit !important;
}

/* FAQリストコンテンツ ex) ドレントーレよくあるご質問ページなど */

.new-faq-list dt {
	font-size: 16px;
}
.new-faq-list dt a {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 15px;
	border-bottom: 1px solid #d2d2d2;
}
.new-faq-list dt a:hover {
	background-color:#BBCCDD;
}
.new-faq-list dt a:before {
	content: 'Q. ';
	padding-right: .5em;
}
.new-faq-list dt i {
	padding-left: 30px;
	margin-left: auto;
}
.new-faq-list dd {
	display: none;
	margin: 0;
	padding: 20px 15px 30px;
}
.new-faq-list dd p.answer-title {
	font-weight: bold;
	color:#115fad;
}
.new-faq-list dd p.answer-title:before {
	content: 'A. ';
}
.new-faq-list dd p.answer-text {

}

.news-list {
	border-top: 1px solid #ccc;
}
.news-list dt {
	padding-top: .5em;
}
.news-list dd {
	margin: 0;
	border-bottom: 1px solid #ccc;
	padding-bottom: .5em;
}
@media  (min-width: 576px ) {
	.news-list dt {
	padding-bottom: .5em;
	border-bottom: 1px solid #ccc;
	}
	.news-list dd {
		padding-top: .5em;
	}
}

/* 動画コンテンツ */

.flex-bottom-parent{
	display: flex;
	flex-direction: column;
}
.flex-bottom-child{
	flex: 3em;
}


/*----------------------------

アブラトール

----------------------------*/

/* 油吸収剤 製品ページ */
.oil-absorber-item .img-box {
	text-align: center;
	margin-bottom: 30px;
}
.oil-absorber-item figure.rounded {
    text-align: center;
    padding: 20px;
	position: relative;
}
.oil-absorber-item img {
	height: auto;
    max-height: 300px;
    width: auto;
}

.oil-absorber-item .youtube-link {
	display: inline-block;
	font-size: 2rem;
	margin-top: 1em;
}
.oil-absorber-item .youtube-link i {
	color: #f00;
}
.oil-absorber-item .discontinued {
	display: flex;
	align-items:center;
	justify-content: center;
	position: absolute;
	background-color: rgba(0,0,0,.5);
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
}
.oil-absorber-item .discontinued span {
	font-size: 4rem;
	color: #fff;
	font-weight: bold;
}
.oil-absorber-item table th {
	white-space: nowrap;
}

/* .oil-absorber-list tr td { border: 1px solid #fff; text-indent: -1em; padding-left: 1.5em;}
.oil-absorber-list tr td p { margin-bottom: 0; }

.oil-absorber-list tr td:first-child { font-weight: bold; white-space: nowrap; width: 150px;}
@media (max-width: 768px) { 
.oil-absorber-list .tableBorder > tbody > tr > td:first-child { width: 100%; border-bottom: 1px dotted #666; padding-bottom: 5px; }
.oil-absorber-list .tableBorder > tbody > tr > td:last-child { border-top: 0; }
}
.oil-absorber-list tr:nth-child(odd) td { background-color: #d0d8e8; }
.oil-absorber-list tr:nth-child(even) td { background-color: #eee; }

.oil-absorber-list table table { margin-bottom: 0; table-layout: fixed; width: auto; }
.oil-absorber-list table table th,
.oil-absorber-list table table td { border: 0; padding: 0 2em 0 0; }
.oil-absorber-list table table td:first-child {font-weight: normal; width: auto; }
@media (max-width: 992px) { 
.oil-absorber-list table table { display: block; }
.oil-absorber-list table table th,
.oil-absorber-list table table td { display: block; }
} */


.ui-widget-content a {
	padding: 5px 10px;
	display: block;
}
.oil-absorber-search-input {
    margin-top: 30px;
	display: flex;
}

.oil-absorber-search-input-model {
	width: 40%;
}
@media (max-width: 768px) { 
	.oil-absorber-search-input-model {
		width: 100%;
	}
}
.oil-absorber-search-input input,
.oil-absorber-search-input select { border: 2px solid #115FAD; border-radius: 6px; height: 36px; line-height: 36px;  width: calc(100% * 3/4); padding: 0 .5em; background-color:#ddeeff; color: #115FAD; }
@media (max-width: 768px) { 

}
.oil-absorber-search-input p { margin-top: 20px; color: #999; font-size: 12px; }

.oil-absorber-search-input a { display: inline-block; text-align: center; background-color: #a8cef4; color: #fff !important; font-weight: bold; height: 36px; width: calc(100% / 4); line-height: 36px; border-radius: 6px; padding: 0 .5em; margin-left: .5em; }
.oil-absorber-search-input a.none { cursor: not-allowed; }
.oil-absorber-search-input a[href^="http"] { background-color: #155FA8; cursor: pointer; }
.oil-absorber-search-table table tr.head td { background-color: #999; font-weight: bold;color: #fff; }
.oil-absorber-search-table table th,
.oil-absorber-search-table table td { vertical-align: middle; height: 36px; }

	.oil-absorber-search-table table .flR {
		float: right !important;
	}


.tablesorter th{
    position: relative;
    cursor: pointer;
    text-align: center;
}
.tablesorter th::before, .tablesorter th::after{
    content: '';
    position: absolute;
    z-index: 2;
    right: 7px;
    width: 0;
    height: 0;
    border: 4px dashed;
    border-color: #333 transparent;
    pointer-events: none;
}
.tablesorter th::before{
    border-bottom-style: solid;
    border-top: none;
    top: 30%;
}
.tablesorter th::after{
    border-top-style: solid;
    border-bottom: none;
    bottom: 30%;
}
.tablesorter th.tablesorter-headerAsc:after{
    border: none;
}
.tablesorter th.tablesorter-headerAsc:before{
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
}
.tablesorter th.tablesorter-headerDesc:before{
    border: none;
}
.tablesorter th.tablesorter-headerDesc:after{
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
}
.tablesorter th.tablesorter-header {
	padding-right: 1.5em;
}
.tablesorter th.tablesorter-header.sorter-false {
	padding-right: 8px;
}
.tablesorter th.sorter-false:before, .tablesorter th.sorter-false:after{
    border: none;
}

.oa_table th,
.oa_table td {
	text-align: center;
	vertical-align: middle !important;
}
.oa_table td .compare-thumb {
	display: block;
	width:115px;
	height:85px;
	border: 1px solid #ccc;
	background-color: rgb(232, 243, 254);
	margin: 0 auto;
}
.oa_table td img {
	width:100%;
	height: 83px;
	max-width: inherit;
	object-fit: contain;
}
a.compare-btn {
	display: block;
	width: 5em;
	margin: 0 auto;
	background-color:#115FAD !important;
	border-radius: 3px;
	padding: .25em !important;
	transition: all .1s;
	color: #fff;

}
a.compare-btn:hover {
	opacity: .8;
}

.compare-check:disabled {
	cursor: progress !important;
}
a.compare-btn.disabled {
	background-color: #ccc !important;
	cursor:not-allowed;
}



.some-handle {
	background-image: none !important;
	background-color: #f0f4f6 !important;
	padding: .5em !important;
	height: auto !important;
	text-align: center !important;
}


.oa-compare-error
 {
	display: none;
}
.oa-compare-error p {
	height: 300px;
	line-height: 300px;
	text-align: center;
	font-weight: bold;
}
#oa-compare-table {
	opacity: 0;
}

.dragtable-sortable { 
    list-style-type: none; margin: 0; padding: 0; -moz-user-select: none;
}
.dragtable-sortable li {
    margin: 0; padding: 0; float: left; font-size: 1em; background: white; 
}

.dragtable-sortable th, .dragtable-sortable td{
    border-left: 0px;
}

.dragtable-sortable li:first-child th, .dragtable-sortable li:first-child td {
    border-left: 1px solid #CCC; 
}

.ui-sortable-helper {
    opacity: 0.7;filter: alpha(opacity=70);
}
/*
.ui-sortable-placeholder { 
    -moz-box-shadow: 4px 5px 4px #C6C6C6 inset;
    -webkit-box-shadow: 4px 5px 4px #C6C6C6 inset;
    box-shadow: 4px 5px 4px #C6C6C6 inset;
    border-top: 1px solid #CCCCCC;
    visibility: visible !important;
    background: #fff !important; 
    visibility: visible !important;
}
*/
.ui-sortable-placeholder * { 
    opacity: 0.0; visibility: hidden; 
}



@media (max-width: 768px) {
	#oa-compare-table th,
	#oa-compare-table td,
	.dragtable-sortable th,
	.dragtable-sortable td  {
		display: table-cell;
	}
}
#oa-compare-table th,
#oa-compare-table td,
.dragtable-sortable th,
.dragtable-sortable td  {
	width: 150px;
	padding: 0 !important;
	text-align: center;
	background-color: #fcfcfc;
}
#oa-compare-table .solid,
.dragtable-sortable .solid {
	width: 100px;
	vertical-align: middle !important;
	font-weight: bold;
}
#oa-compare-table,
.dragtable-sortable {
	overflow-y: hidden;
}
#oa-compare-table .cell-wrap,
.dragtable-sortable .cell-wrap {
	padding: 10px;
	position: relative;
}
#oa-compare-table .cell-wrap {
	background-color: #fcfcfc;

}
.dragtable-sortable .cell-wrap {
	background-color: #195fa9;
}
#oa-compare-table a.product,
.dragtable-sortable a.product {
	display: block;
	font-weight: bold;
	color: #115FAD;
}
#oa-compare-table a.product:hover,
.dragtable-sortable a.product:hover {
	opacity: .7;
}
#oa-compare-table .delete,
.dragtable-sortable .delete {
	display: block;
	background-color:#115FAD !important;
	border-radius: 3px;
	padding: .25em !important;
	transition: all .3s;
	color: #fff;
	cursor: pointer;

}

#oa-compare-table .delete:hover,
.dragtable-sortable .delete:hover {
	opacity: .8;
}




/*----------------------------

コムスキャン仕様（他のページで使う場合は要確認）

----------------------------*/

/* セクショニング */
.cs-bg {
	padding: 12rem 0;
}

.cs-section-mb {
	margin-bottom: 12rem;
}

.cs-card-wrap + .cs-card-wrap {
	margin-top: 6rem;
}

/* リンクボタン */
.cs-linkBtn {
	display: inline-block;
	border-radius: 5px;
	padding:1.5rem;
	border: 2px solid #115fad;
	color: #115fad;
	font-size: 2rem;
}
.cs-linkBtn:hover {
	background-color: #115fad;
	color: #fff;
}

/* カード */
.cs-card {
	align-items:flex-start;
	background-color: #fff;
	height: 100%;
	padding: 3rem;
	box-shadow: 0 10px 10px rgba(0,0,0,.2);
}
.cs-card-img {
	width: 50%;
	margin: 0 auto;
}
.cs-card-title {
	margin-bottom: 2rem;
	font-size: 2rem;
	text-align: center;
}

.cs-card-text {
	margin-bottom: 0 !important;
	text-align: justify;
	font-size: 1.5rem;
}
.cs-card-text-en {
	margin-bottom: 0 !important;
	text-align: inherit;
	font-size: 1.5rem;
}
@media (min-width:768px) {
	.cs-card-wrap + .cs-card-wrap {
		margin-top: 0;
	}
}

/* フォーム */

.cs-form-wrap dt {
	margin-bottom: 1rem;
	font-size: 2rem;
}
.cs-form-wrap dt.required::after {
	content:'必須';
	background-color: rgb(200, 0, 73);
	color: #fff;
	padding: 0.5rem;
	margin-left: .5rem;
	border-radius: .3rem;
	font-size: 70%;
}
.saiyo .cs-form-wrap dt p {
  display: inline-block;
}

.cs-form-wrap dd {
	margin-bottom: 3rem;
}
.cs-form-wrap dd * {
	font-size: 1.5rem;
	font-weight: normal;
}

.saiyo .cs-form-wrap dd .wpcf7-list-item {
  font-size: 14px;
  margin-right: 15px;
}
.saiyo .cs-form-wrap dd .wpcf7-list-item label span {
  margin-left: 5px;
}

.cs-form-wrap input[type="submit"] {
    background: #115fad !important;
    padding: 20px 10% !important;
    font-size: 18px !important;
    border-radius: 5px !important;
}
.cs-form-wrap input[type="submit"][disabled] {
	cursor: not-allowed;
	background-color: #ccc !important;
}

/*----------------------------

コムスキャン仕様（汎用性を想定していないので、他のページでは絶対使わないこと）

----------------------------*/

.comscan-headerTitle {
	position: relative;
	left: -15px;
}
.comscan-headerLogo {
	margin-top: 0;
}
.scroll-nav-wrap {
	height: 45px;
}
.scroll-nav div {
	width: 14.286%;
	font-size: 11px;
	white-space: nowrap;
}
.scroll-nav.scroll-nav-en div {
	font-size: 10px;
	line-height: 1;
}
.scroll-nav.scroll-nav-en div > a {
	padding: 0 !important;
	font-size: 11px !important;
	display: flex;
	height: 100%;
	align-items:center;
	justify-content: center;
}

.scroll-nav.scroll-nav-cn div {
	font-size: 10px;
	line-height: 1;
}
.scroll-nav.scroll-nav-cn div > a {
	padding: 0 !important;
	font-size: 11px !important;
	display: flex;
	height: 100%;
	align-items:center;
	justify-content: center;
}

/*
.comscan-nav div.home {
	width: 4%;
}
*/


.scroll-nav div.service a {
	letter-spacing: 0 !important;
}
.scroll-nav.nav_v2 .gMenu {
	font-size: 14px;
	padding: 12px 0 10px;
}


.comscan-mainVisual {
	position: relative;
	background-color: #fcfcfc;
}
.comscan-mainVisual-bg {
	margin: 0 !important;
	height: 60rem;
	position: relative;
}

.comscan-mainVisual::before {
	position: absolute;
	content: '';
	display: block;
	width: 100%;
	left: 0;
	height: 60rem;
	background:url(../images/comscan/main-visual.jpg) rgb(15, 11, 55) center center/cover no-repeat;
	background-attachment:fixed;
	z-index: 1;
}


.comscan-mainVisual-text-wrap {
	position: relative;
	z-index: 100;
}
.comscan-mainVisual-text {
	display: flex;
	align-items: center;
	height: 60rem;
}
.comscan-mainVisual-text div {
	position: relative;
	background-color: #fff;
	padding: 4rem;
	text-align: center;
	color: #115fad;
	box-shadow: 2rem 2rem 0 1rem rgb(51, 160, 228,.5);
}
.comscan-mainVisual-text div::before {
	content: '';
	display: none;
	position: absolute;
	left: 0;
	top:0;
	border: 3rem solid #115fad;
	border-right-color: transparent;
	border-bottom-color: transparent;
}


.comscan-mainVisual-text h1 {
	font-size: 1rem;
}

.comscan-mainVisual-text h2 {
	font-size: 2rem;
}
.comscan-mainVisual-text h1 br,
.comscan-mainVisual-text h2 br {
	display: none;
}
.comscan-mainVisual-text span {
	/*display: inline-block;*/
}
.comscan-mainVisual-text em {
	font-size: 150%;
	font-style: normal;
}

/* メインイメージ部分更新 202209 */

.headline-text {
  position: absolute;
  bottom: 75px;
  right: 0px;
  left: 0;
  margin: auto;
  width: 400px;
  background-color: #fff;
  padding: 6px 10px;
  border-radius: 2px;
}
.headline-text img {
  display: block;
  width: 140px;
  margin: 0 auto;

}
.comscan-mainVisual-text div {
    padding: 2rem 4rem;
    width: 100%;
}
.comscan-mainVisual-text {
    align-items: flex-start;
    margin-top: 40px;
}
@media only screen and (max-width:768px) {
  .headline-text {
	bottom: 55px;
    font-size: 0.85em;
	width: 92%;
  }
}
@media only screen and (max-width:991px) {
  .comscan-mainVisual-text h2 {
      font-size: 2.4rem !important;
  }
}

/* ここまで　メインイメージ部分更新 202209 */

@media (min-width:768px) {
	.comscan-mainVisual::before {
		/* width: 66.6666%;
		left: 33.33333%; */
	}
	.comscan-mainVisual-text div {
		text-align: left;
	}
	.comscan-mainVisual-text h1 {
		white-space: nowrap;
		font-size: 2rem;
	}
	.comscan-mainVisual-text h2 {
		white-space: nowrap;
		font-size: 3rem;
	}
	.comscan-mainVisual-text h1 br,
	.comscan-mainVisual-text h2 br {
		display: inline;
	}
	
}

.comscan-card-headline {
	display: inline-block;
	margin: 0 4rem 6rem;
	border-bottom: 1px solid #fff;
	color:#fff;
	font-size: 4rem;
	text-align: center;
}
.comscan-card-bg {
	text-align: center;
	background: url(../images/comscan/card-bg.jpg) #666 center center/cover no-repeat;
	background-attachment: fixed;
}
.comscan-overview-title {
	font-size: 3rem;
	margin-bottom: 2rem;
}
.comscan-overview-bg,
.comscan-menus-bg {
	background-color: #f5f5f5;
}

.comscan-front-headline {
	padding: 0;
	font-size: 3rem;
	margin-bottom: 1rem;
}
.comscan-front-headline::before {
	content: '';
	display: inline-block;
	margin-right: 1rem;
	width: 4rem;
	height: 2px;
	background-color: #666;
	vertical-align: super;

}
.comscan-front-subhead {
	padding: 0;
	font-size: 2rem;
	margin-bottom: 1rem;
}

.comscan-links-bg {
	background: url(../images/comscan/link-bg.jpg) #eee center top/cover no-repeat;
}

/*////////////////////////////////////////////////////////////////////// */
/*  ---  parts  ---   */
/* 三角形 */
.triangle {
	width: 100px;
	margin: auto;
	border-top: 100px solid  #195fa9;
	border-right: 100px solid  transparent;
	border-left: 100px solid  transparent;
}
/* 三角形 */
/* タイトルt*/
.title-left-border {
    font-size: 18px!important;
    border-left: 7px solid #115fad;
    padding-left: 7px!important;
    color: #115fad;
}
/* タイトルt*/
/*  ---  parts  ---   */

/*  ---  ティーオカモト株式会社合併  ---   */
#tmt table tbody th{
	font-weight: normal !important;
}
/*  ---  ティーオカモト株式会社合併  ---   */

/* 大物加工タイトル*/
.gray-square {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 100%;
    height: 100%;
    max-width: 555px;
    border: 1px solid #b5b5b5;
    /* padding: 2.5rem 6rem 2.5rem 3rem; */
    padding: 2rem 4rem 2rem 2.5rem;
    text-align: center;
    font-size: 16px;
    color: #000000;
}
/* タイトルt*/



/* 20221017追記 */
.img_zoom {
  display: block;
  overflow: hidden;
}
.img_zoom img {
  transition-duration: 0.5s;
}
.img_zoom:hover img {
  transform: scale(1.1,1.1);
}

.text_underline:hover {
  text-decoration: underline;
}

.btn_example {
  display: block;
  position: relative;
  color: #fff;
  font-size: 14px;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  font-weight: bold;
  width: 200px;
  height: 40px;
  padding-top: 13px;
  padding-right: 15px;
  margin: 20px auto 0;
  border: 1px solid #105fad;
  background-color: #105fad;
  border-radius: 10px;
}
.btn_example.w250 {
  width: 250px;
}
.btn_example.w300 {
  width: 300px;
}
.btn_example.w330 {
  width: 330px;
}
.btn_example.w350 {
  width: 350px;
}
.btn_example.w400 {
  width: 400px;
}
.btn_example.tp-r {
  margin-right: 0;
}
.btn_example.big {
  height: 60px;
  padding-top: 23px;
}
.btn_example::after {
  content: "";
  display: block;
  position: absolute;
  right: 15px;
  bottom: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
  transform-origin: right bottom;
  transition: 0.5s;
}
.btn_example:hover {
  color: #105fad;
  background-color: #fff;
}
.btn_example:hover::after {
  border-color: #105fad;
}

/* 20221025追記 */
.product_list {
  display: flex;
  flex-wrap: wrap;
  margin: 50px 0;
  list-style: none;
}
.product_list li {
  width: 48.5%;
  margin-right: 3%;
  margin-bottom: 30px;
}
.product_list li:nth-of-type(2n) {
  margin-right: 0;
}
.product_list a {
  display: block;
  transition: 0.5s;
}
.product_list.dk a:hover {
  opacity: 1 !important;
}
.product_list.dk a .mask {
  position: relative;
}
.product_list.dk a .mask img {
  vertical-align: bottom;
}
.product_list.dk a .mask::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 100;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.3);
  border-radius: 5px;
  transition: 0.5s;
  opacity: 0;
}
.product_list.dk a:hover .mask::before {
  opacity: 1;
}
.product_list a:hover {
  opacity: 0.7;
}
.product_list a img {
  width: 100%;
  height: auto;
}
.product_list a span {
  display: block;
  font-size: 10px;
  line-height: 1em;
  text-align: center;
  margin-top: 10px;
}
@media (min-width:768px) {
  .product_list li {
    width: 30%;
    margin-right: 5%;
    margin-bottom: 50px;
  }
  .product_list li:nth-of-type(2n) {
    margin-right: 5%;
  }
  .product_list li:nth-of-type(3n) {
    margin-right: 0;
  }
  .product_list a span {
    font-size: 16px;
    margin-top: 15px;
  }
}

#header_img.product {
  background-image: url("../images/header_04.jpg");
}

/* 20221101追記 */
.contents .fs32 {
  font-size: 3.2rem !important;
}
.contents .fs22 {  
  font-size: 2.2rem !important;
}

/* 20221102追記 */
.brock_right {
  margin-right: 0 !important;
  margin-left: auto !important;
}
.brock_left {
  margin-right: auto !important;
  margin-left: 0 !important;
}


/* 20221116追記 */
.midashi-h4 {
  font-size: 16px;
  line-height: 1em;
  text-align: center;
  margin-bottom: 15px;
}
.table-title {
  color: #fff;
  font-size: 14px;
  line-height: 1em;
  text-align: center;
  width: 100%;
  padding: 8px 0;
  background-color: #115fad;
  box-sizing: border-box;
}
.table01 {
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 30px;
}
.table01 tr td {
  padding: 8px 0;
}
.table01 tr:nth-of-type(2n) td {
  background-color: #ddd;
}
.table01 tr td:nth-of-type(1) {
  text-align: center;
  width: 10%;
}
.table01 tr td:nth-of-type(2) {
  text-align: left;
  width: 90%;
}

@media (max-width:768px) {
  .table01 {
    display: table !important;
  }
  .table01 tr td {
    display: table-cell !important;
  }
  .table01 tr td:nth-of-type(1) {
    text-align: center;
    width: 30%;
  }
  .table01 tr td:nth-of-type(2) {
    text-align: left;
    width: 70%;
  }
}

img.fit {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*不要になったら消す*/
.h240 {
  height: 240px;
}
@media (max-width:768px) {
  .h240 {
    height: 230px;
  }
}

.plr20 {
  padding: 0 20px !important;
}

.column_box .column_inner {
  position: relative;
  padding: 50px;
  margin-bottom: 50px;
  border: 1px solid #115fad;
}
.column_box .column_inner img.illust {
  float: right;
  width: 100px;
  height: auto;
  margin: -10px -10px 10px 10px;
}
.column_box .column_inner img.illust2 {
  position: absolute;
  right: 0;
  bottom: 15px;
  width: 250px;
  height: auto;
}
.column_l {
  display: inline-block;
  position: absolute;
  left: 30px;
  top: -8px;
  z-index: 1;
  color: #115fad;
  font-size: 16px;
  line-height: 1em;
  font-weight: bold;
  padding: 0 20px;
  background-color: #fff;
}
.column_l.tp2 {
  left: calc(50% - 144px);
  top: -10px;
  font-size: 20px;
} 
.column_l.tp3 {
  left: calc(50% - 244px);
  top: -10px;
  font-size: 20px;
} 
.column_title {
  color: #000;
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  margin-bottom: 30px;
}
.column_title2 {
  color: #000;
  font-size: 18px;
  line-height: 1.5em;
  font-weight: bold;
  margin-bottom: 10px;
}
.column_box .column_inner p:last-of-type {
  margin-bottom: 0;
}
.column_box em {
  font-style: normal;
  text-decoration: underline;
}

@media (max-width:768px) {
  .column_l {
    left: 15px;
    padding: 0 5px;
  }
  .column_box .column_inner {
    padding: 35px 15px 20px;
    margin-bottom: 30px;
  }
  .column_box .column_inner img.illust {
    width: 70px;
    height: auto;
    margin: 0 0 5px 5px;
  }
  .column_box .column_inner img.illust2 {
    display: block;
    position: static;
    right: auto;
    bottom: auto;
    width: 200px;
    height: auto;
    margin: auto;
  }
}

/* 20221125追記 */

.repair-ccontent00 {
  max-width: 950px;
  margin: auto;
}
.repair-ccontent00 .row-tp01 {
  padding-bottom: 20px;
  margin: 30px 0 30px;
  border-bottom: 1px dashed #115fad;
}
.repair-ccontent00 .col-xl-8 {
  text-align: center;
}
.repair-ccontent00 h3 {
  margin-bottom: 20px;
}
.repair-ccontent00 ul {
  display: flex;
  flex-wrap: wrap;
  max-width: 460px;
  margin: auto;
}
.repair-ccontent00 ul li {
  line-height: 1em;
  text-align: left;
  width: 50%;
  margin-bottom: 15px;
}
.repair-ccontent00 ul li:nth-child(2n+1) {
  width: 40%;
}
.repair-ccontent00 ul li:nth-child(2n) {
  width: 60%;
}
.repair-ccontent00 ul li a:hover {
  color: #337ab7;
  font-weight: bold;
}

@media (max-width:768px) {
  .repair-ccontent00 ul {
    display: block;
  }
  .repair-ccontent00 ul li {
    line-height: 1em;
    text-align: left;
    width: 100%;
    margin-bottom: 15px;
  }
  .repair-ccontent00 ul li:nth-child(2n+1),
  .repair-ccontent00 ul li:nth-child(2n) {
    width: 100%;
  }
}

/* 20221220追記 */
.contact_main_menu {
  display: flex;
  flex-wrap: wrap;
  margin: 30px 0 50px;
}
.contact_main_menu li {
  width: 400px;
  margin: 30px 85px;
}
.contact_main_menu li a {
  display: block;
  position: relative;
  color: #000;
  font-size: 16px;
  line-height: 1em;
  font-weight: bold;
  padding: 40px 0 40px 100px;
  border: 1px solid #000;
  border-radius: 10px;
  transition: 0.5s;
}
.contact_main_menu li a:hover {
  color: #000;
}
.contact_main_menu li a::after {
  content: "";
  display: block;
  position: absolute;
  right: 20px;
  bottom: calc(50% - 15px);
  width: 30px;
  height: 30px;
  background: url("../images/form/arrow.png") no-repeat 0 0 / 30px 30px;
  transition: 0.3s;
}
.contact_main_menu li a:hover::after {
  right: 16px;
}
.contact_main_menu li a br {
  display: none;
}
.contact_main_menu li:nth-of-type(1) a::before {
  content: "";
  display: block;
  position: absolute;
  left: 10px;
  top: calc(50% - 40px);
  width: 80px;
  height: 80px;
  background: url("../images/form/icon01.png") no-repeat 0 0 / 80px 80px;
}
.contact_main_menu li:nth-of-type(2) a::before {
  content: "";
  display: block;
  position: absolute;
  left: 10px;
  top: calc(50% - 40px);
  width: 80px;
  height: 80px;
  background: url("../images/form/icon02.png") no-repeat 0 0 / 80px 80px;
}
.contact_main_menu li:nth-of-type(3) a::before {
  content: "";
  display: block;
  position: absolute;
  left: 10px;
  top: calc(50% - 40px);
  width: 80px;
  height: 80px;
  background: url("../images/form/icon05.png") no-repeat 0 0 / 80px 80px;
}
.contact_main_menu li:nth-of-type(4) a::before {
  content: "";
  display: block;
  position: absolute;
  left: 10px;
  top: calc(50% - 40px);
  width: 80px;
  height: 80px;
  background: url("../images/form/icon04.png") no-repeat 0 0 / 80px 80px;
}
.contact_main_menu li:nth-of-type(5) a::before {
  content: "";
  display: block;
  position: absolute;
  left: 10px;
  top: calc(50% - 40px);
  width: 80px;
  height: 80px;
  background: url("../images/form/icon06.png") no-repeat 0 0 / 80px 80px;
}
@media (max-width:768px) {
  .contact_main_menu {
    display: block;
    margin: 30px 0 50px;
  }
  .contact_main_menu li {
    width: 100%;
    margin: 30px 0;
  }
  .contact_main_menu li a {
    line-height: 1.3em;
    padding: 30px 0 30px 110px;
  }
  .contact_main_menu li a br {
    display: inline;
  }

}

.contact_ichiran {
  display: flex;
  flex-wrap: wrap;
  margin: 50px 0 20px;
}
.contact_ichiran li {
  min-width: 25%;  
  margin-bottom: 25px;
}
.contact_ichiran li a {
  font-weight: bold;
  transition: 0.5s;
}

@media (max-width:768px) {
  .contact_ichiran {
    display: block;
    margin: 30px 0;
  }
  .contact_ichiran li {
    min-width: 100%;  
    margin-bottom: 15px;
  }
}

.contact_btn_wrap {
  display: flex;
  flex-wrap: wrap;  
  margin: auto;
}
.contact_btn_wrap .unit {
  text-align: center;
  width: 400px;
  padding: 10px 0 25px;
  margin: 30px 85px;
  border: 1px solid #115fad;
}
.contact_btn_wrap .unit .title {
  font-size: 16px;
  line-height: 1em;
  font-weight: bold;
  padding-bottom: 10px;
  border-bottom: 1px solid #ddd;
  margin: 15px 10px 25px;
}
.contact_btn_wrap .unit .title.db {
  font-size: 16px;
  line-height: 1.2em;
  padding-bottom: 5px;
  border-bottom: 1px solid #ddd;
  margin: 0 10px 25px;
}
.contact_btn_wrap .unit a {
  display: inline-block;
  color: #fff;
  font-size: 14px;
  line-height: 1em;
  padding: 15px 30px;
  background-color: #115fad;
  border: 1px solid #115fad;
  border-radius: 5px;
  transition: 0.5s;
}
.contact_btn_wrap .unit a:hover {
  color: #115fad;
  background-color: #fff;
}
.contact_btn_wrap .unit .tel {
  font-size: 14px;
  line-height: 1em;
  margin-top: 20px;
}

@media (max-width:768px) {
  .contact_btn_wrap {
    display: block;
    width: 100%;
  }
  .contact_btn_wrap .unit {    
    width: 100%;
    padding: 10px 0 25px;
    margin: 15px 0;
  }
}

.repairs-service8-1,
.repairs-service8-2,
.repairs-service8-3 {
  position: absolute;
}
.repairs-service8-1 {
  left: 0;
  top: 80px;
  width: 260px;
}
.repairs-service8-2 {
  left: 280px;
  top: 0;
  width: 220px;
}
.repairs-service8-3 {
  left: 280px;
  top: 160px;
  width: 220px;
}

.repairs-service8-1 img,
.repairs-service8-2 img,
.repairs-service8-3 img {
  width: 100%;
  height: auto;
}
.repairs-service8-1 figcaption,
.repairs-service8-2 figcaption,
.repairs-service8-3 figcaption {
  font-size: 12px;
  font-weight: bold;
  text-align: center;
}

@media (max-width:1200px) {
  .repairs-service8-1,
  .repairs-service8-2,
  .repairs-service8-3 {
    position: static;
    left: auto;
    top: auto;
    width: 100%;
    margin-top: 15px;
  }
}


.mw450 {
  max-width: 450px !important;
}

.pos-base {
  position: relative;
}
.anchor_pos {
  position: absolute;
  top: -200px;
}
.anchor_pos2 {
  position: absolute;
  top: -290px;
}
.anchor_pos3 {
  position: absolute;
  top: -110px;
}
.pos-rb {
  position: absolute;
  right: 0;
  bottom: 0;
}
@media (max-width:1000px) {
  .pos-rb {
    position: static;
    right: auto;
    bottom: auto;
  }
}

br.sp {
  display: none;
}

@media (max-width:768px) {
  br.sp {
    display: inline;
  }
  br.pc {
    display: none;
  }
}


#print-repair_nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 60px;
}
#print-repair_nav li {
  text-align: center;
  width: 23%;
  padding: 20px 35px;
  border: 1px solid #105fad;
  border-radius: 20px;
}
#print-repair_nav li div {
  color: #000;
  font-size: 16px;
  line-height: 1.5em;
  font-weight: bold;
  padding: 10px 0;
  margin: 15px 0 10px;
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
}
#print-repair_nav li a {
  display: inline-block;
  position: relative;
  color: #fff;
  font-size: 14px;
  line-height: 1em;
  letter-spacing: 0.1em;
  text-align: center;
  font-weight: bold;
  width: 140px;
  height: 40px;
  padding-top: 13px;
  padding-right: 15px;
  margin: 20px auto 0;
  border: 1px solid #105fad;
  background-color: #105fad;
  border-radius: 20px;
}
#print-repair_nav li a::after {
  content: "";
  display: block;
  position: absolute;
  right: 15px;
  bottom: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(-45deg);
  transform-origin: right bottom;
  transition: 0.5s;
}
#print-repair_nav li a:hover {
  color: #105fad;
  background-color: #fff;
}
#print-repair_nav li a:hover::after {
  border-color: #105fad;
}
@media (max-width:1000px) {
  #print-repair_nav {  
    margin-bottom: 20px;
  }
  #print-repair_nav li {
    width: 47%;
    margin-bottom: 20px;
  }
}
@media (max-width:768px) {
  #print-repair_nav {
    display: block;
  }
  #print-repair_nav li {
    width: 100%;
    padding: 15px 20px;
    margin-bottom: 15px;
  }
}

#print-repair_news.ichiran ul {
  display: flex;
  flex-wrap: wrap;
  margin-top: 30px;
}
#print-repair_news.ichiran ul li {
  position: relative;
  font-weight: bold;
  line-height: 1em;
  margin: 0 15px;
}
#print-repair_news.ichiran ul li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: -15px;
  width: 1px;
  height: 100%;
  background-color: #333;
}
#print-repair_news.ichiran ul li a {
  display: block;
  color: #105fad;
  line-height: 1em;
}

#print-repair_news dl {
  padding: 0;
  margin-bottom: 10px;
  border-top: 1px solid #ccc;
}
#print-repair_news.ichiran dl {
  margin: 30px 0 80px;
}
#print-repair_news dt {
  position: relative;
  font-size: 16px;
  line-height: 1.5em;
  padding: 10px 30px;
  border-bottom: 1px solid #ccc;
  cursor: pointer;
}
#print-repair_news dt span {
  display: block;
  position: absolute;
  right: 0;
  top: calc(50% - 12px);
  width: 25px;
  height: 25px;
}
#print-repair_news dt span::before {
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: calc(50% - 1px);
  width: 100%;
  height: 1px;
  background-color: #333;
}
#print-repair_news dt span::after {
  content: "";
  display: block;
  position: absolute;
  right: calc(50% - 1px);
  top: 0;
  width: 1px;
  height: 100%;
  background-color: #333;
}
#print-repair_news dt.open span::after {
  display: none;
}
#print-repair_news.ichiran dt {
  font-weight: normal;
  padding: 15px 30px;
}
#print-repair_news.ichiran dt div.d {
  margin-bottom: 10px;
}
#print-repair_news dd {
  display: none;
  font-size: 16px;
  line-height: 1.5em;
  padding: 10px 30px;
  margin: 0;
  border-bottom: 1px solid #ccc;
}
#print-repair_news dd.open {
  display: block;
}



#repair-service {
  position: relative;
}
#ac_repair-service {
  position: absolute;
  left: 0;
  top: -200px;
}


.max_width_600 {
  max-width: 600px;
  margin: 30px auto;
}
.max_width_700 {
  max-width: 700px;
  margin: 30px auto;
}
.max_width_800 {
  max-width: 800px;
  margin: 30px auto;
}
.max_width_900 {
  max-width: 900px;
  margin: 30px auto;
}
.max_width_full {
  max-width: 100%;
  margin: 30px auto;
}
.monozukuri_img_box {
  max-width: 900px;
  margin: 50px auto;
}
.monozukuri_img_box_s {
  max-width: 500px;
  margin: 50px auto;
}
.solution_img_box {
  width: 900px;
  margin: auto;
}
.h180 img {
  width: auto;
  max-height: 180px;
}

.point_bk_color {
  padding: 20px !important;
  background-color: rgb(232, 243, 254);
}


.partner_list li {
  margin-bottom: 10px;
}

@media (min-width: 768px) {
.partner_list {
  display: flex;
  flex-wrap: wrap;
} 
.partner_list li {
  width: 33.333%;
}
}
.partner_list li a {
  display: block;
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  width: 250px;
  height: 150px;
  padding-top: 50px;
  margin: auto;
  background-color: rgb(232, 243, 254);
}
.partner_black_title {
  color: #000;
  font-size: 20px !important;
}
h4.partner-section-title {
  color: #000;
  font-size: 20px;
}
h5.partner-section-title {
  display: inline-block;
  color: #fff;
  font-size: 16px;
  line-height: 1em;
  text-align: center;
  width: 6em;
  padding: 5px 10px;
  background-color: #115fad;
  border-radius: 5px;
}

@media (min-width: 768px) {
  .partner_black_title {
    font-size: 24px !important;
  }
}


.top-solution-wrap ul {
  width: calc(100% - 20px);
  margin: auto;
}
.top-solution-wrap ul li {
  width: 100%;
  margin-bottom: 10px;
}
.top-solution-wrap ul li a {
  display: block;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 8px;
}
.top-solution-wrap ul li a .i {
  height: 220px;
  overflow: hidden;
  border-radius: 8px 8px 0 0;
}
.top-solution-wrap ul li a .i img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.top-solution-wrap ul li a .t {
  position: relative;
  text-align: left;
  height: 110px;
  padding: 10px;
}
.top-solution-wrap ul li a .t::before {
  content: "\f138";
  font-family: FontAwesome;
  color: #00a040;
  font-size: 24px;
  position: absolute;
  right: 10px;
  top: 5px;
}
.top-solution-wrap ul li a .t h3 {
  font-size: 14px;
  line-height: 1.3em;
  margin-bottom: 15px;
}
.top-solution-wrap ul li a .t p {
  font-size: 13px;
  line-height: 1.3em;
}
.top-solution-wrap ul li a .t p br {
  display: inline;
}

@media (min-width: 540px) {
  .top-solution-wrap ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;    
    margin: auto;
  }
  .top-solution-wrap ul li {
    width: 49%;
    margin-bottom: 20px;
  }
}

@media (min-width: 992px) {
  .top-solution-wrap ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1180px;
    margin: auto;
  }
  .top-solution-wrap ul li {
    width: 32%;
    margin-bottom: 20px;
  }
  .top-solution-wrap ul li a .i {
    height: 240px;
    overflow: hidden;
    border-radius: 8px 8px 0 0;
  }
  .top-solution-wrap ul li a .t {
    position: relative;
    text-align: left;
    height: 130px;
    padding: 10px;
  }
  .top-solution-wrap ul li a .t h3 {
    font-size: 16px;
    line-height: 1.3em;
    margin-bottom: 15px;
  }
  .top-solution-wrap ul li a .t p {
    font-size: 14px;
    line-height: 1.3em;
  }
}



.fl_aki_r {
  margin-bottom: 20px !important;
}
@media (min-width: 768px) {
  .fl_aki_r {
    margin: 0 20px 0 -20px !important;
  }
}


.partner-section-box {
  position: relative;
  padding: 30px;
  margin-bottom: 50px;
  border: 1px solid #ddd;
}
.partner-section-box h4 {
  position: absolute;
  left: 0;
  top: -15px;
  width: 100%;
}
.partner-section-box h4 span {
  display: inline-block;
  padding: 0 10px;
  background-color: #fff;
}

.big_text {
  color: #000;
  font-size: 3.2rem !important;
  font-weight: bold;
}
.black {
  color: #000 !important;
}

.kanren_link a {
  display: inline-block;
  margin-right: 15px;
}

.waku_blue {
  padding: 15px;
  border: 1px solid #115FAD;
}

.contact_service_unit {
  display: flex;
  flex-wrap: wrap;
  padding: 20px 0 0;
  border-bottom: 1px solid #cccccd;
}
.contact_service_unit .h {
  font-weight: bold;
  width: 30%;
}
.contact_service_unit div.list {
  width: 70%;
}
.contact_service_unit div.list .t {
  font-weight: bold;
  margin-bottom: 1em;
}
.contact_service_unit div.list ul {
  display: flex;
  flex-wrap: wrap;
}
.contact_service_unit div.list ul li {
  margin-right: 50px;
  margin-bottom: 20px;
}
.contact_service_unit div.list ul li a:hover {
  color: #23527c;
  font-weight: bold;
}


/*　202304 トップページサムネイルスタイル　*/

.repair-ccontent01 .thumb-btn a {
    display: block;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 8px;
}


.repair-ccontent01 .thumb-btn a div.db {
    padding: 6px 0 0 7px;
}
.repair-ccontent01 .thumb-btn a div {
    text-align: center;
    height: 4em;
    padding: 18px 0 10px;
}
.repair-ccontent01 .thumb-btn a div {
    position: relative;
    text-align: left;
    height: 4em;
    padding: 14px 0 10px 7px;
    border-top: 1px solid #ccc;
}
.repair-ccontent01 .thumb-btn a div::before {
    content: "\f138";
    font-family: FontAwesome;
    color: #00a040;
    font-size: 24px;
    position: absolute;
    right: 10px;
    top: calc(50% - 18px);
}
@media (min-width: 992px) {
.repair-ccontent01 .thumb-btn a div.db {
    padding: 8px 0;
}
.repair-ccontent01 .thumb-btn a div {
    text-align: center;
    height: 4em;
    padding: 18px 0 10px;
}
}


.youtube_wrap {
  position: relative;
  margin-bottom: 15px;
}
.youtube_wrap::after {
  content: "";
  display: block;
  padding-top: 56.25%;
}
.youtube_wrap iframe{
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}


.clum_c3 {
  display: block;
  margin-bottom: 30px;
}
.clum_c3 > div {
  position: relative;
  width: 100%;
  margin-bottom: 45px;
}
.clum_c3 > div::after {
  content: "";
  display: block;
  position: absolute;
  left: calc(50% - 20px);
  bottom: -30px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 20px 0 20px;
  border-color: #115fad transparent transparent transparent;
}
.clum_c3 > div:last-of-type {
  margin-bottom: 0;
}
.clum_c3 > div:last-of-type::after {
  display: none;
}
.clum_c3 > div img {
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .clum_c3 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 30px;
  }
  .clum_c3 > div {
    width: 30%;
    margin-bottom: 0;
  }
  .clum_c3 > div::after {
    content: "";
    display: block;
    position: absolute;
    left: auto;
    right: -40px;
    bottom: calc(50% + 10px);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 10px 0 10px 20px;
    border-color: transparent transparent transparent #115fad;
  }
}


#exchange_calc table {
  width: 100%;
  margin: 20px 0;
}
#exchange_calc table tr td {
  padding: 5px 0;
}
#exchange_calc table tr td:nth-of-type(2) {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  text-align: right;
  width: 100%;
}
#exchange_calc table input[type="text"],
#exchange_calc table select {
  display: inline-block;
  width: 160px;
}
#exchange_calc table input[type="text"]:read-only {
  background-color: #ffc;
}
#exchange_calc table .u {
  display: inline-block;
  text-align: center;
  width: 40px;
}
#exchange_calc input[type="button"] {
  display: block;  
  color: #fff;
  font-size: 16px;
  line-height: 1em;
  font-weight: bold;  
  width: 160px;
  margin: 0 auto;  
  padding: 1em !important;
  background-color: #115FAC !important;
  border-radius: 5px;
}
#exchange_calc input[type="button"]:disabled {
  background-color: #bbb !important;
}
.exchange_calc_att {
  padding: 30px;
  border: 1px solid #000;
}
.exchange_calc_att p:last-of-type {
  margin-bottom: 0 !important;
}
.exchange_calc_mark01 {
  display: inline-block;
  vertical-align: bottom;
  width: 50px;
  height: 24px;
  margin-right: 5px;
  border: 1px solid #bbb;
  border-radius: 3px;
}
.exchange_calc_mark02 {
  display: inline-block;
  vertical-align: bottom;
  width: 50px;
  height: 24px;
  margin-left: 10px;
  margin-right: 5px;
  background-color: #ffc;
  border: 1px solid #bbb;
  border-radius: 3px;
}

@media (min-width: 768px) {
  #exchange_calc table,
  #exchange_calc .btn_box {
    width: 600px;
  }
  #exchange_calc table,
  #exchange_calc table tbody {
    display: block;
  }
  #exchange_calc table tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  #exchange_calc table tr td:nth-of-type(1) {
    display: block;
    width: calc(100% - 200px);
  }
  #exchange_calc table tr td:nth-of-type(2) {
    width: 200px;
  }
}

.box_gray {
  color: #000;
  max-width: 500px;
  padding: 10px !important;
  margin: 0 !important;
  background-color: #ddd;
}

.n_flex {
  display: flex;
  flex-wrap: wrap;
}
.n_flex.f_end {
  justify-content: flex-end !important;
}

.n_flex .col3 {
  width: calc((100% / 3) - 20px);
  margin: 0 30px 30px 0;
}
.n_flex .col3:nth-of-type(3n) {
  margin-right: 0;
}
.n_flex .line_g {
  padding: 10px;
  border: 1px solid #cccccd;
}
@media (max-width: 992px) {
  .n_flex .col3 {
    width: calc((100% / 2) - 15px);
    margin: 0 30px 30px 0;
  }
  .n_flex .col3:nth-of-type(3n) {
    margin-right: 30px;
  }
  .n_flex .col3:nth-of-type(2n) {
    margin-right: 0;
  }  
}

@media (max-width: 768px) {
  .n_flex .col3 {
    width: 100%;
    margin: 0 0 20px;
  }
  .n_flex .col3:nth-of-type(3n) {
    margin-right: 0;
  }
  .n_flex .col3:nth-of-type(2n) {
    margin-right: 0;
  }  
}

.page-news-box .date {
  display: inline-block;
  vertical-align: middle;
}
.page-news-box .category {
  display: inline-block;
  color: #fff;
  background-color: #84AED0;
  padding: 5px;
  border-radius: 3px;
  white-space: nowrap;
  text-align: center;
  width: 110px;
}
.page-news-box .category.news-media {
  background-color: #f5b51a;
}
.page-news-box .text {
  margin: 10px 0;
}


.list_anchor li {
  font-size: 18px;
  font-weight: 600;
  border-bottom: 1px solid #ccc;
}
.list_anchor li br {
  display: none;
}
.list_anchor li a {
  display: block;
  position: relative;
  padding: 15px 0;
}
.list_anchor li a::after {
  content: "\f138";
  position: absolute;
  right: 10px;
  top: calc(50% - 10px);
  font-family: FontAwesome;
  color: #115fad;
  font-size: 24px;
  line-height: 1em;
}
@media (max-width: 768px) {
  .list_anchor li {
    font-size: 15px;
    font-weight: 600;
  }
  .list_anchor li br {
    display: inline;
  }
}


.yakkan_title {
  font-size: 16px !important;
  font-weight: normal !important;
}
.bullet {
  text-indent: -2em;
  padding-left: 3em !important;
}
.bullet2 {
  text-indent: -3em;
  padding-left: 6em !important;
}