/* =====================================================================
   /jp レシピページ専用 CSS
   ===================================================================== */

/* 背景だけ全体に */
body.recipe {
  background-color: #fffdf8;
}

/* -----------------------------
   ベース（フォントは recipe-main 内だけ明朝）
----------------------------- */

.recipe-main {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px 80px;
}

body.recipe .recipe-main,
body.recipe .recipe-main * {
  font-family: "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3",
               "Hiragino Mincho ProN", "MS 明朝", serif;
  line-height: 1.7;
  box-sizing: border-box;
}

/* -----------------------------
   HERO（レシピ検索ヘッダー）
----------------------------- */

.recipe-hero {
  padding: 2.8rem 0 2.4rem;
  background: #fffaf2;
  text-align: center;
  border-bottom: 1px solid rgba(0,0,0,0.05);
}

.recipe-hero__title {
  font-size: 1.9rem;
  color: #4a3522;
  margin-bottom: 0.4rem;
}

.recipe-hero__lead {
  font-size: 1rem;
  color: #6e5b48;
}

/* -----------------------------
   検索フォーム
----------------------------- */

.recipe-filter {
  padding: 2.4rem 0 2.2rem;
}

.recipe-filter__inner {
  max-width: 800px;
  margin: 0 auto;
  background: #ffffff;
  padding: 1.6rem 2rem;
  border-radius: 18px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06);
}

.recipe-filter__title {
  font-size: 1.3rem;
  color: #4a3522;
  text-align: center;
  margin-bottom: 1rem;
  letter-spacing: 0.08em;
}

.select-container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.select-container label {
  font-size: 0.95rem;
  color: #5f5244;
}

.product-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;
}

.product-select:focus-visible {
  border-color: #d86b26;
}

/* 表示ボタンは「非JS用の保険」として残しつつ、見た目からは隠す */
.btn-submit {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* -----------------------------
   レシピ一覧（ヘッダー＋注意書き）
----------------------------- */

.recipe-list {
  padding: 0 0 1rem;
}

.recipe-list__head {
  text-align: center;
  margin-bottom: 0.8rem;
}

.recipe-list__title {
  font-size: 1.4rem;
  color: #4a3522;
}

.recipe-list__summary {
  font-size: 0.9rem;
  color: #7a6b5a;
  text-align: center;
  margin-bottom: 0.4rem;
}

.recipe-list__note {
  font-size: 0.82rem;
  color: #9a8570;
  text-align: center;
  margin-bottom: 0.8rem;
}

/* 「表示されている商品点数：xx」行の調整 */
.recipe-list-count {
  font-size: 0.9rem;
  color: #7a6b5a;
  margin-bottom: 0.6rem;
}

/* -----------------------------
   カードレイアウト（goodslist-4.tpl）
----------------------------- */

/* <a> が <li> を包んでいる崩れを補正 */
.goods-list > a {
  text-decoration: none;
  color: inherit;
  display: block;
}

/* リスト本体をグリッドに（PC 基本） */
.goods-list {
  list-style: none;
  margin: 1.2rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem 1.1rem;
}

/* 各カード（PC 基本） */
.goods-item {
  background-color: #ffffff;
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(0,0,0,0.06);
  padding: 1rem 1.1rem 1.1rem;
  display: block;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.goods-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(0,0,0,0.09);
}

/* ★ ここが肝：常に「左画像＋右テキスト」の2カラムグリッド */
.goods-content {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  column-gap: 0.75rem;
  row-gap: 0.25rem;
  align-items: flex-start;
}

/* サムネイル（左カラムに固定） */
.goods-img {
  grid-row: 1 / span 2;
  grid-column: 1 / 2;
  width: 64px;
  height: 64px;
  border-radius: 14px;
  overflow: hidden;
  background-color: #f8f1e8;
  margin: 0;  /* ここで中央寄せを完全に殺す */
}

.goods-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* タイトル（右カラム・1行目） */
.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;
}

/* 説明文（右カラム・2行目） */
.goods-description {
  grid-column: 2 / 3;
  font-size: 0.84rem;
  color: #6a5a4b;
  margin-top: 0.1rem;
}

/* -----------------------------
   レスポンシブ
----------------------------- */

@media (max-width: 1024px) {
  .recipe-main {
    padding: 0 12px 64px;
  }

  .goods-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .recipe-main {
    padding: 0 12px 56px;
  }

  /* スマホは1列表示。レイアウトロジックは同じ（左画像＋右テキスト） */
  .goods-list {
    grid-template-columns: minmax(0, 1fr);
  }

  .goods-item {
    padding: 0.9rem 1rem;
  }

  .goods-content {
    grid-template-columns: 60px minmax(0, 1fr);
  }

  .goods-img {
    width: 60px;
    height: 60px;
  }
}

@media (max-width: 480px) {
  .recipe-main {
    padding: 0 10px 48px;
  }

  .goods-content {
    grid-template-columns: 56px minmax(0, 1fr);
  }

  .goods-img {
    width: 56px;
    height: 56px;
  }
}
