/* ============================================================
   site.css — infra-study.org 共通デザインシステム（単一の真実源）
   ヘッダー / ブランド / CTA語彙 / フッター / 配色トークン。
   全ページがこれを最初に link する。章ページは続けて chapter.css を
   link し、章固有の :root（濃色パレット）で上書きする（＝章は再塗装なし）。
   新規ページはこのファイルのクラス語彙だけを使うこと（ドリフト防止）。
   ------------------------------------------------------------
   CTA語彙（この3つに集約。旧名 .nav-book/.nav-toc/.nav-cta は
   当面エイリアスとして残すが、新規は canonical 名を使う）:
     .header-cta   … 主ボタン（青・「演習を予約」等）  = 旧 .nav-book / .nav-cta
     .header-link  … 副リンク（枠線ゴースト・「← 目次」等）= 旧 .nav-toc
     .header-nav + .nav-link … ランディングの横並びナビ
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Noto+Sans+JP:wght@300;400;500&display=swap');

:root{
  --bg:#0d1117; --bg2:#161b22; --bg3:#1c2230; --border:#2a3441;
  --text:#e2eaf3; --text-strong:#e6edf3; --muted:#9aacbc; --muted-dim:#3a4a5c;
  --accent:#58a6ff; --green:#3fb950; --amber:#d29922; --purple:#bc8cff; --coral:#f78166; --red:#f85149;
  --accent-bg:#1c2d3d; --accent-bg-hi:#1e3550; --accent-border:#2a4060; --accent-text:#8ecbff; --accent-deep:#16263a;
  --green-bg:#1c2616; --green-border:#2a4020; --green-text:#6fd672;
  --amber-bg:#1c1a0d; --amber-border:#3a3010; --amber-text:#d4a236;
  --purple-bg:#1c1830; --purple-border:#3a2860; --purple-text:#c4b5fd;
  --coral-bg:#1c0e0a; --coral-border:#3a1a10; --coral-text:#f9826c;
  --font-sans:'Noto Sans JP',-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;
  --maxw:1080px;
}

/* ── base（最小限。ul/list-style や code の装飾はページ側/chapter.css に委譲）── */
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-weight:300;font-size:14px;line-height:1.7}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
strong{color:var(--text-strong);font-weight:500}

/* ── ヘッダー本体 ── */
.site-header{position:sticky;top:0;z-index:50;background:rgba(13,17,23,0.92);border-bottom:1px solid var(--border);backdrop-filter:blur(8px)}
.header-inner{max-width:min(96vw,1800px);margin:0 auto;height:60px;padding:0 24px;display:flex;align-items:center;gap:32px}

/* ── ブランド（左側・全アーキタイプ共通）── */
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{width:28px;height:28px;border-radius:6px;background:var(--accent-bg);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:600;color:var(--accent);font-size:13px}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-name{font-size:13px;color:var(--text-strong);font-weight:500}
.brand-domain{font-size:11px;color:var(--muted);font-family:var(--font-mono)}
.brand-sub{font-size:11px;color:var(--muted)}

/* ── パンくず ── */
.crumb{font-size:13px;color:var(--muted)}
.crumb .sep{color:var(--muted-dim);margin:0 6px}
.crumb .now{color:var(--text-strong)}
.badge-free{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:0.08em;color:var(--green-text);background:var(--green-bg);border:1px solid var(--green-border);padding:2px 8px;border-radius:99px;margin-right:8px}

/* ── CTA語彙 ──────────────────────────────────────────────
   主ボタン（青）: .header-cta（＝旧 .nav-book / .nav-cta のエイリアス統合）*/
.header-cta,.nav-book,.nav-cta{margin-left:14px;font-size:13px;padding:8px 14px;border-radius:6px;background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent-text);font-weight:600;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;text-decoration:none}
.header-cta:hover,.nav-book:hover,.nav-cta:hover{background:var(--accent-bg-hi);border-color:var(--accent);color:#fff;text-decoration:none}
/* 副リンク（枠線ゴースト）: .header-link（＝旧 .nav-toc のエイリアス統合）*/
.header-link,.nav-toc{margin-left:auto;font-size:13px;padding:8px 14px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--muted);font-weight:400;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;text-decoration:none}
.header-link:hover,.nav-toc:hover{background:var(--bg2);color:var(--text-strong);border-color:var(--accent-border);text-decoration:none}
/* .header-link の後に続く .header-cta は margin-left を詰める（auto の二重適用回避）*/
.header-link + .header-cta,.nav-toc + .nav-book{margin-left:14px}

/* ライブビュー pill（part2-index 専用・脈動ドット付き）*/
.nav-live{margin-left:14px;font-size:13px;padding:8px 14px;border-radius:6px;background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent-text);font-weight:500;display:inline-flex;align-items:center;gap:7px;white-space:nowrap;text-decoration:none}
.nav-live:hover{background:var(--accent-bg-hi);border-color:var(--accent);color:#fff;text-decoration:none}
.nav-live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:lvpulse 1.6s ease-in-out infinite}
@keyframes lvpulse{0%,100%{opacity:.5}50%{opacity:1}}

/* ユーザーチップ（章の nav-user）*/
.nav-user{margin-left:14px;font-size:12px;color:var(--muted);font-family:var(--font-mono);display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:99px;background:var(--bg2);border:1px solid var(--border)}
.nav-user .avatar{width:18px;height:18px;border-radius:50%;background:var(--accent);color:var(--bg);font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:600}

/* ランディング用 横並びナビ */
.header-nav{margin-left:auto;display:flex;align-items:center;gap:10px}
.nav-link{font-size:13px;color:var(--muted);padding:8px 10px;border-radius:6px;transition:color .15s,background .15s}
.nav-link:hover{color:var(--text);background:var(--bg3);text-decoration:none}
.header-nav .header-cta{margin-left:0}
@media(max-width:680px){.nav-link.hide-sm{display:none}}

/* ── フッター（正典・ランディング/文書ページ共通）── */
.site-footer{border-top:1px solid var(--border);margin-top:0}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:36px 28px 40px;display:flex;align-items:flex-start;justify-content:space-between;gap:28px;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:11px}
.footer-links{display:flex;gap:26px;flex-wrap:wrap}
.footer-col{display:flex;flex-direction:column;gap:9px}
.footer-col-h{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.footer-col a{font-size:13px;color:var(--text)}
.footer-col a:hover{color:var(--accent-text)}
.footer-legal{max-width:var(--maxw);margin:0 auto;padding:0 28px 36px;font-size:11.5px;color:var(--muted-dim);font-family:var(--font-mono)}
.footer-legal a{color:inherit}

/* ── ヘッダー モバイル ── */
@media(max-width:600px){
  .header-inner{gap:14px;padding:0 14px}
}
