/*
Name: 商品詳細テンプレートVersion6（item_detail$v6.xhtml）
Created date: 2025-07-16
*/
/* item detail - 商品詳細
-------------------------------------------------------------*/
#item_feature-wrap.v6 {
  text-align: left;
  font-size: 16px;
}
#item_feature-wrap.v6 p {
  font-size: 16px;
}
.item_feature-wrap.v6 .container {
  max-width: 1000px;
  margin: 0 auto;
}
.klaara_bgw .contents-wrap .heading-2 span {
  background: #fff;
}
.container h2,
.section h2 {
  font-size: 30px;
  color: #3C4453;
  text-align: center;
  line-height: 1.1538461538461537;
  letter-spacing: 0.1em;
  width: fit-content;
  margin: 0 auto;
  border-bottom: 2px solid #87a28e;
  padding-bottom: 22px;
  font-weight: bold;
}
/* PC only */
@media screen and (min-width: 1001px) {
  .pcHide {
    display: none;
  }
  .item_feature-wrap.v6 .item_feature-inner.klaara_bg_none {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  .spHide {
    display: none;
  }
  .container h2,
  .section h2 {
    font-size: 26px;
    padding-bottom: 12px;
  }
  #container.item_list-container,
  #container.item_detail-container,
  #container.option_list-container,
  #container.top-container {
    max-width: 100%;
  }
  h1.product_name, #item_detail {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }
  #item_feature-wrap.v6 p {
    font-size: 14px;
  }
  .item_feature-wrap.v6 {
    overflow-x: hidden;
  }
  .item_feature-wrap.v6 .container {
    padding-left: 20px;
    padding-right: 20px;
    width: calc(100% - 40px);
    width: 100%;
    margin: 0;
  }
  .function-list-container {
    margin-bottom: 70px;
  }
  .function-point-container {
    padding: 30px 0;
    margin-right: -20px;
    overflow: hidden;
  }
  .item_feature-inner.klaara_bgw,
  .item_feature-inner.klaara_bg_none {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
/* item detail - 製品情報
-------------------------------------------------------------*/
#item_detail {
  font-size: 16px;
}
#item_detail .item_info1-txt {
  font-size: 18px;
  font-weight: normal;
  letter-spacing: .02em;
  line-height: 1.76;
  margin-bottom: 22px;
}
#item_detail .attention-description {
  font-size: 14px;
  color: #518a70;
  line-height: 1.5;
  margin-top: 12px;
  margin-bottom: 30px;
}
#item_detail .attention-description .title {
  font-size: 18px;
  color: #518a70;
  line-height: 1.5;
  margin-top: 12px;
  margin-bottom: 12px;
}
#item_detail .attention-description li::before {
  content: "";
  background: url(../images/detail/wifi-green.png) no-repeat center center;
  width: 19px;
  height: 16px;
  background-size: contain;
  display: inline-block;
  margin-right: 16px;
}
#item_detail .checks-list {
  border-top: 1px solid #e4e5e7;
  border-bottom: 1px solid #E4E5E7;
  padding: 30px 0;
  margin: 0 0;
}
#item_detail .checks-list h2 {
  color: #447355;
  font-size: 20px;
  margin-bottom: 18px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
#item_detail .checks-list li {
  font-size: 18px;
  letter-spacing: 0.1em;
}
#item_detail .checks-list li::before {
  content: "";
  background: url(../images/detail/icon-check.png) no-repeat center center;
  width: 19px;
  height: 16px;
  background-size: contain;
  display: inline-block;
  margin-right: 16px;
}
#item_detail .item_purchase-box {
  margin: 30px auto 0;
  max-width: 640px;
  width: 100%;
  gap: 20px;
}
#item_detail .purchase_btn-box {
  width: 100%;
  justify-content: center;
}
#item_detail .item_purchase_btn-buy-wrap {
  width: 100%;
  max-width: 420px;
}
#item_detail .item_purchase_btn-buy-wrap .not-yoyaku .item_purchase_btn-buy {
  padding-left: 10px;
}
#item_detail .purchase_btn-box:not(.rental) .item_purchase_btn-buy-wrap>div>div::before,
#item_detail .item_purchase_btn-buy-wrap .not-yoyaku::before {
  left: 30px;
}
#item_detail .purchase_btn-box.rental .item_purchase_btn-buy-wrap::after {
  border-color: #457456;
}
#item_detail .purchase_btn-box {
  flex-basis: 1;
}
#item_detail .item_purchase_btn-buy.secondary {
  padding: 19px 0;
  border: 1px solid #457456;
  background: #fff;
  color: #457456;
}
/* PC only */
@media screen and (min-width: 1001px) {}
/* Mobile only */
@media screen and (max-width: 1000px) {
  #item_detail .item_info1-txt {
    font-size: 16px;
  }
  #item_detail .attention-description .title {
    font-size: 16px;
  }
  #item_detail .attention-description {
    font-size: 12px;
    margin-bottom: 25px;
  }
  #item_detail .checks-list {
    padding: 25px 0;
  }
  #item_detail .checks-list h2 {
    font-size: 18px;
  }
  #item_detail .checks-list li {
    font-size: 16px;
  }
  #item_detail .item_action-box {
    display: flex;
    flex-direction: column-reverse;
    margin-bottom: 40px;
  }
  .mod_item_spec-table {
    border-top: 1px solid #ccc9cb;
  }
}
/* feature - 特徴
-------------------------------------------------------------*/
#feature {
  padding: 50px 0 60px;
  font-size: 16px;
}
#item_feature-wrap .feature-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 60px;
}
#item_feature-wrap .feature-list li {
  font-weight: 500;
  text-align: center;
  color: #6A768C;
  line-height: 1.2;
}
#item_feature-wrap .feature-list li p {
  text-align: center;
}
#item_feature-wrap .feature-list li img {
  width: auto;
  height: auto;
}
/* PC only */
@media screen and (min-width: 1001px) {
  #item_feature-wrap .feature-list li {
    width: 25%;
  }
  #item_feature-wrap .feature-list li img {
    margin-bottom: 9px;
    /* max-width: 100px; */
    max-height: 80px;
  }
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  #item_feature-wrap .feature-list {
    gap: 30px 0;
    margin-top: 40px;
  }
  #item_feature-wrap .feature-list li {
    width: 33.8%;
    width: 50%;
    font-size: 14px;
    padding: 0 9px;
    box-sizing: border-box;
  }
  #item_feature-wrap .feature-list li img {
    width: auto;
    height: 60px;
    margin-bottom: 15px;
  }
  .contents_movie {
    width: 90%;
  }
}


/* --------------------------------- */
/* #movie */

#movie .mov-list-inr{
  position: relative;
  width: 100%;
  height: max-content;
  aspect-ratio: 560 / 315;
}

.conv-movie-inr{
  width: 100%;
  height: 100%;
}

.conv-movie-inr img{
  max-width: 100%;
}

#movie .conv-movie-inr iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.conv-movie{
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin:auto;
  background: #000;
  opacity: 0;
}

.is_active .conv-movie{
  opacity: 1;
}

.mov-list-item-img.delete_btn{
  opacity: 0;
  pointer-events: none;
}

.mov-list-item-img{
  position: absolute;
  display: block;
  width: 100%;
  top: 0;
}

.mov-list-item-img img{
  width: 100%;
}

/* item detail - 製品紹介カルーセル
-------------------------------------------------------------*/
#function .bx-controls-direction a,
#function .slick-arrow {
  width: 46px;
  height: 46px;
  background-size: contain;
  display: block;
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}
#function .bx-next,
#function .slick-next {
  background: url('../images/detail/icon-next03@2x.png') no-repeat top left;
  background-size: contain;
  right: 20px;
}
#function .bx-prev,
#function .slick-prev {
  background: url('../images/detail/icon-prev03@2x.png') no-repeat top left;
  background-size: contain;
  left: 20px;
  z-index: 1;
}
#function {
  position: relative;
  background: #EAF2E6;
  font-size: 16px;
}
#function h2 {
  margin-bottom: 50px;
}
#function .more-box {
  height: 0;
  opacity: 0;
  transition: .3s ease-in-out;
  transform: translateY(-30px);
  pointer-events: none;
}
#function .more-box.is-open {
  height: 100%;
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
.function-list {
  position: relative;
}
.function-list>li {
  margin-bottom: 30px;
  padding-left: 1.3em;
}
.function-list>li::before {
  content: '●';
  font-size: 0.5em;
  position: absolute;
  left: 0;
  transform: translate(0.6em, 0.6em);
}
.function-list h3 {
  font-weight: bold;
  display: inline-block;
  font-size: 16px;
  margin-bottom: 5px;
}
.function-list-container {
  margin-bottom: 100px;
}
.function-list-container .more a {
  color: #447355;
  position: relative;
}
.function-list-container .more a::after {
  content: "";
  width: 12px;
  height: 6px;
  background: #447355;
  mask-image: url(../images/detail/index_arw_05.png);
  mask-size: 100%;
  mask-repeat: no-repeat;
  display: inline-block;
  margin-left: 10px;
}
#function .function-point-head {
  position: relative;
  color: #447355;
  font-size: 20px;
}
#function .function-point-head::before {
  content: "";
  width: 100%;
  height: 6px;
  background: #447355;
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
#function .function-point-head span {
  background: #eaf2e6;
  padding: 0 30px;
  position: relative;
  margin-left: 50px;
  font-weight: bold;
  font-size: 28px;
}
.function-point-container {
  padding: 60px 0;
}
.function-point-slider .flex {
  display: flex;
}
#function .number {
  font-size: 17px;
  color: #518a70;
  font-weight: bold;
  background: #DCE9D5;
  display: inline-block;
  border-radius: 3em;
  width: 34px;
  height: 34px;
  text-align: center;
}
.function-point-slider .flex .text-box .slide-num {
  display: block;
  margin-bottom: 30px;
}
.function-point-slider .flex .text-box h4 {
  font-size: 22px;
  margin: 30px 0;
  line-height: 1.3636;
  font-weight: bold;
}
#function .image img {
  width: 100%;
}
#function .text-box {
  letter-spacing: 0.1em;
  line-height: 1.7143;
}
/* PC only */
@media screen and (min-width: 1001px) {
  #function {
    padding-bottom: 40px;
  }
  #function h2 {
    font-size: 40px;
    margin-bottom: 50px;
  }
  .function-point-slider .flex {
    flex-direction: row-reverse;
    align-items: center;
    gap: 0 60px;
  }
  .function-point-slider .flex .image {
    width: 50%;
  }
  .function-point-slider .flex .image img {
    width: 100%;
  }
  .function-point-slider .flex .text-box {
    max-width: 350px;
  }
  .function-point-slider .flex .text-box h4 {
    font-size: 28px;
    margin: 30px 0;
    letter-spacing: 0.02em;
  }
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  .function-point-container .bx-wrapper {
    overflow: hidden;
  }
  .function-point-container .slick-list {
    width: 97.1% !important;
    overflow: visible !important;
  }
  .function-point-slider .slick-slide {
    margin-right: 10px;
  }
  #function {
    width: 100%;
  }
  #function h2 {
    margin-bottom: 40px;
  }
  #function .container {
    text-align: left;
    width: 100%;
  }
  #function .function-point-head {
    text-align: center;
    font-size: 24px;
    line-height: 1.3333;
  }
  #function .function-point-head span {
    display: inline-block;
    margin-left: 0;
  }
  .function-point-slider .flex {
    flex-direction: column;
  }
  #function .text-box {
    margin-top: 13px;
    padding: 0 10px;
  }
  .function-point-slider .flex .text-box h4 {
    margin: 20px 0;
  }
  #function .bx-controls-direction a,
  #function .slick-arrow {
    top: 25%;
  }
  .function-point-container {
    padding: 40px 0;
  }
}
/* -------------------------------------------- */
/* attention-list */
.attention-list {
  font-size: 12px;
  line-height: 1.5;
  text-align: left;
  margin-top: 5px;
}
.attention-list li {
  padding-left: 3em;
  margin-top: 4px;
  position: relative;
  letter-spacing: 0.1em;
  /* display: flex; */
}
.attention-list span {
  display: inline-block;
  min-width: 2em;
  margin-left: -2em;
}
.attention-list a {
  text-decoration: underline;
  color: #447355;
  display: contents;
}
/* PC only */
@media screen and (min-width: 1001px) {
  .attention-list li {
    margin-top: 6px;
  }
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  .function-list>li {
    margin-bottom: 20px;
  }
  .attention-list li {
    padding-left: 2em;
  }
  .attention-list span {
    min-width: 2em;
    margin-left: -2em;
  }
}
/* faq - よくある質問
-------------------------------------------------------------*/
#faq_renewal h3.faq_title {
  position: relative;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #447355;
}
#faq_renewal h3.faq_title:not(:first-of-type) {
  margin-top: 20px;
}
#faq_renewal h3.faq_title .pict {
  height: 38px;
  margin-right: 15px;
}
#faq_renewal h3.faq_title .pict img {
  height: 100%;
}
#faq_renewal h3.faq_title .text {
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.06em;
}
#faq_renewal .faq_title .icon {
  position: absolute;
  top: 22px;
  right: 23px;
  width: 15px;
  height: 15px;
  display: inline-block;
}
#faq_renewal .faq_title .icon::before,
#faq_renewal .faq_title .icon::after {
  content: '';
  position: absolute;
  top: 6px;
  right: 0;
  width: 15px;
  height: 3px;
  background-color: #fff;
  transition: all 0.3s;
}
#faq_renewal .faq_title .icon::after {
  transform: rotate(90deg);
}
#faq_renewal .faq_header {
  position: relative;
  color: #447355;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
  text-align: left;
  padding: 17px 20px 17px 45px;
  border: 3px solid #DCE9D3;
  border-top: none;
  transition: all 0.3s;
  cursor: pointer;
  background: #fff;
}
#faq_renewal .faq_header::before {
  content: "Q:";
  position: absolute;
  top: 17px;
  left: 15px;
}
#faq_renewal .faq_title+.faq_header {
  border-top: 3px solid #DCE9D3;
}
#faq_renewal .faq_header .icon {
  position: absolute;
  top: 18px;
  right: 20px;
  width: 15px;
  height: 15px;
  display: inline-block;
}
#faq_renewal .faq_header .icon::before,
#faq_renewal .faq_header .icon::after {
  content: '';
  position: absolute;
  top: 6px;
  right: 0;
  width: 15px;
  height: 3px;
  background-color: #447355;
  transition: all 0.3s;
}
#faq_renewal .faq_header .icon::after {
  transform: rotate(90deg);
}
#faq_renewal .faq_inner {
  max-height: 0;
  padding: 0 20px;
  border: 3px solid #DCE9D3;
  border-top: none;
  border-bottom-width: 0;
  transition: max-height 0.3s, padding 0.3s, border-bottom-width 0.3s;
  overflow: hidden;
  background: #fff;
}
#faq_renewal .faq_inner .answer_wrap {
  position: relative;
  padding-left: 25px;
}
#faq_renewal .faq_inner .answer_wrap::before {
  content: "A:";
  position: absolute;
  top: 0;
  left: -5px;
  font-size: 16px;
}
#faq_renewal .faq_inner p {
  font-size: 14px;
  line-height: 1.75;
  letter-spacing: 0.08em;
}
#faq_renewal .faq_inner p>a {
  color: #447355;
  text-decoration: underline;
}
#faq_renewal .faq_inner p>span.weight_bold {
  font-weight: 700;
}
#faq_renewal .faq_inner p>span.text_red {
  color: red;
}
#faq_renewal .faq_inner_title {
  display: flex;
  align-items: center;
  padding-bottom: 8px;
  margin: 25px auto 10px;
  border-bottom: 1px solid #447355;
}
#faq_renewal .faq_inner_title .number {
  color: #fff;
  font-size: 18px;
  line-height: 1;
  padding: 3px 6px;
  margin-right: 10px;
  background-color: #447355;
}
#faq_renewal .faq_inner_title .text {
  color: #447355;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.08em;
}
/* accordion */
#faq_renewal .js-faq-trigger {
  cursor: pointer;
}
#faq_renewal .faq_header.js-faq-trigger.open {
  background-color: #DCE9D3;
}
#faq_renewal .faq_title.js-faq-trigger.open .icon::after,
#faq_renewal .faq_header.js-faq-trigger.open .icon::after {
  transform: rotate(180deg);
}
#faq_renewal .faq_inner.js-faq-target.open {
  max-height: none;
  padding: 16px 20px 20px;
  border-bottom-width: 3px;
}
#faq_renewal .faq_wrapper.js-faq-target.open {
  max-height: none;
  border-top: 3px solid #DCE9D3;
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  #faq_renewal {
    padding: 40px 20px;
    padding: 0;
  }
  #faq_renewal .dropdown {
    border-bottom: 26px solid #447355;
  }
  #faq_renewal h3.faq_title {
    height: 64px;
  }
  #faq_renewal h3.faq_title:not(:first-of-type) {
    margin-top: 10px;
  }
  #faq_renewal h3.faq_title .pict {
    height: 40px;
  }
  #faq_renewal .faq_title .icon {
    top: 25px;
    right: 17px;
  }
  #faq_renewal .faq_header {
    padding: 17px 35px 17px 45px;
    border: none;
    border-left: 5px solid #447355;
    border-right: 5px solid #447355;
  }
  #faq_renewal .faq_header:not(:first-of-type) {
    border-top: 2px solid #447355;
  }
  #faq_renewal .faq_header .icon {
    top: 18px;
    right: 12px;
  }
  #faq_renewal .faq_inner {
    padding: 0 22px;
    border: none;
    border-left: 5px solid #447355;
    border-right: 5px solid #447355;
  }
  #faq_renewal .faq_inner p {
    margin-top: 0;
  }
  #faq_renewal .faq_inner_title {
    margin: 35px auto 10px;
  }
  #faq_renewal .faq_inner.js-faq-target.open {
    padding: 20px 22px 25px;
  }
  #faq_renewal .faq_wrapper.js-faq-target.open {
    border-bottom-width: 35px !important;
  }
}
/* --------------------------------- */
/* #benefits */
#benefits {
  position: relative;
}
#benefits h2 {
  margin-top: 120px;
  margin-bottom: 60px;
  font-size: 30px;
  border-bottom: 0;
}
.benefits-list-wrapper .bx-wrapper {
  margin-left: 20px;
  overflow: hidden;
}
.benefits-list-wrapper .bx-viewport {
  overflow: visible !important;
  width: 59.1% !important;
  margin-right: auto;
}
/* .benefits-list */
.benefits-list {
  display: flex;
}
.benefits-list li {
  text-align: center;
  max-width: 240px;
  font-size: 14px;
  color: #518a70;
  padding: 20px 8px 9px;
  display: block;
  background: #D8EAD2;
}
.benefits-list li .image {
  max-width: 140px;
  height: 84px;
  margin: 0 auto;
}
.benefits-list li .image img {
  width: 100%;
}
.benefits-list li a {
  display: block;
  color: #447355;
}
.benefits-list .label {
  font-size: 24px;
  margin-top: 17px;
  line-height: 1.25;
  font-weight: 600;
  color: #447355;
}
.benefits-list .lead {
  line-height: 1.4286;
  margin-top: 6px;
  color: #447355;
}
.benefits-list .link {
  color: #6cb86a;
  text-decoration: underline;
  position: relative;
  vertical-align: middle;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 3px;
}
.benefits-list .link::after {
  content: "";
  width: 8px;
  height: 16px;
  display: inline-block;
  margin-left: 8px;
  mask-image: url(../images/detail/index_arw_06.png);
  mask-repeat: no-repeat;
  mask-position: center center;
  mask-size: 7px auto;
  background: #6cb86a;
}
/* PC only */
@media screen and (min-width: 1001px) {
  .benefits-list-wrapper {
    margin-bottom: 80px;
  }
  .benefits-list {
    display: flex;
    justify-content: center;
    gap: 13px;
  }
  .benefits-list .image img {
    width: 100%;
  }
  .benefits-list li {
    width: 24%;
    max-width: 240px;
    font-size: 14px;
    padding: 15px 16px 20px 16px;
  }
  .benefits-list .label strong {
    font-size: 24px;
  }
}
/* Mobile only */
@media screen and (max-width: 1000px) {
  #benefits h2 {
    font-size: 20px;
    margin-bottom: 30px;
    line-height: 1.5;
  }
  .benefits-list-wrapper .bx-viewport {
    width: 67.6% !important;
  }
  .benefits-list {
    flex-wrap: wrap;
    gap: 2px;
  }
  .benefits-list li {
    width: calc((100% - 2px) / 2);
  }
}

ol.notes-list.asterisk > li::before {
  content: "＊" counter(li) "：";
}
.button_wrap .button {
  display: block;
  width: 300px;
  padding: 20px;
  border-radius: 29px;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
  background: #457456;
  color: rgb(255, 255, 255);
  margin: 30px auto 0;
}
.button_wrap .button:hover {
  opacity: .8;
}

/* 吹き出し */
.purchase_btn-buy-wrap,
.purchase_btn-box:not(.rental) {
  position: relative;
}
.purchase_btn-buy-wrap .fukidashi,
.purchase_btn-box:not(.rental) .fukidashi {
  background: #EBC172;
  border-radius: 5em;
  color: #000;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1.2;
  padding: 8px 18px;
  display: inline-block;
  width: fit-content;
  margin: 0 auto;
  margin-bottom: -11px;
  position: absolute;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  width: 163px;
  text-align: center;
  z-index: 10;
}

.purchase_btn-box:not(.rental) .fukidashi::after{
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 9px solid transparent;
  border-left: 9px solid transparent;
  border-top: 10px solid #EBC172;
  border-bottom: 0;
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform:translate(-50%,0);
}
.purchase_btn-box .purchase_btn-buy-wrap .fukidashi {
  width: 114px;
  font-size: 10px;
  padding: 6px 10px;
  top: calc(100% + -2px);
}
.purchase_btn-box .purchase_btn-buy-wrap .fukidashi::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 9px solid transparent;
  border-left: 9px solid transparent;
  border-bottom: 10px solid #EBC172; /* ← 上矢印にする */
  border-top: 0;
  position: absolute;
  top: -6px; /* 下から上に変更 */
  left: 50%;
  transform: translate(-50%, 0);
}
.purchase_btn-buy {
  transition: all 0.6s ease;
}
.purchase_btn-buy:hover {
  opacity: 0.6;
}