* { margin: 0; padding: 0; box-sizing: border-box; }
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Hiragino Sans', 'Noto Sans JP', sans-serif;
  background: #fff; color: #333; line-height: 1.8;
  /* LAB と同じ body 直書きレイアウト (5/11): body 自体に余白を持たせて
     全ページ統一の左右マージン (24px) と最大幅 (800px) を確保。
     これで .container 未ラップのページ (marketing/index.html 等) でも
     スマホの上下左右にゆとりが出る。 */
  max-width: 800px; margin: 0 auto; padding: 40px 24px 80px;
}
/* .container は既存 HTML (privacy/terms/index.html 等) の互換維持用。
   body 側で max-width / padding を持つので、container は透明な wrapper
   として何も装飾しない (二重余白回避)。 */
.container {
  max-width: none; margin: 0; padding: 0;
}
h1 { font-size: 24px; margin-bottom: 8px; color: #1a1a2e; }
.meta { color: #888; font-size: 13px; margin-bottom: 32px; }
h2 { font-size: 18px; margin: 32px 0 12px; color: #1a1a2e; border-left: 4px solid #2196F3; padding-left: 12px; }
h3 { font-size: 15px; margin: 20px 0 8px; color: #444; }
p, ul, ol { margin-bottom: 16px; font-size: 15px; }
ul, ol { padding-left: 24px; }
li { margin-bottom: 6px; }
a { color: #2196F3; }
.footer { margin-top: 48px; padding-top: 24px; border-top: 1px solid #eee; color: #888; font-size: 13px; }
.notice {
  background: #f7f9fc; border-left: 4px solid #888;
  padding: 14px 16px; margin: 20px 0; font-size: 13px; color: #555;
}
.feature-grid {
  display: grid; grid-template-columns: 1fr; gap: 16px;
  margin: 20px 0;
}
@media (min-width: 600px) {
  .feature-grid { grid-template-columns: 1fr 1fr; }
}
.feature {
  background: #fafbfd; border: 1px solid #eef1f5;
  border-radius: 8px; padding: 16px;
}
.feature h3 { margin-top: 0; color: #1a1a2e; }
.feature p { margin-bottom: 0; font-size: 14px; color: #555; }
.lead { font-size: 16px; color: #1a1a2e; margin-bottom: 24px; }

/* ── LP ヒーロー専用 ── */
/* container 内に配置 (privacy/terms と統一)。container が左右 24px padding を持つため
   hero 自身は左右 padding を持たない。下の border で section 区切り。 */
.hero {
  background: linear-gradient(135deg, #fcf9f6 0%, #ffffff 60%);
  padding: 32px 16px 32px;
  text-align: center;
  border: 1px solid #eef1f5;
  border-radius: 12px;
  margin-bottom: 16px;
}
.hero-icon {
  width: 96px; height: 96px;
  border-radius: 22px;
  margin: 0 auto 24px;
  background: #fff;
  box-shadow: 0 4px 16px rgba(0,0,0,0.06);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.hero-icon img { width: 100%; height: 100%; object-fit: cover; }
.hero h1 {
  font-size: 32px; line-height: 1.4; margin-bottom: 16px;
  color: #1a1a2e; font-weight: 800;
}
.hero h1 small { display: block; font-size: 18px; color: #555; font-weight: 600; margin-top: 8px; }
.hero-sub {
  font-size: 15px; color: #555; max-width: 560px; margin: 0 auto 32px;
}
.cta-row {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
  margin-bottom: 12px;
}
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; border-radius: 8px;
  font-size: 14px; font-weight: 700;
  text-decoration: none; transition: opacity 0.2s;
}
.btn:hover { opacity: 0.85; }
.btn-app-store { background: #1a1a2e; color: #fff; }
.btn-google-play { background: #2196F3; color: #fff; }
.btn-disabled { opacity: 0.55; cursor: not-allowed; }
.cta-note { font-size: 12px; color: #888; }

/* セクションラッパー */
.section { padding: 16px 0 8px; }
.section + .section { border-top: 1px solid #f0f2f5; margin-top: 24px; padding-top: 32px; }
@media (min-width: 600px) {
  .hero h1 { font-size: 36px; }
}
