/*--------------------------
color
---------------------------*/ /*--------------------------
main_visual
---------------------------*/
#main_visual .title_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 250px;
}
@media only screen and (max-width: 768px) {
  #main_visual .title_box {
    min-height: 180px;
  }
}
#main_visual .title_box span {
  display: inline-block;
  font-size: 32px;
  font-family: "Montserrat";
  font-weight: 600;
  margin: 0 0 8px;
  border-bottom: 1px solid;
}
#main_visual .title_box h1 {
  position: relative;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.4;
  text-align: center;
}
#main_visual .title_box h1::before {
  content: attr(data-en);
  display: block;
  font-size: 56px;
  font-family: "Montserrat";
  font-weight: 600;
}
@media only screen and (max-width: 768px) {
  #main_visual .title_box h1::before {
    font-size: 36px;
  }
}
#main_visual .title_box span {
  color: #ca0000;
  border-color: #ca0000;
}
#main_visual .visual_box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 350px;
  background-image: url(/jp/special/vnb-ept/asset/image/products/vnb-ept/main_visual.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  overflow-x: hidden;
}
@media only screen and (max-width: 768px) {
  #main_visual .visual_box {
    min-height: 120px;
  }
}

/*--------------------------
section01
---------------------------*/
#section01 {
  position: relative;
  padding: 60px 0;
}
@media only screen and (max-width: 768px) {
  #section01 {
    padding: 40px 0;
  }
}
#section01 .container .scroll_table {
  margin: 0 0 20px;
}
#section01 .container .scroll_table .scroll_table_wrap {
  position: relative;
}
#section01 .container .scroll_table .scroll_table_wrap::-webkit-scrollbar {
  height: 5px;
}
#section01 .container .scroll_table .scroll_table_wrap::-webkit-scrollbar-track {
  background: #F1F1F1;
}
#section01 .container .scroll_table .scroll_table_wrap::-webkit-scrollbar-thumb {
  background: #eee;
  border-radius: 50px;
}
@media only screen and (max-width: 768px) {
  #section01 .container .scroll_table .scroll_table_wrap {
    width: 100%;
    overflow: auto;
  }
}
@media only screen and (max-width: 768px) {
  #section01 .container .scroll_table .scroll_table_wrap table {
    min-width: 768px;
  }
  #section01 .container .scroll_table .scroll_table_wrap table tr th,
  #section01 .container .scroll_table .scroll_table_wrap table tr td {
    white-space: nowrap;
  }
}
#section01 .container .scroll_table .scroll_table_wrap .swipe {
  position: absolute;
  display: none;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  font-size: 16px;
  color: #fff;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  #section01 .container .scroll_table .scroll_table_wrap .swipe {
    display: block;
  }
}
#section01 .container .scroll_table .scroll_table_wrap .swipe span {
  position: absolute;
  top: 50%;
  left: 50%;
  color: #fff;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
}
#section01 .container .scroll_table .scroll_table_wrap table {
  width: 100%;
  table-layout: fixed;
  border: 2px solid #777;
}
#section01 .container .scroll_table .scroll_table_wrap table thead tr th {
  font-weight: 500;
  color: #fff;
  padding: 15px;
  border: 1px solid #fff;
  background: #ca0000;
}
@media only screen and (max-width: 768px) {
  #section01 .container .scroll_table .scroll_table_wrap table thead tr th {
    padding: 10px;
  }
}
#section01 .container .scroll_table .scroll_table_wrap table tbody tr th,
#section01 .container .scroll_table .scroll_table_wrap table tbody tr td {
  padding: 15px;
  border: 1px solid #777;
}
@media only screen and (max-width: 768px) {
  #section01 .container .scroll_table .scroll_table_wrap table tbody tr th,
  #section01 .container .scroll_table .scroll_table_wrap table tbody tr td {
    padding: 10px;
  }
}
#section01 .container .scroll_table .scroll_table_wrap table tbody tr th {
  font-weight: 500;
  text-align: left;
  background: rgba(0, 73, 134, 0.2);
}
#section01 .container .scroll_table .scroll_table_wrap table tbody tr td {
  text-align: center;
  background: #fff;
}
#section01 .container .scroll_table .scroll_table_wrap table tbody tr td a {
  display: block;
  color: #fff;
  padding: 8px 0;
  background: #ca0000;
}
#section01 .container .scroll_table .scroll_table_wrap table tbody tr td a:hover {
  opacity: 0.7;
}