@charset "UTF-8";
/* breakpoint
 600px----- SP
 1024px---- tablet
 1025px over -- PC
 */

/*-------------------start edit details to table blog----------*/
.recruit-details-entry {
  padding: 80px 10px;
}
.recruit-ttl {
  margin: 0 0 60px 0;
}
.recruit-ttl em {
  display: block;
  margin: 0 0 10px 0;
  font-size: 50px;
  font-weight: 600;
  font-family: 'Lato', sans-serif;
}
.recruit-ttl span {
  font-size: 18px;
  color: #df0623 !important;
}
.recruit-ttl-w {
  color: #fff !important;
}
.recruit-details-entry p {
  margin: 0 0 20px 0;
  font-size: 26px;
  line-height: 2em;
  letter-spacing: 1px;
}
.recruit-details-entry > ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: initial;
  width: 80%;
  margin: 0 auto;
}
.recruit-details-entry > ul > li {
  max-width: 364px;
  width: calc(50% - 10px);
  margin: 0 0 20px 0;
}
.recruit-details-entry > ul > li a {
  transition: opacity .3s ease;
}
.recruit-details-entry > ul > li a img {
  width: 100%;
}
.recruit-details-entry > div {
  max-width: 364px;
  width: 100%;
  margin: 0 auto;
}
.recruit-details-entry > div a {
  transition: opacity .3s ease;
}
.recruit-details-entry > div a img {
  width: 100%;
}
.recruit-details-btn {
  max-width: 364px;
  width: 100%;
  height: 78px;
  margin: 0 auto;
  color: #df0623 !important;
}
.recruit-details-btn a, .recruit-details-btn button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  overflow: hidden;
  position: relative;
  background: #fff;
  border: 0;
  cursor: pointer;
  color: #df0623 !important;
  font-family: 'Lato', sans-serif;
}
.recruit-details-btn a:disabled, .recruit-details-btn button:disabled {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  cursor: default;
  pointer-events: none;
}
.recruit-details-btn a:before, .recruit-details-btn button:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
  width: 100%;
  height: 100%;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transition: opacity .3s ease-out, -webkit-transform .3s ease-out;
  transition: transform .3s ease-out, opacity .3s ease-out;
  transition: transform .3s ease-out, opacity .3s ease-out, -webkit-transform .3s ease-out;
  background: #df0623 !important;
}
.recruit-details-btn a:focus, .recruit-details-btn button:focus {
  outline: none;
}
.recruit-details-btn a span, .recruit-details-btn button span {
  display: block;
  width: 100%;
  height: 100%;
  padding: 27px 0 0 27px;
  font-size: 20px;
  font-weight: 600;
  line-height: 1em;
  text-align: left;
  position: relative;
  z-index: 1;
  border: 1px solid;
  transition: color .3s ease, border-color .6s ease;
  border-color: #df0623 !important;
}
.recruit-details-btn a span:before, .recruit-details-btn button span:before {
  content: "";
  position: absolute;
  top: 38px;
  right: 38px;
  width: 26px;
  height: 1px;
  background: #df0623 !important;
  transition: background .2s ease-out, -webkit-transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
}
.recruit-details-btn a span:after, .recruit-details-btn button span:after {
  content: "";
  position: absolute;
  top: 36px;
  right: 37px;
  width: 8px;
  height: 1px;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  background: #df0623 !important;
  transition: background .2s ease-out, -webkit-transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
}
/*------------------------------end edit chin-----------------*/
/*-----------edit chin free trail page-------------*/
.scale-img2 {
  width: 60vw; /*�摜�̕�*/
  height: auto; /*�摜�̍���*/
  transition-duration: 0.5s; /*�ω��̎���*/
}
.scale-img2:hover {
  transform: scale(1.1, 1.1); /*�摜�̏k��*/
  cursor: pointer; /*�J�[�\�����|�C���^�[�ɂ���*/
}
.scale-img {
  width: initial; /*�摜�̕�*/
  height: 175px; /*�摜�̍���*/
  transition-duration: 0.5s; /*�ω��̎���*/
}
.scale-img:hover {
  transform: scale(1.1, 1.1); /*�摜�̏k��*/
  cursor: pointer; /*�J�[�\�����|�C���^�[�ɂ���*/
}
.scale-box {
  width: initial; /*�{�b�N�X�̕�*/
  height: auto; /*�{�b�N�X�̍���*/
  overflow: hidden; /*�摜�g�厞�ɂ͂ݏo���������B��*/
}
#top .about h3.scale-font {
  margin: 100px 0 20px 0;
}
/*----------------end-----------------------------*/
#business .business-header {
  max-width: 1400px;
  width: 100%;
  height: 470px;
  margin: 0 auto;
  position: relative;
  font-size: 0;
  overflow: hidden;
}
#business .business-header > img {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
}
#business .business-header > div {
  position: absolute;
  top: 50%;
  left: 155px;
  width: 470px;
  text-align: left;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
#business .business-header > div h2 {
  margin: 0 0 40px 0;
}
#business .business-header > div h2 em {
  font-size: 46px;
  font-weight: 600;
}
#business .business-header > div h2 span {
  display: block;
  margin: 20px 0 0 0;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.5em;
  color: #D62B2B !important;
}
/*business-header remake h2-> h1 --edit by chin --*/
#business .business-header > div h1 {
  margin: 0 0 40px 0;
}
#business .business-header > div h1 em {
  font-size: 46px;
  font-weight: 600;
}
#business .business-header > div h1 span {
  display: block;
  margin: 20px 0 0 0;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.5em;
  color: #D62B2B !important;
}
#business .business-header > div p {
  font-size: 18px;
  font-weight: 600;
  line-height: 2em;
}
/*----------------end-----------------------------*/
#business .business-header2 {
  max-width: 1400px;
  width: 100%;
  height: 470px;
  margin: 0 auto;
  position: relative;
  font-size: 0;
  overflow: hidden;
}
#business .business-header2 > img {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
}
#business .business-header2 > div {
  position: absolute;
  top: 50%;
  left: 155px;
  width: 900px;
  text-align: left;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
#business .business-header2 > div h2 {
  margin: 0 0 40px 0;
}
#business .business-header2 > div h2 em {
  font-size: 46px;
  font-weight: 600;
}
#business .business-header2 > div h2 span {
  display: block;
  margin: 20px 0 0 0;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.5em;
  color: #D62B2B !important;
}
/*business-header remake h2-> h1 --edit by chin --*/
#business .business-header2 > div h1 {
  margin: 0 0 40px 0;
}
#business .business-header2 > div h1 em {
  font-size: 46px;
  font-weight: 600;
}
#business .business-header2 > div h1 span {
  display: block;
  margin: 20px 0 0 0;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.5em;
  color: #D62B2B !important;
}
#business .business-header2 > div p {
  font-size: 18px;
  font-weight: 600;
  line-height: 2em;
}
p.linkText {
  display: block;
  /* color: rgb(38, 75, 105); */
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  text-align: right;
  line-height: 2.0em;
  margin-top: 2.0em;
}
p.linkText a {
  font-size: 20px;
  /* color: rgb(38, 75, 105); */
  color: #fff;
  font-weight: bold;
  position: relative;
}
p.linkText a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -1.0em;
  width: 9px;
  height: 9px;
  border: solid rgb(38, 75, 105);
  border-width: 3px 3px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
p.linkText a::after:hover {
}
/* business-header2 for SP add 20210506 */
@media screen and (max-width: 768px) { 
  #business .business-header2 {
    height: auto;
  }
  #business .business-header2 > img {
    position: static;
    width: 100%;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-header2 > div {
    position: static;
    width: 100%;
    padding: 30px 10px;
    text-align: left;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-header2 > div h1 {
    margin: 0 0 20px 0;
  }
  #business .business-header2 > div h1 em {
    font-size: 36px;
  }
  #business .business-header2 > div h1 span {
    margin: 10px 0 0 0;
    font-size: 18px;
  }
  #business .business-header2 > div p {
    font-size: 16px;
  }
}
#business .business-info {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto 60px; ページ内リンクなし
  /* margin: 0 auto; ページ内リンクあり*/
}
#business .business-info ul {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
}
#business .business-info ul li {
  padding: 60px 10px;
  color: #fff;
}
#business .business-info ul li:nth-of-type(1) {
  background: #1c354b !important;
}
#business .business-info ul li:nth-of-type(2) {
  background: #264b69 !important;
}
#business .business-info ul li:nth-of-type(3) {
  background: #2e5b7f !important;
}
#business .business-info ul li h3 {
  margin: 0 0 40px 0;
  position: relative;
}
#business .business-info ul li h3:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -15px;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 80px;
  height: 2px;
  background: #df0623 !important;
}
#business .business-info ul li h3 span {
  display: block;
  margin: 0 0 15px 0;
  font-size: 30px;
  font-weight: 600;
  font-style: italic;
  letter-spacing: 2px;
  font-family: 'Lato', sans-serif;
}
#business .business-info ul li h3 em {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.5em;
}
/*business-info h3��h2 -- edit by chin--*/
#business .business-info ul li h2 {
  margin: 0 0 40px 0;
  position: relative;
}
#business .business-info ul li h2:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -15px;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 80px;
  height: 2px;
  background: #df0623 !important;
}
#business .business-info ul li h2 span {
  display: block;
  margin: 0 0 15px 0;
  font-size: 30px;
  font-weight: 600;
  font-style: italic;
  letter-spacing: 2px;
  font-family: 'Lato', sans-serif;
}
#business .business-info ul li h2 em {
  font-size: 30px;
  font-weight: 600;
  line-height: 1.5em;
}
/*business-info h3��h2 -- edit by chin end--*/
#business .business-info ul li p {
  padding: 0 90px;
  font-size: 18px;
  line-height: 2em;
  text-align: left;
}
#business .business-info-col3 ul li {
  width: calc((100% / 3) - 1px);
}
#business .business-info-col2 ul li {
  width: calc(50% - 1px);
}
#business .business-info-col1 ul {
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
#business .business-info-col1 ul li {
  width: 100%;
}
#business .business-info-col1 ul li p {
  text-align: center;
}
#business .business-info-col1 ul li span {
  text-align: center;
  font-size: 22px;
  line-height: 30px;
}
/*business-activity edit by chin----------------*/
/*
#business .flow00 ul {
  margin: 0 auto;
  padding: 20px;
}
#business .flow00 ul li {
  padding: 30px 100px 10px;
  display: inline-flex;
  text-align: start;
  max-width: 1500px;
}

#business .flow00 ul li img {
  width: 12%;
  height: 12%
}
#business .flow00 ul li span {
  font-size: 40px;
  padding: 35px;
  position: relative;
}
#business .flow00 ul li h4 {
  font-size: 28px;
  padding: 35px;
  position: relative;
  width: 850px;
}
*/
/* #business .flow01 
   modify 20210622 */
#business .flow01 ul {
  margin: 0 auto;
  max-width: 1200px;
  width: 75%;
}
#business .flow01 ul li {
  display: inline-flex;
  text-align: start;
  margin-bottom: 40px;
  width: 100%;
}
#business .flow01 ul li div.img-box {
  width: 30%;
  display: flex;
}
#business .flow01 ul li div.img-box div.img {
  display: block;
  max-width: 100%;
}
#business .flow01 ul li div.img-box h3 {
  display: block;
  width: 45%;
  font-size: 26px;
  font-weight: 600;
  padding: 30px;
  position: relative;
  color: #123b73;
}
#business .flow01 ul li div.txt-box {
  width: 70%;
  position: relative;
}
#business .flow01 ul li div.txt-box h4 {
  font-size: 20px;
  line-height: 2em;
  padding: 35px;
  position: relative;
}
#business .flow02 ul {
  margin: auto;
  padding: 20px;
}
#business .flow02 ul li { /*  */
  padding: 30px 100px 10px;
  display: inline-flex;
  text-align: start;
  max-width: 1500px;
}
#business .flow02 ul li img { /*�摜*/
  width: 100%;
  height: 100%
}
#business .flow02 ul li span { /*����*/
  font-size: 40px;
  padding: 35px;
  position: relative;
}
#business .flow02 ul li h4 { /*�ڍא���*/
  font-size: 28px;
  padding: 35px;
  position: relative;
  width: 850px;
}
/*business .flow03 which is used local5g edited by Karen----------------*/
#business .flow03 ul {
  margin: auto;
  padding: 20px;
}
#business .flow03 ul li {
  padding: 30px 100px 10px;
  display: inline-flex;
  text-align: start;
  max-width: 1500px;
}
#business .flow03 ul li img {
  width: 45%;
  height: 45%;
  border: solid;
}
#business .flow03 ul li span {
  font-size: 25px;
  padding: 35px;
  position: relative;
  top: 0;
}
#business .flow03 ul li h3 {
  font-size: 23px;
  font-weight: bolder;
  position: relative;
  width: 850px;
}
#business .flow03 ul li h4 {
  font-size: 20px;
  padding: 35px;
  position: relative;
  width: 850px;
}
/*  modify 20210622 by harada */
#business .business-flow {
  margin: 0 auto; /* modify 100px auto */
  padding: 80px 10px;
  background: #f5f5f5;
}
#business .business-flow h2 {
  margin: 40px 0;
  padding-bottom: 30px;
}
#business .business-flow h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
  color: #123b73 !important; /* add */
}
#business .business-flow div.container {
  margin: 0 auto;
  max-width: 1200px;
  width: 75%;
}
#business .business-flow2 {
  margin: 10px auto;
  padding: 80px 10px;
  background: #FFFFFF;
}
#business .business-flow2 h2 {
  margin: 0px;
  padding-bottom: 30px;
}
#business .business-flow2 h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-flow2 h3 {
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-flow2 p {
  margin: 10px 100px 10px 100px;
  padding-bottom: 30px;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
/* business-flow for SP add 20210506 */
@media screen and (max-width: 768px) {
  #business .business-flow h2 em {
    font-size: 36px;
  }
  /*
#business .flow00 ul {
  margin: 0 auto;
  padding: 0;
  width: 95%;
  height: auto;
}
#business .flow00 ul li {
  padding: 0;
  display:inline-flex;
  text-align: start;
  max-width: 768px;
  height: auto;
}
#business .flow00 ul li img {
  width: 30%;
  height: 30%
}
#business .flow00 ul li span {
  font-size: 22px;
  padding: 15px;
  position: relative;
}
#business .flow00 ul li h4 {
  font-size: 18px;
  padding: 0;
  position:unset;
  width: auto;
}
*/
  #business .flow01 ul {
    margin: 0 auto;
    max-width: 768px;
    width: 95%;
  }
  #business .flow01 ul li {
    display: inline-flex;
    flex-direction: column;
  }
  #business .flow01 ul li div.img-box {
    width: 88%;
    margin: 0 auto;
  }
  #business .flow01 ul li div.txt-box {
    width: 90%;
    margin: 0 auto;
  }
  #business .flow01 ul li div.txt-box h4 {
    line-height: 1.8em;
    padding: 15px;
  }
}
/* business-flow2 for SP add 20210506 */
@media screen and (max-width: 768px) {
  #business .business-flow2 {
    margin-top: 60px;
    padding: 60px 10px 60px 10px;
    height: auto;
  }
  #business .business-flow2 > img {
    position: static;
    width: 100%;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-flow2 > div {
    position: static;
    width: 100%;
    padding: 10px;
    text-align: left;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-flow2 > div h2 {
    margin: 0px;
    padding-bottom: 10px;
    text-align: center;
  }
  #business .business-flow2 > div h2 em {
    font-size: 36px;
  }
  /*
  #business .business-flow2 > div h2 span {
    margin: 10px 0 0 0;
    font-size: 18px;
  }
  */
  #business .business-flow2 > div p {
    margin: 10px;
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 1.5em;
  }
}
#business .business-flow3 {
  /* margin: 10px auto;　ページ内リンクなし */
  margin: 0 auto;
  padding: 80px 10px;
  background: #f5f5f5;
  text-align: center;
}
#business .business-flow3 > div {
  position: static;
  width: 100%;
  padding: 10px;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
#business .business-flow3 > div h2 {
  margin: 0px;
  padding-bottom: 30px;
}
#business .business-flow3 > div h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-flow3 p {
  margin: 10px 100px 10px 100px;
  padding-bottom: 30px;
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-flow3 figure {
  width: 680px;
  height: 382px;
  margin-bottom: 30px;
}
#business .business-flow3 figcaption {
  font-size: 20px;
  padding: 5px 20px 20px;
}
#business .business-flow3 .news-contents-details-video {
  position: relative;
  max-width: 680px;
  width: 100%;
  margin: 40px auto 40px;
}
#business .business-flow3 .news-contents-details-video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 0;
}
/* business-flow3 for SP add 20210506 */
@media screen and (max-width: 768px) {
  #business .business-flow3 {
    margin-top: 60px;
    padding: 60px 10px 60px 10px;
    height: auto;
  }
  #business .business-flow3 > img {
    position: static;
    width: 100%;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-flow3 > div {
    position: static;
    width: 100%;
    padding: 10px;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-flow3 > div h2 {
    margin: 0px;
    padding-bottom: 10px;
  }
  #business .business-flow3 > div h2 em {
    font-size: 36px;
  }
  /*
  #business .business-flow3 > div h2 span {
    margin: 10px 0 0 0;
    font-size: 18px;
  }
  */
  #business .business-flow3 > div p {
    margin: 10px 10px 10px 10px;
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 1.5em;
  }
  #business .business-flow3 p {
    margin: 10px 10px 10px 10px;
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 1.5em;
  }
  #business .business-flow3 figure {
    width: 390px;
    height: 330px;
    padding-bottom: 10px;
  }
  #business .business-flow3 figcaption {
    font-size: 16px;
    line-height: 1.5em;
    padding: 5px 5px 10px;
  }
  #business .business-flow3 .news-contents-details-video {
    position: relative;
    max-width: 390px;
    width: 100%;
    margin: 40px auto 40px;
  }
  #business .business-flow3 .news-contents-details-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    z-index: 0;
  }
}
/* .business-flow4 --> .service by Harada */
#business .business-flow4 {
  margin: 100px auto;
  padding: 80px 10px;
  background: #f5f5f5;
}
#business .business-flow4 h2 {
  margin: 40px 0;
  padding-bottom: 30px;
}
#business .business-flow4 h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
/* business-flow4 for SP add 20210506 */
@media screen and (max-width: 768px) {
  #business .business-flow4 {
    margin-top: 60px;
    padding: 60px 10px 0 10px;
    height: auto;
  }
  #business .business-flow4 > img {
    position: static;
    width: 100%;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  /*
  #business .business-flow4 > div {
    position: static;
    width: 100%;
    padding: 10px;
    text-align: left;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  */
  #business .business-flow4 > h2 {
    margin: 0px;
    padding-bottom: 10px;
  }
  #business .business-flow4 > h2 em {
    font-size: 36px;
  }
  /*
  #business .business-flow4 >h2 span {
    margin: 10px 0 0 0;
    font-size: 18px;
  }
  */
  #business .business-flow4 > p {
    margin: 10px 10px 10px 10px;
    padding-bottom: 10px;
    font-size: 16px;
    line-height: 1.5em;
  }
}
#business .boxdesign01 {
  position: relative;
  margin: 2em;
  padding: 1em 1em 0.5em;
  border: solid 20px #264b69;
  width: auto;
  text-align: start;
}
#business .boxdesign01 .box-title02 {
  position: absolute;
  display: inline-block;
  top: -60px;
  left: 240px;
  padding: 0 25px;
  height: 55px;
  line-height: 45px;
  font-size: 34px;
  background: #264b69 !important;
  color: #ffffff;
  font-weight: bold;
  border-radius: 5px 5px 0 0;
}
#business .boxdesign01 .box-title {
  position: absolute;
  display: inline-block;
  top: -60px;
  left: -0px;
  padding: 0 25px;
  height: 55px;
  line-height: 45px;
  font-size: 34px;
  background: #264b69 !important;
  color: #ffffff;
  font-weight: bold;
  border-radius: 5px 5px 0 0;
}
#business .boxdesign01 p {
  margin: 0;
  padding: 5px 2px 30px;
  font-size: 32px;
  font-weight: bold;
  color: #264b69 !important;
}
#business .boxdesign01 span {
  font-size: 28px;
  padding: 35px;
}
#business .boxdesign01 ul {
  margin: 50px 0 10px 0;
  text-align: center;
}
#business .boxdesign01 ul li {
  padding: 0;
  display: inline-block;
  width: 450px;
  text-align: end;
}
#business .boxdesign01 ul li img {
  width: 90%;
}
#business .boxdesign01 ul li p {
  font-size: 20px;
}
@media screen and (max-width: 768px) { 
  #business .boxdesign01 {
    position: relative;
    margin: 2em;
    padding: 1em 1em 0.5em;
    border: solid 20px #264b69;
    width: auto;
    text-align: start;
  }
  #business .boxdesign01 .box-title02 {
    font-size: 20px;
    top: -60px;
    left: 0;
  }
  #business .boxdesign01 .box-title {
    font-size: 28px;
  }
  #business .boxdesign01 p {
    font-size: 24px;
  }
  #business .boxdesign01 span {
    font-size: 22px;
  }
  #business .boxdesign01 ul {
    margin: 50px 0 10px 0;
    text-align: center;
  }
  #business .boxdesign01 ul li {
    max-width: 758px;
    width: 100%;
    text-align: center;
  }
  #business .boxdesign01 ul li img {
    max-width: 758px;
    width: 100%;
    margin: 5px;
  }
  #business .boxdesign01 ul li p {
    font-size: 20px;
  }
}
#business .business-activity h2 {
  margin: 40px 0 80px 0;
  padding-bottom: 30px;
}
#business .business-activity h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-activity h2 span {
  display: block;
  margin: 12px 0 0 0;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
#business .business-activity {
  margin: 100px auto;
  padding: 80px 10px;
  background: #f5f5f5;
}
#business .business-results {
  margin: 100px auto;
  padding: 80px 10px;
  /*background: #f5f5f5;  */
}
#business .business-item3 {
  margin: 0 0 80px 0;
  color: #123b73 !important;
}
#business .business-results h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
  margin: 0 0 10px 0;
}
#business .business-results ul {
  display: flex;
  justify-content: space-around;
  align-items: stretch;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
}
#business .business-results ul li {
  width: calc(100% / 3 - 12px);
  background: #fff;
  position: relative;
}
#business .business-results ul li:before, #business .business-results ul li:after {
  content: "";
  display: block;
  position: absolute;
  width: 50px;
  height: 50px;
  border: solid;
  border-color: #123b73 !important;
}
#business .business-results ul li:before {
  top: 0;
  left: 0;
  border-width: 10px 0 0 10px;
}
#business .business-results ul li:after {
  top: 0;
  right: 0;
  border-width: 10px 10px 0 0;
}
#business .business-results ul li > div {
  width: 100%;
  height: 100%;
  padding: 40px 30px;
}
#business .business-results ul li > div:before, #business .business-results ul li > div:after {
  content: "";
  display: block;
  position: absolute;
  width: 50px;
  height: 50px;
  border: solid;
  border-color: #123b73 !important;
}
#business .business-results ul li > div:before {
  bottom: 0;
  left: 0;
  border-width: 0 0 10px 10px;
}
#business .business-results ul li > div:after {
  bottom: 0;
  right: 0;
  border-width: 0 10px 10px 0;
}
#business .business-results ul li > div figure {
  max-width: 350px; /*220px*/
  width: 100%;
  margin: 20px auto 50px;
}
#business .business-results ul li > div figure img {
  width: 90%;
}
#business .business-results ul li > div h4 {
  margin: 0 0 15px 0;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5em;
  color: #123b73 !important;
}
#business .business-results ul li > div p {
  font-size: 18px;
  line-height: 2em;
  text-align: left;
}
/* business-results for SP add 20210506 */
@media screen and (max-width: 768px) { 
  #business .business-results {
    margin-top: 60px;
    padding: 60px 10px 0 10px;
    height: auto;
  }
  /*
   #business .business-item3{
     margin: 0 0 80px 0;
     color: #123b73 !important;
   }
   */
  #business .business-results h2 em {
    font-size: 36px;
  }
  #business .business-results ul {
    display: block;
    justify-content: space-around;
    align-items: stretch;
    max-width: 768px;
    width: 100%;
    margin: 0 auto;
  }
  #business .business-results ul li {
    width: 100%;
  }
  #business .business-results ul li > div {
    width: 100%;
    height: 100%;
    padding: 20px 10px;
    margin-bottom: 40px;
  }
}
#business .business-consistent {
  margin: 100px auto;
  padding: 80px 10px;
  background: #f5f5f5;
}
#business .business-item3 {
  margin: 0 0 80px 0;
  color: #123b73 !important;
}
#business .business-consistent h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
  margin: 0 0 10px 0;
}
#business .business-quality {
  max-width: 500px;
  width: 100%;
  margin: 20px auto 50px;
  padding-bottom: 50px;
}
#business .business-quality img {
  width: 100%;
}
/* end  ----------------------------------------------------------------*/
#business .business-relation {
  max-width: 1400px;
  width: 100%;
  /* height: 800px; */
  height: auto;
  /*  margin: 20px auto; */
  margin: 0 auto;
  text-align: center;
  padding-top: 30px;
  padding-bottom: 60px; /* ADD */
}
#business .business-relation h3 {
  margin: 0 0 60px 0;
}
#business .business-relation h3 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-relation h3 span {
  display: block;
  margin: 12px 0 0 0;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*business-relation h3��h2 -------------------------------edit by chin --*/
#business .business-relation h2 {
  margin: 0 0 60px 0;
}
#business .business-relation h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-relation h2 span {
  display: block;
  margin: 12px 0 0 0;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
#business .business-relation ul {
  margin: 0 0 25px 0;
}
#business .business-relation ul li {
  padding: 0 0 30px 0;
  display: inline-block;
  vertical-align: middle;
  width: 480px;
}
#business .business-relation ul li figure {
  margin-bottom: 30px;
}
#business .business-relation ul li img {
  margin: 0 auto;
  text-align: center;
  width: 80%;
}
#business .business-relation ul li p, #business .business-relation ul li figcaption {
  display: block;
  width: 90%;
  font-size: 23px;
  text-align: center;
}
/*business-relation h3��h2 --edit by chin ----------------------end--*/
#business .business-relation .business-relation-list {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1400px;
  width: 100%;
  /* margin: 0 0 250px 0; */
  margin: 0 0 150px 0;
}
/*
-----------------------------------------------------------------------
  .business-relation-list1 : one business related product

  .business-relation-list2-1
  .business-relation-list2-2 : two business related products

  .business-relation-list3 : three business related products
------------------------------------------------------------------------
*/
#business .business-relation .business-relation-list .business-relation-list3 {
  padding: 20px;
  width: 33.3%;
  height: 120px;
  cursor: pointer;
  float: left;
}
#business .business-relation .business-relation-list .business-relation-list1 {
  padding: 20px;
  width: 33.3%;
  height: 120px;
  cursor: pointer;
  margin: auto auto auto auto;
}
#business .business-relation .business-relation-list .business-relation-list2-1 {
  padding: 20px;
  width: 33.3%;
  height: 120px;
  cursor: pointer;
  margin: auto 0 auto auto;
}
#business .business-relation .business-relation-list .business-relation-list2-2 {
  padding: 20px;
  width: 33.3%;
  height: 120px;
  cursor: pointer;
  margin: auto auto auto 0;
}
#business .business-relation .business-relation-list li > a {
  display: block;
  width: 100%;
  position: relative;
  transition: opacity .3s ease;
}
#business .business-relation .business-relation-list li > a:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 30px;
  right: 30px;
  width: 36px;
  height: 1px;
  z-index: 1;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#business .business-relation .business-relation-list li > a:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 32px;
  right: 30px;
  width: 8px;
  height: 1px;
  z-index: 1;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#business .business-relation .business-relation-list li > a figure {
  width: 100%;
  position: relative;
}
#business .business-relation .business-relation-list li > a figure img {
  width: 100%;
}
#business .business-relation .business-relation-list li > a figure figcaption {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0) translateY(-20px);
  transform: translate3d(0, -50%, 0) translateY(-20px);
  width: 100%;
  font-size: 25px;
  font-weight: 600;
  color: #000;
}
#business .business-relation .business-relation-list li > a figure figcaption:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 20px);
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
#business .business-relation .business-relation-list li > a > div {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  pointer-events: none;
  transition: opacity .3s ease;
}
#business .business-relation .business-relation-list li > a > div > div {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  width: 100%;
  padding: 0 40px;
  text-align: left;
  color: #fff;
}
#business .business-relation .business-relation-list li > a > div > div h4 {
  margin: 0 0 20px 0;
  font-size: 23px;
  font-weight: 600;
  text-align: center;
}
#business .business-relation .business-relation-list li > a > div > div p {
  max-width: 340px;
  width: 100%;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.5em;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #business .business-relation .business-relation-list li > a:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  #business .business-relation .business-relation-list li > a:hover:before {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  #business .business-relation .business-relation-list li > a:hover:after {
    -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
    transform: translate3d(10px, 0, 0) rotate(25deg);
  }
  #business .business-relation .business-relation-list li > a:hover > div {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
}
#business .business-performance h3 {
  margin: 0 0 60px 0;
}
#business .business-performance h3 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-performance h3 span {
  display: block;
  margin: 12px 0 0 0;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*business-performance h3��h2 --edit by chin --*/
#business .business-performance h2 {
  margin: 0 0 60px 0;
}
#business .business-performance h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#business .business-performance h2 span {
  display: block;
  margin: 12px 0 0 0;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*business-performance h3��h2 --edit by chin --end--*/
#business .business-performance .business-performance-list {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}
#business .business-performance .business-performance-list header {
  height: 440px;
  padding: 0;
  overflow: hidden;
  position: relative;
}
#business .business-performance .business-performance-list header > img {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
}
#business .business-performance .business-performance-list header > div {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  max-width: 100%;
  width: 100%;
  height: auto;
  padding: 0 10px;
}
#business .business-performance .business-performance-list header > div h4 {
  margin: 0 0 90px 0;
  font-size: 40px;
  font-weight: 600;
  line-height: 1.2em;
  color: #fff;
  position: relative;
}
#business .business-performance .business-performance-list header > div h4:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 15px);
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
#business .business-performance .business-performance-list header > div h3 {
  margin: 0 0 90px 0;
  font-size: 40px;
  font-weight: 600;
  line-height: 1.2em;
  color: #000000;
  position: relative;
}
#business .business-performance .business-performance-list header > div h3:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 15px);
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
#business .business-performance .business-performance-list header > div p {
  margin: 0 0 90px 0;
  font-size: 30px;
  font-weight: 600;
  line-height: 1.2em;
  color: #FFFFFF;
  position: static;
}
#business .business-performance .business-performance-list header > div .business-performance-btn {
  width: 300px;
  margin: 0 auto;
  cursor: pointer;
  position: relative;
  transition: opacity .3s ease;
  background: #df0623 !important;
  font-family: 'Lato', sans-serif;
}
#business .business-performance .business-performance-list header > div .business-performance-btn:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 23px;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  width: 24px;
  height: 24px;
  background: #b3081f;
  border-radius: 100%;
}
#business .business-performance .business-performance-list header > div .business-performance-btn span {
  display: block;
  width: 100%;
  height: 100%;
  padding: 23px 0 25px;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 5px;
  text-indent: 5px;
  color: #fff;
  position: relative;
}
#business .business-performance .business-performance-list header > div .business-performance-btn span:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 34px;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  z-index: 1;
  width: 2px;
  height: 12px;
  background: #fff;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
}
#business .business-performance .business-performance-list header > div .business-performance-btn span:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 34px;
  -webkit-transform: translate3d(0, -50%, 0) rotate(90deg);
  transform: translate3d(0, -50%, 0) rotate(90deg);
  z-index: 1;
  width: 2px;
  height: 12px;
  background: #fff;
  transition: opacity .3s ease;
}
@media screen and (min-width: 769px) {
  #business .business-relation-list {
    width: 100%;
    margin: 0 auto 250px 0;
    padding: 0 10px;
  }
  #business .business-performance .business-performance-list header > div .business-performance-btn:hover {
    opacity: .5;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  }
}
#business .business-performance .business-performance-list header > div .business-performance-btn.active span:before {
  -webkit-transform: translate3d(0, -50%, 0) rotate(90deg);
  transform: translate3d(0, -50%, 0) rotate(90deg);
}
#business .business-performance .business-performance-list header > div .business-performance-btn.active span:after {
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
}
#business .business-performance .business-performance-list article {
  display: none;
  padding: 60px 10px;
}
#business .business-performance .business-performance-list article > p {
  max-width: 800px;
  width: 100%;
  margin: 0 auto 60px;
  font-size: 20px;
  line-height: 2em;
  text-align: left;
}
#business .business-performance .business-performance-list article > img {
  max-width: 100%;
}
/*edited by miso----------------------------------------------------------------------------------*/
/*------------------------------
#business .recruit-details-entry {
  padding: 80px 10px;
}


#business .recruit-ttl {
  margin: 0 0 60px 0;

}

#business .recruit-ttl em {
  display: block;
  margin: 0 0 10px 0;
  font-size: 50px;
  font-weight: 600;
  font-family: 'Lato', sans-serif;
}

#business .recruit-ttl span {
  font-size: 18px;
  color: #df0623 !important;
}

#business .recruit-ttl-w {
  color: #fff !important;
}



#business .recruit-details-entry p {
  margin: 0 0 20px 0;
  font-size: 26px;
  line-height: 2em;
  letter-spacing: 1px;
}

#business .recruit-details-entry > ul {
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 748px;
  width: 100%;
  margin: 0 auto;
}

#business .recruit-details-entry > ul > li {
  max-width: 364px;
  width: calc(50% - 10px);
  margin: 0 0 20px 0;
}

#business .recruit-details-entry > ul > li a {
  transition: opacity .3s ease;
}

#business .recruit-details-entry > ul > li a img {
  width: 100%;
}

#business .recruit-details-entry > div {
  max-width: 364px;
  width: 100%;
  margin: 0 auto;
}

#business .recruit-details-entry > div a {
  transition: opacity .3s ease;
}

#business .recruit-details-entry > div a img {
  width: 100%;
}

#business .recruit-details-btn {
  max-width: 364px;
  width: 100%;
  height: 78px;
  margin: 0 auto;
  color: #df0623 !important;
}

#business .recruit-details-btn a,
#business .recruit-details-btn button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0;
  overflow: hidden;
  position: relative;
  background: #fff;
  border: 0;
  cursor: pointer;
  color: #df0623 !important;
  font-family: 'Lato', sans-serif;
}

#business .recruit-details-btn a:disabled,
#business .recruit-details-btn button:disabled {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  cursor: default;
  pointer-events: none;
}

#business .recruit-details-btn a:before,
#business .recruit-details-btn button:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
  width: 100%;
  height: 100%;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  transition: opacity .3s ease-out, -webkit-transform .3s ease-out;
  transition: transform .3s ease-out, opacity .3s ease-out;
  transition: transform .3s ease-out, opacity .3s ease-out, -webkit-transform .3s ease-out;
  background: #df0623 !important;
}

#business .recruit-details-btn a:focus,
#business .recruit-details-btn button:focus {
  outline: none;
}

#business .recruit-details-btn a span,
#business .recruit-details-btn button span {
  display: block;
  width: 100%;
  height: 100%;
  padding: 27px 0 0 27px;
  font-size: 20px;
  font-weight: 600;
  line-height: 1em;
  text-align: left;
  position: relative;
  z-index: 1;
  border: 1px solid;
  transition: color .3s ease, border-color .6s ease;
  border-color: #df0623 !important;
}

#business .recruit-details-btn a span:before,
#business .recruit-details-btn button span:before {
  content: "";
  position: absolute;
  top: 38px;
  right: 38px;
  width: 26px;
  height: 1px;
  background: #df0623 !important;
  transition: background .2s ease-out, -webkit-transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
}

#business .recruit-details-btn a span:after,
#business .recruit-details-btn button span:after {
  content: "";
  position: absolute;
  top: 36px;
  right: 37px;
  width: 8px;
  height: 1px;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  background: #df0623 !important;
  transition: background .2s ease-out, -webkit-transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out;
  transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
}
-------------------------------*/
@media (min-width: 769px) {
  #business .recruit-details-btn a:hover, #business .recruit-details-btn button:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  #business .recruit-details-btn a:hover:before, #business .recruit-details-btn button:hover:before {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .recruit-details-btn a:hover span, #business .recruit-details-btn button:hover span {
    color: #fff;
    border-color: #fff !important;
  }
  #business .recruit-details-btn a:hover span:before, #business .recruit-details-btn button:hover span:before {
    -webkit-transform: translate3d(5px, 0, 0);
    transform: translate3d(5px, 0, 0);
    background: #fff !important;
  }
  #business .recruit-details-btn a:hover span:after, #business .recruit-details-btn button:hover span:after {
    -webkit-transform: translate3d(5px, 0, 0) rotate(25deg);
    transform: translate3d(5px, 0, 0) rotate(25deg);
    background: #fff !important;
  }
}
/*------------------------------------------------------------------------------------------------*/
#business .product-details-btn {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 120px;
  padding: 0 10px;
}
#business .product-details-btn li a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 34px 10px;
  border: 2px solid #ddd;
  font-size: 18px;
  line-height: 1.5em;
  color: #000;
  position: relative;
  transition: opacity .3s ease;
}
#business .product-details-btn li.product-details-btn-pdf a {
  padding: 15px 10px 17px 30px;
}
#business .product-details-btn li.product-details-btn-pdf a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 30px;
  width: 16px;
  height: 20px;
  background: url(/img/common/ico_Bblank.png) top left no-repeat;
  background-size: 16px 20px;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
#business .product-details-btn.product-details-btn-col1 {
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
#business .product-details-btn.product-details-btn-col1 li {
  width: calc((100% / 3) - 15px);
}
@media screen and (max-width: 1040px) {
  #business .business-info ul li p {
    padding: 0;
  }
}
@media screen and (max-width: 1220px) {
  #business .business-relation .business-relation-list li > a > div > div h4 {
    display: none;
  }
  #business .business-relation .business-relation-list li > a > div > div p {
    max-width: 340px;
    width: 100%;
    margin: 0 auto;
    font-size: 17px;
    line-height: 1.5em;
    text-align: left;
  }
}
@media screen and (max-width: 1150px) {
  #business .business-relation .business-relation-list li > a > div > div h4 {
    display: none;
  }
  #business .business-relation .business-relation-list li > a > div > div p {
    max-width: 340px;
    width: 100%;
    margin: 0 auto;
    font-size: 13px;
    line-height: 1.5em;
    text-align: left;
  }
}
@media screen and (max-width: 900px) {
  #business .business-relation .business-relation-list li > a > div > div h4 {
    display: none;
  }
  #business .business-relation .business-relation-list li > a > div > div p {
    max-width: 340px;
    width: 100%;
    margin: 0 auto;
    font-size: 10px;
    line-height: 1.5em;
    text-align: left;
  }
}
@media screen and (max-width: 768px) { 
  #business .business-header {
    height: auto;
  }
  #business .business-header > img {
    position: static;
    width: 100%;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-header > div {
    position: static;
    width: 100%;
    padding: 60px 10px;
    text-align: left;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
  #business .business-header > div h2 {
    margin: 0 0 20px 0;
  }
  #business .business-header > div h2 em {
    font-size: 36px;
  }
  #business .business-header > div h2 span {
    margin: 10px 0 0 0;
    font-size: 18px;
  }
  #business .business-header > div p {
    font-size: 16px;
  }
  #business .business-info {
    /* margin: 0 auto 60px; ページ内リンクなし*/
    margin: 0 auto; /* ページ内リンクあり */
  }
  #business .business-info ul {
    display: block;
  }
  #business .business-info ul li {
    padding: 40px 10px;
  }
  #business .business-info ul li h3 {
    margin: 0 0 40px 0;
  }
  #business .business-info ul li h3 span {
    margin: 0 0 15px 0;
    font-size: 26px;
  }
  #business .business-info ul li h3 em {
    font-size: 26px;
  }
  #business .business-info ul li p {
    font-size: 16px;
  }
  #business .business-info-col3 ul li, #business .business-info-col2 ul li, #business .business-info-col1 ul li {
    width: 100%;
  }
  #business .business-info-col3 ul li p, #business .business-info-col2 ul li p, #business .business-info-col1 ul li p {
    text-align: left;
  }
  /* add 20210524 */
  #business .business-relation {
    max-width: 768px;
    width: 100%;
    margin: 0 5px 100px;
    text-align: center;
    height: auto;
  }
  #business .business-relation ul {
    margin: 0 0 25px 0;
  }
  #business .business-relation ul li {
    padding: 0 0 30px 0;
    display: inline-block;
    vertical-align: middle;
    width: auto;
  }
  #business .business-relation ul li img {
    width: 70%;
  }
  #business .business-relation ul li p, #business .business-relation ul li figcaption {
    font-size: 20px;
  }
  #business .business-relation h3 {
    margin: 50px 0 25px 0;
  }
  #business .business-relation h3 em {
    font-size: 36px;
  }
  #business .business-relation h3 span {
    margin: 10px 0 0 0;
    font-size: 16px;
  }
  #business .business-relation .business-relation-list {
    margin: 0 auto 50px;
    display: block;
  }
  #business .business-relation .business-relation-list .business-relation-list3 {
    width: 100%;
    font-size: 20px;
    height: auto;
    margin: 0 auto 10px;
    float: left;
  }
  #business .business-relation .business-relation-list .business-relation-list1 {
    width: 100%;
    font-size: 20px;
    height: auto;
    margin: 0 auto 10px;
    float: left;
  }
  #business .business-relation .business-relation-list .business-relation-list2-1 {
    width: 100%;
    font-size: 20px;
    height: auto;
    margin: 0 auto 10px;
    float: left;
  }
  #business .business-relation .business-relation-list .business-relation-list2-2 {
    width: 100%;
    font-size: 20px;
    height: auto;
    margin: 0 auto 10px;
    float: left;
  }
  #business .business-relation .business-relation-list li:last-of-type {
    margin: 0 auto;
  }
  #business .business-relation .business-relation-list li > a {
    padding: 0 0 30px 0;
  }
  #business .business-relation .business-relation-list li > a:before {
    bottom: 0;
    right: 0;
  }
  #business .business-relation .business-relation-list li > a:after {
    bottom: 2px;
    right: 0;
  }
  #business .business-relation .business-relation-list li > a figure figcaption {
    font-size: 26px;
  }
  #business .business-relation .business-relation-list li > a figure figcaption:before {
    top: calc(100% + 10px);
  }
  #business .business-relation .business-relation-list li > a > div {
    position: static;
    background: transparent;
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
  #business .business-relation .business-relation-list li > a > div > div {
    position: static;
    padding: 15px 0 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    color: #000;
  }
  #business .business-relation .business-relation-list li > a > div > div h4 {
    display: none;
  }
  #business .business-relation .business-relation-list li > a > div > div p {
    max-width: 100%;
    font-size: 16px;
  }
@media screen and (min-width: 769px) { 
    #business .business-relation .business-relation-list li > a:hover {
      opacity: 1;
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    }
    #business .business-relation .business-relation-list li > a:hover:before {
      -webkit-transform: translate3d(10px, 0, 0);
      transform: translate3d(10px, 0, 0);
    }
    #business .business-relation .business-relation-list li > a:hover:after {
      -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
      transform: translate3d(10px, 0, 0) rotate(25deg);
    }
    #business .business-relation .business-relation-list li > a:hover > div {
      opacity: 1;
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
      pointer-events: auto;
    }
  }
  #business .business-performance h3 {
    margin: 50px 0 40px 0;
  }
  #business .business-performance h3 em {
    font-size: 36px;
  }
  #business .business-performance h3 span {
    margin: 10px 0 0 0;
    font-size: 16px;
  }
  #business .business-performance .business-performance-list header {
    height: 100vw;
  }
  #business .business-performance .business-performance-list header > img {
    height: 100vw;
  }
  #business .business-performance .business-performance-list header > div h4 {
    margin: 0 0 50px 0;
    font-size: 26px;
  }
  #business .business-performance .business-performance-list header > div .business-performance-btn {
    max-width: 300px;
    width: calc(100% - 20px);
  }
  #business .business-performance .business-performance-list header > div .business-performance-btn:after {
    right: 14px;
  }
  #business .business-performance .business-performance-list header > div .business-performance-btn span:before {
    right: 25px;
  }
  #business .business-performance .business-performance-list header > div .business-performance-btn span:after {
    right: 25px;
  }
  #business .business-performance .business-performance-list article {
    padding: 40px 10px;
  }
  #business .business-performance .business-performance-list article > p {
    margin: 0 auto 40px;
    font-size: 16px;
  }
  /*edited by miso---------------------------------------------------------------*/
  #business .recruit-ttl {
    margin: 50px 0 40px 0;
  }
  #business .recruit-ttl em {
    font-size: 36px;
  }
  #business .recruit-ttl span {
    margin: 10px 0 0 0;
    font-size: 16px;
  }
  #business .recruit-details-entry p {
    font-size: 20px;
    line-height: 1em;
    letter-spacing: 0.5px;
  }
  /*---------------------------------------------------*/
  #business .product-details-btn {
    display: block;
    margin: 0 auto 60px;
  }
  #business .product-details-btn li.product-details-btn-pdf a {
    padding: 34px 10px 34px 55px;
  }
  #business .product-details-btn li.product-details-btn-pdf a:before {
    left: 20px;
  }
  #business .product-details-btn.product-details-btn-col1 li {
    width: 100%;
  }
}
/*-- #business .details-btn 
  modify 20210428
--*/
#business section.relation-contents {
  margin: 0 auto;
  padding: 80px 10px;
  background: #f5f5f5;
}
#business section.relation-contents div {
  margin: 0 auto;
  color: #757575 !important;
}
#business section.relation-contents h3 {
  margin-bottom: 50px;
  line-height: 1.5em;
  color: #123b73 !important;
}
#business section.relation-contents h3 em {
  font-size: 30px;
  font-weight: 600;
  font-family: 'Lato', sans-serif;
}
#business section.relation-contents .details-btn {
  max-width: 380px;
  width: 100%;
  margin: 0 auto 40px;
}
#business section.relation-contents .details-btn a, 
#business section.relation-contents .details-btn button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 20px 50px 22px;
  background: #123b73;
  border: 0;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5em;
  text-align: center;
  color: #fff;
  position: relative;
  cursor: pointer;
  transition: opacity .3s ease;
}
#business section.relation-contents .details-btn a:after, #business section.relation-contents .details-btn button:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 15px;
  border: solid #fff;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
#business section.relation-contents .details-btn a:focus, #business section.relation-contents .details-btn button:focus {
  outline: none;
}
#business section.relation-contents .details-btn a:hover, #business section.relation-contents .details-btn button:hover {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
}
#business section.relation-contents .details-btn a:disabled, #business section.relation-contents .details-btn button:disabled {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  cursor: default;
  pointer-events: none;
}


#company .company-message {
  padding: 80px 0 160px;
}
#company .company-message h3 {
  max-width: 670px;
  width: 100%;
  margin: 0 auto;
}
#company .company-message h3 img {
  width: 100%;
}
#company .company-message > div {
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
  padding: 80px 10px 0;
}
#company .company-message > div p {
  margin: 0 0 60px 0;
  font-size: 20px;
  line-height: 2em;
  text-align: left;
}
#company .company-message > div p span {
  font-size: 14px;
  color: #666;
}
#company .company-message > div p:last-of-type {
  margin: 0;
}
#company .company-philosophy {
  padding: 120px 0 160px;
}
#company .company-philosophy h3 {
  max-width: 980px;
  width: 100%;
  margin: 0 auto 120px;
  padding: 0 10px;
}
#company .company-philosophy h3 img {
  width: 100%;
}
#company .company-philosophy > div {
  padding: 60px 10px;
  background: #f6f6f6;
}
#company .company-philosophy > div > div {
  max-width: 960px;
  width: 100%;
  margin: 0 auto;
}
#company .company-philosophy > div > div > div {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  margin: 0 0 20px 0;
}
#company .company-philosophy > div > div > div:last-of-type {
  margin: 0;
}
#company .company-philosophy > div > div > div h4 {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  width: 220px;
  font-size: 20px;
  color: #fff;
  background: #0969a5 !important;
}
#company .company-philosophy > div > div > div > div {
  width: calc(100% - 220px);
  padding: 20px 0 20px 40px;
  text-align: left;
}
#company .company-philosophy > div > div > div > div p {
  font-size: 18px;
  line-height: 2em;
}
#company .company-philosophy > div > div > div > div p em {
  display: block;
  margin: 0 0 20px 0;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5em;
}
#company .company-outline {
  padding: 80px 10px 160px;
}
#company .company-maps {
  padding: 80px 10px 160px;
}
#company .company-maps ul {
  max-width: 960px;
  width: 100%;
  margin: 0 auto;
  border: #ddd solid;
  border-width: 1px 0 0 0;
}
#company .company-maps ul li {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  padding: 40px 0;
  border: #ddd solid;
  border-width: 0 0 1px 0;
}
#company .company-maps ul li > div {
  width: calc(100% - 530px);
  text-align: left;
}
#company .company-maps ul li > div h3 {
  display: inline-block;
  margin: 0 0 20px 0;
  padding: 5px 30px;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  background: #1c354b !important;
}
#company .company-maps ul li > div p {
  margin: 0 0 15px 0;
  line-height: 1.8em;
  word-break: break-all;
}
#company .company-maps ul li > div p:last-of-type {
  margin: 0;
}
#company .company-maps ul li > figure {
  width: 530px;
  height: 0;
  position: relative;
  padding: 240px 0 0 0;
}
#company .company-maps ul li > figure iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#company .company-sqc {
  padding: 80px 10px 160px;
}
#company .product-details-btn {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 40px;
  padding: 0 10px;
}
#company .product-details-btn li a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 34px 10px;
  border: 2px solid #ddd;
  font-size: 18px;
  line-height: 1.5em;
  color: #000;
  text-align: center;
  position: relative;
  transition: opacity .3s ease;
}
#company .product-details-btn li.product-details-btn-pdf a {
  padding: 15px 10px 17px 30px;
}
#company .product-details-btn li.product-details-btn-pdf a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 30px;
  width: 16px;
  height: 20px;
  background: url(/img/common/ico_pdf.png) top left no-repeat;
  background-size: 16px 20px;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
#company .product-details-btn.product-details-btn-col1 {
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
#company .product-details-btn.product-details-btn-col1 li {
  width: calc((100% / 3) - 15px);
}
@media screen and (max-width: 768px) { 
  #company .company-message {
    padding: 60px 0 120px;
  }
  #company .company-message > div {
    padding: 60px 10px 0;
  }
  #company .company-message > div p {
    margin: 0 0 40px 0;
    font-size: 16px;
  }
  #company .company-philosophy {
    padding: 60px 0 120px;
  }
  #company .company-philosophy h3 {
    margin: 0 auto 60px;
  }
  #company .company-philosophy > div > div > div {
    display: block;
    margin: 0 0 20px 0;
  }
  #company .company-philosophy > div > div > div h4 {
    display: block;
    width: 100%;
    padding: 20px 0;
    font-size: 18px;
  }
  #company .company-philosophy > div > div > div > div {
    width: 100%;
    padding: 20px 0 0 0;
  }
  #company .company-philosophy > div > div > div > div p {
    font-size: 16px;
  }
  #company .company-philosophy > div > div > div > div p em {
    margin: 0 0 10px 0;
  }
  #company .company-outline {
    padding: 60px 10px 120px;
  }
  #company .company-maps {
    padding: 60px 10px 120px;
  }
  #company .company-maps ul li {
    display: block;
    padding: 40px 0;
  }
  #company .company-maps ul li > div {
    width: 100%;
    margin: 0 0 40px 0;
  }
  #company .company-maps ul li > div h3 {
    font-size: 18px;
  }
  #company .company-maps ul li > figure {
    width: 100%;
    padding: 45.2% 0 0 0;
  }
  #company .company-sqc {
    padding: 60px 10px 120px;
  }
  #company .product-details-btn {
    display: block;
    margin: 0 auto 60px;
  }
  #company .product-details-btn li.product-details-btn-pdf a {
    padding: 34px 10px 34px 55px;
  }
  #company .product-details-btn li.product-details-btn-pdf a:before {
    left: 20px;
  }
  #company .product-details-btn.product-details-btn-col1 li {
    width: 100%;
  }
}
.details-header {
  min-height: 260px;
  background: url(/img/common/details_header.jpg) center center no-repeat;
  background-size: cover;
  position: relative;
}
.details-header h2 {
  padding: 90px 10px;
}
.details-header h2 em {
  display: block;
  margin: 0 0 12px 0;
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
.details-header h2 span {
  display: block;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*h1 add --edit by chin --*/
.details-header h1 {
  padding: 90px 10px;
}
.details-header h1 em {
  display: block;
  margin: 0 0 12px 0;
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
.details-header h1 span {
  display: block;
  font-size: 18px;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/* お問い合わせボタン */
.details-contact {
  padding: 90px 10px;
  background: #e3e3e3;
}
.details-contact > div {
  width: 510px;
  margin: 20px auto 20px;
}
.details-contact > div a {
  display: block;
  padding: 32px 40px 36px;
  background: #db1212;
  font-size: 30px;
  line-height: 1.5em;
  color: #fff;
  transition: opacity .3s ease;
  position: relative;
}
.details-contact > div a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 15px;
  height: 15px;
  border: solid #fff;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
.details-contact > p {
  font-size: 16px;
  line-height: 1.5em;
}
/*　add 20210514 
  .details-contact2 change to .function .details-contact
*/
.function .details-contact {
  padding: 10px 10px;
  background: #fff;
  /*
  padding: 90px 10px;
  background: #e3e3e3;
  */
}
.function .details-contact > div {
  width: 510px;
  margin: 20px auto 20px;
}
.function .details-contact > div a {
  background: #e3e3e3;
  color: #292929;
}
/*contact2 add --edit by chin --*/
.details-contact2 {
  padding: 10px 10px;
  background: #fff;
}
.details-contact2 > div {
  width: 510px;
  margin: 20px auto 20px;
}
.details-contact2 > div a {
  display: block;
  padding: 32px 40px 36px;
  background: #e3e3e3;
  font-size: 26px;
  line-height: 1.5em;
  color: #292929;
  transition: opacity .3s ease;
  position: relative;
}
.details-contact2 > div a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 15px;
  height: 15px;
  border: solid #fff;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
.details-contact2 > p {
  font-size: 16px;
  line-height: 1.5em;
}
/*mukushi*/
.details-contact3 {
  padding: 10px 10px;
  background: #fff; /*�O�̐F*/
}
.details-contact3 > div { /*���̈ʒu*/
  width: 510px;
  margin: 20px auto 20px;
}
.details-contact3 > div a {
  display: block;
  padding: 10px 40px; /*���̍����A��*/
  background: #988F0E; /*���̐F�Ԃ�*/
  font-size: 26px;
  line-height: 1.5em;
  color: #fff; /*�����̐F*/
  transition: opacity .3s ease;
  position: relative;
}
.details-contact3 > div a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 15px;
  height: 15px;
  border: solid #fff; /*���₢���킹�̖����̐F*/
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
.details-contact3 > p {
  font-size: 16px;
  line-height: 1.5em;
}
.details-ttl {
  padding: 0 10px;
  font-size: 46px;
  font-weight: 600;
  letter-spacing: 2px;
  text-align: center;
  position: relative;
}
.details-ttl:before {
  content: "";
  display: block;
  position: absolute;
  bottom: -30px;
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
.details-table {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 960px;
  width: 100%;
  margin: 0 auto;
  border: #ddd solid;
  border-width: 1px 0 0 0;
  text-align: left;
}
.details-table > dt {
  width: 300px;
  padding: 30px;
  background: #f6f6f6;
  border: #ddd solid;
  border-width: 0 0 1px 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 2em;
}
.details-table > dd {
  width: calc(100% - 300px);
  padding: 28px 60px;
  border: #ddd solid;
  border-width: 0 0 1px 0;
  font-size: 18px;
  line-height: 2em;
  word-break: break-all;
}
.details-table > dd p {
  margin: 0 0 20px 0;
}
.details-table > dd p:last-of-type {
  margin: 0;
}
.details-table > dd a {
  color: #000;
}
.details-table > dd span {
  font-size: 14px;
}
.details-table > dd > dl {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 18px;
  line-height: 1.8em;
}
.details-table > dd > dl dt {
  width: 18em;
}
.details-table > dd > dl dd {
  width: calc(100% - 20em);
}
.details-table > dl dd dt > figure {
  width: 50px;
}

.details-table-blank {
  display: inline-block;
  width: 200px;
  height: 36px;
  margin: 10px 0 0 0;
}
.details-table-blank a {
  display: block;
  width: 120%;
  height: 100%;
  padding: 10px 0 0 0;
  background: #999;
  font-size: 14px;
  line-height: 1em;
  text-align: center;
  color: #fff !important;
  position: relative;
  transition: opacity .3s ease;
}
.details-table-blank.application a {
  background: #d62b2b;
}
.details-table-blank.seminar a {
  background: #0969a5;
}
.details-table-blank.exhibition a {
  background: #149947;
}
.details-table-blank.products a {
  background: #264b69;
}
.details-table-blank a:before {
  content: "";
  display: block;
  position: absolute;
  top: 14px;
  right: 10px;
  width: 11px;
  height: 11px;
  background: url(/img/common/ico_blank.png) top left no-repeat;
  background-size: 11px 11px;
}
.details-table-blank.products a:before {
  content: "";
  display: block;
  position: absolute;
  top: 18px;
  right: 14px;
  width: 8px;
  height: 8px;
  background: none;
  border: solid #fff;
  border-width: 1px 1px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
.details-table-blank2 {
  display: inline-block;
  width: 200px;
  height: 36px;
  margin: 10px 0 0 0;
}
.details-table-blank2 a {
  display: block;
  width: 120%;
  height: 100%;
  padding: 10px 0 0 0;
  background: #0001E9;
  font-size: 14px;
  line-height: 1em;
  text-align: center;
  color: #fff !important;
  position: relative;
  transition: opacity .3s ease;
}
.details-table-blank2 a:before {
  content: "";
  display: block;
  position: absolute;
  top: 14px;
  right: 10px;
  width: 11px;
  height: 11px;
  background: url(/img/common/ico_blank.png) top left no-repeat;
  background-size: 11px 11px;
}
.details-table > dd > dl dd {
  width: calc(100% - 20em);
}

/* event */
.details-list li {
  padding: 0 0 0 1em;
  text-indent: -.85em;
}
.details-list li:before {
  content: "●";
}
.details-list .details-list-caution {
  font-size: 14px;
}
.details-list .details-list-caution:before {
  display: none;
}
/* company */
.details-item {
  max-width: 960px;
  width: 100%;
  margin: 0 auto 80px;
  text-align: left;
}
.details-item:last-of-type {
  margin: 0 auto;
}
.details-item .details-ttl {
  margin: 0 0 100px 0;
}
.details-item h4 {
  margin: 0 0 5px 0;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
}
.details-item > p {
  margin: 0 0 60px 0;
  font-size: 18px;
  line-height: 2em;
}
.details-item > p span {
  display: block;
  margin: 0 0 10px 0;
  font-size: 14px;
  line-height: 1.5em;
}
.details-item > p:last-of-type {
  margin: 0;
}
.details-item > div > p {
  margin: 0 0 5px 0;
  padding-left: 1em;
  text-indent: 1em;
  line-height: 2em; /* add 20210616 */
}
/*.details-item > div > p > br{
  padding-left:5em;
  text-indent:-1em;
}*/
.details-item-pinfo {
  max-width: 960px;
  width: 100%;
  margin: 0 auto 80px;
  text-align: left;
}
.details-item-pinfo:last-of-type {
  margin: 0 auto;
}
.details-item-pinfo .details-ttl {
  margin: 0 0 100px 0;
}
.details-item-pinfo h4 {
  margin: 0 0 5px 0;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
}
.details-item-pinfo > p {
  margin: 0 0 20px 0;
  font-size: 18px;
  line-height: 2em;
}
.details-item-pinfo > p span {
  display: block;
  margin: 0 0 5px 0;
  font-size: 14px;
  line-height: 1.5em;
}
.details-item-pinfo > p:last-of-type {
  margin: 0;
}
.details-item-pinfo > div > p {
  text-indent: 1em;
  padding-left: 1em;
}
.details-item-pinfo > div > p span {
  display: block;
  margin: 0 0 5px 0;
  font-size: 14px;
  line-height: 1.5em;
}
.details-person p, br {
  text-align: center;
}
/* ボタンデザイン */
.details-btn {
  max-width: 380px;
  width: 100%;
  margin: 0 auto 40px;
}
.details-btn a, .details-btn button {
  display: block;
  width: 100%;
  height: 100%;
  padding: 15px 30px 17px;
  background: #292929;
  border: 0;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5em;
  text-align: center;
  color: #fff;
  position: relative;
  cursor: pointer;
  transition: opacity .3s ease;
}
.details-btn a:after, .details-btn button:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 15px;
  border: solid #fff;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
.details-btn a:focus, .details-btn button:focus {
  outline: none;
}
.details-btn a:hover, .details-btn button:hover {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
}
.details-btn a:disabled, .details-btn button:disabled {
  opacity: .5;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  cursor: default;
  pointer-events: none;
}
@media screen and (max-width: 768px) { 
  .details-header {
    min-height: 0;
  }
  .details-header h2 {
    padding: 40px 10px;
  }
  .details-header h2 em {
    font-size: 40px;
  }
  .details-header h2 span {
    font-size: 16px;
  }
  .details-contact {
    padding: 60px 10px;
  }
  .details-contact > div {
    width: 100%;
    margin: 20px auto 20px;
  }
  .details-contact > div a {
    font-size: 22px;
  }
  .details-contact > div a:after {
    right: 15px;
  }
  /* for function Area*/
  .function .details-contact {
    padding: 60px 10px;
  }
  .function .details-contact > div {
    width: 100%;
    margin: 20px auto 20px;
  }
  .function .details-contact > div a {
    font-size: 22px;
  }
  .function .details-contact > div a:after {
    right: 15px;
  }
  .details-ttl {
    font-size: 36px;
  }
  .details-table > dt {
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    width: 6em;
    padding: 20px 15px;
    font-size: 16px;
  }
  .details-table > dd {
    width: calc(100% - 6em);
    padding: 20px 20px;
    font-size: 16px;
  }
  .details-table > dd > dl {
    display: block;
    font-size: 16px;
  }
  .details-table > dd > dl dt {
    width: 100%;
  }
  .details-table > dd > dl dd {
    width: 100%;
    margin: 0 0 15px 0;
  }
  .details-table > dd > dl dd:last-of-type {
    margin: 0;
  }
  .details-item {
    margin: 0 auto 60px;
  }
  .details-item .details-ttl {
    margin: 0 0 80px 0;
  }
  .details-item h4 {
    font-size: 18px;
  }
  .details-item > p {
    margin: 0 0 40px 0;
    font-size: 16px;
  }
}
.entry {
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
  padding: 80px 10px 160px;
}
.entry h3 {
  padding: 20px 40px 25px;
  color: #fff;
  text-align: left;
  background: #1c354b !important;
}
.entry h3 em {
  display: block;
  margin: 0 0 5px 0;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5em;
}
.entry h3 span {
  display: block;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
}
.entry h4 {
  margin: 0 0 30px 0;
  font-size: 36px;
  font-weight: 600;
  line-height: 1.5em;
  letter-spacing: 3px;
  text-indent: 3px;
}
.entry h5 {
  margin: 0 0 10px 0;
  font-size: 24px;
  font-weight: 600;
  line-height: 1.5em;
}
.entry .entry-form {
  display: block;
  width: 100%;
}
.entry .entry-form .entry-form-contents {
  margin: 80px 0 0 0;
}
.entry .entry-form .entry-form-contents > div {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  padding: 30px 0;
  border-bottom: 1px solid #ddd;
  text-align: left;
}
.entry .entry-form .entry-form-contents > div > label {
  display: block;
  width: 260px;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5em;
  position: relative;
}
.entry .entry-form .entry-form-contents > div > label span {
  display: block;
  padding: 0 20px 0 85px;
}
.entry .entry-form .entry-form-contents > div > label:before {
  content: "任意";
  display: block;
  position: absolute;
  top: 3px;
  left: 30px;
  padding: 5px 7px;
  background: #757575;
  font-size: 12px;
  font-weight: 200;
  line-height: 1em;
  color: #fff;
}
.entry .entry-form .entry-form-contents > div .entry-required:before {
  content: "必須";
  background: #0969a5 !important;
}
.entry .entry-form .entry-form-contents > div > div {
  width: calc(100% - 260px);
  padding: 0 30px 0 0;
  line-height: 1.5em;
}
.entry .entry-form .entry-form-contents > div > div > label {
  position: relative;
}
.entry .entry-form .entry-form-caution {
  padding: 50px 30px 0;
  text-align: left;
}
.entry .entry-form .entry-form-caution p {
  margin: 0 0 30px 0;
  line-height: 2em;
}
.entry .entry-form .entry-form-caution > div:first-of-type {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  margin: 0 0 100px 0;
}
.entry .entry-form .entry-form-caution > div:first-of-type .entry-caution-required {
  margin: 0 40px 0 0;
  padding: 0 0 0 50px;
  line-height: 1.5em;
  position: relative;
}
.entry .entry-form .entry-form-caution > div:first-of-type .entry-caution-required:before {
  content: "必須";
  display: block;
  position: absolute;
  top: 2px;
  left: 0;
  padding: 5px 7px;
  font-size: 12px;
  font-weight: 200;
  line-height: 1em;
  color: #fff;
  background: #0969a5 !important;
}
.entry .entry-form .entry-form-caution > div:first-of-type .entry-caution-required a {
  color: #000;
  text-decoration: underline;
}
@media screen and (min-width: 769px) {
  .entry .entry-form .entry-form-caution > div:first-of-type .entry-caution-required a:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    text-decoration: none;
  }
}
.entry .entry-form .entry-form-caution > div:first-of-type .entry-checkbox {
  margin: 0;
}
.entry .entry-form .entry-form-caution .details-btn {
  margin: 0 auto;
}
.entry .entry-form .entry-form-confirm > p {
  margin: 0 0 80px 0;
  font-size: 20px;
  line-height: 1.5em;
}
.entry .entry-form .entry-form-confirm > dl {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: start;
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 0 80px 0;
  text-align: left;
}
.entry .entry-form .entry-form-confirm > dl > dt {
  width: 260px;
  padding: 30px 20px;
  border-bottom: 1px solid #ddd;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5em;
}
.entry .entry-form .entry-form-confirm > dl > dd {
  width: calc(100% - 260px);
  padding: 30px 20px;
  border-bottom: 1px solid #ddd;
  font-size: 18px;
  line-height: 1.5em;
}
.entry .entry-form .entry-form-submit {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
.entry .entry-form .entry-form-submit .details-btn {
  margin: 0 30px 0 0;
}
.entry .entry-form .entry-form-submit .details-btn:last-of-type {
  margin: 0;
}
.entry .entry-form .entry-form-done > p {
  margin: 0 0 80px 0;
  font-size: 20px;
  line-height: 1.5em;
}
.entry .entry-form .entry-checkbox {
  display: block;
  margin: 0 0 15px 0;
  padding: 0 0 0 30px;
  line-height: 1.5em;
  text-indent: -1em;
  position: relative;
}
.entry .entry-form .entry-checkbox span {
  display: block;
  position: absolute;
  top: calc(50% + 1px);
  left: 0;
  z-index: 1;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #bbb;
  border-radius: 3px;
}
.entry .entry-form .entry-checkbox input[type=checkbox] {
  visibility: hidden;
}
.entry .entry-form .entry-checkbox input[type=checkbox]:checked ~ span {
  border-color: #0969a5;
  background: #0969a5;
}
.entry .entry-form .entry-checkbox input[type=checkbox]:checked ~ span:before {
  content: "" !important;
  display: block !important;
  position: absolute;
  top: 4px;
  left: 3px;
  z-index: 2;
  width: 13px;
  height: 11px;
  background: url(/img/common/ico_check.png) top center no-repeat;
  background-size: 13px 11px;
}
.entry .entry-form .entry-txt {
  display: block;
  width: 100%;
}
.entry .entry-form .entry-txt input {
  display: block;
  width: 100%;
  height: 50px;
  padding: 0 1em;
  font-size: 16px;
  line-height: 1em;
  background: #f5f5f5;
  border: 1px solid #000;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.entry .entry-form .entry-txt input:focus {
  background: #fff;
  border-color: #17a3d2 !important;
}
.entry .entry-form .entry-select {
  display: block;
  width: 180px;
  position: relative;
}
.entry .entry-form .entry-select:after {
  content: "";
  display: block;
  position: absolute;
  top: 22px;
  right: 20px;
  border-style: solid;
  border-width: 8px 4px 0 4px;
  border-color: #0969a5 transparent transparent transparent;
  pointer-events: none;
}
.entry .entry-form .entry-select select {
  display: block;
  width: 100%;
  height: 50px;
  padding: 0 1em;
  font-size: 16px;
  line-height: 1em;
  background: #f5f5f5;
  border: 1px solid #000;
  border-radius: 0;
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.entry .entry-form .entry-select select:focus {
  background: #fff;
  border-color: #17a3d2 !important;
}
.entry .entry-form .entry-area {
  display: block;
  width: 100%;
}
.entry .entry-form .entry-area textarea {
  display: block;
  width: 100%;
  height: 154px;
  margin: 4px 0 0 0;
  padding: .8em 1.2em;
  font-size: 16px;
  line-height: 1.5em;
  background: #f5f5f5;
  border: 1px solid #000;
  border-radius: 0;
  resize: none;
  -webkit-appearance: none;
}
.entry .entry-form .entry-area textarea:focus {
  background: #fff;
  border-color: #17a3d2 !important;
}
.entry .entry-form .entry-area textarea::-webkit-input-placeholder {
  color: #999;
}
.entry .entry-form .entry-form-contents-comment {
  display: block;
  font-size: 14px;
}
.entry .entry-form input.error, .entry .entry-form select.error, .entry .entry-form textarea.error {
  border: 2px solid #f35e5e !important;
}
.entry .entry-form input.error:focus, .entry .entry-form select.error:focus, .entry .entry-form textarea.error:focus {
  outline: 0 !important;
}
.entry .entry-form label.error {
  display: block;
  position: absolute !important;
  top: -15px !important;
  right: 15px !important;
  z-index: 2 !important;
  width: auto !important;
  height: auto !important;
  padding: 4px 8px !important;
  background: #f35e5e !important;
  font-size: 12px !important;
  text-indent: 0 !important;
  color: #fff !important;
  white-space: nowrap !important;
  pointer-events: none !important;
}
@media screen and (max-width: 768px) { 
  .entry {
    padding: 60px 10px 120px;
  }
  .entry h3 {
    padding: 10px 20px 15px;
  }
  .entry h4 {
    margin: 0 0 20px 0;
    font-size: 26px;
  }
  .entry .entry-form .entry-form-contents {
    margin: 60px 0 0 0;
  }
  .entry .entry-form .entry-form-contents > div {
    display: block;
    padding: 20px 0;
  }
  .entry .entry-form .entry-form-contents > div > label {
    width: 100%;
    margin: 0 0 20px 0;
    font-size: 16px;
  }
  .entry .entry-form .entry-form-contents > div > label span {
    padding: 0 20px 0 45px;
  }
  .entry .entry-form .entry-form-contents > div > label:before {
    left: 0;
  }
  .entry .entry-form .entry-form-contents > div > div {
    width: 100%;
    padding: 0;
  }
  .entry .entry-form .entry-form-caution {
    padding: 40px 0 0;
  }
  .entry .entry-form .entry-form-caution p {
    margin: 0 0 20px 0;
    font-size: 14px;
  }
  .entry .entry-form .entry-form-caution > div:first-of-type {
    display: block;
    margin: 0 0 40px 0;
  }
  .entry .entry-form .entry-form-caution > div:first-of-type .entry-caution-required {
    margin: 0 0 30px 0;
    padding: 0 0 0 50px;
    font-size: 14px;
  }
  .entry .entry-form .entry-form-confirm {
    margin: 60px 0 0 0;
  }
  .entry .entry-form .entry-form-confirm > p {
    margin: 0 0 60px 0;
    font-size: 16px;
  }
  .entry .entry-form .entry-form-confirm > dl {
    display: block;
    margin: 0 0 60px 0;
  }
  .entry .entry-form .entry-form-confirm > dl > dt {
    width: 100%;
    margin: 0 0 10px 0;
    padding: 20px 0 0 0;
    border-bottom: 0;
    font-size: 16px;
  }
  .entry .entry-form .entry-form-confirm > dl > dd {
    width: 100%;
    padding: 0 0 20px 0;
    border-bottom: 1px solid #ddd;
    font-size: 16px;
  }
  .entry .entry-form .entry-form-submit {
    display: block;
  }
  .entry .entry-form .entry-form-submit .details-btn {
    margin: 0 auto 20px;
  }
  .entry .entry-form .entry-form-submit .details-btn:last-of-type {
    margin: 0 auto;
  }
  .entry .entry-form .entry-form-done {
    margin: 60px 0 0 0;
  }
  .entry .entry-form .entry-form-done > p {
    margin: 0 0 60px 0;
    font-size: 16px;
  }
  .entry .entry-form .entry-checkbox {
    font-size: 14px;
  }
  .entry .entry-form .entry-select {
    width: 100%;
  }
  .entry .entry-form .entry-select select {
    font-size: 14px;
  }
  .entry .entry-form .entry-area textarea {
    font-size: 14px;
  }
  .entry .entry-form label.error {
    top: -10px !important;
    right: 10px !important;
  }
}
/*--------------edit chin 20200305--------*/
.btn-box {
  display: inline-block;
  width: 350px;
  text-align: center;
  font-size: 22px;
  color: #f2bb30;
  text-decoration: none;
  font-weight: bold;
  padding: 12px 24px;
  position: relative;
  border: 2px solid #f2bb30;
  transition: .4s;
}
.btn-box:hover {
  border: 2px solid transparent;
  color: #f2bb30;
}
.btn-box:before, .btn-box:after {
  width: 100%;
  height: 100%;
  z-index: 3;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  box-sizing: border-box;
  transform: scale(0);
  transition: .2s;
}
.btn-box:before {
  border-bottom: 2px solid #332b17;
  border-left: 2px solid #332b17;
  transform-origin: 100% 0%;
}
.btn-box:after {
  border-top: 2px solid #332b17;
  border-right: 2px solid #332b17;
  transform-origin: 0% 100%;
}
.btn-box:hover:after, .btn-box:hover:before {
  transform: scale(1);
}
.bnt-massage {
  display: inline-block;
  min-width: 130px;
  text-align: center;
  background-color: #000;
  font-size: 20px;
  color: #FFF;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 16px 10px 40px;
  position: relative;
  transition: .9s;
  border: 1px solid #FFF;
}
.bnt-massage:before {
  font-family: "FontAwesome";
  content: "\f0e0";
  position: absolute;
  left: 20px;
  top: 50%;
  margin-top: -10px;
}
.bnt-massage span {
  display: block;
  position: absolute;
  background-color: #d9385f;
  top: 0;
  left: 0;
  width: 100%;
  height: 34px;
  font-size: 14px;
  line-height: 34px;
  border-radius: 0 0 8px 0;
  z-index: -1;
  transition: .5s;
}
.bnt-massage:hover {
  border-radius: 8px 0 0;
}
.bnt-massage:hover span {
  transform: translateY(50px);
}
.btn-animation-02 {
  display: inline-block;
  width: 350px;
  text-align: center;
  background-color: #fc0808;
  border: 2px solid #fc0808;
  font-size: 22px;
  color: #fc0808;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 24px;
  border-radius: 4px;
  position: relative;
  margin: 0 0 10px;
}
.btn-animation-02 span {
  position: relative;
  z-index: 1;
}
.btn-animation-02::before, .btn-animation-02::after {
  content: "";
  display: block;
  background-color: #FFF;
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  transition: .2s;
}
.btn-animation-02::before {
  left: 0;
}
.btn-animation-02::after {
  right: 0;
}
.btn-animation-02:hover:before, .btn-animation-02:hover:after {
  width: 0;
  background-color: #FFF;
}
.btn-animation-02:hover {
  color: #FFF;
}
.container {
  text-align: left;
  padding-top: 1px;
  padding-right: 15px;
}
/*---------*/
.btn-animation-03 {
  display: inline-block;
  width: 350px;
  text-align: center;
  background-color: #f8f3d3;
  border: 2px solid #f8f3d3;
  font-size: 22px;
  color: #f8f3d3;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 24px;
  border-radius: 4px;
  position: relative;
  margin: 0 0 10px;
}
.btn-animation-03 span {
  position: relative;
  z-index: 1;
}
.btn-animation-03::before, .btn-animation-03::after {
  content: "";
  display: block;
  background-color: #E98D00;
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  transition: .2s;
}
.btn-animation-03::before {
  left: 0;
}
.btn-animation-03::after {
  right: 0;
}
.btn-animation-03:hover:before, .btn-animation-03:hover:after {
  width: 0;
  background-color: #E98D00;
}
.btn-animation-03:hover {
  color: #E98D00;
}
/*---------*/
.btn-animation-04 {
  display: inline-block;
  width: 700px;
  text-align: center;
  background-color: #ffffff;
  border: 2px solid #ffffff;
  font-size: 35px;
  color: #ffffff;
  text-decoration: none;
  font-weight: bold;
  padding: 10px 24px;
  border-radius: 4px;
  position: relative;
  margin: 0 0 10px;
}
.btn-animation-04 span {
  position: relative;
  z-index: 1;
}
.btn-animation-04::before, .btn-animation-04::after {
  content: "";
  display: block;
  background-color: #f72929;
  width: 50%;
  height: 100%;
  position: absolute;
  top: 0;
  transition: .2s;
}
.btn-animation-04::before {
  left: 0;
}
.btn-animation-04::after {
  right: 0;
}
.btn-animation-04:hover:before, .btn-animation-04:hover:after {
  width: 0;
  background-color: #f72929;
}
.btn-animation-04:hover {
  color: #f72929;
}
/* for SP add 20210512 by harada*/
@media screen and (max-width: 768px) { 
  .btn-animation-04 {
    width: 350px;
  }
}
#business .btn-animation-02 {
  width: 300px;
  font-size: 20px;
}
/*-----------------button add end -----*/
#product .product-contents {
  padding: 0 10px;
  background: #e3e3e3;
}
#product .product-contents ul {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
  padding: 80px 0;
}
#product .product-contents ul li {
  max-width: 580px;
  width: calc(50% - 10px);
  margin: 0 0 70px 0;
}
#product .product-contents ul li > a {
  display: block;
  width: 100%;
  position: relative;
  transition: opacity .3s ease;
}
#product .product-contents ul li > a:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 30px;
  right: 30px;
  width: 36px;
  height: 1px;
  z-index: 1;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#product .product-contents ul li > a:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 32px;
  right: 30px;
  width: 8px;
  height: 1px;
  z-index: 1;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#product .product-contents ul li > a h3 {
  position: absolute;
  bottom: calc(100% - 25px);
  left: 10px;
  z-index: 1;
  display: inline-block;
  max-width: calc(100% - 20px);
  padding: 5px 20px 6px;
  background: #292929;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.5em;
  text-align: left;
  color: #fff;
}
#product .product-contents ul li > a figure {
  width: 100%;
  position: relative;
}
#product .product-contents ul li > a figure img {
  width: 100%;
}
#product .product-contents ul li > a figure figcaption {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0) translateY(-20px);
  transform: translate3d(0, -50%, 0) translateY(-20px);
  width: 100%;
  font-size: 30px;
  font-weight: 600;
  color: #000;
}
#product .product-contents ul li > a figure figcaption:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 20px);
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
@media screen and (min-width: 769px) {
  #product .product-contents ul li > a:hover:before {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  #product .product-contents ul li > a:hover:after {
    -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
    transform: translate3d(10px, 0, 0) rotate(25deg);
  }
}
#product .product-contents ul li p {
  margin: 20px 0 0 0;
  font-size: 18px;
  line-height: 1.5em;
  text-align: left;
}
#product .product-details-header {
  background: #ededed;
}
#product .product-details-header h1 {
  display: none;
}
#product .product-details-header h2 {
  display: none;
}
#product .product-details-header figure {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}
#product .product-details-header figure img {
  max-width: 1400px;
  width: 100%;
}
#product .details-ttl {
  margin: 90px 0 120px;
  line-height: 1.2em;
}
#product .product-details-info {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto 80px;
}
#product .product-details-info li {
  width: calc(50% - 1px);
  padding: 60px 80px;
  color: #fff;
}
#product .product-details-info li:nth-of-type(1) {
  background: #264b69 !important;
}
#product .product-details-info li:nth-of-type(2) {
  background: #2e5b7f !important;
}
#product .product-details-info li h4 {
  margin: 0 0 40px 0;
  position: relative;
}
#product .product-details-info li h4 em {
  display: block;
  margin: 0 0 10px 0;
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 2px;
}
#product .product-details-info li h4 span {
  display: inline-block;
  font-size: 18px;
  font-style: italic;
  font-weight: 400;
  text-indent: -3px;
  position: relative;
  font-family: 'Lato', sans-serif;
}
#product .product-details-info li h4 span:before, #product .product-details-info li h4 span:after {
  content: "";
  display: block;
  position: absolute;
  top: 8px;
  width: 5px;
  height: 2px;
  background: #fff;
}
#product .product-details-info li h4 span:before {
  left: -14px;
}
#product .product-details-info li h4 span:after {
  right: -14px;
}
#product .product-details-info li p {
  font-size: 18px;
  line-height: 2em;
  text-align: left;
  word-break: break-all;
}
#product .product-details-info2 {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto 80px;
}
#product .product-details-info2 figure {
  max-width: 850px;
  width: 100%;
  margin: 0 auto;
}
#product .product-details-info2 figure img {
  max-width: 800px;
  width: 75%;
  margin: 0;
}
#product .product-details-info3 figure {
  max-width: 850px;
  width: 30%;
  margin: 0 auto;
}
#product .product-details-info2 li:nth-of-type(1) {
  background: #ffffff !important;
}
#product .product-details-info2 li:nth-of-type(2) {
  background: #ffffff !important;
}
/*--- #product .product-details-btn start---*/
#product .product-details-btn {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 120px;
  padding: 0 10px;
}
#product .product-details-btn li a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 34px 10px;
  border: 2px solid #ddd;
  font-size: 18px;
  line-height: 1.5em;
  color: #000;
  position: relative;
  transition: opacity .3s ease;
}
#product .product-details-btn li a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  width: 15px;
  height: 15px;
  border: solid #000;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
/* PDF icon */
#product .product-details-btn li.product-details-btn-pdf a {
  padding: 30px 10px 34px 60px;
  color: #000;
}
#product .product-details-btn li.product-details-btn-pdf a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 30px;
  width: 16px;
  height: 20px;
  background: url(/img/common/ico_pdf.png) top left no-repeat;
  background-size: 16px 20px;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
}
#product .product-details-btn li.product-details-btn-pdf a:after {
  display: none;
}
/*  ボタン3つ  */
#product .product-details-btn.product-details-btn-col3 {
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
#product .product-details-btn.product-details-btn-col3 li {
  width: calc((100% / 3) - 15px);
}
/* ボタン2つ  */
#product .product-details-btn.product-details-btn-col2 {
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
#product .product-details-btn.product-details-btn-col2 li {
  width: calc((100% / 3) - 15px);
  margin: 0 22px 0 0;
}
#product .product-details-btn.product-details-btn-col2 li:last-of-type {
  margin: 0;
}
/* ボタン1つ */
#product .product-details-btn.product-details-btn-col1 {
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}
#product .product-details-btn.product-details-btn-col1 li {
  width: calc((100% / 3) - 15px);
}
/* add 20210531 by harada
    for PC
   #product .button-area.button-area-col2
   #product .button-area.button-area-col4
*/
#product .button-area {
  display: flex;
  flex-direction: row;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 10px;
}
#product .button-area:last-child {
  margin: 0 auto 20px;
}
/* ボタン2つ  レイアウト */
#product .button-area.button-area-col2 {
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
}
#product .button-area.button-area-col2 div {
  width: 50%;
  margin-right: 3px;
}
#product .button-area.button-area-col2 div:last-child {
  width: 50%;
  margin-right: 0;
}
/* default のボタンデザイン を編集*/
#product .button-area.button-area-col2 .details-btn {
  max-width: 600px;
  margin-bottom: 10px;
}
#product .button-area.button-area-col2 .details-btn a {
  font-size: 22px;
}
/*  ボタン4つ  レイアウト*/
#product .button-area.button-area-col4 {
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  margin-bottom: 60px;
}
#product .button-area.button-area-col4 div {
  width: 25%;
  margin-right: 3px;
}
#product .button-area.button-area-col4 div:last-child {
  width: 25%;
  margin-right: 0;
}
/* ボタンカラー */
#product .button-area .details-btn.campaign a {
  background: #ffb31a;
  color: #fff;
}
#product .button-area .details-btn.trial a {
  background: #2dcc14;
  color: #fff;
}
/* コメントアウト　20210716
#product .button-area .details-btn.contact a {
  background: #000;
  color: #fff;
}
#product .button-area .details-btn.document a {
  background: #000;
  color: #fff;
}
#product .button-area .details-btn.leaflet a {
  background: #000;
  color: #fff;
}
#product .button-area .details-btn.price a {
  background: #000;
  color: #fff;
}
*/

#product .button-area {
  margin-bottom: 40px;
}
#product .button-area .details-btn.price {
  width: 220px;
}
#product .button-area .details-btn.price a{
  background-color: #fff;
  font-size: 22px;
  color: #0067b8 !important;
  line-height: 1.2em;
}
#product .button-area .details-btn.price a::after {
  width: 15px;
    height: 15px;
    border:solid #0067b8;
    border-width: 2px 2px 0 0;
    -webkit-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translate3d(0, -50%, 0) rotate(
45deg
);
    transform: translate3d(0, -50%, 0) rotate(45deg);
}

/* アニメーション */
/*
#product .button-area.button-area-col2 .details-btn.campaign a::before {
  content: "";
  display: block;
  width: 60px; 
  height: 200px;
  position: absolute;
  left: -30%; 
  top: -50%;
  background-image: linear-gradient(
                    left, 
                    rgba(255,255,255,0) 0%, 
                    rgba(255,255,255, .8) 50%,
                    rgba(255,255,255,0) 100%
                    );
  background-image: -webkit-gradient(linear, left bottom, right bottom, color-stop(0%,rgba(255,255,255,0)), color-stop(50%,rgba(255,255,255,.8)),color-stop(100%,rgba(255,255,255,0)));
  
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);

  animation: shine 3s infinite linear;
  -webkit-animation: shine 3s infinite linear;
}

@keyframes shine {
  0% { left: -30%; }
  50% { left: 130%; }
  100% { left: 130%; }
}

@-webkit-keyframes shine {
  0% { left: -30%; }
  50% { left: 130%; }
  100% { left: 130%; }
}
*/
/* add 20210531 by harada
    for SP
   #product .button-area
*/
@media screen and (max-width: 768px) {
  #product .button-area {
    display: flex;
    flex-direction: column;
    max-width: 768px;
  }
  #product .button-area.button-area-col2 div {
    width: 90%;
    margin: 0 auto;
  }
  #product .button-area.button-area-col2 div:last-child {
    width: 90%;
    margin: 0 auto 20px;
  }
  /* default のボタンデザイン を編集*/
  #product .button-area.button-area-col2 .details-btn {
    max-width: 768px;
    margin-bottom: 10px;
  }
  /*  ボタン4つ  レイアウト*/
  #product .button-area.button-area-col4 {
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin-bottom: 60px;
  }
  #product .button-area.button-area-col4 div {
    width: 90%;
    margin: 0 auto 5px;
  }
  #product .button-area.button-area-col4 div:last-child {
    width: 90%;
    margin: 0 auto 20px;
  }
}
/*--//end #product .product-details-btn --*/
/*---Edited by miso----------------------------------------------- */
/*new product template */
/*--about start---*/
/* new product template */
#product .about {
  width: 100%;
  max-width: 1200px; /* add harada */
  margin: 0 auto; /* add harada */
  padding: 0 10px; /* add harada */
}
#product .about div h2 {
  font-size: 30px;
  padding-bottom: 90px;
  margin-top: 20px;
}
#product .about ul > div h2 {
  font-size: 40px;
  padding: 20px;
  margin-top: -35px;
}
#product .about figure {
  margin-top: -140px;
  margin-bottom: 50px;
  margin-right: auto;
  margin-left: auto;
  width: 80vw;
  height: 25vw;
}

/*
#product .about div h3 b:before {
    content: "";
    background: #4486bb;
    display: block;
    height: 15px;
    width: 100%;
    position: relative;
    left: 0;
    bottom: -40px;
    z-index: -1;
}*/
#product .about ul > div {
  width: auto;
  margin-top: -25px;
}
#product .about div {
  max-width: 1200px;
  width: 100%;
  padding: 30px 10px 60px;
  margin: 0 auto;
  position: relative;
  display: inline-block;
  text-align: left;
}
/*#product .about div h3:after {
    content: "";
    height: 88px;
    width: 127px;
    position: absolute;
    left: 520px;
    top: 145px;
}*/
/*h1 add --edit by chin ---*/
#product .about div h1 {
  display: inline-block;
  font-size: 40px;
  margin-bottom: 40px;
  /* width: 720px; org 65% */
  text-align: left;
  border-bottom: 15px #4486bb solid;
  padding: 0 20px; /* add harada */
}
#product .about div h1.long-ttl span.smaller {
  font-size: 70%;
}

/* new product template */
#product .about div h2 {
  font-size: 30px;
  padding-bottom: 90px;
  margin-top: 20px;
}

#product .about div p {
  font-size: 20px;
  line-height: 40px;
  /* width: 720px;  commentout 2021.07.08 harada */
  text-align: left;
  text-indent: 1em; /* add harada */
}
#product .about div p span {
  font-size: 14px;
  line-height: 30px;
  /* width: 720px;  commentout 2021.07.08 harada */
  text-align: left;
  text-indent: 1em;
}
#product .about ul {
  /* display: block;
  overflow: hidden; */
  display: flex;
  flex-wrap: wrap;
  justify-content:space-between;
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 10px;
}
#product .about ul li {
  text-align: left;
  /* float: left;
  display: block; */
  width: 31%;
  margin-right: 3%;
  margin-bottom: 40px;
}
#product .about ul li a {
  color: #fff;
  display: block;
}
#product .about ul li span {
  display: block;
  padding: 40px 5px;
  color: #FFFFFF;
  font-size: 25px;
  height: 120px;
}
#product .about ul li h2 {
  font-size: 24px;
  display: block;
  padding: 40px 5px 20px;
  color: #000;
}
#product .about ul li p ,
#product .about ul li h2 p {
  font-size: 20px;
  line-height: 32px;
  text-align: left;
  padding: 0 6px;
  color: #000;
}
#product .about ul li:nth-child(4) {
  clear: both;
}
#product .about ul li:nth-child(odd) span {
  /* background: #ffba00; */
  background: #366b96;
}
#product .about ul li:nth-child(even) span {
  background: #264b69;
}
/*h2 add --edit by chin -- */
#product .about ul li:nth-child(odd) h2 span {
  /* background: #ffba00; */
  background: #366b96;
}
#product .about ul li:nth-child(even) h2 span {
  background: #264b69;
}




/* for SDGs add 20210512*/
#product #sdgs .about figure {
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}
#product #sdgs .about figure img {
  max-width: 1400px;
  width: 100%;
  margin: 30px;
}
/*-- about end ---*/

/*-- connect start--*/
#product .connect {
  width: 100%;
  height: 100%;
  color: #333;
  padding-bottom: 100px;
  background: #fff;
  /*background:linear-gradient(135deg, #b4cfe4, #699fc9, #b4cfe4); */
}
/* h2 add --edit by chin --*/
#product .connect h2 {
  margin-bottom: 60px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .connect h2 span {
  font-size: 20px;
}
#product .connect ul {
  display: block;
  overflow: hidden;
  margin: 25px 190px 20px;
  padding-left: 2em;
  text-indent: -1em;
}
#product .connect ul li {
  text-align: left;
}
#product .connect ul li p {
  font-size: 12px;
  line-height: 23px;
}
#product .connect > h3 {
  font-size: 24px;
  text-align: center;
  margin-bottom: 15px;
}
#product .connect > h3 span {
  display: unset;
  font-size: 24px;
  line-height: 32px;
  letter-spacing:normal;
  color:#000 !important;
}
#product .connect > p {
  font-size: 18px;
  max-width: 1200px;
    margin: 0 auto 40px;
    padding: 0 15px;
    width: 100%;
}
/* for SP add 20210512 */
@media (max-width: 599px) {
  #product .connect > p {
    max-width: 599px;
    text-align: left;
    margin: 0 auto 20px;
    line-height: 1.5em;
  }
}
#product .connect > h3 p {
  display: inline-block;
  font-size: 30px;
  text-align: center;
  margin-bottom: 15px;
  border-bottom: 15px #4486bb solid;
  width: 40%;
}
#product .connect > h4 + p {
  font-size: 16px;
  line-height: 32px;
  text-align: center;
  margin-bottom: 30px;
}
#product .connect > figure {
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
  margin-bottom: 100px;
}
#product .connect > figure h4 {
  font-size: 22px;
  font-weight: 600;
  display: block;
  margin-bottom: 40px;
  color: #366b96;
  text-align: left;
}
#product .connect > figure img {
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
}

#product .connect > figure p {
  font-size: 12px;
  line-height: 32px;
  text-align: initial;
  margin-bottom: 30px;
}

#product .connect div {
  max-width: 1200px; /* add harada */
  width: 100%;
  height: 100%;
  margin: 0 auto 20px;
  padding: 0 10px;
  display: inline-block;
}
#product .connect div ul li {
  display: block;
  margin: 0 16%;
}

#product .connect table {
  width: 50%;
}
#product .connect th, #product .connect td {
  font-size: 20px;
  text-align: left;
  vertical-align: middle;
  height: 61px;
}
#product .connect th {
  background: #c0d7e8;
  font-weight: 400;
  text-align: center;
  width: 30%;
}
#product .connect td {
  background: #fff;
  line-height: 30px;
  font-weight: 600;
  width: 55%;
  padding-left: 25px;
}
#product .connect table:nth-of-type(2n+1) {
  float: left;
  margin: 20px 0;
}
#product .connect table:nth-of-type(2n) {
  float: right;
  margin: 20px 0;
}
#product .connect table:nth-of-type(3) {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}
#product .connect .combined {
  display: none;
}
#product .connect table:nth-of-type(odd) th, #product .connect table:nth-of-type(odd) td {
  border: 1px solid #244864;
}
#product .connect table:nth-of-type(even) th, #product .connect table:nth-of-type(even) td {
  border: 1px solid #244864;
}
#product .connect table:nth-of-type(odd) caption {
  background-color: #244864;
  line-height: 35px;
  vertical-align: middle;
}
#product .connect table:nth-of-type(even) caption {
  background-color: #244864;
  line-height: 35px;
  vertical-align: middle;
}
#product .connect table:nth-of-type(n) caption p {
  font-size: 24px;
  color: #FFF;
}
#product .connect table:nth-of-type(odd) td {
  color: #32638a;
}
#product .connect table:nth-of-type(even) td {
  color: #32638a;
}
/*#product .connect > * {
    position: relative;
    z-index: 2;
} */
/*-- connectend --*/
/*-- connect2 start--*/
#product .connect2 {
  width: 100%;
  height: 100%;
  color: #333;
  padding-bottom: 100px;
  background: #fff;
  /*background:linear-gradient(135deg, #b4cfe4, #699fc9, #b4cfe4); */
}
/* h2 add --edit by chin --*/
#product .connect2 h2 {
  margin-bottom: 60px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .connect2 h2 span {
  font-size: 20px;
}
#product .connect2 ul {
  display: block;
  overflow: hidden;
  margin: 25px 190px 20px;
  padding-left: 2em;
  text-indent: -1em;
}
#product .connect2 ul li {
  text-align: left;
}
#product .connect2 ul li p {
  font-size: 12px;
  line-height: 23px;
}
#product .connect2 > h3 {
  font-size: 24px;
  text-align: center;
  margin-bottom: 15px;
}
#product .connect2 p {
  font-size: 20px;
  text-align: left;
  width: auto;
  margin-bottom: 30px;
  margin-top: 5px;
  margin-left: auto;
  margin-right: auto;
}
#product .connect2 > h3 p {
  display: inline-block;
  font-size: 30px;
  text-align: center;
  margin-bottom: 15px;
  border-bottom: 15px #4486bb solid;
  width: 40%;
}
#product .connect2 > h4 + p {
  font-size: 16px;
  line-height: 32px;
  text-align: center;
  margin-bottom: 30px;
}
#product .connect2 > figure img {
  max-width: 800px;
  width: 95%;
  margin: 0;
}
#product .connect2 > figure p {
  font-size: 12px;
  line-height: 32px;
  text-align: initial;
  margin-bottom: 30px;
}
#product .connect2 div {
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 20px;
  padding: 0 3em;
  display: inline-block;
}
#product .connect2 div ul li {
  display: block;
  margin: 0 16%;
}
#product .connect2 table {
  width: 100%;
}
#product .connect2 th, #product .connect2 td {
  font-size: 20px;
  text-align: left;
  vertical-align: middle;
  height: 61px;
}
#product .connect2 th {
  background: #a8c6dd;
  font-weight: 400;
  text-align: center;
  width: auto;
}
#product .connect2 td {
  background: #fff;
  line-height: 30px;
  font-weight: 600;
  width: auto;
  padding-left: 25px;
}
#product .connect2 table:nth-of-type(2n+1) {
  float: left;
  margin: 20px 0;
}
#product .connect2 table:nth-of-type(2n) {
  float: right;
  margin: 20px 0;
}
#product .connect2 table:nth-of-type(3) {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}
#product .connect2 .combined {
  display: none;
}
#product .connect2 table:nth-of-type(odd) th, #product .connect2 table:nth-of-type(odd) td {
  border: 1px solid #244864;
}
#product .connect2 table:nth-of-type(even) th, #product .connect2 table:nth-of-type(even) td {
  border: 1px solid #244864;
}
#product .connect2 table:nth-of-type(odd) caption {
  background-color: #244864;
  line-height: 35px;
  vertical-align: middle;
}
#product .connect2 table:nth-of-type(even) caption {
  background-color: #244864;
  line-height: 35px;
  vertical-align: middle;
}
#product .connect2 table:nth-of-type(n) caption p {
  font-size: 24px;
  color: #FFF;
}
#product .connect2 table:nth-of-type(odd) td {
  color: #32638a;
}
#product .connect2 table:nth-of-type(even) td {
  color: #32638a;
}
/*#product .connect > * {
  position: relative;
  z-index: 2;
} */
/*-- connect2end --*/

/*-- price-list start--*/
#product .connect#price-list {
  padding-bottom: 0;
  margin-bottom: 20px;
}
#product .connect#price-list h2 {
  margin-top: 80px;
  margin-bottom: 20px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .connect h2 span {
  font-size: 20px;
}

#product .connect#price-list div{
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
  height: 100%;
  margin-bottom: 0;
}

#product .connect#price-list table {
  width: 100%;
}

#product .connect#price-list th {
  width: auto;
}
#product .connect#price-list td {
  width: auto;
}
/*
#product .connect#price-list table:nth-of-type(2n+1) {
  float: left;
  margin: 20px 0;
}
#product .connect#price-list table:nth-of-type(2n) {
  float: right;
  margin: 20px 0;
}
#product .connect#price-list table:nth-of-type(3) {
  clear: both;
  margin-left: auto;
  margin-right: auto;
}
*/

/*-- // price-list end --*/


/*-- function start--*/
#product .function {
  width: 100%;
  height: 100%;
  color: #333;
  padding-bottom: 60px;
}
/*-- h2 add --edit to chin--*/
#product .function h2 {
  margin-bottom: 60px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .function h2 span {
  font-size: 20px;
}
#product .function ul {
  display: block;
  overflow: hidden;
  max-width: 1180px; /* add harada */
  margin: 0 auto;  /* add harada */
  width: 100%;
}
#product .function ul li {
  text-align: center;
  display: inline-block;
  width: 75%;
  margin-bottom: 30px;
}
#product .function ul li a {
  color: #c53d43;
  display: block;
}
#product .function ul li span {
  display: block;
  padding: 10px 0 0 30px;
  border-radius: 25px;
  background: #366b96;
  color: #fff;
  height: 50px;
  text-align: left;
  font-size: 23px;
}
#product .function ul li h3 {
  font-size: 24px;
  display: block;
  padding: 20px 0 0;
  color: #000;
  background: #fff;
  margin: 0 0 20px 0;
}
#product .function ul li h3 p {
  font-size: 18px;
  line-height: 32px;
  text-align: left;
  padding: 0 30px;
  color: #000;
  margin-bottom: 10px;
}
#product .function ul li h4 {
  font-size: 16px;
  line-height: 30px;
  text-align: left;
  padding: 10px 45px;
  color: #000;
}
#product .function ul li p img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
/*--chin add ipnotice kinou --*/
#product .cfix {
  zoom: 1;
  display: inline-block;
}
#product .cfix:after {
  content: ".";
  display: block;
  visibility: hidden;
  clear: both;
  height: .1px;
  font-size: .1em;
  line-height: 0;
}
#product .mb25 {
  margin-bottom: 25px;
}
#product .mt10 {
  margin-top: 10px;
}
#product .kinou_L, .kinou_R {
  padding: 0px;
  float: left;
  margin-left: 60px;
  margin-right: 10px;
}
#product .box26 {
  position: relative;
  margin: 2em 1em;
  padding: 2.5em 1em;
  border: solid 5px #366b96;
  border-radius: 40px;
}
#product .box26 .box-title {
  position: absolute;
  display: inline-block;
  top: -25px;
  left: 10px;
  padding: 0 9px;
  line-height: 1;
  font-size: 28px;
  background: #FFF;
  color: #f54237;
  font-weight: bold;
}
#product .function ul li div div p span {
  all: initial;
  color: #999999;
  font-size: 12px;
  display: block;
  padding: 5px;
  line-height: 16px;
  text-align: left;
  background: transparent;
}
#product .function ul li div div span {
  display: block;
  padding: 8px 0 0 30px;
  border-radius: 25px;
  background: #1ba8d6;
  color: #fff;
  height: 50px;
  text-align: left;
  font-size: 18px;
}
#product .box26 p {
  margin: 0;
  padding: 0;
}
#product .function ul li div div p {
  clear: both;
  padding: 10px 0 30px 10px;
  width: 300px;
  height: 170px;
}
#product .kinou_L p.tx, .kinou_R p.tx {
  font-size: 16px;
  clear: both;
  line-height: 30px;
  padding: 10px 0 30px 10px;
}
#product .kinou_L p.tx2, .kinou_R p.tx2 {
  font-size: 16px;
  clear: both;
  line-height: 30px;
  padding: 10px 0 30px 10px;
}
#product .kinou_L p.tx3, .kinou_R p.tx3 {
  font-size: 16px;
  clear: both;
  line-height: 30px;
  padding: 10px 0 73px 10px;
}
#product .kinou_L p.tx4, .kinou_R p.tx4 {
  font-size: 16px;
  clear: both;
  line-height: 30px;
  letter-spacing: 0.01em;
  padding: 10px 0 0 10px;
}
/*--chin end ipnotice kinou --*/
/*-- function end --*/
/*-- Scene --*/
#product .scene {
  display: inline-block;
  width: 100%;
  height: 100%;
  color: #333;
  padding-bottom: 60px;
  background: #fff;
}
#product .scene h3 {
  margin-bottom: 60px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .scene h3 span {
  font-size: 20px;
}
/*h2 add --edit by chin --*/
#product .scene h2 {
  margin-bottom: 60px;
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  padding-top: 13px;
  background: #264b69;
}
#product .scene h2 span {
  font-size: 20px;
}
#product .scene h4 {
  font-size: 24px;
  display: block;
  padding: 0 0 20px 0;
  color: #366b96;
  text-align: left;
}

#product .scene p {
  font-size: 22px;
  margin-bottom: 40px;
}
#product .scene ul {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 0 10px;
  /* text-align: center; */
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
/* 削除
#product .scene li {
  width: 350px;
  height: 330px;
  margin: 10px;
}
*/
#product .scene ul li {
  font-size: 18px;
  font-weight: 600;
  color: #264b69;
  text-align: left;
  /* display: inline-block; */
  width: 33%;
  margin: 0 0 40px;
  /* 
  width: 390px;
  height: 330px;
  margin: 24px 12px 0 0;
  padding: 12px;
  list-style: none;
  */
}
#product .scene .product-scene-text {
  font-size: 18px;
  font-weight: 600;
  color: #264b69;
  text-align: left;
  padding: 265px 0 0;
}
#product .scene .details-ttl2 {
  margin: 0 auto;
  line-height: 1.2em;
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 2px;
  text-align: center;
}
#product .scene .details-ttl2 h3 {
  background: #fff;
  padding: 0;
  color: #244864;
  font-size: 32px;
  margin: 0;
  height: 1.5em;
}
#product .scene .details-ttl2 p {
  padding: 10px 0px;
  font-size: 20px;
  font-weight: 200;
  letter-spacing: 2px;
  text-align: center;
}
#product .news-contents-details-video {
  max-width: 680px;
  width: 100%;
  margin: 40px auto 20px;
  position: relative;
}
#product .news-contents-details-video:before {
  content: "";
  display: block;
  padding-top: 56.2%;
}
#product .news-contents-details-video iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
  z-index: 0;
}
#product .news-contents-details-video-caption {
  max-width: 680px;
  width: 100%;
  margin: 0 auto 60px;
}
/*-- Scene end --*/
/*-- Case start --*/
#product .case {
  max-width: 1180px; /* add harada */
  margin: 0 auto; /* add harada */
  padding: 90px 0 0;
  margin-bottom: 100px;
  overflow: hidden;
}
#product .case h2 {
  font-size: 32px;
  line-height: 1;
  text-align: center;
  padding: 0 0 40px;
  border-top: 1px solid #244864;
}
#product .case h2 img {
  display: block;
  margin: -22px auto 15px;
  border-left: solid 20px #FFF;
  border-right: solid 20px #FFF;
}
#product .case h2 span {
  font-size: 20px;
  display: block;
  margin-top: 8px;
}
#product .case h2 + img {
  float: left;
  margin-right: 30px;
  margin-left: 15px;
  width: 30%;
}
#product .case dl {
  line-height: 26px;
  display: block;
  padding-bottom: 10px;
  overflow: hidden;
}
#product .case dt {
  font-size: 14px;
  font-weight: 600;
  color: #244864;
  text-align: center;
  display: block;
  height: 24px;
  width: 88px;
  border: 1px solid #244864;
}
#product .case dd {
  font-size: 16px;
  display: block;
  text-align: left;
  margin: -26px 0 20px 120px;
}
#product .case div {
  background: #FFFBEF;
  padding: 25px 25px;
  overflow: hidden;
}
#product .case h3 {
  background: #244864;
  font-size: 22px;
  line-height: 35px;
  font-weight: 600;
  color: #FFF;
  text-align: center;
  display: block;
  margin: 0 -20px;
  height: 40px;
}
#product .case h4 {
  font-size: 16px;
  margin: 20px 0 20px;
  text-align: left;
  line-height: 25px;
}
#product .case li {
  font-size: 14px;
  line-height: 24px;
  text-align: left;
}
#product .case ul li:before {
  content: "��";
  color: #244864;
  margin-right: 0.5em;
}
/*-- Case end --*/
/*-- Security --*/
#product .security {
  text-align: center;
  margin: 0 auto 80px;
  padding-bottom: 40px;
  border: 1px solid #264b69;
}
#product .security h2 {
  font-size: 24px;
  color: #fff;
  background: #264b69;
  display: block;
  padding: 30px 0;
  margin-bottom: 40px;
  border-bottom: 1px solid #264b69;
}
#product .security ul {
  margin: 0 auto 25px;
  display: table;
  border-collapse: separate;
  border-spacing: 30px 0;
  overflow: hidden;
}
#product .security ul li {
  font-size: 16px;
  line-height: 32px;
  background: #EEE url(/img/product/support_bg.png) no-repeat center 14px;
  text-align: center;
  vertical-align: middle;
  width: 330px;
  height: 125px;
  padding: 0 28px;
  display: table-cell;
  box-sizing: border-box;
}
#product .security > figure img {
  max-width: 800px;
  width: 25%;
  margin: 20px 0;
}
/*-- Security end --*/
/*-- Features --*/
#product .features {
  width: 100%;
  height: 100%;
  color: #333;
  /* padding-bottom: 100px; */
  background: #fff;

  /* text-align: center;
  margin: 0 auto -30px;
  border: 1px solid #333;
  font-size: 38px;
  padding: 15px 0;
  background: #264b69;
  color: #fff; */
}
#product .features h2 {
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  margin-bottom: 60px;
  padding-top: 13px;
  background: #264b69;
}
#product .features h2 span {
  font-size: 20px;
}

#product .features ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    padding: 0 10px;
  }
  #product .features ul li {
    text-align: left;
    width: 32%;
    margin-right: 1%;
    margin-bottom: 40px;
  }
#product .features ul li h3 {
  font-size: 24px;
  display: block;
  padding: 0 0 20px 0;
  color: #366b96 !important;
  text-align: left;
  background-color: #fff;
}
#product .features ul li h3 span {
  display: block;
  padding: 0 5px;
  color: #366b96 !important;
  font-size: 25px;
  font-weight: 600;
  height: 60px;
}
#product .features ul li p {
  font-size: 20px;
  line-height: 32px;
  text-align: left;
  padding: 0 5px;
  color: #000;
}

#product .features ul li ul.text {
  font-size: 18px;
  display: block;
}
#product .features ul li ul.text li {
  display: block;
  text-align: left;
  width: auto;
  line-height: normal;
  margin: 5px 0 !important;
  padding: 0 0 0 10px;
}

/* #product .features ul li:nth-child(4) {
clear: both;
}
#product .features ul li:nth-child(odd) span {
background: #366b96;
}
#product .features ul li:nth-child(even) span {
background: #264b69;
}
#product .features ul li:nth-child(odd) h3 span {
background: #366b96;
}
#product .features ul li:nth-child(even) h3 span {
background: #264b69;
} */

/*-- Features end --*/
#product .word {
  text-align: center;
  margin: 0 auto 80px;
  padding-bottom: 40px;
  border: 1px solid #333;
  font-size: 24px;
  padding: 30px 0;
}

/*-- customer-support start --*/
#product .customer-support {
  width: 100%;
  height: 100%;
  color: #333;
  padding-bottom: 40px;
  margin-bottom: 100px;
}
#product .customer-support h2 {
  color: #fff;
  font-size: 38px;
  text-align: center;
  height: 100px;
  margin-bottom: 60px;
  padding-top: 13px;
  background: #264b69;
}
#product .customer-support h2 span {
  font-size: 20px;
}
#product .customer-support > h3 {
  font-size: 24px;
  text-align: center;
  margin-bottom: 40px;
}

#product .customer-support h3 + p {
  line-height: 20px;
  margin-bottom: 30px;
}
#product .customer-support p.contact {
  margin: 0 0 40px;
}
#product .customer-support p.dl {
  margin: 0;
}
#product .customer-support .distributors {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto 60px;
  padding: 0 10px;
  display: flex;
}
#product .customer-support .distributors div {
  text-align: left;
  line-height: 1.5em;
}
#product .customer-support .distributors div.txt-box {
  width: 50%;
}
#product .customer-support .distributors div.txt-box div:nth-of-type(1) {
  padding: 0;
}
#product .customer-support .distributors div.txt-box div:nth-of-type(2) {
  padding: 20px 30px;
  background: rgba(27, 168, 214, 0.1);
  color: rgb(27, 168, 214);
}
#product .customer-support .distributors div.txt-box h3 {
  padding-left: 0;
  font-size: 22px;
  color: #123b73;
  font-weight: bold;
  margin-bottom: 15px;
}
#product .customer-support .distributors div.txt-box h3 p {
  font-size: 18px;
  
}
#product .customer-support .distributors div.txt-box h4 {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 10px;
}
#product .customer-support .distributors div.img-box {
  width: 50%;
}
#product .customer-support .distributors div.img-box img {
  width: 98%;
}

#product .customer-support ul {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 25px;
  padding: 0 10px;
  display: table;
  border-collapse: separate;
  border-spacing: 5px 0;
  overflow: hidden;
}
#product .customer-support ul:nth-of-type(2) {
  margin-bottom: 60px;
}
#product .customer-support ul li {
  font-size: 16px;
  line-height: 32px;
  background: #EEE url(/img/product/support_bg.png) no-repeat center 14px;
  text-align: center;
  vertical-align: middle;
  width: 400px;
  height: 125px;
  padding: 0 28px;
  display: table-cell;
  box-sizing: border-box;
}

/*-- // customer-support end --*/

/*-- Support start --*/
#product .support {
  max-width: 1200px;
  width: 100%;
  text-align: center;
  margin: 0 auto 80px;
  padding-bottom: 40px;
  border: 1px solid #4486bb;
}
#product .support h2 {
  font-size: 24px;
  color: #333;
  display: block;
  padding: 30px 0;
  margin-bottom: 40px;
  border-bottom: 1px solid #4486bb;
}
#product .support ul {
  margin: 0 auto 25px;
  width: 80%;
  display: table;
  border-collapse: separate;
  border-spacing: 30px 0;
  overflow: hidden;
}
#product .support ul:nth-of-type(2) {
  margin-bottom: 60px;
}
#product .support ul li {
  font-size: 16px;
  line-height: 32px;
  background: #EEE url(/img/product/support_bg.png) no-repeat center 14px;
  text-align: center;
  vertical-align: middle;
  width: 400px;
  height: 125px;
  padding: 0 28px;
  display: table-cell;
  box-sizing: border-box;
}
#product .support h3, 
#product .support h3 + p {
  text-align: left;
  display: block;
  width: 1050px;
  margin: 0 auto;
  font-size: 16px;
}
#product .support h3 {
  font-weight: bold;
  margin-bottom: 15px;
}
#product .support h3 + p {
  line-height: 20px;
  margin-bottom: 30px;
}
#product .support p.contact {
  margin: 0 0 40px;
}
#product .support p.dl {
  margin: 0;
}

#product .support .distributors {
  max-width: 1200px;
  width: 75%;
  margin: 0 auto 60px;
  display: flex;
}
#product .support .distributors div {
  text-align: left;
  line-height: 1.5em;
}
#product .support .distributors div.txt-box {
  width: 55%;
}
#product .support .distributors div.txt-box div:nth-of-type(1) {
  padding: 0;
}
#product .support .distributors div.txt-box div:nth-of-type(2) {
  padding: 20px 30px;
  background: rgba(27, 168, 214, 0.1);
  color: rgb(27, 168, 214);
}
#product .support .distributors div.txt-box h3 {
  padding-left: 0;
  font-size: 22px;
  color: #123b73;
}
#product .support .distributors div.txt-box h3 p {
  font-size: 18px;
}

#product .support .distributors div.txt-box h4 {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 10px;
}
#product .support .distributors div.img-box {
  width: 45%;
}
#product .support .distributors div.img-box img {
  width: 98%;
}

/* for SP add 20210512*/
@media screen and (max-width: 768px) {
  #product .support {
    max-width: 768px;
    margin: 0 0 60px;
    width: 98%;
  }
  #product .support ul {
    width: 95%;
  }
  #product .support ul:nth-of-type(2) {
    margin-bottom: 0;
  }
  #product .support h3, #product .support h3 + p {
    width: auto;
    text-align: left;
  }
  #product .support .distributors {
    max-width: 768px;
    width: 95%;
    display: flex;
    flex-flow: column;
  }
  #product .support .distributors div.txt-box div:nth-of-type(2) {
    padding: 20px;
  }
  #product .support .distributors div.txt-box div:nth-of-type(2) p {
    margin-bottom: 0;
}
  #product .support .distributors div.txt-box {
    width: 95%;
    margin-bottom: 30px;
  }
  #product .support .distributors div.img-box {
    width: 95%;
  }
 
}
/*-- Support end --*/
/* .product-relation start
    add 20210517 */
#product .product-relation {
  display: block;
  width: 600px;
  font-size: 18px;
  color: #4486bb;
  padding: 30px;
  margin: 60px auto;
  border: 1px solid #4486bb;
}
#product .product-relation h3 {
  display: block;
  margin: 0 0 20px 0;
  padding: 0;
  text-align: left;
  color: #4486bb;
}
#product .product-relation h4 {
  text-align: left;
  font-weight: normal;
}
#product .product-relation h4 a {
  color: #4486bb;
  font-weight: bold;
}
#product .product-relation h4 a span.material-icons {
  display: inline-flex;
  vertical-align: text-top; /* middle or sub */
  margin-right: 10px;
}

/* 
  ブログ紹介エリア　.blog-introduction
   add 20210630 by harada
*/
.blog-introduction {
  max-width: 1200px;
  margin: 20px auto 60px;
  padding-bottom: 30px;
  width: 90%;
  height: 100%;
  color: #333;
  background: #fff;
  text-align: left;
  font-size: 18px;
  border: 1px solid #264b69;
  /* box-shadow: 0 0 8px #ccc; */
}
.blog-introduction h3 {
  display: block;
  width: 100%;
  height: auto;
  color: #fff;
  background: #264b69;
  font-size: 23px;
  font-weight: bold;
  line-height: 40px;
  margin: 0 0 10px 0 !important;
  padding: 0 40px !important;
}
#product .blog-introduction h3 span {
  display: inline;
  color: #fff !important;
  font-size: 18px;
  font-weight: bold;
}
.blog-introduction p {
  margin: 0 auto;
  padding: 0 20px 40px 20px;
  display: block;
}
.blog-introduction .document-area, 
.blog-introduction .article-area {
  margin: 0 auto;
  padding: 0 10px 30px 10px;
  width: 95%;
  display: block;
  overflow: hidden;
}
.blog-introduction .article-area {
  clear: both;
}
.blog-introduction .document-area h4 {
  font-size: 22px;
  color: rgb(27, 168, 214);
  line-height: 1.8em;
  margin-bottom: 10px;
}
.blog-introduction .document-area p {
  color: #555;
  line-height: 1.5em;
  margin-top: 0;
  padding: 0 0 10px 0;
}

.blog-introduction .document-area .doc-image { /* 左寄せ設定 */
  margin: 0 0 15px 0;
  width: 45%;
  float: left;
  /* box-shadow: 0 0 10px #ccc; */
}
.blog-introduction .document-area .doc-image img {
  border: solid 1px #ccc;
}
.blog-introduction .document-area .description { /* 右寄せ設定 */
  display: block;
  float: right;
  width: 53%;
  margin-left: 2%;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 16px;
}

.blog-introduction .document-area .description p {

}
.blog-introduction .document-area .description p.notice {

}



.blog-introduction .article-ranking { /* 左寄せ */
  float: left;
  margin: 10px 0 20px;
  width: 48%;
  display: block;
}
.blog-introduction .article-recentry { /* 右寄せ */
  float: right;
  margin: 10px 0 20px;
  width: 48%;
  display: block;
}
.blog-introduction .article-ranking h4 ,
.blog-introduction .article-recentry h4 {
  width: 100%;
  border-bottom: 1px solid #264b69;
  margin-bottom: 20px;
  height: 25px;
}

.blog-introduction .article-ranking h4 > span ,
.blog-introduction .article-recentry h4 > span {
  display: inline ;
  font-size: 18px;
  color: #fff;
  background: #264b69;
  padding: 5px 20px;
  height: 25px;
}

.blog-introduction .article-ranking ul ,
.blog-introduction .article-recentry ul {
  margin: 0;
}

.blog-introduction .article-ranking ul li ,
.blog-introduction .article-recentry ul li {
  display: block;
  line-height: 1.5em;
  margin-bottom: 10px;
}

.blog-introduction .article-ranking ul li a ,
.blog-introduction .article-recentry ul li a {
  color: rgb(58, 58, 58);
  border-bottom: 1px solid rgb(58, 58, 58);
}

.blog-introduction .article-ranking ul li span ,
.blog-introduction .article-recentry ul li span {
  display: block;
  font-size: 15px;
  padding-left: 25px;
}

.blog-introduction .listbtn {
  clear: both;
  display: block;
  margin: 0 auto;
  width: 250px;
  margin-bottom: 5px;
}
.blog-introduction .listbtn a {
  transition: all .8s;
  background: rgb(27, 168, 214);
  border-radius: 4px;
  color: #fff;
  text-align: center;
  border: 1px solid rgb(27, 168, 214);
  position: relative;
  display: inline-block;
  width: 250px;
  font-size: 18px;
  font-weight: bold;
  padding: 10px 23px;
  text-decoration: none;
}

@media screen and (max-width: 768px) {
.blog-introduction {
    max-width: 768px;
    margin: 20px auto 60px;
    width: 95%;
  }
  #product .blog-introduction h3 {
    text-align: center;

}

#product .blog-introduction h3 span {
  letter-spacing: 0.1em;
  font-size: 16px;
}

  #product .blog-introduction h3 span::before {
    content: "\A" ;
    white-space: pre ;
}
  .blog-introduction .document-area .doc-image { /* 左寄せ解除 */
    width: 100%;
    clear: left;
    /* box-shadow: 0 0 10px #ccc; */
  }
  .blog-introduction .document-area .description { /* 右寄せ解除 */
    clear: right;
    width: 100%;
    margin-left: 0;
    font-size: 16px;
  }
  .blog-introduction .article-ranking { /* 左寄せ解除 */
    clear: left;
    width: 100%;
  }
  .blog-introduction .article-recentry { /* 右寄せ解除 */
    clear: right;
    width: 100%;
  } 

}

/* 
   資料ダウンロードエリア　.document-download
   add 20210611 by harada
*/
.document-download {
  max-width: 1200px;
  margin: 20px auto 60px;
  width: 90%;
  height: 100%;
  color: #333;
  background: #fff;
  text-align: left;
  font-size: 18px;
  border: 1px solid #264b69;
  /* box-shadow: 0 0 8px #ccc; */
}
.document-download h3 {
  display: block;
  width: 100%;
  height: auto;
  color: #fff;
  background: #264b69;
  font-size: 23px;
  font-weight: bold;
  line-height: 40px;
  margin-bottom: 20px;
  padding: 0 40px !important;
}
.document-download p {
  margin: 0 auto;
  padding: 0 20px 40px 20px;
  width: 95%;
  display: block;
}
.document-download ul.document-area {
  margin: 0 auto;
  padding: 0 10px 20px 10px;
  width: 95%;
  display: block;
  overflow: hidden;
}
.document-download ul.document-area li { /* li の左寄せ設定 */
  display: block;
  width: calc(50% - 20px);
  list-style: none;
  margin: 0 10px 0px 10px;
  padding: 0;
  float: left;
}
.document-download ul.document-area .doc-title {
  margin-bottom: 18px;
}
.document-download ul.document-area .doc-title h4 {
  color: rgb(27, 168, 214);
  font-weight: bold;
  line-height: 1.5em;
}
.document-download ul.document-area .doc-image { /* 左寄せ設定 */
  margin: 0 3% 15px 0;
  float: left;
  width: 42%;
  /* box-shadow: 0 0 10px #ccc; */
}
.document-download ul.document-area .doc-image img {
  border: solid 1px #ccc;
}
.document-download ul.document-area .description { /* 右寄せ設定 */
  display: block;
  float: right;
  width: 52%;
  margin-right: 2%;
}
.document-download ul.document-area .description p.comment {
  font-size: 15px;
}
.document-download ul.document-area .description .doc-text {
  color: #555;
  font-size: 15px;
  line-height: 1.3em;
}
.document-download ul.document-area .description .doc-text p {
  margin-top: 0;
  width: 100%;
  padding: 0;
}
.document-download ul.document-area .description .doc-text dl {
  margin: 10px 0 10px;
  padding: 5px 10px 5px 10px;
  line-height: 1.5em;
  border-top: dotted 1px #555;
  border-bottom: dotted 1px #555;
}
.document-download ul.document-area .description .doc-text dl dd {

}

.document-download ul.document-area .description .listbtn {
  margin-top: 10px;
  margin-bottom: 10px;
}
.document-download ul.document-area .description .listbtn a {
  transition: all .8s;
  background: rgb(27, 168, 214);
  border-radius: 4px;
  color: #fff;
  text-align: center;
  border: 1px solid rgb(27, 168, 214);
  position: relative;
  display: inline-block;
  width: 160px;
  font-size: 16px;
  font-weight: bold;
  padding: 6px 20px;
  text-decoration: none;
}
.document-download ul.document-area .description p.comment {
  font-size: 13px;
  padding: 0;
  color: #264b69;
}
.document-download div.cl {
  clear: both;
}
@media screen and (max-width: 768px) {
.document-download {
    max-width: 768px;
    margin: 20px auto 60px;
    width: 95%;
  }
.document-download ul.document-area li { /* li の左寄せクリア */
    display: block;
    width: 98%;
    list-style: none;
    margin: 10px auto 40px;
    padding: 0;
    clear: left;
  }
}
/* #product #business 共通 
   関連記事　.related-topics
   add 20210528 by harada
*/
#product .related-topics, #business .related-topics {
  max-width: 1200px;
  margin: 20px auto 60px;
  width: 75%;
  height: 100%;
  color: #333;
  background: #fff;
  text-align: left;
  font-size: 18px;
  border: 1px solid #264b69;
}
#product .related-topics h3, #business .related-topics h3 {
  display: block;
  width: 100%;
  height: auto;
  color: #fff;
  background: #264b69;
  font-size: 23px;
  line-height: 40px;
  margin-bottom: 20px;
  padding: 0 20px;
}
#product .related-topics ul, #business .related-topics ul {
  margin: 0 auto;
  padding: 0 20px 20px 20px;
  width: 95%;
}
#product .related-topics ul li, #business .related-topics ul li {
  display: block;
  vertical-align: bottom;
  line-height: 40px;
  border-bottom: dotted 1px #264b69;
  margin-bottom: 3px;
}
#product .related-topics ul li:last-child, #business .related-topics ul li:last-child {
  margin-bottom: 0;
}
/* #product #business 共通 
   関連記事　.related-topics
   for SP
   add 20210528 by harada
*/
@media screen and (max-width: 768px) {
  #product .related-topics, #business .related-topics {
    margin: 20px auto 60px;
    width: 95%;
    height: 100%;
    color: #333;
    background: #fff;
    text-align: left;
    font-size: 14px;
    border: 1px solid #264b69;
  }
  #product .related-topics h3, #business .related-topics h3 {
    display: block;
    width: 100%;
    height: auto;
    color: #fff;
    background: #264b69;
    font-size: 20px;
    line-height: 40px;
    margin-bottom: 20px;
    padding: 0 20px;
  }
  #product .related-topics ul, #business .related-topics ul {
    margin: 0 auto;
    padding: 0 10px 20px 10px;
    width: 100%;
  }
  #product .related-topics ul li, #business .related-topics ul li {
    display: block;
    vertical-align: bottom;
    line-height: 1.5em;
    border-bottom: dotted 1px #264b69;
    margin-bottom: 3px;
  }
  #product .related-topics ul li:last-child, #business .related-topics ul li:last-child {
    margin-bottom: 0;
  }
}
/*new product template end */

@media (max-width: 1220px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 30px 20px 30px;
  }
  #product .connect div ul li {
    display: block;
    margin: 0 25px;
  }
}
@media (max-width: 1150px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 100px 20px 130px;
  }
}
@media (max-width: 970px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 30px 20px 30px;
  }
}
@media (max-width: 930px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 30px 20px 30px;
  }
}
@media (max-width: 890px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 30px 20px 30px;
  }
}
@media (max-width: 414px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined {
    display: block;
    width: 400px;
  }
  #product .connect .combined th, #product .connect .combined td {
    font-size: 15px;
    vertical-align: middle;
  }
  #product .connect .combined th {
    width: 80px;
    text-align: center;
  }
  #product .connect .combined td {
    width: 220px;
    text-align: left;
  }
}
@media (max-width: 375px) {
  #product .connect .table1 {
    display: none;
  }

  #product .connect .combined th, #product .connect .combined td {
    font-size: 15px;
    vertical-align: middle;
  }
  #product .connect .combined th {
    width: 70px;
    text-align: center;
  }
  #product .connect .combined td {
    width: 195px;
    text-align: left;
  }
}
@media (max-width: 320px) {
  #product .connect .table1 {
    display: none;
  }
  #product .connect .combined th, #product .connect .combined td {
    font-size: 15px;
    vertical-align: middle;
  }
  #product .connect .combined th {
    width: 40px;
    text-align: center;
  }
  #product .connect .combined td {
    width: 180px;
    text-align: left;
  }
}
/*-- Service start --*/
/*-- For local5g-ds Add 20210512 --*/
#business .service {
  padding: 80px 10px;
  margin-bottom: 100px;
  background: #f5f5f5;
}
#business .service h2 {
  font-size: 32px;
  line-height: 1;
  text-align: center;
  padding: 0 0 40px;
}
#business .service h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
/* 旧デザイン
#business .service {
  margin: 100px auto;
  padding: 80px 10px;
  background: #f5f5f5;
}

#business .service h2 {
  margin: 40px 0;
  padding-bottom: 30px;
}

#business .service h2 em {
  font-size: 50px;
  font-weight: 600;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
*/
#business .service .wrap {
  margin: 100px auto;
  display: flex;
  align-items: center;
  /*justify-content: center; センタリング */
  justify-content: space-between; /* 両端ぞろえ */
  max-width: 1092px;
  background-color: #fff;
}
#business .service .wrap .image {
  width: 45%;
  padding: 20px;
}
#business .service .wrap .image img {
  width: 100%;
  height: auto;
  display: block;
}
#business .service .wrap .text {
  display: block;
  width: 55%;
  font-size: 20px;
  background-color: #fff;
  padding: 20px;
}
#business .service .wrap .text h4 {
  font-size: 26px;
  margin: 0 0 20px 0;
}
#business .service .wrap .text p {
  text-align: left;
  line-height: 1.8em;
}
/* #business .service for SP add 20210514 */
@media (max-width: 768px) {
  #business .service .wrap {
    margin: 0 auto;
    display: flex;
    align-items: center;
    flex-flow: column;
    max-width: 768px;
    background-color: #fff;
  }
  #business .service .wrap .image {
    width: 100%;
    padding: 20px;
  }
  #business .service .wrap .image img {
    width: 100%;
    height: auto;
    display: block;
  }
  #business .service .wrap .text {
    display: block;
    width: 100%;
    font-size: 20px;
    background-color: #fff;
    padding: 20px;
  }
  #business .service .wrap .text h4 {
    font-size: 26px;
    margin: 0 0 20px 0;
  }
  #business .service .wrap .text p {
    text-align: left;
    line-height: 1.8em;
  }
}
/*-- Service end --*/
/*-------------------------------------------*/
@media (min-width: 769px) {
  #product .scene {
    display: inline-block;
    width: 100%;
    color: #333;
    padding-bottom: 80px;
    background: #fff;
  }
  #product .scene ul {
    width: 1180px;
    /* margin: 5px 3px 0 12px; */
    display: inline-block;
    overflow: hidden;
    list-style: none;
  }
  #product .scene ul li {
    /*
    display: block;
    font-size: 20px;
    font-weight: 600;
    color: #244864;
    */
    display: grid;
    text-align: center;
    float: left;
    width: 33.333%;
    /*
    width: 350px;
    height: 370px;
    padding: 40px 0 0;
    */
  }
 
  #product .case h2 {
    font-size: 32px;
    line-height: 1;
    text-align: center;
    padding: 0 0 40px;
    border-top: 1px solid #244864;
  }
  #product .case h2 img {
    display: block;
    height: auto;
    margin: -22px auto 15px;
    border-left: solid 20px #FFF;
    border-right: solid 20px #FFF;
  }
  #product .case h2 + img {
    float: left;
    width: 380px;
    margin-right: 30px;
  }
  #product .case dl {
    line-height: 26px;
    display: block;
    padding-bottom: 10px;
    overflow: hidden;
  }
  #product .case dt {
    font-size: 14px;
    font-weight: 600;
    color: #244864;
    text-align: center;
    display: block;
    height: 24px;
    width: 88px;
    border: 1px solid #244864;
  }
  #product .case dd {
    font-size: 16px;
    display: block;
    margin: -26px 0 20px 120px;
  }
  #product .case div {
    background: #FFFBEF;
    padding: 0 25px 25px;
    overflow: hidden;
  }
  #product .case h3 {
    background: #244864;
    font-size: 16px;
    line-height: 35px;
    font-weight: 600;
    color: #FFF;
    text-align: center;
    display: block;
    margin: 0 -20px;
    height: 35px;
  }
  #product .case h4 {
    font-size: 16px;
    margin: 20px 0 13px;
    text-align: left;
    line-height: 25px;
  }
  #product .case h6 {
    margin: 0 0 80px;
  }
}

/*
@media (max-width: 1024px) {
  #product .scene ul {
    width: 1020px;
  }
  #product .scene ul li {
    width: 324px;
  }
  #product .connect ul {
    display: block;
    margin: 15px 20px;
  }
  #product .connect div ul li {
    width: 90%;
    margin: 0;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
}
*/
@media (max-width: 768px) {

  /*
  #product .scene ul {
    width: 720px;
  }
  #product .scene ul li {
    width: 330px;
  }
  */
  #product .function ul li {
    text-align: center;
    display: inline-block;
    width: 80%;
    margin-bottom: 10px;
  }
  #product .function ul li span {
    height: 55px;
    font-size: 21px;
    padding: 15px;
    display: block;
    text-align: left;
    vertical-align: middle;
  }
  #product .function ul li h4 {
    font-size: 20px;
  }
  #product .function ul li p img {
    height: auto;
    width: 100%;
  }
  /* ---Chen edit function kinou --*/
  #product .cfix {
    all: initial;
    max-width: 100%;
    display: inline-block;
  }
  #product .box26 {
    max-width: 100%;
    float: left;
    position: relative;
    margin: 1em 1em 3.5em 1em;
    padding: 0.5em 0.5em;
  }
  #product .box26 .box-title {
    all: initial;
    position: absolute;
    display: inline-block;
    top: -21px;
    left: 15px;
    padding: 0 15px;
    line-height: 1;
    background: rgba(255, 255, 255, 1.5);
  }
  #product .function ul li div div p span {
    all: initial;
    color: unset;
    font-size: 12px;
    display: block;
    padding: 5px;
    line-height: 16px;
    text-align: left;
  }
  #product .function ul li div div span {
    all: initial;
    display: block;
    margin: 30px 0 0 0;
    padding: 3px 0 3px 20px;
    color: #1ba8d6;
    height: 50px;
    text-align: left;
    font-size: 18px;
    font-weight: bold;
  }
  #product .box26 p {
    margin: 0;
    padding: 0;
  }
  #product .kinou_L p.tx, .kinou_R p.tx {
    display: inline;
    clear: both !important;
    padding: 10px 0 0 10px !important;
    height: 220px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx2, .kinou_R p.tx2 {
    display: inline;
    clear: both;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx3, .kinou_R p.tx3 {
    display: inline;
    clear: both;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx4, .kinou_R p.tx4 {
    display: inline;
    clear: both;
    letter-spacing: 0;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
  #product .connect div ul li {
    width: 80%;
    margin: 0;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
}

@media (max-width: 768px) {
  #product .scene ul {
    max-width: 599px;
    width: 90%;
    margin: 0 -5px auto 18px;
    display: block;
    overflow: hidden;
    list-style: none;
    padding: 1px;
    text-align: left;
  }
  #product .scene ul li {
    font-size: 17px;
    font-weight: 400;
    color: #264b69;
    background-size: 100% auto !important;
    background: no-repeat center center;
    text-align: center;
    display: block;
    width: 100%;
    height: auto;
    clear: left;
    padding: 5px 0 0;
    /* margin: 5px 5px 15px; */
  }
  #product .scene .product-scene-text {
    padding-top: 10px;
    font-size: 17px;
    font-weight: 400;
    color: #264b69;
    text-align: left;
  }
  #product .product-contents {
    padding: 0 10px;
    background: #e3e3e3;
  }
  #product .product-contents ul {
    display: block;
    padding: 80px 0 20px;
  }
  #product .product-contents ul li {
    max-width: 580px;
    width: 100%;
    margin: 0 auto 60px;
  }
  #product .product-contents ul li > a:before {
    bottom: 20px;
    right: 20px;
  }
  #product .product-contents ul li > a:after {
    bottom: 22px;
    right: 20px;
  }
  #product .product-contents ul li > a h3 {
    padding: 9px 15px 10px;
    font-size: 16px;
  }
  #product .product-contents ul li > a figure figcaption {
    -webkit-transform: translate3d(0, -50%, 0) translateY(-5px);
    transform: translate3d(0, -50%, 0) translateY(-5px);
    font-size: 26px;
  }
  #product .product-contents ul li > a figure figcaption:before {
    top: calc(100% + 10px);
  }
  #product .product-contents ul li p {
    font-size: 16px;
  }
  #product .details-ttl {
    margin: 60px 0 90px;
    font-size: 36px;
  }
  #product .product-details-info {
    display: block;
    margin: 0 auto 60px;
  }
  #product .product-details-info li {
    width: 100%;
    padding: 60px 10px;
  }
  #product .product-details-info li h4 {
    margin: 0 0 30px 0;
  }
  #product .product-details-info li h4 em {
    font-size: 26px;
  }
  #product .product-details-info li h4 span {
    font-size: 16px;
  }
  #product .product-details-info li p {
    font-size: 16px;
  }
  /*-- for SP #product .product-details-btn start --*/
  #product .product-details-btn {
    display: block;
    margin: 0 auto 60px;
  }
  #product .product-details-btn li a:after {
    right: 15px;
  }
  /* PDF icon */
  #product .product-details-btn li.product-details-btn-pdf a { /* PDF icon */
    padding: 34px 10px 34px 55px;
  }
  #product .product-details-btn li.product-details-btn-pdf a:before {
    left: 20px;
  }
  #product .product-details-btn li.product-details-btn-pdf a:after {
    display: none;
  }
  /* ボタン３つ */
  #product .product-details-btn.product-details-btn-col3 li {
    width: 100%;
  }
  #product .product-details-btn.product-details-btn-col3 li:nth-of-type(1) a, #product .product-details-btn.product-details-btn-col3 li:nth-of-type(2) a {
    border-width: 2px 2px 0 2px;
  }
  /* ボタン2つ */
  #product .product-details-btn.product-details-btn-col2 li {
    width: 100%;
    margin: 0;
  }
  #product .product-details-btn.product-details-btn-col2 li:nth-of-type(1) a {
    border-width: 2px 2px 0 2px;
  }
  /* ボタン1つ */
  #product .product-details-btn.product-details-btn-col1 li {
    width: 100%;
  }
  /*--//end for SP #product .product-details-btn --*/
  /*---Edited by miso----------------------------------------------------------------------------------------------------------------------- */
  #product .about div {
    width: 100%;
    padding: 30px 10px;
    text-align: center;
  }
  #product .about div h3 {
    font-size: 24px;
    margin-bottom: 30px;
    width: 67%;
    text-align: left;
    border-bottom: 12px #4486bb solid;
  }
  /* h1 add --edit by chin --*/
  #product .about div h1 {
    font-size: 24px;
    margin-bottom: 30px;
    width: auto; /* org 67% */
    text-align: center;
    border-bottom: 12px #4486bb solid;
  }
  #product .about div h1.long-ttl {
    font-size: 22px;
    padding: 0;
  }
  #product .about div p {
    font-size: 17px;
    line-height: 25px;
    width: 100%;
    text-align: left;
    text-indent: 1em;
    }
  #product .about ul {
    max-width: 599px;
    width: 90%;
}
  #product .about ul li {
    display: inline-block;
    margin-bottom: 50px;
    clear: left;
    width: 100%;
  }
  #product .about ul li span {
    padding: auto;
    font-size: 23px;
  }
  #product .about ul li h4 {
    font-size: 20px;
    padding: auto;
  }
  #product .about ul li p {
    font-size: 13px;
    line-height: 20px;
    padding: auto;
  }
  #product .connect {
    padding-bottom: 30px;
  }
  #product .connect h3 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .connect h3 span {
    font-size: 20px;
  }
  /* h2 add --edit by chin ---*/
  #product .connect h2 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .connect h2 span {
    font-size: 20px;
  }
  #product .connect > h4 {
    font-size: 20px;
    text-align: center;
    margin-bottom: 10px;
    padding: 0 10px 5px;
  }
  #product .connect > h4 + p {
    font-size: 16px;
    line-height: 25px;
    text-align: center;
    margin-bottom: 30px;
    padding: 0 10px 5px;
  }
  #product .connect > figure img {
    width: 100%;
    height: auto;
    /*padding: 0 10px 5px 17px; commentout 20210514*/
    padding: 15px;
  }
/*   #product .connect .table1 {
    display: none;
  } */
  #product .connect div {
    width: 90%;
    height: 90%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
    padding: 0;
    display: inline-block;
  }
  #product .connect ul {
    display: block;
    margin: 1px 2px;
    padding-left: 0;
  }
  #product .connect ul li p {
    margin: 5px 10px;
    font-size: 12px;
    line-height: 23px;
  }
  #product .connect div ul li {
    padding-left: 10px;
    width: 100%;
  }
  #product .connect div ul li img {
    max-width: 100%;
  }
  #product .word {
    margin: 5px 10px 80px;
  }
  #product .connect .combined {
    display: block;
    width: 100%;
    padding: 0 30px 20px 30px;
  }

  #product .function h3 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .function h3 span {
    font-size: 20px;
  }
  #product .function h2 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .function h2 span {
    font-size: 20px;
  }
  #product .function ul li {
    text-align: center;
    display: inline-block;
    width: 80%;
    margin-bottom: 30px;
  }
  #product .function ul li span {
    height: 55px;
    font-size: 21px;
    padding: 15px;
    display: block;
    text-align: left;
    vertical-align: middle;
  }
  #product .function ul li h4 {
    font-size: 20px;
  }
  #product .function ul li h4 p {
    font-size: 18px;
    padding: 0 20px 15px
  }
  #product .function ul li p img {
    height: auto;
    width: 100%;
  }
  /* ---Chen edit function kinou --*/
  #product .cfix {
    all: initial;
    max-width: 100%;
    display: inline-block;
  }
  #product .box26 {
    max-width: 100%;
    float: left;
    position: relative;
    margin: 1em 1em 3.5em 1em;
    padding: 0.5em 0.5em;
  }
  #product .box26 .box-title {
    all: initial;
    position: absolute;
    display: inline-block;
    top: -21px;
    left: 15px;
    padding: 0 15px;
    line-height: 1;
    background: rgba(255, 255, 255, 1.5);
  }
  #product .function ul li div div p span {
    all: initial;
    color: unset;
    font-size: 12px;
    display: block;
    padding: 5px;
    line-height: 16px;
    text-align: left;
  }
  #product .function ul li div div span {
    all: initial;
    display: block;
    margin: 30px 0 0 0;
    padding: 3px 0 3px 20px;
    color: #1ba8d6;
    height: 50px;
    text-align: left;
    font-size: 18px;
    font-weight: bold;
  }
  #product .box26 p {
    margin: 0;
    padding: 0;
  }
  #product .kinou_L p.tx, .kinou_R p.tx {
    display: inline;
    clear: both !important;
    padding: 10px 0 0 10px !important;
    height: 220px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx2, .kinou_R p.tx2 {
    display: inline;
    clear: both;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx3, .kinou_R p.tx3 {
    display: inline;
    clear: both;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
  #product .kinou_L p.tx4, .kinou_R p.tx4 {
    display: inline;
    clear: both;
    letter-spacing: 0;
    padding: 10px 0 0 10px;
    line-height: 25px !important;
  }
}
/*-- //end max-width: 798px --*/
/*-- chen edit end -- */


/* for SP add 20210514  by harada 
   start
*/
@media (max-width: 599px) {
  #product .connect h2 span {
    font-size: 16px;
  }
  #product .function ul li {
    margin: 15px 0;
  }
  #product .function ul li h3 {
    display: inline-block;
  }
  #product .function ul li h3 p {
    font-size: 20px;
    padding: 0 10px;
  }
  #product .function ul li h4 {
    font-weight: normal;
    padding: 20px 10px;
  }
  #product .function ul li h4.link {
    text-align: left;
    font-weight: bold;
    padding: 20px 10px;
  }
}
@media (max-width: 768px) {
  #product .scene h3 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .scene h3 span {
    font-size: 20px;
  }
  /*h2 add --edit by chin --*/
  #product .scene h2 {
    margin-bottom: 40px;
    font-size: 27px;
    height: 80px
  }
  #product .scene h2 span {
    font-size: 20px;
  }
  #product .scene p {
    font-size: 20px;
    padding: 5px 20px;
  }
  #product .scene ul {
    margin: 0 -5px auto 10px;
    display: inline-block;
    overflow: hidden;
    list-style: none;
  }
  
  #product .support {
    text-align: center;
    margin: 0 15px 60px;
    padding: 0 0 40px;
    border: 1px solid #333;
  }
  #product .support ul {
    margin: 0 0 0 0;
    width: 100%;
    padding-bottom: 10px;
    list-style: none;
    -webkit-margin-before: 0px;
    -webkit-margin-after: 0px;
    -webkit-margin-start: 0px;
    -webkit-margin-end: 0px;
    -webkit-padding-start: 0px;
  }
  #product .support ul li {
    font-size: 19px;
    line-height: 27px;
    background: #EEE url(/img/product/support_bg.png) no-repeat center center;
    background-size: auto 58px;
    text-align: left;
    display: block;
    padding: 15px 10px;
    margin-bottom: 20px;
    width: 100%;
  }
  #product .support h4, #product .support h4 + p {
    text-align: left;
    display: block;
    width: 80%;
    margin: 0 auto;
    line-height: 25px;
  }
  #product .support h4 {
    font-size: 17px;
    font-weight: bold;
    margin-bottom: 15px;
  }
  #product .support h4 + p {
    font-size: 15px;
  }
  #product .support h4 + p {
    margin-bottom: 30px;
  }
  #product .case {
    padding: 60px 0 0;
  }
  #product .case h2 {
    font-size: 20px;
    line-height: 1;
    text-align: center;
    padding: 0 25px 25px;
    border-top: 1px solid #244864;
  }
  #product .case h2 img {
    display: block;
    width: 120px;
    height: auto;
    margin: -16px auto 15px;
  }
  #product .case h2 + img {
    width: 100%;
    height: auto;
    margin-bottom: 20px;
    padding: 0 30px 2px 20px;
  }
  #product .case dl {
    display: inline-block;
    padding-bottom: 10px;
    overflow: hidden;
  }
  #product .case dt {
    font-size: 14px;
    line-height: 20px;
    font-weight: 600;
    color: #244864;
    text-align: center;
    display: block;
    height: 24px;
    width: 88px;
    border: 1px solid #244864;
    margin: 15px 0 0 15px;
  }
  #product .case dd {
    font-size: 16px;
    display: block;
    line-height: 20px;
    margin: -26px 0 20px 120px;
  }
  #product .case div {
    background: #FFFBEF;
    padding: 25px 25px;
    overflow: hidden;
  }
  #product .case h3 {
    background: #244864;
    font-size: 16px;
    line-height: 35px;
    font-weight: 600;
    color: #FFF;
    text-align: center;
    display: block;
    margin: 0 -20px;
    height: 35px;
  }
  #product .case h4 {
    font-size: 16px;
    margin: 20px 0 13px;
    line-height: 25px;
    text-align: left;
  }
  #product .connect div ul li {
    width: 50%;
  }
  /* add 20210514*/
  #product .product-relation {
    width: 80%;
    font-size: 16px;
    padding: 20px;
    margin: 30px auto;
  }
  #product .product-relation h3 {
    margin: 0 0 20px 0;
    font-size: 18px;
    height: 1.5em;
  }
}
/*----------------------------------covid-19-------------------------------------------*/
/* Display only PC 
  modify 20210517 */
@media screen and (max-width:768px) {
  .event-details-contents-entry .event-details-contents-entry-btn {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a:before {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a:after {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a div:before {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a div:after {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-btn a div span {
    display: none;
  }
  .event-details-contents-entry .event-details-contents-entry-end {
    display: none;
  }
  .event-details-contents-entry .details-btn {
    display: none;
  }
}
.event-details-contents-entry .event-details-contents-entry-btn {
  position: fixed;
  top: 50%;
  right: 0;
  margin: -85px 0 0 0;
  width: 90px;
  height: 170px;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 20px 0 0 0;
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  position: relative;
  transition: opacity .3s ease;
  background: #df0623 !important;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 26px;
  right: 15px;
  width: 36px;
  height: 1px;
  z-index: 1;
  background: #fff;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 28px;
  right: 15px;
  width: 8px;
  height: 1px;
  z-index: 1;
  background: #fff;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a div:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 20px 20px 0;
  border-color: transparent #b70a21 transparent transparent;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a div:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 20px 0 0 20px;
  border-color: transparent transparent transparent #b70a21;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-btn a div span {
  display: block;
  width: 100%;
  text-align: center;
  z-index: 20;
}
.event-details-contents-entry .event-details-contents-entry-end {
  margin: 0 0 40px 0;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  color: #df0623 !important;
  z-index: 20;
}
.event-details-contents-entry .details-btn {
  margin: 0 auto;
  z-index: 20;
}
/*------------------------------------------0316------------echin--------------------*/
/*-------------------------------------------------------------------------------------------------------*/
#product section h3 {
  margin: 0 0 40px 0;
  padding: 0 10px;
}
#product section h3 em {
  display: block;
  margin: 0 0 5px 0;
  font-size: 50px;
  font-weight: 600;
  line-height: 1.2em;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#product section h3 span {
  display: block;
  font-size: 18px;
  line-height: 1.5em;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*----------------------------------------------------------------------------*/
/*-- modify 20210415
only #product
add .footer_fixed
*/
/* for PC */
/* お問い合わせボタン設置スペース */
#product footer, footer#product {
  padding-bottom: 60px;
}
#product .footer_fixed {
  position: fixed;
  left: 0;
  bottom: 0;
  width: 100%;
  margin: 0 auto;
  height: 60px;
  background: rgba(255, 255, 255, 0.7);
  z-index: 100;
}
/* 親要素(コンテナ) */
#product .footer_fixed ul.flex-container {
  display: flex;
  width: 100%;
  height: 100%;
  margin: auto;
  font-size: 100%;
  font-weight: bold;
  max-width: 1200px;
  /*
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
       -ms-flex-direction: row-reverse;
           flex-direction: row-reverse;
*/
  flex-direction: row;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end; /* 右寄せ */
}
/* 子要素(アイテム) */
#product .footer_fixed ul.flex-container li.flex-item {
  display: flex;
  align-self: auto;
  flex: 1;
  text-align: center;
  max-width: 180px; /* 33.3333% */
  min-width: 0;
}
#product .footer_fixed ul.flex-container li.flex-item p {
  width: 180px;
  text-align: center;
  display: flex;
}
/* 孫要素 */
#product .footer_fixed ul.flex-container li.flex-item a {
  width: 100%;
  height: 100%;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin: 0 auto;
  padding: 1em 1em 1em 1em;
  box-sizing: border-box;
  position: relative;
  text-decoration: none;
  text-align: center;
  word-break: break-all;
  transition: 0.3s all ease;
  /* background-color: rgba(252,157,8, 1.0); */
  background-color: rgba(219, 18, 18, 1.0);
  color: #fff;
}
/* Web フォント icon 装飾*/
.footer_fixed .material-icons {
  display: inline-flex;
  vertical-align: text-top; /* middle or sub */
  margin-right: 5px;
}
/* for SP */
@media screen and (max-width: 599px) { /* 480px or 768px or 1040px */

  
  #product .footer_fixed {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    margin: 0 auto;
    height: 50px;
    background: rgba(255, 255, 255, 0.7);
    z-index: 100;
  }
  /* 親要素(コンテナ) */
  #product .footer_fixed ul.flex-container {
    max-width: 599px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    height: 100%;
    font-size: 15px;
     /*
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
         -ms-flex-direction: row-reverse;
             flex-direction: row-reverse;
  */
    flex-direction: row;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: center /* 中央寄せ */
  }
  /* 子要素(アイテム) */
  #product .footer_fixed ul.flex-container li.flex-item {
    width: 105px;
    margin-right: 10px;
  }
  #product .footer_fixed ul.flex-container li.flex-item:last-child {
    margin-right: 0;
  }
 
  /* 孫要素 */
  #product .footer_fixed ul.flex-container li.flex-item a {
    padding: 15px 4px;
    font-size: 15px;
    }
  /* Web フォント icon 装飾*/
  .footer_fixed .material-icons {
    margin-right: 3px;
  }

  /*
    #product footer > div,
    footer#product > div {
      padding: 0;
    }
    
    #product footer,
    footer#product {
     padding-bottom: 0;
    }

    #product .footer_fixed {
      position: fixed;
      left: 0;
      bottom: 0;
      width: 100%;
      margin: 0 auto;
      height: auto;
      background: #292929;
      z-index: 100;
    }
  
     親要素(コンテナ) 
    #product .footer_fixed ul.flex-container {
      display: flex;
      width: 100%;
      height: 100%;
      margin: auto;
      font-size: 120%;
      font-weight: bold;

      -webkit-box-orient: vertical; 
      -webkit-box-direction: normal;
         -ms-flex-direction: column;
             flex-direction: column;  垂直並び                              
      }
  
     子要素(アイテム) 
    #product .footer_fixed ul.flex-container li.flex-item {
      display: flex;
      align-self: auto;
      flex: 1;
      max-width: 100%;
      min-width: 0;
    }
  
     孫要素 
    #product .footer_fixed ul.flex-container li.flex-item a {
      display: flex;
      width: 100%;

      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;   センタリング 

      -webkit-box-align: stretch;
      -ms-flex-align: stretch;
         align-items: stretch;
      
      margin: 0;
      padding: 0.5em ;
      box-sizing: border-box;
      position: relative;
      text-decoration: none;
      text-align: center;
      word-break: break-all;
      transition: 0.3s all ease;
      background-color: #df0623;
      color: #fff;
    }

     */
}
/*-------------------------------------------------------------------------------------------------------*/
#top section h3 {
  margin: 0 0 40px 0;
  padding: 0 10px;
}
#top section h3 em {
  display: block;
  margin: 0 0 5px 0;
  font-size: 50px;
  font-weight: 600;
  line-height: 1.2em;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#top section h3 span {
  display: block;
  font-size: 18px;
  line-height: 1.5em;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*--------edit trialpage smartphone-ipad--0311-------chin----*/
@media screen and (max-width: 1405px) {
  .recruit-details-entry > ul > li {
    max-width: 364px;
    width: calc(50% - 10px);
    margin: 0 0 45px 0;
  }
}
@media screen and (max-width: 1024px) {
  .recruit-details-entry p {
    margin: 0 0 20px 0;
    font-size: 24px;
    line-height: 2em;
  }
  .recruit-details-entry > ul > li {
    max-width: 364px;
    width: calc(90% - 10px);
    margin: 0 0 60px 0;
  }
  .recruit-details-btn a span, .recruit-details-btn button span {
    display: block;
    font-size: 18px;
  }
  .recruit-details-btn a span:before, .recruit-details-btn button span:before {
    top: 58px;
    width: 28px;
    height: 2px;
  }
  .recruit-details-btn a span:after, .recruit-details-btn button span:after {
    top: 55px;
    width: 15px;
    height: 2px;
  }
  .recruit-details-btn span {
    font-size: 16px;
  }
}
@media screen and (max-width: 768px) { 
  .scale-img2 {
    width: 90vw;
    height: auto;
  }
  .recruit-details-entry {
    padding: 80px 10px;
  }
  .recruit-ttl {
    margin: 0 0 60px 0;
  }
  .recruit-ttl em {
    display: block;
    margin: 0 0 10px 0;
    font-size: 50px;
    font-weight: 600;
    font-family: 'Lato', sans-serif;
  }
  .recruit-ttl span {
    font-size: 18px;
    color: #df0623 !important;
  }
  .recruit-ttl-w {
    color: #fff !important;
  }
  .recruit-details-entry p {
    margin: 0 0 20px 0;
    font-size: 26px;
    line-height: 2em;
    letter-spacing: 1px;
  }
  .recruit-details-entry > ul {
    display: flex;
    justify-content: space-around;
    align-items: flex-start;
    flex-wrap: wrap;
    max-width: initial;
    width: 80%;
    margin: 0 auto;
  }
  .recruit-details-entry > ul > li {
    max-width: 364px;
    width: calc(70% - 10px);
    margin: 0 0 60px 0;
  }
  .recruit-details-entry > ul > li a {
    transition: opacity .3s ease;
  }
  .recruit-details-entry > ul > li a img {
    width: 100%;
  }
  .recruit-details-entry > div {
    max-width: 364px;
    width: 100%;
    margin: 0 auto;
  }
  .recruit-details-entry > div a {
    transition: opacity .3s ease;
  }
  .recruit-details-entry > div a img {
    width: 100%;
  }
  .recruit-details-btn {
    max-width: 364px;
    width: 100%;
    height: 78px;
    margin: 0 auto;
    color: #df0623 !important;
  }
  .recruit-details-btn a, .recruit-details-btn button {
    display: block;
    width: 100%;
    height: 100%;
    padding: 0;
    overflow: hidden;
    position: relative;
    background: #fff;
    border: 0;
    cursor: pointer;
    color: #df0623 !important;
    font-family: 'Lato', sans-serif;
  }
  .recruit-details-btn a:disabled, .recruit-details-btn button:disabled {
    opacity: .5;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
    cursor: default;
    pointer-events: none;
  }
  .recruit-details-btn a:before, .recruit-details-btn button:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
    width: 100%;
    height: 100%;
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    transition: opacity .3s ease-out, -webkit-transform .3s ease-out;
    transition: transform .3s ease-out, opacity .3s ease-out;
    transition: transform .3s ease-out, opacity .3s ease-out, -webkit-transform .3s ease-out;
    background: #df0623 !important;
  }
  .recruit-details-btn a:focus, .recruit-details-btn button:focus {
    outline: none;
  }
  .recruit-details-btn a span, .recruit-details-btn button span {
    display: block;
    width: 100%;
    height: 100%;
    padding: 27px 0 0 27px;
    font-size: 20px;
    font-weight: 600;
    line-height: 1em;
    text-align: left;
    position: relative;
    z-index: 1;
    border: 1px solid;
    transition: color .3s ease, border-color .6s ease;
    border-color: #df0623 !important;
  }
  .recruit-details-btn a span:before, .recruit-details-btn button span:before {
    content: "";
    position: absolute;
    top: 38px;
    right: 38px;
    width: 26px;
    height: 1px;
    background: #df0623 !important;
    transition: background .2s ease-out, -webkit-transform .2s ease-out;
    transition: background .2s ease-out, transform .2s ease-out;
    transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
  }
  .recruit-details-btn a span:after, .recruit-details-btn button span:after {
    content: "";
    position: absolute;
    top: 36px;
    right: 37px;
    width: 8px;
    height: 1px;
    -webkit-transform: rotate(25deg);
    transform: rotate(25deg);
    background: #df0623 !important;
    transition: background .2s ease-out, -webkit-transform .2s ease-out;
    transition: background .2s ease-out, transform .2s ease-out;
    transition: background .2s ease-out, transform .2s ease-out, -webkit-transform .2s ease-out;
  }
}
@media screen and (max-width: 375px) {
  .scale-img2 {
    width: 90vw;
    height: auto;
  }
  .scale-img {
    width: 370px;
    height: auto;
  }
  .recruit-details-entry p {
    margin: 0 0 20px 0;
    font-size: 24px;
    line-height: 2em;
  }
  .recruit-details-entry > ul > li {
    max-width: 364px;
    width: calc(100% - 10px);
    margin: 0 0 60px 0;
  }
  .recruit-details-btn a span, .recruit-details-btn button span {
    display: block;
    font-size: 18px;
  }
  .recruit-details-btn a span:before, .recruit-details-btn button span:before {
    top: 58px;
    width: 28px;
    height: 2px;
  }
  .recruit-details-btn a span:after, .recruit-details-btn button span:after {
    top: 55px;
    width: 15px;
    height: 2px;
  }
  .recruit-details-btn span {
    font-size: 14px;
  }
  #product .about div {
    width: 100%;
    padding: 30px 10px;
  }
}
/*------------------------------------------------end -------------------------------*/
/*------h3 change to h2 -------edit by chin-------------------------------------------*/
#top section h2 {
  margin: 0 0 40px 0;
  padding: 0 10px;
}
#top section h2 em {
  display: block;
  margin: 0 0 5px 0;
  font-size: 50px;
  font-weight: 600;
  line-height: 1.2em;
  letter-spacing: 3px;
  font-family: 'Lato', sans-serif;
}
#top section h2 span {
  display: block;
  font-size: 18px;
  line-height: 1.5em;
  letter-spacing: 3px;
  color: #df0623 !important;
}
/*-----------------------------------------------------------------------------------*/
#top .top-header {
  height: 580px;
  overflow: hidden;
  position: relative;
}
#top .top-header:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100%;
  background: url(/img/top/top_kv.jpg) center center no-repeat;
  background-size: cover;
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  -webkit-animation: 2s topKvBg ease forwards .5s;
  animation: 2s topKvBg ease forwards .5s;
}
#top .top-header h2 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 0;
  height: 100%;
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  overflow: hidden;
  -webkit-animation: 1.5s topKv ease forwards 1s;
  animation: 1.5s topKv ease forwards 1s;
}
#top .top-header h2 > div {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100vw;
  margin: -100px 0 0 0;
  text-align: left;
}
#top .top-header h2 > div > div {
  margin: 0 0 0 50vw;
}
#top .top-header h2 > div > div img {
  width: 541px;
}
#top .top-topic {
  padding: 80px 0;
}
#top .top-topic ul {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  /* li センター寄せ */
  justify-content: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  /* li 等間隔
  justify-content: space-between; 
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
   */
  align-items: stretch;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto 60px;
}
#top .top-topic ul li {
  width: calc(100% / 3);
  background: #f5f5f5;
  border-right: 1px solid #fff;
}
#top .top-topic ul li:last-of-type {
  border-right: 0;
}
#top .top-topic ul li a {
  display: block;
  width: 100%;
  height: 100%;
  padding: 40px 20px 20px;
  position: relative;
  transition: opacity .3s ease;
}
#top .top-topic ul li a:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 30px;
  right: 40px;
  width: 36px;
  height: 1px;
  z-index: 1;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#top .top-topic ul li a:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 32px;
  right: 40px;
  width: 8px;
  height: 1px;
  z-index: 1;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#top .top-topic ul li a figure {
  max-width: 390px;
  width: 100%;
  margin: 0 auto;
  padding: 0 10px;
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  position: relative;
}
#top .top-topic ul li a figure > div {
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  position: relative;
}
#top .top-topic ul li a figure > div:before {
  content: "";
  display: block;
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: -1;
  width: calc(100% + 20px);
  height: calc(100% + 20px);
  background: url(/img/top/top_topic_bdr.svg) top left no-repeat;
  background-size: 100% auto;
}
#top .top-topic ul li a figure > div img {
  width: 100%;
  position: relative;
  z-index: 1;
}


/* 資料イメージ縦型の場合*/
#top .top-topic ul li a figure > div.portrait-format {
  font-size: 0;
  line-height: 0;
  letter-spacing: 0;
  position: relative;
}
#top .top-topic ul li a figure > div.portrait-format:before {
  content: "";
  display: block;
  position: absolute;
  top: -10px;
  left: -10px;
  z-index: -1;
  width: calc(100% + 20px);
  height: calc(100% + 20px);
  /* background: url(/img/top/top_topic_bdr.svg) top left no-repeat; 
    background-size: 100% auto; */
  background: none;
}

#top .top-topic ul li a figure > div.portrait-format img {
  width: 100%;
  position: relative;
  z-index: 1;
}

#top .top-topic ul li a figure figcaption {
  margin: 20px 0 0 0;
  padding: 0 60px 0 0;
  letter-spacing: normal;
  text-align: left;
  color: #000;
  position: relative;
}
#top .top-topic ul li a figure figcaption time {
  display: block;
  font-size: 16px;
  line-height: 1.5em;
}
#top .top-topic ul li a figure figcaption span {
  display: block;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5em;
}
#top .top-topic ul li a > div {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  pointer-events: none;
  transition: opacity .3s ease;
}
#top .top-topic ul li a > div > div {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  padding: 0 40px;
  text-align: left;
  color: #fff;
}
#top .top-topic ul li a > div > div h4 {
  margin: 0 0 15px 0;
  font-size: 26px;
  font-weight: 600;
  line-height: 1.5em;
}
#top .top-topic ul li a > div > div p {
  font-size: 18px;
  line-height: 1.5em;
}
#top .top-topic ul li a > div > div p span {
  display: block;
  font-size: 16px;
}
/*---------edit chin SDGs -------------------*/
/*---------repair by harada 20210519 --------*/
#top .top-sdgs {
  background: #f5f5f5;
  padding: 80px 0;
}
#top .top-sdgs .wrap {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  flex-direction: row;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
  padding: 20px 10px 60px 10px;
}
#top .top-sdgs .wrap .box1, #top .top-sdgs .wrap .box2 {
  max-width: 580px;
  width: calc(50% - 5px);
}
#top .top-sdgs .wrap .box2 {
  padding-top: 15px;
}
#top .top-sdgs .wrap .box1 img {
  width: 100%;
}
#top .top-sdgs .wrap .box2 img {
  width: 100%;
}
#top .top-sdgs .wrap .box2 h3 {
  display: block;
  font-size: 18px;
  line-height: 1.5em;
  /* letter-spacing: 3px; */
  margin: 5px 0 0 0;
  padding: 0;
}
#top .top-sdgs .details-btn {
  margin: 0 auto 0;
}
#top .top-sdgs .details-btn a, #top .top-sdgs .details-btn button {
  background: #49c0f0;
}
/* Index topic area */
#top .top-topic .button-area {
  display: flex;
  flex-direction: column;
  margin: 0 auto 20px;
  max-width: 1400px;
  width: 100%;
}
#top .top-topic .button-area .details-btn {
  max-width: 380px;
  width: 100%;
  margin-bottom: 15px;
}
#top .top-topic .button-area .details-btn:last-child {
  margin-bottom: 0;
}
#top .top-topic .button-area .details-btn:nth-child(3) a {
  background: #1877f2;
  color: #fff;
}
#top .top-topic .button-area .details-btn:nth-child(3) a img {
  margin-left: 10px;
  vertical-align: bottom;
  width: 25px;
  height: 25px;
}
@media screen and (max-width: 768px) { 
  #top .top-sdgs {
    background: #f5f5f5;
    padding: 60px 10px;
  }
  #top .top-sdgs .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    max-width: 748px;
    width: 100%;
    margin: 0 auto;
    padding: 20px 0;
  }
  #top .top-sdgs .wrap .box1, #top .top-sdgs .wrap .box2 {
    max-width: 580px;
    width: 100%;
    margin: 0 auto 30px;
  }
  #top .top-sdgs .wrap .box2 {
    margin-top: 30px;
  }
  #top .top-sdgs .details-btn {
    margin: 0 auto 30px;
  }
}
/*---------------edit chin SDGs smartphone -------------*/
#top .details-sdgs {
  background: #f5f5f5;
  padding: 20px 0px;
}
#top .details-sdgs .wrop {
  padding: 5px 0px;
  display: block;
  margin: 20px 0 40px;
  justify-content: center;
}
#top .details-sdgs .wrop .box1, #top .details-sdgs .wrop .box2 {
  width: 375px;
  height: 250px;
  font-size: 18px;
  margin: 5px;
  text-align: center;
}
#top .details-sdgs .box1 img {
  width: 100vw;
}
#top .details-sdgs .box2 img {
  width: 85vw;
}
#top .details-sdgs .box2 > p {
  font-size: 20px;
  text-align: left;
  width: 370px;
}
/*-------------------20200304-------*/
/*--------------------20200404----------------*/
@media screen and (min-width: 769px) {
  #top .top-topic ul li a:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  #top .top-topic ul li a:hover:before {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  #top .top-topic ul li a:hover:after {
    -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
    transform: translate3d(10px, 0, 0) rotate(25deg);
  }
  #top .top-topic ul li a:hover > div {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
}
#top .top-topic ul .top-topic-new a figure:after {
  content: "- NEW -";
  display: block;
  position: absolute;
  top: -10px;
  left: 20px;
  z-index: 1;
  width: 70px;
  height: 28px;
  padding: 6px 0 0 0;
  font-size: 14px;
  line-height: 1em;
  color: #fff;
  background: #df0623 !important;
}
#top .top-topic > div {
  padding: 0 10px;
}
#top .top-topic > div .details-btn {
  margin: 0 auto;
}
#top .top-business {
  padding: 80px 10px 100px;
  background: #1c354a;
  overflow: hidden;
}
#top .top-business h3 {
  margin: 0 0 60px 0;
}
#top .top-business h3 em {
  margin: 0 0 20px 0;
}
#top .top-business h3 em, #top .top-business h3 span {
  color: #fff !important;
}
/*------h3 change to h2 -------edit by chin-------------------------------------------*/
#top .top-business h2 {
  margin: 0 0 60px 0;
}
#top .top-business h2 em {
  margin: 0 0 20px 0;
}
#top .top-business h2 em, #top .top-business h2 span {
  color: #fff !important;
}
/*--------------------------------------------------------------------------*/
#top .top-business ul {
  position: relative;
}
#top .top-business ul .slick-list {
  overflow: visible;
}
#top .top-business ul .slider-prev, #top .top-business ul .slider-next {
  transition: opacity .3s ease;
}
@media screen and (min-width: 769px) {
  #top .top-business ul .slider-prev:hover, #top .top-business ul .slider-next:hover {
    opacity: .5;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  }
}
#top .top-business ul .slider-prev {
  display: block;
  position: absolute;
  top: -95px;
  right: 140px;
  z-index: 1;
  width: 40px;
  height: 40px;
  background: #fff;
  cursor: pointer;
}
#top .top-business ul .slider-prev:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 16px;
  width: 15px;
  height: 15px;
  border: solid;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(-135deg);
  transform: translate3d(0, -50%, 0) rotate(-135deg);
  border-color: #df0623 !important;
}
#top .top-business ul .slider-next {
  display: block;
  position: absolute;
  top: -95px;
  right: 100px;
  z-index: 1;
  width: 40px;
  height: 40px;
  cursor: pointer;
  background: #df0623 !important;
}
#top .top-business ul .slider-next:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 16px;
  width: 15px;
  height: 15px;
  border: solid #fff;
  border-width: 2px 2px 0 0;
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: translate3d(0, -50%, 0) rotate(45deg);
  transform: translate3d(0, -50%, 0) rotate(45deg);
}
#top .top-business ul li {
  width: 260px;
  margin: 0 20px;
}
#top .top-business ul li a {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
}
#top .top-business ul li a span {
  position: absolute;
  top: -10px;
  left: -10px;
  -webkit-transform: translate3d(0, 0, 1px);
  transform: translate3d(0, 0, 1px);
  z-index: 11;
  display: block;
  width: 50px;
  height: 50px;
  padding: 13px 0 0 0;
  background: #1c354a;
  box-shadow: 3px 3px 0 0 #0075c0;
  border: 1px solid #fff;
  font-size: 20px;
  font-weight: 600;
  font-style: italic;
  color: #fff;
  font-family: 'Lato', sans-serif;
}
#top .top-business ul li a figure img {
  width: 100%;
}
#top .top-business ul li a > div {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 117, 192, 0.9);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  pointer-events: none;
  transition: opacity .3s ease;
}
#top .top-business ul li a > div:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 30px;
  right: 30px;
  width: 36px;
  height: 1px;
  z-index: 1;
  background: #fff;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
}
#top .top-business ul li a > div:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 32px;
  right: 30px;
  width: 8px;
  height: 1px;
  z-index: 1;
  background: #fff;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
}
#top .top-business ul li a > div > div {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  width: 100%;
  padding: 0 40px;
  text-align: left;
  color: #fff;
}
#top .top-business ul li a > div > div h4 {
  margin: 0 0 15px 0;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
  text-align: center;
}
/*---h4 change to h3 ---edit by chin------------------------------------*/
#top .top-business ul li a > div > div h3 {
  margin: 0 0 15px 0;
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5em;
  text-align: center;
}
/*---------------------------------------------------------------------*/
#top .top-business ul li a > div > div p {
  font-size: 18px;
  line-height: 1.5em;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #top .top-business ul li a:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  #top .top-business ul li a:hover > div {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
  #top .top-business ul li a:hover > div:before {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  #top .top-business ul li a:hover > div:after {
    -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
    transform: translate3d(10px, 0, 0) rotate(25deg);
  }
}
#top .top-product {
  padding: 80px 10px;
  background: url(/img/top/top_contents_bg.jpg) bottom center no-repeat;
  background-size: 100% auto;
}
#top .top-product .top-product-toggle {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 0 40px 0;
}
#top .top-product .top-product-toggle li {
  margin: 0 10px 10px 0;
}
#top .top-product .top-product-toggle li:last-of-type {
  margin: 0 0 10px 0;
}
#top .top-product .top-product-toggle li span {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 10px 20px 12px;
  background: #ddd;
  font-size: 18px;
  line-height: 1.5em;
  cursor: pointer;
  transition: opacity .3s ease;
}
@media screen and (min-width: 769px) {
  #top .top-product .top-product-toggle li span:hover {
    opacity: .5;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
  }
}
#top .top-product .top-product-toggle li .top-product-toggle-current {
  background: #292929;
  color: #fff;
  cursor: default;
  pointer-events: none;
}
#top .top-product .top-product-toggle li .top-product-toggle-current:hover {
  opacity: 1;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}
#top .top-product .top-product-list {
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -ms-flex-align: stretch;
  -webkit-align-items: stretch;
  align-items: stretch;
  -ms-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  max-width: 1180px;
  width: 100%;
  margin: 0 auto;
}
#top .top-product .top-product-list li {
  max-width: 580px;
  width: calc(50% - 10px);
  margin: 0 0 20px 0;
}
#top .top-product .top-product-list li > a {
  display: block;
  width: 100%;
  position: relative;
  transition: opacity .3s ease;
}
#top .top-product .top-product-list li > a:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 30px;
  right: 30px;
  width: 36px;
  height: 1px;
  z-index: 1;
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#top .top-product .top-product-list li > a:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 32px;
  right: 30px;
  width: 8px;
  height: 1px;
  z-index: 1;
  -webkit-transform: rotate(25deg);
  transform: rotate(25deg);
  transition: -webkit-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease;
  background: #df0623 !important;
}
#top .top-product .top-product-list li > a figure {
  width: 100%;
  position: relative;
}
#top .top-product .top-product-list li > a figure img {
  width: 100%;
}
#top .top-product .top-product-list li > a figure figcaption {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0) translateY(-20px);
  transform: translate3d(0, -50%, 0) translateY(-20px);
  width: 100%;
  font-size: 30px;
  font-weight: 600;
  color: #000;
}
#top .top-product .top-product-list li > a figure figcaption:before {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 20px);
  left: 50%;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  width: 140px;
  height: 10px;
  background: url(/img/common/details_bdr.png) top center no-repeat;
  background-size: 140px 10px;
}
#top .top-product .top-product-list li > a > div {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  opacity: 0;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  pointer-events: none;
  transition: opacity .3s ease;
}
#top .top-product .top-product-list li > a > div > div {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate3d(0, -50%, 0);
  transform: translate3d(0, -50%, 0);
  width: 100%;
  padding: 0 40px;
  text-align: left;
  color: #fff;
}
#top .top-product .top-product-list li > a > div > div h4 {
  margin: 0 0 20px 0;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}
/*---h4 change to h3 ---edit by chin -------------------------------------*/
#top .top-product .top-product-list li > a > div > div h3 {
  margin: 0 0 20px 0;
  font-size: 26px;
  font-weight: 600;
  text-align: center;
}
/*-------------------------------------------------------------------------*/
#top .top-product .top-product-list li > a > div > div p {
  max-width: 340px;
  width: 100%;
  margin: 0 auto;
  font-size: 18px;
  line-height: 1.5em;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #top .top-product .top-product-list li > a:hover {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
  }
  #top .top-product .top-product-list li > a:hover:before {
    -webkit-transform: translate3d(10px, 0, 0);
    transform: translate3d(10px, 0, 0);
  }
  #top .top-product .top-product-list li > a:hover:after {
    -webkit-transform: translate3d(10px, 0, 0) rotate(25deg);
    transform: translate3d(10px, 0, 0) rotate(25deg);
  }
  #top .top-product .top-product-list li > a:hover > div {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
}
@media screen and (max-width: 1040px) {
  #top .top-header h2 > div > div {
    margin: 0 0 0 20px;
  }
}
@media screen and (max-width: 768px) { 
  #top section h3 {
    margin: 0 0 30px 0;
  }
  #top section h3 em {
    font-size: 40px;
  }
  #top section h3 span {
    font-size: 16px;
  }
  #top .top-header {
    height: auto;
  }
  #top .top-header h2 {
    padding: 20vw 20px 12vw;
    position: static;
  }
  #top .top-header h2 > div {
    position: static;
    margin: 0;
  }
  #top .top-header h2 > div > div {
    margin: 0;
  }
  #top .top-header h2 > div > div > img {
    width: calc(100vw - 60px);
  }
  #top .top-topic {
    padding: 60px 0;
  }
  #top .top-topic ul {
    display: block;
    margin: 0 auto 40px;
  }
  #top .top-topic ul li {
    width: 100%;
    border-right: 0;
    border-bottom: 1px solid #fff;
  }
  #top .top-topic ul li:last-of-type {
    border-bottom: 0;
  }
  #top .top-topic ul li a {
    padding: 30px 10px 60px;
  }
  #top .top-topic ul li a:before {
    bottom: 30px;
    right: 10px;
  }
  #top .top-topic ul li a:after {
    content: "";
    bottom: 32px;
    right: 10px;
  }
  #top .top-topic ul li a figure figcaption {
    margin: 30px 0 0 0;
    padding: 0;
  }
  #top .top-topic ul li a figure figcaption time {
    margin: 0 0 10px 0;
    font-size: 16px;
  }
  #top .top-topic ul li a figure figcaption span {
    margin: 0 0 10px 0;
    font-size: 26px;
  }
  #top .top-topic ul li a > div {
    position: static;
    max-width: 390px;
    margin: 0 auto;
    padding: 0 10px;
    background: transparent;
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
  #top .top-topic ul li a > div > div {
    position: static;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    padding: 0;
    color: #000;
  }
  #top .top-topic ul li a > div > div h4 {
    display: none;
  }
  #top .top-topic ul li a > div > div p {
    font-size: 16px;
  }
  #top .top-topic ul li a > div > div p span {
    display: none;
  }
  #top .top-business {
    padding: 60px 10px;
  }
  #top .top-business h3 {
    margin: 0 0 40px 0;
  }
  #top .top-business h3 span {
    display: block;
    max-width: 400px;
    width: 100%;
    margin: 0 auto;
    text-align: left;
  }
  #top .top-business ul .slider-prev {
    right: 40px;
  }
  #top .top-business ul .slider-next {
    right: 0;
  }
  #top .top-business ul li {
    max-width: 260px;
    width: 75vw;
  }
  #top .top-business ul li a {
    padding: 0 0 30px 0;
  }
  #top .top-business ul li a > div {
    position: static;
    background: transparent;
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
  #top .top-business ul li a > div:before {
    bottom: 0;
    right: 0;
  }
  #top .top-business ul li a > div:after {
    bottom: 2px;
    right: 0;
  }
  #top .top-business ul li a > div > div {
    position: static;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    padding: 15px 0 0 0;
  }
  #top .top-business ul li a > div > div h4 {
    display: none;
  }
  #top .top-business ul li a > div > div p {
    font-size: 16px;
  }
}
@media screen and (max-width: 768px) and (max-width: 600px) {
  #top .top-business ul .slider-prev, #top .top-business ul .slider-next {
    top: 50%;
    margin: -20px 0 0 0;
    background: transparent !important;
  }
  #top .top-business ul .slider-prev {
    left: -10px;
  }
  #top .top-business ul .slider-next {
    right: -10px;
  }
  #top .top-business ul li {
    margin: 0 15vw;
  }
}
@media screen and (max-width: 768px) { 
  #top .top-product {
    padding: 60px 10px;
    background: linear-gradient(to top, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)), url(/img/top/top_contents_bg.jpg) bottom center no-repeat;
    background-size: 100% auto;
  }
  #top .top-product .top-product-toggle {
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin: 0 0 20px 0;
  }
  #top .top-product .top-product-toggle li {
    width: calc(50% - 5px);
    margin: 0 0 10px 0;
  }
  #top .top-product .top-product-toggle li:last-of-type {
    margin: 0 0 10px 0;
  }
  #top .top-product .top-product-toggle li span {
    padding: 10px 10px 12px;
    font-size: 16px;
  }
}
@media screen and (max-width: 768px) and (max-width: 600px) { 
  #top .top-product .top-product-toggle li {
    width: 100%;
  }
}
@media screen and (max-width: 768px) { 
  #top .top-product .top-product-list {
    display: block;
  }
  #top .top-product .top-product-list li {
    max-width: 580px;
    width: 100%;
    margin: 0 auto 30px;
  }
  #top .top-product .top-product-list li:last-of-type {
    margin: 0 auto;
  }
  #top .top-product .top-product-list li > a {
    padding: 0 0 30px 0;
  }
  #top .top-product .top-product-list li > a:before {
    bottom: 0;
    right: 0;
  }
  #top .top-product .top-product-list li > a:after {
    bottom: 2px;
    right: 0;
  }
  #top .top-product .top-product-list li > a figure figcaption {
    font-size: 26px;
  }
  #top .top-product .top-product-list li > a figure figcaption:before {
    top: calc(100% + 10px);
  }
  #top .top-product .top-product-list li > a > div {
    position: static;
    background: transparent;
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    pointer-events: auto;
  }
  #top .top-product .top-product-list li > a > div > div {
    position: static;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    padding: 15px 0 0;
    color: #000;
  }
  #top .top-product .top-product-list li > a > div > div h4 {
    display: none;
  }
  #top .top-product .top-product-list li > a > div > div p {
    max-width: 100%;
    font-size: 16px;
  }
}
/* ページ内リンク（Jump）Jumpボタン設置*/
section.jump-btn {
  width: 100%;
  margin: 0 auto;
  height: 50px;
}
section.jump-btn ul {
  /* liを横並び */
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  /* 両端揃え均等割 */
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  max-width: 1180px;
  width: 100%;
  height: 50px;
  margin: 0 auto;
}
section.jump-btn ul li {
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  width: calc(1180px / 6);
  font-family: 'Lato', sans-serif;
  font-weight: 600;
  font-size: 18px;
  vertical-align: middle;
}
section.jump-btn ul.point-5 li {
  width: calc(1180px / 5);
}
section.jump-btn ul li a {
  display: inline-block;
  padding: 15px 0 3px 0;
  height: auto;
  border-bottom: 1px dotted #df0623;
  color: rgba(0, 0, 0, 1.0);
}
section.jump-btn ul li a::before {
  font-family: Material Icons;
  content: "chevron_right"; /* 使用するアイコン名 */
  font-size: 18px; /* アイコンのサイズ */
  /* top: 5px; アイコンの位置調整 */
  /* left: 5px; アイコンの位置調整 */
  color: #df0623; /* アイコンのカラー */
}
@media screen and (max-width: 768px) {
  section.jump-btn {
    max-width: 768px;
    width: 100%;
    margin: 10px auto;
    height: auto;
  }
  section.jump-btn ul {
    width: 90%;
    height: auto;
    margin: 0 auto;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -ms-flex-pack: start;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    -ms-flex-align: start;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    -ms-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  section.jump-btn ul li, section.jump-btn ul.point-5 li {
    width: 45%;
    height: 25px;
    margin: 0 3px 5px 3px;
    font-weight: bold;
    font-size: 13px;
    vertical-align: middle;
    align-items: center;
    text-align: left;
  }
  section.jump-btn ul li a {
    display: inline-block;
    padding: 0;
  }
  section.jump-btn ul li a::before {
    font-size: 13px; /* アイコンのサイズ */
    /* top: 5px; アイコンの位置調整 */
    /* left: 5px; アイコンの位置調整 */
  }
}
/* 別ウィンドウアイコン設置
a[href^="http"]:after ,
a[href^="//"]:after {
  content: '';
  display: inline-block;
  width: 18px;
  height: 18px;
  margin: -3px 0 0 10px;
  background: url("https://fonts.google.com/icons?selected=Material+Icons:open_in_new") no-repeat; 
  background-size: contain;
  vertical-align: middle;
}
a[href^="https://www.kcme.jp/"]:after {
  margin: inherit;
  font-family: inherit;
  content: '';
  font-weight: inherit;
}
*/

