/* ============================================
   ダレカン和泉 Web制作・開発基礎カリキュラム
   共通スタイルシート
   ============================================ */

:root {
  --green: #2e7d52;
  --green-dark: #1f5c3b;
  --green-pale: #e8f5ec;
  --bg: #f7faf7;
  --text: #2b3530;
  --text-sub: #5c6b62;
  --card: #ffffff;
  --line: #dce8df;
  --step1: #3b82c4;
  --step1-pale: #e7f1fa;
  --step2: #2e9e63;
  --step2-pale: #e6f6ec;
  --step3: #d97f1e;
  --step3-pale: #fcf1e2;
  --step4: #c2545e;
  --step4-pale: #fbeaec;
  --goal: #8e5bbf;
  --goal-pale: #f2eafa;
  --pro: #3f51a3;
  --pro-deep: #2d3a6e;
  --pro-pale: #e9edf8;
  --pd: #c2548d;
  --pd-pale: #f9eaf2;
  --pf: #3b82c4;
  --pf-pale: #e7f1fa;
  --pb: #546e7a;
  --pb-pale: #edf2f5;
  --radius: 14px;
  --shadow: 0 2px 10px rgba(43, 53, 48, 0.07);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ---------- 日本語の折り返し設計 ----------
   見出しは行のバランスを取り、本文・リード文は文節の切れ目で折り返す。
   (auto-phrase は Edge/Chrome の機能。未対応ブラウザでは単に無視される) */

h1, h2, h3 {
  text-wrap: balance;
}

p, li {
  text-wrap: pretty;
}

.hero .tagline,
.step-hero p,
.lead,
.goal-box .goal-text,
.value-card p,
.note-box,
.tip-box,
.warn-box {
  word-break: auto-phrase;
}

/* 広い画面でだけ効かせる改行 (狭い画面では自動折り返しに任せる) */
br.wrap {
  display: none;
}

@media (min-width: 700px) {
  br.wrap {
    display: inline;
  }
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "Yu Gothic", "Meiryo", sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.9;
  font-size: 16px;
}

img {
  max-width: 100%;
}

a {
  color: var(--green-dark);
}

/* ---------- ヘッダー・ナビ ---------- */

.site-header {
  background: var(--card);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 50;
}

.site-header .inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  flex-wrap: nowrap; /* ヘッダーは常に1行。あふれた分はナビ側が横スクロールする */
  align-items: center;
  gap: 8px 18px;
}

.brand {
  font-weight: 700;
  font-size: 1.02rem;
  color: var(--green-dark);
  text-decoration: none;
  line-height: 1.4;
  white-space: nowrap;
  flex-shrink: 0;
}

.brand small {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text-sub);
}

.global-nav {
  margin-left: auto;
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  overflow-x: auto; /* あふれたら1行のまま横にスクロール */
  /* スクロールバーは「細く出す」。完全に隠すと、マウス環境で見切れたとき
     横スクロールの手段がなくなる (2026-06-13 修正)。Firefox 用 */
  scrollbar-width: thin;
  scrollbar-color: var(--line) transparent;
  padding: 2px 2px 5px; /* 下にスクロールバーぶんの余白 */
  -webkit-overflow-scrolling: touch;
}

/* WebKit (Chrome/Edge/Safari) 用の細いスクロールバー */
.global-nav::-webkit-scrollbar {
  height: 6px;
}

.global-nav::-webkit-scrollbar-thumb {
  background: var(--line);
  border-radius: 999px;
}

.global-nav::-webkit-scrollbar-thumb:hover {
  background: var(--text-sub);
}

.global-nav::-webkit-scrollbar-track {
  background: transparent;
}

.global-nav a {
  text-decoration: none;
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--text-sub);
  background: #fff;
  border: 1.5px solid var(--line);
  padding: 5px 12px;
  border-radius: 999px;
  white-space: nowrap;
  flex-shrink: 0;
}

.global-nav a:hover {
  background: var(--green-pale);
  border-color: var(--green);
  color: var(--green-dark);
}

.global-nav a.current {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}

/* ---------- サイト内検索 ---------- */

/* アイコンのみの ゴーストボタン (ナビのピルと差をつけ、Goal を終点として立てる) */
.search-btn {
  font: inherit;
  font-size: 0.95rem;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: 50%;
  margin-left: 4px;
  flex-shrink: 0;
  cursor: pointer;
}

.search-btn:hover {
  background: var(--green-pale);
}

.search-panel {
  display: none;
  background: #fff;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 10px 24px rgba(43, 53, 48, 0.08);
}

.search-panel.open {
  display: block;
}

.search-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 14px 20px 18px;
}

#site-search {
  width: calc(100% - 52px);
  font: inherit;
  font-size: 1rem;
  padding: 9px 14px;
  border: 1.5px solid var(--line);
  border-radius: 10px;
}

#site-search:focus {
  outline: 2px solid var(--green);
  border-color: var(--green);
}

.search-close {
  font: inherit;
  font-size: 1.1rem;
  font-weight: 700;
  width: 40px;
  height: 40px;
  margin-left: 8px;
  color: var(--text-sub);
  background: #fff;
  border: 1.5px solid var(--line);
  border-radius: 50%;
  cursor: pointer;
  vertical-align: middle;
}

.search-close:hover {
  border-color: var(--green);
  color: var(--green-dark);
}

.search-results {
  margin-top: 12px;
  max-height: 55vh;
  overflow: auto;
}

.search-hit {
  display: block;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  margin-bottom: 8px;
  text-decoration: none;
  color: var(--text);
  background: #fff;
}

.search-hit:hover {
  border-color: var(--green);
  background: var(--green-pale);
}

.search-hit strong {
  color: var(--green-dark);
}

.hit-count {
  margin-left: 10px;
  font-size: 0.78rem;
  color: var(--text-sub);
}

.hit-snippet {
  display: block;
  font-size: 0.85rem;
  color: var(--text-sub);
  margin-top: 3px;
  line-height: 1.7;
}

.search-note {
  font-size: 0.9rem;
  color: var(--text-sub);
  margin-top: 8px;
}

mark {
  background: #ffe9a8;
  padding: 0 2px;
  border-radius: 3px;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

/* ---------- 共通レイアウト ---------- */

.container {
  max-width: 1040px;
  margin: 0 auto;
  padding: 0 20px;
}

main {
  /* 下方向の余白は .site-footer の margin-top に一本化 (環境で二重がけ/無効化が起きないように) */
  padding-bottom: 0;
}

section {
  margin-top: 56px;
}

.section-title {
  font-size: 1.45rem;
  color: var(--green-dark);
  border-left: 6px solid var(--green);
  padding-left: 14px;
  margin-bottom: 22px;
  line-height: 1.5;
}

.lead {
  color: var(--text-sub);
  margin-bottom: 18px;
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px 26px;
}

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

.grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid.cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 860px) {
  .grid.cols-3, .grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .grid.cols-2, .grid.cols-3, .grid.cols-4 { grid-template-columns: 1fr; }
}

/* ---------- ヒーロー (トップ) ---------- */

.hero {
  background: linear-gradient(150deg, #eaf6ee 0%, #f4faf0 55%, #fdf9ec 100%);
  border-bottom: 1px solid var(--line);
  padding: 64px 0 56px;
  text-align: center;
}

.hero .badge-row {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.badge {
  display: inline-block;
  background: #fff;
  border: 1.5px solid var(--green);
  color: var(--green-dark);
  font-size: 0.82rem;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 999px;
}

/* プロへの道への 誘導バッジ。生成り色でなく、プロ各ページの アクセント
   (ダークネイビー系) に そろえた 塗りつぶしボタンにする */
.badge.badge-pro {
  background: var(--pro-deep);
  border-color: var(--pro-deep);
  color: #fff;
}

.badge.badge-pro:hover {
  background: var(--pro);
  border-color: var(--pro);
}

.hero h1 {
  font-size: clamp(1.6rem, 4.2vw, 2.5rem);
  color: var(--green-dark);
  line-height: 1.5;
  margin-bottom: 16px;
}

.hero p.tagline {
  font-size: 1.05rem;
  color: var(--text-sub);
  max-width: 620px;
  margin: 0 auto;
}

/* ---------- 4つの大切なこと ---------- */

.value-card {
  text-align: center;
  padding: 26px 18px;
}

.value-card .icon {
  font-size: 1.7rem;
  width: 58px;
  height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green-pale);
  border-radius: 50%;
  margin: 0 auto 12px;
}

.value-card h3 {
  font-size: 1.02rem;
  color: var(--green-dark);
  margin-bottom: 8px;
}

.value-card p {
  font-size: 0.88rem;
  color: var(--text-sub);
  text-align: left;
}

/* ---------- 学習の流れ図 ---------- */

.flow {
  display: flex;
  align-items: stretch;
  gap: 0;
  flex-wrap: nowrap;
  justify-content: center;
}

.flow-item {
  flex: 1 1 140px;
  min-width: 0;
  max-width: 185px;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 18px 10px 16px;
  border-radius: var(--radius);
  border: 2px solid transparent;
  position: relative;
}

.flow-item .num {
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-bottom: 4px;
}

.flow-item .name {
  font-weight: 700;
  font-size: 0.98rem;
  line-height: 1.5;
}

.flow-item .desc {
  font-size: 0.78rem;
  color: var(--text-sub);
  margin-top: 6px;
  line-height: 1.6;
}

.flow-arrow {
  align-self: center;
  font-size: 1.3rem;
  color: var(--text-sub);
  padding: 0 6px;
  user-select: none;
}

.flow-item.f1 { background: var(--step1-pale); }
.flow-item.f1 .num, .flow-item.f1 .name { color: var(--step1); }
.flow-item.f2 { background: var(--step2-pale); }
.flow-item.f2 .num, .flow-item.f2 .name { color: var(--step2); }
.flow-item.f3 { background: var(--step3-pale); }
.flow-item.f3 .num, .flow-item.f3 .name { color: var(--step3); }
.flow-item.f4 { background: var(--step4-pale); }
.flow-item.f4 .num, .flow-item.f4 .name { color: var(--step4); }
.flow-item.fg { background: var(--goal-pale); }
.flow-item.fg .num, .flow-item.fg .name { color: var(--goal); }

.flow-item:hover { border-color: currentColor; }

@media (max-width: 900px) {
  .flow { flex-direction: column; align-items: stretch; }
  .flow-item { max-width: none; }
  .flow-arrow { transform: rotate(90deg); padding: 2px 0; }
}

.flow-total {
  margin-top: 14px;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--text-sub);
  text-align: center;
}

/* ---------- ステップカード (トップ) ---------- */

.step-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--text);
  transition: transform 0.12s ease;
}

.step-card:hover {
  transform: translateY(-3px);
}

.step-card .step-tag {
  display: inline-block;
  align-self: flex-start;
  font-size: 0.76rem;
  font-weight: 700;
  color: #fff;
  padding: 3px 12px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.step-card h3 {
  font-size: 1.08rem;
  margin-bottom: 8px;
  line-height: 1.5;
}

.step-card p {
  font-size: 0.88rem;
  color: var(--text-sub);
  flex: 1;
}

.step-card .period {
  margin-top: 12px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-sub);
}

.step-card.s1 .step-tag { background: var(--step1); }
.step-card.s1 h3 { color: var(--step1); }
.step-card.s2 .step-tag { background: var(--step2); }
.step-card.s2 h3 { color: var(--step2); }
.step-card.s3 .step-tag { background: var(--step3); }
.step-card.s3 h3 { color: var(--step3); }
.step-card.s4 .step-tag { background: var(--step4); }
.step-card.s4 h3 { color: var(--step4); }
.step-card.sg .step-tag { background: var(--goal); }
.step-card.sg h3 { color: var(--goal); }

/* ---------- B型・A型セクション ---------- */

.type-card h3 {
  font-size: 1.05rem;
  color: var(--green-dark);
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--green-pale);
}

.type-card p {
  font-size: 0.9rem;
  color: var(--text-sub);
}

.note-box {
  background: var(--green-pale);
  border-radius: var(--radius);
  padding: 18px 22px;
  font-size: 0.92rem;
  margin-top: 18px;
}

/* ---------- ステップページ共通 ---------- */

.step-hero {
  padding: 46px 0 38px;
  border-bottom: 1px solid var(--line);
}

.step-hero .step-label {
  display: inline-block;
  color: #fff;
  font-weight: 700;
  font-size: 0.85rem;
  padding: 4px 16px;
  border-radius: 999px;
  margin-bottom: 12px;
}

.step-hero h1 {
  font-size: clamp(1.5rem, 3.6vw, 2.1rem);
  line-height: 1.5;
  margin-bottom: 10px;
}

.step-hero p {
  color: var(--text-sub);
  max-width: 720px;
}

.page-s1 .step-hero { background: var(--step1-pale); }
.page-s1 .step-hero .step-label { background: var(--step1); }
.page-s1 .step-hero h1 { color: var(--step1); }
.page-s2 .step-hero { background: var(--step2-pale); }
.page-s2 .step-hero .step-label { background: var(--step2); }
.page-s2 .step-hero h1 { color: var(--step2); }
.page-s3 .step-hero { background: var(--step3-pale); }
.page-s3 .step-hero .step-label { background: var(--step3); }
.page-s3 .step-hero h1 { color: var(--step3); }
.page-s4 .step-hero { background: var(--step4-pale); }
.page-s4 .step-hero .step-label { background: var(--step4); }
.page-s4 .step-hero h1 { color: var(--step4); }
.page-sg .step-hero { background: var(--goal-pale); }
.page-sg .step-hero .step-label { background: var(--goal); }
.page-sg .step-hero h1 { color: var(--goal); }

/* ページごとのアクセント色を、見出し・アイコンにも通す (世界観の統一) */
.page-s1 .global-nav a.current { background: var(--step1); border-color: var(--step1); }
.page-s3 .global-nav a.current { background: var(--step3); border-color: var(--step3); }
.page-s4 .global-nav a.current { background: var(--step4); border-color: var(--step4); }
.page-sg .global-nav a.current { background: var(--goal); border-color: var(--goal); }
.page-tk .global-nav a.current { background: #11898c; border-color: #11898c; }
.page-s1 .section-title { border-left-color: var(--step1); color: var(--step1); }
.page-s2 .section-title { border-left-color: var(--step2); color: var(--step2); }
.page-s3 .section-title { border-left-color: var(--step3); color: var(--step3); }
.page-s4 .section-title { border-left-color: var(--step4); color: var(--step4); }
.page-sg .section-title { border-left-color: var(--goal); color: var(--goal); }
.page-sg .path-card { border-top-color: var(--goal); }
.page-s1 .make-card .icon { background: var(--step1-pale); }
.page-s2 .make-card .icon { background: var(--step2-pale); }
.page-s3 .make-card .icon { background: var(--step3-pale); }
.page-s4 .make-card .icon { background: var(--step4-pale); }

/* ---------- プロへの道 (本格研修) ----------
   ハブ = page-pro / デザイン = page-pd / フロントエンド = page-pf / バックエンド = page-pb。
   既存ステップと同じ要素構成のまま、コースごとのアクセント色だけを差しかえる */

.page-pro .step-hero { background: var(--pro-pale); }
.page-pro .step-hero .step-label { background: var(--pro); }
.page-pro .step-hero h1 { color: var(--pro); }
.page-pd .step-hero { background: var(--pd-pale); }
.page-pd .step-hero .step-label { background: var(--pd); }
.page-pd .step-hero h1 { color: var(--pd); }
.page-pf .step-hero { background: var(--pf-pale); }
.page-pf .step-hero .step-label { background: var(--pf); }
.page-pf .step-hero h1 { color: var(--pf); }
.page-pb .step-hero { background: var(--pb-pale); }
.page-pb .step-hero .step-label { background: var(--pb); }
.page-pb .step-hero h1 { color: var(--pb); }

.page-pro .global-nav a.current { background: var(--pro); border-color: var(--pro); }
.page-pd .global-nav a.current { background: var(--pd); border-color: var(--pd); }
.page-pf .global-nav a.current { background: var(--pf); border-color: var(--pf); }
.page-pb .global-nav a.current { background: var(--pb); border-color: var(--pb); }

.page-pro .section-title { border-left-color: var(--pro); color: var(--pro); }
.page-pd .section-title { border-left-color: var(--pd); color: var(--pd); }
.page-pf .section-title { border-left-color: var(--pf); color: var(--pf); }
.page-pb .section-title { border-left-color: var(--pb); color: var(--pb); }

.page-pro .goal-box { border-color: var(--pro); }
.page-pro .goal-box .label { color: var(--pro); }
.page-pd .goal-box { border-color: var(--pd); }
.page-pd .goal-box .label { color: var(--pd); }
.page-pf .goal-box { border-color: var(--pf); }
.page-pf .goal-box .label { color: var(--pf); }
.page-pb .goal-box { border-color: var(--pb); }
.page-pb .goal-box .label { color: var(--pb); }

.page-pro .steps > li::before { background: var(--pro); }
.page-pd .steps > li::before { background: var(--pd); }
.page-pf .steps > li::before { background: var(--pf); }
.page-pb .steps > li::before { background: var(--pb); }

.page-pro .do-box { border-color: var(--pro); }
.page-pro .do-box .do-label { background: var(--pro); }
.page-pd .do-box { border-color: var(--pd); }
.page-pd .do-box .do-label { background: var(--pd); }
.page-pf .do-box { border-color: var(--pf); }
.page-pf .do-box .do-label { background: var(--pf); }
.page-pb .do-box { border-color: var(--pb); }
.page-pb .do-box .do-label { background: var(--pb); }

.page-pro .lesson-list a::before { background: var(--pro); }
.page-pd .lesson-list a::before { background: var(--pd); }
.page-pf .lesson-list a::before { background: var(--pf); }
.page-pb .lesson-list a::before { background: var(--pb); }
.page-pro .lesson-list a:hover::after { color: #fff; background: var(--pro); border-color: var(--pro); }
.page-pd .lesson-list a:hover::after { color: #fff; background: var(--pd); border-color: var(--pd); }
.page-pf .lesson-list a:hover::after { color: #fff; background: var(--pf); border-color: var(--pf); }
.page-pb .lesson-list a:hover::after { color: #fff; background: var(--pb); border-color: var(--pb); }

.page-pro .make-card .icon { background: var(--pro-pale); }
.page-pd .make-card .icon { background: var(--pd-pale); }
.page-pf .make-card .icon { background: var(--pf-pale); }
.page-pb .make-card .icon { background: var(--pb-pale); }

.page-pro .learn-item h3 { color: var(--pro); }
.page-pd .learn-item h3 { color: var(--pd); }
.page-pf .learn-item h3 { color: var(--pf); }
.page-pb .learn-item h3 { color: var(--pb); }
.page-pro .learn-item .dot { background: var(--pro); }
.page-pd .learn-item .dot { background: var(--pd); }
.page-pf .learn-item .dot { background: var(--pf); }
.page-pb .learn-item .dot { background: var(--pb); }

/* プロのコースカード (バックエンド用。design / front は既存定義を使う) */
.course-card.back h3, .course-card.back ul li::before { color: var(--pb); }

/* 学習の流れ図 (基礎 → プロへの道) */
.flow-item.fp { background: var(--pro-pale); }
.flow-item.fp .num, .flow-item.fp .name { color: var(--pro); }

/* ゴールボックス */
.goal-box {
  border-radius: var(--radius);
  padding: 22px 26px;
  background: var(--card);
  border: 2px solid var(--line);
  box-shadow: var(--shadow);
}

.goal-box .label {
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  display: block;
  margin-bottom: 6px;
}

.goal-box .goal-text {
  font-size: 1.12rem;
  font-weight: 700;
  line-height: 1.7;
}

.page-s1 .goal-box { border-color: var(--step1); }
.page-s1 .goal-box .label { color: var(--step1); }
.page-s2 .goal-box { border-color: var(--step2); }
.page-s2 .goal-box .label { color: var(--step2); }
.page-s3 .goal-box { border-color: var(--step3); }
.page-s3 .goal-box .label { color: var(--step3); }
.page-s4 .goal-box { border-color: var(--step4); }
.page-s4 .goal-box .label { color: var(--step4); }
.page-sg .goal-box { border-color: var(--goal); }
.page-sg .goal-box .label { color: var(--goal); }

/* 学ぶことリスト */
.learn-item h3 {
  font-size: 1rem;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.learn-item h3 .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.page-s1 .learn-item h3 { color: var(--step1); }
.page-s1 .learn-item .dot { background: var(--step1); }
.page-s2 .learn-item h3 { color: var(--step2); }
.page-s2 .learn-item .dot { background: var(--step2); }
.page-s3 .learn-item h3 { color: var(--step3); }
.page-s3 .learn-item .dot { background: var(--step3); }
.page-s4 .learn-item h3 { color: var(--step4); }
.page-s4 .learn-item .dot { background: var(--step4); }

.learn-item p {
  font-size: 0.87rem;
  color: var(--text-sub);
}

/* 作るものカード */
.make-card {
  text-align: center;
  padding: 24px 16px;
}

.make-card .icon {
  font-size: 1.6rem;
  width: 54px;
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--green-pale);
  border-radius: 50%;
  margin: 0 auto 10px;
}

.make-card h3 {
  font-size: 0.98rem;
  margin-bottom: 6px;
  color: var(--text);
}

.make-card p {
  font-size: 0.84rem;
  color: var(--text-sub);
  text-align: left;
}

/* コースカード (Step 4) */
.course-card h3 {
  font-size: 1.08rem;
  margin-bottom: 4px;
}

.course-card .for {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-sub);
  margin-bottom: 12px;
}

.course-card ul {
  list-style: none;
  margin-bottom: 12px;
}

.course-card ul li {
  font-size: 0.88rem;
  padding: 6px 0 6px 22px;
  position: relative;
  border-bottom: 1px dashed var(--line);
}

.course-card ul li::before {
  content: "✓";
  position: absolute;
  left: 2px;
  font-weight: 700;
}

.course-card.design h3, .course-card.design ul li::before { color: #c2548d; }
.course-card.front h3, .course-card.front ul li::before { color: var(--step1); }
.course-card.prog h3, .course-card.prog ul li::before { color: var(--step3); }

.course-card .makes {
  font-size: 0.83rem;
  background: var(--bg);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--text-sub);
}

/* チェックリスト */
.checklist {
  list-style: none;
}

.checklist li {
  margin-bottom: 10px;
}

.checklist label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 13px 16px;
  cursor: pointer;
  font-size: 0.93rem;
  transition: background 0.15s ease;
}

.checklist label:hover {
  background: var(--green-pale);
}

.checklist input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 3px;
  accent-color: var(--green);
  flex-shrink: 0;
}

.checklist input:checked + span {
  color: var(--text-sub);
  text-decoration: line-through;
}

.check-progress {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--green-dark);
  margin-bottom: 14px;
}

/* ---------- 授業一覧 (ステップページ) ---------- */

.lesson-list {
  list-style: none;
  counter-reset: lesson;
}

.lesson-list li {
  counter-increment: lesson;
  margin-bottom: 12px;
}

.lesson-list a {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px 20px;
  text-decoration: none;
  color: var(--text);
  transition: transform 0.12s ease;
}

.lesson-list a:hover {
  transform: translateY(-2px);
}

.lesson-list a::before {
  content: counter(lesson);
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page-s1 .lesson-list a::before { background: var(--step1); }
.page-s2 .lesson-list a::before { background: var(--step2); }
.page-s3 .lesson-list a::before { background: var(--step3); }
.page-s4 .lesson-list a::before { background: var(--step4); }

.lesson-list .ltext {
  flex: 1;
  min-width: 0;
}

.lesson-list .ltext strong {
  display: block;
  line-height: 1.6;
}

.lesson-list .ltext small {
  display: block;
  color: var(--text-sub);
  line-height: 1.6;
}

.lesson-list .progress-badge {
  margin-top: 0;
  white-space: nowrap;
}

/* 行の右端の「開く ›」。クリックでページが開くことを明示する */
.lesson-list a::after {
  content: "開く ›";
  flex-shrink: 0;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text-sub);
  background: var(--bg);
  border: 1.5px solid var(--line);
  border-radius: 999px;
  padding: 4px 14px;
  white-space: nowrap;
}

.page-s1 .lesson-list a:hover::after { color: #fff; background: var(--step1); border-color: var(--step1); }
.page-s2 .lesson-list a:hover::after { color: #fff; background: var(--step2); border-color: var(--step2); }
.page-s3 .lesson-list a:hover::after { color: #fff; background: var(--step3); border-color: var(--step3); }
.page-s4 .lesson-list a:hover::after { color: #fff; background: var(--step4); border-color: var(--step4); }

/* ---------- 授業ページ ---------- */

.crumb {
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 10px;
  color: var(--text-sub);
}

.crumb a {
  color: inherit;
}

/* 番号つき手順 */
.steps {
  list-style: none;
  counter-reset: step;
}

.steps > li {
  counter-increment: step;
  position: relative;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 14px 18px 14px 62px;
  margin-bottom: 10px;
  font-size: 0.95rem;
}

.steps > li::before {
  content: counter(step);
  position: absolute;
  left: 16px;
  top: 13px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--green);
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.92rem;
}

.page-s1 .steps > li::before { background: var(--step1); }
.page-s2 .steps > li::before { background: var(--step2); }
.page-s3 .steps > li::before { background: var(--step3); }
.page-s4 .steps > li::before { background: var(--step4); }

.steps > li strong {
  display: block;
  margin-bottom: 2px;
}

.steps img.shot {
  display: block;
  margin-top: 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

/* やってみよう・ヒント・注意・発展 */
.do-box {
  background: var(--card);
  border: 2px solid var(--green);
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-top: 18px;
}

.do-box .do-label {
  display: inline-block;
  background: var(--green);
  color: #fff;
  font-weight: 700;
  font-size: 0.8rem;
  padding: 3px 14px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.page-s1 .do-box { border-color: var(--step1); }
.page-s1 .do-box .do-label { background: var(--step1); }
.page-s2 .do-box { border-color: var(--step2); }
.page-s2 .do-box .do-label { background: var(--step2); }
.page-s3 .do-box { border-color: var(--step3); }
.page-s3 .do-box .do-label { background: var(--step3); }
.page-s4 .do-box { border-color: var(--step4); }
.page-s4 .do-box .do-label { background: var(--step4); }

.tip-box {
  background: #eef5fc;
  border-left: 5px solid #3b82c4;
  border-radius: 0 10px 10px 0;
  padding: 14px 18px;
  font-size: 0.9rem;
  margin-top: 14px;
}

.warn-box {
  background: #fdf0ef;
  border-left: 5px solid #c2545e;
  border-radius: 0 10px 10px 0;
  padding: 14px 18px;
  font-size: 0.9rem;
  margin-top: 14px;
}

.advanced-box {
  background: #f4eefb;
  border: 2px dashed #8e5bbf;
  border-radius: var(--radius);
  padding: 20px 24px;
  margin-top: 18px;
}

.advanced-box .adv-label {
  display: inline-block;
  background: #8e5bbf;
  color: #fff;
  font-weight: 700;
  font-size: 0.8rem;
  padding: 3px 14px;
  border-radius: 999px;
  margin-bottom: 10px;
}

.advanced-box p, .advanced-box li {
  font-size: 0.92rem;
}

/* コード表示 */
pre {
  background: #2b3530;
  color: #e8f0ea;
  padding: 16px 20px;
  border-radius: 10px;
  overflow-x: auto;
  font-size: 0.88rem;
  line-height: 1.7;
  margin: 12px 0;
}

code {
  font-family: Consolas, "Courier New", monospace;
}

:not(pre) > code {
  background: #e9efe9;
  color: #1f5c3b;
  padding: 1px 7px;
  border-radius: 6px;
  font-size: 0.88em;
  word-break: break-all;
}

kbd {
  background: #fff;
  border: 1px solid #b9c4bd;
  border-bottom-width: 3px;
  border-radius: 6px;
  padding: 1px 9px;
  font-size: 0.85em;
  font-family: inherit;
  font-weight: 700;
  white-space: nowrap;
}

/* ログインバー・なまえ入力欄 */
.user-bar button {
  font: inherit;
  font-weight: 700;
  color: #fff;
  background: var(--green);
  border: none;
  border-radius: 999px;
  padding: 7px 20px;
  cursor: pointer;
}

.user-bar button:hover {
  background: var(--green-dark);
}

.user-bar button.logout-btn {
  background: #fff;
  color: var(--text-sub);
  border: 1.5px solid var(--line);
}

.user-bar button.logout-btn:hover {
  background: var(--bg);
  color: var(--text);
}

.user-bar .login-form {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.login-error {
  color: #c0392b;
  font-weight: 700;
  font-size: 0.88rem;
}

.login-error:empty {
  display: none;
}

.login-status strong {
  color: var(--green-dark);
}

/* ---------- 体験ゾーン (見学者向け) ---------- */

.page-tk .step-hero { background: #e2f3f3; }
.page-tk .step-hero .step-label { background: #11898c; }
.page-tk .step-hero h1 { color: #0e7376; }
.page-tk .section-title { border-left-color: #11898c; color: #0e7376; }
.page-tk .steps > li::before { background: #11898c; }
.page-tk .do-box { border-color: #11898c; }
.page-tk .do-box .do-label { background: #11898c; }

.playground {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 14px;
}

@media (max-width: 760px) {
  .playground { grid-template-columns: 1fr; }
}

.playground .pane-label {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text-sub);
  margin-bottom: 6px;
}

.playground textarea {
  width: 100%;
  min-height: 190px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 0.92rem;
  line-height: 1.7;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  resize: vertical;
  background: #fff;
}

.playground textarea:focus {
  outline: 2px solid #11898c;
}

.playground .preview {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 16px;
  min-height: 190px;
  overflow: auto;
}

/* なまえ入力欄 */
.user-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 16px;
  margin-bottom: 16px;
  font-size: 0.9rem;
}

.user-bar label {
  font-weight: 600;
  color: var(--text-sub);
}

.user-bar input {
  font-size: 1rem;
  font-family: inherit;
  padding: 7px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  width: 13em;
  max-width: 100%;
}

.user-bar input:focus {
  outline: 2px solid var(--green);
  border-color: var(--green);
}

.user-bar small {
  color: var(--text-sub);
}

/* 全体進捗バッジ (トップのステップカード) */
.progress-badge {
  display: block;
  margin-top: 6px;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--green-dark);
}

.progress-badge:empty {
  display: none;
}

.progress-badge[data-state="todo"] {
  color: #93a098;
}

.progress-badge[data-state="done"] {
  color: var(--step2);
}

.check-progress .done-msg {
  color: var(--step3);
}

/* 前へ・次へ */
.pager {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: 56px;
  flex-wrap: wrap;
}

.pager a {
  text-decoration: none;
  background: var(--card);
  border: 1.5px solid var(--green);
  color: var(--green-dark);
  font-weight: 700;
  font-size: 0.92rem;
  padding: 12px 22px;
  border-radius: 999px;
}

.pager a:hover {
  background: var(--green);
  color: #fff;
}

.pager .next {
  margin-left: auto;
}

/* 表 */
.simple-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  background: var(--card);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}

.simple-table th, .simple-table td {
  border: 1px solid var(--line);
  padding: 12px 16px;
  text-align: left;
  vertical-align: top;
}

.simple-table th {
  background: var(--green-pale);
  color: var(--green-dark);
  white-space: nowrap;
}

/* 到達目標リスト */
.goal-list {
  list-style: none;
  counter-reset: goal;
}

.goal-list li {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px 22px 18px 64px;
  margin-bottom: 12px;
  position: relative;
  counter-increment: goal;
}

.goal-list li::before {
  content: counter(goal);
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--goal);
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
}

.goal-list li strong {
  display: block;
  margin-bottom: 2px;
}

.goal-list li small {
  color: var(--text-sub);
}

/* 道のりカード (卒業後) */
.path-card {
  border-top: 5px solid var(--green);
}

.path-card h3 {
  font-size: 1rem;
  color: var(--green-dark);
  margin-bottom: 8px;
}

.path-card p {
  font-size: 0.87rem;
  color: var(--text-sub);
}

/* ---------- フッター ---------- */

.site-footer {
  background: var(--green-dark);
  color: #dcebe2;
  padding: 30px 0;
  margin-top: 70px; /* 本文ブロックとフッターの間の余白 (環境差を避けるためフッター側に一本化) */
  font-size: 0.84rem;
  text-align: center;
}

.site-footer a {
  color: #fff;
}

/* ---------- 印刷用 ---------- */

@media print {
  .site-header,
  .global-nav,
  .pager,
  .user-bar,
  .site-footer {
    display: none;
  }

  body {
    background: #fff;
  }

  .hero,
  .step-hero {
    background: #fff;
    border-bottom: 2px solid #999;
    padding: 20px 0;
  }

  .card,
  .goal-box,
  .goal-list li,
  .simple-table {
    box-shadow: none;
  }

  a {
    text-decoration: none;
    color: inherit;
  }
}
