:root{
  --bg:#f6f7fb; --card:#ffffff; --txt:#1a1f2e; --sub:#5b6478;
  --accent:#5b8cff; --accent2:#3b6ae0; --line:#e6e9f2; --soft:#eef1fa;
  --ok:#1fb37a; --ad:#eef0f6;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font-family:"Segoe UI","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;line-height:1.75}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.narrow{max-width:780px}

/* ヘッダー */
header{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.hd{display:flex;align-items:center;justify-content:space-between;height:62px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--txt)}
.logo:hover{text-decoration:none}
.logo .mk{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#5b8cff,#7a5bff);
  display:flex;align-items:center;justify-content:center}
.logo .mk svg{width:20px;height:20px;fill:#fff}
.logo small{display:block;font-weight:500;font-size:11px;color:var(--sub);letter-spacing:.5px}
nav.main a{color:var(--sub);font-size:14px;margin-left:18px}
nav.main a:hover{color:var(--txt);text-decoration:none}
@media(max-width:680px){ nav.main{display:none} }

/* 広告枠 */
.ad{background:var(--ad);border:1px dashed #c7cde0;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:#9aa2bd;
  position:relative;font-size:12px;letter-spacing:1px}
.ad .lbl{position:absolute;top:5px;left:8px;font-size:10px;color:#aab1c9}
.ad-leader{height:96px;margin:18px 0}

/* パンくず・記事本文 */
.crumbs{font-size:13px;color:var(--sub);margin:18px 0 6px}
article{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:30px 34px;margin:8px 0}
article h1{font-size:28px;margin:0 0 6px;line-height:1.35}
article h2{font-size:20px;margin:34px 0 12px;padding-top:8px;border-top:1px solid var(--line)}
article h3{font-size:16px;margin:22px 0 8px}
article p{margin:12px 0}
article ul,article ol{margin:12px 0;padding-left:24px}
article li{margin:6px 0}
article .updated{color:var(--sub);font-size:13px;margin:0 0 18px}
article .lead{font-size:16px;color:#36405c}
.cta{display:inline-block;background:var(--accent);color:#fff;font-weight:700;padding:12px 22px;
  border-radius:10px;margin:8px 0;font-size:15px}
.cta:hover{background:var(--accent2);text-decoration:none}
.callout{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:16px 0;font-size:14px}
.faq dt{font-weight:700;margin-top:16px}
.faq dd{margin:4px 0 0;color:#36405c}
table.tbl{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px}
table.tbl th,table.tbl td{border:1px solid var(--line);padding:8px 10px;text-align:left}
table.tbl th{background:var(--soft)}

/* 記事カード（一覧用） */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:16px 0}
.cards a{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;display:block;color:var(--txt)}
.cards a:hover{border-color:#cdd6f5;box-shadow:0 8px 24px rgba(50,70,140,.08);text-decoration:none}
.cards h3{margin:0 0 6px;font-size:16px}
.cards p{margin:0;color:var(--sub);font-size:13px}
@media(max-width:680px){ .cards{grid-template-columns:1fr} }

/* フッター（全ページ共通） */
footer.site{border-top:1px solid var(--line);margin-top:46px;padding:26px 0;color:var(--sub);font-size:13px;background:var(--card)}
footer.site .cols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px}
footer.site .flinks a{color:var(--sub);margin-right:16px}
footer.site .flinks a:hover{color:var(--txt)}
footer.site .note{max-width:420px;text-align:right}
@media(max-width:680px){ footer.site .note{text-align:left} }
