@charset "UTF-8";
/*-----------------------------------------------------

  BASE

----------------------------------------------------- */
body {
  color: #333;
  /*font-family: 'Noto Sans JP' , "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;*/
}

._sp,
._sp_df {
  display: none !important;
}

@media (max-width: 767px) {
  ._pc,
  ._pc_df {
    display: none !important;
  }
  ._sp {
    display: block !important;
  }
  ._sp_df {
    display: -webkit-box !important;
    display: -webkit-flex !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
}

input[type="text"],
input[type="password"],
textarea,
select {
  outline: none;
}

*:focus {
  outline: none;
}

/*-----------------------------------------------------

  CLEARFIX

----------------------------------------------------- */
*:first-child + html .clearFix {
  display: inline-block;
}

/* for IE7 */
.clearFix:after {
  content: " ";
  display: block;
  visibility: hidden;
  clear: both;
  height: 0.1px;
  font-size: 0.1em;
  line-height: 0;
}

* html .clearFix {
  display: inline-block;
}

/* no ie mac \*/
* html .clearFix {
  height: 1%;
}

.clearFix {
  display: block;
}

/* ***********************************
 *
 *    Ire's CSS Reset & Base
 *
 * *********************************** */
/* Reset margin, padding, border
 * *********************************** */
html, body,
h1, h2, h3, h4, h5, h6,
a, p, span,
em, small, strong,
sub, sup,
mark, del, ins, strike,
abbr, dfn,
blockquote, q, cite,
code, pre,
ol, ul, li, dl, dt, dd,
div, section, article,
main, aside, nav,
header, hgroup, footer,
img, figure, figcaption,
address, time,
audio, video,
canvas, iframe,
details, summary,
fieldset, form, label, legend,
table, caption,
tbody, tfoot, thead,
tr, th, td {
  margin: 0;
  padding: 0;
  border: 0;
}

/* Typography
 * *********************************** */
html {
  font-size: 62.5%;
}

body {
  font-size: 1.6rem;
  line-height: 1.7;
}

* {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

a,
a:visited {
  color: inherit;
}

a {
  text-decoration: none;
}
@media (min-width: 768px){
a:hover{
    opacity: 0.7;
}
}

/* Layout
 * *********************************** */
article,
aside,
footer,
header,
nav,
section,
main {
  display: block;
}

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

*:before,
*:after {
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

/* Elements
 * *********************************** */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

ol,
ul {
  list-style: none;
}

img {
  border-style: none;
  display: block;
  line-height: 0;
}

blockquote,
q {
  quotes: none;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: "";
  content: none;
}

/* Attributes & states
 * *********************************** */
[hidden] {
  display: none !important;
}

[disabled] {
  cursor: not-allowed;
}

:focus:not(:focus-visible) {
  outline: none;
}

/* Utility classes
 * *********************************** */
.sr-only {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  left: -9999px;
  top: -9999px;
}

.header {
  background: #000;
  height: 100px;
  width: 100%;
  position: relative;
  z-index: 99;
}

@media (max-width: 1000px) {
  .header {
    height: 120px;
  }
}

.header .logo {
  width: 155px;
  display: block;
  position: absolute;
  top: 45px;
  left: 30px;
}

@media (max-width: 1000px) {
  .header .logo {
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}

.header .logo img {
  width: 100%;
}

.header .header_nav {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: calc(100% - 40px);
  max-width: 500px;
  position: absolute;
  bottom: 20px;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
}

@media (max-width: 1000px) {
  .header .header_nav {
    bottom: 7px;
  }
}

.header .header_nav a {
  color: #fff;
  padding-bottom: 23px;
}

@media (max-width: 1000px) {
  .header .header_nav a {
    font-size: 1.3rem;
    padding-bottom: 10px;
  }
}

.header .header_nav a:after {
  content: "";
  background: url(/fileadmin/templates2020/images/mobility-solutions/arrow.png) no-repeat;
  background-size: 9px 12px;
  width: 9px;
  height: 12px;
  display: inline-block;
  margin-left: 5px;
}

@media (max-width: 1000px) {
  .header .header_nav a:after {
    background-size: 8px 10px;
    width: 8px;
    height: 10px;
  }
}

.header .globalBtn {
  position: absolute;
  top: 25px;
  right: 30px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  max-width: 200px;
}

@media (max-width: 1000px) {
  .header .globalBtn {
    top: 12px;
    right: 17px;
  }
}

.header .globalBtn li {
  padding: 0 5px;
}

.header .globalBtn .active {
  font-size: 1.7rem;
  font-weight: bold;
  color: #fff;
}

.header .globalBtn a {
  font-size: 1.4rem;
  color: #999;
}

.header .productBtnList {
  height: 0;
  overflow: hidden;
  position: absolute;
  top: 47px;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
  -ms-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  width: 220px;
  background: #fff;
}

@media (max-width: 1000px) {
  .header .productBtnList {
    width: 160px;
    left: 55%;
    top: 35px;
  }
}

.header .productBtnList li {
  width: 100%;
}

.header .productBtnList a {
  color: #000;
  text-align: center;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  font-size: 1.4rem;
  padding: 15px 0;
}

.header .productBtn {
  position: relative;
}

@media (min-width: 768px) {
  .header .productBtn:hover .productBtnList {
    height: auto;
    overflow: visible;
    -webkit-box-shadow: 0px 0px 10px 3px #d7dbde;
    box-shadow: 0px 0px 10px 3px #d7dbde;
  }
  .header .productBtn:hover .productBtnList a {
    display: block;
    position: relative;
  }
}

@media (min-width: 768px) and (max-width: 1000px) {
  .header .productBtn:hover .productBtnList a {
    font-size: 1.3rem;
    padding: 9px;
  }
}

@media (min-width: 768px) {
  .header .productBtn:hover .productBtnList a:after {
    content: "";
    width: 80%;
    height: 1px;
    background: #d2d9dc;
    position: absolute;
    left: 50%;
    top: 100%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  .header .productBtn:hover .productBtnList li:last-child a:after {
    content: none;
  }
}

@media (max-width: 767px) {
  .header .productBtn.open .productBtnList {
    height: auto;
    overflow: visible;
    -webkit-box-shadow: 0px 0px 10px 3px #d7dbde;
    box-shadow: 0px 0px 10px 3px #d7dbde;
  }
  .header .productBtn.open .productBtnList a {
    display: block;
    position: relative;
  }
}

@media (max-width: 767px) and (max-width: 1000px) {
  .header .productBtn.open .productBtnList a {
    font-size: 1.3rem;
    padding: 9px;
  }
}

@media (max-width: 767px) {
  .header .productBtn.open .productBtnList a:after {
    content: "";
    width: 80%;
    height: 1px;
    background: #d2d9dc;
    position: absolute;
    left: 50%;
    top: 100%;
    -webkit-transform: translate(-50%, 0);
    -ms-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
  }
  .header .productBtn.open .productBtnList li:last-child a:after {
    content: none;
  }
}

@media (max-width: 767px) {
  .en .header_nav a {
    font-size: 1.2rem;
  }
}

.en .productBtnList {
  left: 45%;
}

@media (max-width: 767px) {
  .en .productBtnList {
    left: 44%;
  }
}

@media (max-width: 767px) {
  .en .productBtnList a {
    font-size: 1rem !important;
  }
}

@media (max-width: 767px) {
  .de .productBtnList {
    left: 47%;
  }
}

/* Magnific Popup CSS */
.mfp-bg {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1042;
  overflow: hidden;
  position: fixed;
  background: #000;
  opacity: 0.8;
}

.mfp-wrap {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1043;
  position: fixed;
  outline: none !important;
  -webkit-backface-visibility: hidden;
}

.mfp-container {
  text-align: center;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  padding: 0 8px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.mfp-container:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle;
}

.mfp-align-top .mfp-container:before {
  display: none;
}

.mfp-content {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  margin: 0 auto;
  text-align: left;
  z-index: 1045;
}

.mfp-inline-holder .mfp-content,
.mfp-ajax-holder .mfp-content {
  width: 100%;
  cursor: auto;
}

.mfp-ajax-cur {
  cursor: progress;
}

.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
  cursor: -webkit-zoom-out;
  cursor: zoom-out;
}

.mfp-zoom {
  cursor: pointer;
  cursor: -webkit-zoom-in;
  cursor: zoom-in;
}

.mfp-auto-cursor .mfp-content {
  cursor: auto;
}

.mfp-close,
.mfp-arrow,
.mfp-preloader,
.mfp-counter {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.mfp-loading.mfp-figure {
  display: none;
}

.mfp-hide {
  display: none !important;
}

.mfp-preloader {
  color: #CCC;
  position: absolute;
  top: 50%;
  width: auto;
  text-align: center;
  margin-top: -0.8em;
  left: 8px;
  right: 8px;
  z-index: 1044;
}

.mfp-preloader a {
  color: #CCC;
}

.mfp-preloader a:hover {
  color: #FFF;
}

.mfp-s-ready .mfp-preloader {
  display: none;
}

.mfp-s-error .mfp-content {
  display: none;
}

button.mfp-close,
button.mfp-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  -webkit-box-shadow: none;
  box-shadow: none;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
}

button::-moz-focus-inner {
  padding: 0;
  border: 0;
}

.mfp-close {
  width: 44px;
  height: 44px;
  line-height: 44px;
  position: absolute;
  right: 0;
  top: 0;
  text-decoration: none;
  text-align: center;
  opacity: 0.65;
  padding: 0 0 18px 10px;
  color: #FFF;
  font-style: normal;
  font-size: 28px;
  font-family: Arial, Baskerville, monospace;
}

.mfp-close:hover,
.mfp-close:focus {
  opacity: 1;
}

.mfp-close:active {
  top: 1px;
}

.mfp-close-btn-in .mfp-close {
  color: #333;
}

.mfp-image-holder .mfp-close,
.mfp-iframe-holder .mfp-close {
  color: #FFF;
  right: -6px;
  text-align: right;
  padding-right: 6px;
  width: 100%;
}

.mfp-counter {
  position: absolute;
  top: 0;
  right: 0;
  color: #CCC;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap;
}

.mfp-arrow {
  position: absolute;
  opacity: 0.65;
  margin: 0;
  top: 50%;
  margin-top: -55px;
  padding: 0;
  width: 90px;
  height: 110px;
  -webkit-tap-highlight-color: transparent;
}

.mfp-arrow:active {
  margin-top: -54px;
}

.mfp-arrow:hover,
.mfp-arrow:focus {
  opacity: 1;
}

.mfp-arrow:before,
.mfp-arrow:after {
  content: '';
  display: block;
  width: 0;
  height: 0;
  position: absolute;
  left: 0;
  top: 0;
  margin-top: 35px;
  margin-left: 35px;
  border: medium inset transparent;
}

.mfp-arrow:after {
  border-top-width: 13px;
  border-bottom-width: 13px;
  top: 8px;
}

.mfp-arrow:before {
  border-top-width: 21px;
  border-bottom-width: 21px;
  opacity: 0.7;
}

.mfp-arrow-left {
  left: 0;
}

.mfp-arrow-left:after {
  border-right: 17px solid #FFF;
  margin-left: 31px;
}

.mfp-arrow-left:before {
  margin-left: 25px;
  border-right: 27px solid #3F3F3F;
}

.mfp-arrow-right {
  right: 0;
}

.mfp-arrow-right:after {
  border-left: 17px solid #FFF;
  margin-left: 39px;
}

.mfp-arrow-right:before {
  border-left: 27px solid #3F3F3F;
}

.mfp-iframe-holder {
  padding-top: 40px;
  padding-bottom: 40px;
}

.mfp-iframe-holder .mfp-content {
  line-height: 0;
  width: 100%;
  max-width: 900px;
}

.mfp-iframe-holder .mfp-close {
  top: -40px;
}

.mfp-iframe-scaler {
  width: 100%;
  height: 0;
  overflow: hidden;
  padding-top: 56.25%;
}

.mfp-iframe-scaler iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #000;
}

/* Main image in popup */
img.mfp-img {
  width: auto;
  max-width: 100%;
  height: auto;
  display: block;
  line-height: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 0 40px;
  margin: 0 auto;
}

/* The shadow behind the image */
.mfp-figure {
  line-height: 0;
}

.mfp-figure:after {
  content: '';
  position: absolute;
  left: 0;
  top: 40px;
  bottom: 40px;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.6);
  background: #444;
}

.mfp-figure small {
  color: #BDBDBD;
  display: block;
  font-size: 12px;
  line-height: 14px;
}

.mfp-figure figure {
  margin: 0;
}

.mfp-bottom-bar {
  margin-top: -36px;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  cursor: auto;
}

.mfp-title {
  text-align: left;
  line-height: 18px;
  color: #F3F3F3;
  word-wrap: break-word;
  padding-right: 36px;
}

.mfp-image-holder .mfp-content {
  max-width: 100%;
}

.mfp-gallery .mfp-image-holder .mfp-figure {
  cursor: pointer;
}

@media screen and (max-width: 800px) and (orientation: landscape), screen and (max-height: 300px) {
  /**
       * Remove all paddings around the image on small screen
       */
  .mfp-img-mobile .mfp-image-holder {
    padding-left: 0;
    padding-right: 0;
  }
  .mfp-img-mobile img.mfp-img {
    padding: 0;
  }
  .mfp-img-mobile .mfp-figure:after {
    top: 0;
    bottom: 0;
  }
  .mfp-img-mobile .mfp-figure small {
    display: inline;
    margin-left: 5px;
  }
  .mfp-img-mobile .mfp-bottom-bar {
    background: rgba(0, 0, 0, 0.6);
    bottom: 0;
    margin: 0;
    top: auto;
    padding: 3px 5px;
    position: fixed;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .mfp-img-mobile .mfp-bottom-bar:empty {
    padding: 0;
  }
  .mfp-img-mobile .mfp-counter {
    right: 5px;
    top: 3px;
  }
  .mfp-img-mobile .mfp-close {
    top: 0;
    right: 0;
    width: 35px;
    height: 35px;
    line-height: 35px;
    background: rgba(0, 0, 0, 0.6);
    position: fixed;
    text-align: center;
    padding: 0;
  }
}

@media all and (max-width: 900px) {
  .mfp-arrow {
    -webkit-transform: scale(0.75);
    -ms-transform: scale(0.75);
    transform: scale(0.75);
  }
  .mfp-arrow-left {
    -webkit-transform-origin: 0;
    -ms-transform-origin: 0;
    transform-origin: 0;
  }
  .mfp-arrow-right {
    -webkit-transform-origin: 100%;
    -ms-transform-origin: 100%;
    transform-origin: 100%;
  }
  .mfp-container {
    padding-left: 6px;
    padding-right: 6px;
  }
}

.ver_al_sub {
  vertical-align: baseline;
  font-size: 1rem;
  line-height: 1;
  padding: 0 !important;
  display: inline !important;
}

.btnWrap {
  overflow: hidden;
}

@media (max-width: 767px) {
  .btnWrap {
    overflow: inherit;
  }
}

.fmt_btn_1 {
  width: 100%;
  max-width: 188px;
  display: inline-block;
  border-top: 2px solid #c6c6c6;
  border-left: 2px solid #C6C6C6;
  border-bottom: 2px solid #C6C6C6;
  padding: 3px 10px;
  text-align: center;
  letter-spacing: 0.1em;
  position: relative;
}


@media (max-width: 767px) {
  .fmt_btn_1 {
    max-width: 150px;
    border-top: 1px solid #c6c6c6;
    border-left: 1px solid #C6C6C6;
    border-bottom: 1px solid #C6C6C6;
  }
}

.fmt_btn_1:after {
  content: "";
  background: url(/fileadmin/templates2020/images/mobility-solutions/btn_1.png) no-repeat;
  background-size: contain;
  width: 15%;
  height: 108%;
  position: absolute;
  top: 50%;
  left: calc(100% - 1px);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

@media (max-width: 767px) {
  .fmt_btn_1:after {
    height: 108%;
    left: calc(100% - 1px);
  }
}

@media (max-width: 767px) {
  .fmt_btn_1 {
    margin: 0 auto;
    font-size: 1.4rem;
  }
}

.fmt_btn_1 img {
  width: 100%;
}

.fmt_btn_2 {
  width: 100%;
  max-width: 188px;
  display: inline-block;
  border-top: 2px solid #666767;
  border-left: 2px solid #666767;
  border-bottom: 2px solid #666767;
  padding: 3px 10px;
  background: #666767;
  text-align: center;
  letter-spacing: 0.1em;
  color: #fff !important;
  position: relative;
}

@media (max-width: 767px) {
  .fmt_btn_2 {
    max-width: 150px;
    border-top: 1px solid #666767;
    border-left: 1px solid #666767;
    border-bottom: 1px solid #666767;
  }
}

.fmt_btn_2:after {
  content: "";
  background: url(/fileadmin/templates2020/images/mobility-solutions/btn_2.png) no-repeat;
  background-size: contain;
  width: 15%;
  height: 130%;
  position: absolute;
  top: 50%;
  left: calc(100% - 2px);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

@media (max-width: 767px) {
  .fmt_btn_2:after {
    left: calc(100% - 1px);
    height: calc(100% + 3px);
  }
}

@media (max-width: 767px) {
  .fmt_btn_2 {
    margin: 0 auto;
    font-size: 1.4rem;
  }
}

.fmt_btn_2 img {
  width: 100%;
}

.fmt_btn_3 {
  width: 100%;
  max-width: 188px;
  display: inline-block;
  border-top: 2px solid #268cc4;
  border-left: 2px solid #268cc4;
  border-bottom: 2px solid #268cc4;
  padding: 3px 10px;
  background: #268cc4;
  text-align: center;
  letter-spacing: 0.1em;
  color: #fff !important;
  position: relative;
}

@media (max-width: 767px) {
  .fmt_btn_3 {
    max-width: 150px;
    border-top: 1px solid #268cc4;
    border-left: 1px solid #268cc4;
    border-bottom: 1px solid #268cc4;
  }
}

.fmt_btn_3:after {
  content: "";
  background: url(/fileadmin/templates2020/images/mobility-solutions/btn_3.png) no-repeat;
  background-size: contain;
  width: 15%;
  height: 130%;
  position: absolute;
  top: 50%;
  left: calc(100% - 2px);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

@media (max-width: 767px) {
  .fmt_btn_3:after {
    left: calc(100% - 1px);
    height: calc(100% + 3px);
  }
}

@media (max-width: 767px) {
  .fmt_btn_3 {
    margin: 0 auto;
    font-size: 1.4rem;
  }
}

.fmt_btn_3 img {
  width: 100%;
}

.pagetop {
  display: none;
  position: fixed;
  bottom: 30px;
  right: 25px;
}

@media (max-width: 767px) {
  .pagetop {
    position: absolute;
    top: 0;
    right: 20px;
    display: block;
  }
}

.pagetop a {
  display: block;
  width: 40px;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}

@media (max-width: 767px) {
  .pagetop a {
    width: 35px;
  }
}

.pagetop a img {
  width: 100%;
}

@media (min-width: 768px) {
  .pagetop a:hover {
    opacity: 0.5;
  }
}

.footer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 30px 40px;
  position: relative;
}

@media (max-width: 1000px) {
  .footer {
    display: block;
  }
}

.footer .footerLeft {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
  max-width: 290px;
}

@media (max-width: 1000px) {
  .footer .footerLeft {
    display: block;
    margin: 0 auto 20px;
    max-width: 150px;
  }
}

.footer .footerLeft a {
  font-size: 1.2rem;
  margin-right: 15px;
  display: block;
}

@media (max-width: 1000px) {
  .footer .footerLeft a {
    margin-right: 0;
    line-height: 1.8;
  }
}

.footer .footerLeft a:before {
  content: ">";
  margin-right: 5px;
}

.footer .footerLeft li:last-child a {
  margin-right: 0;
}

.footer .footerRight {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media (max-width: 1000px) {
  .footer .footerRight {
    display: block;
    text-align: center;
  }
}

.footer .footerRight .name {
  font-size: 1.4rem;
  margin-right: 15px;
}

@media (max-width: 767px) {
  .footer .footerRight .name {
    margin-right: 0;
  }
}

.footer .footerRight .copyright {
  font-size: 1.1rem;
}

@media (max-width: 1000px) {
  .footer .footerRight .copyright {
    font-size: 1rem;
  }
}

@media (max-width: 767px) {
  .en .footerLeft {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    max-width: none;
  }
}

@media (max-width: 767px) {
  .en .footerLeft li {
    margin: 0 10px;
  }
}

.en .footerRight {
  display: block;
  text-align: right;
}

@media (max-width: 767px) {
  .en .footerRight {
    text-align: center;
  }
}

.en .footerRight .name {
  margin-right: 0;
}

.top {
  background: #f2f2f2;
}

html, body {
  height: 100%;
}

.keyvisual {
  width: 100%;
  height: calc(100% - 100px);
  background: url(/fileadmin/templates2020/images/mobility-solutions/mainVisual.jpg) no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
  margin-bottom: 40px;
}

.keyvisual .textBox {
  position: absolute;
  bottom: 8%;
  left: 5%;
}

@media (max-width: 767px) {
  .keyvisual .textBox {
    bottom: 9%;
  }
}

.keyvisual .textBox .main {
  font-size: 6.5rem;
  line-height: 1.4;
  color: #fff;
  margin-bottom: 30px;
  font-weight: normal;
}

@media (max-width: 767px) {
  .keyvisual .textBox .main {
    font-size: 7vw;
  }
}

.keyvisual .textBox p {
  font-size: 1.8rem;
  color: #fff;
    background: rgb(20,20,20,0.4);
    padding: 1rem 0 1rem 1rem;
    margin-right: 4rem;
}

@media (max-width: 767px) {
  .keyvisual .textBox p {
    font-size: 3.6vw;
      margin-right: 0;
  }
}

.jp .keyvisual .main {
  /*font-family: 'Noto Serif JP', serif;*/
}

.jp .keyvisual p {
  /*font-family: 'Noto Serif JP', serif;*/
}

.en .keyvisual .main,
.de .keyvisual .main {
  letter-spacing: 0.03em;
}

@media screen and (max-width: 1100px) {
  .en .keyvisual .main,
  .de .keyvisual .main {
    font-size: 5.2vw;
  }
}

@media (max-width: 767px) {
  .en .keyvisual .main,
  .de .keyvisual .main {
    font-size: 6vw;
  }
}

.en .keyvisual p,
.de .keyvisual p {
  letter-spacing: 0.03em;
  font-size: 1.9rem;
}

@media (max-width: 767px) {
  .en .keyvisual p,
  .de .keyvisual p {
    font-size: 1.1rem;
    width: 97%;
    line-height: 1.5;
  }
}

.t_productBoxWrap {
  margin-bottom: 80px;
}

@media (max-width: 767px) {
  .t_productBoxWrap {
    margin-bottom: 40px;
  }
}

.t_productBox {
  max-width: 1100px;
  margin: 0 auto 80px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: #fff;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .t_productBox {
    display: block;
  }
}

.t_productBox:nth-child(odd) .imgWrap {
  -webkit-box-ordinal-group: 0;
  -webkit-order: -1;
  -ms-flex-order: -1;
  order: -1;
}

.t_productBox:nth-child(odd) .textBox .title {
  background: url(/fileadmin/templates2020/images/mobility-solutions/bg_1.jpg) no-repeat;
  background-position: center;
  background-size: cover;
}

.t_productBox .imgWrap {
  width: 50%;
}

@media (max-width: 767px) {
  .t_productBox .imgWrap {
    width: 100%;
  }
}

.t_productBox .imgBox {
  width: 100%;
  margin: 0 auto;
}

.t_productBox .imgBox img {
  width: 100%;
}

.t_productBox .textBox {
  width: 50%;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .t_productBox .textBox {
    width: 100%;
    margin-bottom: 20px;
  }
}

.t_productBox .textBox .title {
  font-size: 2.4rem;
  color: #fff;
  text-shadow: 1px 2px 3px #808080;
  background: url(/fileadmin/templates2020/images/mobility-solutions/bg_2.jpg) no-repeat;
  background-size: cover;
  background-position: center;
  padding: 50px 0 10px 13%;
  margin-bottom: 20px;
  letter-spacing: 0.05em;
  font-weight: normal;
}

@media (max-width: 767px) {
  .t_productBox .textBox .title {
    text-align: center;
    padding: 25px 0;
    background: url(/fileadmin/templates2020/images/mobility-solutions/bg_1.jpg) no-repeat;
    background-position: center;
    background-size: cover;
    font-size: 2rem;
  }
}

.t_productBox .textBox p {
  margin-bottom: 20px;
  padding-left: 13%;
  font-size: 1.7rem;
}

@media (max-width: 1000px) {
  .t_productBox .textBox p {
    font-size: 1.7vw;
  }
}

@media (max-width: 767px) {
  .t_productBox .textBox p {
    text-align: center;
    padding: 0;
    font-size: 1.4rem;
  }
}

.t_productBox .btnWrap {
  padding-left: 13%;
}

@media (max-width: 767px) {
  .t_productBox .btnWrap {
    padding: 40px 0;
    text-align: center;
  }
}

.category_1 .imgBox {
  max-width: 470px;
}

@media (max-width: 767px) {
  .category_1 .imgBox {
    width: 80%;
  }
}

.category_2 .imgBox {
  max-width: 400px;
}

@media (max-width: 767px) {
  .category_2 .imgBox {
    width: 83%;
  }
}

.category_1 .imgWrap,
.category_2 .imgWrap {
  position: relative;
}

.category_1 .imgWrap .imgBox,
.category_2 .imgWrap .imgBox {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  padding-left: 30px;
}

@media (max-width: 767px) {
  .category_1 .imgWrap .imgBox,
  .category_2 .imgWrap .imgBox {
    position: static;
    -webkit-transform: translate(0, 0);
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
    padding: 0;
  }
}

.category_3 .imgBox {
  max-width: none;
  height: 100%;
}

.category_3 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  /* 他のブラウザ用(＝通常の指定) */
  -o-object-position: 50% 50%;
  object-position: 50% 50%;
  /* 他のブラウザ用(＝通常の指定) */
  font-family: "object-fit: cover; object-position: 50% 50%;";
}

.jp .t_productBox .title {
  /*font-family: 'Noto Serif JP', serif;*/
  font-weight: bold;
}

.en .t_productBox .textBox,
.de .t_productBox .textBox {
  text-align: center;
}

.en .t_productBox .textBox .title,
.de .t_productBox .textBox .title {
  font-weight: bold;
  padding: 50px 0 10px;
  line-height: 1.4;
}

@media (max-width: 767px) {
  .en .t_productBox .textBox .title,
  .de .t_productBox .textBox .title {
    padding: 25px 0;
  }
}

.en .t_productBox .textBox p,
.de .t_productBox .textBox p {
  padding: 0;
  font-size: 1.5rem;
}

@media (max-width: 1000px) {
  .en .t_productBox .textBox p,
  .de .t_productBox .textBox p {
    font-size: 1.1rem;
  }
}

.en .t_productBox .btnWrap,
.de .t_productBox .btnWrap {
  padding: 0;
}

@media (max-width: 767px) {
  .en .t_productBox .btnWrap,
  .de .t_productBox .btnWrap {
    padding: 40px 0;
  }
}

.de .t_productBox .textBox {
  width: 60%;
}

@media (max-width: 767px) {
  .de .t_productBox .textBox {
    width: 100%;
  }
}

.de .t_productBox .imgWrap {
  width: 40%;
}

@media (max-width: 767px) {
  .de .t_productBox .imgWrap {
    width: 100%;
  }
}

.contact {
  width: calc(100% - 40px);
  max-width: 712px;
  margin: 0 auto 80px;
}

@media (max-width: 767px) {
  .contact {
    margin: 0 auto 30px;
  }
}

.contact .title {
  text-align: center;
  position: relative;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .contact .title {
    margin-bottom: 20px;
  }
}

.contact .title span {
  font-weight: 500;
  font-size: 1.8rem;
  background: #f2f2f2;
  display: inline-block;
  padding: 0 20px;
}

@media (max-width: 767px) {
  .contact .title span {
    font-size: 1.6rem;
  }
}

.contact .title:before {
  content: "";
  width: 100%;
  height: 1px;
  background: #a7a7a7;
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  z-index: -1;
}

.contact .contactBox {
  text-align: center;
}

.contact .contactBox a {
  font-weight: 400;
  font-size: 2.0rem;
  display: inline-block;
  margin: 1rem auto 0;
  padding: .5rem 4rem;
  border: 2px solid #666767;
  background: #666767;
  color: #fff;
}

@media (max-width: 767px) {
  .contact .contactBox a {
    font-size: 1.9rem;
  }
}

.contact .textBox {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 10px;
}

@media (max-width: 767px) {
  .contact .textBox {
    display: block;
  }
}

.contact .textBox p {
  padding: 0 10px;
  font-size: 1.4rem;
}

.en .contact .textBox p {
  font-size: 1.8rem;
}

.en .contact .title {
  margin-bottom: 20px;
}

.de .contact .title {
  margin-bottom: 20px;
}

.lowerKeyvisual {
  height: 380px;
  background: url(/fileadmin/templates2020/images/mobility-solutions/product_mainVisual.jpg) no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
}

@media (max-width: 767px) {
  .lowerKeyvisual {
    height: 200px;
  }
}

.lowerKeyvisual .textBox {
  width: 100%;
  position: absolute;
  top: 45%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

@media (max-width: 767px) {
  .lowerKeyvisual .textBox {
    top: 40%;
  }
}

.lowerKeyvisual .textBox .main {
  text-align: center;
  font-size: 6rem;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 0.2em;
  color: #fff;
}

@media (max-width: 767px) {
  .lowerKeyvisual .textBox .main {
    font-size: 3rem;
  }
}

.lowerKeyvisual .textBox p {
  font-size: 1.8rem;
  color: #fff;
  text-align: center;
}

@media (max-width: 767px) {
  .lowerKeyvisual .textBox p {
    font-size: 1rem;
  }
}

.productList {
  width: calc(100% - 40px);
  max-width: 760px;
  height: 90px;
  margin: -40px auto 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background: #fff;
  -webkit-box-shadow: 0px 0px 10px 3px #d7dbde;
  box-shadow: 0px 0px 10px 3px #d7dbde;
  position: relative;
}

@media (max-width: 767px) {
  .productList {
    margin: -30px auto;
    height: 60px;
  }
}

.productList li {
  width: calc(100% / 3 - 1px);
  height: 100%;
}

.productList li:last-child a:after {
  content: none;
}

.productList a {
  font-size: 1.8rem;
  height: 100%;
  width: 100%;
  position: relative;
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  line-height: 1.4;
}

@media (max-width: 767px) {
  .productList a {
    font-size: 1.2rem;
  }
}

.productList a:after {
  content: "";
  width: 1px;
  height: 60px;
  background: #a0aeb4;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

@media (max-width: 767px) {
  .productList a:after {
    height: 40px;
  }
}

.productList a:hover {
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
  color: #fff;
  background: #999999;
}

.productList .active {
  color: #fff;
  background: #999999;
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}

.productTopSecWrap {
  width: 100%;
  background: #f8fafb;
  margin-bottom: 80px;
}

@media (max-width: 767px) {
  .productTopSecWrap {
    margin-bottom: 30px;
  }
}

.productTopSec {
  width: calc(100% - 40px);
  max-width: 900px;
  margin: 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

@media (max-width: 767px) {
  .productTopSec {
    display: block;
    width: 100%;
  }
}

.productTopSec .imgBoxLeft {
  width: calc(72% - 30px);
  margin-right: 30px;
}

@media (max-width: 767px) {
  .productTopSec .imgBoxLeft {
    width: 100%;
    padding: 50px 20px 20px;
  }
}

.productTopSec .imgBoxLeft img {
  width: 100%;
}

.productTopSec .imgBoxRight {
  width: 28%;
  padding: 30px 20px;
  background: #fff;
}

@media (max-width: 767px) {
  .productTopSec .imgBoxRight {
    width: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 20px 20px 30px;
  }
}

.productTopSec .imgBoxRightInner {
  width: 100%;
  margin: 0 auto 40px;
}

@media (max-width: 767px) {
  .productTopSec .imgBoxRightInner {
    width: calc(100% / 3 - 10px);
    margin: 0 auto;
  }
}

.productTopSec .imgBoxRightInner img {
  width: 100%;
}

.productTopSec .imgBoxRightInner:last-child {
  margin: 0 auto 0;
}

.productDetailsWrap {
  width: calc(100% - 40px);
  max-width: 800px;
  margin: 0 auto 80px;
}

@media (max-width: 767px) {
  .productDetailsWrap {
    margin: 0 auto 60px;
  }
}

.productDetails {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .productDetails {
    display: block;
    margin-bottom: 40px;
  }
}

.productDetails .imgBox {
  width: 40%;
}

@media (max-width: 767px) {
  .productDetails .imgBox {
    width: 100%;
    height: 170px;
    margin-bottom: 15px;
  }
}

.productDetails .imgBox img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  /* 他のブラウザ用(＝通常の指定) */
  -o-object-position: 50% 50%;
  object-position: 50% 50%;
  /* 他のブラウザ用(＝通常の指定) */
  font-family: "object-fit: cover; object-position: 50% 50%;";
}

.productDetails .textBox {
  width: 60%;
}

@media (max-width: 767px) {
  .productDetails .textBox {
    width: 100%;
  }
}

.productDetails .textBox .title {
  padding: 10px 0;
  line-height: 1.4;
  font-size: 2.1rem;
  border-top: 1px solid #8b8c8c;
  border-bottom: 1px solid #8b8c8c;
  margin-bottom: 20px;
}

@media (max-width: 767px) {
  .productDetails .textBox .title {
    font-size: 4.6vw;
    text-align: center;
    margin-bottom: 10px;
  }
}

@media (max-width: 767px) {
  .productDetails .textBox p {
    font-size: 1.3rem;
  }
}

.productDetails:nth-child(odd) .textBox {
  padding: 0 0 0 4%;
}

@media (max-width: 767px) {
  .productDetails:nth-child(odd) .textBox {
    padding: 0;
  }
}

.productDetails:nth-child(even) .textBox {
  -webkit-box-ordinal-group: 0;
  -webkit-order: -1;
  -ms-flex-order: -1;
  order: -1;
  padding: 0 4% 0 0;
}

@media (max-width: 767px) {
  .productDetails:nth-child(even) .textBox {
    padding: 0;
    -webkit-box-ordinal-group: 2;
    -webkit-order: 1;
    -ms-flex-order: 1;
    order: 1;
  }
}

.productLineup {
  margin-bottom: 80px;
}

@media (max-width: 767px) {
  .productLineup {
    margin-bottom: 20px;
  }
}

.productLineup .productLineupTitle {
  text-align: center;
  font-size: 4.3rem;
  font-weight: normal;
  letter-spacing: 0.1em;
  margin-bottom: 30px;
}

@media (max-width: 767px) {
  .productLineup .productLineupTitle {
    font-size: 2.4rem;
    margin-bottom: 15px;
  }
}

.productLineup .productLineupList {
  width: calc(100% - 40px);
  max-width: 800px;
  margin: 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.productLineup .productLineupList li {
  width: calc(50% - 10px);
  margin-bottom: 40px;
  border-left: 1px solid #deddde;
}

@media (max-width: 767px) {
  .productLineup .productLineupList li {
    border: none;
  }
}

.productLineup .productLineupList .toptext {
  padding-left: 20px;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .toptext {
    text-align: center;
    padding-left: 0;
  }
}

.productLineup .productLineupList .toptext .name {
  color: #fff;
  width: 200px;
  height: 25px;
  margin-right: 5px;
  border-radius: 15px;
  font-size: 1.4rem;
  display: inline-block;
  text-align: center;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .toptext .name {
    display: block;
    margin-bottom: 5px;
    width: 100%;
    font-size: 1.3rem;
    margin-right: 0;
  }
}

.productLineup .productLineupList .toptext .color_1 {
  background: #303174;
}

.productLineup .productLineupList .toptext .color_2 {
  background: #835998;
}

.productLineup .productLineupList .toptext .color_3 {
  background: #6b7986;
}

.productLineup .productLineupList .toptext .min {
  display: block;
  margin-left: 20px;
  font-size: 1.2rem;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .toptext .min {
    margin-left: 0;
    font-size: 1rem;
  }
}

.productLineup .productLineupList .imgBoxWrap {
  height: 200px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .imgBoxWrap {
    height: 120px;
  }
}

.productLineup .productLineupList .imgBox {
  width: 100%;
}

.productLineup .productLineupList .imgBox img {
  width: 100%;
}

.productLineup .productLineupList .item_1 {
  max-width: 130px;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .item_1 {
    max-width: 70px;
  }
}

.productLineup .productLineupList .item_2 {
  max-width: 250px;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .item_2 {
    max-width: 150px;
  }
}

.productLineup .productLineupList .item_3 {
  max-width: 166px;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .item_3 {
    max-width: 100px;
  }
}

.productLineup .productLineupList .item_4 {
  max-width: 100px;
}

@media (max-width: 767px) {
  .productLineup .productLineupList .item_4 {
    max-width: 60px;
  }
}

.productLineup .btnWrap {
  text-align: center;
  margin-bottom: 5px;
}

@media (max-width: 767px) {
  .productLineup .btnWrap {
    margin-bottom: 0;
  }
}

.productLineup .fmt_btn_1,
.productLineup .fmt_btn_2,
.productLineup .fmt_btn_3 {
  font-size: 1.4rem;
}

@media (max-width: 767px) {
  .productLineup .fmt_btn_1,
  .productLineup .fmt_btn_2,
  .productLineup .fmt_btn_3 {
    line-height: 1.2;
    width: 92%;
    font-size: 1.2rem;
    padding: 3px 0;
    margin-bottom: 5px;
  }
}

.jp .productDetails .title {
  /*font-family: 'Noto Serif JP', serif;*/
}

@media (max-width: 767px) {
  .en .productList a,
  .de .productList a {
    font-size: 1rem;
  }
}

.en .productDetails .title,
.de .productDetails .title {
  font-size: 1.9rem;
}

@media (max-width: 767px) {
  .en .productDetails .title,
  .de .productDetails .title {
    font-size: 4.2vw;
  }
}

.en .productDetails p,
.de .productDetails p {
  font-size: 1.3rem;
}

.de .productList {
  height: 110px;
}

@media (max-width: 767px) {
  .de .productList {
    height: 70px;
  }
}

.carbody .productLineup .productLineupList li {
  width: calc(100% / 3 - 2px);
}

@media (max-width: 767px) {
  .carbody .productLineup .productLineupList li:first-child {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .carbody .productLineup .productLineupList li:first-child .toptext {
    width: 54%;
    margin: 0 auto;
  }
}

@media (max-width: 767px) {
  .carbody .productLineup .productLineupList li {
    width: calc(50% - 10px);
  }
}

.carbody .productLineup .item_1 {
  max-width: 186px;
}

@media (max-width: 767px) {
  .carbody .productLineup .item_1 {
    max-width: 163px;
  }
}

.carbody .productLineup .item_2 {
  max-width: 100px;
}

@media (max-width: 767px) {
  .carbody .productLineup .item_2 {
    max-width: 55px;
  }
}

.carbody .productLineup .item_3 {
  max-width: 135px;
}

@media (max-width: 767px) {
  .carbody .productLineup .item_3 {
    max-width: 80px;
  }
}

.carbody .productLineup .toptext .min {
  display: block;
  margin-left: 20px;
}

@media (max-width: 767px) {
  .carbody .productLineup .toptext .min {
    margin-left: 0;
  }
}

.carbody .productLineup .toptext .color_1 {
  background: #17a8d7;
}

.carbody .productLineup .toptext .color_2 {
  background: #6b7885;
}

.carbody .productLineup .toptext .color_3 {
  background: #156aa3;
}

.en .productLineupList .toptext .min,
.de .productLineupList .toptext .min {
  display: block;
  margin-left: 20px;
}

@media (max-width: 767px) {
  .en .productLineupList .toptext .min,
  .de .productLineupList .toptext .min {
    margin-left: 0;
    font-size: 1rem;
  }
}

.en.powertrain .productLineupList li:last-child .imgBoxWrap,
.de.powertrain .productLineupList li:last-child .imgBoxWrap {
  height: 200px;
}

@media (max-width: 767px) {
  .en.powertrain .productLineupList li:last-child .imgBoxWrap,
  .de.powertrain .productLineupList li:last-child .imgBoxWrap {
    height: 121px;
  }
}

@media screen and (max-width: 394px) {
  .en.powertrain .productLineupList li:last-child .imgBoxWrap,
  .de.powertrain .productLineupList li:last-child .imgBoxWrap {
    height: 104px;
  }
}

.en.powertrain .productLineupList li:last-child .item_4,
.de.powertrain .productLineupList li:last-child .item_4 {
  max-width: 80px;
}

@media (max-width: 767px) {
  .en.powertrain .productLineupList li:last-child .item_4,
  .de.powertrain .productLineupList li:last-child .item_4 {
    max-width: 52px;
  }
}

.de.carbody .productLineupList li:nth-child(2) .imgBoxWrap {
  height: 180px;
}

@media (max-width: 767px) {
  .de.carbody .productLineupList li:nth-child(2) .imgBoxWrap {
    height: 102px;
  }
}

@media screen and (max-width: 394px) {
  .de.carbody .productLineupList li:nth-child(2) .imgBoxWrap {
    height: 85px;
  }
}

.de.carbody .productLineupList li:nth-child(2) .item_2 {
  max-width: 80px;
}

@media (max-width: 767px) {
  .de.carbody .productLineupList li:nth-child(2) .item_2 {
    max-width: 45px;
  }
}

.cdisSec {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto 60px;
}

@media (max-width: 767px) {
  .cdisSec {
    margin-top: 60px;
  }
}

.cdisSec .logo {
  text-align: center;
  margin-bottom: 30px;
}

@media (max-width: 767px) {
  .cdisSec .logo {
    margin-bottom: 20px;
  }
}

.cdisSec .logo .imgBox {
  width: 203px;
  margin: 0 auto 10px;
}

@media (max-width: 767px) {
  .cdisSec .logo .imgBox {
    width: 125px;
    margin: 0 auto 0px;
  }
}

.cdisSec .logo .imgBox img {
  width: 100%;
}

.cdisSec .logo span {
  font-size: 1.5rem;
  letter-spacing: 0.1em;
}

@media (max-width: 767px) {
  .cdisSec .logo span {
    font-size: 1rem;
  }
}

.cdisSec .cdisImg {
  width: 100%;
  margin-bottom: 20px;
}

.cdisSec .cdisImg img {
  width: 100%;
}

.cdisSec p {
  width: calc(100% - 40px);
  max-width: 700px;
  margin: 0 auto 40px;
}

@media (max-width: 767px) {
  .cdisSec p {
    font-size: 1.3rem;
  }
}

.cdisSec .btnWrap {
  text-align: center;
}

.en .cdisSec p {
  max-width: 640px;
  font-size: 1.3rem;
}

.de .cdisSec p {
  max-width: 800px;
  font-size: 1.3rem;
}

.detailsContents {
  width: calc(100% - 40px);
  max-width: 1160px;
  margin: 60px auto 80px;
}

@media (max-width: 767px) {
  .detailsContents {
    margin: 20px auto 80px;
  }
}

.detailsMainSec {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 40px;
}

@media (max-width: 767px) {
  .detailsMainSec {
    display: block;
  }
}

.detailsMainSec .textBox {
  width: calc(60% - 50px);
  margin-right: 50px;
}

@media (max-width: 767px) {
  .detailsMainSec .textBox {
    width: 100%;
  }
}

.detailsMainSec .textBox .title {
  font-size: 2.7rem;
  /*text-align: center;*/
  margin-bottom: 10px;
}

@media (max-width: 767px) {
  .detailsMainSec .textBox .title {
    /*font-size: 2.4rem;*/
    font-size: 5.2vw;
  }
}

.detailsMainSec .textBox p {
  margin-bottom: 30px;
  font-size: 1.6rem;
}

@media (max-width: 767px) {
  .detailsMainSec .textBox p {
    font-size: 1.3rem;
  }
}

.detailsMainSec .textBox .figureImg {
  width: 100%;
}

@media (max-width: 767px) {
  .detailsMainSec .textBox .figureImg {
    margin-bottom: 20px;
  }
}

.detailsMainSec .textBox .figureImg img {
  width: 100%;
}

.detailsMainSec .imgBox {
  width: 35%;
}

@media (max-width: 767px) {
  .detailsMainSec .imgBox {
    width: 80%;
    height: 100%;
    margin: 0 auto 20px;
  }
}

.detailsMainSec .imgBox img {
  width: 100%;
}

@media (max-width: 767px) {
  .detailsMainSec .imgBox img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    /* 他のブラウザ用(＝通常の指定) */
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    /* 他のブラウザ用(＝通常の指定) */
    font-family: "object-fit: cover; object-position: 50% 50%;";
  }
}

.detailsBox {
  margin-bottom: 60px;
}

.detailsBox .detailsBoxInner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: flex-start;
  margin-bottom: 40px;
  gap: 5%;
}

@media (max-width: 767px) {
  .detailsBox .detailsBoxInner {
    display: block;
  }
}

.detailsBox .detailsBoxInner:last-child {
  margin-bottom: 0;
}

.detailsBox .detailsBoxInner ol {
  list-style-type: decimal;
  font-size: 1.5rem;
  margin-left: 30px;
}

@media (max-width: 767px) {
  .detailsBox .detailsBoxInner ol {
    font-size: 1.3rem;
  }
}

.detailsBox .imgBox {
  width: 50%;
}

@media (max-width: 767px) {
  .detailsBox .imgBox {
    width: 100%;
    margin: 0 auto 30px;
    text-align: center;
  }
}

.detailsBox .imgBox img {
  width: 100%;
}

.detailsBox .imgTagred {
  color: #e7211a;
  border: 1px solid #e7211a;
  font-size: 1.2rem;
  display: block;
  text-align: center;
  width: 140px;
  margin-bottom: 5px;
}

@media (max-width: 767px) {
  .detailsBox .imgTagred {
    margin: 0 auto 5px;
  }
}

.detailsBox .imgTag {
  font-size: 1.4rem;
  color: #fff;
  background: #666767;
  padding: 2px 10px;
  display: inline-block;
  margin-bottom: 20px;
}

.detailsBox .textBox {
  width: 50%;
}

@media (max-width: 767px) {
  .detailsBox .textBox {
    width: 100%;
    padding: 0 10px;
  }
}

.detailsBox .textBox .title {
  font-size: 1.8rem;
  line-height: 1.5;
  margin-bottom: 15px;
  font-weight: 600;
  letter-spacing: -1px;
}

@media (max-width: 767px) {
  .detailsBox .textBox .title {
    font-size: 1.6rem;
  }
}

.detailsBox .textBox p {
  font-size: 1.5rem;
  line-height: 1.4;
}

@media (max-width: 767px) {
  .detailsBox .textBox p {
    font-size: 1.3rem;
  }
}

.detailsBox .textBox span {
  display: block;
  padding: 10px 20px;
}

.detailsTitle {
  font-size: 2.4rem;
  font-weight: normal;
  color: #fff;
  background: url(/fileadmin/templates2020/images/mobility-solutions/bg_2.jpg) no-repeat;
  background-position: center;
  background-size: cover;
  padding: 0 20px;
  margin-bottom: 30px;
}

@media (max-width: 767px) {
  .detailsTitle {
    font-size: 1.7rem;
    padding: 5px 0;
    line-height: 1.4;
    background-size: auto;
    height: 60px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
  }
}

.camclutch .img_3 {
  max-width: 280px;
}

@media (max-width: 767px) {
  .camclutch .img_3 {
    width: 60%;
  }
}

.camclutch .img_4 {
  max-width: 380px;
}

@media (max-width: 767px) {
  .camclutch .img_4 {
    width: 80%;
  }
}

.camclutch .img_5 {
  max-width: 320px;
}

@media (max-width: 767px) {
  .camclutch .img_5 {
    width: 80%;
  }
}

.camclutch .img_6 {
  max-width: 350px;
}

.camclutch .img_7 {
  max-width: 350px;
}

.camclutch .img_8 {
  max-width: 200px;
  width: 100%;
  margin-bottom: 30px;
}

@media (max-width: 767px) {
  .camclutch .img_8 {
    margin: 0 auto 30px;
  }
}

.camclutch .img_9 {
  width: 100%;
  max-width: 180px;
  margin: 0 auto 40px;
}

.camclutch .img_10 {
  width: 100%;
  max-width: 180px;
  margin: 0 auto;
}

.camclutch .img_11 {
  max-width: 350px;
}

.camclutch .img_12 {
  width: 100%;
  max-width: 560px;
  margin-bottom: 60px;
}

@media (max-width: 767px) {
  .camclutch .img_12 {
    text-align: center;
    width: 80%;
    margin: 0 auto 30px;
  }
}

.camclutch .img_12 img {
  width: 100%;
}

.camclutch .img_13 {
  max-width: 330px;
}

@media (max-width: 767px) {
  .camclutch .img_13 {
    width: 80%;
  }
}

.camclutch .img_14 {
  max-width: 300px;
}

@media (max-width: 767px) {
  .camclutch .img_14 {
    width: 70%;
  }
}

.camclutch .img_15 {
  max-width: 340px;
}

@media (max-width: 767px) {
  .camclutch .img_15 {
    width: 80%;
  }
}

.timingchain .detailsBoxInner .imgBox {
  width: 45%;
}

@media (max-width: 767px) {
  .timingchain .detailsBoxInner .imgBox {
    width: 85%;
  }
}

.timingchain .detailsBoxInner ul li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  line-height: 1;
}

.timingchain .detailsBoxInner ul li:before {
  content: "・";
}

.timingchain .detailsBoxInnerWrap {
  margin-bottom: 50px;
}

@media (max-width: 767px) {
  .timingchain .detailsBoxInnerWrap {
    margin-bottom: 20px;
  }
}

.timingchain .detailsBoxInnerWrap .imgBox {
  width: 40%;
}

@media (max-width: 767px) {
  .timingchain .detailsBoxInnerWrap .imgBox {
    width: 90%;
  }
}

@media (max-width: 767px) {
  .timingchain .imgTgWrap {
    text-align: center;
  }
}

.timingchain .imgTag {
  background: #666767;
  color: #fff;
  border-radius: 5px;
  padding: 3px 20px;
  font-size: 1.6rem;
}

@media (max-width: 767px) {
  .timingchain .imgTag {
    font-size: 1.4rem;
  }
}

.timingchain .oto {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  color: #fff;
  margin-top: 20px;
}

.timingchain .oto a {
  width: calc(50% - 15px);
  display: block;
  font-size: 1.4rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}

@media (max-width: 767px) {
  .timingchain .oto a {
    width: calc(50% - 8px);
    font-size: 1.1rem;
  }
}

.timingchain .video span {
  color: #fff;
  background-size: cover;
  font-size: 1.4rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 100%;
}

@media (max-width: 767px) {
  .timingchain .video span {
    font-size: 1.2rem;
  }
}

.jp .detailsMainSec .title {
  /*font-family: 'Noto Serif JP', serif;*/
  font-weight: 500;
}

@media (max-width: 1000px) {
  .jp .detailsMainSec .title {
    font-size: 2.6vw;
  }
}

@media (max-width: 767px) {
  .jp .detailsMainSec .title {
    font-size: 5.2vw;
  }
}

.jp .detailsTitle {
  /*font-family: 'Noto Serif JP', serif;*/
  font-weight: 500;
}

.en .detailsMainSec .title,
.de .detailsMainSec .title {
  font-size: 3rem;
  line-height: 1.2;
}

@media (max-width: 767px) {
  .en .detailsMainSec .title,
  .de .detailsMainSec .title {
    font-size: 2.4rem;
    font-weight: normal;
  }
}

.en .detailsMainSec p,
.de .detailsMainSec p {
  line-height: 1.4;
  font-size: 1.5rem;
}

@media (max-width: 767px) {
  .en .detailsMainSec p,
  .de .detailsMainSec p {
    font-size: 1.1rem;
  }
}

.en .detailsBox ol,
.de .detailsBox ol {
  font-size: 1.3rem;
}

@media (max-width: 767px) {
  .en .detailsBox ol,
  .de .detailsBox ol {
    font-size: 1.1rem;
  }
}

@media (max-width: 767px) {
  .en .detailsBox .imgBox,
  .de .detailsBox .imgBox {
    margin: 0 auto 15px;
  }
}

.en .detailsBox .title,
.de .detailsBox .title {
  font-size: 2rem;
}

@media (max-width: 767px) {
  .en .detailsBox .title,
  .de .detailsBox .title {
    font-size: 1.6rem;
  }
}

.en .detailsBox p,
.de .detailsBox p {
  font-size: 1.3rem;
}

@media (max-width: 767px) {
  .en .detailsBox p,
  .de .detailsBox p {
    font-size: 1.1rem;
  }
}

@media (max-width: 767px) {
  .en .detailsBox .imgTag,
  .de .detailsBox .imgTag {
    font-size: 1.2rem;
  }
}

.en .detailsTitle,
.de .detailsTitle {
  font-size: 2.1rem;
}

@media (max-width: 767px) {
  .en .detailsTitle,
  .de .detailsTitle {
    font-size: 1.6rem;
  }
}