/* /css/components.css */

/* 共通リスト（カード系リスト） */
.list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* カード本体（PC: 3列想定） */
/* /css/components.css の「カード本体（PC: 3列想定）」をこの内容に置き換え */

.card {
  list-style: none;
  display: flex;
  gap: 8px;
  padding: 8px;
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 6px;

  /* PC は常に 3 カラム固定 */
  flex: 0 0 calc((100% - 24px) / 3);
  max-width: calc((100% - 24px) / 3);

  min-width: 0;
}

.card:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* サムネまわり */
.card-thumb-area {
  flex: 0 0 80px;
}

.card-thumb {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

/* テキストまわり */
.card-body {
  flex: 1 1 auto;
  min-width: 0;
}

.card-title {
  margin: 0 0 4px;
  font-size: 0.95rem;
  line-height: 1.3;
}

.card-title a {
  color: var(--theme-color);
  text-decoration: none;
}

.card-title a:hover {
  text-decoration: underline;
}

.card-tagline {
  margin: 0 0 4px;
  font-size: 0.8rem;
  color: #555;
}

.card-address {
  margin: 0 0 4px;
  font-size: 0.75rem;
  color: #666;
}

.card-meta {
  margin: 0;
  font-size: 0.7rem;
  color: #777;
}

/* スマホ時：カードを1列 & 最大幅に */
@media (max-width: 600px) {
  .list {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
    gap: 8px;
    margin: 0;
  }

  .card {
    flex: 1 1 100%;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    border-radius: 8px;
  }
}

/* -------------------------------------
   バッジ（店舗ページ用）
------------------------------------- */
.badge-wrap {
  margin: 4px 0 8px;
}

.badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 11px;
  border-radius: 12px;
  border: 1px solid var(--theme-color);
  color: var(--theme-color);
  background: #fff;
  margin: 2px;
}

.badge-cat {
  background: #f5f5f5;
}

/* -------------------------------------
   カテゴリーチップ（トップページ）
------------------------------------- */
.category-nav {
  margin-bottom: 24px;
}

.category-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.category-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid #ccc;
  font-size: 0.8rem;
  background: #ffffff;
  color: #333;
  text-decoration: none;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
}

.category-chip .cat-icon {
  font-size: 0.9rem;
}

.category-chip .cat-label {
  font-size: 0.8rem;
}

.category-chip:hover {
  border-color: var(--theme-color);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}

/* ジャンルごとの色調（任意調整OK） */
.category-chip--food          { border-color: #ffb74d;    background: #fff9f0; }
.category-chip--ramen         { border-color: #e57373;    background: #fff8f6; }
.category-chip--cafe          { border-color: #a1887f;    background: #fdf7f2; }
.category-chip--beauty_health { border-color: #f48fb1;    background: #fff6fb; }
.category-chip--life_service  { border-color: #64b5f6;    background: #f4f9ff; }
.category-chip--shopping      { border-color: #81c784;    background: #f4fbf4; }
.category-chip--professional  { border-color: #90a4ae;    background: #f5f7f8; }

/* スマホ時は少しコンパクトに */
@media (max-width: 600px) {
  .category-chip {
    padding: 4px 8px;
    font-size: 0.75rem;
  }
}

/* -------------------------------------
   ボタン（共通 UI）
------------------------------------- */
.button {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 0.85rem;
  cursor: pointer;
  text-align: center;
  border: none;
  background: #e0e0e0;
  color: #333;
}

.button:hover {
  opacity: 0.9;
}

/* メイン強調 */
.button-primary {
  background: var(--theme-color);
  color: #fff;
}

/* 2nd 操作 */
.button-secondary {
  background: #e8eaf6;
  color: #1a237e;
  border: 1px solid #c5cae9;
}

/* 危険操作（削除など） */
.button-danger {
  background: #ef5350;
  color: #fff;
}

/* 小さいボタン */
.button-small {
  padding: 3px 8px;
  font-size: 0.75rem;
}

/* -------------------------------------
   テーブル（フロント側最低限）
------------------------------------- */
.table {
  width: 100%;
  border-collapse: collapse;
}

.table th,
.table td {
  padding: 6px 8px;
  border-bottom: 1px solid #ddd;
  font-size: 0.85rem;
}

/* -------------------------------------
   フラッシュメッセージ共通
------------------------------------- */
.flash {
  padding: 8px 12px;
  background: #e8f5e9;
  border: 1px solid #81c784;
  border-radius: 4px;
  font-size: 0.85rem;
  margin: 12px 0;
}
