:root {
  --fg: #f0f2f5; /* 基本文字色 */
  --muted: #a9b0b7; /* 補助文字色 */
  --acc: #00c2a8;  /* アクセント（ティール系） */
  --line: rgba(255, 255, 255, .14); /* 罫線 */
  --bg: #0b0d10;   /* 背景（ほぼ黒） */
  --chip: rgba(255, 255, 255, .06); /* チップ背景 */
  --tableHead: rgba(255, 255, 255, .06); /* テーブル見出し */
  /* 固定ヘッダー高さ（ページ先頭の余白調整に使用） */
  --fixed-header-h: 88px;
}

html,
body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
  line-height: 1.7;
}

/* 固定ヘッダー分のアンカー位置補正 */
html { scroll-padding-top: calc(var(--fixed-header-h) + 12px); }

.container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px;
}

header {
  padding: 28px 0 10px;
  border-bottom: 1px solid var(--line);
}

/* 固定ヘッダー下にページタイトルが隠れないよう余白を確保 */
.page-header { margin-top: var(--fixed-header-h); }

@media (max-width: 768px) {
  :root { --fixed-header-h: 76px; }
}

h1 {
  font-size: clamp(24px, 3vw, 34px);
  margin: 0 0 8px;
}

.lead {
  color: var(--muted);
  margin: 0 0 18px;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 14px 0 0;
}

.chip {
  background: var(--chip);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  color: #e2e8f0;
}

nav.toc {
  background: #111418;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  margin: 22px 0;
}

nav.toc a {
  color: var(--acc);
  text-decoration: none;
}

nav.toc ol {
  margin: 0 0 0 18px;
  padding: 0;
}

section {
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
}

h2 {
  font-size: clamp(20px, 2.4vw, 28px);
  margin: 0 0 12px;
}

h3 {
  font-size: 18px;
  margin: 24px 0 8px;
  color: #fff;
}

p {
  margin: 8px 0;
}

.grid {
  display: grid;
  gap: 20px;
}

@media (min-width: 900px) {
  .grid-2 {
    grid-template-columns: 1fr 1fr;
  }
}

figure {
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  background: #101418;
}

figure img {
  width: 100%;
  display: block;
}

figure figcaption {
  font-size: 12px;
  color: var(--muted);
  padding: 10px;
  border-top: 1px solid var(--line);
  background: transparent;
}

/* layoutセクション内のキャプションを拡大し白文字に */
#layout figure figcaption {
  font-size: 14px;
  color: #fff;
}

table {
  width: 100%;
  border-collapse: collapse;
  background: #101418;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}

thead {
  background: var(--tableHead);
}

th,
td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
}

th {
  font-weight: 600;
  text-align: left;
}

tbody tr:hover {
  background: rgba(255, 255, 255, .03);
}

.note {
  font-size: 12px;
  color: var(--muted);
}

.kakomi {
  border-left: 4px solid var(--acc);
  background: rgba(0, 194, 168, .08);
  padding: 12px 14px;
  border-radius: 6px;
}

footer {
  padding: 28px 0 14px;
  color: var(--muted);
  font-size: 12px;
}

.cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.btn {
  display: inline-block;
  background: var(--acc);
  color: #fff;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 600;
}

.btn.sub {
  background: #1f2937;
}

.mono {
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 12px;
  color: #b8c0c8;
}

a {
  color: var(--acc);
}
