/* =========================================================
   PLP: Toolbar（件数/並び替え）
   ========================================================= */
.plp-layout .before-shop-loop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin: var(--space-6) 0 var(--space-4);
}

.plp-layout .woocommerce-result-count {
  margin: 0;
  color: var(--c-fg-muted);
}

.plp-layout .woocommerce-ordering select {
  padding: .5rem .75rem;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
  background: #fff;
}

@media (max-width: 640px) {
  .plp-layout .before-shop-loop {
    flex-wrap: wrap;
    gap: var(--space-3);
  }
}

/* =========================================================
   PLP: Breadcrumbs（PDPとトーン/サイズを合わせる）
   ========================================================= */
.plp-breadcrumbs {
  margin: var(--space-2) 0 var(--space-2);
}

.plp-breadcrumbs .woocommerce-breadcrumb {
  font-size: var(--fs-sm);
  line-height: 1.45;
  color: var(--c-fg-muted);
  letter-spacing: .01em;
  display: block;
  padding: 0 !important;
  margin: 0 0 var(--space-2);
}

.plp-breadcrumbs .woocommerce-breadcrumb a {
  color: var(--c-fg-muted);
  text-decoration: none;
}
.plp-breadcrumbs .woocommerce-breadcrumb a:hover {
  color: var(--c-fg);
  text-decoration: none;
}

.plp-breadcrumbs .woocommerce-breadcrumb .delimiter,
.plp-breadcrumbs .woocommerce-breadcrumb .breadcrumb-separator {
  margin: 0 .35rem;
  color: var(--c-border);
}

.plp-header {
  margin: var(--space-2) 0 -3rem;
}

.plp-breadcrumbs .woocommerce-breadcrumb a,
.plp-breadcrumbs .woocommerce-breadcrumb .delimiter,
.plp-breadcrumbs .woocommerce-breadcrumb .breadcrumb-separator {
  padding: 0 !important;
}

/* =========================================================
   WooCommerce ページネーション（横並び・中央寄せ・矢印修正）
   ========================================================= */
.woocommerce-pagination {
  margin: 20px 0 8px;
}

.woocommerce-pagination .page-numbers {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
}

.woocommerce-pagination .page-numbers li {
  margin: 0;
}

.woocommerce-pagination .page-numbers a,
.woocommerce-pagination .page-numbers span {
  display: inline-flex;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--c-border, #e5e7eb);
  border-radius: 9999px;
  background: #fff;
  text-decoration: none;
  line-height: 1;
}

.woocommerce-pagination .page-numbers .current {
  background: #111;
  color: #fff;
  border-color: #111;
}

/* 矢印 */
.woocommerce-pagination .page-numbers a.prev,
.woocommerce-pagination .page-numbers a.next {
  position: relative;
  font-size: 0;
  width: 36px;
  padding: 0;
}
.woocommerce-pagination .page-numbers a.prev::before,
.woocommerce-pagination .page-numbers a.next::before {
  content: '';
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  font-size: 15px;
  line-height: 1;
}
.woocommerce-pagination .page-numbers a.prev::before { content: '‹'; }
.woocommerce-pagination .page-numbers a.next::before { content: '›'; }

/* =====================================================
   並び替えセレクト（ピル型）
   ===================================================== */
.plp-toolbar,
.wc-block-catalog-sorting {
  display: flex;
  justify-content: flex-end;
}

.plp-toolbar .woocommerce-ordering select.orderby,
.wc-block-catalog-sorting select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  height: 40px;
  padding: 0 calc(var(--space-4) + 20px) 0 var(--space-4);
  min-width: 200px;

  border: 1px solid var(--c-border);
  background-color: var(--c-bg);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);

  font-family: var(--font-sans-jp);
  font-size: var(--fs-sm);
  line-height: 40px;
  color: var(--c-fg-muted);

  transition:
    border-color var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease),
    color var(--dur) var(--ease);

  background-image:
    url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' viewBox='0 0 24 24' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  background-size: 16px 16px;
  cursor: pointer;
}

.plp-toolbar .woocommerce-ordering select.orderby:hover,
.wc-block-catalog-sorting select:hover {
  border-color: var(--c-brand-blue-light);
  color: var(--c-fg);
}

.plp-toolbar .woocommerce-ordering select.orderby:focus,
.wc-block-catalog-sorting select:focus {
  outline: none;
  border-color: var(--c-brand-blue);
  box-shadow: 0 0 0 3px rgba(31, 64, 99, .18);
}

/* =====================================================
   Mobile: 並び替えセレクトの右に「絞り込み」ボタンを配置
   ===================================================== */
@media (max-width: 767px) {
  /* ツールバーを横並び */
  .plp-toolbar,
  .plp-layout .before-shop-loop {
    display: flex;
    align-items: center;
    gap: var(--space-3);
  }

  /* 並び替えを可変幅にして左側へ */
  .plp-toolbar .woocommerce-ordering,
  .plp-toolbar .wc-block-catalog-sorting,
  .plp-toolbar form.wc-block-product-sort-select {
    flex: 1 1 auto;
    min-width: 0;
  }
  .plp-toolbar .woocommerce-ordering select.orderby,
  .plp-toolbar .wc-block-catalog-sorting select {
    width: 100%;
  }

  /* 絞り込みボタン（右端） */
  .plp-toolbar .js-plp-filter-open,
  .plp-toolbar .plp-filter__open,
  .plp-toolbar .plp-filter-toggle {
    margin-left: auto;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: .4em;
    height: 40px;
    padding: 0 var(--space-4);
    border-radius: var(--radius-full);
    border: 1px solid var(--c-border);
    background: var(--c-bg);
    color: var(--c-fg);
    box-shadow: var(--shadow-sm);
    white-space: nowrap;
    text-decoration: none;
  }
  .plp-toolbar .js-plp-filter-open:hover,
  .plp-toolbar .plp-filter__open:hover,
  .plp-toolbar .plp-filter-toggle:hover {
    border-color: var(--c-brand-blue-light);
  }

  /* 2段構成：1行目=並び替え＋絞り込み、2行目=件数 */
  .plp-toolbar.before-shop-loop {
    display: flex !important;
    align-items: center;
    gap: var(--space-3);
    flex-wrap: wrap;
  }
  .plp-toolbar.before-shop-loop .woocommerce-ordering,
  .plp-toolbar.before-shop-loop .wc-block-catalog-sorting,
  .plp-toolbar.before-shop-loop form.wc-block-product-sort-select {
    order: 1 !important;
    flex: 1 1 auto;
    min-width: 0;
  }
  .plp-toolbar.before-shop-loop .woocommerce-ordering select.orderby,
  .plp-toolbar.before-shop-loop .wc-block-catalog-sorting select {
    width: 100%;
  }
  .plp-toolbar.before-shop-loop #plp-filter-open,
  .plp-toolbar.before-shop-loop .plpFilterBtn {
    order: 2 !important;
    flex: 0 0 auto;
    margin-left: auto;
  }
  .plp-toolbar.before-shop-loop .woocommerce-result-count {
    order: 3 !important;
    flex: 1 1 100%;
    margin-top: var(--space-2);
  }
  .plp-toolbar.before-shop-loop .woocommerce-notices-wrapper {
    order: 0;
    flex-basis: 100%;
  }
}

/* =====================================================
   PC/Tablet：サイドバー下の送信ボタンは非表示
   ===================================================== */
@media (min-width: 768px) {
  .plp-filters .plp-filter__actions .plp-filter__submit {
    display: none;
  }
}

/* =====================================================
   Mobile Filter Drawer：右から“スーッと”スライド
   （JS が <html> に is-plpFilterReady / is-plpFilterOpen を付与）
   ===================================================== */
.plpFilterMask{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.4);
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-slow,320ms) var(--ease, ease);
  z-index: var(--z-overlay, 1400);
}

/* 初期はオフキャンバス（この段階では transition は未適用） */
.plpFilterDrawer{
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: min(88vw, 360px);
  background: var(--c-bg, #fff);
  box-shadow: var(--shadow-xl, 0 24px 64px rgba(0,0,0,.16));
  transform: translateX(104%);
  will-change: transform;
  backface-visibility: hidden;
  contain: layout paint;
  z-index: calc(var(--z-overlay, 1400) + 1);
  display: flex; flex-direction: column;
}

/* JS 初期化後のみトランジション有効化（フラッシュ防止） */
.is-plpFilterReady .plpFilterDrawer{
  transition: transform var(--dur-slow,320ms) var(--ease, ease);
}

/* ヘッダー/ボディ */
.plpFilterDrawer__head{
  flex: 0 0 auto;
  padding: var(--space-4, 1rem);
  border-bottom: 1px solid var(--c-border, #e5e7eb);
}
.plpFilterDrawer__body{
  flex: 1 1 auto; overflow: auto;
  padding: var(--space-4, 1rem);
}

/* オープン時 */
.is-plpFilterOpen .plpFilterMask{
  opacity: 1; pointer-events: auto;
}
.is-plpFilterOpen .plpFilterDrawer{
  transform: translateX(0);
}

/* 動きを減らす設定でも “ゼロ” にはしない（短く） */
@media (prefers-reduced-motion: reduce){
  .plpFilterMask{ transition-duration: 120ms; }
  .is-plpFilterReady .plpFilterDrawer{ transition-duration: 120ms; }
}

