/* =====================================================================
   /jp カタログページ専用 CSS
   レシピページ(recipe.css)と同じ世界観＋カード画像だけ左側に
   ===================================================================== */

/* 背景だけ全体に */
body.catalog {
  background-color: #fffdf8;
}

/* -----------------------------
   ベース（フォントは catalog-main 内だけ明朝）
----------------------------- */

.catalog-main {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px 80px;
}

/* 本文は必ず明朝体にする（reset.css を上書き） */
.catalog-main,
.catalog-main * {
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3",
               "Hiragino Mincho ProN", "MS 明朝", serif !important;
  line-height: 1.7;
  box-sizing: border-box;
}

/* 共通コンテナ（レシピの .l-container と同じ役割） */
.l-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

/* -----------------------------
   HERO（商品情報ヘッダー）
----------------------------- */

.catalog-hero {
  padding: 2.8rem 0 2.4rem;
  background: #fffaf2;
  text-align: center;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.catalog-hero__title {
  font-size: 1.9rem;
  color: #4a3522;
  margin-bottom: 0.4rem;
  letter-spacing: 0.08em;
}

.catalog-hero__lead {
  font-size: 1rem;
  color: #6e5b48;
}

/* -----------------------------
   検索フォーム（レシピの recipe-filter 相当）
----------------------------- */

.catalog-filter {
  padding: 2.4rem 0 2.2rem;
}

.catalog-filter__inner {
  background: #ffffff;
  padding: 1.6rem 2rem;
  border-radius: 18px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

.catalog-filter__head {
  text-align: center;
  margin-bottom: 1rem;
}

.catalog-filter__title {
  font-size: 1.3rem;
  color: #4a3522;
  margin-bottom: 0.2rem;
  letter-spacing: 0.08em;
}

.catalog-filter__note {
  font-size: 0.9rem;
  color: #7a6b5a;
}

.catalog-filter__form {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
  margin-top: 0.8rem;
}

.catalog-filter__row {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.catalog-filter__label {
  font-size: 0.95rem;
  color: #5f5244;
  white-space: nowrap;
}

.catalog-filter__control {
  min-width: 220px;
}

.catalog-filter__select {
  font-size: 0.95rem;
  padding: 0.6rem 0.8rem;
  border: 1px solid #d4c6b8;
  border-radius: 6px;
  background-color: #fffdf8;
  min-width: 220px;
  outline: none;
}

.catalog-filter__select:focus-visible {
  border-color: #d86b26;
}

/* 非JS用ボタンは画面から隠すだけ（機能は残す） */
.catalog-filter__submit {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* -----------------------------
   商品一覧（レシピの recipe-list 相当）
----------------------------- */

.catalog-list {
  padding: 0 0 1rem;
}

.catalog-list__head {
  text-align: center;
  margin-bottom: 0.8rem;
}

.catalog-list__title {
  font-size: 1.4rem;
  color: #4a3522;
  margin-bottom: 0.4rem;
}

.catalog-list__note {
  font-size: 0.9rem;
  color: #7a6b5a;
  margin-bottom: 0.4rem;
}

.catalog-list__body {
  margin-top: 0.4rem;
}

/* 「表示されている商品点数：xx」的な行 */
.catalog-list-count {
  font-size: 0.9rem;
  color: #7a6b5a;
  margin-bottom: 0.6rem;
}

/* -----------------------------
   カードレイアウト（goodslist-4.php）
   レシピと同じ：3カラムグリッド
   画像だけ「左側・上下中央」、文字は全部左揃え
----------------------------- */

/* a が li を包んでいても崩れないように */
.catalog-main .goods-list > a {
  text-decoration: none;
  color: inherit;
  display: block;
}

/* 一覧：3カラム（横幅に応じて自動で2カラムにも落ちる） */
.catalog-main .goods-list {
  list-style: none;
  margin: 1.2rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.1rem 1.1rem;
}

/* 各カード：レシピと同じトーン（ちょい平べっため） */
.catalog-main .goods-item {
  background-color: #ffffff;
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(0,0,0,0.06);
  padding: 0.9rem 1rem 0.95rem;
  display: block;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  text-align: left;
}

.catalog-main .goods-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.09);
}

/* 左画像＋右テキスト 2カラム（ここがレシピと同じ骨格） */
.catalog-main .goods-content {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  column-gap: 0.75rem;
  row-gap: 0.25rem;
  align-items: center; /* 画像と文字の上下を中央寄せ */
}

/* 画像コンテナ：角丸なし・背景なし・左寄せ／上下中央 */
.catalog-main .goods-img {
  grid-row: 1 / span 2;
  grid-column: 1 / 2;
  width: 64px;
  height: 64px;
  margin: 0;
  border-radius: 0;
  background: transparent;

  display: flex;
  align-items: center;        /* 上下中央 */
  justify-content: flex-start;/* 左揃え */
}

/* 画像そのものは元の比率のまま縮小 */
.catalog-main .goods-img img {
  max-width: 64px;
  max-height: 64px;
  width: auto;
  height: auto;
  display: block;
}

/* タイトル（右・1行目／左揃え） */
.catalog-main .goods-name {
  grid-column: 2 / 3;
  font-size: 0.95rem;
  font-weight: 600;
  color: #4a3522;
  margin-bottom: 0.1rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-align: left;
}

/* JANコードなど（左揃え） */
.catalog-main .goods-jancode,
.catalog-main .goods-code {
  grid-column: 2 / 3;
  font-size: 0.8rem;
  color: #9a8570;
  margin-top: 0.15rem;
  text-align: left;
}

/* 説明文（左揃え） */
.catalog-main .goods-description {
  grid-column: 2 / 3;
  font-size: 0.84rem;
  color: #6a5a4b;
  margin-top: 0.25rem;
  text-align: left;
}

/* -----------------------------
   レスポンシブ
----------------------------- */

@media (max-width: 1024px) {
  .catalog-main {
    padding: 0 12px 64px;
  }
}

@media (max-width: 768px) {
  .catalog-main {
    padding: 0 12px 56px;
  }

  .catalog-filter__inner {
    padding: 1.4rem 1.4rem;
  }

  .catalog-main .goods-item {
    padding: 0.85rem 0.95rem 0.9rem;
  }

  .catalog-main .goods-content {
    grid-template-columns: 60px minmax(0, 1fr);
  }

  .catalog-main .goods-img {
    width: 60px;
    height: 60px;
  }
}

@media (max-width: 480px) {
  .catalog-main {
    padding: 0 10px 48px;
  }

  .l-container {
    padding: 0 12px;
  }

  .catalog-main .goods-content {
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .catalog-main .goods-img {
    width: 56px;
    height: 56px;
  }
}
