/* 共通レイアウト・ナビ・モバイル最適化（全ページ共通） */
.topnav {
  display: flex; align-items: center; gap: 1.1em; flex-wrap: wrap;
  padding: .55em .95em; margin-bottom: 1.4em; font-size: .86em;
  border: 1px solid var(--color-border); border-radius: 10px;
  background: var(--color-bg-highlight);
}
.topnav .brand { font-weight: 700; color: var(--color-primary); letter-spacing: .03em; }
.topnav a { color: var(--color-text-link); text-decoration: none; }
.topnav a:hover { text-decoration: underline; }
.topnav .spacer { flex: 1 1 auto; }
.topnav .who { color: var(--color-text-label); }

/* レーダーの目盛説明・空状態 */
.scale-note { font-size: .75em; color: var(--color-text-label); text-align: center; margin: .2em 0 0; }
.empty { color: var(--color-text-label); font-size: .88em; padding: .5em 0; }

/* レーダー色スウォッチ（DSパレットから選択） */
.swatchrow { display: inline-flex; gap: .4em; vertical-align: middle; margin-left: .4em; }
.swatchrow .sw { width: 1.45em; height: 1.45em; border-radius: 50%; cursor: pointer;
  border: 2px solid transparent; box-sizing: border-box; }
.swatchrow .sw.active {
  border-color: var(--color-bg);
  box-shadow: 0 0 0 2px var(--color-text);
}

/* 設定（歯車）メニュー */
.gearwrap { position: relative; display: inline-flex; }
.gear { background: none; border: 1px solid var(--color-border); border-radius: 7px;
  cursor: pointer; font-size: 1.05em; line-height: 1; padding: .2em .45em; color: var(--color-text); }
.gear:hover { border-color: var(--color-primary); color: var(--color-primary); }
.settings-panel { position: absolute; right: 0; top: 135%; z-index: 60; min-width: 215px;
  background: var(--color-bg); border: 1px solid var(--color-border); border-radius: 10px;
  padding: .75em .85em; box-shadow: 0 6px 20px rgba(0,0,0,.18); }
.settings-panel[hidden] { display: none; }
.sp-title { font-size: .8em; color: var(--color-text-label); margin-bottom: .5em; }
.sp-note { font-size: .72em; color: var(--color-text-label); margin-top: .55em; }
.settings-panel .swatchrow .sw { width: 1.6em; height: 1.6em; }
.themerow { display: inline-flex; gap: .35em; }
.themebtn { font-size: .78em; padding: .28em .7em; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--color-border); background: var(--color-bg-control); color: var(--color-text); }
.themebtn:hover { border-color: var(--color-primary); }
.themebtn.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* スキル項目が「どの人材類型のスキルか」を示すバッジ（a=最重要 / b=重要） */
.typebadges { margin-top: .35em; display: flex; flex-wrap: wrap; gap: .3em; }
.typebadge { font-size: .72em; line-height: 1.5; padding: .04em .55em; border-radius: 999px;
  border: 1px solid var(--color-border); color: var(--color-text-label);
  background: var(--color-bg); white-space: nowrap; }
.typebadge.a { border-color: var(--color-primary); color: var(--color-primary);
  background: var(--color-primary-tint); font-weight: 600; }
.typebadge.more { border-style: dashed; cursor: help; }

/* アドバイス本文中で推薦科目名を強調（選択中のチャート色に追従） */
.coursehl { font-weight: 700; color: var(--dssp-accent, var(--color-primary)); }

/* 全ページ共通フッター（判定アルゴリズム版・DSS版・最終判定） */
.app-footer { margin: 2.4em auto 1.2em; padding-top: .9em; max-width: 980px;
  border-top: 1px solid var(--color-border); text-align: center;
  font-size: .76em; color: var(--color-text-label); line-height: 1.7; }
.app-footer code { background: var(--color-bg-control); padding: .08em .4em; border-radius: 4px; }

/* ワンポイントアドバイス（レーダーの傾向＋DSS狙いRAG） */
.insight { background: var(--color-primary-tint); border-left: 3px solid var(--color-primary);
  border-radius: 6px; padding: .55em .7em; margin-top: .55em; font-size: .85em; line-height: 1.7; }
.insight .src { display: inline-block; margin-top: .4em; font-size: .74em;
  border: 1px solid var(--color-primary); border-radius: 999px; padding: .05em .65em; color: var(--color-primary); }

@media (max-width: 600px) {
  body { margin-top: 1.1em !important; margin-bottom: 1.4em !important; }
  .topnav { font-size: .8em; gap: .85em; padding: .5em .7em; }
  .grid { grid-template-columns: 1fr !important; }
  table { font-size: .82em; }
  h1 { font-size: 1.4em; }
}

/* reskilling-app 追加: デモロール切替セレクタ（プロト専用） */
.roleswitch { font-size: .82em; padding: .25em .5em; border-radius: 7px;
  border: 1px solid var(--color-border); background: var(--color-bg-control);
  color: var(--color-text); cursor: pointer; }
.roleswitch:hover { border-color: var(--color-primary); }

/* ロールビューのヘッダ帯（どのロールで見ているかを明示） */
.rolebanner { display: inline-block; font-size: .8em; font-weight: 600;
  padding: .15em .7em; border-radius: 999px; margin-bottom: .8em;
  color: var(--color-primary); background: var(--color-primary-tint);
  border: 1px solid var(--color-primary); }
.stage-note { color: var(--color-text-label); font-size: .9em;
  border-left: 3px solid var(--color-border); padding: .4em .8em; margin: 1em 0; }
