/* ============================================================
   FP2級・3級 用語集 共通スタイルシート
   style.css
   ============================================================ */


/* ────────────────────────────────────────
   1. カスタムプロパティ（デザイントークン）
   ──────────────────────────────────────── */
:root {
  /* ブランドカラー */
  --color-fp2-primary:    #1a5ca8;   /* 2級：濃いブルー */
  --color-fp2-light:      #dce9f8;
  --color-fp2-accent:     #2979c8;

  --color-fp3-primary:    #1e7c4b;   /* 3級：グリーン */
  --color-fp3-light:      #d6f0e3;
  --color-fp3-accent:     #27a060;

  /* ニュートラル */
  --color-bg:             #f4f6f9;
  --color-surface:        #ffffff;
  --color-border:         #d0d7e3;
  --color-border-light:   #e8ecf2;
  --color-text:           #1a1d23;
  --color-text-muted:     #5a6274;
  --color-note-bg:        #fdf8ec;
  --color-note-border:    #e8c94a;
  --color-note-text:      #5c4a00;

  /* タイポグラフィ */
  --font-sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif;
  --font-size-base:   15px;
  --line-height-base: 1.85;

  /* スペーシング */
  --space-xs:  4px;
  --space-sm:  8px;
  --space-md:  16px;
  --space-lg:  24px;
  --space-xl:  40px;
  --space-2xl: 64px;

  /* 角丸・シャドウ */
  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;
  --shadow-card: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-hover: 0 4px 16px rgba(0,0,0,0.13);

  /* レイアウト */
  --max-width: 900px;
}


/* ────────────────────────────────────────
   2. リセット・ベース
   ──────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

.fp-body {
  font-family: var(--font-sans);
  background-color: var(--color-bg);
  font-size: var(--font-size-base);
  color: var(--color-text);
  line-height: var(--line-height-base);
  -webkit-font-smoothing: antialiased;
}

.fp-body a {
  color: inherit;
  text-decoration: none;
}


/* ────────────────────────────────────────
   3. ヒーローセクション（.hero）
   ──────────────────────────────────────── */
.hero {
  background: linear-gradient(135deg, #1a3a6e 0%, #2060b0 60%, #2979c8 100%);
  color: #ffffff;
  text-align: center;
  padding: var(--space-2xl) var(--space-lg) var(--space-xl);
  position: relative;
  overflow: hidden;
}

/* 3級ページはグリーン系 */
.hero:has(~ * .grade-3),
body:has(.grade-3) .hero {
  background: linear-gradient(135deg, #0f4a2b 0%, #1e7c4b 60%, #27a060 100%);
}

/* ヒーロー内の装飾円 */
.hero::before {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(255,255,255,0.05);
  top: -80px;
  right: -60px;
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  bottom: -60px;
  left: 40px;
  pointer-events: none;
}

.hero-eyebrow {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  opacity: 0.8;
  margin-bottom: var(--space-md);
  text-transform: uppercase;
}

.hero-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border: 2px solid rgba(255,255,255,0.6);
  border-radius: 50%;
  font-size: 1.6rem;
  font-weight: 700;
  margin: 0 auto var(--space-md);
  letter-spacing: 0;
}

.hero h1 {
  font-size: clamp(1.5rem, 4vw, 2.2rem);
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-sm);
  line-height: 1.3;
}

.hero-sub {
  font-size: 0.9rem;
  opacity: 0.75;
}


/* ────────────────────────────────────────
   4. イントロカード（.intro-card）
   ──────────────────────────────────────── */
.intro-card {
  max-width: var(--max-width);
  margin: var(--space-xl) auto;
  padding: var(--space-lg) var(--space-xl);
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  border-left: 5px solid var(--color-fp2-primary);
}

.intro-card.grade-3 {
  border-left-color: var(--color-fp3-primary);
}

.intro-lead {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--color-fp2-primary);
  margin-bottom: var(--space-md);
  line-height: 1.6;
}

.intro-card.grade-3 .intro-lead {
  color: var(--color-fp3-primary);
}

.intro-body {
  font-size: 0.93rem;
  color: var(--color-text-muted);
  line-height: 1.9;
}

.intro-body strong {
  color: var(--color-text);
}


/* ────────────────────────────────────────
   5. ナビゲーション（nav）
   ──────────────────────────────────────── */
.fp-body nav {
  max-width: var(--max-width);
  margin: 0 auto var(--space-xl);
  padding: 0 var(--space-lg);
}

.fp-body nav ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.fp-body nav ul li a {
  display: inline-block;
  padding: 5px 14px;
  font-size: 0.82rem;
  font-weight: 500;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 20px;
  color: var(--color-fp2-primary);
  transition: background 0.18s, color 0.18s, border-color 0.18s, box-shadow 0.18s;
  white-space: nowrap;
}

.fp-body nav ul li a:hover {
  background: var(--color-fp2-primary);
  color: #fff;
  border-color: var(--color-fp2-primary);
  box-shadow: 0 2px 6px rgba(26,92,168,0.2);
}

/* 3級ページ */
body:has(.grade-3) .fp-body nav ul li a {
  color: var(--color-fp3-primary);
}
body:has(.grade-3) .fp-body nav ul li a:hover {
  background: var(--color-fp3-primary);
  color: #fff;
  border-color: var(--color-fp3-primary);
  box-shadow: 0 2px 6px rgba(30,124,75,0.2);
}


/* ────────────────────────────────────────
   6. メインコンテナ（.container）
   ──────────────────────────────────────── */
.fp-container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--space-lg) var(--space-2xl);
}


/* ────────────────────────────────────────
   7. 大項目見出し（h2）
   ──────────────────────────────────────── */
.fp-container h2 {
  font-size: 1.15rem;
  font-weight: 700;
  color: #ffffff;
  background: var(--color-fp2-primary);
  padding: var(--space-sm) var(--space-md);
  border-radius: var(--radius-sm);
  margin: var(--space-xl) 0 var(--space-md);
  letter-spacing: 0.04em;
  scroll-margin-top: 20px;
}

body:has(.grade-3) .fp-container h2 {
  background: var(--color-fp3-primary);
}


/* ────────────────────────────────────────
   8. 用語ブロック（.term-block）
   ──────────────────────────────────────── */
.term-block {
  background: var(--color-surface);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-lg) var(--space-md);
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-card);
  transition: box-shadow 0.2s;
}

.term-block:hover {
  box-shadow: var(--shadow-hover);
}

/* 左ボーダーアクセント */
.term-block {
  border-left: 4px solid var(--color-fp2-primary);
}

body:has(.grade-3) .term-block {
  border-left-color: var(--color-fp3-primary);
}


/* ────────────────────────────────────────
   9. 用語見出し（.term-title）
   ──────────────────────────────────────── */
.term-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-fp2-primary);
  margin-bottom: var(--space-sm);
  line-height: 1.45;
  letter-spacing: 0.02em;
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border-light);
}

body:has(.grade-3) .term-title {
  color: var(--color-fp3-primary);
}


/* ────────────────────────────────────────
   10. 定義文（.term-desc）
   ──────────────────────────────────────── */
.term-desc {
  font-size: 0.93rem;
  color: var(--color-text);
  line-height: 1.9;
  margin-top: var(--space-sm);
  margin-bottom: var(--space-sm);
}

.term-desc strong {
  color: var(--color-fp2-primary);
  font-weight: 700;
}

body:has(.grade-3) .term-desc strong {
  color: var(--color-fp3-primary);
}


/* ────────────────────────────────────────
   11. 補足・注意（.term-note）
   ──────────────────────────────────────── */
.term-note {
  font-size: 0.875rem;
  background: var(--color-note-bg);
  border-left: 3px solid var(--color-note-border);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: var(--space-sm) var(--space-md);
  color: var(--color-note-text);
  margin-top: var(--space-md);
  line-height: 1.8;
}

.term-note strong {
  color: #3d2f00;
}


/* ────────────────────────────────────────
   12. サブ項目リスト（.term-list）
   ──────────────────────────────────────── */
.term-list {
  list-style: none;
  margin-top: var(--space-md);
  padding-left: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.term-list > li {
  background: var(--color-bg);
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius-sm);
  padding: var(--space-sm) var(--space-md);
}

.term-list > li::before {
  content: none;
}


/* ────────────────────────────────────────
   13. サブ項目タイトル（.term-sub-title）
   ──────────────────────────────────────── */
.term-sub-title {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: var(--space-xs);
  line-height: 1.7;
}

.term-sub-title strong {
  color: var(--color-fp2-primary);
  font-weight: 700;
}

body:has(.grade-3) .term-sub-title strong {
  color: var(--color-fp3-primary);
}


/* ────────────────────────────────────────
   14. サブ項目説明文（.term-sub-desc）
   ──────────────────────────────────────── */
.term-sub-desc {
  font-size: 0.875rem;
  color: var(--color-text-muted);
  line-height: 1.85;
  margin-bottom: var(--space-xs);
}

.term-sub-desc strong {
  color: var(--color-text);
  font-weight: 600;
}


/* ────────────────────────────────────────
   15. 入れ子リスト（.term-sublist）
   ──────────────────────────────────────── */
.term-sublist {
  list-style: none;
  margin-top: var(--space-sm);
  padding-left: var(--space-md);
  border-left: 2px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.term-sublist > li {
  position: relative;
  padding-left: var(--space-md);
}

.term-sublist > li::before {
  content: "›";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-fp2-primary);
  font-weight: 700;
  line-height: var(--line-height-base);
}

body:has(.grade-3) .term-sublist > li::before {
  color: var(--color-fp3-primary);
}

.term-sublist .term-sub-title {
  font-size: 0.855rem;
}

.term-sublist .term-sub-desc {
  font-size: 0.845rem;
}


/* ────────────────────────────────────────
   16. インライン強調（strong）
   ──────────────────────────────────────── */
.fp-container strong {
  font-weight: 700;
}


/* ────────────────────────────────────────
   17. レスポンシブ対応
   ──────────────────────────────────────── */

/* タブレット */
@media (max-width: 768px) {
  :root {
    --font-size-base: 14px;
  }

  .hero {
    padding: var(--space-xl) var(--space-md) var(--space-lg);
  }

  .intro-card {
    margin: var(--space-lg) var(--space-md);
    padding: var(--space-md) var(--space-lg);
  }

  .fp-body nav {
    padding: 0 var(--space-md);
  }

  .fp-container {
    padding: 0 var(--space-md) var(--space-xl);
  }

  .fp-container h2 {
    font-size: 1rem;
  }

  .term-block {
    padding: var(--space-md);
  }

  .term-title {
    font-size: 1rem;
  }
}

/* スマートフォン */
@media (max-width: 480px) {
  .hero h1 {
    font-size: 1.35rem;
  }

  .hero-label {
    width: 48px;
    height: 48px;
    font-size: 1.3rem;
  }

  .fp-body nav ul {
    gap: 6px;
  }

  .fp-body nav ul li a {
    font-size: 0.78rem;
    padding: 4px 11px;
  }

  .term-block {
    border-left-width: 3px;
  }

  .term-list > li {
    padding: var(--space-sm);
  }

  .term-sublist {
    padding-left: var(--space-sm);
  }
}


/* ────────────────────────────────────────
   18. 印刷スタイル
   ──────────────────────────────────────── */
@media print {
  .fp-body {
    background: #fff;
    font-size: 11pt;
  }

  .hero {
    background: #1a3a6e !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .fp-body nav {
    display: none;
  }

  .term-block {
    break-inside: avoid;
    box-shadow: none;
    border: 1px solid #ccc;
    margin-bottom: 12pt;
  }

  .fp-container h2 {
    break-after: avoid;
  }

  .term-title {
    break-after: avoid;
  }
}
