@charset "utf-8";

.external-icon {
  width: 20px;
  height: 20px;
  margin-left: 1px;
  vertical-align: middle;
  display: inline;
}


/* ------------------------------------------------------------------
# header
------------------------------------------------------------------ */
/* #header {
  position: initial;
} */

.sticky-top {
  top: 0;
  width: 100%;
  background-color: #fff;
  z-index: 900;
}

.position-relative {
  position: relative;
}

.header-area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 120px;
}
.is-animation .header-area {
	height: 60px;
}
.is-animation .header-right {
    padding-top: 0px;
}


.header-logo img {
  max-width: 180px;
}

.header-right {
  display: flex;
	padding-top: 20px;
}

.header-right-area {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  flex-direction: column;
}


.header-upper-link-area {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.header-upper-link {
  font-size: 14px;
  padding: 0 10px;
  border-right: #e6e6e6 solid 1px;
  white-space: nowrap;
}

.header-upper-link:last-of-type {
  border-right: none;
  padding-right: 0;
}

.header-upper-link a {
  color: black;
}

.nav-area {
  display: flex;
}

.nav-area a {
  color: black;
}

.nav-head-link {
  font-weight: bold;
  margin-left: 40px;
  height: 70px;
  display: flex;
  align-items: center;
}

/* .nav-head-link:hover .nav-mega-menu-area {
  visibility: visible;
}

.nav-mega-menu-area:hover {
  visibility: visible;
} */


.nav-mega-menu-area.visible {
  visibility: visible;
}

.nav-mega-menu-link {
  margin: 15px;
  font-weight: normal;
}

.nav-mega-menu-link a::before {
  font-family: 'FontAwesome';
  content: "\f054  ";
  color: var(--red-color);
  font-size: 14px;
  margin-right: 5px;
}

.nav-mega-menu-area {
  display: flex;
  background-color: #f8f8f8;
  position: absolute;
  width: 100%;
  left: 0;
  top: calc(100%);
  z-index: 1000;
  visibility: hidden;
  align-items: center;
  justify-content: center;
  padding-top: 30px;
  padding-bottom: 30px;
}

.nav-mega-menu-wrap {
  display: flex;
  flex-wrap: wrap;
  max-width: 1200px;
}

.header-button {
  position: relative;
  background-color: var(--main-border-color);
  color: white;
  text-align: center;
  border-radius: 10px;
  padding: 20px 0;
  font-size: 14px;
  font-weight: bold;
  line-height: 20px;
  margin-left: 30px;
  margin-bottom: 20px;
  width: 100px;
}

.header-button i {
  font-size: 16px;
}
header a:link {
    text-decoration: none;
}
header a:link:hover {
    opacity: 0.8;
}
.search-button {
  font-size: 14px;
  text-align: center;
  color: white;
  background-color: var(--navy-color);
  border-radius: 16px;
  line-height: 32px;
  width: 90px;
  height: 32px;
	border: none;
}

.search-button.hide {
  display: none;
}

.header-search-area {
  display: none;
}

.header-search-area.active {
  display: block;
}

.search-wrap01 {
  position: relative;
  width: 240px;
  height: 36px;
}

.search-wrap01 .search-area {
  border: 2px solid var(--navy-color);
  border-radius: 20px;
  font-size: 16px;
  padding: 5px 45px 5px 15px;
  width: 100%;
  transition: 0.3s ease-in-out;
}

.search-wrap01 .search-area :focus {
  box-shadow: 0 0 10px 0 rgba(2,36,98,0.4);
}

.search-wrap01 .search-btn {
  background-color: white;
  border-radius: 0 20px 20px 0;
  width: 40px;
  height: 100%;
  padding: 0 3px 0 0;
  text-align: center;
  position: absolute;
  top: 0;
  right: 0;
}


.is-animation .header-upper-area {
  display: none;
}

.sticky-top.is-animation {
  padding: 5px 0 0;
  border-bottom: #e6e6e6 solid 1px;
}

.is-animation .header-area {
  margin-top: 0;
}

.is-animation .header-button {
  padding: 5px;
  margin-bottom: 0;
  line-height: 18px;
  margin-top: 5px;
}
@media (max-width: 1200px) {
.is-animation .header-button {
  margin-top: 0px;
}
}
.is-animation .header-button i {
  font-size: 14px;
}

.is-animation .header-logo img {
  max-width: 120px;
}

.is-animation .nav-head-link {
  height: 60px;
}

.is-animation .header-button span {
  font-size: 12px;
}

@media (max-width: 1200px) {
  .sticky-top {
    padding-top: 0px;
  }

  .sticky-top.is-animation {
    padding: 0;
  }

  .header-area {
    margin-top: 0;
    position: relative;
	  height: 50px;
  }
.is-animation .header-area {
    height: 65px;
}
  .header-logo {
    padding: 0px 5px;
  }

  #menu-sp-btn {
    display: block;
    width: 65px;
    height: 65px;
    padding: 24px 14px;
  }

  .header-upper-area,
  .header-nav,
  .header-button  {
    display: none;
  }

  .clicked + .header-right .header-nav,
  .clicked + .header-right .header-button {
    display: block;
  }

  .header-nav {
    position: absolute;
    top: 65px;
    left: -15px;
    width: 100vw;
    background-color: #f8f8f8;
  }

  .nav-area {
    display: block;
  }

  .header-button {
    width: 300px;
    margin: 10px auto;
    font-size: 18px;
  }

  
  .header-button i {
    font-size: 18px;
  }

  .is-animation .header-logo img {
    max-width: 180px;
  }

  .is-animation .header-button {
    padding: 20px 0;
    margin-bottom: 10px;
  }

  .is-animation .header-button i,
  .is-animation .header-button span {
    font-size: 18px;
  }

  .nav-head-link {
    font-size: 18px;
    margin-left: 0;
    padding: 10px;
    border-bottom: 1px #e6e6e6 solid;
    display: block;
    position: relative;
    height: auto;
  }

  .is-animation .nav-head-link {
    height: auto;
  }


  .nav-head-link:has(.nav-mega-menu-area)::after {
    position: absolute;
    font-size: 12px;
    line-height: 25px;
    content: "＋";
    font-weight: bold;
    color: var(--navy-color);
    background-color: #e6e6e6;
    border-radius: 50%;
    width: 23px;
    height: 25px;
    right: 16px;
    top: calc(53px / 2);
    margin-top: -10px;
    padding-left: 2px;
    text-align: center;
  }

  .nav-head-link.active:has(.nav-mega-menu-area)::after {
    content: "ー";
  }

  .nav-mega-menu-area {
    visibility: visible;
    position: inherit;
    display: none;
    padding: 10px 0;
  }

  .nav-mega-menu-wrap {
    display: block;
  }

  .nav-mega-menu {
    display: block;
  }

  .nav-mega-menu-link {
    margin: 5px;
    font-size: 16px;
  }
}

@media (max-width: 768px) {
  .header-nav {
    left: -10px;
  }

  .header-logo img {
    height: 30px;
  }

  #menu-sp-btn {
    width: 50px;
    height: 50px;
    padding: 15px 14px;
  }

  .header-nav {
    top: 50px;
  }

  .is-animation .header-area {
    height: 50px;
  }
}

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

	#header .main-nav>ul>li,
	#header .main-nav>ul>li a.active {
		border-bottom: 1px solid #e6e6e6
	}

	#header .main-nav {
		display: none;
		padding: 15px 0 0;
		background-color: #f6f6f6
	}

	#header .main-nav>ul {
		display: block
	}

	#header .main-nav>ul>li {
		display: block;
		margin-right: 0;
		position: relative
	}

	#header .main-nav>ul>li a {
		position: relative;
		display: block;
		padding: 15px;
		font-size: 13px;
		font-size: 1.3rem
	}

	#header .main-nav>ul>li a:after {
		position: absolute;
		top: 50%;
		right: 15px;
		display: block;
		width: 10px;
		height: 15px;
		content: '';
		-webkit-transform: translateY(-50%);
		-ms-transform: translateY(-50%);
		transform: translateY(-50%);
		background: url(https://www.vibitcms.com/tmp/shared/img/ico_arow_right.png);
		background-size: cover
	}

	#header .main-nav>ul>li.has-sub>a:after {
		display: none
	}

	#header .main-nav .header-tools {
		display: block
	}

	#header .main-nav .header-tools .lang-switcher {
		margin: 15px 0;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}

	#header .main-nav .header-tools .contact {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		margin-bottom: 15px;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center
	}
}
@media screen and (min-width: 1200px){

#header .main-nav .header-tools,
#menu-sp-btn {
	display: none
}
}


#menu-sp-btn {
	line-height: 50px;
	position: fixed;
	z-index: 9999;
	top: 0;
	right: 0;
	width: 22px;
	height: 20px;
	padding: 15px 14px;
	background-color: #00a7eb;
}

@media screen and (max-width:768px) {
	#menu-sp-btn {
		display: block
	}
}

#menu-sp-btn span {
	display: block;
	width: 100%;
	height: 2px;
	margin-bottom: 6px;
	transition: transform .3s cubic-bezier(.175, .885, .32, 1.275) .1s, opacity .1s ease-in-out .1s, -webkit-transform .3s cubic-bezier(.175, .885, .32, 1.275) .1s;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	background-color: #fff
}

#menu-sp-btn.clicked span:first-child {
	-webkit-transform: translateY(9px) rotateZ(-135deg);
	-ms-transform: translateY(9px) rotate(-135deg);
	transform: translateY(9px) rotateZ(-135deg)
}

#menu-sp-btn.clicked span:nth-child(2) {
	opacity: 0
}

#menu-sp-btn.clicked span:last-child {
	-webkit-transform: translateY(-7px) rotateZ(135deg);
	-ms-transform: translateY(-7px) rotate(135deg);
	transform: translateY(-7px) rotateZ(135deg)
}

/* ------------------------------------------------------------------
# Scroll-logo
------------------------------------------------------------------ */

.slick-slide {
  height: 70px;
}

/* ------------------------------------------------------------------
# Main Section
------------------------------------------------------------------ */


.container-header {
  display: block;
  margin: 0 auto;
  padding: 0 15px;
  position: relative;
}

.container2 {
  display: block;
  margin: 0 auto;
  padding: 0 15px;
}

.pc-only {
  display: block;
}
@media (max-width: 1200px) {
.pc-only {
  display: none;
}
}
.sp-only {
  display: none;
}

.pc-only-f {
  display: flex;
}

.sp-only-f {
  display: none;
}

.module-6column .module-flex-img-item {
    float: left;
    text-align: center;
    width: calc(100% / 6 - 25px);
    margin-inline-end: 30px;
    margin-block-end: 30px;
}
.module-6column .module-flex-img-item:nth-child(6n) {
  margin-inline-end: 0px;
}
.module-6column .module-flex-img-item:nth-child(6n + 1)  {
  clear: both;
}
@media screen and (max-width:768px) {

.module-6column .module-flex-img-item {
    width: calc(100% / 3 - 10px);
    margin-inline-end: 15px;
    margin-block-end: 10px;
}
.module-6column .module-flex-img-item:nth-child(3n) {
  margin-inline-end: 0px;
}
.module-6column .module-flex-img-item:nth-child(3n + 1)  {
  clear: both;
}
}

.module-6column .module-flex-img-item-txt{
    margin-top: 10px!important;
    font-size: 0.9em;
}
.parts-601-1 .module-flex-img-item-txt a{
  text-decoration: none;
  padding-right: 15px;
  position: relative;
  display: block;
    line-height: 1.3;
}

.parts-601-1 .module-flex-img-item-txt a:after {
        content: "";
        position: absolute;
        top: 50%;
        bottom: 0;
        right: 1px;
        font-size: 90%;
        display: flex;
        justify-content: center;
        align-items: center;
        transition: right 0.3s;
        width: 6px;
        height: 6px;
        border-top: solid 2px var(--main-button-arrow-color);
        border-right: solid 2px var(--main-button-arrow-color);
        transform: translateY(-50%) rotate(45deg);
}
.parts-602-1 dt{
  font-weight: bold;
  margin-bottom: 5px;
}
.footerLogoWrap01 .cont02 {
	float: right;
	text-align: left;
	padding-left: 25px;
	font-size: 12px !important;
	line-height: 1.8em;
}
@media (max-width: 768px) {

.footerLogoWrap01 .cont02 {
	float: none;
  clear: both;
  padding-left: 0;
  padding-top: 15px;
}
}
/* --------------------------------------------------------------------
 # 011-3テキストボタン【5列】
-------------------------------------------------------------------- */
.module-5column .module-flex-img-item {
	float: left;
	text-align: center;
	inline-size: calc(100% / 5 - 16px);
	margin-inline-end: 20px;
	margin-block-end: 20px;

	&:nth-child(5n) {
		margin-inline-end: 0px;
	}

	& img {
		max-inline-size: 100%;
		block-size: auto;
		display: block;
		margin: 0 auto;
	}

	& .module-flex-img-item-txt {
		margin-block: 15px 0;
		text-align: left;
		font-size: 16px;
	}
}
.module-5column .module-flex-img-item:nth-child(5n+1) {
  clear: both;
}



#vcbody-wrapper .module-5column .module-flex-img-item {
	margin-inline-end: 20px;
}

#vcbody-wrapper .module-5column div:nth-child(5n) .module-flex-img-item {
	margin-inline-end: 0;
}
.module-5column .link-btn {
  display: block;
  block-size: inherit;
}
.module-5column .link-btn a{
  min-width: inherit;
    width: calc(100% - 15px);
    margin: 0 auto;
    max-block-size: none;
    padding: 0px 15px 0px 0;
    height: 100%;
    min-height: 60px;
}

.anker-btn .link-btn a:after{
  transform: translateY(-50%) rotate(135deg);
}
.anker-btn .link-btn a:hover:after{
  right: 10px;
}

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

	.module-5column .module-flex-img-item {
		inline-size: 100%;
		margin-block-end: 20px;
	}

	#vcbody-wrapper .module-5column .module-flex-img-item {
		margin-inline-end: 20px;
	}

	#vcbody-wrapper .module-5column div:nth-child(2n) .module-flex-img-item {
		margin-inline-end: 0;
	}

	.module-5column .module-flex-img-item p {
		inline-size: 100%;
		font-size: 14px;
		margin-top: 10px;
	}

	.module-5column .module-flex-img-item img {
		max-inline-size: 100%;
		block-size: auto;
	}

}
.AddParts4-1 ul li{
  margin-left: 30px;
}
.AddParts4-1 ul li a{
  position: relative;
  text-decoration: none;
}
.AddParts4-1 ul li a:hover{
  text-decoration: underline;
}
	.AddParts4-1 ul li a::before {
		content: "";
		background-image: url(../img/common/cont_btn_ar01.png);
		background-repeat: no-repeat;
		background-position: center center;
		background-size: 16px auto;
		width: 16px;
		height: 16px;
		position: absolute;
		left: -30px;
		top: 0.3rem;
	}
@media screen and (min-width: 1200px) {
.contNewsWrap01 {
    & li .cate {
        & p {
            width: 9em;
        }
    }
}  
.contNewsWrap01 {
    & li .cont {
        width: calc(100% - 340px);
    }
}
    .contNewsWrap01.contNewsWrap02 {
        & li .cont {
            width: calc(100% - 200px);
        }
    }
}