@charset "UTF-8";
/* -----------------------------------------------------------------------------------------------------------
_VARIABLE
------------------------------------------------------------------------------------------------------------ */
/* Common */
* {
  margin: 0;
  padding: 0;
}
*:not(.LA-modal-overlay *) {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
}

p {
  margin: 0;
}

@media (max-width: 767px) {
  body {
    padding: 0;
  }

  .container {
    width: calc(100% - 40px);
  }
}
.btn-3D a span {
  width: 70px;
  background: #011b40;
  text-align: center;
}

.btn-3D a span::before,
.btn-3D a:hover span::before,
.btn-3D a:focus span::before {
  background: #1a58b1;
}

@media (max-width: 767px) {
  .gray-bg,
  .darkgray-bg,
  .bright-bg {
    margin: 0 !important;
    padding: 20px 0px;
  }

  .iau-gray-bg,
  .darkgray-bg,
  .bright-bg {
    margin: 0 !important;
    padding: 0px 0px 20px 0px;
  }

  .White-bg,
  .darkgray-bg,
  .bright-bg {
    margin: 0 !important;
    padding: 15px 0px;
  }
}
/*  Black Change Region Link */
@media (max-width: 767px) {
  .black-bg,
  .navbar-wrapper {
    padding: 0;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
/* Switch language */
.switch-language {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  font-family: Verdana, "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  line-height: 160%;
}

.region a {
  font-family: 'Noto Sans JP', sans-serif !important;
}

/* Navigation Menu */
.hero-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  padding-top: 21px;
  z-index: 998;
  background: #222;
}

.hero-header .navbar-wrapper {
  height: 74px;
  background: none;
  border: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  background-color: #222;
  margin-bottom: 0;
}

.hero-header .navbar-wrapper .container {
  position: relative;
}

.hero-header .navbar .nav {
  margin-top: 22px !important;
}

.hero-header .navbar .logo {
  position: absolute;
  top: 0;
  left: 0;
  padding: 22px 0px;
  color: #fff;
  font-size: 13px;
  text-shadow: none;
  z-index: 10;
}

@media (max-width: 979px) {
  .hero-header .navbar .logo {
    margin: 0;
  }
}
.hero-header .navbar .logo span {
  display: inline-block;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 13px;
  padding-left: 12px;
  padding-bottom: 1px;
  vertical-align: bottom;
}

@media (max-width: 767px) {
  .hero-header .navbar .logo span {
    display: none;
  }
}
.hero-header .navbar .logo img {
  width: auto;
  height: 30px;
}

.hero-header .navbar .btn-navbar {
  position: absolute;
  top: 0;
  right: 0;
  margin: 18px 0px 17px;
  padding: 7px 6px;
  background: none;
  z-index: 10;
}

.hero-header .navbar .btn-navbar .icon-bar {
  width: 32px;
  height: 3px;
}

.hero-header .btn-navbar .icon-bar + .icon-bar {
  margin-top: 8px;
}

@media (max-width: 979px) {
  .hero-header .navbar .nav {
    margin-top: 96px !important;
  }
}
.hero-header .nav-pills > li > a {
  font-family: 'Roboto', sans-serif !important;
  font-size: 15px;
  font-weight: 700;
  background: none;
}

.hero-header .nav-collapse {
  position: absolute;
  top: 0;
  left: 0px;
  width: 100%;
  z-index: 1;
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

@media (max-width: 979px) {
  .hero-header .nav-collapse::before {
    position: absolute;
    content: '';
    display: inline-block;
    top: 0;
    left: 0;
    width: 100%;
    height: 74px;
    background-color: #333;
  }
}
/* Manufacturing industry Digital Transformation */
.header_area {
  max-width: 1170px;
  margin: 0 auto;
  width: calc(100% - 80px);
}

.header_area h2 {
  font-size: 20px;
  font-weight: 700;
  color: #094067;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.75;
  text-align: right;
}

/* Footer Catch */
.bright-bg.footer-catch {
  background-color: #333;
  margin-right: calc(50% - 50vw) !important;
  margin-left: calc(50% - 50vw) !important;
}

.bright-bg.footer-catch h3 {
  font-family: 'Noto Sans JP', sans-serif;
  color: #fff;
}

/* Footer */
footer {
  margin-right: calc(50% - 50vw) !important;
  margin-left: calc(50% - 50vw) !important;
}

/* @media (max-width: 767px) {
    footer {
        margin-left: 0!important;
        margin-right: 0!important;
    }
} */
footer a {
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
}

.modal-video-position {
  -webkit-box-sizing: initial;
          box-sizing: initial;
}
.modal-video-position iframe {
  max-width: calc(100% - 10px);
}

@media only screen and (max-width: 767px) {
  #modal-content_business_03 .modal-write {
    overflow-y: auto;
    width: calc(100% - 25px);
  }
}

/* -----------------------------------------------------------------------------------------------------------
	RESET CSS
------------------------------------------------------------------------------------------------------------ */
body {
  font-family: 'Noto Sans JP', sans-serif !important;
  line-height: 1.75;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
a,
li {
  font-family: 'Noto Sans JP', sans-serif !important;
  margin: 0;
  color: inherit;
  line-height: inherit;
}

ul {
  margin: 0;
}

p {
  margin: 0;
  padding: 0;
}
p span {
  margin: 0;
  padding: 0;
  line-height: inherit;
}

@media only screen and (max-width: 1024px) {
  .pc-only {
    display: none;
  }
}

.ipad-only {
  display: none;
}
@media only screen and (max-width: 1024px) {
  .ipad-only {
    display: initial;
  }
}
@media only screen and (max-width: 767px) {
  .ipad-only {
    display: none;
  }
}

.sp-only {
  display: none;
}
@media only screen and (max-width: 767px) {
  .sp-only {
    display: initial;
  }
}

/* -----------------------------------------------------------------------------------------------------------
	LAYOUT
------------------------------------------------------------------------------------------------------------ */
.l-container {
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 40px;
}
@media only screen and (max-width: 767px) {
  .l-container {
    padding: 0 15px;
  }
}

/* -----------------------------------------------------------------------------------------------------------
	COMPONENT
------------------------------------------------------------------------------------------------------------ */
/* 5 - Other ------------------*/
.tp-breadcrumb {
  margin-top: 16px;
}
.tp-breadcrumb-item {
  line-height: 2;
  font-size: 14px;
}
@media only screen and (max-width: 767px) {
  .tp-breadcrumb-item {
    line-height: 1.5;
    margin-bottom: 5px;
  }
}
.tp-breadcrumb-item.color_black {
  color: #212121;
}
.tp-breadcrumb-item .color_blue {
  color: #2296F3;
}
.tp-breadcrumb-item:after {
  border-color: #212121;
}

.section {
  font-size: 16px;
  line-height: 1.75;
}
@media only screen and (max-width: 767px) {
  .section {
    font-size: 14px;
  }
}

.bright-bg.footer-catch,
footer {
  margin-left: auto !important;
  margin-right: auto !important;
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

.btn-3D a span {
  -webkit-box-sizing: initial;
          box-sizing: initial;
}

/* -----------------------------------------------------------------------------------------------------------
Digitalization Common
------------------------------------------------------------------------------------------------------------ */
/* 1 Common css
---------------------------------------*/
/* 2 Main
--------------------------------------*/
.tp-breadcrumb {
  margin-bottom: 16px;
}
.tp-breadcrumb-item:last-child {
  padding-right: 0;
}

/* -----------------------------------------------------------------------------------------------------------
Digitalization
------------------------------------------------------------------------------------------------------------ */
.p-industry-under-page {
  color: #000;
}
.p-industry-under-page .mainVisual {
  margin-top: 95px;
  padding: 396px 0px 29px;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  color: #fff;
}
.p-industry-under-page.p-industry-under-page-mobility .mainVisual {
  background: url("images/bg_mobility.jpg") no-repeat center / cover;
}
.p-industry-under-page.p-industry-under-page-factory-automation .mainVisual {
  background: url("images/bg_factory_automation.jpg") no-repeat center / cover;
}
.p-industry-under-page.p-industry-under-page-life-science .mainVisual {
  background: url("images/bg_life_science.jpg") no-repeat center / cover;
}
@media only screen and (max-width: 767px) {
  .p-industry-under-page .mainVisual {
    padding: 153px 0px 40px;
  }
}
.p-industry-under-page .mainVisual .ttl--right {
  text-align: right;
}
.p-industry-under-page .mainVisual .ttl--white {
  color: #fff;
}
.p-industry-under-page .mainVisual .ttl--black {
  color: #000;
}
.p-industry-under-page .mainVisual .tag {
  font-size: 16px;
  line-height: 1.75;
  background-color: #fff;
  color: #212121;
  display: inline-block;
  padding: 0 12px;
  font-family: "din-2014",sans-serif !important;
  font-style: normal;
  font-weight: 600;
  font-stretch: normal;
}
.p-industry-under-page .mainVisual h1 {
  font-size: 40px;
  line-height: 1;
  font-weight: 700;
  margin: 18px 0 8px;
}
@media only screen and (max-width: 767px) {
  .p-industry-under-page .mainVisual h1 {
    font-size: 32px;
  }
}
@media only screen and (max-width: 550px) {
  .p-industry-under-page .mainVisual h1 {
    font-size: 26px;
  }
}
.p-industry-under-page .mainVisual .short_desc {
  font-size: 20px;
  line-height: 1.75;
  font-weight: 500;
}
@media only screen and (max-width: 640px) {
  .p-industry-under-page .mainVisual .short_desc {
    font-size: 18px;
  }
  .p-industry-under-page .mainVisual .short_desc br {
    display: none;
  }
}
@media only screen and (max-width: 550px) {
  .p-industry-under-page .mainVisual .short_desc {
    font-size: 16px;
  }
}
.p-industry-under-page .tp-breadcrumb {
  overflow: hidden;
}
.p-industry-under-page .tp-breadcrumb a {
  font-size: 16px;
  line-height: 1;
}
.p-industry-under-page .tp-breadcrumb-item {
  font-size: 16px;
}

.section_about {
  padding: 20px 0 56px;
}
.section_about p {
  font-size: 16px;
  line-height: 1.75;
}
.section_about__flow {
  display: grid;
  grid-template-columns: 120px 136px 136px 127px 120px;
  gap: 16px;
  max-width: 793px;
  margin: 59px auto 0;
  padding-left: 40px;
  padding-bottom: 18px;
  background: url("images/bg_flow.png") no-repeat right bottom;
}
@media only screen and (max-width: 992px) {
  .section_about__flow {
    grid-template-columns: 100px 120px 120px 120px 100px;
    padding-left: 25px;
  }
}
@media only screen and (max-width: 767px) {
  .section_about__flow {
    max-width: 600px;
    grid-template-columns: repeat(5, 97px);
    padding-left: 17px;
  }
}
@media only screen and (max-width: 640px) {
  .section_about__flow {
    gap: 10px;
    max-width: 515px;
    grid-template-columns: 60px 100px 100px 90px 80px;
    padding-left: 15px;
  }
}
@media only screen and (max-width: 550px) {
  .section_about__flow {
    display: block;
    padding: 20px 20px 30px;
    background: url("images/bg_flow_sp.png") no-repeat center center;
  }
}
.section_about__flow p {
  padding: 4px 0;
  background-color: #fff;
  -webkit-box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
  border-radius: 4px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  text-align: center;
}
@media only screen and (max-width: 992px) {
  .section_about__flow p {
    font-size: 14px;
  }
}
@media only screen and (max-width: 767px) {
  .section_about__flow p {
    font-size: 12px;
  }
}
@media only screen and (max-width: 550px) {
  .section_about__flow p {
    height: 49px;
    font-size: 14px;
    line-height: 1.43;
  }
  .section_about__flow p + p {
    margin-top: 20px;
  }
}

.section_details .item {
  margin-bottom: 72px;
  position: relative;
  font-size: 16px;
  line-height: 1.75;
  padding-left: 53%;
}
@media only screen and (max-width: 767px) {
  .section_details .item {
    position: static;
    max-width: 552px;
    margin: 0 auto 105px;
    padding-left: 0;
  }
}
.section_details .item.mb85 {
  margin-bottom: 85px;
}
.section_details .item figure {
  position: absolute;
  top: 4px;
  left: 0;
  width: 40%;
}
@media only screen and (max-width: 767px) {
  .section_details .item figure {
    position: static;
    width: auto;
    margin-bottom: 8px;
  }
}
.section_details .item h2 {
  margin-bottom: 8px;
  font-size: 22px;
  line-height: 1.59;
  font-weight: 600;
  text-transform: none;
}
@media only screen and (max-width: 767px) {
  .section_details .item h2 {
    font-size: 20px;
    line-height: 1.4;
  }
}
.section_details .item h3 {
  margin-bottom: 5px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.22;
}
@media only screen and (max-width: 767px) {
  .section_details .item h3 {
    margin-bottom: 15px;
  }
}
.section_details .item ul {
  margin-top: 8px;
  margin-left: 10px;
  list-style-position: inside;
  list-style-type: disc;
}
.section_details .item ul li + li {
  margin-top: 8px;
}
.section_details .item ul li::marker {
  font-size: 10px;
  color: #757575;
}
.section_details .item--imgRight {
  padding-left: 0;
  padding-right: 36.2%;
}
@media only screen and (max-width: 767px) {
  .section_details .item--imgRight {
    padding-right: 0;
  }
}
.section_details .item--imgRight figure {
  left: auto;
  right: 0;
  top: 12px;
}
.section_details .item--imgRight h2 {
  margin-bottom: 15px;
}
.section_details .item--noImg {
  padding-left: 0;
}
.section_details .item--noImg h2 {
  margin-bottom: 15px;
}
.section_details .item .item__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(440px, 230px));
  justify-content: center;
  column-gap: 64px;
  row-gap: 30px;
}
@media only screen and (max-width: 1038px) {
  .section_details .item .item__grid {
    grid-template-columns: repeat(2, calc(50% - 12px));
    column-gap: 25px;
  }
}
@media only screen and (max-width: 767px) {
  .section_details .item .item__grid {
    grid-template-columns: fit-content(100%);
  }
}
.capability_card__inner {
  min-height: 230px;
  padding: 20px;
  background-color: #f5f5f5;
  border-radius: 8px;
}
@media only screen and (max-width: 1038px) {
  .capability_card__inner {
    min-height: 260px;
  }
}
@media only screen and (max-width: 767px) {
  .capability_card__inner {
    min-height: auto;
  }
}
.capability_card__inner img {
  width: 36px;
  height: 36px;
}
.capability_card__ttl {
  margin: 16px 0 8px;
}

.section_work {
  padding: 48px 0 68px;
}
.section_work h2 {
  margin-bottom: 24px;
  font-size: 22px;
  line-height: 1.59;
  font-weight: 600;
  text-align: center;
}
.section_work .items {
  display: grid;
  grid-template-columns: repeat(3, 32.6%);
  gap: 0 16px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media only screen and (max-width: 992px) {
  .section_work .items {
    max-width: 632px;
    margin: 0 auto;
    grid-template-columns: repeat(auto-fill, minmax(300px, 300px));
    gap: 16px;
  }
}
@media only screen and (max-width: 332px) {
  .section_work .items {
    grid-template-columns: 1fr;
  }
}
.section_work .items .item {
  padding: 16px 11px 24px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  background-color: #fff;
}
.section_work .items .item a {
  display: block;
  text-decoration: none;
}
.section_work .items .item a:hover {
  text-decoration: none;
  cursor: pointer;
  color: #000;
}
.section_work .items .item figure {
  margin-bottom: 12px;
}
.section_work .items .item h3 {
  font-size: 16px;
  line-height: 1.75;
  font-weight: 500;
}
.section_work .items .item p {
  font-size: 14px;
  line-height: 1.75;
  font-weight: 400;
  margin-top: 12px;
}

/* -----------------------------------------------------------------------------------------------------------
Digitalization - Contact
------------------------------------------------------------------------------------------------------------ */
.c-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 44px;
  padding: 0 23px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  border-radius: 24px;
  -webkit-transition: all .3s;
  transition: all .3s;
  border: 1.75px solid #fff;
}
.c-btn:hover {
  color: #fff;
  opacity: 0.8;
}
.c-btn--white {
  color: #0b2c55;
  background-color: #fff;
}
.c-btn--white:hover {
  color: #0b2c55;
}

.section_contact {
  background-color: #0b2c55;
  padding: 23px 0 59px;
  text-align: center;
  color: #fff;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
  .section_contact .l-container {
    padding: 0 10px;
  }
}
.section_contact__title {
  font-size: 18px;
  text-align: center;
  font-weight: 600;
  line-height: 1.78;
}
@media only screen and (max-width: 767px) {
  .section_contact__title {
    font-size: 20px;
  }
}
.section_contact p {
  margin: 0 auto;
  font-size: 16px;
  font-weight: 500;
  line-height: 2.5;
}
@media only screen and (max-width: 767px) {
  .section_contact p {
    font-size: 14px;
  }
}
.section_contact .l-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 24px;
  margin-top: 40px;
}
@media only screen and (max-width: 374px) {
  .section_contact .l-btn {
    gap: 10px;
  }
}
@media only screen and (max-width: 374px) {
  .section_contact .c-btn {
    font-size: 14px;
    padding-left: 15px;
    padding-left: 15px;
  }
}
.section_contact__link a {
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
  text-decoration: underline;
  color: #fff;
}


/* Custom drupal */

.p-industry-under-page .section_details {
  padding-bottom: 0;
}
.p-industry-under-page .section_contact {
  margin-top: 128px;
}
.section_about.capability {
  padding-top: 0;
}