@charset "UTF-8";

.ttl {
  padding: 318px 0 180px;
  position: relative;
  z-index: 5;
}

.env-sec_ttl {
  font-size: 54px;
  font-weight: 600;
  line-height: 1.7;
  margin-bottom: 65px;
}

.env-sec_txt {
  font-size: 22px;
  font-weight: 600;
  line-height: 2.18;
}

.env-sec_comment {
  color: #7c7b7a;
  font-size: 14px;
  margin-top: 30px;
}

/* env-sec01 */
.env-sec01 {
  width: 100%;
  position: relative;
}

.env-sec01::before {
  content: "";
  display: block;
  padding-top: 60%;
}

.env-sec01 .env-sec_txt {
  width: 65%;
}

.env-sec01_inner {
  background-size: cover;
  background-position: right center;
  background-repeat: no-repeat;
  width: 55%;
  position: absolute;
  right: 0;
  top: -10%;
}

.env-sec01_bg {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: left;
  position: absolute;
  content: "";
  top: -40%;
  left: 0;
  width: 100%;
  z-index: 2;
}

.env-sec01_bg::before {
  content: "";
  display: block;
  padding-top: 98.36%;
}

.env-sec01_content {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0%;
  margin-left: -12%;
  z-index: 3;
}

.env-sec01_subttl {
  font-size: 26px;
  font-weight: 600;
  line-height: 2;
  margin-top: 24%;
}

.env-sec01_content_bottom {
  position: relative;
}

.env-sec01_ring {
  position: absolute;
  left: 400px;
  top: -20%;
  z-index: 3;
  width: 40%;
}

/* env-sec02 */
.env-sec02 {
  padding: 10% 0 0;
  position: relative;
  margin-top: -3%;
}

.env-sec02 .content_inner {
  padding-right: 0;
}

.env-sec02_flex {
  display: flex;
  align-items: center;
}

.env-sec02_img {
  width: 45%;
  z-index: 2;
  margin-left: auto;
  margin-right: 0;
}

.env-sec02_content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 2;
  width: 55%;
  padding-left: 4%;
}

/* env-sec03 */
.env-sec03 {
  padding: 10.5% 0 0;
  position: relative;
}

.env-sec03 .content_inner {
  padding-right: 0;
}

.env-sec03_flex {
  display: flex;
  align-items: center;
}

.env-sec03_img {
  width: 40%;
  z-index: 2;
  margin-left: auto;
  margin-right: 0;
}

.env-sec03_content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-top: -15px;
  z-index: 2;
  width: 50%;
}

/* env-sec04 */
.env-sec04 {
  padding: 10.5% 0 0;
  position: relative;
}

/* env-sec05 */
.env-sec05 {
  padding: 10.5% 0 0;
  position: relative;
}

.env-sec05 .content_inner {
  padding-right: 0;
}

.env-sec05_flex {
  display: flex;
  align-items: flex-start;
}

.env-sec05_img {
  width: 35%;
  padding-left: 5%;
  z-index: 2;
  margin-left: auto;
  margin-right: 0;
}

.env-sec05_content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-top: -15px;
  z-index: 2;
  width: 60%;
}

.bg_item01 {
  background-size: contain;
  background-repeat: no-repeat;
  width: 20vw;
  height: 100%;
  position: absolute;
  top: -350px;
  right: 3vw;
  z-index: 3;
}

.bg_item02 {
  background-size: contain;
  background-repeat: no-repeat;
  width: 22vw;
  height: 100%;
  position: absolute;
  top: 50%;
  left: -10vw;
  z-index: 3;
  transform: translateX(-50%);
  margin-top: -35%;

}

.bg_item03 {
  background-size: contain;
  background-repeat: no-repeat;
  width: 30%;
  height: 100%;
  position: absolute;
  bottom: -450px;
  right: -16vw;
  z-index: 3;
}

@media print,
screen and (min-width:768px) {
  .ttl_ja {
    margin-top: 25px;
  }

  .js-fixed_img {
    right: -30%;
    left: auto !important;
  }
}

@media screen and (max-width:767px) {
  .ttl_ja {
    margin-top: 20px;
  }

  .content_inner {
    padding: 0;
    width: 100%;
  }

  .ttl {
    padding: 150px 0 50px;
  }

  .env-sec_ttl {
    font-size: 25px;
    margin-bottom: 30px;
  }

  .env-sec_txt {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.6;
  }

  .env-sec01 {
    display: flex;
    flex-direction: column-reverse;
  }

  .env-sec01::before {
    content: none;
  }

  .env-sec01_bg {
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: top left;
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    margin-top: -50%;
    z-index: 4;
  }

  .env-sec01_bg::before {
    content: "";
    display: block;
    padding-top: 200%;
  }

  .env-sec01_inner {
    background-size: cover;
    background-position: -650px center;
    background-repeat: no-repeat;
    width: 100%;
    position: absolute;
    right: 0;
    top: 0;
    padding: 0;
    min-height: 120vw;
  }

  .env-sec01_content {
    position: relative;
    left: 0;
    top: 0;
    z-index: 3;
    margin: 0;
    transform: none;
    padding: 0 8%;
    margin-top: -30%;
    padding-top: 20%;
    background-image: url('/jpn/consumer/products/common/images/bg.jpg');
    background-size: 180% auto;
    background-position: center;
    background-repeat: repeat-y;
    width: 100%;
  }

  .env-sec01 .env-sec_txt {
    width: 100%;
  }

  .env-sec01_ring {
    position: static;
    left: auto;
    top: auto;
    margin: 0 auto;
    display: block;
    width: 80%;
  }

  .env-sec_comment {
    font-family: 'Noto Sans JP', sans-serif;
  }

  .env-sec01_subttl {
    font-size: 22px;
    font-weight: 600;
    line-height: 1.5;
    margin-top: 40px;
  }

  .env-sec02_flex {
    display: block;
    padding: 0 8%;
    width: 100%;
  }

  .env-sec02_img {
    margin-left: 11%;
    display: block;
    width: 100%;
  }

  .env-sec02_content {
    padding: 0;
    width: 100%;
  }

  .env-sec03 .env-sec_ttl {
    padding: 0 8%;
  }

  .env-sec03 {
    padding-top: 20%;
  }

  .env-sec03_flex {
    display: block;
    padding: 0 8%;
    width: 100%;
  }

  .env-sec03_content {
    width: 100%;
  }

  .env-sec03_img {
    display: block;
    margin: 15% 0 0;
    width: 100%;
  }

  .env-sec04 {
    margin: 12% 0 0;
  }

  .env-sec04 .env-sec_ttl {
    margin-bottom: 10%;
  }

  .env-sec04_content {
    padding: 0 8%;
    width: 100%;
  }

  /* .env-sec05 */
  .env-sec05 {
    margin: 12% 0 27%;
  }

  .env-sec05 .env-sec_txt {
    padding: 80% 0 0;
  }

  .env-sec05_flex {
    display: block;
    padding: 0 8%;
    width: 100%;
  }

  .env-sec05_content {
    width: 100%;
  }

  .env-sec05_img {
    position: absolute;
    top: 30%;
    left: 50%;
    transform: translateX(-50%);
    padding: 0;
    width: 45%;
    margin-left: -12%;
  }

  .bg_item01 {
    background-size: contain;
    background-repeat: no-repeat;
    width: 40vw;
    height: auto;
    position: absolute;
    top: -15%;
    right: -17vw;
    z-index: 5;
  }

  .bg_item01::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .bg_item02 {
    background-size: contain;
    background-repeat: no-repeat;
    width: 35vw;
    position: absolute;
    top: -125%;
    left: -15vw;
    z-index: 4;
    transform: translateX(-50%);
  }

  .bg_item02::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .bg_item03 {
    background-size: contain;
    background-repeat: no-repeat;
    width: 45%;
    position: absolute;
    top: 0;
    right: -20vw;
    z-index: 3;
    height: auto;
  }

  .bg_item03::before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .links .content_inner {
    padding: 0 20px;
  }
}

@media screen and (min-width:1024px) and (max-width:1176px) {
  .content_inner {
    width: 100%;
    padding: 0 20px;
  }
}