@charset "utf-8";
/**
 * style.css
 */

/* Bootstrap break point */
@media only screen and (max-width:1199px) {} /* xl */
@media only screen and (max-width:991px) {} /* lg */
@media only screen and (max-width:767px) {} /* md */
@media only screen and (max-width:565px) {} /* sm */
/* (mobile first) */
@media only screen and (min-width:566px) {}
@media only screen and (min-width:768px) {}
@media only screen and (min-width:992px) {}
@media only screen and (min-width:1200px) {}


/* V3.1  break point */
@media only screen and (max-width:959px) {} /* tablet */
@media only screen and (max-width:767px) {} /* smart phone */
/* (mobile first) */
@media only screen and (min-width:768px) {}
@media only screen and (min-width:960px) {}


/* container
--------------------------------------------------*/

#container {min-width: 320px;margin-top: 20px;margin-bottom: 0;padding-top: 0;}
#container.top-bg {
	position: relative;
	background: 
		url(../img/pc/top/bg_pcround.png) center 100px / auto no-repeat,
		linear-gradient(#F7E7E6 0%, #F7E7E6 100%) center 288px / 100% no-repeat;
}
@media only screen and (max-width:959px) {
	#container.top-bg {
		position: relative;
		background:
			url(../img/pc/top/bg_pcround.png) center 445px / 180vw no-repeat,
			linear-gradient(#F7E7E6 0%, #F7E7E6 100%) center 554px / 100% no-repeat
	}
}
@media only screen and (max-width:767px) {
	#container.top-bg {
		position: relative;
		background: 
			url(../img/pc/top/bg_spround.png) center 260px / auto no-repeat,
   		linear-gradient(#F7E7E6 0%, #F7E7E6 100%) center 388px / 100% no-repeat;
	}
}
#container.top-bg::before {
	display: block;
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
		background: 
		url(../img/pc/top/bg_1.png) calc(50% + 380px) 0 / 480px no-repeat,
		url(../img/pc/top/bg_2.png) calc(50% - 580px) 294px / 80px no-repeat,
		url(../img/pc/top/bg_3.png) calc(50% + 306px) 828px / 80px no-repeat,
		url(../img/pc/top/bg_4.png) calc(50% - 580px) calc(100% - 20px) / 80px no-repeat,
		url(../img/pc/top/bg_5.png) calc(50% + 460px) calc(100% - 20px)  / 320px no-repeat
		;
}
@media only screen and (max-width:959px) {
	#container.top-bg::before {
			background: 
			url(../img/pc/top/bg_1.png) calc(80%) 320px / 66vw no-repeat,
			url(../img/pc/top/bg_2.png) 33px 556px / 60px no-repeat,
			/*url(../img/pc/top/bg_3.png) calc(95% ) calc(100% - 500px) / 80px no-repeat,*/
			url(../img/pc/top/bg_4.png) 10px calc(100% - 80px) / 80px no-repeat,
			url(../img/pc/top/bg_5.png) calc(90%)  calc(100% - 80px)  / 235px no-repeat
			;
	}
}
@media only screen and (max-width:767px) {
	#container.top-bg::before {
			background: 
			url(../img/pc/top/bg_1.png) calc(50% - 5vw) 160px / 90vw no-repeat,
			url(../img/pc/top/bg_2.png) 10px 400px / 50px no-repeat,
			url(../img/pc/top/bg_3.png) calc(50% + 32vw) calc(100% - 900px) / 60px no-repeat,
			url(../img/pc/top/bg_4.png) 10px calc(100% - 70px) / 60px no-repeat,
			url(../img/pc/top/bg_5.png) calc(50% + 22vw)  calc(100% - 72px)  / 166px no-repeat
			;
	}
}
@media only screen and (max-width:959px) {
#container {padding-top: 72px;}
}
@media only screen and (max-width:767px) {
#container {padding-top: 60px;}
}


.common-wrap {flex-direction:inherit;padding: 0 8px;background: none;}
.side-area {
	padding-right: 0px;
	padding-left:30px;
}

.main_image{
	margin: 0px auto 20px;
	width: 100%;
	height: 0;
	padding-top:25%;
	background-image: url("../img/pc/top/top_main.gif");
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

@media only screen and (max-width:959px) {
.main_image{height:350px;}	
}

@media only screen and (max-width:767px) {
.main_image{height: 250px;}	
}

@media only screen and (max-width:565px) {
.main_image{height: 180px;background-position: center 15px;}
} 

/* main-slider
--------------------------------------------------*/
.main-slider li .item {
overflow: hidden;
visibility: hidden;
}

.main-slider .slick-slider.slick-initialized li .item {
visibility: visible;
}

.main-slider {
	position: relative;
	margin: 0;
	z-index: 1;
	/* margin-bottom: 64px; */
}

.main-slider * {
	outline: none;
}
.main-slider-wrap {
	position: relative;
}
.main-slider ul {
	padding: 0;
	margin: 0;
}
.main-slider .swiper-slide  img {
	width: 100%;
}
/*.main-slider ul.slick-slider::before,
.main-slider ul.slick-slider::after {
	content: '';
	width: calc((100% - 960px)/2);
	height: 400px;
	background-color: #333;
	z-index: 10;
	position: absolute;
	top: 0;
	left: 0;
	opacity: .5;
}
.main-slider ul.slick-slider::after {
	left: auto;
	right: 0;
}
@media only screen and (max-width:1024px) {
	.main-slider ul::before,
	.main-slider ul::after {
	display: none;
}
}*/


.main-slider .slick-slide {
  opacity: 0.3;
  transition: opacity 0.4s;
}

.main-slider .slick-slide.slick-current,
.main-slider .slick-slide.is-active-next {
  opacity: 1;
}

.main-slider li {
	list-style: none;
	width: 960px;
}

.main-slider li .item {
	overflow: hidden;
	height: 400px;
	width: 960px;
}
@media only screen and (max-width:991px) {
	.main-slider li .item {
		height: 40vw;
		width: auto;
	}
}

.main-slider li .item .image {
	height: 400px;
	width: auto;
}
@media only screen and (max-width:991px) {
	.main-slider li .item .image {
		height: auto;
	}
}
.main-slider li .item .image div {
	height: 400px;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}
@media only screen and (max-width:991px) {
	.main-slider li .item .image div {
		height: 40vw;
		background-position: top center;
		background-size: contain;
	}
}
.main-slider li.box01 .item .image div {
	background-image: url(../img/pc/top/slide_01.jpg);
}
.main-slider li.box02 .item .image div {
	background-image: url(../img/pc/top/slide_02.jpg);
}
.main-slider li.box03 .item .image div {
	background-image: url(../img/pc/top/slide_03.jpg);
}
.main-slider li.box04 .item .image div {
	background-image: url(../img/pc/top/slide_04.jpg);
}
.main-slider li .item .texts {
	float: right;
	width: 360px;
	padding-bottom: 40px;
}
.main-slider li .item .texts .ttl {
	position: relative;
	left: -40px;
	width: 200px;
	font-size: 30px;
	text-align: center;
	color: #fff;
	line-height: 1.5;
}
.main-slider li .item .texts .ttl > div {
	position: relative;
	display: table;
	width: 100%;
	height: 200px;
	z-index: 2;
}
.main-slider li .item .texts .ttl > div > h2 {
	display: table-cell;
	vertical-align: middle;
}
.main-slider li .item .texts .ttl small {
	display: block;
	font-size: 24px;
	line-height: 1.5;
}
.main-slider li .item .texts .ttl span {
	position: relative;
	display: block;
	z-index: 2;
}
.main-slider li .item .texts .ttl:before {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	content: '';
	width: 140px;
	height: 140px;
	margin: -70px 0 0 -70px;
	background-color: #97999b;
	transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	z-index: 1;
}
.main-slider li .item .texts .txt {
	padding: 20px 30px 0;
	line-height: 1.5;
}
@media only screen and (max-width:959px) {
	.main-slider {
		margin-top: 0;
	}
	.main-slider .common-wrap {
		padding: 0;
	}
	.main-slider li .item .image {
		float: none;
		padding-left: 0;
		margin-left: 0;
	}
	/*.main-slider li .item .image > div {
		height: 0;
		padding-bottom: 43%;
	}*/
	.main-slider li .item .texts {
		float: none;
		width: auto;
		margin-top: -50px;
		padding-bottom: 0;
	}
	.main-slider li .item .texts .ttl {
		top: 0;
		left: 10px;
		width: 100px;
		font-size: 15px;
	}
	.main-slider li .item .texts .ttl > div {
		height: 100px;
	}
	.main-slider li .item .texts .ttl small {
		font-size: 12px;
		line-height: 1.3;
	}
	.main-slider li .item .texts .ttl:before {
		width: 70px;
		height: 70px;
		margin: -35px 0 0 -35px;
	}
	.main-slider li .item .texts .txt {
		margin-top: -20px;
		padding: 0 15px 0 90px;
		font-size: 11px;
		line-height: 1.5;
	}
}
@media only screen and (max-width:959px) {
	.main-slider {
			margin-bottom: 220px;
	}
}

/* slick-dots */
.main-slider .slick-dots {
	position: relative;
	text-align: center;
	bottom: -17px;
	line-height: 0;
}
.main-slider .slick-dots li {
	display: inline-block;
	margin: 0 5px;
	vertical-align: top;
	width: inherit;
}
.main-slider .slick-dots li button {
	display: block;
	width: 14px;
	height: 14px;
	background-color: #dcdcdc;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	text-indent: -9999px;
	border-radius: 50%;
}
.main-slider .slick-dots li.slick-active button {
	background-color: #ff6600;
}

@media only screen and (max-width:767px) {
	.main-slider .slick-dots {
	/* bottom: -25px; */
}
	.main-slider .slick-dots li button {
	width: 10px;
	height: 10px;
}
}

/* slick-arrow */

.main-slider .slick-arrow {
		position: absolute;
		bottom: 0;
		width: 30px;
		height: 30px;
		background-color: transparent;
		background-repeat: no-repeat;
		background-size: contain;
		border: none;
		cursor: pointer;
		outline: none;
		padding: 0;
		appearance: none;
		text-indent: -9999px;
		z-index: 20;
		margin: auto;
		top: 0;
		transform: translateY(-50%);
	}
	.main-slider .slick-prev {
		left: calc(50vw - 495px);
		background-image: url(../img/pc/page/slide_arw01.png);
		filter: grayscale(1);
		opacity:0.5;
	}
	.main-slider .slick-next {
		right: calc(50vw - 495px);
		background-image: url(../img/pc/page/slide_arw02.png);
		filter: grayscale(1);
		opacity:0.5;
	}
@media only screen and (max-width:991px) {
	.main-slider .slick-arrow {
		width: 24px;
		height: 24px
	}
	.main-slider .slick-prev {
		left: 0px;
	}
	.main-slider .slick-next {
		right: 0px;
	}
}

/* news-area
--------------------------------------------------*/
.news-area {
	display: none;
	margin-bottom: 20px;
}
.news-area #NewsLine {
	padding: 15px;
	background-color: #f6f6f6;
}
.news-area .inner span {
	display: block;
	font-size: 1.4rem;
}
.news-area .inner a {
	color: #535353;
	text-decoration: none;
}
@media only screen and (max-width:767px) {
	.news-area .common-wrap {
		padding: 0;
	}
	.news-area #NewsLine {
		padding: 10px;
		font-size: 11px;
	}
}


/* news-topics
--------------------------------------------------*/
.news-topics-block {
	background-color: #fff;
	border-radius: 20px;
	padding: 20px;
	margin-bottom: 80px;
	z-index: 10;
	position: relative;
}
@media only screen and (max-width:767px) {
	.news-topics-block {
		margin-top: 50px;
		margin-bottom: 50px;
	}
}
.news-topics {
}
.news-scroll {
	overflow-y: auto;
	height: 330px;
}
.news-scroll ul {
	padding: 5px 0;
	margin: 0;
}
.news-scroll li {
	position: relative;
	display: table;
	width: 100%;
	padding: 6px 35px 6px 25px;
	/* font-size: 1.5rem; */
	list-style: none;
	border-bottom: #dfdddd dotted 1px;
}
.news-scroll li span {
	display: table-cell;
	vertical-align: top;
}
.news-scroll li span:nth-child(1) {
	width: 130px;
	color: var(--primary-text-color);
}
.news-scroll li a {
	color: var(--primary-text-color);
}

.news-scroll a:hover {text-decoration:none; opacity:0.6;} 

.news-tab {
  border-bottom: 2px solid var(--primary-color);
}
.news-tab h3 {
  margin-bottom: 0;
}
.news-tab .parts-tab-btn {
  border-bottom: none;
}

/* news-filter */
.news-filter {
  text-align: left;
  margin: 16px 8px 8px 24px;
}
@media only screen and (max-width:767px) {
	.news-filter {
  margin: 16px 8px 8px 8px;
}
}

.news-filter-btn {
  padding: 4px 12px;
  font-size: 0.813rem;
  font-weight: 700;
  border: 1px solid #ec0000;
  border-radius: 16px;
  background-color: #fff;
  color: #ec0000;
  cursor: pointer;
  transition: all 0.3s;
}
.news-filter-btn:hover {
  opacity: 0.7;
}
.news-filter-btn.active,
.news-filter-btn[aria-pressed="true"] {
  background-color: #ec0000;
  color: #fff;
}

@media only screen and (max-width:767px) {
	.news-scroll {
	overflow: auto;
	/* height: 350px; */
	line-height: 1.5;
}
	
	.news-topics {
		margin-bottom: 10px;
	}
	.news-scroll li {
		display: block;
		padding: 8px 25px 8px 10px;
		font-size: .875rem;
	}
a.inm-news-list-item-link {display: grid;grid-template-columns: 100px auto auto 1fr;grid-template-rows: auto;gap: 4px 0;margin-top: 0;}

	
	.news-scroll li span {
		/* display: contents; */
	}
	.news-scroll li span:nth-child(1) {
		width: auto;
		grid-column: 1 / 2;
		grid-row: 1/2;
	}
	.news-scroll li span.inm-news-list-item-link-title {
		grid-column: 1 / 5;
		grid-row: 2/3;
	}
	
	.news-scroll li span.inm-news-list-item-link-new {
		grid-column: 3/4;
		grid-row: 1;
		margin-top: -2px;
	}
	.news-scroll li span.inm-news-list-item-link-important {
		grid-column: 2/3;
		grid-row: 1;
		margin-top: -2px;
	}
}

.news-topics .index-btn {
	margin: 20px 0 0;
	text-align: right;
}
.news-topics .index-btn a {
	display: inline-block;
	padding: 10px 40px;
	/*color: #535353;
	border-top: #cccbcb solid 1px;
	border-bottom: #cccbcb solid 1px;*/
}
@media only screen and (max-width:767px) {
	.news-topics .index-btn a {
		padding: 10px 20px;
		font-size: .875rem;
	}
}

.news-topics .index-btn a:hover {
  background-position: right center;
  background-size: 200% auto;
  -webkit-animation: pulse 2s 1;
}
@keyframes ripple {
  0% {box-shadow: 0 0 0 0 #ccc;}
  70% {box-shadow: 0 0 0 10px rgb(27 133 251 / 0%);}
  100% {box-shadow: 0 0 0 0 rgb(27 133 251 / 0%);}
}


#pagetop {
	/* display: none; */
}

.newsList li a,
.news-topics .index-btn a{
	color: #333;
}

.news-topics-block .parts-arw01:before {
	background-color: var(--primary-color) ;
}
.news-topics-block .parts-arw01:after {
	    border-top: #fff solid 2px;
    border-right: #fff solid 2px;
}
/* Search-area
--------------------------------------------------*/

#Search-btn-Area {overflow:hidden;}
#Search-btn-Area .parts-tab-body {padding: 0 0 20px; background: none;}
@media only screen and (max-width: 767px) {
	#Search-btn-Area .parts-tab-body {padding: 0;}
}
#Search-btn-Area .parts-box-btns .row > div {
	margin: 10px;
	flex-basis: calc((100% - 100px) / 5);
	max-width: calc((100% - 100px) / 5);
	border-bottom: none;
	border-radius: 8px;
}

#Search-btn-Area.small_wid .parts-box-btns .row > div {
	flex-basis: calc((100% - 100px) / 5);
	max-width: calc((100% - 100px) / 5);
}


@media only screen and (max-width:991px) {
#Search-btn-Area .parts-box-btns .row > div {
	flex-basis: calc((100% - 100px) / 5);
	max-width: calc((100% - 100px) / 5);
}
}

@media only screen and (max-width:767px) {
#Search-btn-Area .parts-box-btns .row > div {
	flex-basis: calc((100% - 80px) / 4);
	max-width: calc((100% - 80px) / 4);
}
}

@media only screen and (max-width:565px) {
#Search-btn-Area .parts-box-btns .row > div {
	flex-basis: calc((100% - 60px) / 3);
	max-width: calc((100% - 60px) / 3);
}
}

@media only screen and (max-width:480px) {
#Search-btn-Area .parts-box-btns .row > div {
	flex-basis: calc((100% - 40px) / 2);
	max-width: calc((100% - 40px) / 2);
}
}






/* banner-area
--------------------------------------------------*/

#search-side-include .widget-box:nth-of-type(2)  {margin-top:50px;}

#search-side-include .side-area ul.parts-widget-list01 li {
   	flex-basis: calc((100% - 30px) / 2);
   	border-bottom: none;
   	margin: 10px 0;
	border: 1px solid #eee;  
}
#search-side-include .parts-widget-list01 li a {
    /* font-size:1.4rem; */
    font-weight:700;
    display: flex;
		align-items: center;
    padding: 20px 30px 20px 10px;
    background-color: #005BAC;
    color: #fff;
}
@media only screen and (max-width:991px) {
	#search-side-include .parts-widget-list01 li a {
			padding: 20px 20px 20px 5px;
	}
}
#search-side-include .parts-widget-list01 li a span {
	margin-right: 10px;
}

#search-side-include .parts-widget-list01 li a:hover { opacity: 0.6;}

#search-side-include .parts-widget-list01 li a:before{
	position: absolute;
	top: 50%;
	left: auto;
	right: 10px;
	display: block;
	content: '';
	width: 8px;
	height: 8px;
	margin-top: -5px;
	border-top: #ccc solid 2px;
	border-right: #ccc solid 2px;
	transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
}



@media only screen and (max-width:991px) {

.side-area {
    display: block;
    padding-left: 0;
    margin-top: 0;
		margin-bottom: 120px;
}

#search-side-include .side-area ul.parts-widget-list01 {
    display: flex;
    flex-wrap: wrap;
	padding: 0;
}

#search-side-include .side-area ul.parts-widget-list01 li {
   	flex-basis: calc((100% - 60px) / 3);
	margin: 10px 10px 0;
}
}

@media only screen and (max-width:767px) {
#search-side-include .side-area ul.parts-widget-list01 li {
   	flex-basis: calc((100% - 40px) / 2);
}
}
@media only screen and (max-width:565px) {
#search-side-include .side-area ul.parts-widget-list01 li {
	flex-basis: 100%;
}
}



/* banner-area01
--------------------------------------------------*/
#BannerArea01 {
	padding: 40px 0;
	margin: 80px auto 0;
	position: relative;
}

#BannerArea01:before{
	position: absolute;
	top: 0px;
	left: 50%;
	display: block;
	content: '';
	width: 150vw;
	height: 100%;
	transform: translateX(-50%);
	background-color: #f5f5f5;
}

#BannerArea01 .parts-btn {
	text-align:center;
	margin:10px 5px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	flex-grow: 1;
	flex-shrink: 0;
	flex-basis: calc((100% - 50px) / 5);
	max-width: calc((100% - 50px) / 5);

}

#BannerArea01 .parts-btn a {
  position: relative;
  overflow: hidden;
  z-index: 2;
  padding:10px 0;
  width:100%;
  box-shadow: 0 1px 4px rgba(0,0,0,0.1);
  background-color: #fff;
  color: #333;
  transition: 0.3s linear;
}

#BannerArea01 .parts-btn a::after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  transition: 0.3s linear;
}
#BannerArea01 .parts-btn a:hover {
    color:#fff;
}
#BannerArea01 .parts-btn a:hover::after {
  left: 0;
  background-color: #268708;
}

@media print, screen and (max-width:991px) {
	#BannerArea01 .parts-btn {
		flex-basis: calc((100% - 30px) / 3);
		max-width: calc((100% - 30px) / 3);
		}
}
@media only screen and (max-width:767px) {
#BannerArea01 .parts-btn {
	flex-basis: calc((100% - 20px) / 2);
	max-width: calc((100% - 20px) / 2);
	}
}

@media only screen and (max-width:565px) {
#BannerArea01 .parts-btn {
	flex-basis: 100%;
	max-width: 100%;
	}
}
#BannerArea01 .parts-btn a:hover {text-decoration: none;}
#BannerArea01 div {margin-left:0; margin-right:0;}

/* banner-area02
--------------------------------------------------*/
#BannerArea02 {
	padding: 40px 0;
	margin: 80px auto 0;
	position: relative;
}

#BannerArea02:before{
	position: absolute;
	top: 0px;
	left: 50%;
	display: block;
	content: '';
	width: 150vw;
	height: 100%;
	transform: translateX(-50%);
	background-color: #f5f5f5;
}

#BannerArea02 .parts-btn {
	text-align:center;
	margin:10px 5px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	flex-grow: 1;
	flex-shrink: 0;
	flex-basis: calc((100% - 50px) / 5);
	max-width: calc((100% - 50px) / 5);
}

#BannerArea02 .parts-btn a {
  position: relative;
  overflow:hidden;
  z-index: 2;
  padding:10px 0;
  	width:100%;
	box-shadow: 0 1px 4px rgba(0,0,0,0.1);
	background-color: #fff;
	color: #333;
}

#BannerArea02 .parts-btn a::before,
#BannerArea02 .parts-btn a::after {
  position: absolute;
  z-index: -1;
  display: block;
  content: '';
}
#BannerArea02 .parts-btn a,
#BannerArea02 .parts-btn a::before,
#BannerArea02 .parts-btn a::after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all .3s;
  transition: all .3s;
}

#BannerArea02 .parts-btn a:hover {
  color: #fff;
}
#BannerArea02 .parts-btn a::after {
  top: -100%;
  width: 100%;
  height: 100%;
}
#BannerArea02 .parts-btn a:hover::after {
  top: 0;
  background-color: #268708;
}

@media print, screen and (max-width:991px) {
	#BannerArea02 .parts-btn {
		flex-basis: calc((100% - 30px) / 3);
		max-width: calc((100% - 30px) / 3);
		}
}
@media only screen and (max-width:767px) {
#BannerArea02 .parts-btn {
	flex-basis: calc((100% - 20px) / 2);
	max-width: calc((100% - 20px) / 2);
	}
}

@media only screen and (max-width:565px) {
#BannerArea02 .parts-btn {
	flex-basis: 100%;
	max-width: 100%;
	}
}

#BannerArea02 .parts-btn a:hover {text-decoration: none;}
#BannerArea02 div {margin-left:0; margin-right:0;}



/* banner-area03
--------------------------------------------------*/
#BannerArea03 {
	padding: 40px 0;
	margin: 80px auto 0;
	position: relative;
}

#BannerArea03 div {margin-left:0; margin-right:0;}

#BannerArea03:before{
	position: absolute;
	top: 0px;
	left: 50%;
	display: block;
	content: '';
	width: 150vw;
	height: 100%;
	transform: translateX(-50%);
	background-color: #f5f5f5;
}

#BannerArea03 .parts-btn {
	text-align:center;
	margin:10px 5px;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	flex-grow: 1;
	flex-shrink: 0;
	flex-basis: calc((100% - 40px) / 4);
	max-width: calc((100% - 40px) / 4);
}

#BannerArea03 div img {overflow:hidden;}

#BannerArea03 .parts-btn a {display: block;text-decoration: none;background-color: #fff;margin: auto;overflow: hidden;}
#BannerArea03 .parts-btn a:hover {text-decoration: none;}

@media print, screen and (max-width:991px) {
	#BannerArea03 .parts-btn {
		flex-basis: calc((100% - 30px) / 3);
		max-width: calc((100% - 30px) / 3);
		}
}
@media only screen and (max-width:565px) {
#BannerArea03 .parts-btn {
	flex-basis: calc((100% - 20px) / 2);
	max-width: calc((100% - 20px) / 2);
	}
}

a img.imgover2 { transition:.2s all;}
a img.imgover2:hover {
transform:scale(1.1,1.1);
transition:.2s all;
}

.side-area .widget-box .ttl {border-radius:0;}
.side-area .widget-box .ttl:before {
	margin:0;
	display:none;
}

.side-area .widget-box .ttl > * {
	vertical-align: middle;
}

.parts-widget-list01 {border:none; margin-bottom: 30px;}

#search-side-include .side-area .widget-box .banner a {
	padding: 0;
	background: none;
}
#search-side-include .side-area .widget-box .banner a:before {
	display: none;
}
#search-side-include .side-area .widget-box .banner img {
	width: 100%;
}

/*--------------------------------------------------

index card

--------------------------------------------------*/
.index-cards {
	padding: 30px 0;
	position:relative;
	margin: 30px auto;
}

.index-cards:before {
	position: absolute;
	top: 0px;
	left: 50%;
	display: block;
	content: '';
	width: 150vw;
	height: 100%;
	transform: translateX(-50%);
	background-color:#f2f4fa;
	min-width: 320px;
}

.index-cards .row > div {
	margin:10px;
	flex-basis: calc((100% - 80px) / 4);
	max-width: calc((100% - 80px) / 4);
	flex-grow: 1;
	flex-shrink: 0;
	border:none;
	box-shadow: 0 1px 8px rgb(0 0 0 / 20%);
	border-radius: 0;
}

.index-cards .row > div.streched:hover {
		opacity:0.7;
		box-shadow: 0 1px 8px rgb(0 0 0 / 20%);
}


.stretched-link::after{
  position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:auto;content:"";background-color:rgba(0,0,0,0)
}

.streched .text-link{
  position: relative; z-index: 2;
}

.parts-arw-bdr-btn2 {
	/* text-align:center; */
	border: none;
	background-color: var(--primary-color);
	border-radius: 0;
}


@media only screen and (max-width:959px) {
.index-cards .row > div {
	margin:10px;
	flex-basis: calc((100% - 60px) / 3);
	max-width: calc((100% - 60px) / 3);
}
}

@media only screen and (max-width:768px) {
.index-cards .row > div {
	margin:10px;
	flex-basis: calc((100% - 40px) / 2);
	max-width: calc((100% - 40px) / 2);
}
}

@media only screen and (max-width:480px) {
.index-cards .row > div {
	margin:10px 20px;
	flex-basis:calc(100% - 40px);
	max-width:calc(100% - 40px);
}
}

/* parts-title-06 */

.parts-title-06 {
  text-align: left;
  color: var(--primary-color);
}

.parts-title-06 span {
  display: block;
  position: relative;
  font-weight:700;
  margin-bottom: 1em;
  font-size: 1.5rem;
}

.parts-title-06 > span:before {
  position: absolute;
  bottom: -3px;
  width: 100%;
  height: 2px;
  content: '';
  background: var(--primary-color);
}

@media only screen and (max-width:767px) {
	.parts-title-06 span {
		font-size: 1.25rem;
	}
}

.card-text{padding: 16px 16px;}


/*--------------------------------------------------

 parts-icon-btn

--------------------------------------------------*/

.parts-tab-body .parts-icon-btn a {
		border-radius: 8px;
		box-shadow: 0 0 4px 2px rgba(255, 255, 255, 0.6), 2px 2px 5px 0px rgba(0, 0, 0, 0.3);
		height: 130px;
  flex-direction: column;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  display: flex;
  width: 100%;
  /* height: 100%; */
  /* padding: 40%; */
  color: #333;
  text-decoration: none;
  text-align: center;
  /* font-size: 1.4rem; */
  font-weight: 600;
  justify-content: center;
	align-items: center;
	padding: 10px;
	border: none !important;
	background: #F7E7E6;
}
.parts-tab-body .parts-icon-btn a:hover {
	background: #FCD4D2 !important;
	box-shadow: none !important;
	border: none !important;
	text-decoration: none;
	opacity: 1 !important;
}
.parts-tab-body .parts-icon-btn a span {
	opacity: 1;
	transition: all 0.3s ease;
}
.parts-tab-body .parts-icon-btn a:hover span {
	font-size: 18px;
}
.parts-tab-body .parts-icon-btn a:hover .ico {
	opacity: 0;
	visibility: hidden;
	height: 0;
	padding: 0;
}
.parts-tab-body.parts-icon-btn a > * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  /* display: table-cell; */
  /* vertical-align: middle; */
  /* padding-right: 20px; */
  text-align: center;
  /* position: absolute; */
  /* top: 58%; */
  line-height: 1.2;
  /* width: 70%; */
  padding: 0;
  display: flex;
  flex-direction: column;
}
.parts-icon-btn a:before {
  position: absolute;
  top: 50%;
  right: 15px;
  display: none;
  content: '';
  width: 8px;
  height: 8px;
  margin-top: -5px;
  border-top: #ddd solid 2px;
  border-right: #ddd solid 2px;
  transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
}
.parts-icon-btn a > * {
	display: block;
	padding-right: 0;
	line-height: 1.2;
}
.parts-icon-btn a .ico {
  padding: 5px 0px;
  width: 100px;
  text-align: center;
}
.parts-icon-btn a .ico img, .parts-icon-btn a .ico > svg {
  max-height: 60px;
  max-width: 100px;
  width: auto;
  height: auto;
}
@media only screen and (max-width:767px) {
  .parts-icon-btn a {
    /* padding: 50%; */
    /* font-size: 13px; */
  }
}


/* banner-area04
--------------------------------------------------*/
#BannerArea04 {
	padding: 48px 0;
	margin: 80px auto 0;
	position: relative;
}

#BannerArea04:before{
	position: absolute;
	top: 0px;
	left: 50%;
	display: block;
	content: '';
	width: 150vw;
	height: 100%;
	transform: translateX(-50%);
	background-color: #f2f4fa;
}

#BannerArea04 div a img:hover{opacity:0.7;}


/* slick-arrow */
	.slick .slick-arrow {
		position: absolute;
		top: 0;
		width: 30px;
		height: 30px;
		display: block !important;
		background-color: transparent;
		background-repeat: no-repeat;
		background-size: contain;
		border: none;
		cursor: pointer;
		outline: none;
		/* transform: translateY(-50%); */
		padding: 0;
		appearance: none;
		text-indent: -9999px;
		z-index: 10;
		bottom: 0;
		margin: auto;
	}
	.slick .slick-prev {
		left: 0;
		background-image: url(../img/pc/page/slide_arw01.png);
		filter:grayscale(1) opacity(0.8);
	}
	.slick .slick-next {
		right: 0;
		background-image: url(../img/pc/page/slide_arw02.png);
		filter:grayscale(1) opacity(0.8);
	}

/* slick-dots */
.Banner_slide .slick-dots {
	position: absolute;
	bottom: -30px;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto;
	right: 0;
	padding: 0;
}
.Banner_slide .slick-dots li {
	display: inline-block;
	margin: 0 5px;
	vertical-align: top;
}
.Banner_slide .slick-dots li button {
	display: block;
	width: 14px;
	height: 14px;
	background-color: #dcdcdc;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	text-indent: -9999px;
	border-radius: 50%;
}
.Banner_slide .slick-dots li.slick-active button {
	background-color: #ff6600;
}

@media only screen and (max-width:767px) {
	.Banner_slide .slick-dots li button {
	width: 10px;
	height: 10px;
}
}

.slickBtnArea {position: relative;}
.slickBtnArea button {border: none;cursor: pointer;line-height: 0;padding: 0;z-index: 1;background: none;right: calc(50% - 90px);outline: none;position: absolute;font-size: 1.3rem;color: #999;}

.Banner_slide .slickBtnArea button{bottom: -34px;}

.Banner_slide .slick-list {
  margin: 0 -10px;
}
.Banner_slide .slick-slide {
  margin: 0 10px;
}

/* swiper */

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: -6px!important;
    position: relative;
}

#BannerArea04 {
.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: -10px!important;
    position: relative;
}
}

.swiper-button-next:after,
.swiper-button-prev:after {
    /*font-size: 15px!important; font-weight: 700; height: 30px!important;*/
}

.swiper-pagination-bullet-active {
    background-color: #e53936!important;
}



/* .swiper-slide img {object-fit:cover;height:100%;width:100%;} */


.swiper-button-next::after,
.swiper-button-prev::after {
    color: #000;
    font-size: 14px;
    font-weight: bold;
}

.swiper-button-next,
.swiper-button-prev {
    width: 34px;
    height: 34px;
    background: #eee;
    border-radius: 100%;
    border: 0;
    top: var(--swiper-navigation-top-offset, 47%);
}

@media only screen and (max-width: 767px) {
    .swiper-button-next,
    .swiper-button-prev {
        width: 28px;
        height: 28px;
        top: var(--swiper-navigation-top-offset, calc(50% - 6px));
    }
}

.swiper-pagination-bullet {
    opacity: 1;
    background-color: #ccc;
}

.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 10px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 10px));
}

.swiper-pagination-clickable .swiper-pagination-bullet{
  position: relative;
}
.swiper-pagination-clickable .swiper-pagination-bullet::before {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  top: -4px;
  left: -4px;
  /* background: #f004; */
}

.swiper-slide {padding: 2px;}

/*
.swiper-slide img {
    transition: 0.75s;
    filter: brightness(70%);
}

.swiper-slide-active img {
    filter: brightness(100%);
}
*/

/*
.swiper-slide {
    overflow: hidden;
    transition: .75s;
}

.swiper-slide {
  transform: scale(.8);
  transition: 1s;
}

.swiper-slide-active {
    transform: scale(1);
}
*/

.swiper .stopbtn,
.swiper2 .stopbtn2{
    cursor: pointer;
    z-index: 100;
    width: 1.6rem;
    height: 1.6rem;
    text-align: center;
    line-height: 1rem;
    color: #999;
    margin-left: 20px;
    position: relative;
    font-size: 1.6rem;
    border: 0;
    background: none;
    top: 7px;
    outline: none;
}

.swiper2 .stopbtn2{
    top: 10px;
}


.swiper .stopbtn:focus:not(:focus-visible),
.swiper2 .stopbtn2:focus:not(:focus-visible){
outline: none;
}

.swiper .stopbtn:focus-visible,
.swiper .stopbtn2:focus-visible{
outline: solid;
}

.swiper .stopbtn:hover,
.swiper2 .stopbtn2:hover{
    opacity: 0.75;
}

.swiper .stopbtn.stop:before,
.swiper .stopbtn.start:before,
.swiper2 .stopbtn2.stop:before,
.swiper2 .stopbtn2.start:before{
    position: absolute;
    top: 5px;
    left: -2px;
}

.swiper .stopbtn.stop:before,
.swiper2 .stopbtn2.stop:before{
    font-family: 'icomoon';
    content: "\ea16";
}

.swiper .stopbtn.start:before,
.swiper2 .stopbtn2.start:before{
    font-family: 'icomoon';
    content: "\ea15";
}

.swiper-button-next {height: 1.8rem!important;color: #fff!important;right: -12px;width: 1.8rem;left: auto;}
.swiper-button-prev {height: 1.8rem!important;color: #fff!important;right: auto;width: 1.8rem;left: -12px;}

#BannerArea04 {
	.swiper-button-next {right: calc(50% - 160px);top: var(--swiper-navigation-top-offset, 95%);}
	.swiper-button-prev {left: calc(50% - 160px);top: var(--swiper-navigation-top-offset, 95%);}
}


.parts-tab-btns2 .parts-tab-btn {
	border-bottom: none;
}
.parts-tab-btns2 .parts-tab-btn a {
	border-radius: 30px;
	border: 2px solid var(--primary-color);
}
@media only screen and (max-width: 767px) {
	.parts-tab-btns2 .parts-tab-btn a {
		padding: 4px;
		border-radius: 15px;
	}
}
.parts-tab-btns2 .parts-tab-btn:not(.on) a {
	background-color: #fff;
}
.parts-tab-btns2 .parts-tab-btn a:before {
	border-top: var(--primary-color) solid 10px;
    border-left: transparent solid 10px;
    border-right: transparent solid 10px;
}
.parts-tab-btns2 .parts-tab-btn:not(.on) a:hover {
	background-color: #fff;
}

.side-ttl {
	margin-top: 1rem;
	font-size: 24px;
}
@media only screen and (max-width:767px) {
	.side-ttl {
		margin-top: 0;
	}
}