:root{--accent:#0f766e;--ink:#1e293b;--muted:#64748b;--line:#e2e8f0;--bg:#f8fafc;--radius:14px;--font:-apple-system,"Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif}
*{box-sizing:border-box}body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.85}
a{color:var(--accent)}img{max-width:100%;height:auto;display:block}
.site-header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.site-header .inner{max-width:1080px;margin:0 auto;padding:18px 24px;display:flex;align-items:center;gap:12px}
.brand{font-weight:800;font-size:20px;color:var(--ink);text-decoration:none}
.brand .dot{color:var(--accent)}
.tag{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:2px 10px}
.container{max-width:1080px;margin:0 auto;padding:32px 24px}
.hero-wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.hero{width:100%;border-radius:calc(var(--radius) + 2px);overflow:hidden;margin-top:24px;aspect-ratio:16/9;object-fit:cover;border:1px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;margin-top:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;transition:.15s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #0f172a14}
.card .thumb{aspect-ratio:16/9;width:100%;object-fit:cover;background:var(--line)}
.card .body{padding:16px}
.card h3{margin:0 0 10px;font-size:16px;line-height:1.5}
.card .meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
.qa{background:var(--accent);color:#fff;border-radius:6px;padding:1px 8px;font-weight:700}
.lede{font-size:15px;color:var(--muted);margin-top:8px}
.article{display:grid;grid-template-columns:220px 1fr;gap:40px;align-items:start;margin-top:8px}
@media(max-width:860px){.article{grid-template-columns:1fr}.toc{position:static!important}}
.toc{position:sticky;top:90px;font-size:14px;border-left:2px solid var(--line);padding-left:16px}
.toc h4{margin:0 0 10px;font-size:12px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.toc a{display:block;padding:4px 0;color:var(--muted);text-decoration:none}
.toc a:hover{color:var(--accent)}
.prose h2{font-size:24px;margin:40px 0 14px;padding-top:8px;border-top:1px solid var(--line);scroll-margin-top:90px}
.prose h3{font-size:18px;margin:24px 0 10px}
.prose p{margin:0 0 16px}
.prose ul,.prose ol{margin:0 0 16px;padding-left:1.4em}
.prose li{margin:4px 0}
/* 強調: 太字は色付き+うっすらマーカー下線 / ==text== は蛍光マーカー */
.prose strong{font-weight:700;color:var(--ink);background:linear-gradient(transparent 62%,color-mix(in srgb,var(--accent) 22%,transparent) 62%)}
.prose mark{background:linear-gradient(transparent 55%,#ffe27a 55%);color:inherit;padding:0 .08em;border-radius:2px}
/* 引用 */
.prose blockquote{margin:0 0 18px;padding:12px 18px;border-left:4px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,#fff);border-radius:0 8px 8px 0;color:#334155}
.prose blockquote p{margin:0 0 6px}.prose blockquote p:last-child{margin:0}
/* 注意ボックス(callout) */
.callout{margin:0 0 18px;padding:14px 16px 14px 16px;border-radius:10px;border:1px solid var(--line);border-left:5px solid #94a3b8;background:#f8fafc}
.callout-label{display:inline-block;font-weight:800;font-size:12px;letter-spacing:.04em;margin-bottom:6px;padding:2px 10px;border-radius:999px;color:#fff;background:#94a3b8}
.callout-body p{margin:0 0 6px}.callout-body p:last-child{margin:0}
.callout.point{border-left-color:#2563eb;background:#eff6ff}.callout.point .callout-label{background:#2563eb}
.callout.warn{border-left-color:#d97706;background:#fffbeb}.callout.warn .callout-label{background:#d97706}
.callout.note{border-left-color:#059669;background:#ecfdf5}.callout.note .callout-label{background:#059669}
.callout.memo{border-left-color:#64748b;background:#f8fafc}.callout.memo .callout-label{background:#64748b}
.inline-img{margin:18px 0;}
.inline-img img{width:100%;border-radius:var(--radius);border:1px solid var(--line);aspect-ratio:16/9;object-fit:cover}
.table-wrap{overflow-x:auto;margin:0 0 18px}
.prose table{border-collapse:collapse;width:100%;font-size:14px}
.prose th,.prose td{border:1px solid var(--line);padding:9px 12px;text-align:left}
.prose th{background:#f1f5f9;font-weight:700}
.crumb{font-size:13px;color:var(--muted);margin-bottom:8px}
.crumb a{text-decoration:none}
.title{font-size:30px;line-height:1.4;margin:6px 0 20px}
.foot{border-top:1px solid var(--line);margin-top:48px;padding:24px;text-align:center;color:var(--muted);font-size:13px;background:#fff}
.foot .dot{color:var(--accent)}