
main {
  padding-top: 95px;
  color: #5c5c5c
}
@media only screen and (max-width:1000px) {
  main {
    padding-top: 60px
  }
}
main.corporate {
  padding-top: 85px;
  color: #5c5c5c
}
@media only screen and (max-width:1000px) {
  main.corporate {
    padding-top: 60px
  }
}
.visually-hidden {
  position: absolute;
  overflow: hidden;
  clip: rect(0 0 0 0);
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  white-space: nowrap;
  border: 0;
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%)
}
.section_title {
  display: flex;
  max-width: 1040px;
  margin: auto;
  padding: 0 20px;
  justify-content: space-between;
  align-items: center
}
.section_title h2 {
  font-size: 32px
}
@media only screen and (max-width:600px) {
  .section_title h2 {
    font-size: 21px
  }
}
.section_title a {
  font-size: 16px;
  position: relative;
  display: block;
  width: 150px;
  padding: 10px 40px 10px 10px;
  border: 1px solid #e7e7e7;
  background: #fff;
  color: #5c5c5c;
  text-align: right;
}
@media only screen and (max-width:600px) {
  .section_title a {
    display: none
  }
}
.section_title a:hover {
  text-decoration: underline;
  color: #e4032e
}
.section_title a:after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.sp_only-button {
  font-size: 16px;
  position: relative;
  display: block;
  width: calc(100% - 40px);
  margin: 36px 20px 67px;
  padding: 10px 30px 10px 20px;
  border: 1px solid #e7e7e7;
  background: #fff
}
@media only screen and (min-width:601px) {
  .sp_only-button {
    display: none
  }
}
.sp_only-button:after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
:focus {
  outline: none
}
.swiper-wrapper {
  width: 100%
}
.swiper-slide {
  position: relative;
  z-index: -1;
  display: block
}
@media only screen and (max-width:768px) {
  .swiper-slide {
    height: auto
  }
}
.swiper-slide img {
  width: 100%
}
.swiper-slide_detail {
  position: absolute;
  z-index: 100;
  right: 20px;
  bottom: 20px;
  opacity: .9;
  color: #5c5c5c;
}
@media only screen and (max-width:768px) {
  .swiper-slide_detail {
    position: relative;
    right: 0;
    bottom: 0;
    opacity: 1
  }
}
.swiper-slide_number {
  position: relative;
  display: flex;
  width: 100%;
  max-width: 170px;
  margin: 15px auto 0;
  padding: 0 20px;
  justify-content: center
}
.swiper-slide_number .swiper-button-prev {
  top: 0;
  bottom: 0;
  width: 25px;
  height: 25px;
  margin: auto;
  cursor: pointer;
  background: #e4032e
}
.swiper-slide_number .swiper-button-prev:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 4.5px;
  width: 9px;
  height: 9px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff
}
.swiper-slide_number .swiper-button-next {
  top: 0;
  bottom: 0;
  width: 25px;
  height: 25px;
  margin: auto;
  cursor: pointer;
  background: #e4032e
}
.swiper-slide_number .swiper-button-next:after {
  position: absolute;
  top: 0;
  right: 4.5px;
  bottom: 0;
  left: 0;
  width: 9px;
  height: 9px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff
}
.swiper-slide_number p {
  font-size: 1.4rem
}
.swiper-slide_element {
  position: relative;
  width: 630px;
  padding: 20px 25px;
  background: #fff
}
@media only screen and (max-width:768px) {
  .swiper-slide_element {
    width: 100%;
    padding: 20px 20px 30px;
    border-bottom: 1px solid #e7e7e7
  }
}
@media only screen and (max-width:414px) {
  .swiper-slide_element {
    padding: 20px 15px 25px
  }
}
.swiper-slide_element h2 {
  font-size: 2.2rem;
  overflow: hidden;
  margin: 0 0 3px;
  white-space: nowrap;
  text-overflow: ellipsis
}
@media only screen and (max-width:768px) {
  .swiper-slide_element h2 {
    font-size: 2.2rem
  }
}
.swiper-slide_text {
  font-size: 1.4rem;
  height: 3em
}
@media only screen and (max-width:768px) {
  .swiper-slide_text {
    overflow: hidden;
    height: 4.5em
  }
}
.swiper-slide_text:after {
  display: inline-block;
  width: 9px;
  height: 9px;
  margin-left: 5px;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.news-area {
  border-bottom: 1px solid #e7e7e7
}
.news-area_wrap {
  font-size: 16px;
  display: flex;
  max-width: 1040px;
  margin: auto;
  padding: 20px;
  flex-wrap: wrap;
  justify-content: space-between
}
@media only screen and (max-width:768px) {
  .news-area_wrap {
    display: block
  }
}
.news-area_title {
  display: inline-block;
  margin-right: 15px;
  padding-right: 15px;
  border-right: 1px solid #e7e7e7
}
@media only screen and (max-width:768px) {
  .news-area_title {
    margin-bottom: 9px;
    border-right: 0
  }
}
.news-area_body {
  margin-right: auto
}
.news-area_body .top-news_category, .news-area_body .top-news_title {
  display: none
}
.news-area_body .top-news_item {
  display: none;
  padding: 0 15px 0 0;
  color: #e4032e
}
@media only screen and (max-width:768px) {
  .news-area_body .top-news_item {
    flex-wrap: wrap
  }
}
.news-area_body .top-news_item:nth-of-type(2) {
  display: flex
}
.news-area_body .top-news_release {
  margin-right: 10px
}
.news-area_link {
  position: relative;
  display: inline-block;
  padding-right: 20px;
  color: #5c5c5c;
}
@media only screen and (max-width:768px) {
  .news-area_link {
    margin-top: 20px
  }
}
.news-area_link:hover {
  text-decoration: underline;
  color: #e40229
}
.news-area_link:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.search-area {
  max-width: 1240px;
  margin: 52px auto 80px;
  padding: 0 20px
}
@media only screen and (max-width:768px) {
  .search-area {
    margin: 47px auto 60px
  }
}
@media only screen and (max-width:600px) {
  .search-area {
    margin: 40px auto 45px
  }
}
.search-area_title {
  font-size: 24px;
  margin-bottom: 20px;
  text-align: center
}
.search-area .searchBlock {
  line-height: 1;
  position: relative;
  display: block;
  visibility: visible;
  float: none;
  width: 100%;
  max-width: 600px;
  margin: auto;
  padding: 0;
  opacity: 1
}
.search-area .gsc-input-box {
  font-size: 16px;
  width: calc(100% - 50px);
  height: 50px !important;
  padding: 15px 24px;
  border: 1px solid #e5e5e6;
  background: #f0f0f0
}
@media only screen and (max-width:600px) {
  .search-area .gsc-input-box {
    font-size: 12px
  }
}
.search-area .gsc-search-button input {
  position: absolute;
  top: 0;
  right: 0;
  width: 50px !important;
  height: 50px !important;
  padding: 15px !important;
  border: 1px solid #e40229;
  background: #e4022e
}
.lineup-area_nav {
  display: flex;
  max-width: 1000px;
  margin: 48px auto -1px
}
@media only screen and (max-width:600px) {
  .lineup-area_nav {
    margin: 36px auto -1px
  }
}
.lineup-area_nav-item {
  font-size: 17px;
  position: relative;
  width: 25%;
  padding: 17px;
  text-align: center;
  border-top: 1px solid #e7e7e7;
  border-left: 1px solid #e7e7e7;
  background-color: transparent;
}
@media only screen and (max-width:768px) {
  .lineup-area_nav-item {
    font-size: 16px
  }
}
@media only screen and (max-width:600px) {
  .lineup-area_nav-item {
    font-size: 13px;
    padding: 1em .25em
  }
}
.lineup-area_nav-item:last-of-type {
  border-right: 1px solid #e7e7e7
}
.lineup-area_nav-item[aria-selected=false]:hover {
  color: #e4032e
}
.lineup-area_nav-item[aria-selected=true] {
  color: #e4032e;
  border-bottom: 1px solid #f6f6f6;
  background: #f6f6f6
}
.lineup-area_nav-item[aria-selected=true]:after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  width: 30px;
  margin: auto;
  content: "";
  border-bottom: 2px solid #e4032e
}
.lineup-area_nav-item .sp_only {
  display: none
}
@media only screen and (max-width:600px) {
  .lineup-area_nav-item .sp_only {
    display: block
  }
}
.lineup-area_item-wrap {
  padding: 55px 20px 10px;
  border-top: 1px solid #e5e5e6;
  border-bottom: 1px solid #e5e5e6;
  background: #f6f6f6
}
@media only screen and (max-width:768px) {
  .lineup-area_item-wrap {
    padding: 50px 20px 20px
  }
}
@media only screen and (max-width:600px) {
  .lineup-area_item-wrap {
    padding: 36px 20px 10px
  }
}
.lineup-area_item {
  display: flex;
  max-width: 1000px;
  margin: auto
}
@media only screen and (max-width:768px) {
  .lineup-area_item {
    flex-wrap: wrap
  }
}
.lineup-area_item[hidden] {
  display: none
}
.lineup-area_item-link {
  width: 20%;
  margin-right: 10px;
  margin-bottom: 30px
}
@media only screen and (max-width:768px) {
  .lineup-area_item-link {
    width: calc(33.33333% - 7.5px)
  }
}
@media only screen and (max-width:600px) {
  .lineup-area_item-link {
    width: calc(50% - 5px)
  }
}
@media only screen and (max-width:600px) {
  .lineup-area_item-link:nth-of-type(2n) {
    margin-right: 0
  }
}
@media only screen and (max-width:768px) {
  .lineup-area_item-link:nth-of-type(3n) {
    margin-right: 0
  }
}
@media only screen and (max-width:600px) {
  .lineup-area_item-link:nth-of-type(3n) {
    margin-right: 10px
  }
}
@media only screen and (min-width:769px) {
  .lineup-area_item-link:nth-of-type(5) {
    margin-right: 0
  }
}
.lineup-area_item-link a:nth-of-type(2) {
  font-size: 16px;
  position: relative;
  display: block;
  margin-top: 10px;
  padding-left: 20px;
  color: #5c5c5c;
}
@media only screen and (max-width:600px) {
  .lineup-area_item-link a:nth-of-type(2) {
    font-size: 14px
  }
}
.lineup-area_item-link a:nth-of-type(2):before {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin: auto;
  margin-right: 10px;
  margin-left: -20px;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.lineup-area_item-link a:hover img {
  opacity: .7
}
.lineup-area_item-link a.lineup-area_item-link-text:hover {
  text-decoration: underline;
  color: #e40229
}
.lineup-area .sp_only-button {
  margin: 27px 20px 67px
}
.tool-area {
  display: flex;
  max-width: 1040px;
  margin: 50px auto 80px;
  padding: 0 20px;
  flex-wrap: wrap
}
@media only screen and (max-width:600px) {
  .tool-area {
    display: block;
    margin: 50px auto 45px
  }
}
.tool-area a {
  position: relative;
  display: flex;
  width: calc(33.33333% - 7.5px);
  margin-right: 10px;
  margin-bottom: 10px;
  padding: 15px 25px 15px 20px;
  border: 1px solid #e5e5e6;
  align-items: center;
  color: #5c5c5c;
}
@media only screen and (max-width:768px) {
  .tool-area a {
    width: calc(50% - 5px)
  }
}
@media only screen and (max-width:600px) {
  .tool-area a {
    width: 100%;
    padding: 5px 25px 5px 20px
  }
}
@media only screen and (max-width:768px) {
  .tool-area a:nth-of-type(2n) {
    margin-right: 0
  }
}
.tool-area a:nth-of-type(3n) {
  margin-right: 0
}
@media only screen and (max-width:768px) {
  .tool-area a:nth-of-type(3n) {
    margin-right: 10px
  }
}
.tool-area a:nth-of-type(6) {
  margin-right: 0
}
.tool-area a:after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.tool-area a:hover {
  text-decoration: underline;
  color: #e40229
}
.tool-area a img {
  margin-right: 10px
}
.tool-area a span {
  font-size: 16px
}
.data-area {
  display: flex;
  max-width: 1040px;
  margin: 50px auto 80px;
  padding: 0 20px;
  align-items: flex-start
}
@media only screen and (max-width:600px) {
  .data-area {
    margin: 45px auto 50px
  }
}
.data-area img {
  width: 160px
}
@media only screen and (max-width:600px) {
  .data-area img {
    width: 40%
  }
}
.data-area_wrap {
  padding: 0 0 0 20px
}
@media only screen and (max-width:600px) {
  .data-area_wrap {
    padding: 0 0 0 10px
  }
}
.data-area_wrap-title {
  font-size: 16px;
  font-weight: 700;
  position: relative;
  margin-bottom: 15px;
  padding-left: 20px
}
@media only screen and (max-width:600px) {
  .data-area_wrap-title {
    margin-bottom: 10px
  }
}
.data-area_wrap-title:before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 10px;
  height: 10px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.data-area_wrap-body {
  font-size: 16px;
  margin-bottom: 20px
}
@media only screen and (max-width:600px) {
  .data-area_wrap-body {
    font-size: 16px;
    display: none
  }
}
.data-area_wrap-link {
  position: relative;
  display: inline-block;
  padding-right: 50px;
  color: #e4032e
}
@media only screen and (max-width:768px) {
  .data-area_wrap-link {
    padding: 10px 50px 14px 20px;
    border: 1px solid #e5e5e6
  }
}
.data-area_wrap-link:after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  width: 20px;
  height: 21px;
  margin: auto;
  content: "";
  background: url(/common/img/icon_link-blank.svg)
}
.industry-area {
  margin-bottom: 80px
}
@media only screen and (max-width:600px) {
  .industry-area {
    padding: 0
  }
}
.industry-area .section_title {
  max-width: 1040px;
  margin: 50px auto 0;
  padding: 0 20px
}
@media only screen and (max-width:600px) {
  .industry-area .section_title {
    overflow: hidden;
    margin: 50px auto 0;
    padding: 0 30px
  }
}
.industry-area .sp_only-button {
  width: 100%;
  margin: 36px 0 67px
}
@media only screen and (max-width:600px) {
  .industry-area .sp_only-button {
    width: calc(100% - 40px);
    margin: 36px 20px 67px
  }
}
.swiper-industry-wrap {
  position: relative;
  overflow: hidden;
  max-width: 1380px;
  margin: 25px auto 0;
  padding: 0 90px
}
@media only screen and (max-width:768px) {
  .swiper-industry-wrap {
    padding: 0 20px
  }
}
.swiper-industry-wrap:before {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 90px;
  height: 100%;
  content: "";
  background: #fff;
  background: linear-gradient(90deg, #fff, hsla(0, 0%, 100%, 0))
}
@media only screen and (max-width:768px) {
  .swiper-industry-wrap:before {
    content: none
  }
}
.swiper-industry-wrap:after {
  position: absolute;
  z-index: 2;
  top: 0;
  right: 0;
  width: 90px;
  height: 100%;
  content: "";
  background: #fff;
  background: linear-gradient(90deg, hsla(0, 0%, 100%, 0), #fff)
}
@media only screen and (max-width:768px) {
  .swiper-industry-wrap:after {
    content: none
  }
}
.swiper-industry-button-next, .swiper-industry-button-prev {
  position: absolute;
  z-index: 3;
  top: 0;
  bottom: 0;
  width: 40px;
  height: 40px;
  margin: auto;
  border-radius: 50%;
  background: #d32d37;
  box-shadow: 0 0 5px 1px hsla(0, 0%, 44%, .5)
}
.swiper-industry-button-next {
  left: 65px
}
@media only screen and (max-width:1280px) {
  .swiper-industry-button-next {
    left: 0
  }
}
.swiper-industry-button-next:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 6px;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-bottom: 2px solid #fff;
  border-left: 2px solid #fff
}
.swiper-industry-button-prev {
  right: 65px
}
@media only screen and (max-width:1280px) {
  .swiper-industry-button-prev {
    right: 0
  }
}
.swiper-industry-button-prev:after {
  position: absolute;
  top: 0;
  right: 6px;
  bottom: 0;
  left: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #fff;
  border-right: 2px solid #fff
}
.swiper-industry .swiper-slide {
  width: 232px !important;
  border: 1px solid #e7e7e7
}
@media only screen and (max-width:768px) {
  .swiper-industry .swiper-slide {
    height: auto !important
  }
}
@media only screen and (max-width:600px) {
  .swiper-industry .swiper-slide {
    width: 100% !important
  }
}
.swiper-industry .swiper-slide_img {
  position: relative;
  overflow: hidden;
  height: 160px
}
@media only screen and (max-width:600px) {
  .swiper-industry .swiper-slide_img {
    height: 200px
  }
}
.swiper-industry .swiper-slide_img img {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  margin: auto
}
.swiper-industry .swiper-slide a:hover img {
  opacity: .8
}
.swiper-industry .swiper-slide a:hover span {
  text-decoration: underline;
  color: #e40229
}
.swiper-industry .swiper-slide span {
  font-size: 16px;
  position: relative;
  display: block;
  padding: 15px;
  color: #5c5c5c;
}
.swiper-industry .swiper-slide span:after {
  position: absolute;
  top: 0;
  right: 15px;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}
.info-area {
  padding: 60px 20px 80px;
  background: #f6f6f6
}
@media only screen and (max-width:600px) {
  .info-area {
    padding: 45px 15px 40px
  }
}
.info-area .section_title {
  max-width: 1000px;
  padding: 0 5px
}
.info-area-body {
  max-width: 1000px;
  margin: 32px auto 0;
  padding: 30px;
  background: #fff
}
.lp-video {
  padding: 60px 0;
}
.lp-video-body {
  max-width: 1000px;
  margin: 32px auto 0;
}
@media only screen and (max-width:768px) {
  .info-area-body {
    padding: 30px 20px
  }
}
@media only screen and (max-width:600px) {
  .info-area-body {
    margin: 20px auto 0;
    padding: 20px
  }
}
.info-area-body .top-news_title {
  display: none
}
.info-area-body .top-news_item {
  display: none;
  margin-bottom: 22px;
  padding: 0 15px 26px 0;
  border-bottom: 1px solid #e7e7e7
}
@media only screen and (max-width:768px) {
  .info-area-body .top-news_item {
    flex-wrap: wrap
  }
}
.info-area-body .top-news_item:nth-of-type(2), .info-area-body .top-news_item:nth-of-type(3), .info-area-body .top-news_item:nth-of-type(4), .info-area-body .top-news_item:nth-of-type(5), .info-area-body .top-news_item:nth-of-type(6) {
  display: flex;
  flex-wrap: wrap
}
.info-area-body .top-news_item:nth-of-type(6) {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: 0
}
.info-area-body .top-news_link {
  font-size: 16px;
  width: 100%;
  color: #e4032e;
  order: 2
}
@media only screen and (max-width:600px) {
  .info-area-body .top-news_link {
    font-size: 14px
  }
}
.info-area-body .top-news_link a:hover {
  text-decoration: underline
}
.info-area-body .top-news_release {
  display: flex;
  margin-right: 10px
}
.info-area-body .top-news_release .top-news_date {
  margin-right: 10px;
  padding-right: 10px;
  border-right: 1px solid #e7e7e7
}
.info-area-body .top-news_release .top-news_category {
  font-size: 14px;
  font-weight: 700
}
.info-area .sp_only-button {
  width: 100%;
  margin: 20px 0 0
}
.bnr-area {
  padding: 60px 20px
}
.bnr-area_list {
  display: flex;
  max-width: 1200px;
  margin: auto;
  flex-wrap: wrap
}
@media only screen and (max-width:768px) {
  .bnr-area_list {
    display: block
  }
}
.bnr-area_list li {
  width: 33.33333%;
  margin-bottom: 10px
}
@media only screen and (max-width:768px) {
  .bnr-area_list li {
    width: 100%
  }
}
.bnr-area_list a {
  display: block;
  margin-right: 20px
}
@media only screen and (max-width:768px) {
  .bnr-area_list li:nth-of-type(2n) a, .bnr-area_list li:nth-of-type(odd) a {
    margin-right: 0
  }
}
.bnr-area_list li:nth-of-type(3) a {
  margin-right: 0
}
.bnr-area_list a img {
  width: 100%
}
.bnr-area_button {
  display: flex;
  max-width: 1200px;
  margin: 10px auto 0
}
@media only screen and (max-width:768px) {
  .bnr-area_button {
    flex-wrap: wrap
  }
}
.bnr-area_button li {
  width: calc(33.33333% - 7.5px);
  margin-right: 20px;
  margin-bottom: 10px
}
@media only screen and (max-width:768px) {
  .bnr-area_button li {
    width: calc(50% - 10px)
  }
}
@media only screen and (max-width:768px) {
  .bnr-area_button li:nth-of-type(2) {
    margin-right: 0
  }
}
.bnr-area_button li:nth-of-type(3) {
  margin-right: 0
}
.bnr-area_button a {
  position: relative;
  display: block;
  padding: 20px 22px;
  border: 1px solid #e5e5e6
}
.bnr-area_button a:hover {
  text-decoration: underline;
  color: #e40229
}
@media only screen and (max-width:600px) {
  .bnr-area_button a {
    padding: 5px 40px 10px 20px
  }
}
.bnr-area_button a:after {
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  width: 12px;
  height: 12px;
  margin: auto;
  content: "";
  transform: rotate(45deg);
  border-top: 2px solid #e4032e;
  border-right: 2px solid #e4032e
}