@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Roboto+Condensed:wght@700&display=swap');


/**
 * Common Style
 * ================================================================================
 * Table of Contents:
 *
 * Basic Structure
 * Parts Settings
 * Content Settings
 * Colorbox Settings
 * ================================================================================
 */






/**
 * ================================================================================
 * Basic Structure
 * ================================================================================
 */


body.productsDmFeaturesOpen {
  overflow: hidden;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}


/* -- Layout-- */
#productsDmTop,
#cboxContent {
  background-color: #000;
  display: block;
  position: relative;
  color: #fff;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  }

  #productsDmTop *,
  #productsDmTop *::before,
  #productsDmTop *::after,
  #cboxContent *,
  #cboxContent *::before,
  #cboxContent *::after { box-sizing: border-box; }

.header {
  background-color: #FFF;
  position: relative;
  z-index: 500;
  }
#headerNavArea {
  position: relative;
  z-index: 499;
  }
.dirpath { margin-top: 0; }
.footer { margin-top: 0 !important; }

#productsDmTop #loader {
  background-color: #000;
  background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_loader.png");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 35px auto;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 102;
  }

#productsDmTop img { width: 100%; }

#productsDmTop strong { font-weight: bold; }

#productsDmTop a {
  display: inline-block;
  opacity: 1;
  transition: opacity 0.2s ease-in;
  text-decoration: none;
  }

#productsDmTop a:hover { opacity: 0.6; }







/**
 * ================================================================================
 * Parts Settings
 * ================================================================================
 */


/**
 * Wrapper
 * -------------------------------
 */

#productsDmTop .p-wrapper {
  width: 1080px;
  margin: 0 auto;
  position: relative;
  }



/**
 * List / Comments / Caution / Caption
 * -------------------------------
 */

#productsDmTop .p-lists,
#productsDmTop .p-comments { list-style: none; }

  #productsDmTop .p-lists > li,
  #productsDmTop .p-comments > li {
    padding-left: 1em;
    text-indent: -1em;
    }

#productsDmTop .p-comments,
#productsDmTop .p-caution,
#productsDmTop .p-caption { font-size: 1.3rem; }



/**
 * Title
 * -------------------------------
 */

#productsDmTop .p-secTtl01 {
  margin-bottom: 35px;
  text-align: center;
  }

  #productsDmTop .p-secTtl01 > span {
    display: inline-block;
    line-height: 1;
    }

    #productsDmTop .p-secTtl01 > span img {
      width: auto;
      height: 29px;
      }

#productsDmTop .p-secTtl02 {
  margin-bottom: 35px;
  font-size: 2.1rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  }



/**
 * Button
 * -------------------------------
 */

#productsDmTop .p-btns {
  list-style: none;
  letter-spacing: -.40em;
  }

#productsDmTop .p-btn {
  display: inline-block;
  letter-spacing: normal;
  vertical-align: top;
  text-align: center;
  }

#productsDmTop .p-btnType01 {}

  #productsDmTop .p-btnType01 > * {
    display: block;
    padding: 20px 75px;
    border: 1px solid #fff;
    border-radius: 15px;
    position: relative;
    color: #fff;
    }

    #productsDmTop .p-btnType01 > a::after {
      content: "";
      background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-arrow01-wt.svg");
      background-repeat: no-repeat;
      background-position: 50% 50%;
      background-size: 100% auto;
      width: 24px;
      height: 9px;
      position: absolute;
      right: 20px;
      top: 50%;
      transform: translateY(-50%);
      }
    #productsDmTop .p-btnType01.p-btnIconPdf > a::after {
      width: 22px;
      height: 29px;
      right: 20px;
      }

    #productsDmTop .p-btnType01 > * > span { display: block; }

    #productsDmTop .p-btnType01 > * > span:nth-of-type(1) {
      font-size: 2.4rem;
      font-weight: 700;
      line-height: 1.4;
      }

  #productsDmTop .p-btnType01.p-btnColorSolidWhite > * {
    background-color: #fff;
    color: #002783;
    }

    #productsDmTop .p-btnType01.p-btnColorSolidWhite > a::after { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-arrow01-bl.svg"); }
    #productsDmTop .p-btnType01.p-btnColorSolidWhite.p-btnIconPdf > a::after { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-pdf-bl.svg"); }

  #productsDmTop .p-btnType01.p-btnColorSolidYellow > * {
    background-color: #ffff00;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border-color: #ffff00;
    color: #002783;
    letter-spacing: -0.03em;
    }

    #productsDmTop .p-btnType01.p-btnColorSolidYellow > a::after { background-image: none; }

#productsDmTop .p-btnType02 {}

  #productsDmTop .p-btnType02 > * {
    background-color: #073cb4;
    display: block;
    padding: 15px 70px;
    position: relative;
    color: #fff;
    border-radius: 16px;
    }

    #productsDmTop .p-btnType02 > a::after {
      content: "";
      background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-arrow01-wt.svg");
      background-repeat: no-repeat;
      background-position: 50% 50%;
      background-size: 100% auto;
      width: 24px;
      height: 9px;
      position: absolute;
      right: 25px;
      top: 50%;
      transform: translateY(-50%);
      }

    #productsDmTop .p-btnType02 > * > span { display: block; }

    #productsDmTop .p-btnType02 > * > span:nth-of-type(1) {
      font-size: 2.1rem;
      font-weight: 700;
      line-height: 1.4;
      }

#productsDmTop .p-btnType03 {}

  #productsDmTop .p-btnType03 > * {
    background-color: #1964ff;
    display: block;
    padding: 15px 70px;
    position: relative;
    color: #fff;
    text-align: center;
    border-radius: 1000px;
    }

    #productsDmTop .p-btnType03 > a::after {
      content: "";
      width: 16px;
      height: 16px;
      border-top: 1.5px solid #fff;
      border-right: 1.5px solid #fff;
      position: absolute;
      right: 30px;
      top: 50%;
      transform: translateY(-50%) rotate(45deg);
      }

    #productsDmTop .p-btnType03 > * > span { display: block; }

    #productsDmTop .p-btnType03 > * > span:nth-of-type(1) {
      font-size: 2.7rem;
      font-weight: 600;
      line-height: 1.4;
      }

    #productsDmTop .p-btnType03 > * > span:nth-of-type(2) {
      margin-top: 5px;
      font-size: 1.5rem;
      line-height: 1.4;
      }

#productsDmTop .p-btnType04 {}

  #productsDmTop .p-btnType04 > * {
    background-color: #000;
    display: inline-block;
    padding: 15px 20px;
    border: 2px solid #c5a448;
    position: relative;
    color: #c5a448;
    text-align: center;
    border-radius: 1000px;
    box-shadow: 3px 6px 10px 0 rgba(0, 0, 0, 0.3);
    }

    #productsDmTop .p-btnType04 > * > span {
      display: block;
      padding-left: 35px;
      position: relative;
      }

    #productsDmTop .p-btnType04 > * > span:nth-of-type(1) {
      font-size: 2.2rem;
      font-weight: 700;
      font-style: italic;
      line-height: 1.4;
      }

      #productsDmTop .p-btnType04 > * > span:nth-of-type(1) > strong { font-weight: 900; }

      #productsDmTop .p-btnType04 > * > span::before,
      #productsDmTop .p-btnType04 > * > span::after {
        content: "";
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        }

      #productsDmTop .p-btnType04 > * > span::before {
        background-color: #c5a448;
        width: 28px;
        height: 28px;
        left: 0;
        z-index: 1;
        border-radius: 1000px;
        }

      #productsDmTop .p-btnType04 > * > span::after {
        background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat bottom right/100% 50%;
        width: 11px;
        height: 13px;
        left: 10px;
        z-index: 2;
        }

  #productsDmTop .p-btnType04.p-btnColorBlack > * {
    background-color: #000;
    border: 2px solid #c5a448;
    color: #c5a448;
    }

    #productsDmTop .p-btnType04.p-btnColorBlack > * > span::before { background-color: #c5a448; }

    #productsDmTop .p-btnType04.p-btnColorBlack > * > span::after { background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat bottom right/100% 50%; }

  #productsDmTop .p-btnType04.p-btnColorGold > * {
    background-color: #c5a448;
    border: 2px solid #000;
    color: #000;
    }

    #productsDmTop .p-btnType04.p-btnColorGold > * > span::before { background-color: #000; }

    #productsDmTop .p-btnType04.p-btnColorGold > * > span::after { background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #c5a448 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #c5a448 50.5%) no-repeat bottom right/100% 50%; }

  #productsDmTop .p-btnType04.p-btnColorGblue > * {
    background: linear-gradient(to right,  rgba(0,150,255,1) 0%,rgba(4,60,230,1) 100%);
    border: 2px solid #fff;
    color: #fff;
    }

    #productsDmTop .p-btnType04.p-btnColorGblue > * > span::before { background-color: #fff; }

    #productsDmTop .p-btnType04.p-btnColorGblue > * > span::after { background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #0096ff 50.5%) no-repeat top left/100% 50%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #0096ff 50.5%) no-repeat bottom right/100% 50%; }



/**
 * Link
 * -------------------------------
 */

#productsDmTop .p-linkYoutube { text-align: center; }

  #productsDmTop .p-linkYoutube > a {
    display: inline-block;
    color: #fff;
    text-decoration: none;
    }

  #productsDmTop .p-linkYoutube dl {
    display: inline-block;
    padding-left: 100px;
    position: relative;
    text-align: left;
    line-height: 1.4;
    }

    #productsDmTop .p-linkYoutube dl:before {
      content: "";
      background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-youtube.svg");
      background-repeat: no-repeat;
      background-size: 100% auto;
      width: 80px;
      height: 80px;
      position: absolute;
      top: 50%;
      left: 0;
      transform: translateY(-50%);
      }

    #productsDmTop .p-linkYoutube dl > dt {
      display: block;
      margin-bottom: 7px;
      font-size: 13px;
      }

    #productsDmTop .p-linkYoutube dl > dd {}

      #productsDmTop .p-linkYoutube dl > dd > p {
        font-size: 14px;
        font-weight: 700;
        }

      #productsDmTop .p-linkYoutube dl > dd > p > * {
        color: #ed0038;
        font-size: 18px;
        font-weight: 700;
        text-decoration: underline;
        }



/**
 * Banner
 * -------------------------------
 */

#productsDmTop .p-bannerTrial {
  margin-top: 65px;
  text-align: center;
  }

  #productsDmTop .p-bannerTrial > dt {
    display: block;
    margin-bottom: 15px;
    position: relative;
    }

    #productsDmTop .p-bannerTrial > dt:before {
      content: "";
      background-color: #fff;
      width: 100%;
      height: 1px;
      position: absolute;
      top: 50%;
      left: 0;
      z-index: 1;
      }

    #productsDmTop .p-bannerTrial > dt > span {
      background-color: #000;
      display: inline-block;
      padding: 0 15px;
      position: relative;
      z-index: 2;
      font-size: 2.0rem;
      font-weight: 700;
      }

  #productsDmTop .p-bannerTrial > dd {}

    #productsDmTop .p-bannerTrial > dd > a {
      display: block;
      border: 1px solid #1964ff;
      }



/**
 * Modal
 * -------------------------------
 */

.p-modal { display: none; }



/**
 * Slickslider
 * -------------------------------
 */

#productsDmTop .slick-arrow {
  background: none;
  width: 50px;
  height: 50px;
  border: 1px solid #fff;
  position: absolute;
  top: 50%;
  border-radius: 1000px;
  transform: translateY(-50%);
  transition: 0.2s all ease-out;
  }

#productsDmTop .slick-prev { left: -58px; }
#productsDmTop .slick-next { right: -58px; }

#productsDmTop .slick-arrow:hover { opacity: 0.6; }

  #productsDmTop .slick-arrow::before {
    content: "";
    width: 16px;
    height: 16px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    }

  #productsDmTop .slick-prev::before {
    margin-left: 4px;
    transform: translate(-50%, -50%) rotate(-135deg);
    }
  #productsDmTop .slick-next::before {
    margin-left: -4px;
    transform: translate(-50%, -50%) rotate(45deg);
    }

#productsDmTop .slick-dots {
  display: inline-block;
  width: 100%;
  list-style: none;
  letter-spacing: -.40em;
  text-align: center;
  position: absolute;
  left: 50%;
  bottom: -40px;
  transform: translateX(-50%);
  }

  #productsDmTop .slick-dots > li {
    display: inline-block;
    letter-spacing: normal;
    vertical-align: top;
    margin: 0 8px;
    line-height: 1;
    }

    #productsDmTop .slick-dots > li > button {
      background-color: transparent;
      width: 60px;
      height: 10px;
      border: none;
      position: relative;
      font-size: 0;
      text-indent: -9999px;
      border-radius: 0;
      transition: 0.2s all ease-out;
      }

    #productsDmTop .slick-dots > li > button:hover { opacity: 0.6; }
    #productsDmTop .slick-dots > li.slick-active > button:hover { opacity: 1; }

      #productsDmTop .slick-dots > li > button::before {
        content: "";
        background-color: rgba(26, 26, 26, 0.3);
        width: 100%;
        height: 6px;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        }

      #productsDmTop .slick-dots > li.slick-active > button::before { background-color: #1964ff; }






/**
 * ================================================================================
 * Top Page Settings
 * ================================================================================
 */


/**
 * UCL
 * -------------------------------
 */

#productsDmTop #ucl {
  background-color: #1964ff;
  display: flex;
  height: 73px;
  align-items: center;
  justify-content: center;
  text-align: center;
  }

  #productsDmTop #ucl > dl {
    display: inline-flex;
    align-items: center;
    line-height: 1;
    }

    #productsDmTop #ucl > dl > dt { display: block; }

      #productsDmTop #ucl > dl > dt img { width: 264px; }

    #productsDmTop #ucl > dl > dd {
      padding-left: 25px;
      margin-left: 25px;
      position: relative;
      color: #fff;
      font-size: 17px;
      font-weight: 700;
      }

      #productsDmTop #ucl > dl > dd::before {
        content: "";
        background-color: #fff;
        width: 2px;
        height: 20px;
        position: absolute;
        left: 0;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        }



/**
 * Main Visual
 * -------------------------------
 */

#productsDmTop #mv {
  margin-bottom: 100px;
  text-align: center;
  }

  #productsDmTop #mv .mvSlider { margin-bottom: 80px; }

    #productsDmTop #mv .mvSliderInner {
      position: relative;
      text-align: center;
      }

      #productsDmTop #mv .mvSliderInner img { width: 100%; }

    #productsDmTop #mv .mvSlider .slick-arrow {
      background-color: #4d4d4d;
      width: 36px;
      height: 200px;
      border: none;
      border-radius: 0;
      }

    #productsDmTop #mv .mvSlider .slick-prev { left: 0; }
    #productsDmTop #mv .mvSlider .slick-next { right: 0; }

      #productsDmTop #mv .mvSlider .slick-arrow::before {
        background-repeat: no-repeat;
        background-position: 50% 50%;
        background-size: 100% 100%;
        width: 10px;
        height: 74px;
        border: none;
        transform: translate(-50%, -50%) rotate(0);
        }

      #productsDmTop #mv .mvSlider .slick-prev::before {
        background-image: url("/files/cdb/ZZ/products/d-mirror/se/2402/zz_products_d-mirror_se_mv-slider-arrow-prev.svg");
        margin-left: -2.5px;
        }
      #productsDmTop #mv .mvSlider .slick-next::before {
        background-image: url("/files/cdb/ZZ/products/d-mirror/se/2402/zz_products_d-mirror_se_mv-slider-arrow-next.svg");
        margin-left: 2.5px;
        }

    #productsDmTop #mv .mvSlider .slick-dots {}

      #productsDmTop #mv .mvSlider .slick-dots > li > button { width: 40px; }

        #productsDmTop #mv .mvSlider .slick-dots > li > button::before {
          background-color: #4d4d4d;
          height: 1px;
          }

        #productsDmTop #mv .mvSlider .slick-dots > li.slick-active > button::before { background-color: #00a0ff; }

  #productsDmTop #mv .mvSlider01Txt {
    width: 100%;
    position: absolute;
    left: 0;
    top: calc(100vw * (25 / 1600));
    font-size: calc(100vw * (21 / 1600));
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.1em;
    }

  #productsDmTop #mv .mvTtl { margin-bottom: 70px; }

    #productsDmTop #mv .mvTtl > span {
      display: block;
      line-height: 1;
      }

    #productsDmTop #mv .mvTtl > span:nth-of-type(1) {
      margin-bottom: 20px;
      font-size: 1.8rem;
      font-weight: 700;
      }

      #productsDmTop #mv .mvTtl > span:nth-of-type(1) img {
        display: inline-block;
        width: 40px;
        margin: -4px 5px 0 0;
        }

    #productsDmTop #mv .mvTtl > span:nth-of-type(2) { margin-bottom: 30px; }

      #productsDmTop #mv .mvTtl > span:nth-of-type(2) img { width: 542px; }

    #productsDmTop #mv .mvTtl > span:nth-of-type(3) {
      font-size: 1.5rem;
      font-weight: 700;
      }

  #productsDmTop #mv .mvMovie { margin-bottom: 80px; }

    #productsDmTop #mv .mvMovie img { width: 311px; }

  #productsDmTop #mv .p-linkYoutube {
    padding-top: 30px;
    margin-bottom: 90px;
    }

  #productsDmTop #mv .mvTrouble {}

    #productsDmTop #mv .mvTrouble .p-btn { width: 535px; }

      #productsDmTop #mv .mvTrouble .p-btn > * { border: 1px solid #0041c8; }



/**
 * Trouble
 * -------------------------------
 */

#trouble {
  background-color: #000;
  color: #fff;
  overflow-x: hidden;
  }

  #trouble .p-wrapper { padding: 120px 80px; }

  #trouble .troubleTtl {
    margin-bottom: 50px;
    text-align: center; 
    }

    #trouble .troubleTtl > span {
      display: block;
      font-weight: bold;
      }

    #trouble .troubleTtl > span:nth-of-type(1) {
      margin-bottom: 30px;
      font-size: 30px;
      }

    #trouble .troubleTtl > span:nth-of-type(2) {
      background-color: #1964ff;
      display: inline-block;
      width: 140px;
      height: 1px;
      }

    #trouble .troubleTtl > span:nth-of-type(3) {
      margin-top: 40px;
      font-size: 23px;
      }

  #trouble .troubleTxt {
    margin-bottom: 95px;
    font-size: 17px;
    text-align: center;
    }

    #trouble .troubleTxt > span { display: block; }

      #trouble .troubleTxt > span img { width: 100%; }

    #trouble .troubleTxt > span:nth-of-type(2) {
      margin-top: -95px;
      margin-bottom: 35px;
      line-height: 1.8;
      }

  #trouble .troubleLists { text-align: center; }

    #trouble .troubleLists > dt { display: block; }

      #trouble .troubleLists > dt > span {
        display: block;
        font-size: 30px;
        font-weight: bold;
        }

      #trouble .troubleLists > dt > span:nth-of-type(1) { margin-bottom: 10px; }

      #trouble .troubleLists > dt > span:nth-of-type(2) { margin-bottom: 45px; }

        #trouble .troubleLists > dt > span:nth-of-type(3) img { width: 103px; }

    #trouble .troubleLists > dd { margin-top: -15px; }

      #trouble .troubleLists > dd > p:nth-of-type(1) {
        margin-bottom: 110px;
        text-align: center;
        }

        #trouble .troubleLists > dd > p:nth-of-type(1) > span { display: block; }

        #trouble .troubleLists > dd > p:nth-of-type(1) > span:nth-of-type(2) {
          margin-top: -70px;
          margin-bottom: 45px;
          font-size: 17px;
          line-height: 1.8;
          }

          #trouble .troubleLists > dd > p:nth-of-type(1) > span img { width: 100%; }

  #trouble .p-comments { text-align: right; }



/**
 * Pickup
 * -------------------------------
 */

#productsDmTop #pickup { padding-bottom: 100px; }

  #productsDmTop #pickup .pickupSlider {}

    #productsDmTop #pickup .pickupSlider .slick-track { display: flex; }

    #productsDmTop #pickup .pickupSlider .slick-arrow {
      background: none;
      width: 50px;
      height: 50px;
      margin: 0;
      border: none;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      transition: 0.2s all ease-out;
      }

    #productsDmTop #pickup .pickupSlider .slick-prev { left: -50px; }
    #productsDmTop #pickup .pickupSlider .slick-next { right: -50px; }

    #productsDmTop #pickup .pickupSlider .slick-arrow:hover { opacity: 0.6; }

      #productsDmTop #pickup .pickupSlider .slick-arrow::before {
        content: "";
        width: 30px;
        height: 30px;
        border-top: 1px solid #1964ff;
        border-right: 1px solid #1964ff;
        position: absolute;
        top: 50%;
        left: 50%;
        }

      #productsDmTop #pickup .pickupSlider .slick-prev::before { transform: translate(-50%, -50%) rotate(-135deg); }
      #productsDmTop #pickup .pickupSlider .slick-next::before { transform: translate(-50%, -50%) rotate(45deg); }

    #productsDmTop #pickup .pickupSlider .slick-slide {
      width: 330px;
      height: auto !important;
      margin-right: 45px;
      }

      #productsDmTop #pickup .pickupSlider .slick-slide > a,
      #productsDmTop #pickup .pickupSliderInner {
        display: block;
        height: 100%;
        }



/**
 * Lineup
 * -------------------------------
 */

#productsDmTop #lineup {
  background-color: #fff;
  padding-top: 56px;
  color: #000;
  }

  #productsDmTop #lineup .p-secTtl01 { margin-bottom: 80px; }

  #productsDmTop #lineup .lineupPkg {
    margin-bottom: 120px;
    text-align: center;
    }

    #productsDmTop #lineup .lineupPkgBanner {}

      #productsDmTop #lineup .lineupPkgBanner > li { margin-top: 20px; }
      #productsDmTop #lineup .lineupPkgBanner > li:nth-of-type(1) { margin-top: 0; }

  #productsDmTop #lineup .lineupTabNav {
    display: flex;
    width: calc(100% + 120px);
    margin-left: -12px;
    transform: translateX(-60px);
    }

    #productsDmTop #lineup .lineupTabNav > li {
      width: 33.3333%;
      padding-left: 12px;
      }

      #productsDmTop #lineup .lineupTabNav > li > * {
        background-color: #999;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 128px;
        border-bottom: 12px solid #fff;
        position: relative;
        color: #fff;
        text-align: center;
        }

        #productsDmTop #lineup .lineupTabNav > li > *.active {
          background-color: #002783;
          border-bottom: 0 solid #000;
          }

        #productsDmTop #lineup .lineupTabNav > li > *.active:hover { opacity: 1; }

      #productsDmTop #lineup .lineupTabNav > li > * span {
        display: block;
        line-height: 1.4;
        }

        #productsDmTop #lineup .lineupTabNav > li > * > span > strong {
          display: block;
          width: 100%;
          position: absolute;
          top: -35px;
          left: 0;
          font-size: 1.6rem;
          text-align: center;
          }

        #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(1) {
          margin-bottom: 8px;
          font-size: 2.2rem;
          transition: 0.2s all;
          }

        #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(1) { font-size: 2.7rem; }

          #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(1) img {
            display: inline-block;
            width: auto;
            height: 32px;
            margin-right: 5px;
            vertical-align: baseline;
            position: relative;
            top: 1px;
            transition: 0.2s all;
            }

          #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(1) img {
            width: auto;
            height: 40px;
            }

        #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(2) {
          display: inline-block;
          min-width: 190px;
          padding: 3px 30px;
          border: 1px solid #fff;
          font-size: 1.3rem;
          transition: 0.2s all;
          }

        #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(2) { font-size: 1.5rem; }

  #productsDmTop #lineup .lineupTabContent { position: relative; }

  #productsDmTop #lineup .lineupTabContent::before {
    content: '';
    background-color: #002783;
    width: 100vw;
    height: 100%;
    position: absolute;
    left: 50%;
    top: 0;
    z-index: -1;
    transform: translateX(-50%);
    }

  #productsDmTop #lineup .lineupTabContent > li {
    display: none;
    position: relative;
    z-index: 1;
    color: #fff;
    }

    #productsDmTop #lineup .lineupTabContent > li.active { display: block; }

    #productsDmTop #lineup .lineupTabContent .lineupTabContentInner {
      padding-top: 120px;
      padding-bottom: 125px;
      }

  #productsDmTop #lineup .lineupBanner {
    letter-spacing: -.40em;
    margin-left: -45px;
    margin-bottom: 70px;
    position: relative;
    }

    #productsDmTop #lineup .lineupBannerCs::after {
      content: "";
      background-color: rgba(0, 0, 0, 0.8);
      background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_lineup-cs.svg");
      background-repeat: no-repeat;
      background-position: 50% 50%;
      background-size: 618px auto;
      width: calc(100vw - 100px);
      height: calc(100% + 140px);
      margin-left: 22.5px;
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: 2;
      transform: translate(-50%, -50%);
      border-radius: 25px;
      }

    #productsDmTop #lineup .lineupBanner > li {
      display: inline-block;
      width: 50%;
      padding-left: 45px;
      letter-spacing: normal;
      vertical-align: top;
      position: relative;
      z-index: 1;
      }

      #productsDmTop #lineup .lineupBanner > li > * {
        display: block;
        color: #fff;
        }

    #productsDmTop #lineup .lineupBannerInner {
      position: relative;
      text-align: center;
      }

      #productsDmTop #lineup .lineupBannerInner > dt { display: block; }

        #productsDmTop #lineup .lineupBannerInner > dt > span {
          display: block;
          line-height: 1;
          }

      #productsDmTop #lineup .lineupBannerInner > dd {
        background-color: #000;
        padding: 20px;
        border-bottom-left-radius: 28px;
        border-bottom-right-radius: 28px;
        }

        #productsDmTop #lineup .lineupBannerInner > dd::after {
          content: "";
          background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_icon-arrow01-wt.svg");
          background-repeat: no-repeat;
          background-position: 50% 50%;
          background-size: 100% auto;
          width: 24px;
          height: 9px;
          position: absolute;
          right: 25px;
          bottom: 25px;
          }

    #productsDmTop #lineup .lineupBannerImg {
      position: relative;
      z-index: 1;
      overflow: hidden;
      border-top-left-radius: 28px;
      border-top-right-radius: 28px;
      }

      #productsDmTop #lineup .lineupBannerImg img { width: 100%; }

    #productsDmTop #lineup .lineupBannerLabel {
      width: 105px;
      height: 105px;
      position: absolute;
      z-index: 2;
      top: -20px;
      }
    #productsDmTop #lineup .lineupBanner > li:nth-child(odd) .lineupBannerLabel { left: -25px; }
    #productsDmTop #lineup .lineupBanner > li:nth-child(even) .lineupBannerLabel { right: -25px; }

      #productsDmTop #lineup .lineupBannerLabel img { width: 100%; }

    #productsDmTop #lineup .lineupBannerSubTtl { margin-bottom: 5px; }

      #productsDmTop #lineup .lineupBannerSubTtl > span {
        display: inline-flex;
        align-items: center;
        font-size: 1.8rem;
        line-height: 1.4;
        }

        #productsDmTop #lineup .lineupBannerSubTtl > span > span {
          display: inline-flex;
          align-items: center;
          padding: 1px 2px;
          margin-right: 5px;
          border: 1px solid #fff;
          font-size: 1.1rem;
          font-weight: 500;
          }

          #productsDmTop #lineup .lineupBannerSubTtl > span img {
            display: inline-block;
            margin-right: 5px;
            width: 45px;
            }

    #productsDmTop #lineup .lineupBannerTtl { margin-bottom: 15px; }

      #productsDmTop #lineup .lineupBannerTtl > span {
        display: block;
        font-size: 2.9rem;
        font-weight: 700;
        line-height: 1.2;
        }

      #productsDmTop #lineup .lineupBannerTtl > span.c-fcYellow {
        margin-top: 5px;
        font-size: 1.9rem;
        }

    #productsDmTop #lineup .lineupBannerCaption {
      color: #666;
      font-size: 1.5rem;
      line-height: 1.4;
      }

    #productsDmTop #lineup .lineupBannerRecommend {
      margin-top: 15px;
      text-align: center;
      }

      #productsDmTop #lineup .lineupBannerRecommend > a {
        color: #ffeb00;
        font-size: 1.8rem;
        line-height: 1.4;
        text-decoration: underline;
        }

  #productsDmTop #lineup .lineupBtn {
    padding-bottom: 80px;
    margin-top: -30px;
    text-align: center;
    }

    #productsDmTop #lineup .lineupBtn .p-btn {
      width: 760px;
      margin-top: 30px;
      }

      #productsDmTop #lineup .lineupBtn .p-btn > *::after {
        width: calc(24px * 1.3);
        height: calc(9px * 1.3);
        }
      #productsDmTop #lineup .lineupBtn .p-btn.p-btnIconPdf > a::after {
        width: 22px;
        height: 29px;
        }

  #productsDmTop #lineup .lineupTtl {
    margin-bottom: 30px;
    position: relative;
    z-index: 1;
    text-align: center;
    }

    #productsDmTop #lineup .lineupTtl::before {
      content: "";
      background-color: #fff;
      width: 100%;
      height: 1px;
      position: absolute;
      top: 50%;
      left: 0;
      z-index: -1;
      }

    #productsDmTop #lineup .lineupTtl > span:nth-of-type(1) {
      background-color: #002783;
      display: inline-block;
      padding: 0 15px;
      font-size: 2.6rem;
      font-weight: 700;
      line-height: 1.4;
      }

  #productsDmTop #lineup .lineupLabel {
    display: block;
    width: 132px;
    border-left: 20px solid #002783;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    }

    #productsDmTop #lineup .lineupLabel img { width: 100%; }

  #productsDmTop #lineup .lineupKit {
    padding: 0 60px;
    border: 1px solid #fff;
    border-radius: 26px;
    margin: 0 -60px;
    }

    #productsDmTop #lineup .lineupKitTtl {
      margin-top: -15px;
      margin-bottom: 50px;
      text-align: center;
      }
  
      #productsDmTop #lineup .lineupKitTtl > span {
        background-color: #002783;
        display: inline-block;
        padding: 0 20px;
        font-size: 2.1rem;
        font-weight: 700;
        line-height: 1.4;
        }
  
    #productsDmTop #lineup .lineupKitSubttl {
      margin-bottom: 15px;
      font-size: 2.1rem;
      font-weight: 700;
      line-height: 1.4;
      }

    #productsDmTop #lineup .lineupKitSearch { /*margin-bottom: 60px;*/ }

      #productsDmTop #lineup .lineupKitSearchMaker { position: relative; }

        #productsDmTop #lineup .lineupKitSearchMaker::after {
          position: absolute;
          top: 50%;
          right: 20px;
          transform: translateY(-50%) rotate(45deg);
          width: 15px;
          height: 15px;
          margin-top: -3px;
          border-right: 2px solid #1964ff;
          border-bottom: 2px solid #1964ff;
          content: '';
          }

        #productsDmTop #lineup .lineupKitSearchMaker select {
          width: 100%;
          padding: 15px 20px;
          border: none;
          border-radius: 15px;
          color: #1a1a1a;
          font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
          font-size: 1.8rem;
          appearance: none;
          cursor: pointer;
          }

    #productsDmTop #lineup .lineupKitSearchResults {
      display: none !important;
      opacity: 0;
      visibility: hidden;
      transition: 0.2s all;
      }
    #productsDmTop #lineup .lineupKitSearchResults[data-lineupkit-maker] {
      display: none !important;
      opacity: 0;
      visibility: hidden;
      transition: unset;
      }

    #productsDmTop #lineup .lineupKitSearchResults.is-active {
      display: block !important;
      opacity: 1;
      visibility: visible;
      }
    #productsDmTop #lineup .lineupKitSearchResults[data-lineupkit-maker].is-active { display: inline-block !important; }

    #productsDmTop #lineup .lineupKitSearchResults:not(.is-active) + .lineupBtn { padding-top: 0 !important; }

    #productsDmTop #lineup .lineupKitInner { margin-top: 60px; }
    #productsDmTop #lineup .lineupKitInner:nth-of-type(1) {
      /* margin-top: 0; */
      margin-top: 80px;
      }

      #productsDmTop #lineup .lineupKitInner > dt {
        display: block;
        margin-bottom: 25px;
        text-align: center;
        position: relative;
        }

        #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) {
          display: inline-block;
          border: 1px solid #fff;
          font-size: 1.9rem;
          font-weight: 700;
          line-height: 1.4;
          }

          #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) > span,
          #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) > strong {
            display: inline-block;
            padding: 8px 10px;
            }

          #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) > strong {
            background-color: #fff;
            color: #002783;
            }

    #productsDmTop #lineup .lineupKitLists { letter-spacing: -.40em; }

      #productsDmTop #lineup .lineupKitLists > li {
        display: inline-block;
        margin: -1px 0 0 -1px;
        width: 25%;
        letter-spacing: normal;
        vertical-align: top;
        }
      #productsDmTop #lineup .lineupKitLists > li:nth-child(4n + 1) { margin-left: 0; }
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(1),
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(2),
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(3),
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(4) { margin-top: 0; }

        #productsDmTop #lineup .lineupKitLists > li > * {
          display: block;
          color: #fff;
          }

      #productsDmTop #lineup .lineupKitListsInner {
        background-color: #000;
        display: flex;
        width: 100%;
        height: 67px;
        align-items: center;
        justify-content: center;
        border: 1px solid #1964ff;
        position: relative;
        text-align: center;
        overflow: hidden;
        }
      #productsDmTop #lineup .lineupKit02 .lineupKitListsInner { border: 1px solid #002783; }

        #productsDmTop #lineup .lineupKitListsInner > dt { width: 44%; }

          #productsDmTop #lineup .lineupKitListsInner > dt img { width: 100%; }

        #productsDmTop #lineup .lineupKitListsInner > dd { width: 56%; }

          #productsDmTop #lineup .lineupKitListsInner > dd > p {
            font-size: 1.1rem;
            line-height: 1.4;
            }

    #productsDmTop #lineup .lineupKitCommonts {
      margin-top: 15px;
      font-size: 1.5rem;
      font-weight: 300;
      }

  #productsDmTop #lineup .lineupArm {
    display: none;
    margin-top: 80px;
    }
  #productsDmTop #lineup .lineupArm.is-active { display: block; }

    #productsDmTop #lineup .lineupArm .lineupTtl { margin-bottom: 40px; }

    #productsDmTop #lineup .lineupArmLists {
      display: flex;
      margin-left: -20px;
      }

      #productsDmTop #lineup .lineupArmLists > li {
        width: 50%;
        padding-left: 20px;
        height: auto;
        letter-spacing: normal;
        vertical-align: top;
        }

      #productsDmTop #lineup .lineupArmListsInner {
        background-color: #000;
        height: 100%;
        padding: 35px 25px;
        border-radius: 21px;
        }

      #productsDmTop #lineup .lineupArmListsBtn { margin-bottom: 35px; }

        #productsDmTop #lineup .lineupArmListsBtn .p-btn { width: 100%; }

          #productsDmTop #lineup .lineupArmListsBtn .p-btn > * {
            display: flex;
            justify-content: center;
            align-items: center;
            width: 100%;
            min-height: 65px;
            padding: 10px 55px;
            border-radius: 11px;
            }

            #productsDmTop #lineup .lineupArmListsBtn .p-btn > *::after {
              width: calc(24px * 0.7);
              height: calc(9px * 0.7);
              right: 20px;
              }

            #productsDmTop #lineup .lineupArmListsBtn .p-btn > * > span { font-size: 1.6rem; }

      #productsDmTop #lineup .lineupArmListsFitting { text-align: center; }

        #productsDmTop #lineup .lineupArmListsFitting > dt {
          display: block;
          margin-bottom: 20px;
          position: relative;
          z-index: 1;
          }

          #productsDmTop #lineup .lineupArmListsFitting > dt::before {
            content: "";
            background-color: #fff;
            width: 100%;
            height: 1px;
            position: absolute;
            top: 50%;
            left: 0;
            z-index: -1;
            }

          #productsDmTop #lineup .lineupArmListsFitting > dt > span {
            background-color: #000;
            display: inline-block;
            padding: 0 20px;
            color: #fff;
            font-size: 1.6rem;
            font-weight: 700;
            }

        #productsDmTop #lineup .lineupArmListsFittingLists {
          margin-top: -10px;
          margin-left: -15px;
          letter-spacing: -.40em;
          }

          #productsDmTop #lineup .lineupArmListsFittingLists > li {
            display: inline-block;
            padding-top: 10px;
            padding-left: 15px;
            letter-spacing: -0.03em;
            vertical-align: top;
            font-size: 1.5rem;
            font-weight: 300;
            }

  #productsDmTop #lineup .lineupOpening { display: none; }
  #productsDmTop #lineup .lineupOpening.is-active { display: block; }

  #productsDmTop #lineup .lineupBottom {
    padding-top: 100px;
    padding-bottom: 95px;
    }

  #productsDmTop #lineup .lineupUc { margin-bottom: 80px; }

    #productsDmTop #lineup .lineupUcBtn { text-align: center; }

      #productsDmTop #lineup .lineupUcBtn .p-btn { width: 545px; }

  #productsDmTop #lineup .lineupComments {
    margin-top: 85px;
    font-size: 1.5rem;
    }

    #productsDmTop #lineup .lineupComments > dt {
      display: block;
      font-weight: 500;
      }

    #productsDmTop #lineup .lineupComments > dd { font-weight: 300; }



/**
 * Recommend
 * -------------------------------
 */

#recommend {
  background-color: #fff;
  color: #000;
  overflow-x: hidden;
  }

  #recommend .p-wrapper { padding: 100px 110px; }

  #recommend .recommendTtl {
    margin-bottom: 25px;
    text-align: center;
    }

    #recommend .recommendTtl > span {
      display: inline-block;
      color: #043cb4;
      font-size: 3.1rem;
      font-weight: 700;
      letter-spacing: 0.05em;
      line-height: 1.4;
      }

  #recommend .recommendInner { text-align: center; }

    #recommend .recommendInner > dt {
      display: block;
      margin-bottom: 25px;
      }

    #recommend .recommendInner > dd > p {
      font-size: 1.6rem;
      font-weight: 500;
      }



/**
 * Features
 * -------------------------------
 */

#productsDmTop #features {
  padding-top: 140px;
  padding-bottom: 30px;
  }

  #productsDmTop .p-secTtl01 { margin-bottom: 40px; }

  #productsDmTop .featuresLists {
    padding-bottom: 140px;
    margin-top: -45px;
    margin-left: -45px;
    letter-spacing: -.40em;
    }

    #productsDmTop .featuresLists > li {
      display: inline-block;
      width: 100%;
      height: 467px;
      margin-top: 45px;
      padding-left: 45px;
      letter-spacing: normal;
      vertical-align: top;
      }
    #productsDmTop .featuresLists .featuresLists02,
    #productsDmTop .featuresLists .featuresLists06 { width: 56.759259%; }
    #productsDmTop .featuresLists .featuresLists03,
    #productsDmTop .featuresLists .featuresLists05 { width: 43.240741%; }
    #productsDmTop .featuresLists .featuresLists04 { height: 339px; }

      #productsDmTop .featuresLists > li > a {
        display: block;
        height: 100%;
        color: #000;
        }

      #productsDmTop .featuresListsInner {
        height: 100%;
        border: 1px solid #0041c8;
        position: relative;
        overflow: hidden;
        border-radius: 30px;
        }
      
        #productsDmTop .featuresListsInner::before,
        #productsDmTop .featuresListsInner::after {
          content: "";
          position: absolute;
          z-index: 3;
          }

        #productsDmTop .featuresListsInner::before {
          width: 49px;
          height: 49px;
          bottom: 20px;
          left: 20px;
          border-radius: 1000px;
          }
        #productsDmTop .featuresListsIconBlack::before { border: 2px solid #000; }
        #productsDmTop .featuresListsIconWhite::before { border: 2px solid #fff; }

        #productsDmTop .featuresListsInner::after {
          width: 14px;
          height: 14px;
          bottom: 38px;
          left: 35px;
          transform: rotate(45deg);
          }
        #productsDmTop .featuresListsIconBlack::after {
          border-top: 2px solid #000;
          border-right: 2px solid #000;
          }
        #productsDmTop .featuresListsIconWhite::after {
          border-top: 2px solid #fff;
          border-right: 2px solid #fff;
          }

        #productsDmTop .featuresListsInner > dt {
          display: block;
          width: 100%;
          height: 100%;
          position: relative;
          z-index: 1;
          line-height: 1;
          }

          #productsDmTop .featuresListsInner > dt img {
            width: auto;
            max-width: initial;
            min-height: 100%;
            height: 102%;
            }

          #productsDmTop .featuresListsInner > dt video { position: absolute; }

        #productsDmTop .featuresListsInner > dd {
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0;
          z-index: 2;
          }

          #productsDmTop .featuresListsTtl {
            position: absolute;
            font-size: 4.2rem;
            font-weight: 700;
            line-height: 1.3;
            letter-spacing: -0.03em;
            }

          #productsDmTop .featuresListsTtlTop { top: 35px; }
          #productsDmTop .featuresListsTtlBottom { bottom: 35px; }
          #productsDmTop .featuresListsTtlLeft { left: 40px; }
          #productsDmTop .featuresListsTtlRight {
            right: 40px;
            text-align: right;
            }

          #productsDmTop .featuresListsTtlBlack { color: #000; }
          #productsDmTop .featuresListsTtlWhite { color: #fff; }

    #productsDmTop .featuresLists03 {}

      #productsDmTop .featuresLists03 .featuresListsInner > dt video {
        margin-top: 40px;
        margin-left: -40px;
        height: 295%;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        }

    #productsDmTop .featuresLists04 {}

      #productsDmTop .featuresLists04 .featuresListsInner > dt video {
        height: 160%;
        top: 50%;
        left: 410px;
        transform: translateY(-50%);
        }

    #productsDmTop .featuresLists04 {}

      #productsDmTop .featuresLists04 .featuresListsInner { background-color: #fff; }

      #productsDmTop .featuresLists04 .featuresListsLogo {
        width: 100%;
        position: absolute;
        left: 100px;
        bottom: 25px;
        }

        #productsDmTop .featuresLists04 .featuresListsLogo > dt {
          display: block;
          padding-left: 50px;
          margin-bottom: 30px;
          }

          #productsDmTop .featuresLists04 .featuresListsLogo > dt img { width: 154px; }

        #productsDmTop .featuresLists04 .featuresListsLogo > dd {}



/**
 * Features Inner
 * -------------------------------
 */

#productsDmTop #featuresInner {
  background-color: #fff;
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9998;
  overflow-y: scroll;
  opacity: 0;
  visibility: hidden;
  color: #000;
  transition: 0.6s all;
  }
body.productsDmFeaturesOpen #productsDmTop #featuresInner {
  visibility: visible;
  opacity: 1;
  }

#productsDmTop .featuresBody {
  min-width: 1280px;
  overflow-x: hidden;
  }

  #productsDmTop #featuresInner .featuresClose {
    background-color: rgba(0, 0, 0, 0.8);
    width: 100px;
    height: 100px;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10;
    cursor: pointer;
    transition: 0.2s all;
    }

  #productsDmTop #featuresInner .featuresClose:hover { opacity: 0.6; }

    #productsDmTop #featuresInner .featuresClose > span {
      display: block;
      width: 100%;
      height: 100%;
      position: relative;
      }

      #productsDmTop #featuresInner .featuresClose > span::before,
      #productsDmTop #featuresInner .featuresClose > span::after {
        content: "";
        background-color: #fff;
        width: 60px;
        height: 2px;
        position: absolute;
        top: 50%;
        left: 50%;
        }
      #productsDmTop #featuresInner .featuresClose > span::before { transform: translate(-50%, -50%) rotate(45deg); }
      #productsDmTop #featuresInner .featuresClose > span::after { transform: translate(-50%, -50%) rotate(-45deg); }

  #productsDmTop #featuresInner .features {
    padding-top: 225px;
    background-repeat: no-repeat;
    background-position: 50% 0;
    background-size: 100% auto;
    position: relative;
    }

    #productsDmTop #featuresInner .features::before,
    #productsDmTop #featuresInner .features::after {
      content: "";
      width: 100%;
      height: 225px;
      position: absolute;
      left: 0;
      }
    #productsDmTop #featuresInner .features::before { top: 0; }
    #productsDmTop #featuresInner .features::after { bottom: 0; }

    #productsDmTop #featuresInner .featuresTtl {
      position: relative;
      z-index: 1;
      }

      #productsDmTop #featuresInner .featuresTtl .featuresTtlNum {
        width: 300px;
        height: 256px;
        position: absolute;
        z-index: -1;
        text-align: center;
        }
      #productsDmTop #featuresInner .featuresTtlLeft .featuresTtlNum { left: 0; }
      #productsDmTop #featuresInner .featuresTtlRight .featuresTtlNum { right: 0; }
      #productsDmTop #featuresInner .featuresTtlTop .featuresTtlNum { top: 0; }
      #productsDmTop #featuresInner .featuresTtlMiddle .featuresTtlNum {
        top: 50%;
        transform: translateY(-50%);
        }

        #productsDmTop #featuresInner .featuresTtl .featuresTtlNum img {
          width: auto;
          height: 100%;
          }

      #productsDmTop #featuresInner .featuresTtl .featuresTtlMain {
        display: block;
        font-size: 4.2rem;
        font-weight: 700;
        line-height: 1.4;
        letter-spacing: 0.04em;
        }
      #productsDmTop #featuresInner .featuresTtlLeft .featuresTtlMain {
        padding-left: 325px;
        text-align: left;
        }
      #productsDmTop #featuresInner .featuresTtlRight .featuresTtlMain {
        padding-right: 325px;
        text-align: right;
        }
      #productsDmTop #featuresInner .featuresTtlTop .featuresTtlMain { padding-top: 15px; }

        #productsDmTop #featuresInner .featuresTtl .featuresTtlMain > span { font-size: 2.5rem; }

    #productsDmTop #featuresInner .featuresSubTtl01 {
      font-size: 4.2rem;
      font-weight: 700;
      text-align: center;
      line-height: 1.4;
      letter-spacing: 0.03em;
      }

    #productsDmTop #featuresInner .featuresSubTtl02 {
      margin-bottom: 35px;
      font-size: 3.5rem;
      font-weight: 700;
      line-height: 1.4;
      letter-spacing: 0.03em;
      }

      #productsDmTop #featuresInner .featuresSubTtl02 > span { font-size: 2.0rem; }

    #productsDmTop #featuresInner .featuresSubTtl03 {
      font-size: 2.5rem;
      font-weight: 700;
      line-height: 1.4;
      letter-spacing: 0.03em;
      }

    #productsDmTop #featuresInner .featuresTxt01 {
      font-size: 2.0rem;
      font-weight: 500;
      letter-spacing: 0.04em;
      }

    #productsDmTop #featuresInner .featuresDlist {
      display: flex;
      align-items: center;
      }
    #productsDmTop #featuresInner .featuresDlist.featuresDlistReverse {
      flex-direction: row-reverse;
      }

      #productsDmTop #featuresInner .featuresDlist > dt {
        display: block;
        width: 44%;
        }

        #productsDmTop #featuresInner .featuresDlist > dt > span { display: block; }
        #productsDmTop #featuresInner .featuresDlist > dt > span.p-comments,
        #productsDmTop #featuresInner .featuresDlist > dt > span.p-caution,
        #productsDmTop #featuresInner .featuresDlist > dt > span.p-caption { margin-top: 10px; }

      #productsDmTop #featuresInner .featuresDlist > dd {
        display: block;
        width: 58%;
        padding-left: 110px;
        text-align: left;
        }
      #productsDmTop #featuresInner .featuresDlist.featuresDlistReverse > dd {
        padding-right: 110px;
        padding-left: 0;
        text-align: right;
        }

  #productsDmTop #featuresInner .features01 {
    padding-top: 125px;
    z-index: 1;
    }

    #productsDmTop #featuresInner .features01-01 {
      padding-top: 20px;
      position: relative;
      z-index: 3;
      }

      #productsDmTop #featuresInner .features01-01Inner { position: relative; }

        #productsDmTop #featuresInner .features01-01Inner > dt {
          display: block;
          margin: 0 -110px;
          position: relative;
          z-index: 1;
          }

        #productsDmTop #featuresInner .features01-01Inner > dd {
          width: 50%;
          position: absolute;
          }
        #productsDmTop #featuresInner .features01-01Inner > dd:nth-of-type(1) {
          margin-left: 185px;
          top: 185px;
          left: 50%;
          }
        #productsDmTop #featuresInner .features01-01Inner > dd:nth-of-type(2) {
          margin-right: 230px;
          bottom: 180px;
          right: 50%;
          text-align: right;
          }

    #productsDmTop #featuresInner .features01-02 {
      background-color: #043cb4;
      padding-top: 225px;
      margin-top: -155px;
      position: relative;
      z-index: 2;
      color: #fff;
      }

      #productsDmTop #featuresInner .features01-02::before {
        content: "";
        background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top left/100% 100%;
        width: 100%;
        height: 224px;
        position: absolute;
        top: 0;
        left: 0;
        }

      #productsDmTop #featuresInner .features01-02 .featuresSubTtl01 { margin-bottom: 5px; }

      #productsDmTop #featuresInner .features01-02Inner {
        margin-left: -75px;
        margin-right: -50px;
        padding-bottom: 30px;
        letter-spacing: -.40em;
        text-align: center;
        }

        #productsDmTop #featuresInner .features01-02Inner .featuresSubTtl01 { padding-bottom: 5px; }

        #productsDmTop #featuresInner .features01-02Inner > li {
          display: inline-block;
          width: 33.3333%;
          padding-left: 25px;
          letter-spacing: normal;
          vertical-align: top;
          }

          #productsDmTop #featuresInner .features01-02Inner > li > dl > dt {
            display: block;
            margin-bottom: 20px;
            position: relative;
            z-index: 1;
            }

            #productsDmTop #featuresInner .features01-02Inner > li:nth-of-type(3) > dl > dt::before {
              content: "";
              background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features01-02-img03-ballon.png");
              background-repeat: no-repeat;
              background-position: 50% 50%;
              background-size: 100% auto;
              width: 162px;
              height: 162px;
              position: absolute;
              top: -80px;
              right: -95px;
              z-index: -1;
              }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dt > span { display: block; }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dt > span img { width: 100%; }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dt > span:nth-of-type(1) {
              margin-bottom: 5px;
              color: #ffff00;
              font-size: 1.8rem;
              font-weight: 700;
              line-height: 1.4;
              }

          #productsDmTop #featuresInner .features01-02Inner > li > dl > dd {
            display: inline-block;
            width: 275px;
            position: relative;
            }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 {}

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span {
                display: block;
                line-height: 1.4;
                }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(1) {
                margin-bottom: 10px;
                font-size: 1.9rem;
                }

                #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(1) img {
                  display: inline-block;
                  width: auto;
                  height: 28px;
                  margin-right: 5px;
                  vertical-align: baseline;
                  }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(2) {
                padding: 5px;
                border: 1px solid #fff;
                font-size: 1.5rem;
                }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > ul {
              margin-left: -13px;
              padding-top: 15px;
              letter-spacing: -.40em;
              }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > ul > li {
                display: inline-block;
                width: 50%;
                padding-left: 13px;
                letter-spacing: normal;
                vertical-align: top;
                }

  #productsDmTop #featuresInner .features02 {
    background-color: #000;
    background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features02_bg.jpg");
    background-repeat: no-repeat;
    background-position: 50% 0;
    background-size: 100% auto;
    padding-bottom: 440px;
    z-index: 1;
    color: #fff;
    }

    #productsDmTop #featuresInner .features02::before { background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #043cb4 50.5%) no-repeat top left/100% 100%; }
    #productsDmTop #featuresInner .features02::after { background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top left/100% 100%; }

    #productsDmTop #featuresInner .features02-01 {
      width: calc(100vw * (460 / 1600));
      margin-left: calc(100vw * (-215 / 1600));
      position: absolute;
      top: calc(100vw * (755 / 1600) - 225px);
      left: 50%;
      }

      #productsDmTop #featuresInner .features02-01Inner {
        font-size: calc(100vw * (25 / 1600));
        font-weight: 500;
        line-height: 1.4;
        }

    #productsDmTop #featuresInner .features02-02 { padding-top: calc(100vw * (900 / 1600) - 225px - 135px); }

      #productsDmTop #featuresInner .features02-02Inner {
        margin-left: -155px;
        margin-right: -100px;
        letter-spacing: -.40em;
        text-align: center;
        }

        #productsDmTop #featuresInner .features02-02Inner > li {
          display: inline-block;
          width: 50%;
          padding-left: 55px;
          letter-spacing: normal;
          vertical-align: top;
          }

          #productsDmTop #featuresInner .features02-02Inner > li > dl > dt {
            display: block;
            margin-bottom: 25px;
            line-height: 1;
            }

          #productsDmTop #featuresInner .features02-02Inner > li:nth-of-type(1) > dl > dd { margin-left: 100px; }
          #productsDmTop #featuresInner .features02-02Inner > li:nth-of-type(2) > dl > dd { margin-right: 100px; }

    #productsDmTop #featuresInner .features02-03 {
      background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features02-03_bg.jpg");
      background-repeat: no-repeat;
      background-position: 50% 0;
      background-size: 100% auto;
      margin-top: 100px;
      }

      #productsDmTop #featuresInner .features02-03 .featuresTtlLeft .featuresTtlMain {
        padding-top: calc(100vw * (85 / 1600));
        padding-left: 0;
        }

      #productsDmTop #featuresInner .features02-03-01 {
        width: calc(100vw * (590 / 1600));
        margin-right: calc(100vw * (-240 / 1600));
        position: absolute;
        top: calc(100vw * (830 / 1600));
        right: 50%;
        text-align: right;
        }

        #productsDmTop #featuresInner .features02-03-01Inner {
          font-size: calc(100vw * (25 / 1600));
          font-weight: 500;
          line-height: 1.4;
          }

      #productsDmTop #featuresInner .features02-03-02 {
        padding-top: calc(100vw * (860 / 1600));
        text-align: center;
        }

        #productsDmTop #featuresInner .features02-03-02 > dt {
          display: block;
          margin-bottom: 25px;
          }

        #productsDmTop #featuresInner .features02-03-02 > dd {
          font-size: 2.0rem;
          font-weight: 500;
          }

  #productsDmTop #featuresInner .features03 {
    padding-top: 140px;
    padding-bottom: 385px;
    z-index: 1;
    }

    #productsDmTop #featuresInner .features03::after { background: linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #043cb4 50.5%) no-repeat top left/100% 100%; }

    #productsDmTop #featuresInner .features03 .featuresTtl { margin-bottom: 95px; }

    #productsDmTop #featuresInner .features03-01 {
      width: 100%;
      position: absolute;
      /* top: calc(-270px - 140px); */
      top: calc(-270px - 140px - 140px);
      left: 50%;
      transform: translateX(-50%);
      }

      #productsDmTop #featuresInner .features03-01Inner > dt {
        display: block;
        margin-bottom: 20px;
        }

      #productsDmTop #featuresInner .features03-01Inner > dd { text-align: right; }

    #productsDmTop #featuresInner .features03-02 { margin-bottom: 120px; }

      #productsDmTop #featuresInner .features03-02Inner > li { margin-top: 105px; }
      #productsDmTop #featuresInner .features03-02Inner > li:nth-of-type(1) { margin-top: 0; }

        #productsDmTop #featuresInner .features03-02-02 {}

          #productsDmTop #featuresInner .features03-02-02 div.p-caption {
            display: inline-block;
            width: 463px;
            margin-top: 35px;
            margin-right: -80px;
            }

        #productsDmTop #featuresInner .features03-02-03 {}

          #productsDmTop #featuresInner .features03-02-03 span.p-caption {
            margin-top: 5px !important;
            color: #4d4d4d;
            text-align: right;
            }

          #productsDmTop #featuresInner .features03-02-03 .p-comments {
            margin-top: 45px;
            line-height: 1.8;
            }

        #productsDmTop #featuresInner .features03-02-04 {}

          #productsDmTop #featuresInner .features03-02-04 .featuresSubTtl02 { margin-top: -15px; }

          #productsDmTop #featuresInner .features03-02-04 .p-caption {
            font-size: 2.0rem;
            font-weight: 500;
            text-align: center;
            }

          #productsDmTop #featuresInner .features03-02-04 dl.p-caution { margin-top: 20px; }

            #productsDmTop #featuresInner .features03-02-04 .p-caution > dt {
              display: inline-block;
              margin-top: 30px;
              }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span {
                display: inline-block;
                line-height: 1.4;
                }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(1) {
                position: relative;
                background-color: #000;
                padding: 15px 20px;
                color: #fff;
                font-size: 2.3rem;
                font-weight: 700;
                }

                #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(1)::before {
                  position: absolute;
                  top: 0;
                  left: -30px;
                  width: 30px;
                  height: 100%;
                  background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat bottom left/100% 50%, linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top right/100% 50%;
                  content: "";
                  }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(2) {
                margin-top: 8px;
                margin-left: 135px;
                padding-left: 1em;
                text-align: left;
                }

                #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(2) > span {
                  display: block;
                  text-indent: -1em;
                  }

            #productsDmTop #featuresInner .features03-02-04 .p-caution > dd {
              font-size: 1.6rem;
              font-weight: 500;
              }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dd > strong { font-weight: 700; }

    #productsDmTop #featuresInner .features03-03 {}

      #productsDmTop #featuresInner .features03-03Inner { text-align: center; }

        #productsDmTop #featuresInner .features03-03Inner > dt {
          display: block;
          margin-bottom: 30px;
          font-size: 2.0rem;
          font-weight: 500;
          line-height: 1.8;
          }

    #productsDmTop #featuresInner .features03-04 { margin-top: 90px; }

      #productsDmTop #featuresInner .features03-04Inner { border: 2px solid #000; }

        #productsDmTop #featuresInner .features03-04Inner > dt {
          display: block;
          position: relative;
          }

          #productsDmTop #featuresInner .features03-04Inner > dt > span {
            display: flex;
            align-items: center;
            height: 52px;
            font-weight: 700;
            }

          #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(1) {
            position: absolute;
            top: 0;
            left: 0;
            justify-content: center;
            width: 152px;
            background-color: #000;
            color: #fff;
            font-size: 2.6rem;
            }

            #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(1)::after {
              position: absolute;
              top: 0;
              right: -30px;
              width: 30px;
              height: 100%;
              background: linear-gradient(to top left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top left/100% 100%;
              content: "";
              }

          #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(2) {
            margin-left: 167px;
            margin-right: 16px;
            padding-left: 26px;
            border-bottom: 1px solid #000;
            font-size: 2.8rem;
            }

        #productsDmTop #featuresInner .features03-04Inner > dd {
          padding: 20px 60px;
          font-size: 2.0rem;
          font-weight: 500;
          }

  #productsDmTop #featuresInner .features04 {
    background-color: #043cb4;
    padding-top: 90px;
    padding-bottom: 160px;
    z-index: 1;
    color: #fff;
    }

    #productsDmTop #featuresInner .features04 .featuresTtl {
      margin-bottom: 95px;
      margin-left: -40px;
      }

    #productsDmTop #featuresInner .features04 .featuresTxt { font-weight: 400; }

    #productsDmTop #featuresInner .features04-01 {
      width: 100%;
      position: absolute;
      /* top: calc(-270px - 90px); */
      top: calc(-270px - 90px - 140px);
      left: 50%;
      z-index: 2;
      transform: translateX(-50%);
      }

      #productsDmTop #featuresInner .features04-01Inner > dt { display: block; }

    #productsDmTop #featuresInner .features04-02 {}

      #productsDmTop #featuresInner .features04-02 .featuresDlist {
        height: 465px;
        padding-top: 40px;
        padding-bottom: 45px;
        padding-right: 45px;
        position: relative;
        z-index: 1;
        }
      #productsDmTop #featuresInner .features04-02 .featuresDlistReverse { padding-left: 45px; }

        #productsDmTop #featuresInner .features04-02 .featuresDlist::before {
          content: "";
          background-color: #000;
          width: 100vw;
          height: 100%;
          position: absolute;
          z-index: -2;
          top: 0;
          right: 0;
          }
        #productsDmTop #featuresInner .features04-02 .featuresDlist.featuresDlistReverse::before { left: 0; }

        #productsDmTop #featuresInner .features04-02 .featuresDlist > dt {
          width: 100vw;
          position: absolute;
          top: 50%;
          z-index: -1;
          overflow: hidden;
          transform: translateY(-50%);
          text-align: right;
          }
        #productsDmTop #featuresInner .features04-02 .featuresDlistReverse > dt { text-align: left; }
        
        #productsDmTop #featuresInner .features04-02 .featuresDlist > dd {
          width: 100%;
          text-align: right;
          }
        #productsDmTop #featuresInner .features04-02 .featuresDlistReverse > dd { text-align: left; }

      #productsDmTop #featuresInner .features04-02-01 { margin-bottom: 20px; }

        #productsDmTop #featuresInner .features04-02-01 > dl {
          display: flex;
          align-items: flex-end;
          }

          #productsDmTop #featuresInner .features04-02-01 > dl > dt {
            display: block;
            width: 200px;
            }

          #productsDmTop #featuresInner .features04-02-01 > dl > dd {
            flex: 1;
            padding-left: 30px;
            }

      #productsDmTop #featuresInner .features04-02-02 { margin-bottom: 110px; }

        #productsDmTop #featuresInner .features04-02-02 .featuresDlist { align-items: flex-start; }

          #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dt { right: 45px; }

            #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dt img { width: 1490px; }

          #productsDmTop #featuresInner .features04-02-02 .featuresDlist .featuresSubTtl02 > span.p-caption {
            display: block;
            margin-top: 10px;
            font-size: 1.5rem;
            font-weight: 400;
            }

      #productsDmTop #featuresInner .features04-02-03 { margin-bottom: 70px; }

        #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dt {
          height: 100%;
          left: 60px;
          }

          #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dt > span { height: 100%; }

          #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dt video {
            width: auto;
            height: 100%;
            }

      #productsDmTop #featuresInner .features04-02-04 {
        margin-bottom: 90px;
        text-align: center;
        }

        #productsDmTop #featuresInner .features04-02-04 .featuresSubTtl02 { margin-bottom: 20px; }

        #productsDmTop #featuresInner .features04-02-04 .featuresTxt01 { margin: 0 -60px 40px -60px; }

        #productsDmTop #featuresInner .features04-02-04 .featuresSlider { margin: 0 -60px; }

          #productsDmTop #featuresInner .features04-02-04 .featuresSlider .slick-dots {
            width: 100%;
            position: absolute;
            left: 50%;
            bottom: 110px;
            transform: translateX(-50%);
            }

            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dt,
            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dt > span { display: block; }

            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd { margin-top: 100px; }

              #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) {
                display: inline-block;
                padding: 15px 20px;
                border: 1px solid #fff;
                letter-spacing: -.40em;
                }

                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span {
                  display: inline-block;
                  letter-spacing: normal;
                  vertical-align: middle;
                  line-height: 1.3;
                  }
                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span:nth-of-type(1) {
                  font-size: 2.8rem;
                  font-weight: 700;
                  }
                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span:nth-of-type(2) {
                  margin-left: 40px;
                  font-size: 1.7rem;
                  }

      #productsDmTop #featuresInner .features04-02-05 { margin-bottom: 115px; }

        #productsDmTop #featuresInner .features04-02-05 .featuresSlider { position: relative; }

          #productsDmTop #featuresInner .features04-02-05 .slick-list { overflow: visible !important; }

          #productsDmTop #featuresInner .features04-02-05 .slick-dots {
            padding-right: 120px;
            text-align: right;
            position: absolute;
            top: 55px;
            left: auto;
            right: 0;
            transform: translateX(0);
            }

            #productsDmTop #featuresInner .features04-02-05 .slick-dots > li > button {
              background-color: transparent;
              width: 75px;
              height: 75px;
              position: relative;
              }

              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li > button::before,
              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li > button::after {
                content: "";
                background-color: transparent;
                background-repeat: no-repeat;
                background-position: 50% 50%;
                background-size: 100% auto;
                width: 100%;
                height: 100%;
                position: absolute;
                top: 0;
                left: 0;
                transform: translate(0, 0);
                }

              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li > button::after { display: none; }
              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li.slick-active > button::after { display: block; }

              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li:nth-of-type(1) > button::before { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features04-02-05-icon01.svg"); }
              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li:nth-of-type(2) > button::before { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features04-02-05-icon02.svg"); }
              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li:nth-of-type(1) > button::after { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features04-02-05-icon01-active.svg"); }
              #productsDmTop #featuresInner .features04-02-05 .slick-dots > li:nth-of-type(2) > button::after { background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features04-02-05-icon02-active.svg"); }

          #productsDmTop #featuresInner .features04-02-05 .featuresSlider01 { color: #fff; }
          #productsDmTop #featuresInner .features04-02-05 .featuresSlider02 { color: #333; }

            #productsDmTop #featuresInner .features04-02-05 .featuresDlist { padding-bottom: 0; }

              #productsDmTop #featuresInner .features04-02-05 .featuresSlider01 .featuresDlist::before { background-color: #000; }
              #productsDmTop #featuresInner .features04-02-05 .featuresSlider02 .featuresDlist::before { background-color: #fff0c8; }

              #productsDmTop #featuresInner .features04-02-05 .featuresDlist > dt {
                margin-top: 10px;
                right: 465px;
                text-align: right;
                }

                #productsDmTop #featuresInner .features04-02-05 .featuresDlist > dt img {
                  display: inline-block !important;
                  width: 1070px;
                  }

      #productsDmTop #featuresInner .features04-02-06 { margin-bottom: 100px; }

        #productsDmTop #featuresInner .features04-02-06 > dl { position: relative; }

          #productsDmTop #featuresInner .features04-02-06 > dl > dt {
            margin: 0 -60px;
            text-align: center;
            }

            #productsDmTop #featuresInner .features04-02-06 > dl > dt > span { display: block; }

          #productsDmTop #featuresInner .features04-02-06 > dl > dd {
            width: 720px;
            position: absolute;
            right: 0;
            bottom: 0;
            }

            #productsDmTop #featuresInner .features04-02-06 > dl > dd .featuresSubTtl03 { margin-bottom: 10px; }

      #productsDmTop #featuresInner .features04-02-07 { margin-bottom: 80px; }

        #productsDmTop #featuresInner .features04-02-07 > dl { text-align: center; }

          #productsDmTop #featuresInner .features04-02-07 > dl > dt,
          #productsDmTop #featuresInner .features04-02-07 > dl > dt > span { display: block; }

            #productsDmTop #featuresInner .features04-02-07 > dl > dt > span.p-caution {
              margin-top: 10px;
              text-align: left;
              }

          #productsDmTop #featuresInner .features04-02-07 > dl > dd { margin-bottom: 20px; }

      #productsDmTop #featuresInner .features04-02-08 {}

        #productsDmTop #featuresInner .features04-02-08 .featuresSubTtl03 {
          margin-bottom: 20px;
          text-align: center;
          }

          #productsDmTop #featuresInner .features04-02-08 .slick-prev { left: -75px; }
          #productsDmTop #featuresInner .features04-02-08 .slick-next { right: -75px; }

          #productsDmTop #featuresInner .features04-02-08 .slick-dots {
            background-color: #000;
            width: auto;
            margin-top: 0;
            padding: 8px 0;
            border-radius: 11px;
            position: relative;
            z-index: 1;
            }

            #productsDmTop #featuresInner .features04-02-08 .slick-dots::before {
              content: "リアスモーク設定";
              display: inline-block;
              position: absolute;
              top: 50%;
              left: -85%;
              letter-spacing: normal;
              color: #fff;
              font-size: 2.5rem;
              font-weight: 700;
              transform: translateY(-50%);
              }

              #productsDmTop #featuresInner .features04-02-08 .slick-dots > li > button {
                background-color: transparent;
                width: 75px;
                height: 34px;
                border-radius: 5px;
                position: relative;
                }

              #productsDmTop #featuresInner .features04-02-08 .slick-dots > li.slick-active > button { background-color: #d26e00; }

                #productsDmTop #featuresInner .features04-02-08 .slick-dots > li > button:before {
                  background-color: transparent;
                  display: flex;
                  align-items: center;
                  justify-content: center;
                  width: 75px;
                  height: 34px;
                  position: absolute;
                  top: 0;
                  left: 0;
                  color: #fff;
                  font-size: 2.6rem;
                  text-align: center;
                  text-indent: 0;
                  transform: translate(0, 0);
                  }
                #productsDmTop #featuresInner .features04-02-08 .slick-dots > li:nth-of-type(1) > button:before { content: "無し"; }
                #productsDmTop #featuresInner .features04-02-08 .slick-dots > li:nth-of-type(2) > button:before { content: "薄い"; }
                #productsDmTop #featuresInner .features04-02-08 .slick-dots > li:nth-of-type(3) > button:before { content: "濃い"; }

      #productsDmTop #featuresInner .features04-02-09 {
        margin: 0 -60px 100px -60px;
        text-align: center;
        }

        #productsDmTop #featuresInner .features04-02-09 .featuresSubTtl02 { margin-bottom: 20px; }

        #productsDmTop #featuresInner .features04-02-09 .featuresTxt01 { margin-bottom: 40px; }

  #productsDmTop #featuresInner .features05 {
    background-color: #000;
    background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_features05_bg.jpg");
    background-repeat: no-repeat;
    background-position: 50% 0;
    background-size: 100% auto;
    padding-top: calc(100vw * (630 / 1600));
    padding-bottom: 435px;
    z-index: 1;
    color: #fff;
    }
    
    #productsDmTop #featuresInner .features05::before { background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #043cb4 50.5%) no-repeat top left/100% 100%; }
    #productsDmTop #featuresInner .features05::after { background: linear-gradient(to bottom left, rgba(255,255,255,0) 50%, #fff 50.5%) no-repeat top left/100% 100%; }

    #productsDmTop #featuresInner .features05 .featuresTtl {
      margin-bottom: 90px;
      margin-left: -60px;
      }

      #productsDmTop #featuresInner .features05 .featuresTtl span.p-caption {
        display: block;
        margin-top: 30px;
        font-size: 1.5rem;
        font-weight: 500;
        }

    #productsDmTop #featuresInner .features05-01 {}

      #productsDmTop #featuresInner .features05-01Inner {
        display: flex;
        margin: 0 -60px;
        }

        #productsDmTop #featuresInner .features05-01Inner > dt {
          display: block;
          width: 42.5%;
          text-align: center;
          }

          #productsDmTop #featuresInner .features05-01Inner > dt .p-caption {
            display: block;
            margin-top: 15px;
            font-size: 1.5rem;
            font-weight: 500;
            line-height: 1.4;
            }

        #productsDmTop #featuresInner .features05-01Inner > dd {
          width: 57.5%;
          padding-left: 35px;
          }

          #productsDmTop #featuresInner .features05-01Inner > dd > ul {
            margin-left: -35px;
            letter-spacing: -.40em;
            }

            #productsDmTop #featuresInner .features05-01Inner > dd > ul > li {
              display: inline-block;
              width: 50%;
              padding-left: 35px;
              letter-spacing: normal;
              vertical-align: top;
              }

  #productsDmTop #featuresInner .features06 {
    padding-top: 100px;
    padding-bottom: 370px;
    z-index: 1;
    }
    
    #productsDmTop #featuresInner .features06::after { background: linear-gradient(to bottom right, rgba(255,255,255,0) 50%, #043cb4 50.5%) no-repeat top left/100% 100%; }

    #productsDmTop #featuresInner .features06 .featuresTtl { margin-bottom: 145px; }

    #productsDmTop #featuresInner .features06-01 {
      width: 100%;
      position: absolute;
      top: calc(-270px - 50px);
      left: 50%;
      transform: translateX(-50%);
      text-align: center;
      }

      #productsDmTop #featuresInner .features06-01Inner > dt { display: block; }

        #productsDmTop #featuresInner .features06-01Inner > dt img { width: 254px; }

      #productsDmTop #featuresInner .features06-01Inner > dd {
        margin-top: -30px;
        margin-left: -460px;
        }

    #productsDmTop #featuresInner .features06-02 {}

      #productsDmTop #featuresInner .features06-02Inner { text-align: center; }

        #productsDmTop #featuresInner .features06-02Inner > dt {
          display: block;
          margin-top: 30px;
          }

        #productsDmTop #featuresInner .features06-02Inner > dd {}

          #productsDmTop #featuresInner .features06-02Inner > dd > ul {
            margin-top: -25px;
            margin-left: -25px;
            letter-spacing: -.40em;
            }

            #productsDmTop #featuresInner .features06-02Inner > dd > ul > li {
              display: inline-block;
              width: 33.3333%;
              padding-top: 25px;
              padding-left: 25px;
              letter-spacing: normal;
              vertical-align: top;
              }
            #productsDmTop #featuresInner .features06-02Inner > dd > ul > li:nth-of-type(1),
            #productsDmTop #featuresInner .features06-02Inner > dd > ul > li:nth-of-type(2) { width: 50%; }

  #productsDmTop #featuresInner .features07 {
    background-color: #043cb4;
    padding-top: 160px;
    padding-bottom: 120px;
    z-index: 1;
    color: #fff;
    }

    #productsDmTop #featuresInner .features07 .featuresTtl {}

    #productsDmTop #featuresInner .features07-01 {
      width: 100%;
      position: absolute;
      top: calc(-270px - 150px);
      left: 50%;
      transform: translateX(-50%);
      text-align: center;
      }

      #productsDmTop #featuresInner .features07-01Inner > dt { display: block; }

        #productsDmTop #featuresInner .features07-01Inner > dt img { width: 709px; }

      #productsDmTop #featuresInner .features07-01Inner > dd {
        text-align: right;
        margin-top: -20px;
        padding-right: 120px;
        }

    #productsDmTop #featuresInner .features07-02 { margin-bottom: 135px; }

      #productsDmTop #featuresInner .features07-02Inner > dt {
        display: block;
        margin-bottom: 45px;
        }

        #productsDmTop #featuresInner .features07-02Inner > dt > span { display: block; }

        #productsDmTop #featuresInner .features07-02Inner > dt > span:nth-of-type(1) {
          margin-bottom: 75px;
          text-align: right;
          }

          #productsDmTop #featuresInner .features07-02Inner > dt > span:nth-of-type(1) img { width: 178px; }

          #productsDmTop #featuresInner .features07-02Inner > dt > span:nth-of-type(2) video { width: 100%; }

      #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) {}

        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) > ul {
          text-align: left;
          letter-spacing: -.40em;
          }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) > ul > li {
            display: inline-block;
            width: 50%;
            letter-spacing: normal;
            vertical-align: top;
            }

      #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) {
        margin-top: 75px;
        text-align: center;
        }

        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > li > a {
          min-width: 850px;
          padding-top: 10px;
          padding-bottom: 10px;
          }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > li > a > span:nth-of-type(1) { font-size: 3.5rem; }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > .p-btnType04 > * > span::before {
            width: 45px;
            height: 45px;
            }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > .p-btnType04 > * > span::after {
            left: 16px;
            width: 17px;
            height: 20px;
            }

        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > p {
          margin-top: 25px;
          font-size: 2.0rem;
          }

    #productsDmTop #featuresInner .features07-03 { margin-bottom: 145px; }

      #productsDmTop #featuresInner .features07-03Inner > li { margin-top: 120px; }
      #productsDmTop #featuresInner .features07-03Inner > li:nth-of-type(1) { margin-top: 0; }

      #productsDmTop #featuresInner .features07-03Inner .featuresTxt01 { font-weight: 400; }

      #productsDmTop #featuresInner .features07-03Inner .featuresLogo01 { margin-top: 45px; }

        #productsDmTop #featuresInner .features07-03-01 .featuresLogo01 img { width: 176px; }

        #productsDmTop #featuresInner .features07-03-02 .featuresLogo01 img { width: 200px; }

        #productsDmTop #featuresInner .features07-03-02 .p-caption { margin-top: 20px; }

    #productsDmTop #featuresInner .features07-04 { text-align: center;  }

      #productsDmTop #featuresInner .features07-04Inner > dt {
        display: block;
        margin-bottom: 40px;
        }

      #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) {
        display: inline-flex;
        align-items: center;
        margin-bottom: 40px;
        }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresSubTtl02,
        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresTxt01 {
          display: inline-block;
          vertical-align: top;
          }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresSubTtl02 { margin-bottom: 0; }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresTxt01 { padding-left: 60px; }

      #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) {}

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table {
          width: 100%;
          margin-bottom: 80px;
          table-layout: fixed;
          }

          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table th,
          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td {
            padding: 10px;
            border: 1px solid #fff;
            font-size: 1.7rem;
            text-align: center;
            vertical-align: middle;
            }

          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td { font-size: 1.6rem; }

          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table tr td:nth-last-of-type(1) {
            background-color: #fff;
            color: #043cb4;
            border: 1px solid #043cb4;
            }
          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table tr:nth-last-of-type(1) td:nth-last-of-type(1) { border-bottom: 1px solid #fff; }

            #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td > div {
              display: flex;
              align-items: center;
              }

              #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td > div > div:nth-of-type(1) { width: 45%; }
              #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td > div > div:nth-of-type(2) { flex: 1; }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) .p-comments { text-align: left; }



/**
 * Floating
 * -------------------------------
 */

#productsDmTop #m-floating > ul { margin-top: -10px; }

  #productsDmTop #m-floating > ul > li {
    display: block;
    margin-top: 10px;
    }


/* -- .dm-m-floatingYoutube -- */
#productsDmTop .dm-m-floatingYoutube {
  background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_floating-youtube-bg.svg");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: 100% auto;
  }

  #productsDmTop .dm-m-floatingYoutube > a {
    display: block;
    height: 150px;
    position: relative;
    }

    #productsDmTop .dm-m-floatingYoutube > a > span { padding: 0 10px; }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) {
        display: flex;
        align-items: center;
        align-content: center;
        justify-content: center;
        flex-wrap: wrap;
        height: 75px;
        margin: 0;
        color: #fff;
        font-size: 11px;
        font-weight: 700;
        }

        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong {
          display: block;
          margin-top: 2px;
          font-size: 18px;
          font-weight: 900;
          line-height: 1;
          }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > span { display: inline-block; }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > .c-ffRobotoCond {
            color: #ed0038;
            font-size: 24px;
            font-weight: 700;
            }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > span:nth-of-type(2) {
            font-size: 14px;
            font-weight: 700;
            }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > span:nth-of-type(3) {
            font-size: 18px;
            font-weight: 900;
            }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(2) { display: none; }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) {
        display: flex;
        align-items: center;
        align-content: center;
        flex-wrap: wrap;
        height: 75px;
        padding-right: 45px;
        
        text-align: left;
        }

        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span {
          font-size: 17px;
          font-weight: 700;
          line-height: 1.2;
          position: relative;
          }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span:after {
            content: "";
            background-image: url("/files/cdb/ZZ/products/d-mirror/se/2210/zz_products_d-mirror_se_floating-icon_arrow01.svg");
            background-repeat: no-repeat;
            background-position: 50% 0;
            background-size: 100% auto;
            display: inline-block;
            width: 25px;
            height: 25px;
            position: absolute;
            bottom: -3px;
            right: 7px;
            }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span > span {
            display: inline;
            font-size: 10px;
            font-weight: 700;
            }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(4) {
        width: 47px;
        height: 66px;
        margin: 0;
        padding: 0;
        position: absolute;
        right: 5px;
        bottom: 2px;
        }

        #productsDmTop .da-m-floatingWebinar > a > span > span:nth-of-type(4):before,
        #productsDmTop .da-m-floatingWebinar > a > span > span:nth-of-type(4):after { display: none; }

        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(4) img { width: 100%; }

        




/**
 * ================================================================================
 * Colorbox Settings
 * ================================================================================
 */


#cboxContent { padding: 0 !important; }

#cboxClose {
  top: 0 !important;
  right: 0 !important;
  }

#cboxContent .p-modal { display: block; }






/**
 * ================================================================================
 * Other Settings
 * ================================================================================
 */

/* -- Color -- */
.c-fcYellow { color: #ffff00 !important; }


/* -- Font Family -- */
.c-ffRobotoCond { font-family: "Roboto Condensed", sans-serif !important; }








@media only screen and (min-width: 768px) and (max-width: 1279px) {
  

/**
 * ================================================================================
 * Top Page Settings
 * ================================================================================
 */
  
  
/**
 * Main Visual
 * -------------------------------
 */
  
#productsDmTop #mv .mvSlider01Txt {
  top: calc(1280px * (25 / 1600));
  font-size: calc(1280px * (21 / 1600));
  }

  
  
/**
 * Lineup
 * -------------------------------
 */

#productsDmTop #lineup .lineupTabContent::before { width: 1280px; }
  
  
#productsDmTop #lineup .lineupBannerCs::after { width: calc(1280px - 100px); }
  
  
  
/**
 * Features Inner
 * -------------------------------
 */
  
#productsDmTop #featuresInner .features02 {}
  
  #productsDmTop #featuresInner .features02-01 {
    width: calc(1280px * (460 / 1600));
    margin-left: calc(1280px * (-215 / 1600));
    top: calc(1280px * (755 / 1600) - 225px);
    }

    #productsDmTop #featuresInner .features02-01Inner { font-size: calc(1280px * (25 / 1600)); }

  #productsDmTop #featuresInner .features02-02 { padding-top: calc(1280px * (900 / 1600) - 225px - 135px); }
  
  
  #productsDmTop #featuresInner .features02-03 {}

    #productsDmTop #featuresInner .features02-03 .featuresTtlLeft .featuresTtlMain { padding-top: calc(1280px * (85 / 1600)); }

    #productsDmTop #featuresInner .features02-03-01 {
      width: calc(1280px * (590 / 1600));
      margin-right: calc(1280px * (-240 / 1600));
      top: calc(1280px * (830 / 1600));
      }

      #productsDmTop #featuresInner .features02-03-01Inner { font-size: calc(1280px * (25 / 1600)); }

    #productsDmTop #featuresInner .features02-03-02 { padding-top: calc(1280px * (860 / 1600)); }
  
  
#productsDmTop #featuresInner .features04 {}
  
  #productsDmTop #featuresInner .features04-02 .featuresDlist::before { width: 1280px; }

  #productsDmTop #featuresInner .features04-02 .featuresDlist > dt { width: 1280px; }
  
#productsDmTop #featuresInner .features05 { padding-top: calc(1280px * (630 / 1600)); }
  
  
}








@media only screen and (min-width: 0px) and (max-width: 767px) {
  
  
/**
 * ================================================================================
 * Basic Structure
 * ================================================================================
 */
  
  
#productsDmTop a:hover { opacity: 1; }
  
    
  
  
  
  
/**
 * ================================================================================
 * Parts Settings
 * ================================================================================
 */
  
  
/**
 * Wrapper
 * -------------------------------
 */

#productsDmTop .p-wrapper {
  width: 100%;
  padding: 0 15px;
  }
  
  
  
/**
 * Lists / Comments / Caution / Caption
 * -------------------------------
 */
  
#productsDmTop .p-comments,
#productsDmTop .p-caution,
#productsDmTop .p-caption { font-size: 1.0rem; }
  
  

/**
 * Title
 * -------------------------------
 */

#productsDmTop .p-secTtl01 {
  margin-bottom: 25px;
  text-align: center;
  }

  #productsDmTop .p-secTtl01 > span img {
    width: auto;
    height: calc(29px * 0.7);
    }
  
#productsDmTop .p-secTtl02 {
  margin-bottom: 15px;
  font-size: 1.3rem;
  }



/**
 * Button
 * -------------------------------
 */

#productsDmTop .p-btns {}

#productsDmTop .p-btn {}

#productsDmTop .p-btnType01 {}

  #productsDmTop .p-btnType01 > * {
    padding: 15px 30px;
    border-radius: 8px;
    }

    #productsDmTop .p-btnType01 > a::after {
      width: calc(27px * 0.6);
      height: calc(11px * 0.6);
      right: 10px;
      bottom: 10px;
      }
    #productsDmTop .p-btnType01.p-btnIconPdf > a::after {
      width: calc(22px * 0.7);
      height: calc(29px * 0.7);
      right: 10px;
      }

    #productsDmTop .p-btnType01 > * > span:nth-of-type(1) { font-size: 1.5rem; }
  
#productsDmTop .p-btnType02 {}

  #productsDmTop .p-btnType02 > * {
    padding: 10px 20px;
    border-radius: 11px;
    }

    #productsDmTop .p-btnType02 > a::after {
      width: calc(27px * 0.6);
      height: calc(11px * 0.6);
      right: 10px;
      bottom: 10px;
      }

    #productsDmTop .p-btnType02 > * > span:nth-of-type(1) { font-size: 1.4rem; }
  
#productsDmTop .p-btnType03 {}

  #productsDmTop .p-btnType03 > * { padding: 10px 30px; }

    #productsDmTop .p-btnType03 > a::after {
      width: 12px;
      height: 12px;
      border-top: 1px solid #fff;
      border-right: 1px solid #fff;
      right: 15px;
      }

    #productsDmTop .p-btnType03 > * > span:nth-of-type(1) { font-size: 1.4rem; }

    #productsDmTop .p-btnType03 > * > span:nth-of-type(2) {
      margin-top: 3px;
      font-size: 1.0rem;
      }
  
#productsDmTop .p-btnType04 {}

  #productsDmTop .p-btnType04 > * {
    padding: 5px 15px;
    border: 1px solid #c5a448;
    }

    #productsDmTop .p-btnType04 > * > span {
      padding-left: 25px;
      text-align: left;
      }

    #productsDmTop .p-btnType04 > * > span:nth-of-type(1) { font-size: 1.4rem; }

      #productsDmTop .p-btnType04 > * > span::before {
        width: calc(28px * 0.6);
        height: calc(28px * 0.6);
        }

      #productsDmTop .p-btnType04 > * > span::after {
        width: calc(11px * 0.6);
        height: calc(13px * 0.6);
        left: calc(10px * 0.6);
        }

  #productsDmTop .p-btnType04.p-btnColorBlack > * { border: 1px solid #c5a448; }

  #productsDmTop .p-btnType04.p-btnColorGold > * { border: 1px solid #000; }
  
  #productsDmTop .p-btnType04.p-btnColorGblue > * {
    padding-top: 5px;
    padding-bottom: 5px;
    border: 1px solid #fff; 
    }
  
  
  
/**
 * Link
 * -------------------------------
 */
  
#productsDmTop .p-linkYoutube {}
  
  #productsDmTop .p-linkYoutube dl { padding-left: 70px; }

    #productsDmTop .p-linkYoutube dl:before {
      width: 55px;
      height: 55px;
      }

    #productsDmTop .p-linkYoutube dl > dt {
      margin-bottom: 5px;
      font-size: 10px;
      }

    #productsDmTop .p-linkYoutube dl > dd {}

      #productsDmTop .p-linkYoutube dl > dd > p { font-size: 11px; }

      #productsDmTop .p-linkYoutube dl > dd > p > * { font-size: 13px; }
  
  
  
/**
 * Banner
 * -------------------------------
 */

#productsDmTop .p-bannerTrial { margin-top: 30px; }

  #productsDmTop .p-bannerTrial > dt { margin-bottom: 10px; }

    #productsDmTop .p-bannerTrial > dt > span {
      padding: 0 10px;
      font-size: 1.2rem;
      }

  
  
/**
 * Slickslider
 * -------------------------------
 */

#productsDmTop .slick-arrow {
  width: calc(50px * 0.6);
  height: calc(50px * 0.6);
  }

#productsDmTop .slick-prev { left: calc(-58px * 0.6); }
#productsDmTop .slick-next { right: calc(-58px * 0.6); }
  
  #productsDmTop .slick-prev::before { margin-left: 2.5px; }
  #productsDmTop .slick-next::before { margin-left: -2.5px; }

#productsDmTop .slick-arrow:hover { opacity: 1; }

  #productsDmTop .slick-arrow::before {
    width: calc(16px * 0.6);
    height: calc(16px * 0.6);
    }

#productsDmTop .slick-dots { bottom: -20px; }

  #productsDmTop .slick-dots > li { margin: 0 4px; }

    #productsDmTop .slick-dots > li > button {
      width: 30px;
      height: 6px;
      }

    #productsDmTop .slick-dots > li > button:hover { opacity: 1; }

      #productsDmTop .slick-dots > li > button::before { height: 4px; }
  
  
  

  
  
/**
 * ================================================================================
 * Content Settings
 * ================================================================================
 */
  
  
/**
 * UCL
 * -------------------------------
 */

#productsDmTop #ucl {
  display: block;
  height: auto;
  padding: 5px 10px 10px 10px;
  }

  #productsDmTop #ucl > dl { display: block; }

    #productsDmTop #ucl > dl > dt {}

      #productsDmTop #ucl > dl > dt img { width: 60%; }

    #productsDmTop #ucl > dl > dd {
      padding-left: 0;
      margin-left: 0;
      padding-top: 10px;
      font-size: 12px;
      }

      #productsDmTop #ucl > dl > dd::before {
        width: 20px;
        height: 1px;
        left: 50%;
        top: 0;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
        }
  


/**
 * Main Visual
 * -------------------------------
 */

#productsDmTop #mv { margin-bottom: 50px; }

  #productsDmTop #mv .mvSlider {
    margin-bottom: calc(80px * 0.6);
    margin-left: calc(100vw * (-30 / 640));
    margin-right: calc(100vw * (-30 / 640));
    }

    #productsDmTop #mv .mvSliderInner {}

    #productsDmTop #mv .mvSlider .slick-arrow {
      display: none !important;
      width: calc(36px * 0.4);
      height: calc(200px * 0.25);
      margin-top: 0;
      opacity: 0.9;
      }
    #productsDmTop #mv .mvSlider .slick-prev { left: calc(100vw * (30 / 640)); }
    #productsDmTop #mv .mvSlider .slick-next { right: calc(100vw * (30 / 640)); }

      #productsDmTop #mv .mvSlider .slick-arrow::before {
        width: calc(10px * 0.4);
        height: calc(74px * 0.4);
        }

      #productsDmTop #mv .mvSlider .slick-prev::before { margin-left: -1px; }
      #productsDmTop #mv .mvSlider .slick-next::before { margin-left: 1px; }

    #productsDmTop #mv .mvSlider .slick-dots {}

      #productsDmTop #mv .mvSlider .slick-dots > li > button { width: 20px; }


  #productsDmTop #mv .mvSlider01Txt {
    top: calc(100vw * (9 / 640));
    font-size: calc(100vw * (14 / 640));
    }
  
  #productsDmTop #mv .mvTtl { margin-bottom: 35px; }
  
    #productsDmTop #mv .mvTtl > span:nth-of-type(1) {
      margin-bottom: 15px;
      font-size: 1.2rem;
      }

      #productsDmTop #mv .mvTtl > span:nth-of-type(1) img {
        width: 30px;
        margin: -2px 5px 0 0;
        }

    #productsDmTop #mv .mvTtl > span:nth-of-type(2) { margin-bottom: 20px; }

      #productsDmTop #mv .mvTtl > span:nth-of-type(2) img { width: calc(542px * 0.55); }

    #productsDmTop #mv .mvTtl > span:nth-of-type(3) { font-size: 1.1rem; }

  #productsDmTop #mv .mvMovie { margin-bottom: 40px; }

    #productsDmTop #mv .mvMovie img { width: calc(311px * 0.6); }
  
  #productsDmTop #mv .p-linkYoutube {
    padding-top: 20px;
    margin-bottom: 40px;
    }

  #productsDmTop #mv .mvTrouble {}

    #productsDmTop #mv .mvTrouble .p-btn { width: 80%; }
  
  

/**
 * Trouble
 * -------------------------------
 */

#trouble {}

  #trouble .p-wrapper { padding: 30px 15px; }

  #trouble .troubleTtl { margin-bottom: 25px; }

    #trouble .troubleTtl > span:nth-of-type(1) {
      margin-bottom: 15px;
      font-size: 15px;
      }

    #trouble .troubleTtl > span:nth-of-type(2) {
      width: 50px;
      height: 1px;
      }

    #trouble .troubleTtl > span:nth-of-type(3) {
      margin-top: 20px;
      font-size: 13px;
      }

  #trouble .troubleTxt {
    margin-bottom: 45px;
    font-size: 12px;
    }

    #trouble .troubleTxt > span:nth-of-type(2) {
      margin-top: -30px;
      margin-bottom: 20px;
      }
  
      #trouble .troubleTxt > span img {
        width: 120%;
        max-width: initial;
        margin-left: -10%;
        }

  #trouble .troubleLists {}

    #trouble .troubleLists > dt {}

      #trouble .troubleLists > dt > span { font-size: 15px; }

      #trouble .troubleLists > dt > span:nth-of-type(1) { margin-bottom: 5px; }

      #trouble .troubleLists > dt > span:nth-of-type(2) { margin-bottom: 20px; }

        #trouble .troubleLists > dt > span:nth-of-type(3) img { width: calc(103px * 0.6); }

    #trouble .troubleLists > dd { margin-top: -15px; }

      #trouble .troubleLists > dd > p:nth-of-type(1) { margin-bottom: 50px; }

        #trouble .troubleLists > dd > p:nth-of-type(1) > span:nth-of-type(2) {
          margin-top: -10px;
          margin-bottom: 20px;
          font-size: 12px;
          }

          #trouble .troubleLists > dd > p:nth-of-type(1) > span img {
            width: 120%;
            max-width: initial;
            margin-left: -10%;
            }

  
  
/**
 * Pickup
 * -------------------------------
 */

#productsDmTop #pickup { padding-bottom: 60px; }
  
  
  /* -- .pickupSlider -- */
  #productsDmTop #pickup .pickupSlider { padding: 0 30px; }

    #productsDmTop #pickup .pickupSlider .slick-track {}

    #productsDmTop #pickup .pickupSlider .slick-arrow {
      width: 30px;
      height: 30px;
      margin: 0;
      }

    #productsDmTop #pickup .pickupSlider .slick-prev { left: -35px; }
    #productsDmTop #pickup .pickupSlider .slick-next { right: -35px; }

    #productsDmTop #pickup .pickupSlider .slick-arrow:hover { opacity: 1 }

      #productsDmTop #pickup .pickupSlider .slick-arrow::before {
        width: 15px;
        height: 15px;
        }

    #productsDmTop #pickup .pickupSlider .slick-slide {
      width: calc(100vw - 90px) !important;
      height: auto !important;
      margin-right: 15px;
      }

  
  
/**
 * Lineup
 * -------------------------------
 */

#productsDmTop #lineup { padding-top: 25px; }

  #productsDmTop #lineup .p-secTtl01 { margin-bottom: 25px; }

  #productsDmTop #lineup .lineupPkg { margin-bottom: 40px; }

    #productsDmTop #lineup .lineupPkgBanner {}

      #productsDmTop #lineup .lineupPkgBanner > li { margin-top: 10px; }

  #productsDmTop #lineup .lineupTabNav {
    width: 100%;
    margin-left: -3px;
    transform: translateX(0);
    }

    #productsDmTop #lineup .lineupTabNav > li { padding-left: 3px; }

      #productsDmTop #lineup .lineupTabNav > li > * {
        height: calc(128px * 0.7);
        border-bottom: 3px solid #fff;
        }
  
        #productsDmTop #lineup .lineupTabNav > li > * > span > strong {
          top: -20px;
          font-size: 1.0rem;
          }

        #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(1) {
          margin-bottom: 5px;
          font-size: 1.5rem;
          }

        #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(1) { font-size: 1.6rem; }

          #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(1) img {
            height: calc(32px * 0.55);
            margin-right: 3px;
            top: 1px;
            }

          #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(1) img { height: calc(40px * 0.55); }

        #productsDmTop #lineup .lineupTabNav > li > * > span > span:nth-of-type(2) {
          min-width: 60px;
          padding: 2px 10px;
          font-size: 1.0rem;
          line-height: 1.2;
          }

        #productsDmTop #lineup .lineupTabNav > li > *.active > span > span:nth-of-type(2) { font-size: 1.05rem; }

    #productsDmTop #lineup .lineupTabContent .lineupTabContentInner { padding: 50px 15px 50px 15px; }

  #productsDmTop #lineup .lineupBanner {
    margin-top: -20px;
    margin-left: -10px;
    margin-bottom: 30px;
    }
  
    #productsDmTop #lineup .lineupBannerCs::after {
      background-size: calc(618px * 0.4) auto;
      width: calc(100vw - 20px);
      height: calc(100% + 20px);
      margin-left: 5px;
      border-radius: 10px;
      }

    #productsDmTop #lineup .lineupBanner > li {
      display: inline-block;
      width: 100%;
      padding-top: 20px;
      padding-left: 10px;
      }

    #productsDmTop #lineup .lineupBannerInner {}

      #productsDmTop #lineup .lineupBannerInner > dt {}

      #productsDmTop #lineup .lineupBannerInner > dd {
        padding: 15px 10px;
        border-bottom-left-radius: 14px;
        border-bottom-right-radius: 14px;
        }

        #productsDmTop #lineup .lineupBannerInner > dd::after {
          width: calc(27px * 0.6);
          height: calc(11px * 0.6);
          right: 10px;
          bottom: 15px;
          }

    #productsDmTop #lineup .lineupBannerImg {
      border-top-left-radius: 14px;
      border-top-right-radius: 14px;
      }

    #productsDmTop #lineup .lineupBannerLabel {
      width: calc(105px * 0.6);
      height: calc(105px * 0.6);
      top: -10px;
      }
    #productsDmTop #lineup .lineupBanner > li:nth-child(odd) .lineupBannerLabel { left: -15px; }
    #productsDmTop #lineup .lineupBanner > li:nth-child(even) .lineupBannerLabel {
      left: -15px;
      right: auto;
      }

    #productsDmTop #lineup .lineupBannerSubTtl { margin-bottom: 4px; }

      #productsDmTop #lineup .lineupBannerSubTtl > span { font-size: 1.3rem; }
  
        #productsDmTop #lineup .lineupBannerSubTtl > span > span { font-size: 1.0rem; }

          #productsDmTop #lineup .lineupBannerSubTtl > span img {
            margin: 1px 5px 0 2px;
            width: 45px;
            }

    #productsDmTop #lineup .lineupBannerTtl { margin-bottom: 10px; }

      #productsDmTop #lineup .lineupBannerTtl > span { font-size: 2.0rem; }

      #productsDmTop #lineup .lineupBannerTtl > span.c-fcYellow {
        margin-top: 6px;
        font-size: 1.4rem;
        }

    #productsDmTop #lineup .lineupBannerCaption { font-size: 1.1rem; }
  
    #productsDmTop #lineup .lineupBannerRecommend { margin-top: 10px; }

      #productsDmTop #lineup .lineupBannerRecommend > a { font-size: 1.2rem; }

  #productsDmTop #lineup .lineupBtn {
    padding-bottom: 35px;
    margin-top: -15px;
    }

    #productsDmTop #lineup .lineupBtn .p-btn {
      width: 100%;
      margin-top: 15px;
      }

      #productsDmTop #lineup .lineupBtn .p-btn > *::after {
        width: calc(27px * 0.6);
        height: calc(11px * 0.6);
        }
      #productsDmTop #lineup .lineupBtn .p-btn.p-btnIconPdf > a::after {
        width: calc(22px * 0.7);
        height: calc(29px * 0.7);
        }

  #productsDmTop #lineup .lineupTtl { margin-bottom: 20px; }

    #productsDmTop #lineup .lineupTtl > span:nth-of-type(1) {
      padding: 0 10px;
      font-size: 1.5rem;;
      }

  #productsDmTop #lineup .lineupLabel {
    width: calc(132px * 0.6);
    margin: 10px auto 0 auto;
    border-left: none;
    position: static;
    transform: translateY(0);
    }

  #productsDmTop #lineup .lineupKit {
    padding: 0 15px;
    border-radius: 13px;
    margin: 0 -15px;
    }
  
    #productsDmTop #lineup .lineupKitTtl {
      margin-top: -10px;
      margin-bottom: 20px;
      }
  
      #productsDmTop #lineup .lineupKitTtl > span {
        padding: 0 10px;
        font-size: 1.4rem;
        }
  
    #productsDmTop #lineup .lineupKitSubttl {
      margin-bottom: 10px;
      font-size: 1.4rem;
      }
  
    #productsDmTop #lineup .lineupKitSearch {}

      #productsDmTop #lineup .lineupKitSearchMaker { position: relative; }

        #productsDmTop #lineup .lineupKitSearchMaker::after {
          top: 50%;
          right: 10px;
          width: 10px;
          height: 10px;
          margin-top: -2px;
          border-right: 2px solid #1964ff;
          border-bottom: 2px solid #1964ff;
          }

        #productsDmTop #lineup .lineupKitSearchMaker select {
          padding: 10px 15px;
          border-radius: 8px;
          font-size: 1.4rem;
          }

    #productsDmTop #lineup .lineupKitInner { margin-top: 30px; }
    #productsDmTop #lineup .lineupKitInner:nth-of-type(1) {
      /* margin-top: 0; */
      margin-top: 40px;
      }

      #productsDmTop #lineup .lineupKitInner > dt { margin-bottom: 10px; }

        #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) {
          display: block;
          font-size: 1.3rem;
          }

          #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) > span,
          #productsDmTop #lineup .lineupKitInner > dt > span:nth-of-type(1) > strong {
            display: block;
            padding: 4px 5px;
            }

    #productsDmTop #lineup .lineupKitLists {}

      #productsDmTop #lineup .lineupKitLists > li { width: 50%; }
      #productsDmTop #lineup .lineupKitLists > li:nth-child(2n + 1) { margin-left: 0; }
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(3),
      #productsDmTop #lineup .lineupKitLists > li:nth-of-type(4) { margin-top: -1px; }

      #productsDmTop #lineup .lineupKitListsInner { height: 60px; }

        #productsDmTop #lineup .lineupKitListsInner > dd > p { font-size: 1.0rem; }

    #productsDmTop #lineup .lineupKitCommonts {
      margin-top: 10px;
      font-size: 1.0rem;
      }

  #productsDmTop #lineup .lineupArm { margin-top: 30px; }

    #productsDmTop #lineup .lineupArm .lineupTtl { margin-bottom: 20px; }

    #productsDmTop #lineup .lineupArmLists {
      display: block;
      margin-top: -15px;
      margin-left: -10px;
      }

      #productsDmTop #lineup .lineupArmLists > li {
        width: 100%;
        padding-top: 15px;
        padding-left: 10px;
        }

      #productsDmTop #lineup .lineupArmListsInner {
        height: auto;
        padding: 20px 25px;
        border-radius: 10px;
        }

      #productsDmTop #lineup .lineupArmListsBtn { margin-bottom: 15px; }

          #productsDmTop #lineup .lineupArmListsBtn .p-btn > * {
            display: block;
            width: 100%;
            min-height: initial;
            padding: 5px 25px;
            border-radius: 5px;
            }

            #productsDmTop #lineup .lineupArmListsBtn .p-btn > *::after {
              width: calc(27px * 0.6);
              height: calc(11px * 0.6);
              right: 10px;
              }

            #productsDmTop #lineup .lineupArmListsBtn .p-btn > * > span { font-size: 1.3rem; }

      #productsDmTop #lineup .lineupArmListsFitting {}

        #productsDmTop #lineup .lineupArmListsFitting > dt { margin-bottom: 10px; }

          #productsDmTop #lineup .lineupArmListsFitting > dt > span {
            padding: 0 10px;
            color: #fff;
            font-size: 1.2rem;
            }

        #productsDmTop #lineup .lineupArmListsFittingLists {
          margin-top: -5px;
          margin-left: -8px;
          }

          #productsDmTop #lineup .lineupArmListsFittingLists > li {
            padding-top: 5px;
            padding-left: 8px;
            font-size: 1.1rem;
            }
  
  #productsDmTop #lineup .lineupBottom {
    padding-top: 40px;
    padding-bottom: 40px;
    }

  #productsDmTop #lineup .lineupUc { margin-bottom: 40px; }

    #productsDmTop #lineup .lineupUcBtn {
      padding-left: 30px;
      padding-right: 30px;
      }

      #productsDmTop #lineup .lineupUcBtn .p-btn { width: 100%; }

  #productsDmTop #lineup .lineupComments {
    margin-top: 30px;
    font-size: 1.0rem;
    }
  
  
  
/**
 * Recommend
 * -------------------------------
 */

#recommend {}

  #recommend .p-wrapper { padding: 30px 15px; }

  #recommend .recommendTtl { margin-bottom: 15px; }

    #recommend .recommendTtl > span { font-size: 1.6rem; }
  
    #recommend .recommendInner > dt { margin-bottom: 15px; }

    #recommend .recommendInner > dd > p { font-size: 1.2rem; }
  
  
  
/**
 * Features
 * -------------------------------
 */

#productsDmTop #features {
  padding-top: 60px;
  padding-bottom: 20px;
  }

  #productsDmTop .p-secTtl01 { margin-bottom: 20px; }

  #productsDmTop .featuresLists {
    padding-bottom: 40px;
    margin-top: -8px;
    margin-left: -8px;
    }

    #productsDmTop .featuresLists > li {
      height: calc(100vw * (467 / 640) * 0.6);
      margin-top: 8px;
      padding-left: 8px;
      }
    #productsDmTop .featuresLists .featuresLists02,
    #productsDmTop .featuresLists .featuresLists06 { width: 56.759259%; }
    #productsDmTop .featuresLists .featuresLists03,
    #productsDmTop .featuresLists .featuresLists05 { width: 43.240741%; }
    #productsDmTop .featuresLists .featuresLists04 { height: calc(100vw * (467 / 640) * 0.6); }

      #productsDmTop .featuresListsInner { border-radius: 10px; }

        #productsDmTop .featuresListsInner::before {
          width: calc(49px * 0.4);
          height: calc(49px * 0.4);
          bottom: calc(20px * 0.4);
          left: calc(20px * 0.4);
          }
  
        #productsDmTop .featuresListsIconBlack::before { border: 1px solid #000; }
        #productsDmTop .featuresListsIconWhite::before { border: 1px solid #fff; }

        #productsDmTop .featuresListsInner::after {
          width: calc(14px * 0.4);
          height: calc(14px * 0.4);
          bottom: calc(38px * 0.4);
          left: calc(35px * 0.4);
          }

        #productsDmTop .featuresListsIconBlack::after {
          border-top: 1px solid #000;
          border-right: 1px solid #000;
          }
        #productsDmTop .featuresListsIconWhite::after {
          border-top: 1px solid #fff;
          border-right: 1px solid #fff;
          }

          #productsDmTop .featuresListsInner > dt img {
            width: auto;
            max-width: initial;
            min-height: 100%;
            height: 100%;
            overflow: hidden;
            }

        #productsDmTop .featuresListsInner > dd {}

          #productsDmTop .featuresListsTtl {
            font-size: 1.6rem;
            letter-spacing: normal;
            }

          #productsDmTop .featuresListsTtlTop { top: calc(35px * 0.4); }
          #productsDmTop .featuresListsTtlBottom { bottom: calc(35px * 0.4); }
          #productsDmTop .featuresListsTtlLeft { left: calc(40px * 0.4); }
          #productsDmTop .featuresListsTtlRight { right: calc(40px * 0.4); }
  
            #productsDmTop .featuresListsTtl > span { font-size: 1.3rem; }

    #productsDmTop .featuresLists03 {}

      #productsDmTop .featuresLists03 .featuresListsInner > dt video {
        margin-top: calc(40px * 0.5);
        margin-left: calc(-40px * 0.5);
        height: 310%;
        }

    #productsDmTop .featuresLists04 {}

      #productsDmTop .featuresLists04 .featuresListsInner > dt video {
        height: 100%;
        left: calc(100vw * (410 / 640) * 0.65);
        }

    #productsDmTop .featuresLists04 {}

      #productsDmTop .featuresLists04 .featuresListsLogo {
        left: 45px;
        bottom: 10px;
        }

        #productsDmTop .featuresLists04 .featuresListsLogo > dt {
          padding-left: 0px;
          margin-bottom: 10px;
          }

          #productsDmTop .featuresLists04 .featuresListsLogo > dt img { width: calc(154px * 0.4); }

        #productsDmTop .featuresLists04 .featuresListsLogo > dd {}

  

/**
 * Features Inner
 * -------------------------------
 */

#productsDmTop #featuresInner {}
  
#productsDmTop .featuresBody { min-width: 100%; }
  
  #productsDmTop #featuresInner .featuresClose {
    width: 40px;
    height: 40px;
    }

  #productsDmTop #featuresInner .featuresClose:hover { opacity: 1; }

      #productsDmTop #featuresInner .featuresClose > span::before,
      #productsDmTop #featuresInner .featuresClose > span::after {
        width: 25px;
        height: 2px;
        }

  #productsDmTop #featuresInner .features { padding-top: 50px; }

    #productsDmTop #featuresInner .features::before,
    #productsDmTop #featuresInner .features::after { height: 50px; }

    #productsDmTop #featuresInner .featuresTtl {}

      #productsDmTop #featuresInner .featuresTtl .featuresTtlNum {
        width: calc(100vw * (300 / 640) * 0.5);
        height: calc(100vw * (256 / 640) * 0.5);
        }

      #productsDmTop #featuresInner .featuresTtl .featuresTtlMain { font-size: calc(100vw * (30 / 640)); }
      #productsDmTop #featuresInner .featuresTtlLeft .featuresTtlMain { padding-left: calc(100vw * (325 / 640) * 0.5); }
      #productsDmTop #featuresInner .featuresTtlRight .featuresTtlMain { padding-right: calc(100vw * (325 / 640) * 0.5); }
      #productsDmTop #featuresInner .featuresTtlTop .featuresTtlMain { padding-top: calc(100vw * (5 / 640)); }
  
        #productsDmTop #featuresInner .featuresTtl .featuresTtlMain > span { font-size: calc(100vw * (20 / 640)); }

    #productsDmTop #featuresInner .featuresSubTtl01 { font-size: 1.6rem; }

    #productsDmTop #featuresInner .featuresSubTtl02 {
      margin-bottom: 10px;
      font-size: 1.4rem;
      }

    #productsDmTop #featuresInner .featuresSubTtl03 { font-size: 1.3rem; }

    #productsDmTop #featuresInner .featuresTxt01 {
      font-size: 1.2rem;
      letter-spacing: 0.06em;
      }

    #productsDmTop #featuresInner .featuresDlist { display: block; }
  
      #productsDmTop #featuresInner .featuresDlist > dt {
        display: block;
        width: 100%;
        margin-top: 20px;
        }

        #productsDmTop #featuresInner .featuresDlist > dt > span.p-comments,
        #productsDmTop #featuresInner .featuresDlist > dt > span.p-caution,
        #productsDmTop #featuresInner .featuresDlist > dt > span.p-caption { margin-top: 5px; }

      #productsDmTop #featuresInner .featuresDlist > dd {
        display: block;
        width: 100%;
        padding-left: 0;
        text-align: center;
        }
      #productsDmTop #featuresInner .featuresDlist.featuresDlistReverse > dd {
        padding-right: 0;
        text-align: center;
        }

  #productsDmTop #featuresInner .features01 { padding-top: 30px; }

    #productsDmTop #featuresInner .features01-01 { padding-top: 5px; }

      #productsDmTop #featuresInner .features01-01Inner {}

        #productsDmTop #featuresInner .features01-01Inner > dt { margin: 10px 0 0 0; }

        #productsDmTop #featuresInner .features01-01Inner > dd:nth-of-type(1) {
          margin-left: calc(100vw * (185 / 640) * 0.45);
          top: calc(100vw * (185 / 640) * 0.35);
          }
        #productsDmTop #featuresInner .features01-01Inner > dd:nth-of-type(2) {
          margin-right: calc(100vw * (230 / 640) * 0.45);
          bottom: calc(100vw * (180 / 640) * 0.3);
          }

    #productsDmTop #featuresInner .features01-02 {
      padding-top: 50px;
      margin-top: -30px;
      }

      #productsDmTop #featuresInner .features01-02::before { height: 50px; }

      #productsDmTop #featuresInner .features01-02 .featuresSubTtl01 { margin-bottom: 5px; }

      #productsDmTop #featuresInner .features01-02Inner {
        margin-left: -5px;
        margin-right: 0;
        padding-bottom: 15px;
        }

        #productsDmTop #featuresInner .features01-02Inner .featuresSubTtl01 { padding-bottom: 3px; }

        #productsDmTop #featuresInner .features01-02Inner > li {
          width: 33.3333%;
          padding-left: 5px;
          }

          #productsDmTop #featuresInner .features01-02Inner > li > dl > dt { margin-bottom: 10px; }

            #productsDmTop #featuresInner .features01-02Inner > li:nth-of-type(3) > dl > dt::before {
              width: calc(162px * 0.3);
              height: calc(162px * 0.3);
              top: calc(100vw * (140 / 640) * 0.47);
              right: calc(-95px * 0.17);
              }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dt > span:nth-of-type(1) {
              margin-bottom: 3px;
              font-size: 1.0rem;
              letter-spacing: -0.03em;
              }

          #productsDmTop #featuresInner .features01-02Inner > li > dl > dd {
            width: 90%;
            position: relative;
            z-index: 2;
            }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 {}

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(1) {
                margin-bottom: 5px;
                font-size: 1.1rem;
                }

                #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(1) img {
                  height: calc(28px * 0.7);
                  margin-right: 3px;
                  }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > h3 > span:nth-of-type(2) {
                display: inline-block;
                width: 80%;
                padding: 3px;
                font-size: 1.0rem;
                }

            #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > ul {
              margin-top: -3px;
              margin-left: -3px;
              padding-top: 10px;
              }

              #productsDmTop #featuresInner .features01-02Inner > li > dl > dd > ul > li {
                width: 80%;
                padding-left: 3px;
                padding-top: 3px;
                }

  #productsDmTop #featuresInner .features02 {
    background-size: 130% auto;
    padding-bottom: 120px;
    }

    #productsDmTop #featuresInner .features02-01 {
      width: calc(100vw * (460 / 640));
      margin-left: calc(100vw * (-215 / 640) * 0.55);
      top: calc(100vw * (755 / 640) * 0.55 - 50px);
      }

      #productsDmTop #featuresInner .features02-01Inner { font-size: 1.1rem; }

    #productsDmTop #featuresInner .features02-02 { padding-top: calc(100vw * (900 / 640) * 0.65 - 50px - 135px); }

      #productsDmTop #featuresInner .features02-02Inner {
        margin-left: -15px;
        margin-right: -5px;
        }

        #productsDmTop #featuresInner .features02-02Inner > li {
          width: 50%;
          padding-left: 10px;
          }

          #productsDmTop #featuresInner .features02-02Inner > li > dl > dt { margin-bottom: 10px; }

          #productsDmTop #featuresInner .features02-02Inner > li:nth-of-type(1) > dl > dd { margin-left: calc(100vw * (100 / 640) * 0.5); }
          #productsDmTop #featuresInner .features02-02Inner > li:nth-of-type(2) > dl > dd { margin-right: calc(100vw * (100 / 640) * 0.5); }

            #productsDmTop #featuresInner .features02-02Inner > li > dl > dd .featuresTxt01 { font-size: 1.0rem; }
  
    #productsDmTop #featuresInner .features02-03 {
      margin-top: 40px;
      background-size: 130% auto;
      }

      #productsDmTop #featuresInner .features02-03 .featuresTtlLeft .featuresTtlMain {
        padding-top: 20px;
        padding-left: 20px;
        }

      #productsDmTop #featuresInner .features02-03-01 {
        width: calc(100vw * (590 / 640) * 0.75);
        margin-right: calc(100vw * (-240 / 1600) * 1.4);
        top: calc(100vw * (830 / 640) * 0.55);
        }

        #productsDmTop #featuresInner .features02-03-01Inner { font-size: 1.1rem; }

      #productsDmTop #featuresInner .features02-03-02 { padding-top: calc(100vw * (860 / 640) * 0.55); }

        #productsDmTop #featuresInner .features02-03-02 > dt {; margin-bottom: 10px; }

        #productsDmTop #featuresInner .features02-03-02 > dd { font-size: 1.0rem; }

  #productsDmTop #featuresInner .features03 {
    padding-top: calc(100vw * (140 / 640));
    padding-bottom: calc(100vw * (220 / 640));
    }

    #productsDmTop #featuresInner .features03 .featuresTtl { margin-bottom: 30px; }

    #productsDmTop #featuresInner .features03-01 {
      padding: 0 15px;
      top: calc(100vw * ((-270 - 140 - 100) / 640) * 0.65);
      }

      #productsDmTop #featuresInner .features03-01Inner > dt { /* margin-bottom: 10px; */ }

      #productsDmTop #featuresInner .features03-01Inner > dd {
        margin-top: calc(100vw * (-110 / 640));
        text-align: right;
        }

    #productsDmTop #featuresInner .features03-02 { margin-bottom: 40px; }

      #productsDmTop #featuresInner .features03-02Inner > li { margin-top: 30px; }

        #productsDmTop #featuresInner .features03-02-02 {}

          #productsDmTop #featuresInner .features03-02-02 div.p-caption {
            width: 100%;
            margin-top: 15px;
            margin-right: 0;
            padding: 0 15px;
            }

        #productsDmTop #featuresInner .features03-02-03 {}

          #productsDmTop #featuresInner .features03-02-03 span.p-caption {
            margin-top: 5px !important;
            color: #4d4d4d;
            text-align: right;
            }

          #productsDmTop #featuresInner .features03-02-03 .p-comments {
            margin-top: 15px;
            line-height: 1.8;
            }

        #productsDmTop #featuresInner .features03-02-04 {}

          #productsDmTop #featuresInner .features03-02-04 .featuresSubTtl02 { margin-top: 0; }

          #productsDmTop #featuresInner .features03-02-04 .p-caption { font-size: 1.1rem; }

          #productsDmTop #featuresInner .features03-02-04 dl.p-caution { margin-top: 10px; }

            #productsDmTop #featuresInner .features03-02-04 .p-caution > dt { margin-top: 20px; }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(1) {
                display: block;
                padding: 5px 10px;
                font-size: 1.3rem;
                }

                #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(1)::before {
                  background: linear-gradient(to top right, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top left/50% 100%, linear-gradient(to top left, rgba(255,255,255,0) 50%, #000 50.5%) no-repeat top right/50% 100%;
                  width: 20px;
                  height: 10px;
                  position: absolute;
                  top: auto;
                  bottom: -10px;
                  left: 50%;
                  transform: translateX(-50%);
                  }

              #productsDmTop #featuresInner .features03-02-04 .p-caution > dt > span:nth-of-type(2) {
                margin-top: 15px;
                margin-left: 0;
                }

            #productsDmTop #featuresInner .features03-02-04 .p-caution > dd { font-size: 1.2rem; }

    #productsDmTop #featuresInner .features03-03 {}

      #productsDmTop #featuresInner .features03-03Inner { text-align: center; }

        #productsDmTop #featuresInner .features03-03Inner > dt {
          margin-bottom: 15px;
          font-size: 1.2rem;
          }
  
    #productsDmTop #featuresInner .features03-04 { margin-top: 35px; }

      #productsDmTop #featuresInner .features03-04Inner {}

        #productsDmTop #featuresInner .features03-04Inner > dt {}

          #productsDmTop #featuresInner .features03-04Inner > dt > span { height: 35px; }

          #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(1) {
            width: 70px;
            font-size: 1.3rem;
            }

            #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(1)::after {
              right: -15px;
              width: 15px;
              }

          #productsDmTop #featuresInner .features03-04Inner > dt > span:nth-of-type(2) {
            margin-left: 80px;
            margin-right: 10px;
            padding-left: 10px;
            font-size: 1.4rem;
            }

        #productsDmTop #featuresInner .features03-04Inner > dd {
          padding: 10px 15px;
          font-size: 1.2rem;
          }
  
  #productsDmTop #featuresInner .features04 {
    padding-top: 40px;
    padding-bottom: 60px;
    }

    #productsDmTop #featuresInner .features04 .featuresTtl {
      margin-bottom: 20px;
      margin-left: 0;
      }
  
      #productsDmTop #featuresInner .features04 .featuresTtlNum {
        top: 0;
        transform: translateY(0);
        }

    #productsDmTop #featuresInner .features04-01 {
      padding: 0 15px;
      /* top: calc(100vw * ((-270 - 40) / 640) * 0.65); */
      top: calc(100vw * ((-270 - 40 - 120) / 640) * 0.65);
      }

      #productsDmTop #featuresInner .features04-01Inner > dt { display: block; }

    #productsDmTop #featuresInner .features04-02 {}

      #productsDmTop #featuresInner .features04-02 .featuresDlist {
        height: auto;
        padding-top: 20px;
        padding-bottom: 20px;
        padding-right: 15px;
        }
      #productsDmTop #featuresInner .features04-02 .featuresDlistReverse { padding-left: 15px; }

        #productsDmTop #featuresInner .features04-02 .featuresDlist::before { right: -5px; }
        #productsDmTop #featuresInner .features04-02 .featuresDlist.featuresDlistReverse::before { left: -5px; }
  
        #productsDmTop #featuresInner .features04-02 .featuresDlist > dt {
          top: auto;
          bottom: 20px;
          transform: translateY(0);
          }
  
        #productsDmTop #featuresInner .features04-02 .featuresDlist > dd { text-align: center !important; }

      #productsDmTop #featuresInner .features04-02-01 { margin-bottom: 10px; }

        #productsDmTop #featuresInner .features04-02-01 > dl { align-items: flex-start; }

          #productsDmTop #featuresInner .features04-02-01 > dl > dt { width: 100px; }

          #productsDmTop #featuresInner .features04-02-01 > dl > dd { padding-left: 10px; }

      #productsDmTop #featuresInner .features04-02-02 { margin-bottom: 30px; }

        #productsDmTop #featuresInner .features04-02-02 .featuresDlist { align-items: flex-start; }

          #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dt { right: 10px; }
  
            #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dt > span { float: right; }

            #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dt img {
              max-width: calc(100vw * (1490 / 640) * 0.55);
              width: calc(100vw * (1490 / 640) * 0.55);
              }

            #productsDmTop #featuresInner .features04-02-02 .featuresDlist .featuresSubTtl02 > span.p-caption {
              margin-top: 5px;
              font-size: 1.0rem;
              }
  
          #productsDmTop #featuresInner .features04-02-02 .featuresDlist > dd { padding-bottom: calc(100vw * (225 / 640)); }

      #productsDmTop #featuresInner .features04-02-03 { margin-bottom: 30px; }

        #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dt {
          height: calc(100vw * (240 / 640));
          left: 15px;
          bottom: 0;
          }
  
          #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dt > span {
            margin-left: calc(100vw * (-40 / 640));
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            }
  
        #productsDmTop #featuresInner .features04-02-03 .featuresDlist > dd { padding-bottom: calc(100vw * (230 / 640)); }

      #productsDmTop #featuresInner .features04-02-04 {
        margin-bottom: 20px;
        text-align: center;
        }

        #productsDmTop #featuresInner .features04-02-04 .featuresSubTtl02 { margin-bottom: 10px; }

        #productsDmTop #featuresInner .features04-02-04 .featuresTxt01 { margin: 0 0 20px 0; }

        #productsDmTop #featuresInner .features04-02-04 .featuresSlider { margin: 0 30px; }
  
          #productsDmTop #featuresInner .features04-02-04 .featuresSlider .slick-arrow { margin-top: -65px; }

          #productsDmTop #featuresInner .features04-02-04 .featuresSlider .slick-dots { bottom: 100px; }

            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dt,
            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dt > span { display: block; }

            #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd { margin-top: 40px; }

              #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) { padding: 8px 15px; }

                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span { display: block; }
                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span:nth-of-type(1) { font-size: 1.4rem; }
                #productsDmTop #featuresInner .features04-02-04 .featuresSliderInner > dd > p:nth-of-type(1) > span:nth-of-type(2) {
                  margin-left: 0;
                  margin-top: 5px;
                  font-size: 1.2rem;
                  }

      #productsDmTop #featuresInner .features04-02-05 { margin-bottom: 30px; }

        #productsDmTop #featuresInner .features04-02-05 .featuresSlider { position: relative; }

          #productsDmTop #featuresInner .features04-02-05 .slick-list { overflow: visible !important; }

          #productsDmTop #featuresInner .features04-02-05 .slick-dots {
            margin-left: -20px;
            position: absolute;
            top: 120px;
            right: auto;
            left: 50%;
            transform: translateX(-50%);
            }

            #productsDmTop #featuresInner .features04-02-05 .slick-dots > li > button {
              width: 40px;
              height: 40px;
              }

              #productsDmTop #featuresInner .features04-02-05 .featuresDlist > dt {
                margin-top: 5px;
                width: 100%;
                padding-top: 20px;
                position: static;
                }

                #productsDmTop #featuresInner .features04-02-05 .featuresDlist > dt img { width: 100%; }
  
              #productsDmTop #featuresInner .features04-02-05 .featuresDlist > dd { padding-bottom: 50px; }

      #productsDmTop #featuresInner .features04-02-06 { margin-bottom: 30px; }

        #productsDmTop #featuresInner .features04-02-06 > dl { text-align: center; }

          #productsDmTop #featuresInner .features04-02-06 > dl > dt { margin: 20px 0 0 0; }

          #productsDmTop #featuresInner .features04-02-06 > dl > dd {
            width: 100%;
            position: static;
            }

            #productsDmTop #featuresInner .features04-02-06 > dl > dd .featuresSubTtl03 { margin-bottom: 10px; }

      #productsDmTop #featuresInner .features04-02-07 { margin-bottom: 30px; }

        #productsDmTop #featuresInner .features04-02-07 > dl > dt > span.p-caution { margin-top: 5px;  }

        #productsDmTop #featuresInner .features04-02-07 > dl > dd { margin-bottom: 15px; }

      #productsDmTop #featuresInner .features04-02-08 {}

        #productsDmTop #featuresInner .features04-02-08 .featuresSubTtl03 { margin-bottom: 10px; }
  
          #productsDmTop #featuresInner .features04-02-08 .featuresSlider { margin: 0 30px; }

          #productsDmTop #featuresInner .features04-02-08 .slick-arrow { margin-top: -25px; }
          #productsDmTop #featuresInner .features04-02-08 .slick-prev { left: calc(-58px * 0.6); }
          #productsDmTop #featuresInner .features04-02-08 .slick-next { right: calc(-58px * 0.6); }

          #productsDmTop #featuresInner .features04-02-08 .slick-dots {
            margin-top: 15px;
            padding: 4px 0;
            border-radius: 6px;
            }

            #productsDmTop #featuresInner .features04-02-08 .slick-dots::before {
              width: 100%;
              font-size: 13px;
              margin-top: -30px;
              top: 50%;
              left: 50%;
              transform: translate(-50%, -50%);
              }

              #productsDmTop #featuresInner .features04-02-08 .slick-dots > li > button {
                width: 40px;
                height: 20px;
                border-radius: 3px;
                }

                #productsDmTop #featuresInner .features04-02-08 .slick-dots > li > button:before {
                  width: 40px;
                  height: 20px;
                  font-size: 13px;
                  }
  
      #productsDmTop #featuresInner .features04-02-09 { margin: 0 0 40px 0; }

        #productsDmTop #featuresInner .features04-02-09 .featuresSubTtl02 { margin-bottom: 10px; }

        #productsDmTop #featuresInner .features04-02-09 .featuresTxt01 { margin-bottom: 20px; }
  

  #productsDmTop #featuresInner .features05 {
    background-size: 130% auto;
    padding-top: calc(100vw * (630 / 640) * 0.5);
    padding-bottom: 120px;
    }

    #productsDmTop #featuresInner .features05 .featuresTtl {
      margin-bottom: 30px;
      margin-left: 0;
      }
  
      #productsDmTop #featuresInner .features05 .featuresTtlNum {
        top: 0;
        transform: translateY(0);
        }

      #productsDmTop #featuresInner .features05 .featuresTtl span.p-caption {
        margin-top: 15px;
        font-size: 1.0rem;
        }

    #productsDmTop #featuresInner .features05-01 {}

      #productsDmTop #featuresInner .features05-01Inner {
        display: block;
        margin: 0;
        }

        #productsDmTop #featuresInner .features05-01Inner > dt { width: 100%; }

          #productsDmTop #featuresInner .features05-01Inner > dt .p-caption {
            margin-top: 10px;
            font-size: 1.2rem;
            }

        #productsDmTop #featuresInner .features05-01Inner > dd {
          width: 100%;
          padding-left: 0;
          padding-top: 20px;
          }

          #productsDmTop #featuresInner .features05-01Inner > dd > ul {
            margin-left: 0;
            margin-top: -15px;
            }

            #productsDmTop #featuresInner .features05-01Inner > dd > ul > li {
              width: 100%;
              padding-left: 0;
              padding-top: 15px;
              }

  #productsDmTop #featuresInner .features06 {
    padding-top: 80px;
    padding-bottom: 120px;
    z-index: 1;
    }

    #productsDmTop #featuresInner .features06 .featuresTtl { margin-bottom: 30px; }

    #productsDmTop #featuresInner .features06-01 { top: calc(100vw * ((-270 - 230) / 640) * 0.55); }

        #productsDmTop #featuresInner .features06-01Inner > dt img { width: calc(100vw * (254 / 640) * 0.7); }

      #productsDmTop #featuresInner .features06-01Inner > dd {
        margin-top: 0;
        margin-left: calc(100vw * (-460 / 640) * 0.7);
        }

    #productsDmTop #featuresInner .features06-02 {}

      #productsDmTop #featuresInner .features06-02Inner {}

        #productsDmTop #featuresInner .features06-02Inner > dt { margin-top: 15px; }

        #productsDmTop #featuresInner .features06-02Inner > dd {}

          #productsDmTop #featuresInner .features06-02Inner > dd > ul {
            margin-top: -5px;
            margin-left: -5px;
            }

            #productsDmTop #featuresInner .features06-02Inner > dd > ul > li {
              padding-top: 5px;
              padding-left: 5px;
              }

  #productsDmTop #featuresInner .features07 {
    padding-top: 100px;
    padding-bottom: 60px;
    }

    #productsDmTop #featuresInner .features07 .featuresTtl {}

    #productsDmTop #featuresInner .features07-01 { top: calc(100vw * ((-270 - 260) / 640) * 0.6); }

        #productsDmTop #featuresInner .features07-01Inner > dt img { width: calc(100vw * (709 / 640) * 0.6); }

      #productsDmTop #featuresInner .features07-01Inner > dd {
        margin-top: 5px;
        padding-right: 15px;
        }

    #productsDmTop #featuresInner .features07-02 { margin-bottom: 35px; }

      #productsDmTop #featuresInner .features07-02Inner > dt { margin-bottom: 20px; }

        #productsDmTop #featuresInner .features07-02Inner > dt > span:nth-of-type(1) { margin-bottom: 30px; }

          #productsDmTop #featuresInner .features07-02Inner > dt > span:nth-of-type(1) img { width: calc(178px * 0.6); }

      #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) {}
  
        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) > ul { margin-left: -10px; }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(1) > ul > li {
            width: 50%;
            padding-left: 10px;
            }

      #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) { margin-top: 25px; }

        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > li > a { min-width: 100%; }
  
            #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > li > a > span:nth-of-type(1) { font-size: 1.5rem; }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > .p-btnType04 > * > span::before {
            width: calc(28px * 0.6);
            height: calc(28px * 0.6);
            }

          #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > ul > .p-btnType04 > * > span::after {
            width: calc(11px * 0.6);
            height: calc(13px * 0.6);
            left: calc(10px * 0.6);
            }

        #productsDmTop #featuresInner .features07-02Inner > dd:nth-of-type(2) > p {
          margin-top: 10px;
          font-size: 1.2rem;
          }

    #productsDmTop #featuresInner .features07-03 { margin-bottom: 35px; }

      #productsDmTop #featuresInner .features07-03Inner > li { margin-top: 30px; }

      #productsDmTop #featuresInner .features07-03Inner .featuresLogo01 { margin-top: 20px; }

        #productsDmTop #featuresInner .features07-03-01 .featuresLogo01 img { width: calc(176px * 0.6); }

        #productsDmTop #featuresInner .features07-03-02 .featuresLogo01 img { width: calc(200px * 0.6); }

        #productsDmTop #featuresInner .features07-03-02 .p-caption { margin-top: 10px; }

    #productsDmTop #featuresInner .features07-04 {}

      #productsDmTop #featuresInner .features07-04Inner > dt { margin-bottom: 20px; }

      #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) {
        display: block;
        margin-bottom: 20px;
        }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresSubTtl02,
        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresTxt01 { display: block; }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresSubTtl02 { margin-bottom: 20px; }

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(1) .featuresTxt01 { padding-left: 0; }

      #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) {}

        #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table { margin-bottom: 40px; }

          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table th,
          #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td {
            padding: 5px;
            font-size: 1.1rem;
            }
  
            #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td > div { display: block; }
  
              #productsDmTop #featuresInner .features07-04Inner > dd:nth-of-type(2) table td > div > div { width: 100% !important; }
  
  
  
/**
 * Floating
 * -------------------------------
 */
  
#productsDmTop #m-floating > ul {
  display: flex;
  align-items: stretch;
  margin-top: 0;
  }

  #productsDmTop #m-floating > ul > li {
    display: inline-block;
    width: 50%;
    margin-top: 0;
    border-left: 1px solid #000;
    }
  
  #productsDmTop #m-floating > ul > li:nth-of-type(1) { border-left: none; }
  
    #productsDmTop #m-floating > ul > li > a { height: 100px; }


/* -- .dm-m-floatingYoutube -- */
#productsDmTop .dm-m-floatingYoutube {
  background-image: none;
  background-color: #ed0038;
  }

  #productsDmTop .dm-m-floatingYoutube > a { height: auto; }
  
    #productsDmTop .dm-m-floatingYoutube > a > span { padding: 0; }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) {
        background-color: #1a1a1a;
        height: 50px;
        padding: 8px 5px;
        color: #fff;
        font-size: 11px;
        }
  
        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong {
          margin-top: 3px;
          font-size: 13px;
          }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > .c-ffRobotoCond { font-size: 20px; }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > span:nth-of-type(2) { font-size: 10px; }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(1) > strong > span:nth-of-type(3) {
            font-size: 15px;
            font-weight: 900;
            }

      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) {
        display: flex;
        justify-content: center;
        height: 50px;
        padding: 8px 30px 8px 5px;
        text-align: center;
        }
  
        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span {
          font-size: 14px;
          line-height: 1.3;
          }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span:after {
            width: calc(20px * 0.8);
            height: calc(20px * 0.8);
            position: relative;
            top: 3px;
            right: -5px;
            }

          #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(3) > span > span {
            display: inline;
            font-size: 11px;
            font-weight: 700;
            }
  
      #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(4) {
        width: calc(47px * 0.6);
        height: calc(66px * 0.6);
        right: 3px;
        bottom: 0;
        }
  
        #productsDmTop .dm-m-floatingYoutube > a > span > span:nth-of-type(4) img {
          width: auto;
          height: 100%;
          position: absolute;
          bottom: 0;
          right: 0;
          }
 



 
  
/**
 * ================================================================================
 * Other Settings
 * ================================================================================
 */



}