
/* ===== RM-759 初心者向けオリパ遊び方ガイド =====
   縦スクロール型LP / モバイル402px基準 (iPhone 16 Pro)
   用語: オリパ(モノ) / ガチャを引く(操作) / PT表記は 500PT 形式
   配色: DOPA 実ブランドカラー
     - プライマリ  #CD3054 (ローズ/クリムゾン: CTA)
     - ネイビー    #132337 (地・見出し)
     - サブ文字    #3F4E60
     - ゴールド    #E8B53D (マスコット王冠 → アクセント) */

:root {
  --brand:        #cd3054;   /* DOPA プライマリ（CTA・アクセント） */
  --brand-dark:   #a8254a;
  --brand-soft:   #fdeef2;   /* ローズ淡色（背景） */
  --brand-line:   #f5c6d2;   /* ローズ罫線 */
  --navy:         #132337;   /* DOPA ネイビー */
  --navy-2:       #2c4a78;   /* 信頼・透明性の補助（PT還元など） */
  --navy-soft:    #eaf0f9;
  --navy-line:    #cdd9ec;
  --gold:         #e8b53d;   /* 王冠カラー（★・ハイライト） */
  --ink:          #132337;
  --ink-soft:     #3f4e60;
  --line:         #e6e8ee;
  --bg:           #fafbfc;
  --card:         #ffffff;
  --warn-bg:      #fff8e6;
  --warn-line:    #f3d27a;
  --radius:       16px;
  --shadow:       0 4px 18px rgba(19,35,55,.08);
  --maxw:         402px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", system-ui, sans-serif;
  color: var(--ink);
  background: #dde1ea;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  font-size: 16.5px;
  overflow-x: hidden;
}


/* モバイル幅をシミュレートする外枠（実装時は body 全幅でOK） */
.app {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  background: var(--bg);
  min-height: 100vh;
  overflow-x: hidden;
}

/* 横オーバーフロー防止: flex/grid 子の最小幅を解除し、はみ出しを根絶 */
.rec-grid, .rec-card2, .rec-card2 .body,
.methods, .method, .assure-card, .assure-card .txt,
.options, .opt, .flow, .term-chips, .trust-badges {
  min-width: 0;
}
img, table { max-width: 100%; }
.rec-card2 .nm, .rec-card2 .desc, .index a { overflow-wrap: anywhere; }


section { padding: 32px 20px; scroll-margin-top: 12px; }
section + section { border-top: 1px solid var(--line); }

.eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: var(--brand);
  background: var(--brand-soft);
  padding: 4px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
  letter-spacing: .04em;
}

h2.sec-title {
  font-size: 23px;
  font-weight: 900;
  line-height: 1.4;
  margin-bottom: 18px;
  letter-spacing: .01em;
  color: var(--navy);
}
h2.sec-title .num {
  color: var(--brand);
  margin-right: 8px;
}

h3.block-title {
  font-size: 18px;
  font-weight: 800;
  margin: 24px 0 12px;
  padding-left: 12px;
  border-left: 5px solid var(--brand);
  line-height: 1.5;
  color: var(--navy);
}

p { margin-bottom: 13px; color: var(--ink); }
.note { font-size: 14px; color: var(--ink-soft); }


.pt { font-weight: 800; color: var(--brand); font-variant-numeric: tabular-nums; }
.tbc { /* 〔要確認〕 */
  font-size: 11px; font-weight: 700; color: #b06a00;
  background: var(--warn-bg); border: 1px solid var(--warn-line);
  border-radius: 6px; padding: 1px 6px; white-space: nowrap;
}

/* ---------- CTA ---------- */
.cta {
  display: block;
  width: 100%;
  text-align: center;
  background: var(--brand);
  color: #fff;
  font-weight: 800;
  font-size: 16px;
  padding: 16px;
  border: none;
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 6px 16px rgba(205,48,84,.30);
  cursor: pointer;
  transition: transform .12s ease, background .12s ease;
}
.cta:active { transform: translateY(1px); background: var(--brand-dark); }
.cta.secondary {
  background: #fff; color: var(--brand);
  border: 2px solid var(--brand); box-shadow: none;
}
.cta-recap { margin-top: 24px; }

/* ---------- Hero ---------- */
.hero {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(205,48,84,.10) 0%, rgba(205,48,84,0) 55%),
    linear-gradient(165deg, #ffffff 0%, #fdeef2 55%, #fbe0e7 100%);
  text-align: center;
  padding: 36px 20px 40px;
  border-top: none;
}
.hero .brand-logo {
  display: block;
  width: auto; height: 38px;
  margin: 0 auto 14px;
  object-fit: contain;
}
.hero .mascot {
  width: 240px; height: auto; max-width: 84%;
  margin: 0 auto 14px;
  display: block;
  object-fit: contain;
  filter: drop-shadow(0 12px 18px rgba(205,48,84,.20));
}

/* セクション内の装飾フィギュア（マスコット） */
.section-figure {
  display: block;
  width: 180px; height: auto; max-width: 64%;
  margin: 18px auto 6px;
  object-fit: contain;
  filter: drop-shadow(0 8px 14px rgba(19,35,55,.14));
}
.hero .badge {
  display: inline-block;
  color: var(--brand);
  background: #fff;
  border: 1px solid var(--brand-line);
  font-weight: 800; font-size: 12px;
  padding: 5px 14px;
  border-radius: 999px;
  letter-spacing: .06em;
  box-shadow: 0 2px 8px rgba(205,48,84,.10);
  margin-bottom: 14px;
}
.hero h1 {
  font-size: 31px; font-weight: 900; line-height: 1.3;
  margin: 4px 0 18px; letter-spacing: .01em; color: var(--navy);
}
.hero h1 em { color: var(--brand); font-style: normal; }
.hero .lead {
  font-size: 14.5px; color: var(--ink-soft);
  text-align: left; line-height: 1.9;
  max-width: 360px; margin: 0 auto 24px;
}
.hero .lead b { color: var(--navy); font-weight: 800; }



/* ---------- Index ---------- */
.index { background: var(--card); }
.index ol {
  list-style: none; counter-reset: idx;
  display: grid; gap: 8px;
}
.index li { counter-increment: idx; }
.index a {
  display: flex; align-items: center; gap: 12px;
  text-decoration: none; color: var(--ink);
  background: var(--bg); border: 1px solid var(--line);
  border-radius: 12px; padding: 12px 14px; font-weight: 700; font-size: 14px;
  transition: border-color .12s, background .12s;
}
.index a:active { border-color: var(--brand); background: var(--brand-soft); }
.index a::before {
  content: counter(idx);
  flex: 0 0 26px; height: 26px;
  background: var(--brand); color: #fff;
  border-radius: 50%; font-size: 13px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}

/* ---------- Highlight / guarantee box ---------- */
.callout {
  background: var(--brand-soft);
  border: 1px solid var(--brand-line);
  border-radius: var(--radius);
  padding: 16px;
  margin: 16px 0;
}
.callout .ttl { font-weight: 800; color: var(--brand-dark); margin-bottom: 6px; }
.callout .fine { font-size: 12px; color: var(--ink-soft); margin-bottom: 0; }

/* ---------- Recommend cards ---------- */
.rec-card {
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 16px; margin-bottom: 12px;
  border-top: 3px solid var(--brand);
}
.rec-card .head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.rec-card .icon {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--brand-soft); display: flex; align-items: center;
  justify-content: center; font-size: 22px;
}
.rec-card .name { font-weight: 800; color: var(--navy); }
.rec-card .stars { margin-left: auto; color: var(--gold); font-size: 14px; letter-spacing: 1px; }
.rec-card dl { display: grid; grid-template-columns: auto 1fr; gap: 4px 12px; font-size: 13px; }
.rec-card dt { color: var(--ink-soft); }
.rec-card dd { font-weight: 700; text-align: right; color: var(--navy); }

/* ---------- Recommend grid（実オリパのサムネ付き） ---------- */
.rec-grid { display: grid; gap: 12px; margin: 14px 0 8px; }
.rec-card2 {
  grid-template-columns: 104px 1fr; gap: 12px;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow);
  overflow: hidden; text-decoration: none; color: inherit;
  transition: transform .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.rec-card2:active { transform: translateY(1px); border-color: var(--brand); }
.rec-card2 .thumb { position: relative; background: #f1f3f7; }
.rec-card2 .thumb img {
  min-height: 112px;
  object-fit: cover; display: block;
}
.rec-card2 .thumb .rank {
  position: absolute; left: 0; top: 0;
  background: var(--brand); color: #fff; font-size: 10px; font-weight: 800;
  padding: 3px 9px; border-bottom-right-radius: 10px; letter-spacing: .02em;
}
.rec-card2 .body { padding: 12px; display: flex; flex-direction: column; gap: 7px; }
.rec-card2 .nm { font-weight: 800; color: var(--navy); font-size: 14px; line-height: 1.4; }
.rec-card2 .tags { display: flex; flex-wrap: wrap; gap: 6px; }
.rec-card2 .tag {
  font-size: 11px; font-weight: 700; border-radius: 999px; padding: 2px 9px; line-height: 1.6;
}
.rec-card2 .tag.price { background: var(--brand-soft); color: var(--brand-dark); }
.rec-card2 .tag.warranty { background: var(--navy-soft); color: var(--navy-2); }
.rec-card2 .desc { font-size: 12px; color: var(--ink-soft); margin: 0; line-height: 1.6; }

/* rankバッジの役割別カラー */
.rec-card2 .rank.free { background: #2e9c4a; }
.rec-card2 .rank.hot  { background: var(--gold); color: #5a4500; }
.rec-card2 .rank.hi   { background: var(--navy-2); }
/* ログインボーナス用サムネ（マスコット） */
.rec-card2 .thumb.login {
  background: linear-gradient(160deg, #fdeef2, #fbe0e7);
  display: flex; align-items: center; justify-content: center;
}
.rec-card2 .thumb.login img { width: 76px; height: 76px; min-height: 0; object-fit: contain; }
/* リード文 */
.rec-lead { font-size: 13px; color: var(--ink-soft); margin: 4px 0 0; }
.rec-lead b { color: var(--brand); }



/* ---------- Lists ---------- */
ul.checklist, ul.fail-list { list-style: none; display: grid; gap: 8px; }
ul.checklist li, ul.fail-list li {
  position: relative; padding-left: 26px; font-size: 14px;
}
ul.fail-list li::before { content: "⚠️"; position: absolute; left: 0; }
ul.checklist li::before {
  content: "✓"; position: absolute; left: 0;
  color: var(--brand); font-weight: 900;
}

/* ---------- Tables ---------- */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin: 8px 0; }
table {
  width: 100%; border-collapse: collapse; font-size: 13px;
  background: var(--card); border-radius: 12px; overflow: hidden;
}
th, td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--line); vertical-align: top; }
thead th { background: var(--navy); color: #fff; font-weight: 700; font-size: 12px; }
tbody tr:last-child td { border-bottom: none; }
tbody tr:nth-child(even) td { background: #fbf4f6; }

/* ---------- Term box ---------- */
.terms { display: grid; gap: 10px; margin: 12px 0; }
.term {
  background: var(--card); border: 1px solid var(--line);
  border-radius: 12px; padding: 12px 14px;
  border-left: 4px solid var(--navy-2);
}
.term b { color: var(--navy-2); }

/* ---------- Steps ---------- */
ol.steps { list-style: none; counter-reset: st; display: grid; gap: 0; margin: 12px 0; }
ol.steps li {
  counter-increment: st; position: relative;
  padding: 0 0 18px 40px; font-size: 14px;
}
ol.steps li::before {
  content: counter(st); position: absolute; left: 0; top: 0;
  width: 26px; height: 26px; background: var(--brand); color: #fff;
  border-radius: 50%; font-weight: 800; font-size: 13px;
  display: flex; align-items: center; justify-content: center; z-index: 1;
}
ol.steps li:not(:last-child)::after {
  content: ""; position: absolute; left: 12px; top: 26px; bottom: 0;
  width: 2px; background: var(--brand-line);
}
ol.steps .step-ttl { font-weight: 700; }

/* ---------- Flow chips ---------- */
.flow { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin: 12px 0; }
.flow .chip {
  background: var(--brand-soft); color: var(--brand-dark);
  border: 1px solid var(--brand-line); border-radius: 999px;
  padding: 8px 12px; font-size: 13px; font-weight: 700;
}
.flow .arrow { color: var(--brand); font-weight: 700; }

/* ---------- Methods (registration / payment / genre) ---------- */
.methods { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 14px 0; }
.method {
  display: flex; align-items: center; gap: 10px;
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 11px 13px; font-weight: 700; font-size: 13px; color: var(--navy);
}
.method .ico {
  flex: 0 0 auto; width: 34px; height: 34px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  background: var(--brand-soft); overflow: hidden;
}
/* 汎用ラインアイコン（ブランドカラーのストローク） */
.method .ico svg { width: 19px; height: 19px; stroke: var(--brand); fill: none; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.method .ico.navy { background: var(--navy-soft); }
.method .ico.navy svg { stroke: var(--navy-2); }
/* ブランド別カラーバッジ（白抜きアイコン/ロゴ） */
.method .ico.b-google { background: #fff; border: 1px solid var(--line); }
.method .ico.b-google svg { width: 21px; height: 21px; stroke: none; }
.method .ico.b-apple  { background: #000; }
.method .ico.b-apple svg { stroke: none; fill: #fff; width: 18px; height: 18px; }
.method .ico.b-line   { background: #06c755; }
.method .ico.b-line svg { fill: #fff; stroke: none; }
.method .ico.b-paypay { background: #ff0033; }
.method .ico.b-merpay { background: #ff0211; }
.method .ico.b-amazon { background: #232f3e; }
.method .ico.b-amazon svg { fill: none; stroke: #ff9900; stroke-width: 2.4; }

/* 塗りつぶし系アイコン（スパークル等） */
.method .ico.solid svg { fill: var(--brand); stroke: none; }
.method .ico.solid.navy svg { fill: var(--navy-2); stroke: none; }
/* 文字バッジ（PayPay / メルペイ） */
.method .ico .lbl { color: #fff; font-weight: 900; line-height: 1; }
.method .ico.b-paypay .lbl { font-size: 18px; }
.method .ico.b-merpay .lbl { font-size: 12px; letter-spacing: -.04em; font-style: italic; }




/* ---------- Receive options ---------- */
.options { display: grid; gap: 12px; margin: 12px 0; }
.opt {
  border: 2px solid var(--line); border-radius: var(--radius);
  padding: 16px; background: var(--card);
}
.opt.ship { border-color: var(--brand-line); }
.opt.ship .opt-ttl { color: var(--brand); }
.opt.refund { border-color: var(--navy-line); }
.opt.refund .opt-ttl { color: var(--navy-2); }
.opt .opt-ttl { font-weight: 800; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }

/* ---------- FAQ accordion ---------- */
.faq { display: grid; gap: 8px; }
details.qa {
  background: var(--card); border: 1px solid var(--line);
  border-radius: 12px; overflow: hidden;
}
details.qa summary {
  list-style: none; cursor: pointer; padding: 14px 44px 14px 16px;
  font-weight: 700; font-size: 14px; position: relative; color: var(--navy);
}
details.qa summary::-webkit-details-marker { display: none; }
details.qa summary::before { content: "Q. "; color: var(--brand); font-weight: 900; }
details.qa summary::after {
  content: "+"; position: absolute; right: 16px; top: 50%;
  transform: translateY(-50%); font-size: 20px; color: var(--brand);
  transition: transform .2s;
}
details.qa[open] summary::after { content: "−"; }
details.qa[open] summary { background: var(--brand-soft); }
details.qa .ans {
  padding: 14px 16px 16px; font-size: 14px; color: var(--ink-soft);
}
details.qa .ans::before { content: "A. "; color: var(--navy-2); font-weight: 800; }

/* ---------- Mascot cheer (§4) ---------- */
.mascot-cheer {
  display: flex; align-items: center; gap: 14px;
  margin: 22px 0 4px; justify-content: center;
}
.mascot-cheer img {
  flex: 0 0 auto; width: 92px; height: 92px; object-fit: contain;
  filter: drop-shadow(0 6px 10px rgba(205,48,84,.18));
}
.mascot-cheer .bubble {
  position: relative; margin: 0;
  background: #fff; border: 2px solid var(--brand);
  color: var(--brand-dark); font-weight: 800; font-size: 15px;
  line-height: 1.5; border-radius: 14px; padding: 12px 16px;
}
.mascot-cheer .bubble::before,
.mascot-cheer .bubble::after {
  content: ""; position: absolute; right: 100%; top: 50%;
  border: 8px solid transparent; transform: translateY(-50%);
}
.mascot-cheer .bubble::before { border-right-color: var(--brand); margin-right: 0; }
.mascot-cheer .bubble::after { border-right-color: #fff; margin-right: -3px; }

/* ---------- Support ---------- */
.support {
  background: linear-gradient(160deg, #ffffff, var(--navy-soft));
}
.support .box {
  background: var(--card); border-radius: var(--radius);
  padding: 18px; box-shadow: var(--shadow);
}
.support .support-head { display: flex; align-items: flex-start; gap: 12px; }
.support .support-head img {
  flex: 0 0 auto; width: 64px; height: 64px; object-fit: contain;
  filter: drop-shadow(0 4px 8px rgba(19,35,55,.15));
}
.support .support-head p { margin: 0; }
.support .links { display: flex; gap: 8px; margin-top: 14px; }
.support .links a {
  flex: 1; text-align: center; text-decoration: none;
  border: 2px solid var(--navy-2); color: var(--navy-2);
  border-radius: 999px; padding: 10px; font-weight: 800; font-size: 14px;
}

/* ---------- Footer ---------- */
footer {
  background: linear-gradient(165deg, var(--brand) 0%, var(--brand-dark) 100%);
  color: rgba(255,255,255,.95);
  padding: 36px 24px 40px; text-align: center; font-size: 13.5px;
}
footer p { color: rgba(255,255,255,.95); }
footer .logo { font-size: 26px; font-weight: 900; color: #fff; letter-spacing: .08em; }
footer .logo span { color: var(--gold); }
footer .tag { margin: 8px 0; }
footer .taglines {
  list-style: none; margin: 14px 0 10px; display: grid; gap: 8px;
}
footer .taglines li {
  color: #fff; font-weight: 800; font-size: 15px; line-height: 1.5;
}
footer .taglines li::before {
  content: "“"; color: var(--gold); font-weight: 900; margin-right: 2px;
}
footer .taglines li::after { content: "”"; color: var(--gold); font-weight: 900; margin-left: 2px; }

footer .copy { font-size: 11px; color: rgba(255,255,255,.75); margin-top: 14px; }



/* ===================== Responsive ===================== */

/* 小型スマホ（〜359px）: 余白・文字・カードを詰める */
@media (max-width: 359px) {
  body { font-size: 14px; }
  section { padding: 28px 16px; }
  .hero { padding: 28px 16px 32px; }
  .hero .mascot { width: 200px; height: auto; }
  .hero h1 { font-size: 22px; }
  h2.sec-title { font-size: 18px; }
  .methods { grid-template-columns: 1fr 1fr; }
  .rec-card2 { grid-template-columns: 84px 1fr; }
  .rec-card2 .thumb img { width: 84px; min-height: 100px; }
  .flow { gap: 5px; }
  .flow .chip { padding: 7px 10px; font-size: 12px; }
}

/* タブレット（600px〜）: 枠を広げ、グリッドを多段化して間延びを防ぐ */
@media (min-width: 600px) {
  body { background: #dde1ea; }
  .app { max-width: 768px; box-shadow: 0 10px 40px rgba(19,35,55,.10); }
  section { padding: 44px 40px; }
  .hero { padding: 52px 40px 56px; }
  .hero .mascot { width: 280px; height: auto; }
  .hero h1 { font-size: 30px; }
  .hero .lead { font-size: 15px; max-width: 600px; margin-left: auto; margin-right: auto; }
  .index ol { grid-template-columns: 1fr 1fr; }
  .rec-grid { grid-template-columns: 1fr 1fr; }
  .methods { grid-template-columns: repeat(4, 1fr); }
  .options { grid-template-columns: 1fr 1fr; align-items: start; }
  .support .links a, .cta { max-width: 420px; margin-left: auto; margin-right: auto; }
}

/* デスクトップ（960px〜）: さらに広く、おすすめは縦型3カラム */
@media (min-width: 960px) {
  .app { max-width: 1000px; }
  section { padding: 56px 64px; }
  .hero h1 { font-size: 34px; }
  .index ol { grid-template-columns: repeat(2, 1fr); }
  .rec-grid { grid-template-columns: repeat(3, 1fr); }
  .rec-card2 { grid-template-columns: 1fr; }
  .rec-card2 .thumb img { width: 100%; min-height: 0; }
  .rec-card2 .body { padding: 12px 14px 16px; }
  .terms { grid-template-columns: 1fr 1fr; }
}

/* ===== ブラッシュアップ追加分（UX検証反映） ===== */

/* ヒーロー: 信頼バッジ（数字を主役にした3分割の実績） */
.trust-badges {
  list-style: none;
  display: flex;
  align-items: center;
  margin: 22px auto 24px;
  max-width: 340px;
}
.trust-badges li {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  position: relative;
  padding: 0 6px;
}
.trust-badges li:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  width: 1px; height: 30px;
  background: var(--brand-line);
}
.trust-badges li b {
  font-size: 26px;
  font-weight: 900;
  color: var(--brand);
  line-height: 1;
  letter-spacing: -.02em;
}
.trust-badges li b small {
  font-size: 13px;
  font-weight: 800;
  margin-left: 1px;
}
.trust-badges li span {
  font-size: 11px;
  color: var(--ink-soft);
  font-weight: 700;
  letter-spacing: .02em;
}

/* ヒーロー: 無料訴求（CTA直前の控えめな一文） */
.hero-free {
  font-size: 13.5px;
  line-height: 1.7;
  color: var(--ink-soft);
  margin: 0 auto 16px;
  max-width: 340px;
}
.hero-free b { color: var(--brand); font-weight: 800; }
.hero-fine {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 12px;
  opacity: .8;
}




/* 安心ブロック（ミニマル・横並びリスト型） */
.assurance { background: var(--card); }
.assure-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 8px;
}
.assure-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 4px;
  text-align: left;
}
.assure-card + .assure-card { border-top: 1px solid var(--line); }
.assure-card .ic {
  flex: 0 0 auto;
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--brand-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--brand);
}
.assure-card .ic svg { width: 24px; height: 24px; }
.assure-card .txt { flex: 1 1 auto; min-width: 0; }
.assure-card .ttl {
  font-weight: 800;
  color: var(--navy);
  margin: 2px 0 4px;
  font-size: 16.5px;
}
.assure-card p { font-size: 14.5px; color: var(--ink-soft); margin: 0; line-height: 1.75; }




/* 用語ミニチップ */
.term-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 4px 0 18px;
}
.term-chips .tchip {
  background: var(--navy-soft);
  border: 1px solid var(--navy-line);
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--navy-2);
}
.term-chips .tchip b { color: var(--navy); }

/* フッター: 年齢・健全性注記 */
footer .age-note {
  font-size: 11.5px;
  color: rgba(255,255,255,.85);
  background: rgba(0,0,0,.12);
  border-radius: 10px;
  padding: 10px 14px;
  max-width: 340px;
  margin: 16px auto 0;
  line-height: 1.7;
}


/* 安心ブロックはPCでも縦リスト（区切り線を活かす）。最大幅で間延び防止 */

@media (min-width: 600px) {
  .assure-grid { max-width: 640px; }
}



