@import url(https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700|Poppins:400,500,600,700);


:root {
  --base-font-size: 16;
  --rem-font-size: 16px;
  --inner-padding: calc(50 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  :root {
    --rem-font-size: calc(16 / 1024 * 100vw);
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  :root {
    --rem-font-size: calc(16 / 375 * 100vw);
    --inner-padding: calc(25 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * メインコンテンツ
 */
.main {
  display: block;
  font-family: "Poppins", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", メイリオ, sans-serif;
  font-size: calc(16 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .main {
    /* --rem-font-size: calc(16 / 1024 * 100vw); */
    font-size: calc(12 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  /* .main {
    --rem-font-size: calc(16 / 375 * 100vw);
    --inner-padding: calc(25 / var(--base-font-size) * var(--rem-font-size));
  } */
}

.main img {
  display: block;
  width: 100%;
  height: auto;
}


/**
 * マージン
 */
.mt-80 {
  margin-top: calc(80 / var(--base-font-size) * var(--rem-font-size));
}

.mt-30-20 {
  margin-top: calc(30 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .mt-30-20 {
    margin-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
  }
}

.mt-80-20 {
  margin-top: calc(80 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .mt-80-20 {
    margin-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * 表示・非表示
 */
@media screen and (min-width: 767.1px) {
  .visible-sp {
    display: none !important;
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .hidden-sp {
    display: none !important;
  }
}


/**
 * アンカーのヘッダー埋もれ解消
 */
 .anchor {
  display: flex;
  align-items: flex-end;
  background: transparent;
  position: absolute;
  padding-bottom: 100px;
  width: 0px;
  pointer-events: none;
  user-select: none;
  transform: translateY(-100%);
}


/**
 * モーダル表示用のボタン
 */
.more {
  font-size: calc(20 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .more {
    font-size: calc(16 / var(--base-font-size) * var(--rem-font-size));
  }
}

.more__icn {
  width: calc(6 / var(--base-font-size) * var(--rem-font-size));
  height: calc(9 / var(--base-font-size) * var(--rem-font-size));
}
/*
@media screen and (min-width: 0px) and (max-width: 767px) {
  .more__icn {
    width: calc(6 / var(--base-font-size) * var(--rem-font-size));
    height: calc(9 / var(--base-font-size) * var(--rem-font-size));
  }
} */


/**
 * インナー
 */
.inner-1200 {
  max-width: calc(1200 / var(--base-font-size) * var(--rem-font-size));
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--inner-padding);
  padding-right: var(--inner-padding);
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}


/**
 * 黒背景のコンテンツ
 */
.wrapper-1 {
  padding-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
  background: #000;
  color: #fff;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .wrapper-1 {
    padding-top: calc(50 / var(--base-font-size) * var(--rem-font-size));
  }
}



/**
 * 白背景のコンテンツ
 */
 .wrapper-2 {
  padding-bottom: calc(150 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .wrapper-2 {
    padding-bottom: calc(80 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * メインビジュアル下のスクロール
 */
.scroll {
  display: block;
  width: calc(24 / var(--base-font-size) * var(--rem-font-size));
  margin-left: auto;
  margin-right: auto;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .scroll {
    display: none;
  }
}


/**
 * セクションの見出し
 */
.header {
  font-size: calc(28 / var(--base-font-size) * var(--rem-font-size));
  margin-bottom: calc(40 / var(--base-font-size) * var(--rem-font-size));
  text-align: center;
  letter-spacing: 0.2em;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .header {
    font-size: calc(22 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * section : SHOWER
 */
.shower {
  margin-top: calc(38 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower {
    margin-top: 0;
  }
}


/**
 * SHOWER内のコンテンツ
 */
.shower-contents {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-contents {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}

.shower-contents__column {
  display: -ms-grid;
  display: grid;
  -ms-flex-align: center;
      -webkit-box-align: center;
          align-items: center;
}

.shower-contents__body {
  position: relative;
  z-index: 1;
  -ms-grid-column: 1;
  grid-column: 1;
  -ms-grid-row: 1;
  grid-row: 1;
  padding-left: calc(100 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-contents__body {
    padding-left: calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-contents__title {
  /* font-family: "Poppins", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", メイリオ, sans-serif; */
  font-size: calc(56 / var(--base-font-size) * var(--rem-font-size));
  line-height: 1;
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
  .shower-contents__title {
    font-size: calc(40 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-contents__text {
  margin-top: calc(15 / var(--base-font-size) * var(--rem-font-size));
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 100%;
  grid-template-columns: 100%;
  gap: 0.75em;
  line-height: 1.8;
}

.shower-contents__button {
  margin-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-contents__button {
    margin-top: calc(10 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-contents__thumbnail {
  -ms-grid-column: 1;
  grid-column: 1;
  -ms-grid-row: 1;
  grid-row: 1;
}


/**
 * 製品のグリッド 2カラム
 */
.shower-grid-1 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr calc(30 / var(--base-font-size) * var(--rem-font-size)) 1fr;
  grid-template-columns: 1fr 1fr;
  gap: calc(10 / var(--base-font-size) * var(--rem-font-size)) calc(30 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-grid-1 {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
  }
}


/**
 * 製品のグリッド 3カラム
 */
.shower-grid-2 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr calc(30 / var(--base-font-size) * var(--rem-font-size)) 1fr calc(30 / var(--base-font-size) * var(--rem-font-size)) 1fr;
  grid-template-columns: 1fr 1fr 1fr;
  gap: calc(10 / var(--base-font-size) * var(--rem-font-size)) calc(30 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .shower-grid-2 {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-grid-2 {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
  }
}


/**
 * 製品のグリッド
 */
.shower-card {
  display: -ms-grid;
  display: grid;
  color: #fff;
  -ms-flex-align: start;
      -webkit-box-align: start;
          align-items: flex-start;
  border: solid 1px #3B3B3B;
}

.shower-card__body {
  -ms-grid-column: 1;
  grid-column: 1;
  -ms-grid-row: 1;
  grid-row: 1;
  position: relative;
  z-index: 1;
  padding-top: calc(40 / var(--base-font-size) * var(--rem-font-size));
  padding-bottom: calc(40 / var(--base-font-size) * var(--rem-font-size));
  padding-left: calc(60 / var(--base-font-size) * var(--rem-font-size));
  padding-right: calc(20 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-card__body {
    padding-top: calc(30 / var(--base-font-size) * var(--rem-font-size));
    padding-left: calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-card__icons {
  display: -ms-grid;
  display: grid;
  grid-template-columns: repeat(auto-fill, calc(65 / var(--base-font-size) * var(--rem-font-size)));
  gap: calc(10 / var(--base-font-size) * var(--rem-font-size));
  margin-bottom: calc(10 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .shower-card__icons {
    grid-template-columns: repeat(auto-fill, calc(50 / var(--base-font-size) * var(--rem-font-size)));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-card__icons {
    grid-template-columns: repeat(auto-fill, calc(53 / var(--base-font-size) * var(--rem-font-size)));
  }
}

.shower-card__title {
  font-size: calc(24 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 600;
}

.shower-card__title.-margin {
  margin-top: calc(75 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .shower-card__title.-margin {
    margin-top: calc(55 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-card__text {
  margin-top: calc(5 / var(--base-font-size) * var(--rem-font-size));
}

.shower-card__button {
  margin-top: calc(25 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .shower-card__button {
    margin-top: calc(10 / var(--base-font-size) * var(--rem-font-size));
  }
}

.shower-card__thumbnail {
  -ms-grid-column: 1;
  grid-column: 1;
  -ms-grid-row: 1;
  grid-row: 1;
}


/**
 * LINE UP
 */
.line-up {
  margin-top: calc(80 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .line-up {
    margin-top: calc(70 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * LINE UPの製品
 */
.product {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 705fr 735fr;
  grid-template-columns: 705fr 735fr;
  max-width: calc(1440 / var(--base-font-size) * var(--rem-font-size));
  margin-left: auto;
  margin-right: auto;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .product {
    grid-auto-flow: dense;
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
    padding-left: var(--inner-padding);
    padding-right: var(--inner-padding);
    gap: calc(30 / var(--base-font-size) * var(--rem-font-size));
  }

  .product + .product {
    margin-top: calc(35 / var(--base-font-size) * var(--rem-font-size));
  }
}

.product__body {
  padding-top: calc(85 / var(--base-font-size) * var(--rem-font-size));
  position: relative;
  z-index: 1;
  -ms-grid-column: 2;
  grid-column: 2;
  -ms-grid-row: 1;
  grid-row: 1;
  max-width: calc(615 / var(--base-font-size) * var(--rem-font-size));
  padding-right: calc(50 / var(--base-font-size) * var(--rem-font-size));
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

@media screen and (max-width: 1024px) {
  .product__body {
    padding-top: calc(40 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .product__body {
    padding-top: 0;
    padding-right: 0;
    grid-column: auto;
    grid-row: auto;
  }
}

.product__header {
  padding-bottom: calc(20 / var(--base-font-size) * var(--rem-font-size));
  margin-bottom: calc(20 / var(--base-font-size) * var(--rem-font-size));
  border-bottom: solid 1px #797979;
}

.product__name {
  line-height: 1.4;
  font-size: calc(56 / var(--base-font-size) * var(--rem-font-size));
  margin-bottom: calc(5 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .product__name {
    font-size: calc(40 / var(--base-font-size) * var(--rem-font-size));
  }
}

.product__text-1 {
}

.product__text-2 {
  font-size: calc(24 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 400;
  margin-bottom: calc(20 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
/* @media screen and (min-width: 0px) and (max-width: 767px) { */
  .product__text-2 {
    font-size: calc(20 / var(--base-font-size) * var(--rem-font-size));
  }
}

.product__button {
  margin-top: calc(30 / var(--base-font-size) * var(--rem-font-size));
}

.product__image {
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-column: 1 / 3;
  -ms-grid-row: 1;
  grid-row: 1;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .product__image {
    grid-column: auto;
    -ms-grid-row: 2;
    grid-row: 2;
  }
}


/**
 * 製品内の特徴のアイコンとラベル
 */
.feature-label {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-align: center;
      -webkit-box-align: center;
          align-items: center;
  gap: calc(30 / var(--base-font-size) * var(--rem-font-size)) calc(50 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .feature-label {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
    gap: calc(15 / var(--base-font-size) * var(--rem-font-size));
  }
}

.feature-label__item {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -ms-flex-align: center;
      -webkit-box-align: center;
          align-items: center;
  gap: calc(10 / var(--base-font-size) * var(--rem-font-size));
}

.feature-label__item.-wide {
  width: 100%;
}

.feature-label__icons {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  gap: calc(15 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .feature-label__icons {
    gap: calc(10 / var(--base-font-size) * var(--rem-font-size));
  }
}

.feature-label__icon {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: calc(40 / var(--base-font-size) * var(--rem-font-size));
}

.feature-label__label {
  font-size: calc(24 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 600;
}

@media screen and (max-width: 1024px) {
/* @media screen and (min-width: 0px) and (max-width: 767px) { */
  .feature-label__label {
    font-size: calc(20 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * Z Selectionの追加の画像
 */
.z-selection-image {

}


/**
 * SHOWCASE
 */
.showcase {
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase {
    margin-top: calc(80 / var(--base-font-size) * var(--rem-font-size));
    padding-bottom: calc(80 / var(--base-font-size) * var(--rem-font-size));
  }
}


/**
 * SHOWCASEのスライダー
 */
.showcase-slider {
  position: relative;
  /* max-width: calc(1440 / var(--base-font-size) * var(--rem-font-size));
  margin-left: auto;
  margin-right: auto; */
}

.showcase__card {
  display: block;
  overflow: hidden;
}

@media screen and (min-width: 1024.1px) {
  .showcase__card {
    -webkit-transition: -webkit-filter 0.3s ease;
    transition: -webkit-filter 0.3s ease;
    transition: filter 0.3s ease;
    transition: filter 0.3s ease, -webkit-filter 0.3s ease;
  }

  .showcase__card:hover {
    /* filter: brightness(140%); */
    /* filter: saturate(140%); */
    -webkit-filter: brightness(1.2);
            filter: brightness(1.2);
  }
}

.showcase-slider .swiper-slide-active .showcase-slider__background {
  -webkit-animation-duration: 7s;
          animation-duration: 7s;
  -webkit-animation-timing-function: ease;
          animation-timing-function: ease;
  -webkit-animation-name: bg-fade2;
          animation-name: bg-fade2;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.showcase-slider__indicator {
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__indicator {
    display: -ms-grid;
    display: grid;
    -ms-flex-align: center;
        -webkit-box-align: center;
            align-items: center;
    margin-top: calc(15 / var(--base-font-size) * var(--rem-font-size));
    gap: calc(35 / var(--base-font-size) * var(--rem-font-size));
    padding-right: calc(20 / var(--base-font-size) * var(--rem-font-size));
    padding-left: calc(20 / var(--base-font-size) * var(--rem-font-size));
    -ms-grid-columns:
      calc(8 / var(--base-font-size) * var(--rem-font-size)) calc(35 / var(--base-font-size) * var(--rem-font-size))
      1fr calc(35 / var(--base-font-size) * var(--rem-font-size))
      calc(8 / var(--base-font-size) * var(--rem-font-size));
    grid-template-columns:
      calc(8 / var(--base-font-size) * var(--rem-font-size))
      1fr
      calc(8 / var(--base-font-size) * var(--rem-font-size));
  }
}

.showcase-slider__pagination {
  position: absolute;
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  gap: calc(10 / var(--base-font-size) * var(--rem-font-size));
  right: calc(40 / var(--base-font-size) * var(--rem-font-size));
  bottom: calc(20 / var(--base-font-size) * var(--rem-font-size));
  z-index: 1;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__pagination {
    gap: calc(4 / var(--base-font-size) * var(--rem-font-size));
    position: static;
  }
}

.showcase-slider__bullet {
  position: relative;
  width: calc(40 / var(--base-font-size) * var(--rem-font-size));
  height: calc(2 / var(--base-font-size) * var(--rem-font-size));
  background: rgba(255, 255, 255, 0.4);
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__bullet {
    width: auto;
    -ms-flex-positive: 1;
        -webkit-box-flex: 1;
            flex-grow: 1;
  }
}

.showcase-slider__bullet.-active::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  background: #fff;
  -webkit-transform-origin: left;
          transform-origin: left;
  -webkit-animation-duration: 5s;
          animation-duration: 5s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-name: bullet;
          animation-name: bullet;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes bullet {
  0% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

@keyframes bullet {
  0% {
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  100% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
}

.showcase-slider__button-prev {
  position: absolute;
  z-index: 1;
  left: calc(40 / var(--base-font-size) * var(--rem-font-size));
  top: 50%;
  -webkit-transform: translateY(-50%) scaleX(-1);
          transform: translateY(-50%) scaleX(-1);
  width: calc(26 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__button-prev {
    width: auto;
    position: static;
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
  }
}

.showcase-slider__button-prev::before {
  content: '';
  display: block;
  width: calc(80 / var(--base-font-size) * var(--rem-font-size));
  height: calc(80 / var(--base-font-size) * var(--rem-font-size));
  background: transparent;
  z-index: -1;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-55%, -50%);
          transform: translate(-55%, -50%);
  border-radius: 50%;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__button-prev::before {
    display: none;
  }
}

.showcase-slider__button-next {
  position: absolute;
  z-index: 1;
  right: calc(40 / var(--base-font-size) * var(--rem-font-size));
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: calc(26 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__button-next {
    width: auto;
    position: static;
    -webkit-transform: none;
            transform: none;
  }
}

.showcase-slider__button-next::before {
  content: '';
  display: block;
  width: calc(80 / var(--base-font-size) * var(--rem-font-size));
  height: calc(80 / var(--base-font-size) * var(--rem-font-size));
  background: transparent;
  z-index: -1;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-55%, -50%);
          transform: translate(-55%, -50%);
  border-radius: 50%;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .showcase-slider__button-next::before {
    display: none;
  }
}


/**
 * TECHNOLOGY
 */
.technology {
  margin-top: calc(90 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .technology {
    margin-top: calc(70 / var(--base-font-size) * var(--rem-font-size));
  }
}

.technology__grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr calc(30 / var(--base-font-size) * var(--rem-font-size)) 1fr;
  grid-template-columns: 1fr 1fr;
  gap: calc(20 / var(--base-font-size) * var(--rem-font-size)) calc(30 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .technology__grid {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
  }
}


/**
 * TECHNOLOGYの1つ目のコンテンツ
 */
.container-2 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 410fr 790fr;
  grid-template-columns: 410fr 790fr;
  background: #F4F4F4;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-2 {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
  }
}

.container-2__body {
  padding: 0 calc(60 / var(--base-font-size) * var(--rem-font-size));
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}

@media screen and (max-width: 1024px) {
  .container-2__body {
    padding: 0 calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-2__body {
    padding:
     calc(20 / var(--base-font-size) * var(--rem-font-size))
     calc(30 / var(--base-font-size) * var(--rem-font-size))
     calc(25 / var(--base-font-size) * var(--rem-font-size));
  }
}

.container-2__title {
  font-size: calc(56 / var(--base-font-size) * var(--rem-font-size));
  line-height: 1.4;
  margin-bottom: calc(10 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
}

@media screen and (max-width: 1024px) {
  .container-2__title {
    font-size: calc(40 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
}

.container-2__text {
}


/**
 * TECHNOLOGYの2つ目、3つ目のコンテンツ
 */
.container-3 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 279fr 307fr;
  grid-template-columns: 279fr 307fr;
  background: #F4F4F4;
}

@media screen and (max-width: 1024px) {
  .container-3 {
    -ms-grid-columns: 100%;
    grid-template-columns: 100%;
    grid-auto-flow: dense;
  }
}

.container-3__body {
  padding: calc(40 / var(--base-font-size) * var(--rem-font-size)) calc(20 / var(--base-font-size) * var(--rem-font-size)) calc(20 / var(--base-font-size) * var(--rem-font-size)) calc(40 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .container-3__body {
    -ms-grid-row: 1;
    grid-row: 1;
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-3__body {
    padding:
    calc(25 / var(--base-font-size) * var(--rem-font-size))
    calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

.container-3__icon {
  width: calc(65 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-3__icon {
    width: calc(56 / var(--base-font-size) * var(--rem-font-size));
  }
}

.container-3__title {
  margin-top: calc(15 / var(--base-font-size) * var(--rem-font-size));
  font-size: calc(24 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: calc(5 / var(--base-font-size) * var(--rem-font-size));
}

.container-3__text {
}

.container-3__video {
  margin-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
}


/**
 * TECHNOLOGYの4つ目
 */
.container-4 {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  background: #F4F4F4;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-4 {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}

.container-4__body {
  padding:
    calc(40 / var(--base-font-size) * var(--rem-font-size))
    calc(40 / var(--base-font-size) * var(--rem-font-size))
    calc(40 / var(--base-font-size) * var(--rem-font-size))
    calc(60 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .container-4__body {
    padding:
      calc(20 / var(--base-font-size) * var(--rem-font-size))
      calc(20 / var(--base-font-size) * var(--rem-font-size))
      calc(20 / var(--base-font-size) * var(--rem-font-size))
      calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-4__body {
    padding:
      calc(20 / var(--base-font-size) * var(--rem-font-size))
      calc(30 / var(--base-font-size) * var(--rem-font-size))
      calc(25 / var(--base-font-size) * var(--rem-font-size));
  }
}

.container-4__title-1 {
  font-size: calc(56 / var(--base-font-size) * var(--rem-font-size));
  line-height: 1.4;
  margin-bottom: calc(10 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 500;
}

@media screen and (max-width: 1024px) {
  .container-4__title-1 {
    font-size: calc(40 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-4__title-1 {
    margin-right: calc(-30 / var(--base-font-size) * var(--rem-font-size));
    /* font-size: calc(24 / var(--base-font-size) * var(--rem-font-size)); */
  }
}

.container-4__icon {
  margin-top: calc(30 / var(--base-font-size) * var(--rem-font-size));
  width: calc(65 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (max-width: 1024px) {
  .container-4__icon {
    width: calc(50 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .container-4__icon {
    width: calc(56 / var(--base-font-size) * var(--rem-font-size));
  }
}

.container-4__title-2 {
  margin-top: calc(15 / var(--base-font-size) * var(--rem-font-size));
  font-size: calc(24 / var(--base-font-size) * var(--rem-font-size));
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: calc(5 / var(--base-font-size) * var(--rem-font-size));
}

.container-4__video {
  margin-top: calc(20 / var(--base-font-size) * var(--rem-font-size));
}


/**
 * バナー
 */
.banners {
  margin-top: calc(120 / var(--base-font-size) * var(--rem-font-size));
  max-width: calc(1000 / var(--base-font-size) * var(--rem-font-size));
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--inner-padding);
  padding-right: var(--inner-padding);
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .banners {
    margin-top: calc(80 / var(--base-font-size) * var(--rem-font-size));
    padding-left: 0;
    padding-right: 0;
  }
}

.banners__list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 100%;
  grid-template-columns: 100%;
  gap: calc(40 / var(--base-font-size) * var(--rem-font-size));
}

@media screen and (min-width: 0px) and (max-width: 767px) {
  .banners__list {
    gap:  calc(30 / var(--base-font-size) * var(--rem-font-size));
  }
}

@media screen and (min-width: 1024.1px) {
  .banners__banner {
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
  }

  .banners__banner:hover {
    opacity: 0.4;
  }
}


/**
 * バナー
 */
.modal-slider {
  width: 100%;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 100%;
  grid-template-columns: 100%;
  overflow: hidden;
}

.modal-slider__body {
  width: 100%;
  overflow: hidden;
}

.modal-slider__indicator {
  display: -ms-grid;
  display: grid;
  -ms-flex-align: center;
      -webkit-box-align: center;
          align-items: center;
  margin-top: calc(15 / var(--base-font-size) * var(--rem-font-size));
  gap: calc(35 / var(--base-font-size) * var(--rem-font-size));
  padding-right: calc(20 / var(--base-font-size) * var(--rem-font-size));
  padding-left: calc(20 / var(--base-font-size) * var(--rem-font-size));
  -ms-grid-columns:
    calc(8 / var(--base-font-size) * var(--rem-font-size)) calc(35 / var(--base-font-size) * var(--rem-font-size))
    1fr calc(35 / var(--base-font-size) * var(--rem-font-size))
    calc(8 / var(--base-font-size) * var(--rem-font-size));
  grid-template-columns:
    calc(8 / var(--base-font-size) * var(--rem-font-size))
    1fr
    calc(8 / var(--base-font-size) * var(--rem-font-size));
}

.modal-slider__pagination {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  gap: calc(4 / var(--base-font-size) * var(--rem-font-size));
  -ms-flex-pack: center;
      -webkit-box-pack: center;
          justify-content: center;
}

.modal-slider__bullet {
  width: auto;
  max-width: calc(50 / var(--base-font-size) * var(--rem-font-size));
  height: calc(2 / var(--base-font-size) * var(--rem-font-size));
  background: rgba(255, 255, 255, 0.4);
  -ms-flex-positive: 1;
      -webkit-box-flex: 1;
          flex-grow: 1;
}

.modal-slider__bullet.-active {
  background: #fff;
}

.modal-slider__button-prev {
  width: auto;
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}

.modal-slider__button-prev img {
  display: block;
}

.modal-slider__button-next {
  width: auto;
}

.modal-slider__button-next img {
  display: block;
}
