/* IB-Link docs 共通スタイル
 * - docs/index.html（ユーザーマニュアル）
 * - docs/installer/index.html（インストーラー一覧）
 * 間で共有されるベースレイアウトとコンポーネント用 CSS
 */

:root{
  --navy:#1e3a5f;
  --navy-dark:#0f2744;
  --navy-light:#2c4f7c;
  --bg:#ffffff;
  --sidebar-bg:#f5f7fa;
  --border:#d1d5db;
  --text:#1f2937;
  --text-light:#4b5563;
  --accent-hover:#e8f1f8;
  --card:#ffffff;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Kaku Gothic ProN","Noto Sans JP",Meiryo,system-ui,sans-serif;
  line-height:1.7;
  letter-spacing:0.01em;
}

/* サイドバー TOC / ダウンロードメニュー */
.toc{
  position:fixed;
  top:0;
  left:0;
  bottom:0;
  width:280px;
  background:var(--sidebar-bg);
  border-right:1px solid var(--border);
  overflow:auto;
  padding:20px 16px 24px 20px;
  box-shadow:2px 0 8px rgba(0,0,0,.03);
}

.toc .brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
  font-size:15px;
  color:var(--navy-dark);
  padding:10px 6px 16px 6px;
  letter-spacing:.03em;
  border-bottom:2px solid var(--navy);
  margin-bottom:16px;
}

.toc .title{
  font-size:11px;
  font-weight:700;
  color:var(--text-light);
  text-transform:uppercase;
  letter-spacing:.1em;
  margin:12px 0 8px 4px;
}

.toc ul{
  list-style:none;
  margin:0;
  padding:0 4px 24px 4px;
}

.toc li{
  margin:3px 0;
}

.toc a{
  display:block;
  padding:8px 10px;
  border-radius:6px;
  text-decoration:none;
  color:var(--text);
  font-size:13.5px;
  transition:all .15s ease;
}

.toc a:hover{
  background:var(--accent-hover);
  color:var(--navy);
}

.toc a.active{
  background:var(--navy);
  color:#fff;
  font-weight:600;
  box-shadow:0 2px 4px rgba(30,58,95,.2);
}

.toc .lvl3{
  padding-left:16px;
  font-size:13px;
}

/* メインコンテナの共通余白 */
.container{
  margin-left:300px;
  max-width:1000px;
  padding:40px 32px 60px;
}

/* 共通テキスト系（主にマニュアル用だが他ページでも利用可） */
.container h1{
  font-size:32px;
  line-height:1.3;
  margin:0 0 24px;
  color:var(--navy-dark);
  font-weight:700;
  letter-spacing:-.01em;
}

.container h2{
  margin-top:36px;
  padding-top:20px;
  border-top:2px solid var(--border);
  color:var(--navy);
  font-weight:600;
  font-size:24px;
  letter-spacing:-.005em;
}

.container h3{
  margin-top:24px;
  color:var(--navy-light);
  font-weight:600;
  font-size:19px;
}

.container a{
  color:var(--navy);
  text-decoration:underline;
  text-decoration-color:var(--border);
  text-underline-offset:3px;
  transition:text-decoration-color .2s;
}

.container a:hover{
  text-decoration-color:var(--navy);
}

.container p{
  margin:12px 0;
  color:var(--text);
}

.container ul,
.container ol{
  margin:12px 0;
  padding-left:24px;
  color:var(--text);
}

.container li{
  margin:6px 0;
}

pre{
  background:#fafbfc;
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow:0 1px 3px rgba(0,0,0,.06);
  padding:18px;
  overflow:auto;
  font-size:13.5px;
}

code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  font-size:13.5px;
}

:not(pre)>code{
  background:#f3f4f6;
  padding:2px 6px;
  border-radius:4px;
  color:var(--navy-dark);
  font-size:13px;
}

img{
  max-width:100%;
  height:auto;
  border-radius:6px;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  margin:16px 0;
}

blockquote{
  border-left:4px solid var(--navy);
  background:#f9fafb;
  padding:12px 16px;
  margin:16px 0;
  color:var(--text-light);
  font-style:italic;
}

table{
  border-collapse:collapse;
  width:100%;
  margin:16px 0;
}

th,
td{
  border:1px solid var(--border);
  padding:10px 12px;
  text-align:left;
}

th{
  background:var(--sidebar-bg);
  color:var(--navy);
  font-weight:600;
}

/* クイックリンク（サイドバー内ショートカット） */
.quick-links{
  display:flex;
  flex-direction:column;
  gap:3px;
  margin:12px 4px 16px;
  width:100%;
}

.quick-links a{
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--text);
  padding:8px 10px;
  border-radius:6px;
  font-size:13.5px;
  transition:all .15s ease;
}

.quick-links a:hover{
  background:var(--accent-hover);
  color:var(--navy);
}

.quick-links .ico{
  display:flex;
  align-items:center;
}

.quick-links .ico svg{
  width:16px;
  height:16px;
  display:block;
}

/* Back to top ボタン（共通） */
.back-to-top{
  position:fixed;
  right:20px;
  bottom:20px;
  background:var(--navy);
  color:#fff;
  border:none;
  border-radius:999px;
  padding:12px 16px;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(30,58,95,.3);
  opacity:0;
  pointer-events:none;
  transition:all .25s ease;
}

.back-to-top.show{
  opacity:1;
  pointer-events:auto;
}

.back-to-top:hover{
  background:var(--navy-dark);
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(30,58,95,.4);
}

/* レスポンシブ共通 */
@media (max-width:1024px){
  .toc{
    display:none;
  }
  .container{
    margin-left:0;
    padding:24px 20px;
  }
}


