/* 共通スタイル: 落ち着いた技術ドキュメント風 */
:root {
  --bg: #ffffff;
  --fg: #1f2328;
  --muted: #57606a;
  --accent: #4f46e5;
  --accent-weak: #eef2ff;
  --border: #d0d7de;
  --ok: #1a7f37;
  --ng: #cf222e;
  --code-bg: #1e1e2e;
  --max-w: 820px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
  line-height: 1.85;
}
.wrap { max-width: var(--max-w); margin: 0 auto; padding: 32px 20px 96px; }
header.site { border-bottom: 1px solid var(--border); }
header.site .wrap { padding-bottom: 16px; padding-top: 20px; }
header.site .home { color: var(--accent); text-decoration: none; font-weight: 600; }
h1 { font-size: 1.9rem; line-height: 1.4; margin: 0.2em 0 0.4em; }
h2 { font-size: 1.4rem; margin-top: 2em; padding-bottom: 0.2em; border-bottom: 2px solid var(--accent-weak); }
h3 { font-size: 1.15rem; margin-top: 1.6em; color: var(--muted); }
p { margin: 0.8em 0; }
.lead { color: var(--muted); font-size: 1.05rem; }
ul, ol { padding-left: 1.4em; }
li { margin: 0.3em 0; }
code { font-family: "SF Mono", Menlo, Consolas, monospace; font-size: 0.9em; }
:not(pre) > code { background: var(--accent-weak); padding: 0.1em 0.35em; border-radius: 4px; }
pre { border-radius: 8px; overflow: auto; margin: 1.2em 0; }
pre code.hljs { padding: 16px 18px; font-size: 0.88rem; line-height: 1.6; }
.callout { background: var(--accent-weak); border-left: 4px solid var(--accent); border-radius: 0 8px 8px 0; padding: 12px 16px; margin: 1.2em 0; }
.keypoints { background: #f6f8fa; border: 1px solid var(--border); border-radius: 8px; padding: 8px 20px; }

/* クイズ */
.quiz-q { border: 1px solid var(--border); border-radius: 8px; padding: 16px 18px; margin: 14px 0; }
.quiz-q .qtext { font-weight: 600; margin-bottom: 10px; }
.quiz-options { list-style: none; padding: 0; margin: 0; }
.quiz-options li { margin: 8px 0; }
.quiz-opt { display: block; width: 100%; text-align: left; padding: 10px 14px; border: 1px solid var(--border); border-radius: 6px; background: #fff; cursor: pointer; font: inherit; }
.quiz-opt:hover:not(:disabled) { border-color: var(--accent); background: var(--accent-weak); }
.quiz-opt:disabled { cursor: default; }
.quiz-opt.correct { border-color: var(--ok); background: #e6f4ea; }
.quiz-opt.wrong { border-color: var(--ng); background: #fce8e6; }
.quiz-explain { margin-top: 10px; padding: 10px 14px; background: #f6f8fa; border-radius: 6px; font-size: 0.95rem; display: none; }
.quiz-explain.show { display: block; }
.quiz-score { font-weight: 700; margin: 16px 0; padding: 12px 16px; border-radius: 8px; background: var(--accent-weak); }

/* 記述確認問題 */
.written-q { border: 1px solid var(--border); border-radius: 8px; padding: 16px 18px; margin: 14px 0; }
.written-q .qtext { font-weight: 600; }
.toggle-ans { margin-top: 10px; padding: 8px 14px; border: 1px solid var(--accent); color: var(--accent); background: #fff; border-radius: 6px; cursor: pointer; font: inherit; }
.model-ans { margin-top: 12px; padding: 12px 16px; background: #f6f8fa; border-radius: 6px; display: none; }
.model-ans.show { display: block; }

/* ナビ */
.chapter-nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 48px; padding-top: 20px; border-top: 1px solid var(--border); }
.chapter-nav a { color: var(--accent); text-decoration: none; }
.chapter-nav a.disabled { color: var(--muted); pointer-events: none; }

/* ダッシュボード（index） */
.chapter-card { display: block; border: 1px solid var(--border); border-radius: 10px; padding: 16px 18px; margin: 12px 0; text-decoration: none; color: inherit; }
.chapter-card:hover { border-color: var(--accent); box-shadow: 0 2px 8px rgba(79,70,229,0.08); }
.chapter-card .part { color: var(--muted); font-size: 0.85rem; }
.chapter-card .title { font-size: 1.1rem; font-weight: 700; margin: 4px 0; }
.status { display: inline-block; font-size: 0.8rem; padding: 2px 10px; border-radius: 999px; border: 1px solid var(--border); }
.status.done { background: #e6f4ea; border-color: var(--ok); color: var(--ok); }
.status.learning { background: var(--accent-weak); border-color: var(--accent); color: var(--accent); }
.status.todo { background: #f6f8fa; color: var(--muted); }

@media (max-width: 600px) { .wrap { padding: 20px 14px 80px; } h1 { font-size: 1.6rem; } }
