/* ━━━ 易のいろは 卦個別ページ（hexagram）固有スタイル ━━━ */

/* ─── nav-toggle（モバイル） ─── */
.nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: 4px; flex-direction: column; gap: 5px; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--accent); border-radius: 1px; }

/* ─── Main（このページは max-width: 900px） ─── */
.main { max-width: 900px; margin: 20px auto 60px; padding: 0 20px; }

/* ─── Hero ─── */
.hero { background: var(--white); border: 1px solid var(--border); border-radius: 6px; padding: 36px 40px; margin-bottom: 20px; display: grid; grid-template-columns: 110px 1fr; gap: 36px; align-items: start; }
.hexagram-fig { display: flex; flex-direction: column; gap: 0; padding-top: 4px; }
.trigram-group { display: flex; flex-direction: column; gap: 8px; padding: 8px 0; }
.trigram-group + .trigram-group { border-top: 1px dashed var(--border); }
.trigram-group-label { font-size: 0.65rem; color: var(--muted); letter-spacing: 0.05em; padding-left: 32px; margin-bottom: -2px; }
.yao-row { display: flex; align-items: center; gap: 8px; }
.yao-label { font-size: 0.68rem; color: var(--muted); width: 24px; text-align: right; flex-shrink: 0; }
.yao-line { width: 64px; height: 9px; background: var(--accent); border-radius: 2px; position: relative; }
.yao-line.yin { background: transparent; }
.yao-line.yin::before, .yao-line.yin::after { content: ''; position: absolute; top: 0; bottom: 0; width: 27px; background: var(--accent); border-radius: 2px; }
.yao-line.yin::before { left: 0; }
.yao-line.yin::after  { right: 0; }
.hero-kana { font-size: 0.78rem; color: var(--muted); letter-spacing: 0.08em; margin-bottom: 2px; }
.hero-title { font-family: var(--serif); font-size: 2.2rem; color: var(--accent); line-height: 1.2; margin-bottom: 4px; letter-spacing: 0.1em; }
.hero-en { font-size: 0.8rem; color: var(--muted); letter-spacing: 0.06em; margin-bottom: 18px; }

/* ─── 上卦・下卦カード ─── */
.trigram-info { display: flex; gap: 10px; margin-bottom: 18px; }
.trigram-card { flex: 1; display: flex; flex-direction: column; gap: 2px; background: var(--panel); border: 1px solid var(--border); border-radius: 5px; padding: 10px 12px; text-decoration: none; transition: border-color .15s; }
.trigram-card:hover { border-color: var(--accent-lt); }
.trigram-card-label { font-size: 0.62rem; color: var(--muted); letter-spacing: 0.06em; }
.trigram-card-name { font-family: var(--serif); font-size: 1rem; color: var(--accent); display: flex; align-items: center; gap: 6px; }
.trigram-card-symbol { font-size: 1.2rem; opacity: 0.7; }
.trigram-card-attr { font-size: 0.68rem; color: var(--muted); }

/* ─── 卦辞ブロック ─── */
.kiji-block { background: var(--panel); border-left: 3px solid var(--accent); border-radius: 0 4px 4px 0; padding: 14px 18px; margin-bottom: 14px; }
.kiji-label { font-size: 0.65rem; color: var(--muted); letter-spacing: 0.08em; margin-bottom: 4px; }
.kiji-original { font-family: var(--serif); font-size: 1.05rem; color: var(--accent); font-weight: bold; margin-bottom: 2px; }
.kiji-reading { font-size: 0.78rem; color: var(--muted); margin-bottom: 6px; }
.kiji-trans { font-size: 0.88rem; color: var(--text); }

/* ─── キーワード ─── */
.keyword-list { display: flex; flex-wrap: wrap; gap: 6px; }
.keyword-tag { font-size: 0.72rem; background: var(--panel); border: 1px solid var(--border); color: var(--accent); border-radius: 20px; padding: 3px 10px; }

/* ─── 先生コメント追加スタイル ─── */
.sensei-comment-body p + p { margin-top: 8px; }

/* ─── セクション共通 ─── */
.section { background: var(--white); border: 1px solid var(--border); border-radius: 6px; margin-bottom: 16px; overflow: hidden; }
.section-head { background: var(--panel); border-bottom: 1px solid var(--border); padding: 12px 22px; display: flex; align-items: center; gap: 10px; }
.section-head h2 { font-family: var(--serif); font-size: 1.05rem; color: var(--accent); }
.section-body { padding: 22px 24px; font-size: 0.92rem; line-height: 2; }
.section-body p + p { margin-top: 12px; }

/* ─── 六爻テーブル ─── */
.yao-table { width: 100%; border-collapse: collapse; font-size: 0.86rem; }
.yao-table th { text-align: left; padding: 9px 14px; background: var(--panel); border-bottom: 2px solid var(--border); font-weight: bold; color: var(--accent); font-family: var(--serif); font-size: 0.8rem; white-space: nowrap; }
.yao-table td { padding: 11px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.yao-table tr:last-child td { border-bottom: none; }
.yao-table tr:hover td { background: #fdf9f5; }
.yao-num { font-size: 0.75rem; color: var(--muted); white-space: nowrap; }
.yao-name { font-family: var(--serif); font-size: 0.95rem; color: var(--accent); white-space: nowrap; }
.yao-text-original { font-family: var(--serif); font-size: 0.9rem; color: var(--text); }
.yao-text-trans { font-size: 0.78rem; color: var(--muted); margin-top: 2px; }
.yao-kikkyo { display: inline-block; font-family: var(--serif); font-size: 0.72rem; padding: 2px 9px; border-radius: 3px; white-space: nowrap; font-weight: bold; letter-spacing: 0.04em; }
.kikkyo-daikichi { background: #c8960c; color: #fff; }
.kikkyo-kichi    { background: #2e7d32; color: #fff; }
.kikkyo-chukichi { background: #558b2f; color: #fff; }
.kikkyo-shokichi { background: var(--accent); color: #fff; }
.kikkyo-hei      { background: #78909c; color: #fff; }
.kikkyo-shokyou  { background: #e65100; color: #fff; }
.kikkyo-kyou     { background: #b71c1c; color: #fff; }
.kikkyo-daikyou  { background: #4a148c; color: #fff; }
.yao-link { display: inline-block; font-size: 0.75rem; color: var(--accent); text-decoration: none; border: 1px solid var(--border); border-radius: 3px; padding: 3px 10px; white-space: nowrap; transition: background .15s, color .15s; }
.yao-link:hover { background: var(--accent); color: var(--white); border-color: var(--accent); }

/* ─── 八卦カード ─── */
.hakke-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.hakke-card { background: var(--panel); border: 1px solid var(--border); border-radius: 5px; padding: 18px 20px; text-decoration: none; display: block; transition: border-color .15s, box-shadow .15s; }
.hakke-card:hover { border-color: var(--accent-lt); box-shadow: 0 2px 8px rgba(0,0,0,.07); }
.hakke-card-role { font-size: 0.65rem; color: var(--muted); letter-spacing: 0.08em; margin-bottom: 6px; }
.hakke-card-name { font-family: var(--serif); font-size: 1.4rem; color: var(--accent); display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.hakke-card-sym { font-size: 2rem; opacity: 0.6; line-height: 1; }
.hakke-card-attrs { font-size: 0.78rem; color: var(--muted); line-height: 1.7; }
.hakke-card-link { font-size: 0.72rem; color: var(--accent); margin-top: 8px; }

/* ─── 関連する卦 ─── */
.related-hexagrams { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.related-card { display: block; text-decoration: none; background: var(--panel); border: 1px solid var(--border); border-radius: 5px; padding: 14px 16px; text-align: center; transition: border-color .15s, box-shadow .15s; }
.related-card:hover { border-color: var(--accent-lt); box-shadow: 0 2px 6px rgba(0,0,0,.07); }
.related-label { font-size: 0.62rem; color: var(--muted); letter-spacing: 0.06em; margin-bottom: 6px; }
.related-svg-wrap { margin: 0 auto 8px; width: 44px; }
.related-name { font-family: var(--serif); font-size: 0.9rem; color: var(--accent); margin-bottom: 2px; }
.related-yomi { font-size: 0.68rem; color: var(--muted); }
.related-num { font-size: 0.62rem; color: var(--muted); margin-top: 3px; }
.related-note { font-size: 0.78rem; color: var(--muted); margin-top: 14px; line-height: 1.7; }

/* ─── 前後ナビ ─── */
.hex-nav { display: flex; gap: 10px; margin-bottom: 16px; }
.hex-nav-card { flex: 1; display: flex; align-items: center; gap: 10px; background: var(--white); border: 1px solid var(--border); border-radius: 5px; padding: 12px 16px; text-decoration: none; transition: border-color .15s; }
.hex-nav-card:hover { border-color: var(--accent-lt); }
.hex-nav-card.prev { flex-direction: row; }
.hex-nav-card.next { flex-direction: row-reverse; text-align: right; }
.hex-nav-dir { font-size: 0.65rem; color: var(--muted); letter-spacing: 0.06em; }
.hex-nav-name { font-family: var(--serif); font-size: 0.9rem; color: var(--accent); }
.hex-nav-yomi { font-size: 0.68rem; color: var(--muted); }
.hex-nav-arrow { font-size: 1.1rem; color: var(--accent); opacity: 0.5; flex-shrink: 0; }
.hex-nav-placeholder { flex: 1; }

/* ─── 占いバナー（グラデーション版） ─── */
.uranai-banner { background: linear-gradient(135deg, #6B3A2A 0%, #9B5B3E 100%); border: none; border-radius: 6px; padding: 24px 28px; margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.uranai-banner-text h3 { font-family: var(--serif); font-size: 1.05rem; color: var(--white); margin-bottom: 4px; }
.uranai-banner-text p { font-size: 0.8rem; color: rgba(255,255,255,.75); }
.uranai-banner-btn { display: inline-block; background: var(--white); color: var(--accent); font-family: var(--serif); font-size: 0.88rem; font-weight: bold; padding: 10px 22px; border-radius: 4px; text-decoration: none; white-space: nowrap; transition: opacity .15s; }
.uranai-banner-btn:hover { opacity: .85; }

/* ─── Responsive ─── */
@media (max-width: 620px) {
  .hero { grid-template-columns: 1fr; padding: 24px 20px; gap: 24px; }
  .hexagram-fig { flex-direction: row; gap: 24px; }
  .site-nav { display: none; }
  .nav-toggle { display: flex; }
  .hero-title { font-size: 1.8rem; }
  .hakke-cards { grid-template-columns: 1fr; }
  .uranai-banner { flex-direction: column; align-items: flex-start; }
}
