@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* ===== のべもあ 辞書ページ共通 ===== */
:root {
  --nb-brand:   #2d1b69;
  --nb-text:    #1a0e3d;
  --nb-link:    #2d1b69;
  --nb-bg:      #f8f6ff;
  --nb-border:  #d9d3f0;
  --nb-accent:  #7c5cdb;
}

.glossary-archive,
.glossary-single {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro",
               "メイリオ", Meiryo, sans-serif;
  color: var(--nb-text);
  background: var(--nb-bg);
}

/* ===== 辞書トップ ===== */
.glossary-archive .l-container {
  max-width: 860px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

.glossary-archive h1 {
  font-size: 1.6rem;
  color: var(--nb-brand);
  border-left: 4px solid var(--nb-brand);
  padding-left: 0.75rem;
  margin-bottom: 0.5rem;
}

.glossary-archive > .l-container > p {
  color: var(--nb-text);
  font-size: 0.95rem;
  margin-bottom: 1.5rem;
}

/* 検索フォーム */
.glossary-search {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.glossary-search input {
  flex: 1;
  padding: 0.6rem 1rem;
  border: 1.5px solid var(--nb-border);
  border-radius: 6px;
  font-size: 0.95rem;
  background: #fff;
  color: var(--nb-text);
  outline: none;
  transition: border-color 0.2s;
}

.glossary-search input:focus {
  border-color: var(--nb-accent);
}

.glossary-search button {
  padding: 0.6rem 1.2rem;
  background: var(--nb-brand);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.95rem;
  cursor: pointer;
  transition: opacity 0.2s;
}

.glossary-search button:hover {
  opacity: 0.85;
}

/* カテゴリ絞り込み */
.glossary-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.gf-cat {
  padding: 0.35rem 1rem;
  border: 1.5px solid var(--nb-border);
  border-radius: 20px;
  font-size: 0.85rem;
  font-family: inherit;
  color: var(--nb-brand);
  background: #fff;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.gf-cat:hover {
  border-color: var(--nb-accent);
  color: var(--nb-accent);
}

.gf-cat.active {
  background: var(--nb-brand);
  color: #fff;
  border-color: var(--nb-brand);
}

/* 50音インデックス */
.glossary-index {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 1.75rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--nb-border);
}

.gi-row {
  position: relative;
}

.gi-label {
  display: inline-block;
  padding: 0.3rem 0.7rem;
  border: 1px solid var(--nb-border);
  border-radius: 4px;
  font-size: 0.82rem;
  color: var(--nb-text);
  cursor: default;
  transition: background 0.2s, color 0.2s;
  user-select: none;
}

.gi-row:hover .gi-label,
.gi-row.open .gi-label {
  background: var(--nb-brand);
  color: #fff;
  border-color: var(--nb-brand);
}

.gi-chars {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 100;
  background: #fff;
  border: 1px solid var(--nb-border);
  border-radius: 6px;
  padding: 0.4rem;
  gap: 0.25rem;
  box-shadow: 0 4px 12px rgba(45, 27, 105, 0.12);
  white-space: nowrap;
}

.gi-row.open .gi-chars {
  display: flex;
}

.gi-char {
  padding: 0.3rem 0.6rem;
  border: 1px solid var(--nb-border);
  border-radius: 4px;
  font-size: 0.82rem;
  color: var(--nb-text);
  background: #fff;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.gi-char:hover,
.gi-char.active {
  background: var(--nb-accent);
  color: #fff;
  border-color: var(--nb-accent);
}

/* 用語リスト */
.glossary-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border: 1px solid var(--nb-border);
  border-radius: 8px;
  overflow: hidden;
}

.glossary-item {
  border-bottom: 1px solid var(--nb-border);
}

.glossary-item:last-child,
.glossary-item:nth-last-child(2):nth-child(odd) {
  border-bottom: none;
}

.glossary-item:nth-child(odd) {
  border-right: 1px solid var(--nb-border);
}

.glossary-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}

.glossary-item a {
  display: flex;
  align-items: center;
  padding: 0.75rem 1.25rem;
  text-decoration: none;
  transition: background 0.15s;
  min-height: 48px;
}

.glossary-item a:hover {
  background: #eee9fc;
}

.glossary-term {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--nb-link);
}

.glossary-desc {
  display: none;
}

@media (max-width: 600px) {
  .glossary-list {
    grid-template-columns: 1fr;
  }

  .glossary-item:nth-child(odd) {
    border-right: none;
  }
}

/* ===== 個別辞書ページ ===== */
.glossary-single .l-container {
  max-width: 860px;
  margin: 0 auto;
  padding: 2rem 1rem;
}

.glossary-single h1 {
  font-size: 1.5rem;
  color: var(--nb-brand);
  line-height: 1.4;
  margin-bottom: 1rem;
  border-left: 4px solid var(--nb-brand);
  padding-left: 0.75rem;
}

/* 一言定義ボックス */
.glossary-summary {
  background: #fff;
  border: 1.5px solid var(--nb-border);
  border-radius: 8px;
  padding: 1rem 1.25rem;
  font-size: 0.95rem;
  line-height: 1.7;
  margin-bottom: 2rem;
  color: var(--nb-text);
}

/* 本文 */
.glossary-body h2 {
  font-size: 1.2rem;
  color: var(--nb-brand);
  border-bottom: 2px solid var(--nb-brand);
  padding-bottom: 0.4rem;
  margin: 2rem 0 0.75rem;
}

.glossary-body h3 {
  font-size: 1rem;
  color: var(--nb-text);
  border-left: 3px solid var(--nb-accent);
  padding-left: 0.6rem;
  margin: 1.25rem 0 0.5rem;
}

.glossary-body p {
  font-size: 0.95rem;
  line-height: 1.8;
  margin-bottom: 1rem;
}

/* 読者の期待セクション */
.glossary-expectation {
  background: #fff;
  border: 1px solid var(--nb-border);
  border-radius: 8px;
  padding: 1.25rem;
  margin: 2rem 0;
}

.glossary-expectation h2 {
  font-size: 1.1rem;
  color: var(--nb-brand);
  margin-bottom: 0.75rem;
}

.glossary-expectation p {
  font-size: 0.95rem;
  line-height: 1.8;
}

/* 関連用語 */
.glossary-related-terms {
  margin: 2rem 0;
}

.glossary-related-terms h2 {
  font-size: 1.1rem;
  color: var(--nb-brand);
  border-bottom: 1px solid var(--nb-border);
  padding-bottom: 0.4rem;
  margin-bottom: 0.75rem;
}

.glossary-related-terms ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.glossary-related-terms a {
  padding: 0.35rem 0.9rem;
  background: var(--nb-bg);
  border: 1.5px solid var(--nb-border);
  border-radius: 20px;
  font-size: 0.88rem;
  color: var(--nb-brand);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}

.glossary-related-terms a:hover {
  background: var(--nb-brand);
  color: #fff;
}

/* 関連記事 */
.glossary-related-posts {
  margin: 2rem 0;
}

.glossary-related-posts h2 {
  font-size: 1.1rem;
  color: var(--nb-brand);
  border-bottom: 1px solid var(--nb-border);
  padding-bottom: 0.4rem;
  margin-bottom: 0.75rem;
}

.glossary-related-posts ul {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.glossary-related-posts a {
  display: block;
  padding: 0.6rem 1rem;
  background: #fff;
  border: 1px solid var(--nb-border);
  border-radius: 6px;
  font-size: 0.9rem;
  color: var(--nb-link);
  text-decoration: none;
  transition: border-color 0.2s;
}

.glossary-related-posts a:hover {
  border-color: var(--nb-accent);
}

/* スマホ対応 */
@media (max-width: 600px) {
  .glossary-list {
    grid-template-columns: 1fr;
  }

  .glossary-filter,
  .glossary-index {
    gap: 0.35rem;
  }

  .glossary-single h1 {
    font-size: 1.25rem;
  }
}

/* 前の語句・次の語句ナビゲーション */
.glossary-adjacent {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin: 2.5rem 0 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--nb-border);
}

.glossary-adjacent-prev,
.glossary-adjacent-next {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  max-width: 48%;
}

.glossary-adjacent-next {
  text-align: right;
  margin-left: auto;
}

.glossary-adjacent-label {
  font-size: 0.75rem;
  color: var(--nb-text);
  opacity: 0.6;
}

.glossary-adjacent a {
  font-size: 0.95rem;
  color: var(--nb-link);
  text-decoration: none;
  font-weight: 600;
  transition: opacity 0.2s;
}

.glossary-adjacent a:hover {
  opacity: 0.7;
}

/* 自動リンク */
.glossary-auto-link {
  color: var(--nb-accent);
  text-decoration: underline;
  text-decoration-style: dotted;
  text-underline-offset: 2px;
}

.glossary-auto-link:hover {
  color: var(--nb-brand);
}

@media (max-width: 600px) {
  .glossary-adjacent {
    flex-direction: column;
    gap: 1rem;
  }

  .glossary-adjacent-next {
    text-align: left;
    margin-left: 0;
  }
}

/* サイドバー辞書検索 */
.sidebar-glossary-search {
  background: var(--nb-bg);
  border: 1.5px solid var(--nb-border);
  border-radius: 8px;
  padding: 1rem 1.25rem;
}

.sidebar-glossary-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--nb-brand);
  margin-bottom: 0.75rem;
}

.sidebar-glossary-search input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1.5px solid var(--nb-border);
  border-radius: 6px;
  font-size: 0.88rem;
  background: #fff;
  color: var(--nb-text);
  outline: none;
  box-sizing: border-box;
  margin-bottom: 0.5rem;
  transition: border-color 0.2s;
}

.sidebar-glossary-search input:focus {
  border-color: var(--nb-accent);
}

.sidebar-glossary-search button {
  width: 100%;
  padding: 0.5rem;
  background: var(--nb-brand);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.88rem;
  cursor: pointer;
  transition: opacity 0.2s;
  margin-bottom: 0.75rem;
}

.sidebar-glossary-search button:hover {
  opacity: 0.85;
}

.sidebar-glossary-link {
  display: block;
  font-size: 0.85rem;
  color: var(--nb-accent);
  text-decoration: none;
  text-align: right;
}

.sidebar-glossary-link:hover {
  color: var(--nb-brand);
}

/* 辞書ページでサイドバー辞書検索を非表示 */
.post-type-archive-glossary .sidebar-glossary-search {
  display: none;
}