/* /css/layout.css */

/* -------------------------------------
   基本リセット・ベース
------------------------------------- */
body {
  font-family: sans-serif;
  line-height: 1.7;
  margin: 0;
  padding: 0;
  background: #fafafa;
  color: #333;
}

/* コンテナ（全ページ共通） */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 16px;
}

/* -------------------------------------
   見出し
------------------------------------- */
h1 {
  font-size: 24px;
  margin: 8px 0 4px;
  border-left: 6px solid var(--theme-color);
  padding-left: 10px;
}

h2 {
  font-size: 18px;
  margin: 20px 0 8px;
  border-left: 4px solid var(--theme-color);
  padding-left: 8px;
}

/* スマホ用見出し調整 */
@media (max-width: 600px) {
  h1 { font-size: 20px; }
  h2 { font-size: 16px; }
}

/* -------------------------------------
   リンク共通
------------------------------------- */
a {
  text-decoration: none;
  color: var(--theme-color);
}
a:hover {
  text-decoration: underline;
}

/* -------------------------------------
   ページ上部のパンくず
------------------------------------- */
.page-breadcrumb {
  margin: 0 0 8px;
  font-size: 0.8rem;
  color: #666;
}

.page-breadcrumb a {
  color: var(--theme-color);
  text-decoration: none;
}

/* -------------------------------------
   セクション共通
------------------------------------- */
.section-block {
  margin: 24px 0;
}

.section-block h2 {
  margin-top: 0;
}

/* -------------------------------------
   情報ボックス（基本情報 / memo / links 等）
------------------------------------- */
.info-box,
.memo-box,
.links-box {
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 12px;
  background: #ffffff;
  font-size: 0.9rem;
}

/* -------------------------------------
   フッター（必要なら）
------------------------------------- */
footer {
  margin-top: 40px;
  padding: 16px;
  text-align: center;
  color: #777;
  font-size: 0.85rem;
}

/* -------------------------------------
   スマホ調整（余白・フォント）
------------------------------------- */
@media (max-width: 600px) {
  body {
    font-size: 14px;
  }
  .container {
    padding: 12px;
  }
}

/* layout.css の末尾に追加 */

/* TOP 全体レイアウト */
/* layout.css の「TOP 全体レイアウト」部分をこの内容に置き換え */
/* TOP 全体レイアウト */
.page-index {
  display: block;
  max-width: 1200px;   /* ← ここを変える！ */
  margin: 0 auto;
  padding: 16px 8px 0;
}

.page-hero h1 {
  font-size: 1.6rem;
  margin: 0 0 4px;
}

.page-hero p {
  margin: 0;
  color: #555;
  font-size: 0.9rem;
}

/* 検索フォーム */
.page-search {
  margin: 0 0 24px;
}

.page-search-form {
  display: flex;
  gap: 8px;
  max-width: 480px;
}

.page-search-form input[type="text"] {
  flex: 1;
  padding: 6px 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

.page-search-form button {
  padding: 6px 12px;
  border: none;
  border-radius: 4px;
  background: var(--theme-color);
  color: #fff;
}

/* セクション共通 */
.section-block {
  margin-bottom: 24px;
}

.section-block h2 {
  font-size: 1.2rem;
  margin: 0 0 8px;
}

/* 「すべてのお店」だけ少し詰める */
.section-all {
  margin: 8px 0 8px;
}

/* スマホ時は画面幅いっぱい＆余白調整 */
@media (max-width: 600px) {
  .page-index {
    max-width: 100%;
    padding: 12px 0 0;
  }

  .page-search-form {
    max-width: 100%;
    padding: 0 8px;
  }

  .section-block,
  .category-nav {
    padding: 0 8px;
  }

  .list {
    gap: 8px;
  }

  .card {
    border-radius: 0;
  }
}

/* ==== TOP(index) 専用のスマホ調整 ==== */
@media (max-width: 600px) {
  /* コンテナの左右余白を削る */
  .container {
    max-width: 100%;
    padding: 0;
  }

  /* index ページ本体も端まで広げる */
  .page-index {
    max-width: 100%;
    margin: 0;
    padding: 8px 0 0;
  }

  /* 中のセクションだけ、少しだけ左右余白を付ける */
  .page-index .page-hero,
  .page-index .page-search,
  .page-index .category-nav,
  .page-index .section-block {
    padding: 0 8px;
  }
}

.page-result-meta {
  margin: 4px 0 12px;
  font-size: 0.85rem;
  color: #666;
}
