/********************************************************
 *  Catalog Search Page
 *  – このファイルは catalog_index.css と同じ名前空間を使用
 ********************************************************/
#catalog-search-page{
  --c-primary:#009fcc;
  --shadow-sm:0 4px 12px rgba(0,0,0,.06);
  --radius:.7rem;
}

/* ------- 検索バー -------- */
#catalog-search-page .search-bar .form-control{
  border-radius:var(--radius) 0 0 var(--radius);
}
#catalog-search-page .search-bar .btn{
  border-radius:0 var(--radius) var(--radius) 0;
}

/* 検索オプション */
#catalog-search-page .search-options .form-select{
  border-radius:var(--radius);
}
#catalog-search-page #category-select{ width:240px; } /* ★拡大 */
#catalog-search-page #sort-select     { width:160px; }

/* ------- フィルタタブ ---- */
#catalog-search-page .catalog-filter{
  gap:.6rem; padding-left:0;
}
#catalog-search-page .catalog-filter .nav-link{
  padding:.4rem 1.1rem; background:#f4f6f8; color:#555;
  border-radius:50rem; font-weight:600; transition:.2s;
}
#catalog-search-page .catalog-filter .nav-link:hover,
#catalog-search-page .catalog-filter .nav-link.active{
  color:#fff; background:var(--c-primary);
}

/* ------- グリッド -------- */
#catalog-search-page .product-grid{
  display:grid;
  gap:1.6rem;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}

/* ------- カード ---------- */
#catalog-search-page .catalog-card{
  position:relative; display:flex; flex-direction:column;
  background:#fff; border:1px solid #e3e6ea;
  border-radius:var(--radius); box-shadow:var(--shadow-sm);
  transition:.25s;
}
#catalog-search-page .catalog-card:hover{
  transform:translateY(-4px); box-shadow:0 12px 24px rgba(0,0,0,.12);
}

/* ------- サムネイル ---------- */
#catalog-search-page .catalog-thumb{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border-top-left-radius:var(--radius);
  border-top-right-radius:var(--radius);
}

/* ------- バッジ ---------- */
#catalog-search-page .cat-badge{
  position:absolute; top:.6rem; left:.6rem;
  background:var(--c-primary); color:#fff;
  font-size:.75rem; font-weight:700;
  padding:.25rem .55rem; border-radius:.45rem;
}

/* ------- カード本文 ---------- */
#catalog-search-page .card-body{
  padding:1rem 1.15rem 1.4rem; flex:1 0 auto;
}
#catalog-search-page .card-body h2{
  font-size:1.05rem; font-weight:600; margin-bottom:.35rem;
}
#catalog-search-page .card-body p{
  font-size:.85rem; color:#6c757d; margin-bottom:1rem;
}
#catalog-search-page .btn-detail{
  width:100%; border:none; padding:.45rem 1rem;
  background:var(--c-primary); color:#fff; border-radius:.4rem;
  font-size:.9rem; transition:.2s;
}
#catalog-search-page .btn-detail:hover{ opacity:.9; }

/* ------- No Data -------- */
#catalog-search-page .no-data{
  grid-column:1/-1; text-align:center; color:#666;
  padding:60px 0; font-size:1.1rem;
}

/* ------- トップへ戻るボタン -------- */
#catalog-search-page .back-to-top{
  position:fixed;
  right:1.5rem;
  bottom:2rem;
  z-index:999;
  width:48px; height:48px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem;
  box-shadow:var(--shadow-sm);
  opacity:0;
  transition:opacity .3s;
  border-radius:50%;
  padding:0;
}
