/* ============================================================
   DiPilot AI 研修スライド — 共有スタイル（ライトテーマ）
   明るい背景（ライトグレー/白）＋ DiPilotブルー & オレンジのアクセント
   ============================================================ */
:root{
  /* 背景・面 */
  --bg:#F5F6F8;          /* ページ全体 */
  --bg-2:#FFFFFF;        /* カード・白面 */
  --bg-soft:#EEF1F5;     /* うっすらグレー */
  /* 文字 */
  --navy:#0D1B2A;        /* 見出し・ブランド（背景ではなく文字色として使用） */
  --ink:#1B2431;
  --ink-dim:#586173;
  --ink-mute:#8A94A3;
  /* ブルー */
  --blue:#2563EB;
  --blue-2:#1D4ED8;
  --blue-soft:#EAF0FE;
  /* オレンジ */
  --amber:#E8912D;
  --amber-2:#B4690E;
  --amber-soft:#FDF1E3;
  /* 線・影 */
  --line:#E4E7EC;
  --line-2:#D7DCE3;
  --shadow:0 1px 2px rgba(16,32,58,.04), 0 8px 24px rgba(16,32,58,.06);
  --shadow-hover:0 4px 10px rgba(37,99,235,.10), 0 16px 40px rgba(16,32,58,.10);
  --radius:16px;
  --max:940px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Noto Sans JP',sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
strong{font-weight:700}

/* ── 固定トップバー ───────────────── */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  max-width:var(--max);margin:0 auto;padding:12px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.brand{font-weight:900;font-size:1rem;color:var(--navy);letter-spacing:.01em;white-space:nowrap}
.brand span{color:var(--blue)}
.topbar .label{font-size:.78rem;color:var(--ink-dim);font-weight:700;letter-spacing:.04em;flex:1;text-align:center}
.topbar .home{font-size:.8rem;color:var(--ink-dim);transition:.2s;white-space:nowrap}
.topbar .home:hover{color:var(--blue)}
#progress{position:absolute;left:0;bottom:-1px;height:3px;background:linear-gradient(90deg,var(--blue),var(--amber));width:0;transition:width .1s linear}

/* ── レイアウト ───────────────── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.hero{max-width:var(--max);margin:0 auto;padding:130px 24px 30px}
.doc{max-width:var(--max);margin:0 auto;padding:16px 24px 40px}
.block{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 30px;margin:20px 0;box-shadow:var(--shadow);
}
.block.plain{background:transparent;border:none;box-shadow:none;padding:14px 4px}

/* ── 章の区切り（濃紺のダーク面ではなく、ブルー淡色バンド） ── */
.chapter{
  max-width:var(--max);margin:34px auto 8px;padding:26px 30px;
  background:linear-gradient(120deg,var(--blue-soft),#fff);
  border:1px solid var(--line);border-left:5px solid var(--blue);
  border-radius:var(--radius);
}
.chapter .cn{font-size:.8rem;font-weight:800;letter-spacing:.14em;color:var(--blue);text-transform:uppercase}
.chapter h2{margin:6px 0 4px}
.chapter p{color:var(--ink-dim);margin:0}

/* ── タイポ ───────────────── */
.eyebrow{
  display:inline-block;font-size:.76rem;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue);margin-bottom:14px;
}
.eyebrow.amber{color:var(--amber-2)}
h1{font-size:clamp(2rem,5.4vw,3.2rem);font-weight:900;line-height:1.28;color:var(--navy);letter-spacing:.01em}
h2{font-size:clamp(1.4rem,3.6vw,2rem);font-weight:900;line-height:1.34;color:var(--navy);margin-bottom:6px}
h3{font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:6px}
p{margin:10px 0}
p.lead{font-size:1.05rem;color:var(--ink-dim);max-width:720px}
.sub{color:var(--ink-dim)}
.hl{color:var(--amber-2);font-weight:700}
.hl-b{color:var(--blue);font-weight:700}
.catch{font-size:clamp(1.15rem,3vw,1.5rem);font-weight:700;line-height:1.55;color:var(--navy);margin:18px 0 8px}

/* ── カード ───────────────── */
.cards{display:grid;gap:16px;margin-top:22px}
.cards.col2{grid-template-columns:1fr}
.cards.col3{grid-template-columns:1fr}
@media(min-width:640px){.cards.col2{grid-template-columns:1fr 1fr}.cards.col3{grid-template-columns:repeat(3,1fr)}}
.card{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 22px;box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.block .card{box-shadow:none;background:#FBFCFE}
.card .num{font-size:1.5rem;font-weight:900;color:var(--blue);margin-bottom:4px;line-height:1.2}
.card .num.amber{color:var(--amber)}
.card h3{color:var(--navy)}
.card p{color:var(--ink-dim);font-size:.92rem;margin:4px 0 0;flex:1}

/* リンクカード（一覧ページ） */
a.card{transition:.25s}
a.card:hover{border-color:rgba(37,99,235,.4);transform:translateY(-3px);box-shadow:var(--shadow-hover)}
a.card.newcard{border-color:rgba(232,145,45,.45)}
a.card.newcard:hover{border-color:var(--amber);box-shadow:0 4px 10px rgba(232,145,45,.14),0 16px 40px rgba(16,32,58,.10)}
a.card .code{font-size:.82rem;font-weight:900;letter-spacing:.06em;color:var(--blue)}
a.card.newcard .code{color:var(--amber-2)}
a.card .open{margin-top:16px;font-size:.85rem;font-weight:700;color:var(--blue)}
a.card.newcard .open{color:var(--amber-2)}

/* ── ビフォーアフター／2カラム比較 ── */
.ba{display:grid;gap:16px;margin-top:22px}
@media(min-width:720px){.ba{grid-template-columns:1fr 1fr;align-items:stretch}}
.ba .box{border-radius:var(--radius);padding:22px 22px;border:1px solid var(--line);background:#FBFCFE}
.ba .box.bad{border-color:var(--line-2)}
.ba .box.accent{background:linear-gradient(160deg,var(--amber-soft),#fff);border-color:rgba(232,145,45,.4)}
.ba .box.good{background:linear-gradient(160deg,var(--blue-soft),#fff);border-color:rgba(37,99,235,.35)}
.ba .tag{display:inline-block;font-size:.75rem;font-weight:800;letter-spacing:.06em;padding:4px 12px;border-radius:999px;margin-bottom:12px}
.ba .box .tag{background:var(--bg-soft);color:var(--ink-dim)}
.ba .box.accent .tag{background:var(--amber);color:#241503}
.ba .box.good .tag{background:var(--blue);color:#fff}
.ba .box p{color:var(--ink);margin:6px 0}
.ba ul{list-style:none;margin:4px 0}
.ba li{padding-left:24px;position:relative;margin:8px 0;color:var(--ink-dim)}
.ba .box.accent li,.ba .box.good li{color:var(--ink)}
.ba li::before{position:absolute;left:0;top:0;font-weight:800}
.ba .box.bad li::before,.ba .box:not(.accent):not(.good) li::before{content:"−";color:#AAB2BD}
.ba .box.accent li::before{content:"✓";color:var(--amber-2)}
.ba .box.good li::before{content:"✓";color:var(--blue)}
.ba .example{margin-top:12px;font-size:.9rem;color:var(--ink-dim);border-top:1px dashed var(--line-2);padding-top:10px}

/* ── 表 ───────────────── */
.table-wrap{overflow-x:auto;margin:16px 0;border:1px solid var(--line);border-radius:12px}
table.tbl{width:100%;border-collapse:collapse;font-size:.93rem;min-width:520px;background:var(--bg-2)}
table.tbl th,table.tbl td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
table.tbl thead th{background:var(--bg-soft);color:var(--navy);font-weight:800;white-space:nowrap;border-bottom:2px solid var(--line-2)}
table.tbl tbody th{color:var(--navy);font-weight:800;white-space:nowrap}
table.tbl td{color:var(--ink-dim)}
table.tbl tbody tr:last-child th,table.tbl tbody tr:last-child td{border-bottom:none}
table.tbl tr.hi td,table.tbl tr.hi th{background:var(--amber-soft)}
table.tbl .maker{display:block;font-size:.76rem;color:var(--ink-mute);font-weight:400}
table.tbl .ok{color:var(--blue);font-weight:700}
table.tbl .ng{color:#C0553B;font-weight:700}

/* ── ノート（コールアウト） ── */
.note{
  margin:18px 0 0;padding:16px 20px;border-left:4px solid var(--blue);
  background:var(--blue-soft);border-radius:10px;font-size:.98rem;color:var(--ink);
}
.note.amber{border-left-color:var(--amber);background:var(--amber-soft)}
.note b{color:var(--blue-2)}
.note.amber b{color:var(--amber-2)}
.note .t{display:block;font-weight:800;margin-bottom:2px}

.bigmsg{
  font-size:clamp(1.3rem,3.4vw,1.9rem);font-weight:900;line-height:1.5;color:var(--navy);
  background:linear-gradient(160deg,var(--amber-soft),#fff);
  border:1px solid rgba(232,145,45,.4);border-radius:var(--radius);padding:26px 26px;
}
.bigmsg .hl{color:var(--amber-2)}

/* ── ステップ ───────────────── */
.steps{display:grid;gap:12px;margin-top:20px}
@media(min-width:680px){.steps.s3{grid-template-columns:repeat(3,1fr)}.steps.s2{grid-template-columns:repeat(2,1fr)}}
.step{background:#FBFCFE;border:1px solid var(--line);border-radius:12px;padding:16px 16px}
.step .s-no{font-size:.72rem;font-weight:800;color:var(--blue);letter-spacing:.08em}
.step .s-title{font-weight:700;margin:6px 0 4px;color:var(--navy)}
.step .s-desc{font-size:.88rem;color:var(--ink-dim)}

/* ── チップ ───────────────── */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{font-size:.82rem;color:var(--ink);background:var(--bg-2);border:1px solid var(--line-2);padding:7px 13px;border-radius:999px}
.chip.blue{background:var(--blue-soft);border-color:transparent;color:var(--blue-2);font-weight:700}
.chip.amber{background:var(--amber-soft);border-color:transparent;color:var(--amber-2);font-weight:700}
.chip.tag{position:absolute;top:18px;right:18px;font-size:.7rem;font-weight:800;letter-spacing:.04em;padding:4px 10px}
.chip.tag.new{background:var(--amber);color:#241503;border-color:transparent}
.chip.tag.ext{background:var(--bg-soft);color:var(--ink-dim)}

/* ── チェックリスト ───────────────── */
.checks{list-style:none;margin-top:14px;display:grid;gap:8px}
.checks li{position:relative;padding:10px 14px 10px 40px;background:#FBFCFE;border:1px solid var(--line);border-radius:10px;color:var(--ink);font-size:.95rem}
.checks li::before{content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid var(--blue);border-radius:5px}

/* ── 番号付きTips ───────────────── */
.tips{list-style:none;margin-top:18px;display:grid;gap:10px}
.tips li{position:relative;padding:14px 16px 14px 54px;background:#FBFCFE;border:1px solid var(--line);border-radius:12px;color:var(--ink)}
.tips li .n{position:absolute;left:14px;top:14px;width:28px;height:28px;border-radius:8px;background:var(--blue);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.tips li b{color:var(--amber-2)}

/* ── コードブロック（暗色でコントラスト） ── */
.code{
  margin:14px 0 0;background:#0F1B2D;color:#E6ECF5;border-radius:12px;
  padding:16px 18px;font-family:'SFMono-Regular',Consolas,Menlo,monospace;
  font-size:.9rem;line-height:1.7;white-space:pre-wrap;word-break:break-word;overflow-x:auto;
}
.code .cm{color:#8FA3BF}
.code .k{color:#F0B267}

/* ── Claude Codeへの伝え方ボックス ── */
.say{margin:16px 0 0;border:1px solid rgba(37,99,235,.3);background:var(--blue-soft);border-radius:14px;padding:16px 18px}
.say .say-h{display:flex;align-items:center;gap:8px;font-weight:800;color:var(--blue-2);font-size:.92rem;margin-bottom:6px}
.say .prompt{background:var(--bg-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;color:var(--ink);font-size:.93rem;margin-top:8px}
.say .prompt .arrow{display:block;margin-top:6px;color:var(--ink-dim);font-size:.86rem}

/* プロンプト（役割色分け） */
.prompt-ex{margin-top:16px;background:#0F1B2D;color:#E6ECF5;border-radius:12px;padding:18px 20px;font-size:.95rem;line-height:1.9}
.prompt-ex .role{color:#F0B267}.prompt-ex .bg{color:#7EC8E3}.prompt-ex .ask{color:#A8E6A1}.prompt-ex .fmt{color:#F5A3C7}

.prompt-parts{display:grid;gap:10px;margin-top:18px}
@media(min-width:640px){.prompt-parts{grid-template-columns:1fr 1fr}}
.pp{border:1px solid var(--line);background:#FBFCFE;border-radius:12px;padding:14px 16px}
.pp .k{font-weight:900;color:var(--amber-2);font-size:.92rem}
.pp .d{font-size:.88rem;color:var(--ink-dim)}

/* ── まとめリスト ───────────────── */
.summary{list-style:none;margin-top:18px;display:grid;gap:10px;max-width:680px}
.summary li{padding:14px 18px;background:#FBFCFE;border:1px solid var(--line);border-radius:12px;font-size:1rem}
.summary li b{color:var(--blue)}

/* ── ボタン ───────────────── */
.nextbtns{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.btn{display:inline-block;padding:13px 22px;border-radius:12px;font-weight:700;font-size:.95rem;transition:.2s;border:1px solid transparent}
.btn.primary{background:var(--blue);color:#fff}
.btn.primary:hover{background:var(--blue-2)}
.btn.ghost{border-color:var(--line-2);color:var(--ink)}
.btn.ghost:hover{background:var(--bg-soft)}

/* ── フッター ───────────────── */
.pagefoot{max-width:var(--max);margin:20px auto 0;padding:26px 24px 56px;border-top:1px solid var(--line);color:var(--ink-mute);font-size:.82rem}
.pagefoot b{color:var(--blue)}

/* ── レスポンシブ微調整 ───────────────── */
@media(max-width:560px){
  .hero{padding:110px 18px 24px}
  .doc,.wrap{padding-left:18px;padding-right:18px}
  .block{padding:24px 20px}
  .chapter{padding:22px 20px}
  .topbar .label{display:none}
}
