/*探してみる*/
/*.category_subhead{
  padding-top: 15px;
  padding-bottom: 15px;
  padding-right: 20px;
  padding-left: 20px;
  background: #f2f2f2;
  border-left: solid 5px #9d0000;
  margin-bottom: 2rem;
  border-bottom: none;
}*/
.category_subhead{
  padding: 20px 15px;
  font-size: 2.5rem;
  text-align: center;
  position: relative;
  padding: 15px 15px;
  outline: 2px solid #333;
  color: #fff;
  background: #2f4fb6;
  font-weight: bold;
  border-bottom: none !important;
  line-height: 1.4;
}
.contents_calendar{
    display: flex;
    align-items: center;
}
.category-contents_flexbox{
    font-size: 1.3rem;
}
.category-contents_flexbox span{
    font-size: 1.6rem;
    font-weight: bold;
}
.category-contents__item{
    position: relative;
}
.category-contents__item:after{
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 7px;
    height: 7px;
    transform: rotate(45deg) translate(0, -50%);
    border-bottom: 2px solid #ccc;
    border-right: 2px solid #ccc;
}
/*5つのポイント*/
.calendar_point{
    text-align: center;
    margin-bottom: 20px;
}
/*卓上カレンダーから選ぶ*/
.title_sub{
    /*padding-bottom: 7px;
    border-bottom: solid 3px #2f4fb6;
    font-size: 2rem;
    margin-bottom: 2rem;*/
    margin: 20px 0 25px;
    font-size: 22px;
    background: #efefef;
    padding: 10px;
    border-left: 7px solid #2589d0;
}
@media screen and (max-width: 767px) {
.title_sub{
 font-size: 20px;
}
}
#top_takujo,#top_kabekake,#top_size,#top_small-lot,#top_large-lot,#contents_takujo_01,#contents_takujo_02{
    margin-top: -100px;
    padding-top: 100px;
}
.category-contents_takujo .col-2{
    width: calc((100% - 15px) / 2);
}
.contents_takujo_text:after{
    content: "";
    position: absolute;
    width: 7px;
    height: 7px;
    transform: rotate(45deg) translate(0, -50%);
    border-bottom: 2px solid #000;
    border-right: 2px solid #000;
}
.contents_takujo a:hover{
    opacity: 0.6;
}
.category-contents_takujo{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
    margin: 4rem auto 5rem;
}
.contents_takujo a{
    display: flex;
    width: 100%;
    justify-content: center;
    position: relative;
    border: 2px solid #000;
    border-radius: 5px;
    font-weight: bold;
}
.contents_takujo_text{
    color: #000;
    text-align: center;
}
.contents_takujo_text span{
    color: #2f4fb6;
}
.category_explanation{
  margin-bottom: 2rem;
}
@media screen and (min-width: 998px) {
  .category-contents_flexbox{
    margin-left: 1.5rem;
}
  .contents_calendar{
      padding: 1rem 3rem;
  }
    .contents_takujo_text{
      font-size: 1.6rem;
  }
  .contents_takujo_text span{
    font-size: 2.5rem;
  }
  .contents_takujo_text:after{
    top: 50%;
    right: 20px;
}
}
@media screen and (max-width: 997px) {
  .category-contents_flexbox{
    margin-left: 3.5rem;
}
  .contents_calendar{
      padding: 0.5rem 1rem 2rem;
  }
  .contents_takujo_text{
      font-size: 1.3rem;
  }
  .contents_takujo_text span{
    font-size: 1.6rem;
  }
    .contents_takujo_text:after {
      bottom: 5%;
      right: 50%;
  }
}


/* ボタン(〜探す) */
.button_content_sct{
    margin: 50px 0;
}

.button_content_sct h2{
    position: relative;
    padding: .5em .7em .4em;
    border-bottom: 3px solid #2589d0;
    color: #333333;
    font-size: 2.4rem;
    margin-bottom: 20px;
}

.button_content_sct h2::before{
  background-color: #2589d0;
}

.button_content_sct h2::after{
    bottom: -11px;
    background-color: #fff;
}

.fl-button_item1{
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin: auto;
}

.fl-button_items1{
    width: calc((100% - 60px) / 4);
}

.fl-button_items1 a, .fl-button_items2 a, .fl-button_items3 a{
    border: 3px solid rgb(37 137 208);
    background-color: #FFF;
    color: #222;
    display: flex;
    padding: 20px 1px;
    position: relative;
    align-items: center;
    font-size: 15px;
    font-weight: bold;
    justify-content: center;
    max-height: 100%;
    height: 50px;
}

.fl-button_items1 a::after{
    content: "";
    border-bottom: 2px solid #4187d5;
    border-right: 2px solid #4187d5;
    transform: rotate(45deg);
    width: 6px;
    height: 6px;
    position: absolute;
    top: 71px;
}

.fl-button_item2{
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin: auto;
}

.fl-button_items2{
    width: calc((100% - 40px) / 3);
}

.fl-button_items2 a::after{
    content: "";
    border-bottom: 2px solid #4187d5;
    border-right: 2px solid #4187d5;
    transform: rotate(45deg);
    width: 6px;
    height: 6px;
    position: absolute;
    top: 71px;
}

.fl-button_item2 img{
  width: 50px;
  max-width: 50px;
}


.fl-button_item3{
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin: auto;
}

.fl-button_items3{
    width: calc((100% - 60px) / 4);
}

.fl-button_items3 a::after{
    content: "";
    border-bottom: 2px solid #4187d5;
    border-right: 2px solid #4187d5;
    transform: rotate(45deg);
    width: 6px;
    height: 6px;
    position: absolute;
    top: 71px;
}


/*商品　ぺパリンなどのおすすめ商品部分*/
.tab_content .tab_content_description ul li a:hover{
  opacity: 0.7;
}
.lot_content .tab_content_description ul li a:hover{
  opacity: 0.7;
}
.js-scrollable_02{
    margin-bottom: 8.5rem;
}
.search{
  margin-bottom: 0.7rem;
  display: flex;
  align-items: center;
}
.js-scrollable h3{
  margin-bottom: 0.7rem;
  display: flex;
  align-items: center;
}
.tab_content_description h3{
  font-size: 1.6rem;
  margin-bottom: 0.7rem;
}
.calendar-product__card a{
    gap: 0.5rem;
    background: #fff;
    color: #000;
}
.kessan-product__list{
  background-image: linear-gradient(-45deg, #f7f7f7 25%, #e1e1e1 25%, #e1e1e1 50%, #f7f7f7 50%, #f7f7f7 75%, #e1e1e1 75%, #e1e1e1);
  background-size: 3px 3px;
}
.col-1{
  padding: 1rem 2rem;
}
.calendar-product__card a:hover{
    opacity: 0.7;
}
.block-calendar_price{
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 0 1rem;
    border-bottom: 1px solid #000;
}
.product-detail{
  padding: 2px 0 2px 5px;
}
.calendar_unitprice{
    font-weight: bold;
}
.calendar_lot{
    font-size: 1.4rem;
}
.block-calendar_tax{
    text-align: end;
    font-size: 1.3rem;
}
.calendar_unitprice{
    color: #bf0000;
}
.related_item a {
  display: flex;
  color: #ffffff;
  background-color: #bf0000;
  width: 100%;
  justify-content: center;
  position: relative;
  border-radius: 5px;
  font-size: 1.4rem;
  font-weight: bold;
}
@media screen and (min-width: 998px) {
  .search{
    font-size: 2rem;
  }
  .calendar_unitprice{
    font-size: 3rem;
}
  .tab_content_description h3{
    font-size: 1.8rem;
    margin-bottom: 0.7rem;
  }
      .js-scrollable{
        margin-bottom: 5rem;
    }
    .js-scrollable h3{
      font-size: 2rem;
    }
      .calendar-product__card a{
        display: flex;
        padding: 0rem 1rem;
    }
    .calendar-product__card a{
        box-sizing: border-box;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }
    .product-name{
        font-size: 2rem;
        font-weight: bold;
        color: #000000;
        margin: 10px 0 35px;
    }
    .cale_comment span {
        font-size: 1.6rem;
        font-weight: bold;
        color: #e60012;
        line-height: 2.5rem;
    }
    .cale_comment {
        font-size: 1.4rem;
        font-weight: bold;
        color: #000000;
        padding: 13px 10px 10px;
        line-height: 20px;
    }
    .comment-box{
        display: block;
        margin: 15px 0;
        background: #fcfbde;
        border: 1px solid #ffe68c;
        font-size: 1.2rem;
        padding: 7px 10px;
        border-radius: 5px;
        color: #000;
    }
    .calendar_unitprice{
        font-size: 2.2rem;
    }
    .calendar_unitprice b{
        font-size: 3rem;
    }
    .related_item a {
      padding: 17px 10px;
    }
}
@media screen and (max-width: 997px) {
  .product-name{
    font-size: 1.7rem;
    font-weight: bold;
    color: #000000;
    margin: 10px 0 7px;
}
  .search{
    font-size: 1.7rem;
  }
  .js-scrollable{
    margin-bottom: 6rem;
}
  .js-scrollable h3{
    font-size: 1.7rem;
  }
  .calendar-product__card a img{
    width: 49%;
  }
  .calendar_unitprice{
      font-size: 2.5rem;
  }
  .related_item a {
    padding: 12px 0px;
  }
}
/*壁掛け選ぶ*/
#contents_kabe_01,#contents_kabe_02{
  margin-top: -100px;
  padding-top: 100px;
}
/*タブ切り替え部分*/
/*タブ切り替え全体のスタイル*/
.tabs {
    margin-top: 50px;
    padding-bottom: 40px;
    background-color: #fff;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
    margin: 0 auto 5rem;
}
/*商品ならび*/
.tab_content_description ul{
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: wrap;
    margin-top: 2rem;
}
.tab_content_description li {
    position: relative;
    transition: opacity 0.3s;
}
.tab_content_description a {
    text-decoration: none;
    color: #333;
}
.category-ranking__title{
    color: #333;/*文字色*/
    border-bottom: dashed 2px #0993c6;
}
.ranking-list_inr .product-image h3{
  border-bottom: 0 !important;
}
.tab_content_description h3 span{
    color: #0993c6;
}
@media (min-width: 998px) {
    .tab_content_description ul>li:nth-child(n+6) {
        margin-top: 30px;
    }
    .tab_content_description ul>li:not(:nth-child(5n+1)) {
        margin-left: 20px;
    }
    .tab_content_description ul>li {
        width: calc((100% - 80px) / 5);
    }
    .tab_content_description h3 span{
      font-size: 2.3rem;
  }
}
@media screen and (max-width: 997px) {
  .tab_content_description ul li{
    width: calc((100% - 20px) / 2);
  }
  
  .tab_content_description ul{
    gap: 2rem;
}
.tab_content_description h3 span{
  font-size: 2rem;
}
}
  /*タブのスタイル*/
  .tab_item, .tab_item_03 ,.tab_item_02,.tab_item_04, .tab_item_09,.tab_item_10,.tab_item_11{
    width: calc(100%/5);
    height: 50px;
    border-bottom: 3px solid #0993c6;
    border-right: 1px solid #898989;
    background-color: #d9d9d9;
    text-align: center;
    color: #333;
    float: left;
    font-weight: bold;
    transition: all 0.2s ease;
  }
  .tab_item{
    width: calc(100%/5);
  }
  .tab_item_03{
    width: calc(100%/2);
  }
  .tab_item_02,.tab_item_04,.tab_item_10{
    width: calc(100%/3);
  }
  .tab_item_09{
    width: calc(100%/4);
  }
  .tab_item_11{
    width: calc(100%/8);
  }

  .tab_item:last-of-type {
    border-right: none;
  }
  .tab_item:hover {
    opacity: 0.7;
  }
  .tab_item_02:last-of-type {
    border-right: none;
  }
  .tab_item_02:hover {
    opacity: 0.7;
  }
  .tab_item_03:last-of-type {
    border-right: none;
  }
  .tab_item_03:hover {
    opacity: 0.7;
  }
  .tab_item_04:last-of-type {
    border-right: none;
  }
  .tab_item_04:hover {
    opacity: 0.7;
  }
  .tab_item_09:last-of-type {
    border-right: none;
  }
  .tab_item_09:hover {
    opacity: 0.7;
  }
  .tab_item_10:last-of-type {
    border-right: none;
  }
  .tab_item_10:hover {
    opacity: 0.7;
  }
  .tab_item_11:last-of-type {
    border-right: none;
  }
  .tab_item_11:hover {
    opacity: 0.7;
  }
  
  /*ラジオボタンを全て消す*/
  input[name="tab_item"] {
    display: none;
  }
  input[name="tab_item_03"] {
    display: none;
  }
  input[name="tab_item_02"] {
    display: none;
  }
  input[name="tab_item_04"] {
    display: none;
  }
  input[name="tab_item_09"] {
    display: none;
  }
  input[name="tab_item_10"] {
    display: none;
  }
  input[name="tab_item_11"] {
    display: none;
  }


  
  
  /*タブ切り替えの中身のスタイル*/
  .tab_content {
    display: none;
    padding: 20px 20px 0;
    clear: both;
    overflow: hidden;
  }
  
  
  /*選択されているタブのコンテンツのみを表示 卓上*/
  #naire_01:checked ~ #naire_01_content,
  #naire_02:checked ~ #naire_02_content,
  #naire_03:checked ~ #naire_03_content,
  #naire_04:checked ~ #naire_04_content,
  #naire_05:checked ~ #naire_05_content,
  #original_01:checked ~ #original_01_content,
  #original_02:checked ~ #original_02_content,
  #original_03:checked ~ #original_03_content,
  #original_04:checked ~ #original_04_content,
  #original_05:checked ~ #original_05_content {
    display: block;
  }
/*選択されているタブのコンテンツのみを表示 壁かけ*/
    #kabenaire_01:checked ~ #kabenaire_01_content,
    #kabenaire_02:checked ~ #kabenaire_02_content,
    #kabenaire_03:checked ~ #kabenaire_03_content,
    #kabenaire_04:checked ~ #kabenaire_04_content,
    #kabenaire_05:checked ~ #kabenaire_05_content,
    #kabeoriginal_01:checked ~ #kabeoriginal_01_content,
    #kabeoriginal_02:checked ~ #kabeoriginal_02_content,
    #kabeoriginal_03:checked ~ #kabeoriginal_03_content,
    #kabeoriginal_04:checked ~ #kabeoriginal_04_content,
    #kabeoriginal_05:checked ~ #kabeoriginal_05_content {
      display: block;
    }

    /*選択されているタブのコンテンツのみを表示 サイズ*/
    #size_01:checked ~ #size_01_content,
    #size_02:checked ~ #size_02_content,
    #size_03:checked ~ #size_03_content,
    #size_04:checked ~ #size_04_content,
    #size_05:checked ~ #size_05_content,
    #kabesize_01:checked ~ #kabesize_01_content,
    #kabesize_02:checked ~ #kabesize_02_content,
    #kabesize_03:checked ~ #kabesize_03_content,
    #kabesize_04:checked ~ #kabesize_04_content,
    #kabesize_05:checked ~ #kabesize_05_content {
      display: block;
    }
    #kabesize_item_01:checked ~ #kabesize_item_01_content,
    #kabesize_item_02:checked ~ #kabesize_item_02_content,
    #kabesize_item_03:checked ~ #kabesize_item_03_content,
    #kabesize_item_04:checked ~ #kabesize_item_04_content,
    #kabesize_item_05:checked ~ #kabesize_item_05_content,
    #kabesize_item_06:checked ~ #kabesize_item_06_content,
    #kabesize_item_07:checked ~ #kabesize_item_07_content,
    #kabesize_item_08:checked ~ #kabesize_item_08_content {
      display: block;
    }
  
  /*選択されているタブのスタイルを変える*/
  .tabs input:checked + .tab_item {
    background-color: #0993c6;
    color: #fff;
  }
  .tabs input:checked + .tab_item_03 {
    background-color: #0993c6;
    color: #fff;
  }
  .tabs input:checked + .tab_item_02 {
    background-color: #0993c6;
    color: #fff;
  }
  .tabs input:checked + .tab_item_04 {
    background-color: #0993c6;
    color: #fff;
  }

  .tabs input:checked + .tab_item_09 {
    background-color: #0993c6;
    color: #fff;
  }
  .tabs input:checked + .tab_item_10 {
    background-color: #0993c6;
    color: #fff;
  }
  .tabs input:checked + .tab_item_11 {
    background-color: #0993c6;
    color: #fff;
  }

@media (min-width: 998px) {
  .tab_item, .tab_item_03 ,.tab_item_02,.tab_item_04, .tab_item_09,.tab_item_10,.tab_item_11{
    line-height: 50px;
    font-size: 16px;
    display: block;
  }
}
/*小ロット対応でざがす*/
.lot_midashi:first-of-type{
  margin-top: 2rem!important;
}
.lot_midashi{
  margin-top: 4rem;
    /*font-size: 1.8rem;
    font-weight: bold;*/
    font-weight: bold;
    border-left: 4px solid #000000;
    padding-left: 1rem;
}

/*サイズ別でさがす*/
#contents_size_02,#contents_size_01{
  margin-top: -100px;
  padding-top: 100px;
}
.size_about{
  margin-bottom: 5rem;
}
.size_img{
  text-align: center;
  margin-bottom: 1.5rem;
}
.size_kabe_li{
  opacity: 1!important;
}
.annotation{
  background-color: #e9e9e9;
}
@media (min-width: 998px) {
  .category_size_explanation {
    font-size: 1.5rem;
  }
  .size_kabe_li{
    width: calc((100% - 80px) / 5)!important;
  }
  .annotation{
    padding: 1.8rem 2rem;
    font-size: 15px;
  }
}
@media screen and (max-width: 997px) {
  .category_size_explanation {
    font-size: 1.4em;
  }
  .tab_item, .tab_item_03 ,.tab_item_02,.tab_item_04, .tab_item_09,.tab_item_10,.tab_item_11{
    font-size: 14px;
  }
  .size_kabe_li{
    width: calc((100% - 20px) / 2)!important;
  }
  .tab_item_02,.tab_item_03,.tab_item_04,.tab_item_10,.tab_item_11{
    line-height: 50px;
  }
  .annotation{
    padding: 1rem 0.8rem;
    font-size: 13px;
  }
}

/*カテゴリ別でさがす_2*/
.cate-card_list{
  display: flex;
  flex-wrap: wrap;
  gap:15px 10px;
  margin: 20px 0 50px;
}
.cate-card_item{
  width: calc((100% - 10px) / 2);
}
.cate-card_item a{
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
  border-radius: 8px;
  border-radius: 8px;
  background-color: #d1eaf6;
  position: relative;
  border: 2px solid #555;
  text-decoration: none;
  color: #222;
}
.cate-card_item a:after{
  content: '';
  display: block;
  width: 15px;
  height: 15px;
  aspect-ratio: 1;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  background-color: #222;
  position: absolute;
  bottom: 8px;
  right: 8px;
}
.cate-card_item a:hover img{
  transform: scale(1.1);
}
.cate-card_image{
  overflow: hidden;
}
.cate-card_item img{
  display: block;
  object-fit: cover;
  object-position: center center;
  width: 100%;
  transition: transform 0.3s ease;
  transform: translate3d(0, 0, 0);
}
.cate-card_title{
  padding: 15px 10px;
  line-height: 1.4;
  font-size: 1.3rem;
}
.cate-card_title span{
  font-size: 1.6rem;
  font-weight: bold;
}
.cate-card_item:first-child{
  width: 100%;
}
.cate-card_item:first-child .cate-card_title span{
  font-size: 3rem;
}
@media (min-width: 768px) {
  .cate-card_list{
    gap: 15px 10px;
  }
  .cate-card_item{
    width: calc((100% - 30px) / 4);
  }
  .cate-card_item:first-child a{
    flex-direction: row;
    align-items: center;
  }
  .cate-card_image{
    height: auto;
  }
  .cate-card_title br{
    display: none;
  }
  .cate-card_title span{
    font-size: 1.8rem;
  }
  .cate-card_title span br{
    display: none;
  }
}

/*パソコンでは表示*/
@media screen and (min-width: 998px) {
    .pc_on {
        display: block;
    }
    .sp_on{
      display: none;
    }
}
@media screen and (max-width: 997px) {
    .pc_on {
        display: none;
    }
    .sp_on{
      display: block;
    }
}

/* sidenavi */
#side_navi{
  display: none;
}
@media screen and (min-width: 1400px) and (min-height: 550px){
  /* 初期表示はサイドメニューが表示された状態 */
  #side_navi {
      position: fixed;
      display: block;
      z-index: 100;
      right: -130px; 
      bottom: 80px;
      transition: all 0.3s ease; 
  }
  /* 非表示時のスタイル */
  #side_navi.hidden {
      right: -130px;
  }
  #side_navi.visible{
      right: -130px; 
  }
  #side_navi.visible.hidden{
      right: 0; 
  }
  /* トグルボタンのスタイル */
  .toggle-btn {
      position: absolute;
      left: -34px;
      top: 50%;
      transform: translateY(-50%);
      background-color: #efefef;
      border: 1px solid #dfdfdf;
      border-radius: 5px 0 0 5px;
      border-right: none;
      padding: 25px 10px;
      cursor: pointer;
      z-index: 1000;
      transition: all 0.3s ease;
      font-size: 1.4rem;
  }
  #side_navi .toggle-btn {
      opacity: 0;
      cursor: default;
  }
  #side_navi.visible .toggle-btn,
  #side_navi.visible.hidden .toggle-btn{
      opacity: 1;
      cursor: pointer;
  }
  .item_navi {
      position: relative;
      border-radius: 10px 0 0 10px;
      width: 130px;
      padding: 15px 10px;
      text-align: center;
      background: #efefef;
      border: 1px solid #dfdfdf;
      border-right: none;
  }
  .snav li {
      margin-top: 7px;
      position: relative;
  }
  .snav li a {
      display: flex;
      align-items: center;
      position: relative;
      color: #222;
      padding: 2px 2px 2px 14px;
      min-height: 30px;
      border: 1px solid #b3b3b3;
      border-radius: 5px;
      background: #fff;
      line-height: 1.3;
      font-size: 1rem;
      font-weight: bold;
      text-align: left;
      transition: all 0.2s;
  }
  .snav li a:before{
      content: "";
      position: absolute;
      top: 39%;
      left: 5px;
      color: #bf0000;
      border-style: solid;
      border-color: transparent;
      border-width: 0.35em 0.5em;
      border-right-color: currentColor;
      border-left: 0;
  }
  .snav li a:hover {
      color: #fff;
      background: #bf0000;
  }
  .snav li a.active {
      color: #fff;
      background: #bf0000;
  }
  .section-navi{
      margin-top: -100px;
      padding-top: 110px;
  }
}
@media screen and (min-width: 1500px) and (min-height: 650px){
  #side_navi {
      right: -150px; 
  }
  /* 非表示時のスタイル */
  #side_navi.hidden {
      right: -150px;
  }
  #side_navi.visible{
      right: -150px; 
  }
  .item_navi {
      width: 150px;
      padding: 15px 10px;
  }
  .snav li {
      margin-top: 7px;
  }
  .snav li a {
      padding: 4px 5px 4px 17px;
      min-height: 35px;
      font-size: 1.2rem;
  }
}
/*タブ切り替え全体のスタイル*/
.b_tabs {
  padding-bottom: 50px;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
}

/*タブのスタイル*/
.b_tab_item {
  width: calc(100%/3);
  height: 50px;
  border-bottom: 3px solid #0993c6;
  background-color: #d9d9d9;
  line-height: 50px;
  font-size: 16px;
  text-align: center;
  color: #565656;
  display: block;
  float: left;
  text-align: center;
  font-weight: bold;
  transition: all 0.2s ease;
}
.b_tab_item:hover {
  opacity: 0.75;
}

@media screen and (max-width: 767px) {
.b_tab_item{
 font-size: 14px;
}
}

/*ラジオボタンを全て消す*/
input[name="tab_item"] {
  display: none;
}

/*タブ切り替えの中身のスタイル*/
.b_tab_content {
  display: none;
  padding: 40px 40px 0;
  clear: both;
  overflow: hidden;
}


/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#programming:checked ~ #programming_content,
#design:checked ~ #design_content {
  display: block;
}

/*選択されているタブのスタイルを変える*/
.b_tabs input:checked + .b_tab_item {
  background-color: #0993c6;
  color: #fff;
}
.fl_taitle{
  font-size: 20px;
  margin-bottom: 20px;
  border-bottom: solid 2px #2589d0;

}
.all-item_btn a, .all-item_btn_col_1 a {
    gap: 10px;
    justify-content: center;
    position: relative;
    padding: 20px 0;
    border: 3px solid #2589d0;
    border-radius: 5px;
    color: #222;
    font-size: 1.6rem;
    width: 100%;
    font-weight: bold;
    text-align: center;
    margin-bottom: 30px;
}
@media (min-width: 768px) {
    .all-item_btn {
        display: flex;
        gap: 1rem;
        flex-wrap: wrap;
    }
}
@media (min-width: 768px) {
    .all-item_btn a {
        width: calc((100% - 60px) / 4);
    }
}
.sonota_btn {
    gap: 10px;
    justify-content: center;
    position: relative;
    padding: 20px 0;
    border: 3px solid #2589d0;
    border-radius: 5px;
    color: #222;
    font-size: 1.6rem;
    width: 100%;
    font-weight: bold;
    text-align: center;
    margin-bottom: 30px;
}
.points-container {
    display: grid;
    /* 3列2行のグリッドレイアウト */
    grid-template-columns: repeat(3, 1fr);
    gap: 15px; /* 項目間の隙間 */
    max-width: 1200px; /* 全体の最大幅（調整してください） */
    margin: 0 auto; /* 中央寄せ */
    box-sizing: border-box;
    margin-bottom: 50px;
}

.point-item {
    background-color: #ffe8ed; /* 背景色（画像の色を参考に調整） */
    padding: 15px;
    text-align: center;
    border-radius: 5px; /* 角の丸み */
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}
.point-number {
    font-size: 20px;
    font-weight: bold;
    color: #333;
    margin-bottom: 10px;
    border-bottom:solid 2px #333;

}

.point-number .number {
    font-size: 25px;
    color: #333; /* 数字の色（画像の色を参考に調整） */
    margin-left: 5px;
}

.point-title {
    font-size: 25px;
    font-weight: bold;
    color: #e51d1a; /* タイトルの色（画像の色を参考に調整） */
    margin-bottom: 15px;
}

.point-description {
    font-size: 15px;
    color: #333;
    line-height: 1.6;
    margin-bottom: 10px;
}

.point-note {
    font-size: 10px;
    color: #333;
    margin-top: auto; /* 下部に配置 */
}

/* レスポンシブ対応（必要であれば追加・調整してください） */
@media (max-width: 768px) {
    .points-container {
        grid-template-columns: repeat(2, 1fr); /* 2列にする */
    }
}

.seletc_ttl{
  color: #000000 !important;
}


.heading-11 {
    position: relative;
    padding: .5em .7em;
    background-color: #2589d0;
    color: #fff;
    font-size: 25px;
    margin-top: 30px;
    margin-bottom: 30px;
}

.heading-11::before {
    position: absolute;
    top: 100%;
    left: 0;
    border-bottom: solid 10px transparent;
    border-right: solid 20px #1579c0;
    content: '';
}


table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 50px;
    background-color: #fff;
}
 
th, td {
    border: 1px solid #ddd;
    padding: 12px;
    text-align: left;
    vertical-align: top;
    font-size: 14px;
}
 
th {
    background-color: #e0f2f7; /* Light blue header */
    font-weight: bold;
    white-space: nowrap; /* テキストの折り返しを防ぐ */
    font-size: 15px;
}
 
td {
    background-color: #fff;
}
 
/* Specific column widths (調整可能) */
th:nth-child(1), td:nth-child(1) {
    width: 15%; /* 比較ポイント */
}
th:nth-child(2), td:nth-child(2) {
    width: 42.5%; /* 名入れカレンダー */
}
th:nth-child(3), td:nth-child(3) {
    width: 42.5%; /* オリジナルカレンダー */
}


@media screen and (max-width: 767px) {
  .heading-11{
    font-size: 20px;
  }
}
/* デザイン自由度の記号 */
.symbol {
    font-size: 1.5em; /* 記号を大きく表示 */
    font-weight: bold;
    display: inline-block; /* 行内で並ぶように */
    margin-right: 5px;
}

ul {
    list-style-type: none; /* デフォルトの箇条書き記号を非表示 */
    padding-left: 0;
    margin: 0;
}

li {
    position: relative;
    margin-bottom: 5px;
}


/* 費用感のテキスト中央寄せ */
td:nth-child(2):not([colspan]):not([rowspan]):first-child + td,
td:nth-child(3):not([colspan]):not([rowspan]):first-child + td {
    text-align: center; /* 費用感のセルを中央寄せ */
}
.ranking-list_inr ul {
    flex-wrap: wrap;
    gap: 10px;
}
.ranking-list_inr li {
    border-right:none;
}
@media screen and (min-width: 768px) {
    .ranking-list_inr li {
        width: calc((100% - 40px) / 5);
    }
}
.ranking-list_inr li:nth-of-type(6) .ranking_num:before {
    content: "6";
}
.ranking-list_inr li:nth-of-type(7) .ranking_num:before {
    content: "7";
}
.ranking-list_inr li:nth-of-type(8) .ranking_num:before {
    content: "8";
}
.ranking-list_inr li:nth-of-type(9) .ranking_num:before {
    content: "9";
}
.ranking-list_inr li:nth-of-type(10) .ranking_num:before {
    content: "10";
}

.ranking-list_inr .ranking_num {
    background-image:none; 
}
.fl-button{
  gap: 10px;
  display: flex;
  margin-bottom: 30px;
}

.fl-button-2{
  gap: 10px;
  display: flex;
  margin-bottom: 30px;
}

.fl-button-4{
  gap: 10px;
  display: flex;
  margin-bottom: 30px;
}

.button-4 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin:0 auto;
    border: none;
    border-bottom: solid 5px #0059a0;
    border-radius: 25px;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 18px;
    transition: .5s ease;
    position: relative;

}

.button-4::after {
    transform: rotate(135deg);
    width: 5px;
    height: 5px;
    /* margin-left: 10px; */
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    content: '';
    position: absolute;
    right: 20px;
}

.button-4:hover {
    transform: translateY(3px);
    border-bottom-width: 2px;
}
/* .fl-button:hover{
  opacity: 1;
} */


/* .fl-button-2, .fl-button-4{
  gap: 10px;
  display: flex;
  margin-bottom: 30px;
} */

.button-5 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 500px;
    margin:0 auto;
    border: none;
    border-bottom: solid 5px #0059a0;
    border-radius: 25px;
    background-color: #fff;
    color: #2589d0;
    font-weight: 600;
    font-size: 18px;
    transition: .5s ease;
    position: relative;
    border: 2px solid #2589d0;
}

.button-5::after {
    transform: rotate(135deg);
    width: 5px;
    height: 5px;
    /* margin-left: 10px; */
    border-top: 2px solid #2589d0;
    border-right: 2px solid #2589d0;
    content: '';
    position: absolute;
    right: 20px;
}

.button-5:hover {
    transform: translateY(3px);
    border-bottom-width: 2px;
}
/* .fl-button-2:hover{
  opacity: 1;
} */

.fl-button-3{
  margin-bottom: 30px;
}
.button-6 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 500px;
    margin:0 auto;
    border: none;
    border-bottom: solid 5px #0059a0;
    border-radius: 25px;
    background-color: #fff;
    color: #2589d0;
    font-weight: 600;
    font-size: 18px;
    transition: .5s ease;
    position: relative;
    border: 2px solid #2589d0;
}


.button-6::after {
    transform: rotate(45deg);
    width: 5px;
    height: 5px;
    /* margin-left: 10px; */
    border-top: 2px solid #2589d0;
    border-right: 2px solid #2589d0;
    content: '';
    position: absolute;
    right: 20px;
}

.button-6:hover {
    transform: translateY(3px);
    border-bottom-width: 2px;
}
.fl-button:hover, .fl-button-2:hover, .fl-button-3:hover, .fl-button-4:hover{
  opacity: 1;
}
/* .fl-button-4{
  gap: 10px;
  display: flex;
  margin-bottom: 30px;
} */
.button-7 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 250px;
    margin:0 auto;
    border: none;
    border-bottom: solid 5px #0059a0;
    border-radius: 25px;
    background-color: #2589d0;
    color: #fff;
    font-weight: 600;
    font-size: 18px;
    transition: .5s ease;
    position: relative;

}

.button-7::after {
    transform: rotate(135deg);
    width: 5px;
    height: 5px;
    /* margin-left: 10px; */
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    content: '';
    position: absolute;
    right: 20px;
}

.button-7:hover {
    transform: translateY(3px);
    border-bottom-width: 2px;
}
/* .fl-button-4:hover{
  opacity: 1;
} */
.button-4 a, .button-7 a{
  color: #fff;
  padding: 15px;
  width: 100%;
}
.button-5 a, .button-6 a{
  color: #2589d0;
  padding: 15px;
  width: 100%;
}
/* .button-6 a{
  color: #2589d0;
  padding: .9em 2em;
  width: 100%;
} */
/* .button-7 a{
  color: #fff;
  padding: .9em 2em;
  width: 100%;
} */

@media screen and (max-width: 767px) {
  .fl-button{
  display: grid;
  /* grid-template-columns: 1rf; */
  gap: 10px;
  }

  /* .pc{
  display: block;
  } */
.fl-button, .fl-button-2, .fl-button-4{
  display: grid;
  gap: 15px;
}
.button-5, .button-6{
  width: 100%;
}
.button-5 a, .button-6 a{
  font-size: 14px;
}

}


@media screen and (min-width: 1400px) and (min-height: 550px) {
    .section-navi {
        margin-top: -100px;
        padding-top: 110px;
    }
}


.readmore {
  position: relative;
  margin: 50px auto 0;
  padding: 0 0 75px;
}

.readmore label {
  position: absolute;
  display: table;
  left: 50%;
  bottom: 0;
  margin: 0 auto;
  width: 250px;
  padding: 10px 0;
  color: #2589d0;
  text-align: center;
  border-radius: 25px;
  background-color: #fff;
  transform: translateX(-50%);
  cursor: pointer;
  z-index: 1;
  font-size: 18px;
  font-weight: 600;
    border: 2px solid #2589d0;
}
.button-7:hover {
    transform: translateY(3px);
    border-bottom-width: 2px;
}
.readmore label::before{
  content: 'デザインの続きを見る';
}

.readmore input[type="checkbox"]:checked ~ label::before {
  content: '元に戻す';
}

.readmore input[type="checkbox"]{
  display: none;
}

.readmore-content {
  position: relative;
  height: 330px;
  overflow: hidden;
}

.readmore input[type="checkbox"]:checked ~ .readmore-content {
  height: auto;
}
.readmore-content::before {
  position: absolute;
  display: block;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 75px;
  background: linear-gradient( rgba(255,255,255,0) 0%, rgba(255,255,255,0.8) 50%, #fff 100%);
}

.readmore input[type="checkbox"]:checked ~ .readmore-content::before {
  display: none;
}
.calen_select ul > li {
      border: 1.5px solid #2589d0 !important;
    background: #fff !important;
}


@media screen and (min-width: 768px) {
    .calen_select .select_btn {
        font-weight: bold;
        border: 1.2px solid;
    }
}

.table-container {
  /* スマートフォンなどの小さい画面幅でスクロールできるようにする */
  overflow-x: auto; /* または scroll */
  -webkit-overflow-scrolling: touch; /* iOSでのスクロールをスムーズにするためのプロパティ */
}

/* 通常の画像（サムネイル）のスタイル */
.thumbnail {
    cursor: pointer; /* マウスカーソルをポインターにする */
    max-width: 100%; /* 必要に応じて調整 */
    height: auto;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease-in-out; /* ホバー時のアニメーション */
    margin-bottom: 30px;
}

.thumbnail:hover {
    transform: scale(1.02); /* ホバー時に少し拡大 */
}

/* ライトボックスのスタイル（拡大表示時のオーバーレイ） */
.lightbox {
    display: none; /* 初期状態では非表示 */
    position: fixed; /* 画面に固定 */
    z-index: 1000; /* 他の要素より手前に表示 */
    left: 0;
    top: 0;
    width: 100%; /* 全幅 */
    height: 100%; /* 全高 */
    overflow: auto; /* 必要であればスクロール可能にする */
    background-color: rgba(0, 0, 0, 0.8); /* 半透明の黒背景 */
    justify-content: center; /* 子要素を水平方向に中央揃え */
    align-items: center; /* 子要素を垂直方向に中央揃え */
}

/* 拡大表示される画像のスタイル */
.lightbox-content {
    margin: auto;
    display: block;
    max-width: 90%; /* 最大幅 */
    max-height: 90vh; /* 最大高さ（ビューポートの高さの90%） */
    border: 3px solid #fff; /* 白い枠線 */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); /* 影 */
}

/* 閉じるボタンのスタイル */
.close-button {
    position: absolute;
    top: 20px;
    right: 35px;
    color: #fff;
    font-size: 40px;
    font-weight: bold;
    transition: 0.3s;
    cursor: pointer;
}

.close-button:hover,
.close-button:focus {
    color: #bbb;
    text-decoration: none;
    cursor: pointer;
}
/* 商品カードコンテナ */
.product-card {
    display: flex; /* Flexbox を使用して要素を横並びにする */
    background-color: #fff; /* カードの白い背景 */
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); /* 柔らかい影 */
    width: 100%; /* 最大幅まで全幅を占める */
    overflow: hidden; /* border-radius が子要素にも適用されるようにする */
    margin-bottom: 50px;
}

/* 商品画像セクション */
.product-image-container {
    flex: 2; /* 成長・縮小を許可 */
    position: relative; /* バッジの配置用 */
    padding: 20px;
    display: flex; /* 画像を中央揃えにするため */
    justify-content: center;
    align-items: center;
}

.product-image {
    max-width: 100%; /* 画像がコンテナ内に収まるようにする */
    height: auto; /* アスペクト比を維持 */
    display: block; /* 画像の下の余白を削除 */
}

/* 発送バッジ (最速出荷対応) */
.shipping-badge {
    position: absolute;
    top: 0;
    left: 0;
    background-color: #dc143c; /* クリムゾンレッド */
    color: white;
    padding: 8px 12px;
    font-size: 14px;
    font-weight: bold;
    border-bottom-right-radius: 8px;
    z-index: 10; /* 他の要素の上に表示 */
    text-align: center;
    line-height: 1; /* 重ねたテキストの行の高さを調整 */
}

.shipping-badge span {
    display: block; /* 各行をブロック要素にする */
}

.shipping-badge .fast-shipping-text {
    font-size: 10px;
    font-weight: normal;
}

/* 商標バッジ (意匠登録取得済) */
.trademark-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    background-color: #e0f2f7; /* 薄い青緑 */
    color: #008080; /* ティール */
    padding: 4px 8px;
    font-size: 12px;
    border-radius: 4px;
    font-weight: bold;
}

/* 商品詳細セクション */
.product-details {
    flex: 3; /* このセクションを少し広くする */
    padding: 25px 30px;
    display: flex;
    flex-direction: column; /* 内容を垂直に積み重ねる */
    justify-content: center;
}

.product-title {
    font-size: 20px;
    font-weight: 700;
    color: #333;
    margin-bottom: 15px;
    line-height: 1.4;
}

/* オプション (フルカラー, 最小ロット) */
.options {
    display: flex;
    gap: 10px; /* オプションボタン間のスペース */
    margin-bottom: 20px;
    flex-wrap: wrap; /* 小さい画面でボタンを折り返す */
}

.option-button {
    display: flex;
    align-items: center;
    padding: 8px 15px;
    border: 1px solid #ddd;
    border-radius: 5px;
    font-size: 14px;
    color: #555;
    background-color: #fff;
    cursor: pointer; /* インタラクティブであることを示す */
}


.option-button .color-icon {
    width: 12px;
    height: 12px;
    background-color: #888; /* 色インジケーターのプレースホルダー */
    border-radius: 50%;
    margin-right: 6px;
    border: 1px solid #ccc; /* コントラストのための小さなボーダー */
}

.option-button.min-lot {
    background-color: #808080; /* 「最小ロット」の灰色 */
    color: white;
    border-color: #808080;
    padding-left: 10px; /* アイコンがないボタンのパディングを調整 */
}

.option-button.min-lot .value {
    font-weight: bold;
    margin-left: 5px;
}

/* 価格セクション */
.price-section {
    display: flex;
    align-items: flex-end; /* 価格と数量を下揃え */
    margin-bottom: 20px;
    gap: 10px;
}

.price {
    font-size: 22px;
    font-weight: 700;
    color: #dc143c; /* クリムゾンレッド */
    line-height: 1; /* 数字の下の余白をなくす */
}

.set-quantity {
    font-size: 16px;
    color: #555;
    display: flex;
    flex-direction: column; /* 「100セット」と「(税込)」を縦に並べる */
    line-height: 1.2;
}

.set-quantity .tax-info {
    font-size: 12px;
    color: #888;
    align-self: flex-end; /* 税情報を右揃えにする */
}

/* 商品説明 */
.description {
    font-size: 15px;
    color: #555;
    margin-bottom: 25px;
    line-height: 1.6;
}

/* 詳細ボタン (詳細はこちら) */
.details-button {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #dc143c; /* クリムゾンレッド */
    color: white;
    padding: 15px 0;
    border-radius: 5px;
    text-decoration: none; /* リンクの下線を削除 */
    font-size: 18px;
    font-weight: 700;
    transition: background-color 0.3s ease; /* スムーズなホバー効果 */
    gap: 10px; /* テキストと矢印の間のスペース */
    width: 100%; /* 内容に合わせて幅を調整 */
}

.details-button:hover {
    background-color: #b00c2e; /* ホバーで濃い赤色 */
}

.details-button .arrow {
    font-size: 20px;
}

@media screen and (max-width: 767px) {
.product-card {
  display: block;
}
.details-button{
  margin: auto;
}
}
.custom-survey-widget {
    font-family: sans-serif;
    color: #333;
    margin-bottom: 30px;
    border: 1px solid #ddd;
    padding: 15px;
    border-radius: 8px;
    background-color: #fff;
    max-width: 100%;
    box-sizing: border-box;
}

.custom-survey-question {
    font-size: 18px;
    font-weight: bold;
}

.custom-survey-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 10px;
    margin-bottom: 20px;
}

.custom-survey-table th,
.custom-survey-table td {
    border: 1px solid #ddd;
    padding: 10px;
    text-align: left;
}

.custom-table-header {
    font-weight: normal;
}

.custom-table-header-percent,
.custom-table-data-percent {
    width: 60px;
    text-align: right;
    white-space: nowrap;
}

.custom-table-header-bar,
.custom-table-data-bar {
    width: auto;
}

.custom-bar-container {
    width: 100%;
    height: 20px;
    background-color: #e0e0e0;
    border-radius: 3px;
    overflow: hidden;
}

.custom-bar-color {
    height: 100%;
    border-radius: 3px;
}

.custom-bar-pink {
    background-color: #f06292;
}

.custom-bar-blue {
    background-color: #64b5f6;
}
.custom-survey-table th:nth-child(1), td:nth-child(1) {
    width: 29%;
}
.custom-survey-table th:nth-child(2), td:nth-child(2) {
    width: 7.5%;
}

@media screen and (max-width: 767px) {
.custom-survey-question {
    font-size: 15px;
}
}