/* ============================================================
   pSEO 完成版 共通スタイル（正本・全サイト再利用）
   各サイトは :root の --brand 系を上書きしてブランド色を当てる。
   例) <style>:root{--brand:#0a9fd4;--brand-d:#0782ad}</style> を head 末尾に置く
   ============================================================ */
:root{
  --brand:#2b6cb0; --brand-d:#234e7d; --ink:#20303a; --muted:#5d6f7a;
  --line:#e3eaee; --bg:#f4f8fa; --card:#ffffff; --accent:#ff7a59; --good:#1a8f5e;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;-webkit-font-smoothing:antialiased}
a{color:var(--brand-d);text-decoration:none}
a:hover{text-decoration:underline}
.preview{background:#eef3f6;color:#6a7b85;font-size:12px;text-align:center;padding:5px 10px;border-bottom:1px solid var(--line)}
header.site{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--line)}
.bar{max-width:960px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:18px}
.logo{display:flex;align-items:center;gap:9px;font-weight:800;font-size:19px;color:var(--ink)}
.logo .dot{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 32% 30%,var(--brand),var(--brand-d));display:inline-block}
nav.main{margin-left:auto;display:flex;gap:18px;font-size:14px;font-weight:600}
nav.main a{color:var(--muted)}
.nav-cta{background:var(--brand);color:#fff!important;padding:8px 15px;border-radius:999px;font-weight:700}
.nav-cta:hover{background:var(--brand-d);text-decoration:none}
main{max-width:960px;margin:0 auto;padding:0 18px 60px}
.crumb{font-size:12.5px;color:var(--muted);padding:16px 2px 6px}
h1{font-size:27px;line-height:1.35;margin:8px 0 10px;letter-spacing:.2px}
.lead{color:var(--muted);font-size:15px;margin:0 0 8px;max-width:680px}
.ribbon{display:inline-flex;gap:7px;align-items:center;background:#eafaf3;color:var(--good);font-weight:700;font-size:13px;padding:5px 12px;border-radius:8px;margin:6px 0 22px}
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 28px}
.perk{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:12px 13px;text-align:center}
.perk b{display:block;font-size:14px}
.perk span{font-size:11.5px;color:var(--muted)}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 20px 8px;margin:0 0 26px;box-shadow:0 1px 2px rgba(20,40,55,.04)}
.card h2{font-size:19px;margin:2px 0 4px}
.card .src{font-size:12px;color:var(--muted);margin:2px 0 14px}
table{width:100%;border-collapse:collapse;font-size:14.5px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
thead th{background:#f0f6f9;color:#3f5663;font-size:13px;font-weight:700}
tbody tr:hover{background:#f7fbfd}
td.price{text-align:right;font-weight:700;white-space:nowrap}
td.price .was{display:block;font-size:11px;color:#a6b2ba;font-weight:500;text-decoration:line-through}
.tag-sale{display:inline-block;background:#fff1ec;color:#d8542f;font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px;margin-left:6px}
td.num{text-align:center;white-space:nowrap}
ul.tips{margin:4px 0 8px;padding-left:20px}
ul.tips li{margin:6px 0}
.note{font-size:12.5px;color:var(--muted)}
.cta{background:linear-gradient(135deg,var(--brand),var(--brand-d));border-radius:16px;padding:26px;text-align:center;color:#fff;margin:8px 0 30px}
.cta h3{margin:0 0 4px;font-size:20px}
.cta p{margin:0 0 16px;font-size:13.5px;opacity:.92}
.btn{display:inline-block;background:#fff;color:var(--brand-d)!important;font-weight:800;font-size:16px;padding:14px 34px;border-radius:999px;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.btn:hover{text-decoration:none}
.related h2{font-size:16px}
.related ul{list-style:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.related a{display:block;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 13px}
footer.site{border-top:1px solid var(--line);margin-top:30px;padding:22px 18px;background:#fff}
footer.site .inner{max-width:960px;margin:0 auto;font-size:12.5px;color:var(--muted)}
footer.site b{color:var(--ink)}
@media(max-width:680px){
  nav.main{display:none}
  .perks{grid-template-columns:1fr 1fr}
  .related ul{grid-template-columns:1fr}
  h1{font-size:22px}
}
