/* 検索ページ追加CSS（iOSの入力ズーム抑止含む） */
.searchbox input,
.searchbox select,
.searchbox textarea,
.searchbox button {
  font-size: 16px; /* iOS Safari zoom抑止 */
}

.search-controls {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 10px;
}

.search-controls .select {
  height: 44px;
  border-radius: 12px;
  padding: 0 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
}

.pager {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
  align-items: center;
}

.pager a,
.pager span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.92);
  text-decoration: none;
  font-size: 14px;
}

.pager .current {
  background: rgba(37,99,235,.18);
  border-color: rgba(37,99,235,.35);
}

/* ===== 検索結果グリッド（モバイルで横に伸びるのを防ぐ） ===== */
.search-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

/* grid item が min-width:auto のせいで縮まず溢れるのを防止 */
.search-grid > *{
  min-width: 0;
}

/* 長い英数字やURLがあっても横に押し広げない */
.search-grid *{
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* スマホは1列に落とす（横スクロール防止） */
@media (max-width: 520px){
  .search-grid{
    grid-template-columns: 1fr;
  }
}

/* ===== 検索フォームもスマホで崩れないように ===== */
.searchbox{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
}

.searchbox input[type="text"]{
  width: 100%;
  min-width: 0;
}

@media (max-width: 520px){
  .searchbox{
    grid-template-columns: 1fr;
  }
  .searchbox button{
    width: 100%;
  }
}