/* =========================================
   家系ラーメン解説ページ 最小スタイル
   - 和テイスト: 深紅×墨×生成り
   - レスポンシブ対応
   ========================================= */

:root {
  --ink: #111111;
  --paper: #faf6ef;      /* 生成り */
  --accent: #b80f0a;     /* 深紅 */
  --gold: #c6a969;       /* 鶏油イメージ */
  --muted: #666;
  --radius: 16px;
  --shadow: 0 10px 20px rgba(0,0,0,0.08);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: system-ui, -apple-system, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.75;
}

/* Header */
.site-header {
  background: linear-gradient(180deg, var(--ink), #1b1b1b);
  color: #fff;
  padding: 32px 16px;
  border-bottom: 4px solid var(--accent);
}
.site-header .header-inner {
  max-width: 1080px; margin: 0 auto;
}
.site-header h1 {
  margin: 0 0 4px 0; font-size: clamp(24px, 4vw, 40px); letter-spacing: 0.02em;
}
.subtitle { margin: 0; color: #ddd; }

/* Layout */
.container {
  max-width: 1080px;
  margin: 24px auto 64px;
  padding: 0 16px;
}

.card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
}

figure { margin: 0; }
figure img {
  max-height: 400px;
  width: auto;
  display: block;
  border-radius: calc(var(--radius) - 4px);

}
figcaption {
  margin-top: 8px; color: var(--muted); font-size: 14px;
}

h2 {
  margin: 8px 0 12px; font-size: clamp(20px, 3vw, 28px);
  border-left: 6px solid var(--accent);
  padding-left: 10px;
}

.bullets, .check, .summary-points { padding-left: 20px; margin: 8px 0; }
.check li::marker { color: var(--gold); }
.summary-points li::marker { color: var(--accent); }

/* Grids */
.grid-2 {
  display: grid; gap: 16px; grid-template-columns: 1fr;
}
.grid-3 {
  display: grid; gap: 16px; grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .grid-2 { grid-template-columns: 1.1fr 0.9fr; }
  .grid-3 { grid-template-columns: 1.1fr 0.9fr 0.9fr; }
}
.img-center { text-align: center; }
.img-center img {max-height: 400px; width: auto; margin: 0 auto; }

/* Hero */
.hero { padding: 0; overflow: hidden; }
.hero img { border-radius: var(--radius) var(--radius) 0 0; }
.hero figcaption { padding: 12px 16px 16px; }

/* Footer */
.site-footer {
  text-align: center; padding: 24px 16px; color: var(--muted);
  border-top: 4px solid var(--accent);
  background: #fff;
}

/* Small niceties */
strong { color: var(--accent); }
