/* WooCommerce デフォルトウィジェット */

/* 一部ウィジェットは見出しを変更 */
/* NOTE: 価格フィルター */
:is(.widget_price_filter, .widget_rating_filter, .widget_layered_nav) .p-widget-headline {
  color: var(--tcd-accent-color);
  padding: 0;
  background: initial;
  margin-block: var(--tcd-half-read) calc(30px + var(--tcd-half-read));
}

/* WooCommerce Brand の説明 */
/* NOTE: ブランドページのみタイトル、画像、説明文が表示される */
.widget_brand_description img {
  margin-bottom: 20px;
}

.widget_brand_description p {
  margin-block: var(--tcd-half-read);
}

/* WooCommerce Brand ポスター画像 */
/* NOTE: ブランドページのサムネイルを一覧表示する */
.widget_brand_thumbnails {}

/*
 * リスト
 * - WC_Widget_Brand_Nav
 * - WC_Widget_Product_Categories
 */
:is(.widget_layered_nav, .widget_product_categories) li {
  position: relative;
  padding: 0 !important;
}

:is(.widget_layered_nav, .widget_product_categories) a {
  display: flex;
  align-items: center;
  column-gap: 5px;
  padding-block: calc(20px + var(--tcd-half-read)) !important;
  padding-inline: calc(30px + 1em * var(--tcd-widget-level, 0)) 20px !important;
  border: 1px solid #dddddd;
  margin-top: -1px;
}

:is(.widget_layered_nav, .widget_product_categories) ul ul {
  --tcd-widget-level: 1;
}

:is(.widget_layered_nav, .widget_product_categories) ul ul ul {
  --tcd-widget-level: 2;
}

:is(.widget_layered_nav, .widget_product_categories) ul ul ul ul {
  --tcd-widget-level: 3;
}

@media (any-hover: hover) {

  :is(.widget_layered_nav, .widget_product_categories) a:hover {
    color: rgba(0, 0, 0, 0.5);
  }
}

/* ステイカラー 1階層 */
.widget_product_categories .product-categories>li.current-cat>a {
  color: var(--tcd-accent-color);
}

/* ステイカラー 2階層以降 */
.widget_product_categories .product-categories ul.children .current-cat a {
  position: relative;
  z-index: 1;
  color: #fff;
  background: color-mix(in srgb, var(--tcd-accent-color) 70%, #ffffff);
  border-color: color-mix(in srgb, var(--tcd-accent-color) 70%, #ffffff);
  margin-block: -1px;
}

.widget_product_categories .product-categories ul.children .current-cat .count {
  color: var(--tcd-accent-color);
  border-color: #fff;
}

/*
 * 商品カテゴリーリストの2階層以降を開閉式にする
 * NOTE: jsでulをdivでラップ
 * - WC_Widget_Product_Categories
 */
.widget_product_categories .child-wrap {
  position: relative;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.3s cubic-bezier(0.17, 0.84, 0.44, 1);
  background: #f6f6f6;
}

.widget_product_categories .child-wrap>ul {
  overflow: hidden;
}

.widget_product_categories a .toggle {
  display: block;
  flex: 0 0 50px;
  align-self: stretch;
  background-image: var(--tcd-icon--arrow-bottom);
  background-repeat: no-repeat;
  background-position: right 20px center;
  background-size: 1.5em;
  margin-block: calc(-20px - var(--tcd-half-read));
  margin-left: auto;
  margin-right: -20px;
  transition: opacity 0.2s ease;
}

/* active時 */
.widget_product_categories li.is-active>a {
  color: var(--tcd-accent-color);
}

.widget_product_categories li.is-active .child-wrap {
  grid-template-rows: 1fr;
}

.widget_product_categories li.is-active .toggle {
  background-image: var(--tcd-icon--arrow-top);
}

/* 2階層目の最初がアクティブの場合、下ボーダーをなくす */
.widget_product_categories li.is-active>a:has(+.child-wrap >.children>li:first-child.current-cat) {
  border-bottom-color: #fff;
}

@media (any-hover: hover) {

  .widget_product_categories a .toggle:hover {
    opacity: 0.5;
  }
}


/*
 * カウント
 * - WC_Widget_Brand_Nav
 * - WC_Widget_Product_Categories
 */
:is(.widget_layered_nav, .widget_product_categories) .count {
  display: none;
}

:is(.widget_layered_nav, .widget_product_categories) a .count {
  display: grid;
  place-items: center;
  flex: 0 0 30px;
  height: 30px;
  border-radius: 50%;
  font-size: 12px;
  line-height: 1;
  color: inherit;
  background: #fff;
  border: 1px solid #ddd;
  transition: color 0.3s ease;
  margin-left: auto;
  margin-right: -3px;
}

/*
 * ドロップダウン
 * - WC_Widget_Brand_Nav
 */
.widget_layered_nav select {
  cursor: pointer;
  appearance: none;
  width: 100%;
  height: 60px;
  padding: 0 20px;
  background: #fff;
  border: 1px solid #ddd;
  background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgLTk2MCA5NjAgOTYwIiAgZmlsbD0iIzAwMDAwMCI+PHBhdGggZD0iTTQ4MC0zODQuODVxLTYuNDYgMC0xMS45Mi0yLjExLTUuNDYtMi4xMi0xMC43LTcuMzVMMjgxLjg1LTU2OS44NXEtNS42Mi01LjYxLTYtMTMuNzctLjM5LTguMTUgNi0xNC41MyA2LjM4LTYuMzkgMTQuMTUtNi4zOSA3Ljc3IDAgMTQuMTUgNi4zOUw0ODAtNDI4LjMxbDE2OS44NS0xNjkuODRxNS42MS01LjYyIDEzLjc3LTYgOC4xNS0uMzkgMTQuNTMgNiA2LjM5IDYuMzggNi4zOSAxNC4xNSAwIDcuNzctNi4zOSAxNC4xNUw1MDIuNjItMzk0LjMxcS01LjI0IDUuMjMtMTAuNyA3LjM1LTUuNDYgMi4xMS0xMS45MiAyLjExWiIvPjwvc3ZnPg==');
  background-repeat: no-repeat;
  background-position: right 15px center;
  background-size: 1.5em;
  margin-top: -1px;
}

/* お買い物カゴ */
/* NOTE: サイト全体で使うため、general.cssに記載 */

/*
 * 商品を価格で絞り込む
 * - WC_Widget_Price_Filter
 */
.woocommerce .widget_price_filter {
  font-size: 16px;
}

.woocommerce .widget_price_filter .price_slider {
  margin-bottom: 30px;
}

.woocommerce .widget_price_filter .price_slider_wrapper .ui-widget-content {
  background-color: #ddd;
  margin-inline: 7px;
}

.woocommerce .widget_price_filter .ui-slider-horizontal {
  height: 0.25em;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-range {
  background: #000;
}

.woocommerce .widget_price_filter .ui-slider .ui-slider-handle {
  top: -0.38em;
  background-image: radial-gradient(circle closest-corner, #fff 40%, #000 30%);
}

.woocommerce .widget_price_filter .price_slider_amount {
  display: flex;
  align-items: center;
  --tcd-wc-number-width: 85px;
  --tcd-wc-number-height: 45px;
  --tcd-wc-number-width-sp: var(--tcd-wc-number-width);
  --tcd-wc-number-height-sp: var(--tcd-wc-number-height);
  --tcd-wc-number-text-align-sp: left;
}

.woocommerce .widget_price_filter .price_slider_amount .button {
  float: none;
  flex: 0 0 85px;
  height: 45px;
  padding: 0;
  font-size: 14px;
  font-weight: normal;
  color: #fff;
  background: #000;
  border-radius: 5px;
  margin-left: auto;
}

@media (any-hover: hover) {
  .woocommerce .widget_price_filter .price_slider_amount .button:hover {
    color: rgba(255, 255, 255, 0.5);
  }
}

/*
 * select2 ドロップダウン
 * - WC_Widget_Product_Categories
 * - WC_Widget_Layered_Nav - AND
 */
body:has(.woocommerce-widget-layered-nav-dropdown, .dropdown_product_cat) .select2-container {
  --wc-form-border-color: #ddd;
  --wc-form-border-radius: 0px;
}

body:has(.woocommerce-widget-layered-nav-dropdown, .dropdown_product_cat) .select2-results__option {
  padding: 10px 15px;
}

:is(.woocommerce-widget-layered-nav-dropdown, .widget_product_categories) {
  margin-top: -1px;
}

:is(.woocommerce-widget-layered-nav-dropdown, .widget_product_categories) .select2-container .select2-selection--single {
  height: auto;
  border-color: #ddd;
  border-radius: 0px;
}

:is(.woocommerce-widget-layered-nav-dropdown, .widget_product_categories) .select2-container .select2-selection--single .select2-selection__rendered {
  padding: 12px 15px;
}

:is(.woocommerce-widget-layered-nav-dropdown, .widget_product_categories) .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 12px;
  right: 10px;
}

:is(.woocommerce-widget-layered-nav-dropdown, .widget_product_categories):has(.select2-selection__clear) .select2-selection__arrow {
  display: none;
}

/*
 * select2 ドロップダウン
 * - WC_Widget_Layered_Nav - OR
 */
.woocommerce-widget-layered-nav-dropdown:has(.select2-selection--multiple) {
  display: flex;
}

.woocommerce-widget-layered-nav-dropdown:has(.select2-selection--multiple) .select2-container {
  flex: 1;
}

:is(.woocommerce-widget-layered-nav-dropdown) .select2-container .select2-selection--multiple {
  height: auto;
  border-color: #ddd !important;
  border-radius: 0px;
}

:is(.woocommerce-widget-layered-nav-dropdown) .select2-container .select2-selection--multiple .select2-selection__rendered {
  display: block;
  padding: 0;
  margin: 7px 15px 12px;
}

:is(.woocommerce-widget-layered-nav-dropdown) .select2-container--default .select2-selection--multiple .select2-selection__choice {
  font-size: 14px;
  padding: 3px 5px !important;
  background: #f6f6f6;
  border-color: #ddd;
}

:is(.woocommerce-widget-layered-nav-dropdown) .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
  font-weight: normal;
  margin-right: 5px;
}

:is(.woocommerce-widget-layered-nav-dropdown) .woocommerce-widget-layered-nav-dropdown__submit {
  position: relative;
  white-space: nowrap;
  padding-inline: 1.5em;
  font-size: 14px;
  color: #fff;
  background: #000;
  margin: 0 0 0 -1px;
}

@media (any-hover: hover) {
  :is(.woocommerce-widget-layered-nav-dropdown) .woocommerce-widget-layered-nav-dropdown__submit:hover {
    color: rgba(255, 255, 255, 0.5);
  }
}

/*
 * 商品を評価で絞り込む
 * - WC_Widget_Rating_Filter
 */
.widget_rating_filter .p-widget-headline+ul {
  margin-top: -10px;
}

.widget_rating_filter ul li+li {
  margin-top: 5px;
}

.widget_rating_filter ul li a {
  display: flex;
  align-items: center;
  width: fit-content;
  gap: 5px;
  color: var(--tcd-accent-color);
}

.widget_rating_filter ul li a>.star-rating {
  margin-top: -2px;
}

.widget_rating_filter ul li a>strong {
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: normal;
  width: 2em;
  height: 2em;
  border-radius: 50%;
  overflow: hidden;
  color: #fff;
  background: var(--tcd-accent-color);
  transition: color 0.3s ease;
}

.widget_rating_filter ul li.chosen a::before {
  margin-right: 0px !important;
}

/*
 * 商品タグクラウド
 * - WC_Widget_Product_Tag_Cloud
 */
.widget_product_tag_cloud .tagcloud {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.widget_product_tag_cloud .p-widget-headline+.tagcloud {
  margin-top: 20px;
}

.widget_product_tag_cloud .tag-cloud-link {
  display: grid;
  grid-auto-flow: column;
  place-items: center;
  height: 30px;
  padding-inline: 1em;
  color: #000000;
  background: #eeeeee;
  border-radius: 5px;
}

@media (any-hover: hover) {
  .widget_product_tag_cloud .tag-cloud-link:hover {
    background: var(--tcd-accent-color);
    color: #ffffff;
  }
}

/*
 * 商品一覧
 * - 最近閲覧された商品
 * - 評価の高い商品
 */
:is(.widget_products, .widget_recently_viewed_products, .widget_top_rated_products) li {
  margin-top: -1px;
  line-height: 1;
}

:is(.widget_products, .widget_recently_viewed_products, .widget_top_rated_products) li a {
  display: grid;
  grid-template-columns: 110px 1fr;
  grid-template-rows: 110px;
  font-size: 14px;
  --tcd-wc-star-rating-margin: -2px 0 0;
}

:is(.widget_products, .widget_recently_viewed_products, .widget_top_rated_products) li .product-title {
  line-height: 1.4;
}

:is(.widget_products, .widget_recently_viewed_products, .widget_top_rated_products) .widget_products_item_content {
  display: grid;
  align-content: center;
  row-gap: 10px;
  background: #fff;
  padding-inline: 20px;
  border: 1px solid #ddd;
  border-left: none;
}

/*
 * 商品検索
 * NOTE: デフォルトのWP検索フォームと同じスタイル
 */

/*
 * 最新の商品評価
 */
.widget_recent_reviews ul.product_list_widget li {
  padding: 0px;
  margin-top: -1px;
}

.widget_recent_reviews ul.product_list_widget li>a {
  display: grid;
  grid-template-columns: 110px 1fr;
  grid-template-rows: 110px;
  font-size: 14px;
  font-weight: normal;
  --tcd-wc-star-rating-margin: -2px 0 0;
}

.widget_recent_reviews ul.product_list_widget li img {
  float: none;
  margin-left: 0px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.widget_recent_reviews ul.product_list_widget li .widget_recent_reviews_content {
  display: grid;
  align-content: center;
  row-gap: 10px;
  background: #fff;
  padding-inline: 20px;
  border: 1px solid #ddd;
  border-left: none;
}

.widget_recent_reviews ul.product_list_widget li .reviewer {
  margin-block: var(--tcd-half-read);
}

/*
 * 有効な商品絞り込み
 */
.woocommerce .widget_layered_nav_filters ul {
  margin-top: 10px;
}

/*
 * TCD 商品ランキングウィジェット
 */
.p-widget-product-ranking-list-item {
  display: grid;
  grid-template-columns: 100px 40px 1fr;
  grid-template-rows: 100px;
  font-size: 14px;
  background: #fff;
  margin-top: -1px;
}

.p-widget-product-ranking-list-item-rank {
  display: grid;
  place-items: center;
  border: 1px solid #ddd;
  border-left: none;
}

.p-widget-product-ranking-list-item-title {
  --tcd-line-clamp: 2;
  --tcd-line-clamp-height: auto;
  display: grid;
  align-items: center;
  line-height: 1.6;
  padding-inline: 20px;
  border: 1px solid #ddd;
  border-left: none;
}