@charset "utf-8";

/*-------------------------------------------
slick-theme.min.css
-------------------------------------------*/
.slick-loading .slick-list{background:#fff url(./ajax-loader.gif) center center no-repeat}@font-face{font-family:'slick';font-weight:400;font-style:normal;src:url(./fonts/slick.eot);src:url('./fonts/slick.eot?#iefix') format('embedded-opentype'),url(./fonts/slick.woff) format('woff'),url(./fonts/slick.ttf) format('truetype'),url('./fonts/slick.svg#slick') format('svg')}.slick-prev,.slick-next{font-size:0;line-height:0;position:absolute;top:50%;display:block;width:20px;height:20px;padding:0;-webkit-transform:translate(0,-50%);-ms-transform:translate(0,-50%);transform:translate(0,-50%);cursor:pointer;color:transparent;border:none;outline:none;background:transparent}.slick-prev:hover,.slick-prev:focus,.slick-next:hover,.slick-next:focus{color:transparent;outline:none;background:transparent}.slick-prev:hover:before,.slick-prev:focus:before,.slick-next:hover:before,.slick-next:focus:before{opacity:1}.slick-prev.slick-disabled:before,.slick-next.slick-disabled:before{opacity:.25}.slick-prev:before,.slick-next:before{font-family:'slick';font-size:20px;line-height:1;opacity:.75;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.slick-prev{left:-25px}[dir='rtl'] .slick-prev{right:-25px;left:auto}.slick-prev:before{content:'←'}[dir='rtl'] .slick-prev:before{content:'→'}.slick-next{right:-25px}[dir='rtl'] .slick-next{right:auto;left:-25px}.slick-next:before{content:'→'}[dir='rtl'] .slick-next:before{content:'←'}.slick-dotted.slick-slider{margin-bottom:30px}.slick-dots{position:absolute;bottom:-25px;display:block;width:100%;padding:0;margin:0;list-style:none;text-align:center}.slick-dots li{position:relative;display:inline-block;width:20px;height:20px;margin:0 5px;padding:0;cursor:pointer}.slick-dots li button{font-size:0;line-height:0;display:block;width:20px;height:20px;padding:5px;cursor:pointer;color:transparent;border:0;outline:none;background:transparent}.slick-dots li button:hover,.slick-dots li button:focus{outline:none}.slick-dots li button:hover:before,.slick-dots li button:focus:before{opacity:1}.slick-dots li button:before{font-family:'slick';font-size:6px;line-height:20px;position:absolute;top:0;left:0;width:20px;height:20px;content:'•';text-align:center;opacity:.25;color:#000;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.slick-dots li.slick-active button:before{opacity:.75;color:#000}

/*-------------------------------------------
基本設定
-------------------------------------------*/
.inner {
  width: min(100%, 1204px);
  margin: 0 auto;
  padding: 0 22px;
}

.sp {
  display: none;
}



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

  body:not(.home) {
    font-size: 1.6em;
  }

}

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

  .pc {
    display: none;
  }

  .sp {
    display: block;
  }

}

body:not(.home) .site {
  overflow-x: clip;
}

/*-------------------------------------------
ページヘッダー
-------------------------------------------*/
.page-header {
  padding: 98px 0 106px;
}

.page-template-page-company .page-header,
.page-template-page-greeting .page-header,
.page-template-page-actionplan .page-header,
.page-template-page-introduction .page-header,
.page-template-page-history .page-header,
.page-template-page-company-english .page-header,
.page-template-page-privacy .page-header,
.page-template-page-sitemap .page-header {
  background: url(../images/sub/page-header_company_pc.png) no-repeat center / 2400px auto;
}

.post-type-archive-item .page-header,
.tax-item_usage .page-header,
.tax-item_tag .page-header,
.tax-item_kinds .page-header,
.single-item .page-header,
.search .page-header {
  background: url(../images/sub/page-header_item_pc.png) no-repeat center / 2400px auto;
}

.page-template-page-recruit .page-header {
  background: url(../images/sub/page-header_recruit_pc.png) no-repeat center / 2400px auto;
}

.page-template-page-technology .page-header,
.page-template-page-technology-child .page-header {
  background: url(../images/sub/page-header_technology_pc.jpg) no-repeat center / 2400px auto;
}

.page-template-page-materials .page-header,
.page-template-page-materials-child .page-header {
  background: url(../images/sub/page-header_materials_pc.png) no-repeat center / 2400px auto;
}

.page-template-page-faq .page-header {
  background: url(../images/sub/page-header_faq_pc.png) no-repeat center / 2400px auto;
}

.page-template-page-deveropment .page-header {
  background: url(../images/sub/page-header_deveropment_pc.png) no-repeat center / 2400px auto;
}

.post-type-archive-news .page-header,
.tax-cat_news .page-header,
.single-news .page-header {
  background: url(../images/sub/page-header_news_pc.png) no-repeat center / 2400px auto;
}

.page-template-page-contact .page-header,
.page-template-page-contact-english .page-header {
  background: url(../images/sub/page-header_contact_pc.png) no-repeat center / 2400px auto;
}


.page-header__title {
  color: #404040;
  font-size: 46px;
  line-height: 1;
  font-weight: 400;
  text-transform: uppercase;
}

.page-header__title span {
  font-size: 18px;
  font-weight: 500;
  vertical-align: 10px;
  line-height: 1.44;
}

.page-header__title span:before {
  display: inline-block;
  width: 24px;
  height: 1px;
  margin-right: 12px;
  background: #3e3e3e;
  vertical-align: 7px;
  content: '';
}

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

  .page-header {
    padding: 100px 0 50px;
  }

  .page-template-page-company .page-header,
.page-template-page-greeting .page-header,
.page-template-page-actionplan .page-header,
.page-template-page-introduction .page-header,
.page-template-page-history .page-header,
.page-template-page-company-english .page-header,
.page-template-page-privacy .page-header,
.page-template-page-sitemap .page-header  {
    background: url(../images/sub/page-header_company_sp.png) no-repeat center / cover;
  }

  .post-type-archive-item .page-header,
  .single-item .page-header {
    background: url(../images/sub/page-header_item_sp.png) no-repeat center / cover;
  }

  .page-template-page-recruit .page-header {
    background: url(../images/sub/page-header_recruit_sp.png) no-repeat center / cover;
  }


.page-template-page-technology .page-header,
.page-template-page-technology-child .page-header {
  background: url("../images/sub/spmain_tech.jpg") no-repeat center / cover;
}

.page-template-page-materials .page-header,
.page-template-page-materials-child .page-header {
  background: url("../images/sub/spmain_material.jpg") no-repeat center / cover;
}

.page-template-page-faq .page-header {
  background: url(../images/sub/spmain_contact.jpg) no-repeat center / cover;
}

.page-template-page-deveropment .page-header {
  background: url(../images/sub/spmain_business.jpg) no-repeat center / cover;
}

.post-type-archive-news .page-header,
.tax-cat_news .page-header,
.single-news .page-header {
  background: url(../images/sub/spmainbg_news.jpg) no-repeat center / cover;
}

.page-template-page-contact .page-header,
.page-template-page-contact-english .page-header {
  background: url("../images/sub/spmain_contact.jpg") no-repeat center / cover;
}

  .page-header__title {
    font-size: 26px;
    line-height: 1.64;
  }

  .page-header__title span {
    display: block;
    margin-top: 3px;
  }

  .page-header__title span:before {
    margin-right: 16px;
    vertical-align: 6px;
  }

}

/*-------------------------------------------
パンくずリスト
-------------------------------------------*/
.breadcrumb {
  padding: 12px 0;
}

.page-template-page-company-english .breadcrumb {
  background: #f8f8f8;
}

.breadcrumb__item {
  display: inline;
  color: #000;
  font-size: 12px;
  line-height: 2.5;
}

.breadcrumb__item:nth-last-child(n + 2):after {
  display: inline;
/*  margin: 0 1em;*/
  margin: 0 .5em 0 1em;
  content: '＞';
}

.breadcrumb__item a {
  color: #000;
  transition: opacity .6s;
}

.breadcrumb__item a:hover {
  opacity: .6;
}

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

  .breadcrumb {
    padding: 3px 0;
  }

}

/*-------------------------------------------
見出し
-------------------------------------------*/
h2.heading {
  margin-bottom: 62px;
  font-size: 28px;
  font-weight: 400;
}

h2.heading span {
  display: block;
  margin-bottom: 5px;
  color: #ACACAC;
  font-size: 18px;
  line-height: 1.78;
}

h3.heading {
  margin-bottom: 30px;
  padding: 8px 0;
  border-bottom: 1px solid #404040;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.55;
}

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

  h2.heading {
    margin-bottom: 22px;
    font-size: 24px;
  }

  h2.heading span {
    margin-bottom: 0;
    line-height: 1.38;
  }

  h3.heading {
    margin-bottom: 20px;
  }

}
/*-------------------------------------------
カテゴリフッタナビ
-------------------------------------------*/
.cate-navi{
	display: block;
    width: min(100%, 1204px);
    margin: 80px auto 0;
}
.cate-navi ul {
	display: inline-flex;
    width: 100%;
    justify-content: space-around;
    font-size: 15px;
    color: #252525;
    font-weight: 400;
    padding: 60px 100px 0;
	border-top: solid 1px  rgba(182,182,182,1.00);
 }
.cate-navi li {
	display: inline-flex;
	align-items:center;
   width: auto;
	min-height: 20px;
}
.cate-navi li span {
	display: inline-block;
  min-width: 18px;
	min-height: 18px;
  line-height: 18px;
	background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
}

/*.cate-navi li::after {
	content: "";
    position: absolute;
    top: 40%;
    right: 20px;
    width: 16px;
    height: 16px;
    background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
	
	}*/
.materials .cate-navi li::after {
	top: 38%;
	right: 0;
}
.cate-navi li>a {
	display: block;
    position: relative;
	transition: opacity .3s;
	
	}
@media screen and (max-width: 767px) {
	.cate-navi ul {
	 padding: 20px 3px;
    flex-wrap: nowrap;
    display: inline-flex;
    width: 100%;
	}
	.cate-navi li {
    display: block;
    font-size: 14px;
    position: relative;
}
.cate-navi li span {
	display: inline-block;
  width: 14px;
	height: 14px;
  line-height: 16px;
   background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
}

	
}

/*-------------------------------------------
企業情報
-------------------------------------------*/
.about {
}

.about-nav {
  padding: 55px 0 90px;
}

.about-nav__group {
  display: flex;
  justify-content: space-between;
}

.about-main-nav {
  width: min(100%, 760px);
}

.about-main-nav__list {
  display: flex;
}

.about-main-nav__item {
  width: calc((100% - (40px * 1)) / 2);
}

.about-main-nav__item:nth-child(n + 2) {
  margin-left: 40px;
}

.about-main-nav__item a {
  display: block;
  transition: opacity .6s;
}

.about-main-nav__item a:hover {
  opacity: .6;
}

.about-main-nav__image {
  position: relative;
  width: 100%;
  margin-bottom: 12px;
}

.about-main-nav__image:before {
  display: block;
  padding-top: calc((230 / 360) * 100%);
  content: '';
}

.about-main-nav__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-main-nav__title {
  color: #000;
  font-size: 24px;
  text-align: center;
  line-height: 1.42;
}

.about-sub-nav {
  width: min(100%, 380px);
  padding-left: 20px;
}

.about-sub-nav__item {
  display: flex;
  min-height: 100px;
  background: #f8f8f8;
}

.about-sub-nav__item:nth-child(n + 2) {
  margin-top: 30px;
}

.about-sub-nav__item a {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  padding: 20px 60px 20px 30px;
  color: #000;
  transition: opacity .6s;
}

.about-sub-nav__item a:hover {
  opacity: .6;
}

.about-sub-nav__item a:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.about-sub-nav__title {
  font-size: 24px;
  line-height: 1.42;
}

.about-sub-nav__title span {
  margin-left: 18px;
  font-size: 14px;
}

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

  .about-nav__group {
    display: block;
  }

  .about-main-nav {
    width: 100%;
    margin-bottom: 40px;
  }

  .about-main-nav__item {
    width: calc((100% - (10px * 1)) / 2);
  }

  .about-main-nav__item:nth-child(n + 2) {
    margin-left: 10px;
  }

  .about-main-nav__image:before {
    padding-top: calc((120 / 168) * 100%);
  }

  .about-sub-nav {
    width: 100%;
    padding-left: 0;
  }

  .about-sub-nav__list {
    display: flex;
  }

  .about-sub-nav__item {
    width: calc((100% - (10px * 1)) / 2);
    min-height: 120px;
  }

  .about-sub-nav__item:nth-child(n + 2) {
    margin-top: 0;
    margin-left: 10px;
  }

}

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

  .about-nav {
    padding: 22px 0 50px;
  }

  .about-main-nav__title {
    font-size: 20px;
    line-height: 1.1;
  }

  .about-sub-nav__item a {
    padding: 20px 40px 20px 20px;
  }

  .about-sub-nav__item a:before {
    right: 10px;
  }

  .about-sub-nav__title {
    font-size: 20px;
    line-height: 1.5;
  }

  .about-sub-nav__title span {
    display: block;
    margin-left: 0;
    font-size: 20px;
    line-height: 1.5;
  }

}

.group {
  padding: 72px 0 195px;
  background: #f8f8f8;
}

.group-list {
  display: flex;
  flex-wrap: wrap;
}

.group-item {
  width: calc((100% - (40px * 1)) / 2);
}

.group-item:nth-child(2n) {
  margin-left: 40px;
}

.group-item:nth-child(n + 3) {
  margin-top: 75px;
}

.group-item__image {
  position: relative;
  width: min(100%, 270px);
}

.group-item__image:before {
  display: block;
  padding-top: calc((240 / 270) * 100%);
  content: '';
}

.group-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.group-item__content {
  display: flex;
  align-items: center;
  position: relative;
  width: min(100%, 330px);
  min-height: 200px;
  margin: -140px 0 28px auto;
  padding: 30px 60px 30px 30px;
  background: #fff;
  transition: opacity .6s;
}

.group-item__content:hover {
  opacity: .6;
}

.group-item__content:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.group-item__name {
  color: #000;
  font-size: 24px;
  line-height: 1.33;
}

.group-item__text {
  line-height: 2;
}

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

  .group-item__content {
    width: calc((250 / 346) * 100%);
    min-height: 170px;
    margin: -50px 0 28px auto;
  }

}

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

  .group {
    padding: 50px 0 55px;
  }

  .group-list {
    display: block;
  }

  .group-item {
    width: 100%;
  }

  .group-item:nth-child(2n) {
    margin-left: 0;
  }

  .group-item:nth-child(n + 2) {
    margin-top: 50px;
  }

  .group-item__image {
    width: calc((225 / 346) * 100%);
  }

  .group-item__content {
    padding: 30px 42px 30px 30px;
  }

  .group-item__content:before {
    right: 12px;
  }

  .group-item__name {
    font-size: 20px;
    line-height: 1.6;
  }

  .group-item__text {
    font-size: 18px;
    line-height: 1.78;
  }

}

.en-group {
  padding: 46px 0 80px;
  background: #f8f8f8;
}

.en-group-list {
  display: flex;
  flex-wrap: wrap;
}

.en-group-item {
  width: calc((100% - (60px * 1)) / 2);
}

.en-group-item:nth-child(2n) {
  margin-left: 60px;
}

.en-group-item:nth-child(n + 3) {
  margin-top: 75px;
}

.en-group-item__image {
  position: relative;
  width: min(100%, 270px);
}

.en-group-item__image:before {
  display: block;
  padding-top: calc((240 / 270) * 100%);
  content: '';
}

.en-group-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.en-group-item__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  width: min(100%, 380px);
  min-height: 200px;
  margin: 0 0 30px;
  padding: 20px;
  background: #fff;
  /*transition: opacity .6s;*/
}

.en-group-item__content:hover {
  opacity: .6s;
}

.en-group-item__name {
  color: #000;
  font-size: 24px;
  line-height: 1.33;
}

.en-group-item__text {
  line-height: 2;
}

.en-group-item__logo {
  width: 200px;
  margin: 0 auto 18px;
}

.en-group-item__caption {
  font-size: 24px;
  text-align: center;
  line-height: 1.33;
}

.en-group-item__list {
  display: flex;
  flex-wrap: wrap;
 width: min(100%, 490px);
margin: 0;
}

.en-group-item__list dt,
.en-group-item__list dd {
  line-height: 2;
}

.en-group-item__list dt {
  width: 30%;
  color: #679ECC;
  text-align: left;
  font-weight: 700;
}

.en-group-item__list dd {
  width: 70%;
  padding-left: 20px;
}

.en-group-item__button {
  display: flex;
  align-items: center;
  position: relative;
  width: 360px;
  height: 100px;
  margin: auto;
  padding: 10px 60px 10px 30px;
  background: #679ECC;
  color: #fff;
  font-size: 24px;
  line-height: 1.33;
  transition: opacity .6s;
}

.en-group-item__button:hover {
  opacity: .6;
}

.en-group-item__button:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url(../images/sub/icon_arrow.svg) no-repeat center / contain;
  content: '';
}
.en-bt-abutus {
	display: block;
	width: 100%;
	margin: 60px auto;
	
}
@media screen and (max-width: 1203px) {

  .en-group-item__content {
    width: 100%;
    min-height: 170px;
    margin: 0 auto 20px;
  }

}

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

  .en-group {
    padding: 22px 0 50px;
  }

  .en-group-list {
    display: block;
  }

  .en-group-item {
    width: 100%;
  }

  .en-group-item:nth-child(2n) {
    margin-left: 0;
  }

  .en-group-item:nth-child(n + 2) {
    margin-top: 50px;
  }

  .en-group-item__image {
    width: calc((225 / 346) * 100%);
  }

  .en-group-item__content {
  }

  .en-group-item__logo {
    width: 180px;
    margin: 0 auto 8px;
  }

  .en-group-item__caption {
    font-size: 20px;
    line-height: 1.6;
  }

  .en-group-item__button {
    width: 340px;
    height: 90px;
    margin: 0 auto;
    font-size: 22px;
  }

}

.en-network {
  padding: 65px 0 80px;
  background: #F0F7FD;
}

.en-network__group {
  display: flex;
}

.en-network__content {
  flex-shrink: 0;
  margin-right: 170px;
}

.en-network__image {
  position: relative;
  width: min(100%, 700px);
  margin-top: 10px;
}

.en-network__image:before {
  display: block;
  padding-top: calc((500 / 700) * 100%);
  content: '';
}

.en-network__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

  .en-network__content {
    margin-right: 20px;
  }

}

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

  .en-network {
    padding: 40px 0 50px;
  }

  .en-network__group {
    display: block;
  }

  .en-network__content {
    margin-right: 0;
  }

  .en-network__image {
    width: 100%;
    margin-top: 0;
  }

  .en-group-item__list dt,
  .en-group-item__list dd {
    font-size: 18px;
    line-height: 1.78;
  }

  .en-group-item__list dt:nth-of-type(n + 2),
  .en-group-item__list dd:nth-of-type(n + 2) {
    margin-top: 5px;
  }

  .en-group-item__list dt {
    width: 30%;
  }

  .en-group-item__list dd {
    width: 70%;
    padding-left: 20px;
  }

}

.en-office {
  padding: 75px 0 200px;
}

.en-office__group {
  display: flex;
  justify-content: space-between;
}

.en-office__content {
  flex-shrink: 0;
}

.en-office-list {
  width: min(100%, 880px);
  padding-left: 20px;
}

.en-office-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
}

.en-office-item:nth-child(n + 2) {
  margin-top: 35px;
}

.en-office-item:before,
.en-office-item:after {
  position: absolute;
  background: #F8DE4D;
  content: '';
}

.en-office-item:before {
  left: 256px;
  width: 3px;
}

.en-office-item:first-child:before {
  top: 5px;
  height: 100%;
}

.en-office-item:nth-child(n + 2):before {
  top: -40px;
  height: calc(100% + 40px);
}

.en-office-item:after {
  top: 5px;
  left: 268px;
  width: 20px;
  height: 20px;
}

.en-office-item__image {
  flex-shrink: 0;
  position: relative;
  width: min(100%, 220px);
  margin-top: 5px;
}

.en-office-item__image:before {
  display: block;
  padding-top: 100%;
  content: '';
}

.en-office-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.en-office-item__content {
  width: min(100%, 640px);
  padding-left: 80px;
}

.en-office-item__address {
  font-size: 16px;
  line-height: 2;
  margin: -0.3rem 0;
}

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

  .en-office {
    padding: 50px 0 55px;
  }

  .en-office__group {
    display: block;
  }

  .en-office-list {
    width: 100%;
    padding-left: 0;
  }

  .en-office-item:before {
    left: 96px;
    width: 2px;
  }

  .en-office-item:after {
    left: 108px;
    width: 15px;
    height: 15px;
  }

  .en-office-item__image {
    width: min(100%, 80px);
  }

  .en-office-item__content {
    padding-left: 50px;
  }

  .en-office-item__address {
    font-size: 16px;
    margin: -0.5rem 0;
  }

}

/*-------------------------------------------
ワコー株式会社
-------------------------------------------*/
.info {
  padding-top: 60px;
}

.info__group {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.info__content {
  width: min(100%, 1000px);
  padding-right: 20px;
}

.info__content .w-heading {
  margin-bottom: 60px;
}

.info__text {
  font-size: 16px;
  line-height: 2;
}

.info__image {
  position: relative;
  width: min(100%, 560px);
  min-width: 430px;
}

.info__image:before {
  display: block;
  padding-top: calc((430 / 560) * 100%);
  content: '';
}

.info__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

  .info {
    padding-top: 20px;
  }

  .info__group {
    flex-direction: column;
  }

  .info__content {
    display: contents;
    width: 100%;
  }

  .info__text {
    order: 1;
    line-height: 1.78;
  }

  .info__image {
    width: 100%;
    min-width: 0;
    margin-bottom: 10px;
  }

}

.overview {
  padding-top: 80px;
}

.overview__list {
  display: flex;
  flex-wrap: wrap;
  padding-left: 40px;
}

.overview__list dt,
.overview__list dd {
  line-height: 2.875;
}

.overview__list dt {
  width: 22%;
  font-weight: 700;
  font-weight: 500;
}

.overview__list dd {
  width: 78%;
  padding-left: 20px;
}

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

  .overview {
    padding-top: 50px;
  }

  .overview__list {
    padding-left: 0;
  }

  .overview__list dt,
  .overview__list dd {
    font-size: 16px;
    line-height: 1.78;
  }

  .overview__list dt:nth-of-type(n + 2),
  .overview__list dd:nth-of-type(n + 2) {
    margin-top: 15px;
  }

  .overview__list dt {
    width: 30%;
  }

  .overview__list dd {
    width: 70%;
  }

}

.office {
  padding: 70px 0 200px;
}

.office-item {
  width: min(100%, 1080px);
  margin: 0 auto;
  padding-bottom: 60px;
  border-bottom: 1px solid #acacac;
}

.office-item:nth-child(n + 2) {
  padding-top: 60px;
}

.office-item__group {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.office-item__content {
  padding-right: 20px;
}

.office-item__name {
  margin-bottom: 20px;
  font-size: 18px;
  font-weight: 700;
  font-weight: 500;
  line-height: 1.78;
}

.office-item__address {
  margin-bottom: 35px;
  font-size: 16px;
  line-height: 2;
}

.office-item__google-maps {
  display: flex;
  align-items: center;
  position: relative;
  width: 160px;
  height: 50px;
  padding: 0 32px 0 10px;
  border: 1px solid #acacac;
  background: #f8f8f8;
  color: #404040;
  font-size: 14px;
  line-height: 2.14;
  transition: opacity .6s;
}

.office-item__google-maps:hover {
  opacity: .6;
}

.office-item__google-maps:before {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.office-item__image {
  flex-shrink: 0;
  position: relative;
  width: min(100%, 430px);
}

.office-item__image:before {
  display: block;
  padding-top: calc((280 / 430) * 100%);
  content: '';
}

.office-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

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

  .office {
    padding: 50px 0 60px;
  }

  .office-item {
    width: 100%;
    padding-bottom: 40px;
  }

  .office-item:nth-child(n + 2) {
    padding-top: 40px;
  }

  .office-item__group {
    flex-direction: column-reverse;
  }

  .office-item__content {
    padding-right: 0;
  }

  .office-item__content {
    width: 100%;
  }

  .office-item__name {
    margin-bottom: 10px;
  }

  .office-item__image {
    width: 100%;
    margin-bottom: 10px;
  }

}

/*-------------------------------------------
ごあいさつ
-------------------------------------------*/
.greeting {
  padding: 65px 0 210px;
}

.greeting__group {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.greeting__group h2.heading {
  flex-shrink: 0;
}

.greeting__content {
  width: min(100%, 880px);
  padding-left: 20px;
}

.greeting__text {
  line-height: 2;
}

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

  .greeting {
    padding: 20px 0 55px;
  }

  .greeting__group {
    display: block;
  }

  .greeting__content {
    width: 100%;
    padding-left: 0;
  }

  .greeting__text {
    font-size: 18px;
    line-height: 1.78;
  }

}

/*-------------------------------------------
一般事業主行動計画
-------------------------------------------*/
.plan {
  padding: 55px 0 185px;
}

.plan__content {
  width: min(100%, 940px);
  margin: 0 auto;
  padding: 0 20px;
}

.plan .w-heading {
  margin-bottom: 60px;
}

.plan__lead {
  margin-bottom: 55px;
  padding-bottom: 65px;
  border-bottom: 1px solid #ACACAC;
  font-size: 16px;
  line-height: 2;
}

.plan-item {
  display: flex;
}

.plan-item:nth-child(n + 2) {
  margin-top: 35px;
}

.plan-item__title {
  width: 150px;
  font-size: 16px;
  line-height: 2;
}

.plan-item__content {
  width: calc(100% - 150px);
  padding-left: 20px;
}

.plan-item__text {
/*  padding-left: 3em;*/
  font-size: 16px;
/*  text-indent: -3em;*/
  line-height: 2;
}

.plan-timing {
  margin-top: 25px;
}

.plan-timing:nth-last-child(n + 2) {
  margin-bottom: 25px;
}

.plan-timing__title {
  margin-bottom: 30px;
  line-height: 2;
}

.plan-timing__list {
  display: flex;
  flex-wrap: wrap;
}

.plan-timing__list dt,
.plan-timing__list dd {
  line-height: 2;
}

.plan-timing__list dt:nth-of-type(n + 2),
.plan-timing__list dd:nth-of-type(n + 2) {
  margin-top: 2em;
}

.plan-timing__list dt {
  width: 25%;
}

.plan-timing__list dd {
  width: 75%;
  padding-left: 20px;
}

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

  .plan {
    padding: 20px 0 55px;
  }

  .plan__lead {
    margin-bottom: 25px;
    padding-top: 6px;
    padding-bottom: 30px;
    font-size: 20px;
    line-height: 1.7;
  }

  .plan-item {
    display: block;
  }

  .plan-item:nth-child(n + 2) {
    margin-top: 25px;
  }

  .plan-item__title {
    width: 100%;
    margin-bottom: 8px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.89;
  }

  .plan-item__content {
    width: 100%;
    padding-left: 0;
  }

  .plan-item__text {
    line-height: 1.78;
  }

  .plan-timing__title {
    margin-bottom: 10px;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.75;
  }

  .plan-timing__list {
    display: block;
  }

  .plan-timing__list dt,
  .plan-timing__list dd {
    font-size: 16px;
    line-height: 1.75;
  }

  .plan-timing__list dt {
    width: 100%;
    margin-bottom: 12px;
  }

  .plan-timing__list dt:nth-of-type(n + 2) {
    margin-top: 28px;
  }

  .plan-timing__list dd {
    width: 100%;
    padding-left: 0;
  }

  .plan-timing__list dd:nth-of-type(n + 2) {
    margin-top: 0;
  }

}

/*-------------------------------------------
商品一覧
-------------------------------------------*/
.items {
  padding: 35px 0 190px;
}

.items__container {
  display: flex;
  flex-flow: row-reverse;
/*align-items: flex-start;*/
}

.items__side {
  width: min(100%, 260px);
}

.items__main {
  width: min(100%, 900px);
  padding-left: 40px;
}

.items__title {
  margin-bottom: 40px;
  padding: 8px 0;
  border-bottom: 1px solid #404040;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.55;
}

.items__conditions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 45px;
}

.items__conditions dt {
  margin-right: 20px;
  font-size: 18px;
  line-height: 2;
}

.items__conditions dd {
  margin-right: 20px;
  padding: 2px 10px;
  background: #F4F4F4;
  font-size: 14px;
}

.items-list {
  display: flex;
  flex-wrap: wrap;
}

.items-item {
  width: calc((100% - (27px * 4)) / 5);
}

.items-item:nth-child(5n - 3),
.items-item:nth-child(5n - 2),
.items-item:nth-child(5n - 1),
.items-item:nth-child(5n) {
  margin-left: 27px;
}

.items-item:nth-child(n + 6) {
  margin-top: 30px;
}

.items-item a {
  display: block;
  transition: opacity .6s;
}

.items-item a:hover {
  opacity: .6;
}

.items-item__thumbnail {
  position: relative;
  margin-bottom: 8px;
}

.items-item__thumbnail:before {
  display: block;
  padding-top: calc((130 / 150) * 100%);
  content: '';
}

.items-item__thumbnail img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-fit: contain;
}

.items-item__title {
  color: #000;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.625;
}

.items-item__part-number {
  color: #000;
  font-size: 14px;
  font-weight: 300;
  line-height: 2.14;
}

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

  .items__container {
    flex-direction: column-reverse;
  }

  .items__side {
    display: none;
    width: 100%;
    margin-bottom: 50px;
  }

  .items__main {
    width: 100%;
    padding-left: 0;
  }

}

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

  .items {
    padding: 25px 0 50px;
  }

  .items__title {
  }

  .items-item {
    width: calc((100% - (10px * 1)) / 2);
  }

  .items-item:nth-child(5n - 3),
  .items-item:nth-child(5n - 2),
  .items-item:nth-child(5n - 1),
  .items-item:nth-child(5n) {
    margin-left: 0;
  }

  .items-item:nth-child(2n) {
    margin-left: 10px;
  }

  .items-item:nth-child(n + 3) {
    margin-top: 30px;
  }

}

/*-------------------------------------------
検索フォーム
-------------------------------------------*/
body:not(.home) .searchform {
  position: sticky;
  top: 110px;
  padding: 20px 20px 60px;
  background: #EFEFEF;
}

body:not(.home) .searchform__title {
  margin-bottom: 20px;
  font-size: 18px;
  font-weight: 500;
  text-align: center;
}

body:not(.home) .searchform__label {
  margin-bottom: 6px;
  font-weight: 500;
}

body:not(.home) .searchform__label:nth-of-type(n + 2) {
  margin-top: 12px;
}

.searchform__button--select {
  position: relative;
}

.searchform__button--select:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  z-index: 10;
  width: 10px;
  height: 6px;
  background: url(../images/sub/icon_select02.svg) no-repeat center / contain;
  content: '';
  pointer-events: none;
}

body:not(.home) .searchform input[type="search"],
body:not(.home) .searchform select {
  width: 100%;
  padding: 10px 18px;
  background: #fff;
  outline: none;
}

body:not(.home) .searchform input[type="search"] {
  border-radius: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* プレースホルダー */
body:not(.home) .searchform input[type="search"]::placeholder {
  color: #ACACAC;
}

body:not(.home) .searchform input[type="search"]::-ms-input-placeholder {
  color: #ACACAC;
}

body:not(.home) .searchform input[type="search"]:-ms-input-placeholder {
  color: #ACACAC;
}

body:not(.home) .searchform select {
  color: #000;
}

body:not(.home) .searchform__button--submit,
body:not(.home) .searchform__button--reset {
  position: relative;
  border-radius: 8px;
}

body:not(.home) .searchform__button--submit {
  height: 40px;
  margin-top: 20px;
}

body:not(.home) .searchform__button--reset {
  height: 40px;
  margin-top: 20px;
}

body:not(.home) .searchform__button--submit:before,
body:not(.home) .searchform__button--reset:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%) rotate(45deg);
  z-index: 10;
  width: 9px;
  height: 9px;
  content: '';
}

body:not(.home) .searchform__button--submit:before {
  border-top: 1px solid #000;
  border-right: 1px solid #000;
}

body:not(.home) .searchform__button--reset:before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

body:not(.home) .searchform__button--submit input[type="submit"],
body:not(.home) .searchform__button--reset button {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  font-size: 18px;
  font-weight: 500;
}

body:not(.home) .searchform__button--submit input[type="submit"] {
  background: #FAE473;
  color: #000;
}

body:not(.home) .searchform__button--reset button {
  background: #b5b2b2;
  color: #fff;
}

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

  body:not(.home) .searchform {
    position: static;
  }

}

/*-------------------------------------------
ページネーション
-------------------------------------------*/
.pagenation {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  margin-top: 40px;
}

.pagenation .page-numbers {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 20px;
  height: 20px;
  margin: 0 5px 10px;
}

.pagenation .page-numbers.current {
  color: #000;
}

.pagenation .prev.page-numbers,
.pagenation .next.page-numbers {
  position: relative;
}

.pagenation .prev.page-numbers {
  background: #ddd;
}

.pagenation .next.page-numbers {
  background: #FAE473;
}

.pagenation .prev.page-numbers:before,
.pagenation .next.page-numbers:before {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 7px;
  height: 7px;
  content: '';
}

.pagenation .prev.page-numbers:before {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.pagenation .next.page-numbers:before {
  border-top: 1px solid #000;
  border-right: 1px solid #000;
}

.pagenation .prev.page-numbers:before {
  transform: translate(-25% , -50%) rotate(-135deg);
}

.pagenation .next.page-numbers:before {
  transform: translate(-75% , -50%) rotate(45deg);
}

.pagenation a {
  color: #000;
  transition: opacity .6s;
}

.pagenation a:hover {
  opacity: .6;
}

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

  .pagenation .page-numbers {
    width: 30px;
    height: 30px;
    font-size: 18px;
  }

  .pagenation .prev.page-numbers:before,
  .pagenation .next.page-numbers:before {
    width: 9px;
    height: 9px;
  }

  .pagenation .prev.page-numbers:before {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }

  .pagenation .next.page-numbers:before {
    border-top: 2px solid #000;
    border-right: 2px solid #000;
  }

}

/*-------------------------------------------
商品詳細
-------------------------------------------*/
.item {
  padding: 65px 0 200px;
}

.item__title {
  margin-bottom: 30px;
  padding: 8px 0;
  border-bottom: 1px solid #404040;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.55;
}

.item__subtitle {
  margin-bottom: 30px;
  padding-top: 10px;
  color: #3d3d3d;
  font-size: 28px;
  font-weight: 400;
}

.item__group {
  display: flex;
  justify-content: space-between;
  align-self: start;
  margin-bottom: 90px;
}

.item__content:first-child {
/*  width: min(100%, 640px);*/
  width: calc((640 / 1160) * 100%);
  padding-top: 5px;
}

.item__content:nth-child(2) {
/*  width: min(100%, 480px);*/
  width: calc((480 / 1160) * 100%);
  padding-left: 20px;
}

.item__youtube {
  position: relative;
  width: 100%;
  margin-bottom: 30px;
}

.item__youtube:before {
  display: block;
  padding-top: 56.25%;
  content: '';
}

.item__youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.item-slider {
  margin-bottom: 39px;
}

/* arrow */
.item-slider .slick-prev,
.item-slider .slick-next {
  z-index: 10;
  opacity: 0;
  transition: opacity .4s;
}

.item-slider:hover .slick-prev,
.item-slider:hover .slick-next {
  opacity: 1;
}

.item-slider .slick-prev {
  left: 10px;
}

.item-slider .slick-next {
  right: 10px;
}

.item-slider .slick-prev:before,
.item-slider .slick-next:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  background: url(../images/common/Icon-arrow-gray-2.svg) no-repeat center / contain;
  content: '';
}

.item-slider .slick-prev:before {
  transform: scale(-1, 1);
}

.item-slider__image {
  position: relative;
}

.item-slider__image:before {
  display: block;
  padding-top: 100%;
  content: '';
}

.item-slider__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-fit: contain;
}

.item-thumb {
  margin-bottom: 70px;
}

.item-thumb .slick-track {
  transform: initial;
  width: 100%!important;
  margin-left: 0;
  transform: translate3d(0, 0, 0)!important;
}

.item-thumb__image {
  position: relative;
  border: 1px solid #ddd;
  cursor: pointer;
/*  width: 100px;*/
  width: calc((100% - (20px * 4)) / 5)!important;
}

.item-thumb__image:nth-child(n + 2) {
  margin-left: 20px;
}

.item-thumb__image:before {
  display: block;
  padding-top: 100%;
  content: '';
}

.item-thumb__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-fit: contain;
}

.item-online__title {
  margin-bottom: 12px;
  font-size: 18px;
  line-height: 2.22;
}

.item-online__list {
  display: flex;
}

.item-online__item {
  width: calc((100% - (40px * 1)) / 2);
  height: 85px;
}

.item-online__item:nth-child(2) {
  margin-left: 40px;
}

.item-online__item a {
  display: block;
  transition: opacity .6s;
}

.item-online__item a:hover {
  opacity: .6;
}

.item__catchphrase {
  margin-bottom: 40px;
  font-size: 18px;
  line-height: 2.22;
}

.item__feature {
  margin-bottom: 35px;
}

.item__feature dt {
  margin-bottom: 15px;
  font-weight: 500;
  line-height: 1.625;
}

.item__feature dd {
  color: #404040;
  line-height: 2;
}

.item__info {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 28px;
  padding: 22px 0;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

.item__info dt,
.item__info dd {
  color: #404040;
  font-size: 14px;
  line-height: 2.57;
}

.item__info dt {
  width: 25%;
  font-weight: 500;
}

.item__info dd {
  width: 75%;
  padding-left: 20px;
}

.item__remarks {
  margin-bottom: 45px;
}

.item__remarks dt,
.item__materials dt {
  margin-bottom: 15px;
  font-weight: 500;
  line-height: 1.625;
}

.item__remarks dd,
.item__materials dd {
  color: #404040;
  line-height: 2;
}

.item__materials dd a {
  color: #404040;
  text-decoration: underline;
  transition: opacity .6s;
}

.item__materials dd a:hover {
  opacity: 0.6;
}

.item-taxonomy {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 115px;
  padding: 16px 0;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

.item-taxonomy dl {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.item-taxonomy dl:nth-last-child(n + 2) {
  margin-right: 40px;
}

.item-taxonomy dt {
  color: #6e6e6e;
  font-weight: 500;
  line-height: 1.625;
}

.item-taxonomy dt img {
  width: 18px;
  margin-right: 10px;
  vertical-align: -3px;
}

.item-taxonomy dd {
  font-size: 14px;
  line-height: 2.14;
}

.item-taxonomy dd:nth-last-child(n + 2) {
  margin-right: 1em;
}

.item-taxonomy dd a {
  display: block;
  color: #404040;
  text-decoration: underline;
  transition: opacity .6s;
}

.item-taxonomy dd a:hover {
  opacity: .6;
}

.item-relation {
  display: none;
  margin-bottom: 60px;
  padding: 40px 0 20px;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

.item-button {
  display: flex;
  justify-content: center;
}

.item-button__list,
.item-button__contact {
  display: flex;
  align-items: center;
  position: relative;
  height: 60px;
  transition: opacity .6s;
}

.item-button__list:hover,
.item-button__contact:hover {
  opacity: .6;
}

.item-button__list {
  justify-content: flex-end;
  width: 200px;
  padding-right: 20px;
  border: 1px solid #ACACAC;
  background: #F8F8F8;
  color: #404040;
}

.item-button__list:before {
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%) scale(-1, 1);
  width: 12px;
  height: 12px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.item-button__contact {
  justify-content: center;
  width: 260px;
  margin-left: 40px;
  background: #6e6e6e;
  color: #fff;
  font-size: 18px;
}

.item-button__contact:after {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  content: '';
}

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

  .item {
    padding: 25px 0 60px;
  }

  .item__title {
    margin-bottom: 15px;
  }

  .item__subtitle {
    margin-bottom: 20px;
    padding-top: 0;
    font-size: 22px;
    line-height: 1.73;
  }

  .item__group {
    flex-direction: column;
    margin-bottom: 0;
  }

  .item__content {
    display: contents;
  }

  .item__content:first-child {
    width: 100%;
    margin-bottom: 50px;
    padding-top: 0;
  }

  .item__content:nth-child(2) {
    width: 100%;
  }

  .item__youtube {
    margin-bottom: 20px;
  }

  .item-slider {
    margin-bottom: 20px;
  }

  .item-slider .slick-prev,
  .item-slider .slick-next {
    width: 15px;
    height: 15px;
    opacity: 1;
  }

  .item-thumb {
    margin-bottom: 30px;
  }

  .item-thumb__image {
    width: calc((100% - (20px * 2)) / 3)!important;
  }

  .item-thumb__image:nth-child(n + 2) {
    margin-left: 0;
  }

  .item-thumb__image:nth-child(3n - 1),
  .item-thumb__image:nth-child(3n) {
    margin-left: 20px;
  }

  .item-thumb__image:nth-child(n + 4) {
    margin-top: 20px;
  }

  .item-online {
    order: 1;
    transform: translateX(-22px);
    width: calc(100% + 44px);
    padding: 20px 20px 30px;
    background: #F8F8F8;
  }

  .item-online__title {
    width: min(100%, 300px);
    margin: 0 auto 12px;
  }

  .item-online__list {
    display: block;
  }

  .item-online__item {
    margin: 0 auto;
    width: min(100%, 300px);
  }

  .item-online__item:nth-child(2) {
    margin-top: 20px;
    margin-left: auto;
  }

  .item__catchphrase {
    margin-bottom: 25px;
    line-height: 1.67;
  }

  .item__feature {
    margin-bottom: 25px;
  }

  .item__feature dt {
    margin-bottom: 8px;
  }

  .item__feature dd {
    line-height: 1.75;
  }

  .item__info dt {
    width: 28%;
  }

  .item__info dd {
    width: 72%;
  }

  .item__materials {
    margin-bottom: 40px;
  }

  .item-button {
    flex-direction: column-reverse;
    align-items: center;
  }

  .item-button__contact {
    margin-bottom: 30px;
    margin-left: 0;
  }

  .item-button__list {
    justify-content: center;
    padding-right: 0;
    width: 260px;
  }

  .item-button__list:before {
    left: 18px;
  }

  .item-taxonomy {
    transform: translateX(-22px);
    width: calc(100% + 44px);
    margin-bottom: 40px;
    padding: 16px 22px 0;
  }

  .item-taxonomy dl {
    margin-bottom: 16px;
  }

}

/*-------------------------------------------
素材
-------------------------------------------*/
.top-materials {
  padding: 65px 0 200px;
}

.top-materials-nav {
  margin-bottom: 95px;
}

.top-materials-nav__list {
  display: flex;
  flex-wrap: wrap;
}

.top-materials-nav__item {
  width: calc((100% - (40px * 3)) / 4);
  background: #F8F8F8;
  font-size: 18px;
  line-height: 2;
}

.top-materials-nav__item:nth-child(4n - 2),
.top-materials-nav__item:nth-child(4n - 1),
.top-materials-nav__item:nth-child(4n) {
  margin-left: 40px;
}

.top-materials-nav__item:nth-child(n + 5) {
  margin-top: 40px;
}

.top-materials-nav__item a {
  display: block;
  position: relative;
  padding: 12px 60px 12px 30px;
  color: #000;
  transition: opacity .6s;
}

.top-materials-nav__item a:hover {
  opacity: 0.6;
}

.top-materials-nav__item a:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%) rotate(90deg);
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.top-materials__container {

}

.top-materials__group {

}

.top-materials__group:nth-child(n + 2) {
  margin-top: 100px;
}

.top-materials__header {
  display: flex;
  align-items: center;
  margin-bottom: 40px;
}

.top-materials__link {
  flex-shrink: 0;
  margin-right: 42px;
  padding-right: 38px;
  transition: opacity .6s;
}

.top-materials__link:hover {
  opacity: 0.6;
}

.top-materials__title {
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.78;
}

.top-materials__title span {
  display: inline-block;
  position: relative;
  margin-top: 8px;
  color: #3D3D3D;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
}

.top-materials__title span:after {
  position: absolute;
  bottom: 0;
  right: -38px;
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.top-materials__colmun {
  width: auto;
}

.top-materials__lead {
  font-size: 18px;
  line-height: 2;
}

.top-materials__body {

}

.top-materials-cards {
  display: flex;
  flex-wrap: wrap;
}

.top-materials-card {
  width: calc((100% - (40px * 3)) / 4);
}

.top-materials-card:nth-child(4n - 2),
.top-materials-card:nth-child(4n - 1),
.top-materials-card:nth-child(4n) {
  margin-left: 40px;
}

.top-materials-card:nth-child(n + 5) {
  margin-top: 40px;
}

.top-materials-card a {
  display: block;
  transition: opacity .6s;
}

.top-materials-card a:hover {
  opacity: 0.6;
}

.top-materials-card__image {
  position: relative;
  margin-bottom: 10px;
}

.top-materials-card__image:before {
  display: block;
  padding-top: calc((160 / 260) * 100%);
  content: '';
}

.top-materials-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-materials-card__title {
  position: relative;
  padding-right: 32px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.625;
}

.top-materials-card__title:after {
  position: absolute;
    top: 13px;
    right: 0;
    width: 8px;
    height: 8px;
        border-top: 1px solid #000;
    border-right: 1px solid #000;
        transform: translate(-75% , -50%) rotate(45deg);
    content: '';
}

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

  .top-materials-nav__item {
    display: flex;
    width: calc((100% - (10px * 1)) / 2);
  }

  .top-materials-nav__item:nth-child(4n - 2),
  .top-materials-nav__item:nth-child(4n - 1),
  .top-materials-nav__item:nth-child(4n) {
    margin-left: 0;
  }

  .top-materials-nav__item:nth-child(2n) {
    margin-left: 10px;
  }

  .top-materials-nav__item:nth-child(n + 3) {
    margin-top: 10px;
  }

  .top-materials-nav__item a {
    display: flex;
    align-items: center;
    width: 100%;
  }

}

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

  .top-materials {
    padding: 25px 0 55px;
  }

  .top-materials-nav {
    margin-bottom: 32px;
  }

  .top-materials-nav__item {
    min-height: 60px;
    font-size: 16px;
    line-height: 1.25;
  }

  .top-materials-nav__item a {
    padding: 10px 40px 10px 10px;
  }

  .top-materials-nav__item a:before {
    right: 10px;
  }

  .top-materials__group:nth-child(n + 2) {
    margin-top: 70px;
  }

  .top-materials__header {
    display: block;
    margin-bottom: 28px;
  }

  .top-materials__link {
    display: block;
    margin-right: 0;
    margin-bottom: 15px;
    padding-right: 0;
  }

  .top-materials__title span {
    margin-top: 2px;
    font-size: 24px;
  }

  .top-materials__title span:after {
    right: -28px;
  }

  .top-materials__colmun {
    width: 100%;
  }

  .top-materials__lead {
    font-size: 16px;
    line-height: 1.75;
  }

  .top-materials-card {
    width: calc((100% - (26px * 1)) / 2);
  }

  .top-materials-card:nth-child(4n - 2),
  .top-materials-card:nth-child(4n - 1),
  .top-materials-card:nth-child(4n) {
    margin-left: 0;
  }

  .top-materials-card:nth-child(2n) {
    margin-left: 26px;
  }

  .top-materials-card:nth-child(n + 3) {
    margin-top: 40px;
  }

  .top-materials-card__image {
    margin-bottom: 5px;
  }

  /*.top-materials-card__title:after {
    top: 8px;
  }*/

}

/*-------------------------------------------
発泡素材 / 不織布 / 機能素材 / サスティナブル素材
-------------------------------------------*/
.materials {
  padding: 60px 0 200px;
}

.materials__title {
  margin-bottom: 80px;
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.78;
}

.materials__title span {
  display: block;
  margin-top: 8px;
  color: #3D3D3D;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
}

.materials-cards {

}

.materials-card {
  display: flex;
}

.materials-card:nth-child(n + 2) {
  margin-top: 80px;
}

.materials-card__image {
  position: relative;
  width: min(100%, 360px);
}

.materials-card__image:before {
  display: block;
  padding-top: calc((320 / 360) * 100%);
  content: '';
}

.materials-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.materials-card__content {
  width: min(100%, 800px);
  padding: 40px;
/*background: #F8F8F8;*/
}

.materials-card__title {
  margin-bottom: 26px;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.42;
}

.materials-card__text {
  line-height: 2;
}

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

  .materials {
    padding: 18px 0 60px;
  }

  .materials__title {
    margin-bottom: 25px;
  }

  .materials__title span {
    margin-top: 2px;
    font-size: 24px;
  }

  .materials-card {
    display: block;
  }

  .materials-card:nth-child(n + 2) {
    margin-top: 40px;
  }

  .materials-card__image {
    width: 100%;
  }

  .materials-card__image:before {
    padding-top: calc((160 / 346) * 100%);
  }

  .materials-card__content {
    width: 100%;
    padding: 16px 20px 28px;
  }

  .materials-card__title {
    margin-bottom: 5px;
    font-size: 18px;
    line-height: 1.89;
  }

  .materials-card__text {
    font-size: 16px;
    line-height: 1.75;
  }

}

/*-------------------------------------------
技術
-------------------------------------------*/
.top-tech {
  padding: 60px 0 200px;
}

.top-tech__header {
  margin-bottom: 75px;
}

.top-tech__group {
  display: flex;
}

.top-tech__column:first-child {
  width: min(100%, 340px);
  margin-right: 60px;
}

.top-tech__column:nth-child(2) {
  width: min(100%, 660px);
}

.top-tech__title {
  padding-top: 6px;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.36;
}

.top-tech__lead {
  font-size: 16px;
  line-height: 2;
}

/*.top-tech-menu {
}

.top-tech-menu__list {
  display: flex;
}

.top-tech-menu__item {
  width: 110px;
}

.top-tech-menu__item:nth-child(n + 2) {
  margin-left: 35px;
}

.top-tech-menu__item a {
  transition: opacity .6s;
}

.top-tech-menu__item a:hover {
  opacity: .6;
}

.top-tech-menu__item a:after {
  display: block;
  width: 20px;
  height: 10px;
  margin: 12px auto 0;
  background: url(images/icon_down.svg) no-repeat center / contain;
  content: '';
}

.top-tech-menu__image {
  position: relative;
  margin-bottom: 5px;
  border-radius: 50%;
}

.top-tech-menu__image:before {
  display: block;
  padding-top: 100%;
  content: '';
}

.top-tech-menu__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
}

.top-tech-menu__title {
  color: #6E6E6E;
  font-weight: 500;
  text-align: center;
}*/

.top-tech-card {
  position: relative;
}

.top-tech-card:nth-child(n + 2) {
  margin-top: 70px;
}

.top-tech-card__group {
  display: flex;
  align-items: flex-start;
}

.top-tech-card__link {
  display: flex;
  width: min(100%, 660px);
  transition: opacity .6s;
}

.top-tech-card__link:hover {
  opacity: .6;
}

.top-tech-card__header {
  flex-shrink: 0;
  width: min(100%, 200px);
}

.top-tech-card__title {
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.78;
}

.top-tech-card__title span {
  display: block;
  margin-top: 8px;
  color: #3D3D3D;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
}

.top-tech-card__title span:after {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 16px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.top-tech-card__image {
  width: min(100%, 460px);
  position: relative;
  margin-top: 8px;
}

.top-tech-card__image:before {
  display: block;
  padding-top: calc((300 / 460) * 100%);
  content: '';
}

.top-tech-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-tech-card__content {
  width: min(100%, 360px);
  min-width: 300px;
  padding: 5px 0 0 40px;
}

.top-tech-card__item {
  font-size: 16px;
  line-height: 1.67;
}

.top-tech-card__item:nth-child(n + 2) {
  margin-top: 26px;
}

.top-tech-card__item a {
  text-decoration: underline;
}

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

  .top-tech {
    padding: 18px 0 55px;
  }

  .top-tech__header {
    margin-bottom: 28px;
  }

  .top-tech__group {
    display: block;
  }

  .top-tech__column:first-child {
    width: 100%;
    margin-right: 0;
    margin-bottom: 12px;
  }

  .top-tech__column:nth-child(2) {
    width: 100%;
  }

  .top-tech__title {
    padding-top: 0;
    font-size: 22px;
  }

  .top-tech__lead {
    font-size: 16px;
    line-height: 1.75;
  }

  .top-tech-card__group {
    display: block;
  }

  .top-tech-card__link {
    display: block;
    width: 100%;
    margin-bottom: 10px;
  }

  .top-tech-card__header {
    width: 100%;
    margin-bottom: 20px;
  }

  .top-tech-card__title span {
    margin-top: 2px;
    font-size: 24px;
  }

  .top-tech-card__title span:after {
    margin-left: 6px;
  }

  .top-tech-card__image {
    width: 100%;
    margin-top: 0;
  }

  .top-tech-card__content {
    width: 100%;
    padding: 0;
  }

  .top-tech-card__item {
    font-size: 16px;
    line-height: 1.75;
  }

  .top-tech-card__item:nth-child(n + 2) {
    margin-top: 6px;
  }

}

/*-------------------------------------------
切る / 貼る / 変える / 包む
-------------------------------------------*/
.tech {
  padding: 58px 0 200px;
}

.tech__header {
  margin-bottom: 62px;
}

/*.tech__circle {
  display: flex;
  align-items: center;
  position: absolute;
  top: -80px;
  left: 0;
  z-index: 5;
  width: 200px;
  height: 200px;
  border: 10px solid #fff;
  border-radius: 50%;
  background: #F0F7FD;
  transition: opacity .6s;
}*/

.tech__group {
  display: flex;
  align-items: flex-start;
}

.tech__column:first-child {
  width: min(100%, 180px);
  margin-right: 20px;
}

.tech__column:nth-child(2) {
  padding-top: 22px;
}

.tech__title {
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.78;
}

.tech__title span {
  display: block;
  margin-top: 8px;
  color: #3D3D3D;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
}

.tech__subtitle {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.42;
}

/*.tech-media-text {
  display: flex;
}

.tech-media-text__content {
  display: flex;
  align-items: center;
  width: calc(100% - 460px);
  padding: 0 70px;
  background: #F8F8F8;
}

.tech-media-text__text {
  width: 100%;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.42;
}

.tech-media-text__image {
  width: min(100%, 460px);
  position: relative;
}

.tech-media-text__image:before {
  display: block;
  padding-top: 35%;
  content: '';
}

.tech-media-text__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}*/

.tech-card {
  position: relative;
}

.tech-card:nth-child(n + 2) {
  margin-top: 80px;
}

.tech-card__group {
  display: flex;
  align-items: flex-start;
}

.tech-card__image {
  width: min(100%, 460px);
  position: relative;
}

.tech-card__image:before {
  display: block;
  padding-top: 65%;
  content: '';
}

.tech-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tech-card__content {
  width: calc(100% - 460px);
  margin-left: auto;
  padding-left: 40px;
}

.tech-card__title {
  margin-bottom: 26px;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.42;
}

.tech-card__text {
  line-height: 2;
}

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

  .tech {
    padding: 18px 0 55px;
  }

  .tech__header {
    margin-bottom: 28px;
  }

  .tech__group {
    display: block;
  }

  .tech__column:first-child {
    width: 100%;
    margin-right: 0;
    margin-bottom: 12px;
  }

  .tech__column:nth-child(2) {
    padding-top: 0;
  }

  .tech__title span {
    margin-top: 2px;
    font-size: 24px;
  }

  .tech__subtitle {
    font-size: 20px;
  }

  .tech-card:nth-child(n + 2) {
    margin-top: 70px;
  }

  .tech-card__group {
    display: block;
  }

  .tech-card__image {
    width: 100%;
    margin-bottom: 10px;
  }

  .tech-card__image:before {
    padding-top: 55%;
  }

  .tech-card__content {
    width: 100%;
    margin-left: 0;
    padding-left: 0;
  }

  .tech-card__title {
    margin-bottom: 8px;
    font-size: 20px;
  }

  .tech-card__text {
    font-size: 16px;
    line-height: 1.75;
  }

}

/*-------------------------------------------
沿革
-------------------------------------------*/
.history {
  padding: 60px 0 240px;
}

.history__group {
  display: flex;
  justify-content: space-between;
}

.history__content {
  flex-shrink: 0;
  margin-right: 60px;
}

.history__title {
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
  text-transform: uppercase;
  line-height: 1.78;
}

.history__title span {
  display: block;
  margin-top: 8px;
  color: #3D3D3D;
  font-size: 28px;
  font-weight: 400;
  line-height: 1;
}

.history__list {
  padding-top: 4px;
}

.history__item {
  display: flex;
  align-items: flex-start;
}

.history__item:nth-child(n + 2) {
  margin-top: 40px;
}

.history__ad {
  margin-right: 40px;
  color: #679ECC;
  font-size: 26px;
  font-weight: 500;
}

.history__wrapper {
  padding-top: 4px;
}

.history__container {
  display: flex;
}

.history__container:nth-child(n + 2) {
  margin-top: 45px;
}

.history__inner {
  display: flex;
  flex-shrink: 0;
  justify-content: space-between;
  position: relative;
  width: 160px;
  margin-right: 140px;
}

.history__inner:before,
.history__inner:after {
  position: absolute;
  content: '';
}

.history__inner:before {
  top: 0;
  right: -70px;
  width: 5px;
  height: calc(100% + 50px);
  background: #ddd;
}

.history__inner:after {
  top: 6px;
  right: -75px;
  z-index: 10;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #005197;
}

.history__jc {
  margin-right: 20px;
  font-size: 20px;
}

.history__month {
  font-size: 20px;
}

.history__desc {
  font-size: 18px;
}

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

  .history {
    padding: 28px 0 100px;
  }

  .history__group {
    display: block;
  }

  .history__content {
    margin-bottom: 28px;
    margin-right: 0;
  }

  .history__title span {
    margin-top: 2px;
    font-size: 24px;
  }

  .history__list {
    padding-top: 0;
  }

  .history__item {
    display: block;
  }

  .history__ad {
    margin-right: 0;
    margin-bottom: 10px;
    font-size: 24px;
  }

  .history__wrapper {
    padding-top: 0;
  }

  .history__inner {
    width: 115px;
    margin-right: 55px;
  }

  .history__inner:before {
    right: -30px;
    width: 3px;
  }

  .history__item:nth-child(n + 2) .history__inner:first-child:before {
    top: -60px;
    height: calc(100% + 100px);
  }

  .history__inner:after {
    right: -35px;
    width: 13px;
    height: 13px;
  }

  .history__jc {
    margin-right: 10px;
    font-size: 16px;
  }

  .history__month {
    font-size: 16px;
  }

  .history__desc {
    font-size: 16px;
    line-height: 1.75;
  }

}

/*-------------------------------------------
採用情報
-------------------------------------------*/
.recruit {
  padding: 60px 0 200px;
}

.recruit__title {
  margin-bottom: 45px;
  font-size: 28px;
  font-weight: 400;
}

.recruit__title span {
  display: block;
  margin-bottom: 2px;
  color: #ACACAC;
  font-size: 18px;
  font-weight: 500;
}

.new-graduate__list {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid #ddd;
}

.new-graduate__list dt,
.new-graduate__list dd {
  padding: 25px 35px;
  font-size: 16px;
  line-height: 2;
}

.new-graduate__list dt:nth-of-type(n + 2),
.new-graduate__list dd:nth-of-type(n + 2) {
  border-top: 1px solid #ddd;
}

.new-graduate__list dt {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 22%;
  background: #F4F4F4;
  font-weight: 500;
  text-align: center;
}

.new-graduate__list dd {
  width: 78%;
  word-break: break-all;
}

.new-graduate__list dd a {
  color: #000;
  text-decoration: underline;
  transition: opacity .6s;
}

.new-graduate__list dd a:hover {
  opacity: .6;
}

.our-team {
  padding-top: 100px;
}

.our-team-card {
  padding: 30px 0 20px;
  border-top: 1px solid #707070;
}

.our-team-card__name {
  margin-bottom: 20px;
  font-size: 24px;
}

.our-team-card__name span {
  margin-left: 20px;
  color: #005197;
  font-size: 18px;
  font-weight: 500;
}

.our-team-card__group {
  display: flex;
  align-items: flex-start;
}

.our-team-card__image {
  width: min(100%, 460px);
  position: relative;
}

.our-team-card__image:before {
  display: block;
  padding-top: 70%;
  content: '';
}

.our-team-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.our-team-card__content {
  width: min(100%, 660px);
  padding-left: 40px;
}

.our-team-card__text {
  line-height: 2;
}

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

  .recruit {
    padding: 22px 0 60px;
  }

  .recruit__title {
    margin-bottom: 22px;
    font-size: 24px;
  }

  .recruit__title span {
    margin-bottom: 0;
    line-height: 1.38;
  }

  .new-graduate__list {
    display: block;
    border-top: none;
    border-right: none;
    border-left: none;
  }

  .new-graduate__list dt {
    display: block;
    width: 100%;
    padding: 7px;
  }

  .new-graduate__list dd {
    width: 100%;
    padding: 25px 0;
  }

  .new-graduate__list dt:nth-of-type(n + 2),
  .new-graduate__list dd:nth-of-type(n + 2) {
    border-top: none;
  }

}

/*-------------------------------------------
よくある質問
-------------------------------------------*/
.faq {
  padding: 60px 0 200px;
}

.faq__title {
  padding: 8px 40px;
  background: #EFEFEF;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.54;
}

.faq__group {
  padding: 30px 50px 60px;
  background: #F0F7FD;
}

.faq__list {
  background: #fff;
}

.faq__list:nth-child(n + 2) {
  margin-top: 20px;
}

.faq__list dt,
.faq__list dd {
  display: flex;
}

.faq__list dd:before {
  margin-right: 20px;
  font-size: 30px;
  line-height: 1.93;
}

.faq__list dt {
  position: relative;
  padding: 20px 106px 20px 50px;
  cursor: pointer;
}

.faq__list dt span {
  flex-shrink: 0;
  color: #005197;
  font-size: 30px;
}

.faq__list dt:after {
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%) rotate(-90deg);
  width: 26px;
  height: 26px;
  background: url(../images/sub/icon_down.svg) no-repeat center / contain;
  content: '';
  transition: transform .4s;
}

.faq__list dt.is-open:after {
  transform: translateY(-50%) rotate(0deg);
}

.faq__list dt p {
  padding: 4px 0 0 20px;
  font-size: 18px;
  line-height: 2;
}

.faq__list dd {
  width: min(100%, 820px);
  margin: 0 auto;
  padding: 15px 50px;
  color: #404040;
}

.faq__list dd span {
  flex-shrink: 0;
  color: #E02A2A;
  font-size: 30px;
}

.faq__inner {
  padding: 2px 0 0 20px;
}

.faq__inner p {
  line-height: 2;
}

.faq__inner a {
  color: #404040;
  text-decoration: underline;
  transition: opacity .6s;
}

.faq__inner a:hover {
  opacity: 0.6;
}

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

  .faq {
    padding: 25px 0 60px;
  }

  .faq__title {
    padding: 8px 20px;
  }

  .faq__group {
    padding: 25px 20px 40px;
  }

  .faq__list dt {
    padding: 15px 46px 15px 20px;
  }

  .faq__list dt:after {
    right: 12px;
    width: 22px;
    height: 22px;
  }

  .faq__list dt p {
    padding: 2px 0 0 15px;
    line-height: 1.7;
  }

  .faq__list dt span {
    font-size: 22px;
  }

  .faq__list dd {
    width: 100%;
    padding: 15px 20px;
  }

  .faq__list dd span {
    font-size: 22px;
  }

  .faq__inner {
    padding: 2px 0 0 15px;
  }

}

/*-------------------------------------------
法人のお客様
-------------------------------------------*/
.dev {
  padding: 60px 0 200px;
}

.dev__header {
  display: flex;
  margin-bottom: 75px;
}

.dev__title {
  flex-shrink: 0;
  width: min(100%, 200px);
  margin-right: 100px;
  padding-top: 5px;
  font-size: 24px;
  font-weight: 400;
  line-height: 1.67;
}

.dev__lead {
  font-size: 16px;
  line-height: 2;
}

.dev-nav {
  margin-bottom: 60px;
}

.dev-nav__list {
  display: flex;
  flex-wrap: wrap;
}

.dev-nav__item {
  display: flex;
  width: calc((100% - (40px * 3)) / 4);
  height: 60px;
  background: #F8F8F8;
  font-size: 16px;
}

.dev-nav__item:nth-child(n + 2) {
  margin-left: 40px;
}

.dev-nav__item a {
  display: flex;
  align-items: center;
  position: relative;
  width: 100%;
  padding: 10px 60px 10px 30px;
  color: #000;
  transition: opacity .6s;
}

.dev-nav__item a:hover {
  opacity: 0.6;
}

.dev-nav__item a:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%) rotate(90deg);
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.dev__body {
  margin-bottom: 145px;
}

.dev-list {
}

.dev-item {
}

.dev-item:nth-child(n + 2) {
  margin-top: 140px;
}

.dev-item__group {
  display: flex;
  margin-bottom: 40px;
}

.dev-item__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: min(100%, 600px);
  padding: 36px 40px;
/*  background: #F8F8F8;*/
}

.dev-item__title {
  width: 100%;
  margin-bottom: 20px;
  padding: 8px 0;
  border-bottom: 1px solid #404040;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.67;
}

.dev-item__text {
  width: 100%;
  font-size: 16px;
  line-height: 2;
}

.dev-item__image {
  position: relative;
  width: min(100%, 560px);
  min-width: 330px;
}

.dev-item__image:before {
  display: block;
  padding-top: calc((330 / 560) * 100%);
  content: '';
}

.dev-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dev-crads {
  display: flex;
  flex-wrap: wrap;
}

.dev-crad {
  width: calc((100% - (40px * 2)) / 3);
}

.dev-crad:nth-child(3n - 1),
.dev-crad:nth-child(3n) {
  margin-left: 40px;
}

.dev-crad:nth-child(n + 4) {
  margin-top: 40px;
}

.dev-crad__image {
  position: relative;
  margin-bottom: 15px;
  border: 1px solid #EFEFEF;
}

.dev-crad__image:before {
  display: block;
  padding-top: calc((2 / 3) * 100%);
  content: '';
}

.dev-crad__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dev-crad__content {
}

.dev-crad__title {
  margin-bottom: 15px;
  font-size: 18px;
  font-weight: 500;
  line-height: 1.89;
}

.dev-crad__text {
  line-height: 2;
}

.dev__fotter {
}

.flow {
}

.flow__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 50px;
  background: #F5F5F5;
  background: url(../images/sub/bg_flow_pc.png) no-repeat center / cover;
}

.flow__column:first-child {
  display: flex;
  align-items: center;
  width: min(100%, 350px);
  padding: 20px 40px;
}

.flow__column:nth-child(2) {
  width: min(100%, 315px);
  padding: 20px;
}

.flow__title {
  font-size: 28px;
  font-weight: 500;
}

.flow-contact {
}

.flow-contact__title {
  margin-bottom: 7px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.4;
}

.flow-contact__number {
  margin-bottom: 7px;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.4;
}

.flow-contact__number:before {
  display: inline-block;
  width: 22px;
  height: 22px;
  margin-right: 10px;
  background: url(../images/sub/icon_phone.svg) no-repeat center / contain;
  vertical-align: -2px;
  content: '';
}

.flow-contact__button {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 230px;
  height: 50px;
  background: #404040;
  color: #fff;
  line-height: 1.5;
  transition: opacity .6s;
}

.flow-contact__button:hover {
  opacity: .6;
}

.flow-contact__button:after {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 6px;
  height: 10px;
  background: url(../images/sub/icon_arrow02.svg) no-repeat center / contain;
  content: '';
}

.flow__body {
}

.flow-list {
  display: flex;
  flex-wrap: wrap;
}

.flow-item {
  width: calc((100% - (40px * 2)) / 3);
}

.flow-item:nth-child(3n - 1),
.flow-item:nth-child(3n) {
  margin-left: 40px;
}

.flow-item:nth-child(n + 4) {
  margin-top: 100px;
}

.flow-item__header {
  display: flex;
  align-items: center;
  position: relative;
  height: 100px;
  margin-bottom: 20px;
  background: #EFEFEF;
}

.flow-item:nth-last-child(n + 2) .flow-item__header {
  width: calc(100% - 40px);
  padding: 20px 25px;
}

.flow-item:last-child .flow-item__header {
  width: 100%;
  padding: 20px 65px 20px 25px;
}

.flow-item:nth-last-child(n + 2) .flow-item__header:before {
  position: absolute;
  top: 0;
  right: -40px;
  width: 0;
  height: 0;
  border-top: 50px solid transparent;
  border-bottom: 50px solid transparent;
  border-left: 40px solid #EFEFEF;
  content: '';
}

.flow-item__title {
  width: 100%;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.17;
}

.flow-item__body {
}

.flow-item__image {
  position: relative;
  margin-bottom: 18px;
}

.flow-item__image:before {
  display: block;
  padding-top: calc((120 / 360) * 100%);
  content: '';
}

.flow-item__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.flow-item__content p {
  line-height: 2;
}

.flow-item__content p a {
  color: #000;
  text-decoration: underline;
  transition: opacity .6s;
}

.flow-item__content p a:hover {
  opacity: 0.6;
}

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

  .dev__title {
    margin-right: 20px;
  }

  .dev-nav__item {
    width: calc((100% - (10px * 1)) / 2);
  }

  .dev-nav__item:nth-child(n + 2) {
    margin-left: 0;
  }

  .dev-nav__item:nth-child(2n) {
    margin-left: 10px;
  }

  .dev-nav__item:nth-child(n + 3) {
    margin-top: 10px;
  }

}

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

  .dev {
    padding: 20px 0 55px;
  }

  .dev__header {
    display: block;
    margin-bottom: 30px;
  }

  .dev__title {
    width: 100%;
    margin-bottom: 15px;
    padding-top: 0;
    text-align: center;
  }

  .dev__lead {
    font-size: 16px;
    line-height: 1.75;
  }

  .dev-nav {
    margin-bottom: 40px;
  }

  .dev-nav__item {
    font-size: 16px;
    line-height: 1.25;
  }

  .dev-nav__item a {
    padding: 10px 44px 10px 10px;
  }

  .dev-nav__item a:before {
    right: 12px;
  }

  .dev-item:nth-child(n + 2) {
    margin-top: 50px;
  }

  .dev-item__group {
    flex-direction: column-reverse;
    transform: translateX(-22px);
    width: calc(100% + 44px);
    margin-bottom: 30px;
  }

  .dev-item__content {
    width: 100%;
    padding: 36px 20px;
  }

  .dev-item__title {
  }

  .dev-item__image {
    width: 100%;
  }

  .dev-crads {
    display: block;
  }

  .dev-crad {
    width: 100%;
  }

  .dev-crad:nth-child(3n - 1),
  .dev-crad:nth-child(3n) {
    margin-left: 0;
  }

  .dev-crad:nth-child(n + 2) {
    margin-top: 50px;
  }

  .dev-crad__title {
    margin-bottom: 5px;
  }

  .dev-crad__text {
    font-size: 16px;
  }

  .dev__body {
    margin-bottom: 90px;
  }

  .flow__header {
    display: block;
    width: calc(100% + 44px);
    transform: translateX(-22px);
    margin-bottom: 30px;
    background: url(../images/sub/bg_flow_sp.png) no-repeat center / cover;
  }

  .flow__column:first-child {
    display: block;
    width: 100%;
    padding: 32px 20px;
  }

  .flow__column:nth-child(2) {
    display: none;
  }

  .flow__title {
    font-size: 24px;
  }

  .flow-list {
    display: block;
  }

  .flow-item {
    width: 100%;
  }

  .flow-item:nth-child(3n - 1),
  .flow-item:nth-child(3n) {
    margin-left: 0;
  }

  .flow-item:nth-child(n + 2) {
    margin-top: 60px;
  }

  .flow-item__header {
    margin-bottom: 15px;
  }

  .flow-item__image {
    margin-bottom: 8px;
  }

  .flow-item__text {
    font-size: 16px;
  }

}

/*-------------------------------------------
最新情報
-------------------------------------------*/
.newslist {
  padding: 82px 0 200px;
}

.newslist__title {
  margin-bottom: 60px;
    padding: 8px 0;
    border-bottom: 1px solid #404040;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.55;
}

.newslist-list {
  width: min(100%, 960px);
  margin: 0 auto;
}

.newslist-item {
}

.newslist-item__group {
  display: flex;
  align-items: flex-start;
}

.newslist-item:nth-child(n + 2) {
  margin-top: 45px;
}

.newslist-item__meta {
  display: flex;
  flex-shrink: 0;
  justify-content: space-between;
  align-items: center;
}

.newslist-item__time {
  margin-right: 30px;
  color: #4c4c4c;
  font-size: 14px;
  font-weight: 500;
  line-height: 2.14;
}

.newslist-item__taxonomy {
}

.newslist-item__terms {
  min-width: 110px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.newslist-item__terms a {
  display: block;
  padding: 4px;
  border-radius: inherit;
  transition: opacity .6s;
}

.newslist-item__terms a:hover {
  opacity: 0.6;
}

.newslist-item__link {
  color: #000;
  transition: opacity .6s;
}

.newslist-item__link:hover {
  opacity: 0.6;
}

.newslist-item__title {
  padding: 3px 0 0 28px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
}

.newslist .pagenation {
  justify-content: center;
  margin-top: 100px;
}

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

  .newslist {
    padding: 30px 0 60px;
  }

  .newslist__title {
    margin-bottom: 30px;
  }

  .newslist-list {
    width: 100%;
  }

  .newslist-item__group {
    display: block;
  }

  .newslist-item__meta {
    justify-content: flex-start;
    margin-bottom: 8px;
  }

  .newslist-item__time {
    margin-right: 15px;
  }

  .newslist-item__title {
    padding: 0;
  }

  .newslist .pagenation {
    margin-top: 40px;
  }

}

/*-------------------------------------------
最新情報
-------------------------------------------*/
.newsitem {
display: block;
 width: 80%;
margin: 0 auto;
 padding: 30px 0 190px;
}

.newsitem__thumbnail {
  position: relative;
  width: 80%;
  margin: 0 auto 30px;
}

.newsitem__meta {
  display: flex;
  align-items: center;
  margin-bottom: 30px;
}

.newsitem__time {
  margin-right: 30px;
  color: #4c4c4c;
  font-size: 14px;
  font-weight: 500;
  line-height: 2.14;
}

.newsitem__taxonomy {
}

.newsitem__terms {
  min-width: 110px;
  border-radius: 9999px;
  font-size: 12px;
  font-weight: 700;
  text-align: center;
}

.newsitem__terms a {
  display: block;
  padding: 4px;
  border-radius: inherit;
  transition: opacity .6s;
}

.newsitem__terms a:hover {
  opacity: 0.6;
}

.newsitem__title {
  margin-bottom: 40px;
  font-size: 26px;
  font-weight: 400;
  line-height: 1.5;
}

.newsitem__content {
	    overflow-wrap: break-word;
}

.newsitem__content > *:last-child {
  margin-bottom: 0;
}

.newsitem__content h2 {
  margin: 55px 0 15px;
  font-size: 22px;
  font-weight: 400;
  line-height: 1.5;
}

.newsitem__content h3 {
  margin: 45px 0 15px;
  font-size: 20px;
  font-weight: 400;
  line-height: 1.5;
}

.newsitem__content h4 {
  margin: 35px 0 15px;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.5;
}

.newsitem__content ol,
.newsitem__content ul {
  margin-bottom: 20px;
}

.newsitem__content ol li,
.newsitem__content ul li {
  line-height: 1.75;
}

.newsitem__content ol li:nth-child(n + 2),
.newsitem__content ul li:nth-child(n + 2) {
  margin-top: 10px;
}

.newsitem__content ol li {
  list-style: decimal;
  list-style-position: inside;
}

.newsitem__content ul li {
  list-style: disc;
  list-style-position: inside;
}

.newsitem__content p {
  margin-bottom: 15px;
  line-height: 1.75;
}

.newsitem__content a {
  color: #1558d6;
  text-decoration: underline;
  transition: opacity .6s;
}

.newsitem__content a:hover {
  opacity: 0.6;
}

.newsitem__content img {
  width: auto;
}

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

  .newsitem {
	  width: 100%;
    padding: 30px 0 55px;
  }

  .newsitem__thumbnail {
    width: 100%;
    margin-bottom: 20px;
  }

  .newsitem__time {
    margin-right: 15px;
  }

  .newsitem__meta {
    margin-bottom: 15px;
  }

  .newsitem__title {
    margin-bottom: 25px;
    font-size: 24px;
  }

  .newsitem__content h2 {
    margin: 25px 0 10px;
    font-size: 20px;
  }

  .newsitem__content h3 {
    margin: 20px 0 10px;
    font-size: 18px;
  }

  .newsitem__content h4 {
    margin: 15px 0 10px;
    font-size: 16px;
  }

	.wp-block-group {
  display: block!important;
}

.wp-block-group > * {
  width: 100%;
}
	
}

/*-------------------------------------------
お問い合わせ
-------------------------------------------*/
.form_linktxt {
	display: inline-flex;
	width: 100%;
	font-size: 16px;
}
.form_linktxt a {
}
.form_linktxt li{
	display: block;
	padding: 10px;
	margin: 15px 80px 15px 0;
	border-bottom: solid 1px #dddddd;
}
.contact {
  padding: 50px 0 200px;
}

.contact__header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 70px;
}

.contact-en__header {
  margin-bottom: 50px;
}

.contact__content {
  /*width: min(100%, 660px);*/
}

.contact__title {
  margin-bottom: 30px;
  font-size: 32px;
  font-weight: 400;
  line-height: 1.8125;
}

.contact-en__title {
  padding: 32px 20px;
  background: #F4F4F4;
  font-size: 24px;
  font-weight: 400;
  text-align: center;
  line-height: 1.42;
}

.contact__note {
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 2;
}

.contact__lead {
  line-height: 2;
}

.contact-nav {
  padding: 6px 0 0 20px;
}

.contact-nav__list {
}

.contact-nav__item {
  width: 360px;
  background: #F8F8F8;
  font-size: 24px;
  line-height: 1.42;
}

.contact-nav__item:nth-child(n + 2) {
  margin-top: 40px;
}

.contact-nav__item a {
  display: block;
  position: relative;
  padding: 33px 60px 33px 30px;
  color: #000;
  transition: opacity .6s;
}

.contact-nav__item a:hover {
  opacity: 0.6;
}

.contact-nav__item a:before {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  content: '';
}

.contact-nav__item span {
  margin-left: 20px;
  color: #6E6E6E;
  font-size: 14px;
  font-weight: 500;
}

.contact__body {
}

.wpcf7 {
  width: 100%!important;
}

.wpcf7__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 60px;
  padding-bottom: 60px;
  border-bottom: 1px solid #ACACAC;
}

.wpcf7__list dt,
.wpcf7__list dd {
}

.wpcf7__list dt:nth-of-type(n + 2),
.wpcf7__list dd:nth-of-type(n + 2) {
  margin-top: 50px;
}

.wpcf7__list dt {
  width: 24%;
  padding-top: 20px;
  font-size: 20px;
}

.wpcf7__format {
  display: block;
  padding-top: 15px;
  color: #404040;
  font-size: 14px;
  line-height: 2.14;
}

/* 必須 */
.wpcf7__req {
  margin-left: 5px;
  color: #E02A2A;
  font-size: 14px;
  font-weight: 700;
  vertical-align: 1px;
  letter-spacing: 0.05em;
}

.wpcf7__list dd {
  width: 76%;
  padding-left: 2%;
}

.wpcf7__caption {
  position: absolute;
  top: -30px;
  left: 0;
/*  margin: -32px 0 2px;*/
  color: #6E6E6E;
  line-height: 2;
}

.wpcf7__columns {
  display: flex;
  justify-content: space-between;
/*  align-items: flex-end;*/
}

.wpcf7__column {
  position: relative;
  width: 48%;
}

.wpcf7__row {
  position: relative;
}

.wpcf7__row:nth-child(n + 2) {
  margin-top: 60px;
}

.wpcf7-form-control-wrap {
  display: block;
}

/* ファイル */
.wpcf7-files {
  padding-top: 22px;
}

.wpcf7-file {
  width: min(100%, 540px);
}

.wpcf7-file:nth-child(n + 2) {
  margin-top: 20px;
}

.wpcf7-file__group {
  display: flex;
  align-items: center;
  padding-right: 20px;
  border: 1px solid #CED4DA;
  background: #fff;
}

.wpcf7-file__label {
  display: flex;
  align-items: center;
  height: 100%;
  margin-right: 30px;
  padding: 6px 18px;
  border-right: 1px solid #CED4DA;
  background: #F8F8F8;
  color: #343A40;
  cursor: pointer;
}

.wpcf7-file__select {
  color: #797979;
}

.wpcf7-file__delete {
  display: none;
  padding-left: 20px;
  cursor: pointer;
}

.wpcf7 input[type="file"] {
  display: none!important;
}

/* 入力欄 / テキストエリア / ドロップダウンメニュー */
.wpcf7 input[type="text"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="email"],
.wpcf7 textarea,
.wpcf7 select {
  padding: 20px;
  border: 1px solid #DDDDDD;
  background: #F8F8F8;
  outline: none;
}

.wpcf7 input[type="text"],
.wpcf7 input[type="tel"]:not(.zip),
.wpcf7 input[type="email"],
.wpcf7 textarea,
.wpcf7 select {
  width: 100%;
}

.wpcf7 input[type="tel"].zip {
  width: min(100%, 160px);
}

/* ドロップダウンメニュー */
.wpcf7__select {
  position: relative;
  width: min(100%, 360px);
}

.wpcf7__select:before {
  position: absolute;
  top: 50%;
  right: 12px;
  z-index: 10;
  transform: translateY(-50%);
  width: 10px;
  height: 6px;
  background: url(../images/sub/icon_select.svg) no-repeat center / contain;
  pointer-events: none;
  content: '';
}

.wpcf7 select {
  color: #404040;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* チェックボックス / ラジオボタン */
.wpcf7-radio {
  display: block;
  padding: 22px 0;
}

.wpcf7-checkbox .wpcf7-list-item,
.wpcf7-radio .wpcf7-list-item {
  margin: 0;
}

.wpcf7-radio .wpcf7-list-item:nth-child(n + 2) {
  margin-left: 38px;
}

.wpcf7-checkbox .wpcf7-list-item label,
.wpcf7-radio .wpcf7-list-item label {
  cursor: pointer;
}

.wpcf7 input[type="checkbox"],
.wpcf7 input[type="radio"] {
  position: relative;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* チェックボックス */
.wpcf7 input[type="checkbox"] {
  width: 24px;
  height: 24px;
  margin-right: 12px;
  border: 1px solid #707070;
  background: #fff;
  vertical-align: -4px;
}

.wpcf7 input[type="checkbox"]:checked {
}

.wpcf7 input[type="checkbox"]:checked:before {
  position: absolute;
  top: 1px;
  left: 7px;
  transform: rotate(50deg);
  width: 8px;
  height: 16px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  content: '';
}

/* ラジオボタン */
.wpcf7 input[type="radio"] {
  width: 20px;
  height: 20px;
  margin-right: 10px;
  border: 2px solid #6E6E6E;
  border-radius: 50%;
  background: #fff;
  vertical-align: -4px;
}

.wpcf7 input[type="radio"]:checked {
}

.wpcf7 input[type="radio"]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #6E6E6E;
  content: '';
}

/* プレースホルダー */
.wpcf7 input[type="text"]::placeholder,
.wpcf7 input[type="tel"]::placeholder,
.wpcf7 input[type="email"]::placeholder,
.wpcf7 textarea::placeholder {
  color: #ACACAC;
}

.wpcf7 input[type="text"]::-ms-input-placeholder,
.wpcf7 input[type="tel"]::-ms-input-placeholder,
.wpcf7 input[type="email"]::-ms-input-placeholder,
.wpcf7 textarea::-ms-input-placeholder {
  color: #ACACAC;
}

.wpcf7 input[type="text"]:-ms-input-placeholder,
.wpcf7 input[type="tel"]:-ms-input-placeholder,
.wpcf7 input[type="email"]:-ms-input-placeholder,
.wpcf7 textarea:-ms-input-placeholder {
  color: #ACACAC;
}

.wpcf7__text {
  font-size: 20px;
  text-align: center;
  line-height: 2;
}

.wpcf7__text a {
  color: #000;
  text-decoration: underline;
  transition: opacity .6s;
}

.wpcf7__text a:hover {
  opacity: .6;
}

.wpcf7__note {
  margin-bottom: 16px;
  font-size: 16px;
  text-align: center;
  line-height: 2;
}

/* 同意ボタン */
.wpcf7__acceptance {
  margin-bottom: 30px;
  font-size: 20px;
  text-align: center;
  line-height: 2.5;
}

.wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
}

.wpcf7-acceptance .wpcf7-list-item label {
  cursor: pointer;
}

/* 送信ボタン */
.wpcf7__button {
  position: relative;
  width: 360px;
  height: 90px;
  margin: 0 auto;
}

.wpcf7__button:before {
  position: absolute;
  top: 50%;
  right: 20px;
  z-index: 10;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  height: 8px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  pointer-events: none;
  content: '';
}

.wpcf7__button input[type="submit"] {
  width: 100%;
  height: 100%;
  background: #005197;
  color: #fff;
  font-size: 22px;
  font-weight: 600;
  transition: opacity .6s;
}

.wpcf7__button input[type="submit"]:hover {
  opacity: .6;
}

/* ajax-loader */
.wpcf7-spinner {
  display: none!important;
}

/* reCAPTCHA */
.grecaptcha-badge {
/*  visibility: hidden;*/
}

.recaptcha {
  padding-top: 30px;
}

.recaptcha__text {
  color: #000;
  font-size: 14px;
  text-align: center;
  line-height: 1.7;
}

.recaptcha__text a {
  color: #000;
  text-decoration: underline;
  transition: opacity .6s;
}

.recaptcha__text a:hover {
  opacity: .6;
}

@media screen and (max-width: 767px) {
	.form_linktxt {
	display: block;
	width: auto;
	font-size: 16px;
}
.form_linktxt a {
}
.form_linktxt li{
	display: block;
	padding: 10px;
	margin: 15px 0;
	border-bottom: solid 1px #dddddd;
}

  .contact {
    padding: 20px 0 60px;
  }

  .contact__header {
    display: block;
  }

  .contact__content {
    width: 100%;
    margin-bottom: 30px;
  }

  .contact__title {
    margin-bottom: 10px;
    font-size: 24px;
  }

  .contact__note {
    font-size: 16px;
    line-height: 1.75;
  }

  .contact__lead {
    font-size: 16px;
    line-height: 1.75;
  }

  .contact-nav {
    padding: 0;
  }

  .contact-nav__item {
    width: 100%;
    font-size: 20px;
  }

  .contact-nav__item a {
    padding: 33px 60px 33px 20px;
  }

  .contact-nav__item span {
    margin-left: 15px;
  }

  .wpcf7__list {
    display: block;
    margin-bottom: 40px;
    padding-bottom: 40px;
  }

  .wpcf7__list dt {
    width: 100%;
    margin-bottom: 5px;
    padding-top: 0;
    font-size: 16px;
  }

  .wpcf7__list dt:nth-of-type(n + 2) {
    margin-top: 30px;
  }

  .wpcf7__format {
    padding-top: 8px;
    line-height: 1.7;
  }

  .wpcf7__list dd {
    width: 100%;
    padding-left: 0;
    font-size: 16px;
  }

  .wpcf7__list dd:nth-of-type(n + 2) {
    margin-top: 0;
  }

  .wpcf7__caption {
    position: static;
  }

  .wpcf7__columns {
    display: block;
  }

  .wpcf7__column {
    width: 100%;
  }

  .wpcf7__column:nth-child(n + 2) {
    margin-top: 20px;
  }

  .wpcf7__row:nth-child(n + 2) {
    margin-top: 20px;
  }

  /* ファイル */
  .wpcf7-files {
    padding-top: 12px;
  }

  .wpcf7-file__group {
    padding-right: 10px;
  }

  .wpcf7-file__label {
    margin-right: 15px;
    padding: 18px 10px;
    font-size: 14px;
  }

  .wpcf7-file__select {
    font-size: 14px;
  }

  /* 入力欄 / テキストエリア / ドロップダウンメニュー */
  .wpcf7 input[type="text"],
  .wpcf7 input[type="tel"],
  .wpcf7 input[type="email"],
  .wpcf7 textarea,
  .wpcf7 select {
    padding: 18px;
  }

  /* ラジオボタン */
  .wpcf7-radio {
    padding: 12px 0;
  }

  .wpcf7-radio .wpcf7-list-item {
    display: block;
  }

  .wpcf7-radio .wpcf7-list-item:nth-child(n + 2) {
    margin-top: 20px;
    margin-left: 0;
  }

  /* チェックボックス */
  .wpcf7 input[type="checkbox"] {
    margin-right: 8px;
    vertical-align: -5px;
  }

  .wpcf7__text {
    margin-bottom: 5px;
    font-size: 16px;
    line-height: 1.7;
  }

  .wpcf7__note {
    font-size: 14px;
  }

  .wpcf7__acceptance {
    font-size: 16px;
  }

  /* 送信ボタン */
  .wpcf7__button {
    width: 320px;
    height: 80px;
  }

  .wpcf7__button input[type="submit"] {
    font-size: 18px;
  }

}

/*-------------------------------------------
プライバシーポリシー
-------------------------------------------*/
.privacy {
  padding: 60px 0 190px;
}

.privacy h2.heading {
  margin-bottom: 30px;
}

.privacy h3 {
  margin: 50px 0 40px;

    padding: 8px 0;
    border-bottom: 1px solid #404040;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.55;
}

.privacy .wp-block-table {
  margin: 40px auto 0;
  width: min(100%, 920px);
}

.privacy .wp-block-table td {
  padding: 14px 20px;
  border: 1px solid #ddd;
  line-height: 2;
}

.privacy .wp-block-table td:first-child {
  background: #F4F4F4;
}

.privacy ol,
.privacy ul {
  padding: 0 30px;
  counter-reset: number 0;
}

.privacy ol {
  margin-top: 40px;
}

.privacy ol li {
  padding-left: 48px;
  color: #005197;
  font-weight: 500;
  text-indent: -48px;
  line-height: 2;
}

.privacy ol li:nth-child(n + 2) {
  margin-top: 10px;
}

.privacy ol li:before {
  margin-right: 30px;
  font-size: 20px;
  font-weight: 700;
  counter-increment: number 1;
  content: counter(number) '.';
}

.privacy ul {
 margin-top: 40px;
}

.privacy ul li {
  padding-left: 51px;
  text-indent: -51px;
  line-height: 2;
}

.privacy ul li:nth-child(n + 2) {
  margin-top: 10px;
}

.privacy ul li:before {
  margin-right: 10px;
  counter-increment: number 1;
  content: '（' counter(number) '）';
}

.privacy p:first-of-type {
  font-size: 16px;
  line-height: 2;
}

.privacy p:nth-of-type(n + 2) {
  margin-top: 30px;
  padding: 0 30px;
  line-height: 2;
}

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

  .privacy {
    padding: 30px 0 55px;
  }

  .privacy h2.heading {
    margin-bottom: 20px;
  }

  .privacy h3 {
    margin: 40px 0 20px;
  }

  .privacy ol,
  .privacy ul {
    margin-top: 20px;
    padding: 0;
  }

  .privacy ol li {
    padding-left: 25px;
    text-indent: -25px;
    line-height: 1.75;
  }

  .privacy ol li:before {
    margin-right: 10px;
    font-size: 16px;
  }

  .privacy ul li {
    line-height: 1.75;
  }

  .privacy .wp-block-table td {
    padding: 5px 10px;
    line-height: 1.75;
  }

  .privacy p:nth-of-type(n + 2) {
    margin-top: 20px;
    padding: 0;
    line-height: 1.75;
  }

}

/*-------------------------------------------
サイトマップ
-------------------------------------------*/
.sitemap {
  padding: 30px 0 190px;
}

.sitemap__container {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.sitemap__side {
  flex-shrink: 0;
}

.sitemap__main {
  display: flex;
  flex-wrap: wrap;
  padding-left: 20px;
}

.sitemap__main > .sitemap__list {
  width: calc(100% / 3);
}

.sitemap__main > .sitemap__list:nth-child(3n - 1),
.sitemap__main > .sitemap__list:nth-child(3n) {
  padding-left: 20px;
}

.sitemap__list:nth-child(n + 4) {
  margin-top: 80px;
}

.sitemap__item {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.89;
}

.sitemap__item a {
  text-decoration: underline;
  transition: opacity .6s;
}

.sitemap__item a:hover {
  opacity: 0.6;
}

.sitemap__child {
  margin-top: 10px;
}

.sitemap__child li {
  font-size: 16px;
  font-weight: 400;
  line-height: 2.5;
}

.sitemap__child li a {
  color: #404040;
}

.sitemap-extra {
  margin-top: 50px;
}

.sitemap-extra__item {
  font-weight: 500;
  line-height: 2.125;
}

.sitemap-extra__item:nth-child(n + 2) {
  margin-top: 20px;
}

.sitemap-extra__item a {
  text-decoration: underline;
  transition: opacity .6s;
}

.sitemap-extra__item a:hover {
  opacity: 0.6;
}

.sitemap-online {
  margin-top: 50px;
}

.sitemap-online__label {
  margin-bottom: 15px;
  font-size: 16px;
  font-weight: 500;
  line-height: 2.125;
}

.sitemap-online__item {
  line-height: 2;
}

.sitemap-online__item:nth-child(n + 2) {
  margin-top: 15px;
}

.sitemap-online__item a {
  color: #404040;
  text-decoration: underline;
  transition: opacity .6s;
}

.sitemap-online__item a:hover {
  opacity: 0.6;
}

.sitemap-online__item a:before {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 10px;
  background: url(../images/common/icon-arrow-gray.svg) no-repeat center / contain;
  vertical-align: -6px;
  content: '';
}

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

  .sitemap {
    padding: 30px 0 55px;
  }

  .sitemap__container {
    display: block;
  }

  .sitemap__main {
    padding-left: 0;
  }

  .sitemap__main > .sitemap__list {
    width: 100%;
  }

  .sitemap__side {
    margin-bottom: 35px;
  }

  .sitemap-extra {
    margin-top: 30px;
  }

  .sitemap-extra__item:nth-child(n + 2) {
    margin-top: 12px;
  }

  .sitemap-online {
    margin-top: 30px;
  }

  .sitemap-online__label {
    margin-bottom: 5px;
  }

  .sitemap-online__item:nth-child(n + 2) {
    margin-top: 12px;
  }

  .sitemap__main > .sitemap__list:nth-child(3n - 1),
  .sitemap__main > .sitemap__list:nth-child(3n) {
    padding-left: 0;
  }

  .sitemap__list:nth-child(n + 2) {
    margin-top: 30px;
  }

}

.page-template-page-company .page-header,
.page-template-page-company .breadcrumb {
  display: none;
}

.page-template-page-company .about-recruit {
  padding: 70px 0 160px;
}

.page-template-page-company .page-header__title {
  margin-bottom: 40px;
}

.page-template-page-company .page-header__title span {
  margin-left: 10px;
}

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


  .page-template-page-company .about-recruit {
    padding: 50px 0 120px;
  }

  .page-template-page-company .page-header__title {
    margin: 60px 0 30px;
  }

  .page-template-page-company .page-header__title span {
    display: inline;
    vertical-align: 3px;
  }

}

.history--en {
	    background: #f8f8f8;
}