/* =========================================================
   PLP サイドバー（区切り線なし・小さめ文字・カスタムチェック）
   対象: .plp-sidebar 内の .plp-filters
   ========================================================= */

/* サイドバーの基本幅とグリッド間隔 */
.plp-sidebar { width: 280px; }
.plp-filters { display: grid; gap: 8px; }

/* fieldset をフラット化（枠/背景/余白の統一） */
.plp-filters .plp-filter {
  display: block;
  width: 100%;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 見出し（小さめ＆セミボールド） */
.plp-filter legend {
  display: block;
  padding-top: 8px;
  margin: 12px 0 8px;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-14);
  color: var(--c-fg);
}

/* 行（ラベル）— 文字は1pxだけ小さく、余白もタイトに */
.plp-filter__item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 0;
  font-size: var(--fs-sm); /* 13px想定 */
  line-height: 1.3;
  color: var(--c-fg);
  cursor: pointer;
}
.plp-filter__item:hover { background: transparent !important; color: inherit; }
.plp-filter__item:hover span { opacity: .85; }

/* ===========================
   カスタムチェックボックス
   =========================== */
:root{
  --chk-size: 16px;     /* 外枠サイズ */
  --chk-br:   4px;      /* 角丸 */
  --chk-bw:   2px;      /* 枠線太さ */
  --chk-bd:   #cbd5e1;  /* 枠線(未選択) */
  --chk-bd-h: #9aa6b2;  /* 枠線(hover) */
  --chk-on:   #6b7280;  /* 枠線(選択時) */
  --chk-inner:#4a4a4a;  /* 内側の四角 */
}

.plp-filter__item input[type="checkbox"]{
  appearance: none;
  -webkit-appearance: none;
  inline-size: var(--chk-size);
  block-size: var(--chk-size);
  margin: 0;
  border: var(--chk-bw) solid var(--chk-bd);
  border-radius: var(--chk-br);
  background: #fff;
  display: inline-grid;
  place-content: center;
  position: relative;
  vertical-align: middle;
  transition: border-color .15s ease, box-shadow .15s ease;
}

/* フォーカスリング（キーボード操作時のみ） */
.plp-filter__item input[type="checkbox"]:focus-visible{
  box-shadow: 0 0 0 3px rgba(0,0,0,.10);
  border-color: var(--chk-on);
}
.plp-filter__item input[type="checkbox"]:hover{ border-color: var(--chk-bd-h); }

/* 既存の ✓ マークを完全無効化 */
.plp-filter__item input[type="checkbox"]::after{ content:none; }

/* チェック時：中央に小さな四角 */
.plp-filter__item input[type="checkbox"]:checked{
  background:#fff; border-color: var(--chk-on);
}
.plp-filter__item input[type="checkbox"]:checked::before{
  content:""; width:8px; height:8px; background: var(--chk-inner);
  border-radius: 2px; display:block;
}

/* 無効状態 */
.plp-filter__item input[disabled]{ opacity:.55; cursor:not-allowed; }
.plp-filter__item input[disabled] + span{ color: var(--c-fg-muted); }

/* モバイル微調整 */
@media (max-width: 767.98px){
  .plp-filters .plp-filter { padding: 10px 0 !important; }
  .plp-filter__item { padding: 5px 0; }
}

.plp-main.is-loading{ opacity:.6; pointer-events:none; }

/* ========== PLP: フィルター送信/クリア（モバイルのみボタン表示） ========== */
.plp-filter__actions{
  margin-top: var(--space-4);
  display:flex; align-items:center; gap:var(--space-3);
}

/* 「絞り込む」ボタン（モバイル想定） */
.plp-filter__submit{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.625rem 1rem;
  border:1px solid transparent; border-radius: var(--radius-full);
  background: var(--c-brand-blue); color: var(--c-fg-inverse);
  font-family: var(--font-sans-jp); font-size: var(--fs-14); font-weight: var(--fw-medium);
  line-height: 1; box-shadow: var(--shadow-sm);
  transition: transform var(--dur-fast) var(--ease),
             background var(--dur-fast) var(--ease),
             box-shadow var(--dur-fast) var(--ease);
}
.plp-filter__submit:focus-visible{
  outline:2px solid color-mix(in srgb, var(--c-brand-blue) 40%, white);
  outline-offset:2px; box-shadow: var(--shadow-md);
}
.plp-filter__submit:hover{ transform: translateY(-1px); }
.plp-filter__submit:active{ transform: translateY(0); }

/* クリアは常にテキストリンク */
.plp-filter__clear{ font-size: var(--fs-14); color: var(--c-fg-muted); text-decoration: underline; }

/* PC / タブレットでは「絞り込む」非表示 */
@media (min-width:768px){
  .plp-filter__submit{ display:none; }
  .plp-filter__actions{ gap:0; }
}

/* ====== モバイル用トリガーボタン ====== */
.plpFilterBtn{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .875rem; border:1px solid var(--c-border);
  border-radius: var(--radius-full); background: var(--c-bg);
  font: var(--fw-medium) var(--fs-14)/1 var(--font-sans-jp);
  color: var(--c-fg); box-shadow: var(--shadow-sm);
}
.plpFilterBtn__icon{ font-size:1rem; line-height:1; }
@media (min-width:768px){ .plpFilterBtn{ display:none; } }

/* ====== PC/タブレットのサイドバー下げ（ご要望） ====== */
.plp-sidebar .plp-filters{ margin-top: var(--space-8); }
@media (min-width:768px){ .plp-sidebar .plp-filters{ margin-top: var(--space-12); } }

/* ====== 再掲（統一外観） ====== */
.plp-filter__actions{
  display:flex; align-items:center; gap:var(--space-4); margin-top: var(--space-6);
}
.plp-filter__submit{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.875rem 1.25rem; border-radius: var(--radius-full);
  border:1px solid transparent; background: var(--c-brand-blue); color:#fff;
  font: var(--fw-semibold) var(--fs-14)/1 var(--font-sans-jp); box-shadow: var(--shadow-sm);
}
.plp-filter__clear{ font-size: var(--fs-14); color: var(--c-fg-muted); text-decoration: underline; }
@media (min-width:768px){ .plp-filter__submit{ display:none; } }

/* ====== ドロワー（モバイル）— クラス版（既存） ====== */
.plpDrawer{ position:fixed; inset:0; z-index:var(--z-modal); display:none; }
.plpDrawer.is-open{ display:block; }
.plpDrawer__overlay{ position:absolute; inset:0; background:rgba(0,0,0,.35); opacity:0; transition:opacity var(--dur) var(--ease); }
.plpDrawer.is-open .plpDrawer__overlay{ opacity:1; }
.plpDrawer__panel{
  position:absolute; inset:0 0 0 auto; width:min(88vw,420px); background: var(--c-bg);
  transform: translateX(100%); transition: transform var(--dur) var(--ease);
  display:grid; grid-template-rows:auto 1fr auto; box-shadow:-10px 0 30px rgba(0,0,0,.12);
}
.plpDrawer.is-open .plpDrawer__panel{ transform: translateX(0); }
.plpDrawer__header{
  display:flex; align-items:center; justify-content:space-between;
  padding: var(--space-4) var(--space-6); border-bottom:1px solid var(--c-border);
}
.plpDrawer__title{ font: var(--fw-medium) var(--fs-base)/1 var(--font-sans-jp); }
.plpDrawer__close{ inline-size:40px; block-size:40px; border-radius: var(--radius-full); background:transparent; border:1px solid var(--c-border); }
.plpDrawer__body{ padding: var(--space-4) var(--space-6); overflow:auto; }
.plpDrawer__footer{
  position:sticky; bottom:0; padding: var(--space-4) var(--space-6);
  background: linear-gradient(to top, var(--c-bg), color-mix(in oklab, var(--c-bg), transparent 30%));
  border-top:1px solid var(--c-border);
  display:flex; align-items:center; justify-content:space-between; gap: var(--space-4);
}
.plpDrawer__submit{
  flex:1 1 auto; padding:1rem; border-radius: var(--radius-full); border:none;
  background: var(--c-brand-blue); color:#fff;
  font: var(--fw-semibold) var(--fs-base)/1 var(--font-sans-jp); box-shadow: var(--shadow-md);
}
.plpDrawer__clear{ color: var(--c-fg-muted); text-decoration: underline; }

/* スクロールロック */
html.is-locked, body.is-locked{ overflow:hidden; }

/* ドロワー内：上のアクション行を非表示、下フッターは表示 */
@media (max-width:767px){
  #plp-filter-drawer .plp-filter__actions:first-of-type{ display:none !important; }
  #plp-filter-drawer .plpDrawer__body .plp-filter__actions{ display:none !important; }
  #plp-filter-drawer .plpDrawer__footer .plp-filter__actions{ display:flex !important; }
}

/* ===== Price block ===== */
.plp-filter--price{ margin-top:20px; }
.plp-filter--price legend{ font-weight:700; font-size:14px; margin-bottom:10px; }

/* プリセット（縦リスト） */
.plp-price-presets{ display:grid; margin-bottom:14px; }
.plp-filter__item.price-preset{
  display:grid; grid-template-columns: var(--chk-size) 1fr;
  align-items:center; gap:8px; cursor:pointer; user-select:none;
}

/* --- ここがポイント：radio も“内側四角”で描画 --- */
.plp-filter__item.price-preset input[type="radio"]{
  appearance: none; -webkit-appearance:none; -moz-appearance:none;
  width: var(--chk-size); height: var(--chk-size);
  border: var(--chk-bw) solid var(--chk-bd);
  border-radius: var(--chk-br);
  background:#fff; position:relative; margin:0; vertical-align:middle;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.plp-filter__item.price-preset input[type="radio"]:hover{ border-color: var(--chk-bd-h); }
.plp-filter__item.price-preset input[type="radio"]:focus-visible{
  box-shadow: 0 0 0 3px rgba(0,0,0,.10); border-color: var(--chk-on);
}
/* 既存のチェック記号を使わず、inner square を ::before で */
.plp-filter__item.price-preset input[type="radio"]::after{ content:none; }
.plp-filter__item.price-preset input[type="radio"]:checked{
  border-color: var(--chk-on); background:#fff;
}
.plp-filter__item.price-preset input[type="radio"]:checked::before{
  content:""; position:absolute; inset:auto;
  width:8px; height:8px; background: var(--chk-inner); border-radius:2px;
  /* 中央配置 */
  left:50%; top:50%; transform: translate(-50%,-50%);
}

/* 任意価格 */
.plp-price-custom{ margin-top:14px; }
.plp-price-custom__hd{ font-size:12px; color:#6b7280; margin-bottom:8px; }
.plp-price-inputs{ display:flex; align-items:center; gap:8px; }
.plp-price-inputs .tilde{ color:#6b7280; font-size:13px; }

.price-field{ position:relative; display:inline-flex; align-items:center; }
.price-field .yen{
  position:absolute; left:12px; font-size:13px; color:#6b7280; pointer-events:none;
}
.price-field input{
  width:128px; height:36px; padding:8px 12px 8px 26px;
  border:1px solid #d1d5db; border-radius:18px; background:#fff;
  font-size:14px; outline:none; transition: border-color .15s ease;
}
.price-field input:focus{ border-color:#111; }

/* ボタン行 */
.plp-price-actions{ display:flex; align-items:center; gap:12px; margin-top:10px; }
.plp-price-actions .btn.btn--sm{
  height:34px; padding:0 14px; border-radius:16px;
  background:#111; color:#fff; font-size:13px; font-weight:600;
  border:none; cursor:pointer;
}
.plp-price-actions .btn.btn--sm:hover{ opacity:.9; }
.plp-price-actions .plp-link--clear{
  color:#6b7280; font-size:13px; text-decoration: underline; text-underline-offset:2px;
}
.plp-price-actions .plp-link--clear:hover{ color:#111; }

/* サイドバーとの余白調整（任意） */
.plp-filter--price .plp-filter__item span{ font-size:13px; }

/* モバイルのドロワー内では 価格の「適用／リセット」を非表示にする */
@media (max-width: 767px){
  #plp-filter-drawer .plp-price-actions{ display: none !important; }
  /* 既に上側アクション行は非表示にしているのでそのまま */
}
