.f-red {
  color: #FF1142;
}

.f-blue {
  color: #117DD8;
}

.f-vermilion {
  color: #FF5611;
}

.b-dns .u-header,
.b-missionstatement .u-header {
  position: relative;
  margin-bottom: 17.3333333333vw;
}
.b-dns .u-header .e-ja,
.b-missionstatement .u-header .e-ja {
  font-family: 'Noto Serif JP', serif;
  font-size: 20px;
  letter-spacing: .5em;
  text-align: center;
}
.b-dns .u-header .e-en,
.b-missionstatement .u-header .e-en {
  -webkit-transform: translateY(-50%);
  position: absolute;
  top: 50%;
          transform: translateY(-50%);
  font-family: Barlow, sans-serif;
  font-size: 30px;
  font-weight: 600;
  line-height: 1;
}
.b-dns .u-header .e-en.m-right,
.b-missionstatement .u-header .e-en.m-right {
  right: 0;
}

.b-dns {
  position: relative;
  padding-top: 13.3333333333vw;
  padding-bottom: 54.4vw;
  background-color: #FFF3EE;
}
.b-dns .e-en {
  color: #FFEDE5;
}
.b-dns .e-img {
  width: 32.8358208955%;
}
.b-dns .e-lists {
  width: 59.1044776119%;
  margin-left: auto;
}
.b-dns .e-lists .e-item + .e-item {
  margin-top: 17.3333333333vw;
}
.b-dns .e-lists .e-ja {
  margin-bottom: 4vw;
  font-family: 'Noto Serif JP', serif;
  font-size: 17px;
}
.b-dns .e-lists .e-en {
  margin-bottom: 2.6666666667vw;
  color: #FF5611;
  font-family: "Garamond", sans-serif;
  font-size: 12px;
  font-weight: bold;
}
.b-dns .e-image {
  -webkit-transform: translateY(50%);
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
          transform: translateY(50%);
}
.b-dns .e-image #canvasWave {
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.b-dns .e-image picture {
  display: block;
  position: relative;
  width: 100%;
  padding-bottom: 66.6666666667%;
}
.b-dns .e-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 85.3333333333%;
}

.b-missionstatement {
  margin-bottom: 30.1333333333vw;
  padding-top: 50.9333333333vw;
}
.b-missionstatement .e-en {
  color: #F6F6F6;
}
.b-missionstatement .e-posture {
  padding-top: 14.6666666667vw;
  padding-bottom: 20vw;
  background-color: #F6F6F6;
  font-family: 'Noto Serif JP', serif;
}
.b-missionstatement .e-posture .e-wrap + .e-wrap {
  margin-top: 29.3333333333vw;
}
.b-missionstatement .e-posture .e-heading {
  width: 80%;
  margin-right: auto;
  margin-bottom: 10.6666666667vw;
  margin-left: auto;
  padding-bottom: 11.4666666667vw;
  border-bottom: 1px solid #BBB;
  font-size: 18px;
  text-align: center;
}
.b-missionstatement .e-posture ul {
  width: 80%;
  margin-right: auto;
  margin-left: auto;
  padding: 0 5%;
}
.b-missionstatement .e-posture li {
  padding: 5px 0;
  padding-left: 1.55em;
  font-size: 15px;
  line-height: 1.87;
  text-indent: -1.55em;
}
@media (min-width: 768px) {
  .b-dns .u-header,
  .b-missionstatement .u-header {
    margin-bottom: 150px;
  }
  .b-dns .u-header .e-ja,
  .b-missionstatement .u-header .e-ja {
    font-size: 30px;
  }
  .b-dns .u-header .e-en,
  .b-missionstatement .u-header .e-en {
    font-size: 100px;
  }
  .b-dns .u-header .e-en.m-right,
  .b-missionstatement .u-header .e-en.m-right {
    -webkit-transform: translate(100%, -50%);
    right: calc(50% - 100px);
            transform: translate(100%, -50%);
  }
  .b-dns .u-header .e-en.m-left,
  .b-missionstatement .u-header .e-en.m-left {
    -webkit-transform: translate(-100%, -50%);
    left: calc(50% - 100px);
            transform: translate(-100%, -50%);
  }
  .b-dns {
    padding-top: 171px;
    padding-bottom: 334px;
  }
  .b-dns .e-img {
    display: none;
  }
  .b-dns .e-lists {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
            align-items: center;
            justify-content: center;
    width: 1555px;
    height: 340px;
    margin: 0 auto;
    background: url(../images/corporate/philosophy/img_dna_mark.png) center no-repeat;
  }
  .b-dns .e-lists .e-item {
    width: 385px;
    text-align: center;
  }
  .b-dns .e-lists .e-item + .e-item {
    margin-top: 0;
  }
  .b-dns .e-lists .e-ja {
    margin-bottom: 25px;
    font-size: 24px;
  }
  .b-dns .e-lists .e-en {
    margin-bottom: 20px;
    font-size: 14px;
  }
  .b-dns .e-lists .e-text {
    font-size: 18px;
  }
  .b-dns .e-image {
    -webkit-transform: translateY(416px);
    height: 550px;
            transform: translateY(416px);
  }
  .b-dns .e-image picture {
    position: absolute;
    top: 0;
    left: 50%;
    width: 1920px;
    margin-left: -960px;
    padding-bottom: 0;
  }
  .b-dns .e-image img {
    position: absolute;
    top: 0;
    right: calc(50% - 600px);
    width: 1560px;
    height: 560px;
  }
  .b-missionstatement {
    margin-bottom: 180px;
    padding-top: 576px;
  }
  .b-missionstatement .e-posture {
    padding-top: 123px;
    padding-bottom: 140px;
  }
  .b-missionstatement .e-posture .e-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
            align-items: center;
    width: 798px;
    margin: 0 auto;
  }
  .b-missionstatement .e-posture .e-wrap + .e-wrap {
    margin-top: 101px;
  }
  .b-missionstatement .e-posture .e-heading {
    width: 248px;
    margin: 0;
    padding-bottom: 0;
    border-bottom: none;
    font-size: 26px;
    text-align: left;
  }
  .b-missionstatement .e-posture ul {
    width: 550px;
    margin: 0;
    padding-left: 100px;
    border-left: 1px solid #BBB;
  }
  .b-missionstatement .e-posture li {
    font-size: 20px;
  }
}
@media (max-width: 767px) {
  .b-dns .e-wrap {
    -webkit-box-align: center;
        -ms-flex-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
            align-items: center;
    width: 89.3333333333%;
    margin-right: auto;
    margin-left: auto;
  }
}
