@charset "utf-8";

/* ======================================================
 * index.css
 * ------------------------------------------------------
 * Common
 * @media print, screen and (min-width: 768px)
 * - Override
 * - Page Component
 * - Clearfix
 * PC Media Queries
 * @media only screen and (max-width: 767px)
 * - Override
 * - Page Component
 * - Clearfix
 * SP Media Queries
 * Print
====================================================== */
  /* ------------------------------------------------------
   * Common
  ------------------------------------------------------ */
/* ----- font ----- */
/* Noto Sans */
.box-layout-v5.type-npcst > .box_title,
.npcst-hero-layout .hero_item_text *,
.npcst-hero-layout .hero_item-v2_text *,
.npcst-hero-layout .hero_item-v3_text *,
.npcst-index-box .box_title,
.npcst-explanation-column .column_title {
  font-family: "Noto Sans", "Noto Sans CJK JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

/* ======================================================
 * PC
====================================================== */
@media print, screen and (min-width: 768px) {
  /* ------------------------------------------------------
   * Override
  ------------------------------------------------------ */
  /* ----- box-layout ----- */
  /* type-npcst */
  .box-layout-v5.type-npcst {
    margin-top: 80px;
  }
  .box-layout-v5.type-npcst > .box_title {
    border-bottom: 2px solid #ddd;
  }
  .box-layout-v5.type-npcst > .box_title::before {
    top: .75em;
  }

  .npcst-index-box .npcst-index-lead--center + .youtube-layout {
    margin-top: 8px;
  }

  /* ------------------------------------------------------
   * Page Component
  ------------------------------------------------------ */
  /* ----- tab-layout ----- */
  .npcst-tab-layout > .tab_navi > .tab_list {
    font-family: "Noto Sans", "Noto Sans CJK JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    color: #333;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a {
    color: #3381d0;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a:hover {
    color: #fff;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a:hover {
    color: #3381d0;
    text-decoration: underline;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    -webkit-transition: all .2s ease-out 0s;
    transition: all .2s ease-out 0s;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_label::before {
    -webkit-transition: border-color .2s ease-out 0s;
    transition: border-color .2s ease-out 0s;
  }
  .npcst-tab-layout {
    margin-top: 2.5em;
  }
  .npcst-tab-layout > .tab_navi {
    margin: 0 0 2em;
    padding: 0 5px;
    border-bottom: 2px solid #418fde;
  }
  .npcst-tab-layout.has-bottom > .tab_navi ~ .tab_navi {
    margin: 2em 0 0;
    border-top: 2px solid #418fde;
    border-bottom: none;
  }
  .npcst-tab-layout > .tab_navi > .tab_list {
    display: flex;
    gap: 10px;
    flex-flow: row wrap;
    margin-bottom: 10px;
    padding: 0 5px;
    width: 100%;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link {
    display: block;
    width: 100%;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li {
    position: relative;
    display: flex;
    width: calc((100% - (10px * 2)) / 3 - .1px);
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    position: relative;
    display: flex;
    flex: 1 1;
    gap: 10px;
    align-items: center;
    flex-flow: nowrap;;
    padding: 2px;
    background-color: #f2f2f2;
    font-size: 2.4rem;
    line-height: 1.5;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a {
    display: inline;
    background: none;
    font-size: 1.6rem;
    line-height: 1.75;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body {
    width: 100%;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body > .tab_new-icon {
    position: absolute;
    color: #fff;
    font-style: normal;
    font-size: clamp(7.5px, 0.8333vw, 10px);
    font-weight: bold;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    top: 0;
    right: 0;
    padding: 8px 6px 0 0;
    z-index: 1;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body > .tab_new-icon::after {
    position: absolute;
    top: 0;
    right: 0;
    margin: 2px 2px 0 0;
    width: clamp(39px, 3.916vw, 47px);
    aspect-ratio: 1;
    clip-path: polygon(0 0,100% 0,100% 100%);
    background: #e90f0f;
    content: '';
    z-index: -1;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_image {
    width: min(6.5vw, 90px);
    flex-shrink: 0;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_image > img {
    width: 100%;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body > .tab_text {
    width: 100%;
    padding: 12px 22px 12px 5px;
    font-size: 2.2rem;
    font-weight: bold;
    line-height: 1.5;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    text-align: center;
  }
  .npcst-tab-layout.type-news > .tab_navi > .tab_list > li > a {
    padding-right: 8px;
    padding-left: 8px;
    font-size: 2.0rem;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a:hover {
    background-color: #418fde;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li.is-current > a {
    background-color: #418fde;
    color: #fff;
    font-weight: 700;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a:hover {
    background: none;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link.is-current > a {
    background: none;
    color: #3381d0;
    font-weight: normal;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_label {
    display: inline-block;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_label .is-smaller {
    font-size: 85%;
    font-weight: normal;
  }
  .npcst-tab-layout > .tab_detail > *:first-child,
  .npcst-tab-layout > .tab_detail > section:first-child > [class*="heading-lv"] {
    margin-top: 0 !important;
  }


  /* ----- heading-ec-button ----- */
  .ec-heading {
    position: relative;
    padding-right: 100px;
  }
  .heading-ec-button {
    position: absolute;
    display: inline-block;
    width: 88px;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .ec-button_link {
    display: inline-block;
    padding: 5px 24px 7px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde!important;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .ec-button_link:hover {
    background-color: #daebfc;
  }

  /* ----- npcst-index-lead--center ----- */
  .npcst-index-lead--center {
    margin: 1em 0 0;
    text-align:center;
    color: #2e5164;
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 1.4;
  }

  /* ----- npcst-hero-layout ----- */
  .npcst-hero-layout {
    position: relative;
  }
  .npcst-hero-layout + * {
    margin-top: 50px!important;
  }
  .npcst-hero-layout .hero_image {
    position: relative;
  }
  .npcst-hero-layout .npcst-hero-new-icon {
    position: absolute;
    padding: min(0.416vw, 5px) min(0.75vw, 8px) min(0.25vw, 3px);
    top: 10.6%;
    left: 0;
    background-color: #e90f0f;
    color: #fff;
    font-style: normal;
    font-size: min(1.833vw, 2.2rem);
    font-weight: bold;
    line-height: 1.0;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item {
    position: absolute;
    top: 54%;
    left: 0;
    width: 100%;
  }
  .npcst-hero-layout .hero_item_image {
    position: relative;
    width: 193px;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item_text {
    position: absolute;
    bottom: 21.8%;
    left: 100px;
    padding: 0 30px 10px 110px;
    border-bottom: 2px solid #2e5164;
    z-index: 1;
  }
  .npcst-hero-layout .hero_item_text_title {
    color: #2e5164;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.3;
  }
  .npcst-hero-layout .hero_item_text_sub {
    font-weight: bold;
    line-height: 1.75;
  }
  .npcst-hero-layout .hero_item_release {
    position: absolute;
    top: 85%;
    left: 210px;
  }
  .npcst_main_detail_text {
    position: absolute;
    top:38%;
    left: 15%;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .npcst_main_detail_text-font {
    letter-spacing: 0.8px;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  /* ----- npcst-index-layout-v1 ----- */
  .npcst-index-layout-v1 {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    margin-top: 50px;
    padding: 0 53px 0 40px;
  }
  .npcst-index-layout-v1 + * {
    margin-top: 86px!important;
  }
  .npcst-index-layout-v1 .layout-v1_text {
    position: relative;
    width: 560px;
    margin-right: 32px;
    padding: 30px 2px 24px;
    border: 2px solid #2e5164;
    color: #2e5164;
    font-size: 3.6rem;
    line-height: 1.3;
    text-align: center;
    z-index: 1;
  }
  .npcst-index-layout-v1 .layout-v1_text::before,
  .npcst-index-layout-v1 .layout-v1_text::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: -40px;
    border-style: solid;
    border-width: 18px 20px;
    border-color: transparent transparent transparent #2e5164;
    transform: translateY(-50%);
  }
  .npcst-index-layout-v1 .layout-v1_text::after {
    right: -37px;
    border-color: transparent transparent transparent #fff;
  }
  .npcst-index-layout-v1 .layout-v1_image {
    width: 515px;
  }

  /* ----- npcst-index-box ----- */
  .npcst-index-box {
    margin-top: 40px;
    border-bottom: 2px solid #ddd;
  }
  .npcst-index-box + .npcst-index-box {
    margin-top: -2px;
  }
  .npcst-index-box .box_title {
    display: block;
    padding: 7px;
    background: #2e5164;
    color: #fff;
    font-size: 3.4rem;
    font-weight: bold;
    text-align: center;
  }
  .npcst-index-box .box_title_sub {
    font-size: 2.0rem;
    font-weight: normal;
    vertical-align: 4px;
  }
  .npcst-index-box .box_detail {
    padding: 40px 30px;
    border: solid #ddd;
    border-width: 0 2px;
  }
  .npcst-index-box .box_detail > :first-child {
    margin-top: 0!important;
  }
  .npcst-index-box .box_text {
    margin: 1.0em 0 0;
    color: #333;
    font-size: 1.6rem;
    font-weight: normal;
    line-height: 1.6;
  }

  /* ----- npcst-explanation-column ----- */
  .npcst-explanation-column {
    display: -webkit-flex;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 40px;
  }
  .npcst-explanation-column[data-column-img="right"] {
    flex-direction: row;
  }
  .npcst-explanation-column[data-column-img="left"] {
    flex-direction: row-reverse;
  }
  .npcst-explanation-column > * {
    width: calc((100% - 40px)/2);
  }
  .npcst-explanation-column .column_title {
    padding-bottom: 10px;
    border-bottom: 2px solid #2e5164;
    color: #2e5164;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
  }
  .npcst-explanation-column .column_title + * {
    margin-top: 20px!important;
  }
  .npcst-explanation-column .column_detail {
    margin-top: 10px;
  }

  /* ----- npcst-explanation-column ----- */
  .npcst-index-column-flow {
    position: relative;
    display: flex;
    flex-flow: row nowrap;
    gap: 108px
  }
  .npcst-index-column-flow__item {
    position: relative;
    width: 50%;
  }
  .npcst-index-column-flow__item:first-of-type::after {
    position: absolute;
    top: calc(50% - 15px);
    right: calc(-54px - 25px);
    width:0;
    height:0;
    border-style:solid;
    border-width: 30px 0 30px 50px;
    border-color: transparent transparent transparent #2e5164;
    content: "";
  }

  /* ------------------------------------------------------
   * tab02
  ------------------------------------------------------ */
  .npcst-hero-layout .hero_item_text_right {
    padding-right: 68px;
    bottom: 22.8%;
  }
  .hero_item_text_title_shadow {
    text-shadow: 0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff;
  }
  .hero_item_note {
    position: absolute;
    top: 82%;
    left: 210px;
  }
  .hero_item_note_text {
    position: relative;
    padding-left: 15px;
    font-size: 1.6rem;
    line-height: 1.5;
    color: #333;
  }
  .hero_item_note_left {
    position: absolute;
    top: 0;
    left: 0;
  }
  .npcst-nps-content_title {
    padding-bottom: 2px;
    border-bottom: 2px solid #2e5164;
    color: #2e5164;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
  }
  .npcst-nps-content_detail {
    margin-top: 14px;
  }
  .npcst-nps_column {
    margin-top: 1.2em;
  }
  .column_text-nps_center {
    align-items: stretch;
  }
  .column_text-nps {
    padding-top: 13px;
  }
  .column_text-nps:nth-child(n+2) {
    padding-top: 25px;
  }
  .column_text-nps .column_title {
    font-weight: 800;
  }
  .column_text-nps .column_detail {
    line-height: 1.5;
  }
  .column_text-nps .hero_item_note_text {
    margin-top: 10px;
    font-size: 1.4rem
  }
  .column_image-nps {
    padding: 2% 0 0 5%;
  }
  .nps-box_inner {
    padding-bottom: 15px;
  }
  .nps-box_title {
    display: block;
    margin: 27px 2px 0 0;
    padding: 9px 3px 9px 0px;
    background: #2e5164;
    color: #fff;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
    border-radius: 9px;
  }
  .nps-box_image {
    margin: 40px 0 0 4%;
    text-align: center;
  }

  /* ------------------------------------------------------
   * tab03,tab04,tab05,tab06,
  ------------------------------------------------------ */
  .npcst-hero-layout .hero_item-v2 {
    position: absolute;
    top: 54%;
    left: 0;
    width: 100%;
  }
  .npcst-hero-layout .hero_item-v2_image {
    position: relative;
    width: 193px;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item-v2_text {
    position: absolute;
    bottom: 22.8%;
    left: 100px;
    padding: 0 68px 10px 110px;
    border-bottom: 2px solid #2e5164;
    text-shadow: 0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff,0px 3px 13px #fff;
    z-index: 1;
  }
  .npcst-hero-layout .hero_item-v2_text_title {
    color: #2e5164;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.3;
  }
  .npcst-hero-layout .hero_item-v2_text_sub {
    font-weight: bold;
    line-height: 1.75;
  }
  .npcst-hero-layout .hero_item-v2_release {
    position: absolute;
    top: 82%;
    left: 210px;
  }
  .npcst-hero-layout .hero_item-v3 {
    position: absolute;
    top: 54%;
    left: 0;
    width: 100%;
  }
  .npcst-hero-layout .hero_item-v3_image {
    position: relative;
    width: 193px;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item-v3_text {
    position: absolute;
    bottom: 22.8%;
    left: 100px;
    padding: 0 68px 10px 110px;
    border-bottom: 2px solid #2e5164;
    z-index: 1;
  }
  .npcst-hero-layout .hero_item-v3_text_title {
    padding: 3px 10px 3px 0;
    background-color: #fff;
    color: #2e5164;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.2;
  }
  .npcst-hero-layout .hero_item-v3_text_sub {
    margin-top: -2px;
    font-weight: bold;
    line-height: 1.75;
  }
  .npcst-hero-layout .hero_item-v3_release {
    position: absolute;
    top: 82%;
    left: 210px;
  }
  .nps-column {
    display: flex;
    flex-wrap: wrap;
    margin-top: 2.0em;
  }
  .nps-column > .nps-column_item {
    width: calc((100% - (40px * 2)) / 3 - .1px);
  }
  .nps-column > .nps-column_item:not(:nth-child(3n+1)) {
    margin-left: 40px;
  }
  .nps-column > .nps-column_item > *:first-child {
    margin-top: 0 !important;
  }
  .nps-column-v2 {
    display: flex;
    flex-wrap: wrap;
    margin-top: 2.0em;
  }
  .nps-column-v2 > .nps-column-v2_item {
    width: calc((100% - (40px * 1)) / 2 - .1px);
  }
  .nps-column-v2 > .nps-column-v2_item:not(:nth-child(3n+1)) {
    margin-left: 40px;
  }
  .nps-column-v2 > .nps-column-v2_item > *:first-child {
    margin-top: 0 !important;
  }
  .nps-figure {
    display: flex;
    justify-content: center;
    margin-top: 2.4em;
  }
  .nps-figure .nps-figure__inner {
    margin: 0;
    text-align: center;
  }
  .nps-figure .nps-figure__title {
    margin: 0 0 0.4em;
    color: #2e5164;
    font-size: 2.0rem;
    font-weight: bold;
    line-height: 1.4;
  }
  .nps-figure .nps-figure__frame {
    display: inline-block;
  }
  .nps-figure .nps-figure__frame > img {
    max-width: 100%;
  }
  .nps-figure .nps-figure__caption,
  .nps-figure .nps-figure__caption--center {
    margin: 1.4em 0 0;
    color: #333;
    font-size: 1.6rem;
    line-height: 1.6;
  }
  .nps-figure .nps-figure__caption {
    text-align: left;
  }
  .nps-figure .nps-figure__caption--center {
    text-align: center;
  }

    /* ------------------------------------------------------
   * 2カラム画像
  ------------------------------------------------------ */
  .nps-img-column {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
  }
  .nps-img-column_item {
    margin: 40px 0 0 34px;
  }
  /* ------------------------------------------------------
   * 仕様一覧購入ボタン
  ------------------------------------------------------ */
  .table-ec {
    display: flex;
    align-items: center;
  }
  .table-ec-button {
    margin-left: 10px;
    max-width: 250px;
    min-width: 88px;
    vertical-align: top;
  }
  .table-ec-button_link {
    display: inline-block;
    padding: 5px 25px 7px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 6px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.6rem;
    line-height: 1;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .table-ec-button_link:hover {
    opacity: 1;
    background-color: #daebfc;
  }
  /* -------- * ご使用上の注意---------- */
  .nps-caution-colmn {
    display: -webkit-flex;
    display: flex;
  }
  .nps-caution-colmn {
    margin: 18px 32px 0;
    padding-bottom: 24px;
    border-bottom: 1px solid #ddd;
  }
  .nps-caution-colmn-item {
    width: 358px;
  }
  .nps-caution-colmn-item:first-child {
  }
  .nps-caution-colmn-item:nth-child(n+2){
    margin-left: 29px;
  }
  .nps-caution-colmn-img{
    border: 1px solid #ddd;
  }
  .nps-caution-colmn-text {
    position: relative;
    padding-left: 15px;
    margin-top: 15px;
    font-size: 1.4rem;
    letter-spacing: 0.5px;
  }
  .nps-caution-colmn-text-note {
    position: absolute;
    top: 0;
    left: 0;
  }
  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .clearfix::after {
    display: block;
    clear: both;
    content: "";
  }
}

/* ======================================================
 * PC Media Queries
====================================================== */
@media screen and (min-width: 1921px) {
}
@media screen and (min-width: 768px) and (max-width: 1920px) {
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .npcst-hero-layout + * {
    margin-top: 3.9vw;
  }
  .npcst-hero-layout .hero_item_image {
    width: 15vw;
  }
  .npcst-hero-layout .hero_item-v2_image,
  .npcst-hero-layout .hero_item-v3_image {
    width: 15vw;
  }
  .npcst-hero-layout .hero_item_text {
    left: 7.8vw;
    padding: 0 2.3vw 0.7vw 8.6vw;
  }
  .npcst-hero-layout .hero_item_text_title {
    font-size: 1.875vw;
  }
  .npcst-hero-layout .hero_item_text_sub {
    font-size: 1.25vw;
  }
  .npcst-hero-layout .hero_item_release {
    left: 16.4vw;
    font-size: 1.25vw;
  }
  .npcst-hero-layout .hero_item-v2_text,
  .npcst-hero-layout .hero_item-v3_text {
    left: 7.8vw;
    padding: 0 2.3vw 0.7vw 8.6vw;
  }
  .npcst-hero-layout .hero_item-v2_text_title,
  .npcst-hero-layout .hero_item-v3_text_title {
    font-size: 1.875vw;
  }
  .npcst-hero-layout .hero_item-v2_text_sub,
  .npcst-hero-layout .hero_item-v3_text_sub {
    font-size: 1.25vw;
  }
  .npcst-hero-layout .hero_item-v2_release,
  .npcst-hero-layout .hero_item-v3_release {
    left: 16.4vw;
    font-size: 1.25vw;
  }

  .npcst-index-layout-v1 {
    padding: 0 4.1vw 0 3.125vw;
  }
  .npcst-index-layout-v1 .layout-v1_text {
    width: 43.75vw;
    margin-right: 2.5vw;
    padding: 2.3vw 2px 1.875vw;
    font-size: 2.8125vw;
  }
  .npcst-index-layout-v1 .layout-v1_text::before,
  .npcst-index-layout-v1 .layout-v1_text::after {
    right: -3.125vw;
    border-width: 1.4vw 1.5625vw;
    z-index: 2;
  }
  .npcst-index-layout-v1 .layout-v1_text::after {
    right: -2.89vw;
  }
  .npcst-index-layout-v1 .layout-v1_image {
    width: 40vw;
  }

  .npcst-index-box .box_title {
    font-size: 2.65625vw;
  }
  .npcst-index-box .box_title_sub {
    font-size: 1.5625vw;
    vertical-align: 0.3125vw;
  }
  .npcst-index-box .box_detail {
    padding: 3.125vw 2.34375vw;
  }

  .npcst-explanation-column > * {
    width: calc((100% - 3.125vw)/2);
  }
  .npcst-explanation-column .column_title {
    font-size: 1.875vw;
  }
  .npcst-explanation-column .column_detail {
    margin-top: 10px;
  }
  .hero_item_note {
    left: 16.4vw;
  }
  .hero_item_note_text {
    font-size: 1.25vw;
  }
  .nps-image_inner {
    width: 38vw;
  }
  .nps-caution-colmn-img_inner {
    width: 24vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1279px) {
}
@media screen and (min-width: 768px) and (max-width: 1190px) {
}
@media screen and (min-width: 768px) and (max-width: 1080px) {
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
}
@media screen and (min-width: 768px) and (max-width: 960px) {
}
@media screen and (min-width: 768px) and (max-width: 840px) {
}


/* ======================================================
 * SP
====================================================== */
@media only screen and (max-width: 767px) {
  /* ------------------------------------------------------
   * Override
  ------------------------------------------------------ */
  /* ----- box-layout ----- */
  /* type-npcst */
  .box-layout-v5.type-npcst {
    margin-top: 40px;
  }
  .box-layout-v5.type-npcst > .box_title::before {
    top: .75em;
  }

  .npcst-index-box .npcst-index-lead--center + .youtube-layout {
    margin-top: 6.4px;
  }

  /* ------------------------------------------------------
   * Page Component
  ------------------------------------------------------ */
  /* ----- tab-layout ----- */
  .npcst-tab-layout > .tab_navi > .tab_list {
    font-family: "Noto Sans", "Noto Sans CJK JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    color: #333;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    -webkit-transition: background-color .2s ease-out 0s;
    transition: background-color .2s ease-out 0s;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a {
    color: #3381d0;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a {
    -webkit-transition: background-color .2s ease-out 0s;
    transition: background-color .2s ease-out 0s;
  }
  .npcst-tab-layout {
    width: 100vw;
    margin: 2em 0 0 calc(50% - 50vw);
  }
  .npcst-tab-layout > .tab_navi {
    padding: 0 13px;
    border-bottom: 2px solid #418fde;
  }
  .npcst-tab-layout.has-bottom > .tab_navi ~ .tab_navi {
    margin: 1.5em 0 0;
    border-top: 2px solid #418fde;
    border-bottom: none;
  }
  .npcst-tab-layout > .tab_navi > .tab_list {
    display: flex;
    gap: 10px;
    margin-bottom: 10px;
    width: 100%;
    flex-flow: row wrap;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li {
    position: relative;
    display: flex;
    width: calc((100% - (10px * 1)) / 2 - .1px);
    padding: 0 2px;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link {
    display: block;
    width: 100%;
    padding: 0 2px 0 0;
  }
  .npcst-tab-layout > .tab_navi > .tab_list[data-layout-sp="scroll"] {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row nowrap;
    flex-flow: row nowrap;
    width: auto;
    margin: 0 -13px;
    overflow-x: auto;
  }
  .npcst-tab-layout > .tab_navi > .tab_list[data-layout-sp="scroll"] > li {
    display: block;
    -webkit-flex: 0 0 150px;
    flex: 0 0 150px;
  }
  .npcst-tab-layout > .tab_navi > .tab_list[data-layout-sp="scroll"] > li:first-child {
    padding-left: 15px;
    -webkit-flex-basis: 163px;
    flex-basis: 163px;
  }
  .npcst-tab-layout > .tab_navi > .tab_list[data-layout-sp="scroll"] > li:last-child {
    padding-right: 15px;
    -webkit-flex-basis: 163px;
    flex-basis: 163px;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a {
    position: relative;
    display: flex;
    flex: 1 1;
    gap: 5px;
    align-items: center;
    flex-flow: nowrap;
    padding: 2px;
    background-color: #f2f2f2;
    font-size: 1.3rem;
    line-height: 1.25;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link > a {
    display: inline;
    padding: 2px;
    background: none;
    font-size: 1.4rem;
    line-height: 1.5;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li.is-current > a {
    background-color: #418fde;
    color: #fff;
    font-weight: 700;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > .npcst-index-tab-list-link.is-current > a {
    background: none;
    color: #3381d0;
    font-weight: normal;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body > .tab_new-icon {
    display: inline-block;
    color: #fff;
    font-style: normal;
    font-size: 10px;
    font-weight: bold;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Noto Sans", "Noto Sans CJK JP", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    line-height: 1.0;
    margin-bottom: 3px;
    padding: 2px 5px;
    background-color: #e90f0f;
    vertical-align: top;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_image {
    width: min(12vw, 45px);
    flex-shrink: 0;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_image > img {
    width: 100%;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_list_body > .tab_text {
    width: 100%;
    font-size: 2.666vw;
    font-weight: bold;
    line-height: 1.4;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    text-align: left;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_label {
    display: inline-block;
  }
  .npcst-tab-layout > .tab_navi > .tab_list > li > a > .tab_label .is-smaller {
    font-size: 87.5%;
    font-weight: normal;
  }
  .npcst-tab-layout.type-news > .tab_navi {
    overflow-x: auto;
  }
  .npcst-tab-layout.type-news > .tab_navi > .tab_list {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row nowrap;
    flex-flow: row nowrap;
  }
  .npcst-tab-layout.type-news > .tab_navi > .tab_list > li {
    display: block;
    -webkit-flex: 0 0 129px;
    flex: 0 0 129px;
  }
  .npcst-tab-layout.type-news > .tab_navi > .tab_list > li:last-child {
    -webkit-flex-basis: 142px;
    flex-basis: 142px;
    padding-right: 15px;
  }
  .npcst-tab-layout.type-news > .tab_navi > .tab_list > li > a {
    padding-right: 8px;
    padding-left: 8px;
    font-size: 1.4rem;
  }
  .npcst-tab-layout > .tab_detail {
    margin-top: 1.5em;
    padding: 0 15px;
  }
  .npcst-tab-layout > .tab_detail > *:first-child {
    margin-top: 0 !important;
  }

  /* ----- npcst-index-lead--center ----- */
  .npcst-index-lead--center {
    margin: 1em 0 0;
    text-align:center;
    color: #2e5164;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.5;
  }

  /* ----- npcst-hero-layout ----- */
  .npcst-hero-layout {
  }
  .npcst-hero-layout + * {
    margin-top: 50px!important;
  }
  .npcst-hero-layout .hero_image {
    position: relative;
    width: calc(100% + 30px);
    margin: 0 -15px;
  }
  .npcst-hero-layout .npcst-hero-new-icon {
    position: absolute;
    margin-left: 4.0vw;
    padding: 5px 7px 3px;
    top: 52.0vw;
    left: 0;
    background-color: #e90f0f;
    color: #fff;
    font-style: normal;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.0;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item {
    position: relative;
    width: 100%;
    margin-top: 20px;
  }
  .npcst-hero-layout .hero_item_image {
    position: relative;
    width: 32.5vw;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item_text {
    position: absolute;
    bottom: 21.8%;
    left: 16.3vw;
    width: calc(100% - 16.3vw);
    padding: 0 1.5vw 2vw 19.2vw;
    border-bottom: 1.5px solid #2e5164;
    z-index: 1;
  }
  .npcst-hero-layout .hero_item_text_title {
    color: #2e5164;
    font-size: 3.73vw;
    font-weight: bold;
    line-height: 1.3;
  }
  .npcst-hero-layout .hero_item_text_sub {
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 1.75;
  }
  .npcst-hero-layout .hero_item_release {
    position: absolute;
    top: 85%;
    left: 35.5vw;
    font-size: 2.7vw;
  }

  /* ----- npcst-index-layout-v1 ----- */
  .npcst-index-layout-v1 {
    margin-top: 50px;
  }
  .npcst-index-layout-v1 + * {
    margin-top: 30px!important;
  }
  .npcst-index-layout-v1 .layout-v1_text {
    position: relative;
    width: 100%;
    margin-bottom: 25px;
    padding: 18px 2px 14px;
    border: 2px solid #2e5164;
    color: #2e5164;
    font-size: 2.2rem;
    line-height: 1.3;
    text-align: center;
    z-index: 1;
  }
  .npcst-index-layout-v1 .layout-v1_text::before,
  .npcst-index-layout-v1 .layout-v1_text::after {
    content: "";
    display: block;
    position: absolute;
    left: 50%;
    bottom: -35px;
    border-style: solid;
    border-width: 17px 15px;
    border-color: #2e5164 transparent transparent transparent;
    transform: translateX(-50%);
  }
  .npcst-index-layout-v1 .layout-v1_text::after {
    bottom: -32px;
    border-color: #fff transparent transparent transparent;
  }
  .npcst-index-layout-v1 .layout-v1_image {
    width: 100%;
    text-align: center;
  }

  /* ----- npcst-index-box ----- */
  .npcst-index-box {
    margin-top: 30px;
    border-bottom: 1px solid #ddd;
  }
  .npcst-index-box + .npcst-index-box {
    margin-top: -1px;
  }
  .npcst-index-box .box_title {
    display: block;
    padding: 10px;
    background: #2e5164;
    color: #fff;
    font-size: 2.3rem;
    font-weight: bold;
    text-align: center;
  }
  .npcst-index-box .box_title_sub {
    display: block;
    margin-top: 5px;
    font-size: 1.3rem;
    font-weight: normal;
  }
  .npcst-index-box .box_detail {
    padding: 30px 15px;
    border: solid #ddd;
    border-width: 0 1px;
  }
  .npcst-index-box .box_detail > :first-child {
    margin-top: 0!important;
  }
  .npcst-index-box .box_text {
    margin: 1.0em 0 0;
    color: #333;
    font-size: 1.4rem;
    font-weight: normal;
    line-height: 1.5;
  }

  /* ----- npcst-explanation-column ----- */
  .npcst-explanation-column {
    margin-top: 30px;
  }
  .npcst-explanation-column > :first-child {
    margin-top: 0!important;
  }
  .npcst-explanation-column .column_text,
  .npcst-explanation-column .column_image {
    margin-top: 20px;
  }
  .npcst-explanation-column .column_title {
    padding-bottom: 10px;
    border-bottom: 2px solid #2e5164;
    color: #2e5164;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.5;
  }
  .npcst-explanation-column .column_title + * {
    margin-top: 20px!important;
  }
  .npcst-explanation-column .column_detail {
    margin-top: 10px;
  }

  /* ----- npcst-explanation-column ----- */
  .npcst-index-column-flow {
    position: relative;
    display: flex;
    flex-flow: column nowrap;
    gap: 60px;
  }
  .npcst-index-column-flow__item {
    position: relative;
  }
  .npcst-index-column-flow__item:first-of-type::after {
    position: absolute;
    bottom: -55px;
    right: calc(50% - 20px);
    width:0;
    height:0;
    border-style:solid;
    border-width: 30px 20px 0 20px;
    border-color: #2e5164 transparent transparent transparent ;
    content: "";
  }

  /* ------------------------------------------------------
   * tab02
  ------------------------------------------------------ */
  /* ----- hero ----- */
  .nps-hero-layout {
    margin-bottom: 86px;
  }

  .hero_item_note {
    position: absolute;
    top: 88%;
    left: 35.5vw;
    font-size: 2.7vw;
  }
  .hero_item_note_text {
    position: relative;
    padding-left: 1.2em;
    font-size: 1.2rem;
    color: #555;
  }
  .hero_item_note_left {
    position: absolute;
    top: 0;
    left: 0;
  }
  .ec-heading {
    position: relative;
    padding-right: 80px;
  }
  .heading-ec-button {
    position: absolute;
    display: inline-block;
    width: 70px;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
  }
  .ec-button_link {
    display: inline-block;
    padding: 2px 19px;
    background-color: #fff;
    border: 2px solid #418fde;
    border-radius: 5px;
    color: #418fde!important;
    font-weight: bold;
    font-size: 1.4rem;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  .hero_item_text_right .hero_item_text_title_shadow {
    letter-spacing: 1.2px;
    line-height: 1.5;
  }
  .hero_item .hero_item_text_right {
    bottom: 17.8%
  }
  .npcst_main_detail_text {
    margin: 5px 0 0 4%;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.5;
  }

  /* ------------------------------------------------------
   * tab03,tab04,tab05,tab06
  ------------------------------------------------------ */
  .npcst-hero-layout .hero_item-v2,
  .npcst-hero-layout .hero_item-v3 {
    position: relative;
    width: 100%;
    margin-top: 28px;
  }
  .npcst-hero-layout .hero_item-v2_image,
  .npcst-hero-layout .hero_item-v3_image {
    position: relative;
    width: 32.5vw;
    z-index: 2;
  }
  .npcst-hero-layout .hero_item-v2_text,
  .npcst-hero-layout .hero_item-v3_text {
    position: absolute;
    bottom: 22.0%;
    left: 16.3vw;
    width: calc(100% - 16.3vw);
    padding: 0 1.5vw 2vw 19.2vw;
    border-bottom: 1.5px solid #2e5164;
    z-index: 1;
  }
  .npcst-hero-layout .hero_item-v2_text_title,
  .npcst-hero-layout .hero_item-v3_text_title {
    color: #2e5164;
    font-size: 3.73vw;
    font-weight: bold;
    letter-spacing: 1.2px;
    line-height: 1.5;
  }
  .npcst-hero-layout .hero_item-v2_text_sub,
  .npcst-hero-layout .hero_item-v3_text_sub {
    font-size: 2.7vw;
    font-weight: bold;
    line-height: 1.75;
  }
  .npcst-hero-layout .hero_item-v2_release,
  .npcst-hero-layout .hero_item-v3_release {
    position: absolute;
    top: 83%;
    left: 35.5vw;
    font-size: 2.7vw;
  }

  /* ----- hero ----- */
  .nps-hero-layout-v2 {
    margin-bottom: 15px;
  }

  .nps-column {
    display: block;
    margin-top: 2.0em;
  }
  .nps-column > .nps-column_item {
    width: 100%;
  }
  .nps-column > .nps-column_item:nth-child(n+2) {
    margin-top: 1.5em;
  }
  .nps-column > .nps-column_item > *:first-child {
    margin-top: 0 !important;
  }
  .nps-column-v2 {
    display: block;
    margin-top: 2.0em;
  }
  .nps-column-v2 > .nps-column-v2_item {
    width: 100%;
  }
  .nps-column-v2 > .nps-column-v2_item:nth-child(n+2) {
    margin-top: 1.5em;
  }
  .nps-column-v2 > .nps-column-v2_item > *:first-child {
    margin-top: 0 !important;
  }
  .nps-figure {
    display: flex;
    justify-content: center;
    margin-top: 1.0em;
  }
  .nps-figure .nps-figure__inner {
    margin: 0;
    text-align: center;
  }
  .nps-figure .nps-figure__title {
    margin: 0 0 0.4em;
    color: #2e5164;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.5;
  }
  .nps-figure .nps-figure__frame {
    display: inline-block;
  }
  .nps-figure .nps-figure__frame > img {
    max-width: 100%;
  }
  .nps-figure .nps-figure__caption,
  .nps-figure .nps-figure__caption--center {
    margin: 1.1em 0 0;
    color: #333;
    font-size: 1.4rem;
    line-height: 1.5;
  }
  .nps-figure .nps-figure__caption {
    text-align: left;
  }
  .nps-figure .nps-figure__caption--center {
    text-align: center;
  }

  /* ----- 2段階角度調整 ----- */
  .npcst-nps-content_title {
    padding-bottom: 10px;
    border-bottom: 2px solid #2e5164;
    color: #2e5164;
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.5;
  }
  .npcst-nps-content_detail {
    padding-top: 14px;
  }
  .npcst-nps_column {
     margin-top: 1.2em;
  }
  .column_text-nps .column_title {
    padding-bottom: 7px;
  }
  .column_text-nps:nth-child(n+2) {
    margin-top: 29px;
  }
  .column_text-nps .hero_item_note_text {
    margin-top: 6px;
    padding-left: 1em;
  }
  .column_image-nps {
    padding: 11px 32px 0;
  }
  .nps-box_title {
    display: block;
    margin: 41px 9px 0 7px;
    padding: 6px 3px 6px 0px;
    background: #2e5164;
    color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    border-radius: 8px;
  }
  .nps-box_image {
    padding: 23px 25px 0;
  }
  .nps-box_inner {
    padding-bottom: 11px;
  }
  .nps-image-set {
    margin-top: 20px;
  }
    /* ---- * 仕様一覧購入ボタン--------- */
  .table-ec {
    display: flex;
    align-items: center;
    flex-flow: row wrap;
  }
  .table-ec-button {
    display: inline-block;
    max-width: 120px;
    min-width: 65px;
    margin-top: 5px;
    margin-left: 10px;
    padding: 0;
    vertical-align: middle;
  }
  .table-ec-button_link {
    display: inline-block;
    border: 2px solid #418fde;
    border-radius: 5px;
    background-color: #fff;
    padding: 3px 15px;
    color: #418fde;
    font-weight: bold;
    font-size: 1.4rem;
    font-family: "Noto Sans CJK JP", "Noto Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }
  /* -------- * ご使用上の注意---------- */
  .nps-caution-colmn {
    margin: 16px 14px 6px;
    border-bottom: 1px solid #ddd;
  }
  .nps-caution-colmn-img_inner {
    border: 1px solid #ddd;
  }
  .nps-caution-colmn-item {
    margin-bottom: 14px;
  }
  .nps-caution-colmn-text {
    position: relative;
    padding-left: 15px;
    margin-top: 12px;
    font-size: 1.1rem;
    letter-spacing: 0.5px;
  }
  .nps-caution-colmn-text-note {
    position: absolute;
    top: 0;
    left: 0;
  }

  /* ------------------------------------------------------
   * Clearfix
  ------------------------------------------------------ */
  .clearfix::after {
    display: block;
    clear: both;
    content: "";
  }
}


/* ======================================================
 * SP Media Queries
====================================================== */
/* **
@media only screen and (min-width: 320px) and (max-width: 767px) {
}
@media only screen and (max-width: 736px) {
}
@media only screen and (max-width: 667px) {
}
@media only screen and (max-width: 640px) {
}
@media only screen and (max-width: 568px) {
}
@media only screen and (max-width: 480px) {
}
@media only screen and (max-width: 375px) {
}
@media only screen and (max-width: 360px) {
}
@media only screen and (max-width: 320px) {
}
** */

/* ======================================================
 * Print
====================================================== */
@media print {
}