/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
  --c-primary:        #8b411c;
  --c-primary-light:  #A65D3F;
  --c-primary-dark:   #6B2F10;
  --c-accent:         #C9A96E;
  --c-accent-light:   #E0CCA0;

  --c-topbg:          #eee4da;
  --c-topline:        url(/images/topline.png);
  --c-bg:             #F5F0EB;
  --c-surface:        #FFFFFF;
  --c-surface-alt:    #FAF7F3;
  --c-text:           #2C2520;
  --c-text-secondary: #8C7E72;
  --c-border:         #D6CEC6;
  --c-border-light:   #EAE4DD;
  --c-shadow:         rgba(44,37,32,0.08);

  --ff-sans:  "PingFang SC","Hiragino Sans GB","Microsoft YaHei","Noto Sans SC",system-ui,sans-serif;
  --ff-serif: "Noto Serif SC","Source Han Serif SC","Songti SC","SimSun",serif;
  --ff-mono:  "JetBrains Mono","Fira Code","SF Mono",monospace;

  --fs-xs:    0.75rem;
  --fs-sm:    0.875rem;
  --fs-base:  1rem;
  --fs-lg:    1.125rem;
  --fs-xl:    1.25rem;
  --fs-2xl:   1.5rem;
  --fs-3xl:   2rem;

  --sp-xs:  4px;
  --sp-sm:  8px;
  --sp-md:  16px;
  --sp-lg:  24px;
  --sp-xl:  32px;
  --sp-2xl: 48px;

  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;

  --transition-fast: 0.15s ease;
  --transition-base: 0.25s ease;
  --transition-slow: 0.4s ease;

  --content-max: 1200px;
  --header-h:    52px;
}


/* ============================================
   DARK THEME
   ============================================ */
[data-theme="dark"] {
  --c-bg:             #1A1614;
  --c-topbg:          #1A1614;
  --c-topline:        url(/images/topline_dark.png);
  --c-surface:        #252120;
  --c-surface-alt:    #2E2926;
  --c-text:           #E8E0D8;
  --c-text-secondary: #A09488;
  --c-border:         #3E3832;
  --c-border-light:   #332E28;
  --c-shadow:         rgba(0,0,0,0.25);
  --c-primary:        #C9845A;
  --c-primary-light:  #D4A070;
  --c-primary-dark:   #A06B40;
}


/* ============================================
   RESET
   ============================================ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  overflow-x: hidden;
}

body {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: 100vw;
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul, ol { list-style: none; }
table { border-collapse: collapse; width: 100%; }


/* ============================================
   HEADER WRAP — 顶部背景容器
   ============================================ */
.header-wrap {
  background: url(/images/bg0.png);
  position: sticky;          /* ★ 新增 */
  top: 0;                    /* ★ 新增 */
  z-index: 100;              /* ★ 新增 */
}

[data-theme="dark"] .header-wrap {
  background: url(/images/bg_dark.png);
}


/* ============================================
   1. TOP BAR — 桌面端顶部导航（移动端隐藏）
   ============================================ */
.top-bar {
  display: none;
}

@media (min-width: 1024px) {
  .top-bar {
    display: block;
    background: none;
    border-bottom: none;
    font-size: var(--fs-xs);
    line-height: 1;
  }
  .top-bar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: var(--content-max);
    margin: 0 auto;
    padding: 6px var(--sp-lg);
  }
  .top-bar__nav {
    display: flex;
    align-items: center;
    gap: 4px;
  }
  .top-bar__nav a {
    color: var(--c-text-secondary);
    padding: 4px 6px;
    border-radius: 3px;
    transition: color var(--transition-fast);
  }
  .top-bar__nav a:hover,
  .top-bar__nav a.is-active {
    color: var(--c-primary);
  }
  .top-bar__sep {
    color: var(--c-border);
    font-size: 10px;
    user-select: none;
  }
  .top-bar__actions {
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .top-bar__link {
    color: var(--c-text-secondary);
    padding: 4px 6px;
    border-radius: 3px;
    font-size: var(--fs-xs);
    display: inline-flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    transition: color var(--transition-fast);
    text-decoration: none;
    background: none;
    border: none;
    font: inherit;
    line-height: 1;
  }
  .top-bar__link:hover {
    color: var(--c-primary);
  }
}


/* ============================================
   SITE HEADER
   ============================================ */
.site-header {
  width: 100%;
  margin: 0;
  /*box-shadow: 0 2px 8px var(--c-shadow);*/
  background: none;
  color: var(--c-text);
}



.site-header__inner {
  padding: var(--sp-sm) var(--sp-md);
}

/* ★ 移动端：CSS Grid 强制两行 */
@media (max-width: 1023px) {
  .site-header__inner {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: 6px var(--sp-sm);
    align-items: center;
    width: 100%;
  }

  .site-header .nav-toggle {
    grid-column: 1;
    grid-row: 1;
  }

  .site-header .site-logo {
    grid-column: 2;
    grid-row: 1;
    justify-self: start;
  }

  .site-header .search-bar {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
  }
}

/* 桌面端 */
@media (min-width: 1024px) {
  .site-header {
    background: none;
    color: #fff;
  }
  .site-header__inner {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--sp-sm);
    max-width: var(--content-max);
    margin: 0 auto;
    padding: var(--sp-sm) var(--sp-lg);
    height: var(--header-h);
  }
}


/* ============================================
   NAV TOGGLE（汉堡按钮，仅移动端）
   ============================================ */
.nav-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  color: inherit;
  transition: background var(--transition-fast);
  flex-shrink: 0;
}

.nav-toggle:hover {
  background: rgba(0, 0, 0, 0.06);
}

@media (min-width: 1024px) {
  .nav-toggle { display: none; }
}


/* ============================================
   LOGO
   ============================================ */
/* 默认亮色：显示 logo.png，隐藏 logo2.png */
.site-logo__seal--dark  { display: none; }

/* 暗色模式：隐藏 logo.png，显示 logo2.png */
[data-theme="dark"] .site-logo__seal--light { display: none; }
[data-theme="dark"] .site-logo__seal--dark  { display: block; }


.site-logo {
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  color: inherit;
  flex-shrink: 0;
}

.site-logo__seal {
  width: 110px;
  height: 41px;
  object-fit: contain;
}

.site-logo__text {
  font-family: var(--ff-serif);
  font-size: clamp(1.2rem, 1rem + 1vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--c-primary);
}

@media (min-width: 1024px) {
  .site-logo__text { color: #fff; }
  .site-logo:hover { opacity: 0.9; }
}


/* ============================================
   SEARCH BAR
   ============================================ */
.search-bar {
  display: flex;
  align-items: center;
  height: 38px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--c-border);
  background: var(--c-surface);
  transition: box-shadow var(--transition-fast);
  min-width: 0;
}

.search-bar:focus-within {
  box-shadow: 0 0 0 2px var(--c-primary);
  border-color: var(--c-primary);
}

.search-bar__type {
  position: relative;
  flex-shrink: 0;
  border-right: 1px solid var(--c-border);
  background: var(--c-surface-alt);
  height: 100%;
  display: flex;
  align-items: center;
}

.search-bar__select {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: none;
  color: var(--c-text);
  font-size: var(--fs-sm);
  padding: 0 24px 0 10px;
  height: 100%;
  cursor: pointer;
  min-width: 52px;
}

.search-bar__arrow {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  color: var(--c-text-secondary);
  opacity: 0.6;
}

@media (min-width: 768px) {
  .search-bar__select {
    min-width: 72px;
    padding: 0 28px 0 14px;
  }
}

.search-bar__input {
  flex: 1;
  border: none;
  background: transparent;
  height: 100%;
  padding: 0 var(--sp-sm);
  font-size: var(--fs-base);
  color: var(--c-text);
  min-width: 0;
}

.search-bar__input::placeholder {
  color: var(--c-text-secondary);
  opacity: 0.6;
}

.search-bar__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 100%;
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  border-left: 1px solid var(--c-border);
  flex-shrink: 0;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.search-bar__btn:hover {
  background: var(--c-primary);
  color: #fff;
}

@media (min-width: 1024px) {
  .site-header .search-bar {
    flex: 1 1 auto;
    max-width: 480px;
  }
}

@media (min-width: 1280px) {
  .site-header .search-bar {
    max-width: 560px;
  }
}


/* ============================================
   HEADER ORNAMENT（装饰线）
   ============================================ */
.header-ornament {
  height: 12px;
  background: var(--c-topline);
}


/* ============================================
   DROPDOWN（查询索引下拉）
   ============================================ */
.dropdown {
  position: relative;
}

.dropdown__trigger {
  cursor: pointer;
}

.dropdown__panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 180px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px var(--c-shadow);
  padding: var(--sp-xs);
  z-index: 200;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity var(--transition-fast),
              transform var(--transition-fast),
              visibility var(--transition-fast);
}

.dropdown.is-open .dropdown__panel {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.dropdown__panel a {
  display: flex;
  align-items: center;
  padding: 8px 14px;
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--c-text);
  text-decoration: none;
  min-height: 36px;
  transition: background var(--transition-fast);
}

.dropdown__panel a:hover {
  background: var(--c-surface-alt);
  color: var(--c-primary);
}


/* ============================================
   DRAWER（移动端抽屉导航）
   ============================================ */
.drawer {
  position: fixed;
  inset: 0;
  z-index: 200;
  pointer-events: none;
  visibility: hidden;
}

.drawer.is-open {
  pointer-events: auto;
  visibility: visible;
}

.drawer__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.drawer.is-open .drawer__overlay {
  opacity: 1;
}

.drawer__panel {
  position: absolute;
  top: 0;
  left: 0;
  width: 280px;
  max-width: 85vw;
  height: 100%;
  background: var(--c-surface);
  transform: translateX(-100%);
  transition: transform var(--transition-base);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: var(--sp-lg) var(--sp-md);
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.drawer.is-open .drawer__panel {
  transform: translateX(0);
}

.drawer__close {
  position: absolute;
  top: var(--sp-sm);
  right: var(--sp-sm);
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  color: var(--c-text-secondary);
}

.drawer__close:hover {
  background: var(--c-surface-alt);
}

.drawer__section {
  padding-top: var(--sp-sm);
}

.drawer__title {
  font-size: var(--fs-xs);
  font-weight: 700;
  color: var(--c-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: var(--sp-xs) var(--sp-sm);
  margin-bottom: var(--sp-xs);
}

.drawer__links li a {
  display: flex;
  align-items: center;
  padding: 10px var(--sp-sm);
  border-radius: var(--radius-sm);
  font-size: var(--fs-base);
  color: var(--c-text);
  min-height: 44px;
  transition: background var(--transition-fast);
}

.drawer__links li a:hover,
.drawer__links li a.is-active {
  background: var(--c-surface-alt);
  color: var(--c-primary);
}

.drawer__footer {
  margin-top: auto;
  padding-top: var(--sp-md);
  border-top: 1px solid var(--c-border-light);
  display: flex;
  gap: var(--sp-md);
}

.drawer__footer-link {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  padding: var(--sp-xs) 0;
}

.drawer__footer-link:hover {
  color: var(--c-primary);
}

@media (min-width: 1024px) {
  .drawer { display: none; }
}


/* ============================================
   THEME TOGGLE
   ============================================ */
.theme-toggle {
  cursor: pointer;
  position: relative;
}

.icon-moon { display: none; }
[data-theme="dark"] .icon-sun  { display: none; }
[data-theme="dark"] .icon-moon { display: block; }


/* ============================================
   AD SLOTS
   ============================================ */
.ad-wrapper--banner {
  max-width: var(--content-max);
  margin: var(--sp-md) auto;
  padding: 0 var(--sp-md);
}

@media (max-width: 767px) {
  .ad-wrapper--banner {
    padding: 0;
    margin: var(--sp-sm) 0;
    max-width: 100%;
  }
  .ad-slot--banner {
    border-radius: 0;
    min-height: 60px;
  }
}

.ad-slot {
  /* 关键：必须是 block，不能用 flex —— flex 会让 AdSense 测量 <ins> 时拿到 width=0 */
  display: block;
  width: 100%;
  min-height: var(--ad-slot-h, 90px);
  background: var(--c-surface-alt);
  border-radius: var(--radius-md);
  overflow: hidden;
  /* 占位提示文字（如果想显示 "广告" 二字时居中，用 line-height 而非 flex） */
  text-align: center;
}

/* 让 AdSense 的 <ins> 元素填满容器 */
.ad-slot .adsbygoogle {
  display: block !important;
  width: 100%;
}

.ad-slot--banner  { --ad-slot-h: 90px; }
.ad-slot--rect    { --ad-slot-h: 250px; }
.ad-slot--inline  { --ad-slot-h: 100px; margin: var(--sp-lg) 0; }
.ad-slot--anchor  { --ad-slot-h: 50px; }

.ad-slot[data-loaded="true"] {
  min-height: auto;
  background: transparent;
}

.ad-anchor {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 150;
  background: var(--c-surface);
  border-top: 1px solid var(--c-border);
  padding: var(--sp-xs) var(--sp-sm);
  transform: translateY(100%);
  transition: transform var(--transition-base);
}

.ad-anchor.is-visible { transform: translateY(0); }

.ad-anchor__close {
  position: absolute;
  top: -28px;
  right: var(--sp-sm);
  width: 28px;
  height: 28px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 50%;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-text-secondary);
}

@media (min-width: 768px) {
  .ad-anchor { display: none; }
}


/* ============================================
   PAGE LAYOUT
   ============================================ */
.page-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-lg);
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--sp-lg) var(--sp-md);
  min-width: 0;
  overflow-x: clip;
  overflow-y: visible;
}

.content {
  min-width: 0;
  max-width: 100%;
}

@media (min-width: 1024px) {
  .page-layout {
    /* 侧边栏从 280px 改为 300px —— AdSense 的 medium rectangle (300x250) 
       和 half-page (300x600) 这些主力广告位需要至少 300px 宽 */
    grid-template-columns: 1fr 300px;
    padding: var(--sp-xl) var(--sp-lg);
  }
}


/* ============================================
   CHAR CARD — 字头信息卡片
   ============================================ */
.char-card {
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  padding: var(--sp-lg);
  box-shadow: 0 1px 4px var(--c-shadow);
  border: 1px solid var(--c-border-light);
}

.char-card__main {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-md) var(--sp-lg);
  align-items: start;
}

/* ═══════════════ 桌面端 ≥ 768px ═══════════════ */
@media (min-width: 768px) {
  .char-card__main {
    grid-template-columns: auto 1fr;
  }

  .char-card .char-meta {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
  }

  .char-card .char-meta .meta-row {
    grid-column: unset;
    align-self: unset;
  }

  .char-variants {
    grid-column: 1 / -1;
    padding-top: var(--sp-sm);
    border-top: 1px solid var(--c-border-light);
    margin-top: var(--sp-xs);
  }
}

/* ═══════════════ 移动端 ≤ 767px ═══════════════ */
@media (max-width: 767px) {
  .char-card {
    padding: var(--sp-md);
  }

  .char-card__main {
    grid-template-columns: auto 1fr;
    gap: 6px 10px;
  }

  .char-card__main .char-glyph {
    width: 100px;
    grid-column: 1;
    grid-row: 1 / 3;
    align-self: start;
  }

  .char-meta {
    display: contents;
  }

  .char-meta .meta-row:nth-child(-n+2) {
    grid-column: 2;
    align-self: center;
  }

  .char-meta .meta-row:nth-child(n+3) {
    grid-column: 1 / -1;
  }

  /* pronun-grid 作为整体占据 char-card grid 第2列 */
  .char-card__main > .pronun-grid {
    grid-column: 2;
    align-self: center;
  }

  .char-variants {
    grid-column: 1 / -1;
    padding-top: var(--sp-sm);
    border-top: 1px solid var(--c-border-light);
    margin-top: var(--sp-xs);
  }
}


/* ============================================
   WORD DOMAIN — 词头信息卡片样式
   （word_detail.php 重用 .char-card 骨架，
   此处定义词头行/拼音行/成语区块专用样式）
   ============================================ */

/* 词头行：主标题 + 繁体 + 成语徽章 */
.word-headword-row {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  margin-bottom: var(--sp-sm);
}

.word-headword-variant {
  font-family: var(--ff-serif);
  font-size: 1.15em;
  color: var(--c-text-secondary);
}

.word-headword-variant a {
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
}
.word-headword-variant a:hover {
  color: var(--c-primary);
  text-decoration: underline;
}

/* 拼音/注音行 —— 标签+文本同行，紧凑 */
.word-pronun-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 4px;
  margin-bottom: var(--sp-xs);
  line-height: 1.6;
  grid-column: 1 / -1;
}

.word-pronun-label {
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--c-text-secondary);
}

.word-pronun-text {
  font-size: var(--fs-base);
  color: var(--c-text);
}

/* ── 成语区块样式 ── */
.idiom-entry {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.idiom-entry__num {
  font-size: var(--fs-xs);
  color: var(--c-primary);
  font-weight: 600;
  margin-bottom: calc(-1 * var(--sp-xs));
}

.idiom-entry__line {
  display: flex;
  align-items: baseline;
  gap: var(--sp-xs);
  line-height: 1.7;
}

.idiom-entry__label {
  font-weight: 600;
  color: var(--c-text);
  white-space: nowrap;
  flex-shrink: 0;
}

.idiom-entry__text {
  color: var(--c-text);
}

.idiom-entry__source {
  font-style: normal;
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  white-space: nowrap;
}


/* ============================================
   CHAR GLYPH — 字形图
   ============================================ */
.char-glyph {
  position: relative;
  width: 160px;
  aspect-ratio: 1;
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
}

@media (max-width: 767px) {
  .char-glyph { width: 100px; }
}

.char-glyph__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: var(--sp-sm);
}

/* ★ 播放按钮 → 左上角 */
.char-glyph__play {
  position: absolute;
  top: 6px;
  left: 6px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(139, 65, 28, 0.8);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--transition-fast);
}

.char-glyph__play:hover {
  background: var(--c-primary);
}

.char-glyph__play svg {
  margin-left: 2px;
  width: 16px;
  height: 16px;
}


/* ============================================
   META BADGE 标签布局
   ============================================ */
.char-meta { display: contents; }

.meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 8px;
  line-height: 1.6;
  font-size: var(--fs-sm);
}

/* ── 拼音/注音两行（badge + 内容同行） ── */
.pronun-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pronun-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 8px;
}

.pronun-items {
  display: inline;
}

.col-val {
  white-space: nowrap;
}

.meta-badge {
  --n: 2;
  /* ── 桌面端默认值 ── */
  --row-h:  26px;
  --base-w: 42px;
  --step-w: 10px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  width:  calc(var(--base-w) + var(--n) * var(--step-w));
  height: var(--row-h);
  line-height: var(--row-h);
  background: url(/images/z_i_bon1.png) 0 calc((var(--n) - 2) * var(--row-h) * -1) no-repeat;
  color: #660000;
  font-size: 14px;
  font-weight: normal;
  white-space: nowrap;
  flex-shrink: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  letter-spacing: 0.03em;
}

[data-theme="dark"] .meta-badge {
background-image: url(/images/z_i_bon1_dark.png);
  color: var(--c-primary-light);
}

/* ★ 移动端：换图 + 换尺寸参数 */
@media (max-width: 767px) {
.meta-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: auto;
    height: 18px;
    line-height: 1;
    padding: 0 4px;
    font-size: 12px;
    color: #8a4a4a;
    background: #f5dcd6;
    border: 1px solid #d9a89f;
    border-radius: 6px;
    letter-spacing: normal;
}

[data-theme="dark"] .meta-badge {
  color: #f0e4d4;             /* 浅米色文字 */
  background: #3d2a1f;        /* 深棕色填充 */
  border: 1px solid #3d2a1f;  /* 边框同色 */
}
}


.meta-pinyin {
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-weight: 600;
  font-size: var(--fs-base);
  display: inline-flex;
  align-items: center;
  gap: 2px;
}

.meta-radical {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  color: var(--c-primary);
  font-weight: 700;
}


/* ============================================
   AUDIO BUTTON
   ============================================ */
.audio-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  min-width: 28px;
  padding: 0;
  color: var(--c-primary);
  border-radius: 50%;
  transition: background var(--transition-fast);
  flex-shrink: 0;
  vertical-align: middle;
}

.audio-btn:hover {
  background: var(--c-surface-alt);
}


/* ============================================
   CHAR VARIANTS — 异体字
   ============================================ */
.char-variants {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
}

.variant-char {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  min-height: 32px;
  padding: 4px;
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  color: var(--c-text);
  transition: color var(--transition-fast);
}

.variant-char:hover { color: var(--c-primary); }

.variant-char img {
  width: 28px;
  height: 28px;
}


/* ============================================
   SECTION NAV — pill 标签（粘性跟随）
   ============================================ */
.section-nav {
  position: sticky;
  top: 96px;
  z-index: 50;
  background: var(--c-bg);
  padding: var(--sp-sm) 0;
  margin-top: var(--sp-md);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.section-nav::-webkit-scrollbar { display: none; }

@media (max-width: 1023px) {
  .section-nav {
    top: 112px;
    margin-top: var(--sp-sm);
    padding: var(--sp-xs) 0;
  }
}

.section-nav__list {
  display: flex;
  gap: 6px;
  min-width: max-content;
  padding: 0 var(--sp-xs);
}

.section-nav__tab {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  font-weight: 500;
  white-space: nowrap;
  text-decoration: none;
  min-height: 38px;
  transition: all var(--transition-fast);
  color: var(--c-text-secondary);
  background: var(--c-surface);
  border: 1px solid var(--c-border-light);
}

.section-nav__tab:hover {
  color: var(--c-primary);
  border-color: var(--c-primary);
}

.section-nav__tab.is-active {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
  font-weight: 700;
  position: relative;
}

.section-nav__tab.is-active::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 20px;
  height: 3px;
  background: var(--c-primary);
  border-radius: 2px;
}


/* ============================================
   DICT SECTIONS
   ============================================ */
.dict-section {
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-top: var(--sp-lg);
  border: 1px solid var(--c-border-light);
  box-shadow: 0 1px 3px var(--c-shadow);
  scroll-margin-top: 162px;
}

@media (max-width: 1023px) {
  .dict-section {
    scroll-margin-top: 172px;
  }
}

.dict-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-sm);
  padding: var(--sp-md) var(--sp-xl);
  background: var(--c-surface-alt);
  border-bottom: 1px solid var(--c-border-light);
}

.dict-section__title {
  font-size: var(--fs-lg);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
}

.dict-section__char {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  color: var(--c-primary);
}

.dict-section__badges {
  display: flex;
  gap: 4px;
}

.zbadge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.zbadge:hover { opacity: 0.8; }
.zbadge--common   { background: var(--c-primary); color: #fff; }
.zbadge--standard  { background: var(--c-accent);  color: #fff; }
.zbadge--tw        { background: #C9A96E;          color: #fff; }

.dict-section__body {
  padding: var(--sp-xl);
}

@media (max-width: 767px) {
  .dict-section__header { padding: var(--sp-sm) var(--sp-md); }
  .dict-section__body   { padding: var(--sp-md); }
}

.dict-section__footer {
  margin-top: var(--sp-xl);
  padding-top: var(--sp-md);
  border-top: 1px solid var(--c-border-light);
  text-align: right;
}

.copyright {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
}

.dict-sub-title {
  font-size: var(--fs-base);
  font-weight: 700;
  margin-top: var(--sp-lg);
  margin-bottom: var(--sp-sm);
  padding-bottom: var(--sp-xs);
  border-bottom: 2px solid var(--c-primary);
  display: inline-block;
  color: var(--c-text);
}

.dict-sub-title:first-child { margin-top: 0; }


/* ============================================
   DICT ENTRY
   ============================================ */
.dict-entry {
  margin-bottom: var(--sp-lg);
}

.dict-entry:last-child { margin-bottom: 0; }

.dict-entry__head {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--sp-sm);
  margin-bottom: var(--sp-sm);
  padding-bottom: var(--sp-xs);
  border-bottom: 1px solid var(--c-border-light);
}

.dict-entry__char {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  color: var(--c-primary);
}

.dict-entry__pinyin {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  color: var(--c-primary);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.dict-entry__zhuyin {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
}

.dict-entry__pos {
  color: var(--c-primary);
  font-weight: 700;
}

.dict-entry__pos-label {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  font-weight: 600;
  margin-bottom: var(--sp-sm);
}

.dict-entry__defs {
  list-style: decimal;
  padding-left: 1.5em;
}

.dict-entry__defs li {
  margin-bottom: var(--sp-sm);
  line-height: 1.8;
}

.dict-entry__defs li p {
  margin-bottom: var(--sp-xs);
}

.dict-quote {
  margin: var(--sp-xs) 0 var(--sp-sm) var(--sp-md);
  padding-left: var(--sp-md);
  border-left: 3px solid var(--c-accent);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.8;
}

.dict-ancient {
  line-height: 2;
  font-size: var(--fs-base);
}

.dict-ancient__ref {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  margin-bottom: var(--sp-sm);
}

.ancient-char {
  font-family: var(--ff-serif);
  color: var(--c-primary);
}


/* ============================================
   TRANSLATIONS
   ============================================ */
.translations {
  margin-top: var(--sp-lg);
  padding: var(--sp-md) var(--sp-lg);
  background: var(--c-surface-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border-light);
}

.translations__item {
  display: flex;
  gap: var(--sp-md);
  padding: var(--sp-sm) 0;
}

.translations__item + .translations__item {
  border-top: 1px solid var(--c-border-light);
}

.translations__lang {
  font-weight: 700;
  font-style: italic;
  color: var(--c-primary);
  min-width: 80px;
  flex-shrink: 0;
  font-size: var(--fs-sm);
}

@media (max-width: 767px) {
  .translations { padding: var(--sp-sm) var(--sp-md); }
  .translations__item { flex-direction: column; gap: 2px; }
  .translations__lang { min-width: auto; }
}


/* ============================================
   TABLE
   ============================================ */
.table-responsive {
  overflow-x: auto;
  margin: var(--sp-sm) 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border-light);
}

.dict-table { font-size: var(--fs-sm); }

.dict-table th,
.dict-table td {
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--c-border-light);
}

.dict-table th {
  background: var(--c-surface-alt);
  font-weight: 700;
  color: var(--c-text);
  white-space: nowrap;
}

.dict-table tbody tr:last-child td { border-bottom: none; }
.dict-table tbody tr:hover { background: var(--c-surface-alt); }


/* ============================================
   ENCODING GRID（编码信息）
   ============================================ */
.encoding-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-sm) var(--sp-lg);
  margin-bottom: var(--sp-xl);
}

.encoding-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.encoding-item code {
  font-family: var(--ff-mono);
  font-size: var(--fs-base);
  background: var(--c-surface-alt);
  padding: 2px 10px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--c-border-light);
}


/* ============================================
   GLYPH EVOLUTION（字源演变）
   ============================================ */
.glyph-evolution {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-md);
  margin-bottom: var(--sp-xl);
}

.glyph-evolution__item { text-align: center; }

.glyph-evolution__item a,
.glyph-evolution__link {
  display: block;
  width: 95px;
  height: 95px;
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--sp-xs);
  transition: border-color var(--transition-fast);
  cursor: pointer;
}

.glyph-evolution__item a:hover,
.glyph-evolution__link:hover { border-color: var(--c-primary); }

.glyph-evolution__item a img,
.glyph-evolution__link img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.glyph-evolution__label {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
}


/* ============================================
   GLYPH COMPARE（字形对比）
   ============================================ */
.glyph-compare {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-md);
  margin-bottom: var(--sp-lg);
}

.glyph-compare__item {
  text-align: center;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
}

.glyph-compare__item img {
  width: 100px;
  height: 100px;
  object-fit: contain;
  margin-bottom: var(--sp-xs);
}

.glyph-compare__item span {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
  display: block;
}


/* ============================================
   SIDEBAR
   ============================================ */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-lg);
}

.sidebar__sticky {
  position: sticky;
  top: calc(var(--header-h) + var(--sp-lg));
}

.sidebar-card {
  background: var(--c-surface);
  border-radius: var(--radius-lg);
  padding: var(--sp-lg);
  border: 1px solid var(--c-border-light);
}

.sidebar-card__title {
  font-size: var(--fs-base);
  font-weight: 700;
  margin-bottom: var(--sp-md);
  padding-bottom: var(--sp-sm);
  border-bottom: 2px solid var(--c-primary);
  color: var(--c-text);
}

.related-chars--grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
}

.related-char-tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  color: var(--c-text);
  transition: all var(--transition-fast);
  text-decoration: none;
}

.related-char-tag:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
}

.poetry-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.poetry-item__line {
  font-size: var(--fs-sm);
  line-height: 1.8;
}

.poetry-item__line mark {
  background: var(--c-accent-light);
  color: var(--c-primary-dark);
  padding: 0 2px;
  border-radius: 2px;
}

.poetry-item__source {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
  margin-top: 2px;
}


/* ============================================
   SITE FOOTER
   ============================================ */
/* ============================================
   FOOTER (旧 EmpireCMS 风格)
   ============================================ */
.site-footer { margin-top: 0; }

footer {
  background: url(/images/bg0.png);
  text-shadow: 1px 1px 1px #fff;
  margin-top: 1em;
}

footer .footer_top {
  height: 12px;
  width: 100%;
  background: var(--c-topline);
  transform: scaleY(-1);
}

footer .footer_content {
  min-height: 50px;
  margin-top: 20px;
  text-align: center;
}

footer .main-content {
  margin: 0 auto;
  max-width: 980px;
}

footer .footer_block {
  list-style-type: none;
  margin: 10px 0;
  vertical-align: top;
}

footer .footer_block li {
  display: inline-block;
  margin-right: 30px;
  color: #9f9489;
}

footer .footer_block a {
  color: #9f9489;
  text-decoration: none;
}

footer .footer_block a:hover {
  color: var(--c-primary);
}

footer .lesp {
  letter-spacing: 4px;
}

footer .footer_bottom {
  background: #372629;
  color: #aaa;
  padding: 10px;
  text-align: center;
  font-size: 0.9em;
}

[data-theme="dark"] footer {
  background: none;
  text-shadow: none;
}

[data-theme="dark"] footer .footer_top {
  background: var(--c-primary);
}

[data-theme="dark"] footer .footer_bottom {
  background: #1a0f0d;
}

/* 兼容过渡：保留 site-footer 供已缓存页面使用 */
.site-footer {
  background: var(--c-surface);
  border-top: 1px solid var(--c-border-light);
  margin-top: var(--sp-2xl);
}

.site-footer__inner {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: var(--sp-xl) var(--sp-lg);
  text-align: center;
}

.site-footer__links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--sp-sm) var(--sp-lg);
  margin-bottom: var(--sp-md);
}

.site-footer__links a {
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  transition: color var(--transition-fast);
}

.site-footer__links a:hover { color: var(--c-primary); }

.site-footer__copy {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
}


/* ============================================
   UTILITIES
   ============================================ */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

@media print {
  .top-bar,
  .site-header,
  .header-ornament,
  .nav-toggle,
  .drawer,
  .section-nav,
  .sidebar,
  .ad-slot,
  .ad-anchor,
  .audio-btn,
  .char-glyph__play,
  .site-footer {
    display: none !important;
  }
  body {
    background: #fff;
    color: #000;
    font-size: 12pt;
  }
  .page-layout { display: block; }
  .dict-section {
    break-inside: avoid;
    border: 1px solid #ccc;
  }
}

/* ============================================================
   publish/css/partials.css
   --------------------------------------------------------
   为 templates/partials/*.php 中使用但未出现在 main.css
   的类提供样式补丁。
   设计要求：
     - 仅使用 main.css 中已定义的 :root 设计 token（--c-*, --sp-*,
       --fs-*, --radius-*, --ff-*），不新增全局变量
     - 与 zi.html 的整体审美一致（纸色背书、主色 --c-primary、
       小号字号、轻描边）
     - 移动端收窄内边距与字号
   加载方式：在 layout.php 的 <head> 中 main.css 之后 link，
     或直接 @import 到 main.css 底部。
   ============================================================ */

/* ============================================================
   reading_block.php
   （模板内联渲染了拼音/注音，但 partial 仍可能被其他地方使用）
   ============================================================ */
.reading-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  margin: 0 0 var(--sp-sm);
}

.reading-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-xs) var(--sp-sm);
  font-size: var(--fs-sm);
}

.reading-item--primary {
  /* 主读音：提高一点对比度即可 */
  font-weight: 500;
}

.reading-item__type {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 4px;
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-xs);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.reading-item__num {
  font-family: var(--ff-mono);
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
}

/* 注音样式 */
.meta-zhuyin {
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-weight: 600;
  font-size: var(--fs-base);
  display: inline-flex;
  align-items: center;
  gap: 2px;
}

/* 读音组合容器 — 每个发音位一组拼音+注音 */
.meta-pronun {
  display: inline-flex;
  align-items: center;
  gap: 4px 8px;
  white-space: nowrap;
}

/* ============================================================
   sense_block.php
   --------------------------------------------------------
   模板结构：
     .sense-group                (词典域某 reading 下的义项组外壳)
     .sense-reading-ref          (组头显示 reading_order 等)
     .dict-entry                 (单个义项，main.css 已定义框架)
       .dict-entry__head         (main.css 已定义)
       .dict-entry__defs         (main.css 已定义)
       .dict-entry__def          (单个 <p> 义项文本)
       .dict-entry__grammar      (词典域语法/搭配说明)
       .dict-entry__etym         (字典域词源补注)
     .sense-item--archaic        (古义附加样式)
     .sense-item__alt            (又作 / 亦作 标注)
     .sense-item__redirect-mark  (跳转标记)
     .sense-kind-badge           (义项种类徽章)
     .guoyu-pos / .guoyu-reading / .guoyu-example  (国语辞典分字段)
   ============================================================ */

.sense-group {
  margin: 0 0 var(--sp-md);
}

.sense-group + .sense-group {
  padding-top: var(--sp-md);
  border-top: 1px dashed var(--c-border-light);
}

.sense-reading-ref {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  margin-bottom: var(--sp-sm);
  padding: 2px var(--sp-sm);
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-xs);
  border-left: 3px solid var(--c-accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* .dict-entry 框架本身由 main.css 提供；这里补几个子元素 */
.dict-entry__def {
  margin: 0 0 var(--sp-xs);
  line-height: 1.8;
  color: var(--c-text);
}

.dict-entry__def:last-child {
  margin-bottom: 0;
}

.dict-entry__grammar {
  margin: var(--sp-xs) 0;
  padding: var(--sp-xs) var(--sp-sm);
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--c-border);
}

.dict-entry__etym {
  margin: var(--sp-xs) 0;
  padding: var(--sp-xs) var(--sp-sm);
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--c-accent);
}

.dict-entry__etym::before {
  content: "※ ";
  color: var(--c-accent);
  font-weight: 600;
}

.sense-item--archaic {
  opacity: 0.85;
}

.sense-item--archaic::before {
  content: "〔古〕";
  margin-right: 4px;
  color: var(--c-text-secondary);
  font-size: var(--fs-xs);
}

.sense-item__alt {
  display: inline-block;
  margin-left: var(--sp-xs);
  padding: 1px 6px;
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-xs);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
}

.sense-item__redirect-mark {
  display: inline-flex;
  align-items: center;
  margin-left: var(--sp-xs);
  color: var(--c-primary-light);
  font-size: var(--fs-xs);
}

.sense-kind-badge {
  display: inline-block;
  padding: 1px 6px;
  margin-right: var(--sp-xs);
  background: var(--c-accent-light);
  color: var(--c-primary-dark);
  font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
  font-weight: 500;
}

[data-theme="dark"] .sense-kind-badge {
  background: var(--c-primary-dark);
  color: var(--c-accent-light);
}

/* 国语辞典字段 */
.guoyu-pos {
  display: inline-block;
  padding: 1px 6px;
  margin-right: var(--sp-xs);
  background: var(--c-accent-light);
  color: var(--c-primary-dark);
  font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
}

.guoyu-reading {
  display: block;
  margin-bottom: var(--sp-xs);
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-weight: 500;
}

/* 成语区块 xxjs 级书证 fallback（义项级无书证时显示） */
.idiom-xxjs-cits {
  margin-top: var(--sp-md);
  padding-top: var(--sp-sm);
  border-top: 1px solid var(--c-border);
}

.guoyu-example {
  display: block;
  margin: var(--sp-xs) 0 0 var(--sp-md);
  padding: var(--sp-xs) var(--sp-sm);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  background: var(--c-surface-alt);
  border-left: 2px solid var(--c-border);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* ============================================================
   citation_block.php
   --------------------------------------------------------
   char 分支：.citation-list / .citation-item /
              .citation-source / .citation-dynasty /
              .citation-author / .citation-book /
              .citation-chapter / .citation-bindtype
   word 分支：.citation-list--word / .citation-item--word /
              .citation-bilingual / .citation-bilingual__j /
              .citation-bilingual__f / .citation-script-tag /
              .align-badge（同 example_block）
   ============================================================ */

.citation-block {
  margin: 0 0 var(--sp-md);
}

.citation-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.citation-item {
  padding: var(--sp-sm) var(--sp-md);
  background: var(--c-surface);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
}

.citation-item--word {
  position: relative;
}

.citation-source {
  display: block;
  margin-top: var(--sp-xs);
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  font-style: normal;
}

.citation-dynasty,
.citation-author,
.citation-book,
.citation-chapter {
  color: var(--c-text-secondary);
}

.citation-author {
  margin: 0 2px;
  color: var(--c-text);
}

.citation-book {
  color: var(--c-primary);
}

.citation-bindtype {
  margin-left: var(--sp-xs);
}

/* word 域书证双列展示 */
.citation-bilingual {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-md);
}

.citation-bilingual__j,
.citation-bilingual__f {
  position: relative;
}

.citation-script-tag {
  display: inline-block;
  padding: 1px 6px;
  margin-right: var(--sp-xs);
  background: var(--c-accent-light);
  color: var(--c-primary-dark);
  font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
  font-weight: 500;
}

[data-theme="dark"] .citation-script-tag {
  background: var(--c-primary-dark);
  color: var(--c-accent-light);
}

@media (max-width: 767px) {
  .citation-bilingual {
    grid-template-columns: 1fr;
    gap: var(--sp-sm);
  }
}

/* ── align-badge（citation_block / example_block 共用） ─── */
.align-badge {
  display: inline-block;
  padding: 1px 6px;
  margin-right: var(--sp-xs);
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: var(--radius-sm);
  vertical-align: middle;
}

.align-badge--ok {
  background: #E6F0E3;
  color: #2C5E1E;
  border: 1px solid #B8D4B0;
}

.align-badge--warn {
  background: #FAF2D9;
  color: #7A5A10;
  border: 1px solid #E8D496;
}

.align-badge--danger {
  background: #F5D9D9;
  color: #7A1818;
  border: 1px solid #D89A9A;
}

.align-badge--neutral {
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  border: 1px solid var(--c-border-light);
}

[data-theme="dark"] .align-badge--ok {
  background: #1E3A18;
  color: #B0D4A0;
  border-color: #2E5E28;
}

[data-theme="dark"] .align-badge--warn {
  background: #3A2E10;
  color: #E0C878;
  border-color: #5E4E20;
}

[data-theme="dark"] .align-badge--danger {
  background: #3A1818;
  color: #E0A0A0;
  border-color: #5E2828;
}

[data-theme="dark"] .align-badge--neutral {
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  border-color: var(--c-border);
}

/* ============================================================
   example_block.php
   --------------------------------------------------------
   .example-block / .example-list / .example-item
   .example-bilingual / .example-text / .example-text--j/f
   .example-script-tag
   ============================================================ */

.example-block {
  margin: 0 0 var(--sp-md);
}

.example-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.example-item {
  padding: var(--sp-sm) var(--sp-md);
  background: var(--c-surface-alt);
  border-left: 3px solid var(--c-accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.example-bilingual {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.example-text {
  margin: 0;
  line-height: 1.7;
  color: var(--c-text);
}

.example-text--j,
.example-text--f {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-xs);
}

.example-script-tag {
  display: inline-block;
  flex-shrink: 0;
  padding: 0 5px;
  margin-top: 2px;
  background: var(--c-accent-light);
  color: var(--c-primary-dark);
  font-size: var(--fs-xs);
  border-radius: var(--radius-sm);
  font-weight: 500;
  line-height: 1.5;
}

[data-theme="dark"] .example-script-tag {
  background: var(--c-primary-dark);
  color: var(--c-accent-light);
}

/* ============================================================
   synonym_block.php
   --------------------------------------------------------
   .synonym-block / .synonym-section / .synonym-section--entry/sense
   .synonym-section__sense-label / .synonym-row
   .synonym-label / .synonym-label--syn/ant
   .synonym-tags / .synonym-tag
   ============================================================ */

.synonym-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.synonym-section {
  padding: var(--sp-sm) 0;
}

.synonym-section--entry {
  padding-bottom: var(--sp-md);
  border-bottom: 1px dashed var(--c-border-light);
}

.synonym-section--entry:last-child {
  border-bottom: none;
}

.synonym-section--sense {
  padding-left: var(--sp-md);
  border-left: 3px solid var(--c-border-light);
}

.synonym-section__sense-label {
  display: inline-block;
  margin-bottom: var(--sp-xs);
}

.synonym-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-xs) var(--sp-sm);
  margin-bottom: var(--sp-xs);
}

.synonym-row:last-child {
  margin-bottom: 0;
}

.synonym-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 2px var(--sp-sm);
  font-size: var(--fs-sm);
  font-weight: 500;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}

.synonym-label--syn {
  background: #E6F0E3;
  color: #2C5E1E;
  border: 1px solid #B8D4B0;
}

.synonym-label--ant {
  background: #F5D9D9;
  color: #7A1818;
  border: 1px solid #D89A9A;
}

[data-theme="dark"] .synonym-label--syn {
  background: #1E3A18;
  color: #B0D4A0;
  border-color: #2E5E28;
}

[data-theme="dark"] .synonym-label--ant {
  background: #3A1818;
  color: #E0A0A0;
  border-color: #5E2828;
}

.synonym-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
}

.synonym-tag {
  display: inline-block;
  padding: 2px 8px;
  background: var(--c-surface);
  color: var(--c-primary);
  font-size: var(--fs-sm);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.synonym-tag:hover {
  background: var(--c-primary);
  color: var(--c-surface);
  border-color: var(--c-primary);
}

/* 内联近反义词链接（xxjs-also 内） */
.syn-tag {
  color: var(--c-primary);
  text-decoration: none;
}
.syn-tag:hover {
  text-decoration: underline;
}

/* ============================================================
   移动端微调
   ============================================================ */
@media (max-width: 767px) {
  .citation-item,
  .example-item {
    padding: var(--sp-xs) var(--sp-sm);
  }
  .synonym-section--sense {
    padding-left: var(--sp-sm);
  }
  .synonym-tag {
    font-size: var(--fs-xs);
  }
  .guoyu-example {
    margin-left: 0;
  }
}


/* ============================================================
   音韵方言区块（char_detail.php）
   --------------------------------------------------------
   sub-tab 导航 + 面板折叠 + 嵌套分组折叠
   ============================================================ */

/* ── sub-tab 导航（概览/韵书/方言/上古音系/中古音/上古音） ── */
.phon-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--sp-md);
  padding: 0;
}

.phon-subnav__tab {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-xs);
  padding: var(--sp-xs) var(--sp-md);
  background: transparent;
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  font-family: inherit;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.phon-subnav__tab:hover {
  color: var(--c-primary);
}

.phon-subnav__tab.is-active {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
  font-weight: 600;
}

.phon-subnav__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 18px;
  padding: 0 6px;
  background: var(--c-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: 9px;
  line-height: 1;
}

.phon-subnav__tab:not(.is-active) .phon-subnav__count {
  background: var(--c-text-secondary);
  opacity: 0.7;
}

/* ── sub-tab 面板 ── */
.phon-panel {
  display: none;
}

.phon-panel.is-active {
  display: block;
}

/* hidden 属性兜底（当 JS 失效时只展示概览，其它可通过 details 独立查看）*/
.phon-panel[hidden] {
  display: none;
}

/* ── 概览面板：定义列表（dt-dd 两列） ── */
.phon-defs {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0;
  margin: 0 0 var(--sp-md);
  border-top: 1px solid var(--c-border-light);
}

.phon-defs__row {
  display: contents;
}

.phon-defs__label,
.phon-defs__value {
  padding: var(--sp-xs) var(--sp-sm);
  border-bottom: 1px solid var(--c-border-light);
  font-size: var(--fs-sm);
  line-height: 1.6;
}

.phon-defs__label {
  grid-column: 1;
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-weight: 500;
  white-space: nowrap;
  min-width: 96px;
}

.phon-defs__value {
  grid-column: 2;
  color: var(--c-text);
  word-break: break-word;
}

.phon-defs__hint {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
  font-weight: normal;
  margin-left: 4px;
}

/* ── 分组折叠（方言的 11 大方言区 / 上古音系的书系） ── */
.phon-groups {
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.phon-group {
  background: var(--c-surface);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.phon-group__summary {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-xs) var(--sp-md);
  cursor: pointer;
  list-style: none;
  user-select: none;
  background: var(--c-surface-alt);
  transition: background var(--transition-fast);
}

.phon-group__summary::-webkit-details-marker { display: none; }
.phon-group__summary::marker { content: ''; }

.phon-group__summary:hover {
  background: var(--c-border-light);
}

.phon-group__name {
  flex: 1;
  font-size: var(--fs-base);
  font-weight: 500;
  color: var(--c-text);
  font-family: var(--ff-serif);
}

.phon-group__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 20px;
  padding: 0 8px;
  background: var(--c-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: 10px;
  line-height: 1;
  flex-shrink: 0;
}

.phon-group__chevron {
  display: inline-flex;
  align-items: center;
  color: var(--c-text-secondary);
  transition: transform var(--transition-fast);
  flex-shrink: 0;
}

.phon-group[open] .phon-group__chevron {
  transform: rotate(180deg);
}

.phon-group__body {
  padding: var(--sp-sm) var(--sp-md);
  background: var(--c-surface);
  border-top: 1px solid var(--c-border-light);
}

/* 分组内的表格取消外边距，让布局紧凑 */
.phon-group__body .table-responsive {
  margin: 0;
}

/* ── 暗色主题 ── */
[data-theme="dark"] .phon-subnav__tab.is-active {
  color: var(--c-primary-light);
  border-bottom-color: var(--c-primary-light);
}

[data-theme="dark"] .phon-subnav__count {
  background: var(--c-primary);
}

[data-theme="dark"] .phon-group__count {
  background: var(--c-primary);
}

/* ── 移动端 ── */
@media (max-width: 767px) {
  .phon-subnav {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
  }
  .phon-subnav::-webkit-scrollbar { display: none; }
  .phon-subnav__tab {
    padding: var(--sp-xs) var(--sp-sm);
    font-size: var(--fs-xs);
  }
  .phon-defs {
    grid-template-columns: 1fr;
  }
  .phon-defs__label {
    grid-column: 1;
    border-bottom: none;
    padding-bottom: 0;
    min-width: 0;
    background: transparent;
  }
  .phon-defs__value {
    grid-column: 1;
    padding-top: 0;
  }
  .phon-group__summary {
    padding: var(--sp-xs) var(--sp-sm);
  }
  .phon-group__body {
    padding: var(--sp-xs) var(--sp-sm);
  }
  .phon-group__name {
    font-size: var(--fs-sm);
  }
}


/* ============================================================
   基本解释（jbjs）—— 图 1 样式
   --------------------------------------------------------
   - 红色数字序号（ol counter，对齐 main.css 风格）
   - 定义文本正常色 + 例如徽章 + 浅灰例句
   ============================================================ */
.jbjs-list {
  list-style: none;
  counter-reset: jbjs;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}

.jbjs-item {
  counter-increment: jbjs;
  display: block;
  padding: 4px 0;
  line-height: 1.9;
  font-size: var(--fs-base);
  color: var(--c-text);
}

.jbjs-item::before {
  content: counter(jbjs);
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  margin-right: 0.35em;
}

/* 只有一个义项时不显示序号 */
.jbjs-list > .jbjs-item:only-of-type::before {
  content: none;
}

.jbjs-item__def {
  /* 定义部分：默认文本色 */
}

.jbjs-item__eg-label {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  background: var(--c-text-secondary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
  flex-shrink: 0;
  line-height: 1.6;
}

[data-theme="dark"] .jbjs-item__eg-label {
  background: var(--c-text-secondary);
  color: var(--c-bg);
}

.jbjs-item__eg {
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
}

/* ============================================================
   zsqt 其它字义（嵌入基本解释底部）
   ============================================================ */
.zsqt-extra {
  margin-top: var(--sp-md);
}

.zsqt-extra__title {
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--c-text);
  margin: 0 0 var(--sp-xs) 0;
}

.zsqt-extra__sep {
  border: 0;
  border-top: 1px dashed var(--c-border);
  margin: var(--sp-xs) 0 var(--sp-sm) 0;
}

/* ============================================================
   详细解释（xxjs）—— 图 2 样式
   --------------------------------------------------------
   布局：
     .xxjs-pos-row      pos 组首行，单独一行显示深红 pos 徽章
     .xxjs-item         单条义项
       .xxjs-item__def      红色序号 + 定义文本（序号由 counter 生成）
       .xxjs-item__etym     词源注（浅灰）
       .xxjs-citation       书证块（棕褐色"书证"徽章 + 条目列表）
       .xxjs-also           例如块（深灰"例如"徽章 + also_note）
       .xxjs-english        英文块（绿色"英文"徽章 + 英文）
   ============================================================ */
.sense-group--xxjs {
  margin: 0;
}

.xxjs-list {
  list-style: none;
  counter-reset: xxjs;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

/* pos 组首行：不计数、不缩进 */
.xxjs-pos-row {
  margin-top: var(--sp-sm);
  padding: 0;
}

.xxjs-pos-row:first-child {
  margin-top: 0;
}

.xxjs-pos-badge {
  display: inline-block;
  padding: 0px 3px;
  background: var(--c-primary);
  color: #fff;
  font-family: var(--ff-serif);
  font-size: var(--fs-base);
  font-weight: 500;
  border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
}

/* 单条义项 */
.xxjs-item {
  counter-increment: xxjs;
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
  padding: 4px 0;
}

.xxjs-item__def {
  display: flex;
  align-items: baseline;
  gap: var(--sp-xs);
  line-height: 1.8;
  font-size: var(--fs-base);
  color: var(--c-text);
}

.xxjs-item__def::before {
  content: counter(xxjs) ".";
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  min-width: 28px;
  flex-shrink: 0;
}

.xxjs-item__etym {
  margin-left: 32px;
  padding: var(--sp-xs) var(--sp-sm);
  background: var(--c-surface-alt);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  border-left: 3px solid var(--c-accent);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* 通用：xxjs 块级徽章 */
.xxjs-block-label {
  display: inline-flex;
  align-items: center;
  padding: 1px 7px;
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: var(--radius-lg);
  letter-spacing: 0.05em;
  flex-shrink: 0;
  line-height: 1.7;
  vertical-align: middle;
}

.xxjs-block-label--cit  { background: #8b6f3e; }  /* 棕褐 */
.xxjs-block-label--also { background: var(--c-text-secondary); }  /* 深灰 */
.xxjs-block-label--en   { background: #4f8a52; }  /* 绿色 */
.xxjs-block-label--syn  { background: #c07a3a; }  /* 橙色 */
.xxjs-block-label--ant  { background: #b84c5c; }  /* 红色 */

[data-theme="dark"] .xxjs-block-label--cit  { background: #9c8253; }
[data-theme="dark"] .xxjs-block-label--also { background: var(--c-text-secondary); color: var(--c-bg); }
[data-theme="dark"] .xxjs-block-label--en   { background: #5e9c62; }
[data-theme="dark"] .xxjs-block-label--syn  { background: #d4944a; }
[data-theme="dark"] .xxjs-block-label--ant  { background: #c46070; }

/* 书证块 */
.xxjs-citation {
  margin-left: 32px;
  padding: var(--sp-xs) 0;
}

.xxjs-citation__list {
  list-style: none;
  padding: 0;
  margin: var(--sp-xs) 0 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.xxjs-citation__item {
  padding: 4px 0;
  border-bottom: 1px dashed var(--c-border-light);
  color: var(--c-primary-dark);
  font-family: var(--ff-serif);
  line-height: 1.8;
}

.xxjs-citation__item:last-child {
  border-bottom: none;
}

.xxjs-citation__text {
  color: var(--c-primary-dark);
}

[data-theme="dark"] .xxjs-citation__text,
[data-theme="dark"] .xxjs-citation__item {
  color: var(--c-primary-light);
}

.xxjs-citation__dash {
  color: var(--c-text-secondary);
  margin: 0 4px;
}

.xxjs-citation__source {
  color: var(--c-text-secondary);
  font-style: normal;
  font-size: var(--fs-sm);
  font-family: var(--ff-serif);
}

/* 例如块 */
.xxjs-also {
  margin-left: 32px;
  padding: var(--sp-xs) 0;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-sm);
  flex-wrap: wrap;
}

.xxjs-also__text {
  flex: 1 1 auto;
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.8;
}

/* 英文块 */
.xxjs-english {
  margin-left: 32px;
  padding: var(--sp-xs) 0;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-sm);
}

.xxjs-english__text {
  font-family: var(--ff-mono);
  color: var(--c-text);
  font-size: var(--fs-sm);
}

/* 书证开关（详细解释 / 国语辞典 section 右上角）
   目标：严格对齐参考图的“小金色开关 + 纯文本标签”质感，
   无外包 border/background，仅优化开关本体的尺寸、渐变、描边、阴影与文字色。 */
.dict-section__header {
  position: relative;
}

.citations-toggle-wrap {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  line-height: 1;
}

/* 隐藏原生 checkbox，但保留可访问性 */
.citations-toggle {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

/* 标签：纯文本 + 左侧小型开关 */
.citations-toggle__label {
  display: inline-flex;
  align-items: center;
  position: relative;
  min-height: 18px;
  padding-left: 31px;
  color: #9d7a2f;
  font-size: 13px;
  line-height: 1;
  font-family: inherit;
  font-weight: 400;
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  letter-spacing: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  text-decoration: none;
  -webkit-tap-highlight-color: transparent;
  transition: color .18s ease;
}

/* 金色轨道 */
.citations-toggle__label::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 24px;
  height: 12px;
  transform: translateY(-50%);
  border-radius: 999px;
  border: 1px solid #ba8d2e;
  background: linear-gradient(180deg, #e5c36d 0%, #d1a347 55%, #be8930 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 223, .7),
    inset 0 -1px 0 rgba(136, 97, 0, .18),
    0 1px 2px rgba(136, 97, 0, .18);
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease;
}

/* 白色滑块圆点 */
.citations-toggle__label::after {
  content: '';
  position: absolute;
  left: 2px;
  top: 50%;
  width: 8px;
  height: 8px;
  transform: translateY(-50%);
  border-radius: 50%;
  background: linear-gradient(180deg, #ffffff 0%, #f8f4ea 100%);
  box-shadow:
    0 1px 2px rgba(96, 68, 0, .28),
    inset 0 1px 0 rgba(255, 255, 255, .95);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.citations-toggle:checked + .citations-toggle__label::after {
  transform: translate(12px, -50%);
}

.citations-toggle:not(:checked) + .citations-toggle__label {
  color: #b19a71;
}

.citations-toggle:not(:checked) + .citations-toggle__label::before {
  border-color: #ccb98d;
  background: linear-gradient(180deg, #f4ead2 0%, #ead7ad 100%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, .82),
    0 1px 2px rgba(120, 91, 34, .08);
}

.citations-toggle:not(:checked) + .citations-toggle__label::after {
  background: linear-gradient(180deg, #fffefb 0%, #f4ecda 100%);
  box-shadow:
    0 1px 2px rgba(120, 91, 34, .14),
    inset 0 1px 0 rgba(255, 255, 255, .95);
}

.citations-toggle:focus-visible + .citations-toggle__label {
  outline: 2px solid rgba(190, 137, 48, .35);
  outline-offset: 3px;
  border-radius: 3px;
}

/* toggle off 时隐藏书证块（各 section 用 data-show-citations 控制） */
.xxjs-section[data-show-citations="off"] .xxjs-citation {
  display: none;
}
.guoyu-section[data-show-citations="off"] .gy-sense__cit,
.guoyu-section[data-show-citations="off"] .xxjs-citation {
  display: none;
}

/* 移动端：取消绝对定位，改为跟随标题行 */
@media (max-width: 767px) {
  .citations-toggle-wrap {
    position: static;
    top: auto;
    right: auto;
    transform: none;
    margin-top: var(--sp-xs);
  }
  .citations-toggle__label {
    min-height: 20px;
    border: 0;
    background: transparent;
  }
  .gy-sense__cit {
    padding-left: 0;
  }
  .jbjs-item::before,
  .xxjs-item__def::before {
    min-width: 20px;
    font-size: var(--fs-base);
  }
}


/* ============================================================
   基本解释 —— 嵌套书证套色（图 1 的繁体条目 / 图 2 风格）
   --------------------------------------------------------
   当 jbjs 条目文本里包含古典引文（《书名》：「引文」），
   用内联 span 高亮这两部分。套色规则与 xxjs 的书证一致。
   ============================================================ */
.jbjs-book {
  color: var(--c-text-secondary);
  font-family: var(--ff-serif);
}

.jbjs-quote {
  color: var(--c-primary-dark);
  font-family: var(--ff-serif);
}

[data-theme="dark"] .jbjs-quote {
  color: var(--c-primary-light);
}


/* ============================================================
   国语辞典 —— 按读音+词性分组（图「王」后台样式）
   --------------------------------------------------------
   结构：
     .sense-group--guoyu
       .guoyu-group               一组（同读音同词性的连续义项）
         .guoyu-group__head       组头：拼音 + 注音 + 词性徽章 + 计数徽章
           .guoyu-group__pinyin
           .guoyu-group__zhuyin
           .guoyu-group__pos
           .guoyu-group__count
         .guoyu-list              ol，组内义项
           .guoyu-item
             .guoyu-item__text
             .guoyu-item__example
   ============================================================ */
.sense-group--guoyu {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.guoyu-group {
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border-light);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.guoyu-group__head {
  display: flex;
  align-items: center;
  gap: var(--sp-sm);
  padding: var(--sp-xs) var(--sp-md);
  background: var(--c-surface);
  border-bottom: 1px solid var(--c-border-light);
  flex-wrap: wrap;
}

.guoyu-group__pinyin {
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.guoyu-group__zhuyin {
  color: var(--c-text-secondary);
  font-family: var(--ff-serif);
  font-size: var(--fs-base);
}

.guoyu-group__pos {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 22px;
  padding: 0 6px;
  background: var(--c-surface);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font-family: var(--ff-serif);
  line-height: 1;
}

.guoyu-group__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 8px;
  background: var(--c-primary);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: 500;
  border-radius: 11px;
  line-height: 1;
  margin-left: auto;  /* 推到行尾（图里计数徽章靠右） */
}

[data-theme="dark"] .guoyu-group {
  background: var(--c-surface-alt);
}

[data-theme="dark"] .guoyu-group__head {
  background: var(--c-surface);
}

/* 组内义项列表 */
.guoyu-list {
  list-style: none;
  counter-reset: guoyu;
  padding: 0;
  margin: 0;
}

.guoyu-item {
  counter-increment: guoyu;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--sp-xs) var(--sp-md) var(--sp-xs) 44px;
  border-bottom: 1px dashed var(--c-border-light);
  position: relative;
}

.guoyu-item:last-child {
  border-bottom: none;
}

.guoyu-item::before {
  content: counter(guoyu);
  position: absolute;
  left: var(--sp-md);
  top: var(--sp-xs);
  color: var(--c-text-secondary);
  font-family: var(--ff-mono);
  font-size: var(--fs-sm);
  min-width: 20px;
}

.guoyu-item__text {
  color: var(--c-text);
  line-height: 1.8;
}

.guoyu-item__example {
  margin: 0;
  padding: var(--sp-xs) var(--sp-sm);
  background: var(--c-bg);
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  border-left: 2px solid var(--c-border);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* 移动端 */
@media (max-width: 767px) {
  .guoyu-group__head {
    padding: var(--sp-xs) var(--sp-sm);
  }
  .guoyu-group__pinyin {
    font-size: var(--fs-base);
  }
  .guoyu-item {
    padding-left: 32px;
    padding-right: var(--sp-sm);
  }
  .guoyu-item::before {
    left: var(--sp-sm);
  }
}


/* ============================================================
   详细解释 + 国语辞典：两层嵌套（读音 → 词性 → 义项）
   --------------------------------------------------------
   详细解释用 .xxjs-reading / .xxjs-pos-section
   国语辞典用 .gy-reading / .gy-pos / .gy-sense
   共享同样的视觉模式（读音头 + 词性徽章 + 义项列表）
   ============================================================ */

/* ── 读音头（xxjs + guoyu 共用视觉） ───────────────────────── */
.xxjs-reading,
.jbjs-reading,
.gy-reading {
  margin: 0 0 var(--sp-lg);
}

.xxjs-reading:last-child,
.jbjs-reading:last-child,
.gy-reading:last-child {
  margin-bottom: 0;
}

.xxjs-reading__head,
.jbjs-reading__head,
.gy-reading__head {
  display: flex;
  align-items: baseline;
  gap: var(--sp-sm);
  padding: var(--sp-sm) 0;
  margin-bottom: var(--sp-sm);
  border-bottom: 1px dashed var(--c-border-light);
}

.xxjs-reading__char,
.jbjs-reading__char,
.gy-reading__char {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--c-text);
}

.xxjs-reading__zy,
.jbjs-reading__zy,
.gy-reading__zy {
  font-family: var(--ff-serif);
  font-size: var(--fs-base);
  color: var(--c-text-secondary);
}

.xxjs-reading__py,
.jbjs-reading__py,
.gy-reading__py {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--c-primary);
  letter-spacing: 0.02em;
}

[data-theme="dark"] .xxjs-reading__py,
[data-theme="dark"] .jbjs-reading__py,
[data-theme="dark"] .gy-reading__py {
  color: var(--c-primary-light);
}

/* ── 词性段落（xxjs） ───────────────────────────────────────── */
.xxjs-pos-section {
  margin: 0 0 var(--sp-md);
  padding-left: 0;
}

.xxjs-pos-section:last-child {
  margin-bottom: 0;
}

.xxjs-pos-section .xxjs-pos-badge {
  display: inline-block;
  margin-bottom: var(--sp-sm);
}

/* xxjs 列表：有序号（多义项）时用 counter，单义项时不显示 */
.xxjs-list {
  list-style: none;
  counter-reset: xxjs;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.xxjs-item {
  counter-increment: xxjs;
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.xxjs-item__def {
  display: flex;
  align-items: baseline;
  gap: var(--sp-xs);
  line-height: 1.8;
  font-size: var(--fs-base);
  color: var(--c-text);
}

.xxjs-item__def::before {
  content: counter(xxjs) ".";
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  min-width: 28px;
  flex-shrink: 0;
}

/* 单义项时（data-count="1"）不显示序号 */
.xxjs-list[data-count="1"] .xxjs-item__def::before {
  content: none;
}

.xxjs-list[data-count="1"] .xxjs-item__def {
  padding-left: 0;
}

.xxjs-item--nonum .xxjs-item__def::before {
  content: none;
}

/* ── 国语辞典词性段落 ──────────────────────────────────────── */
.gy-pos {
  margin: 0 0 var(--sp-md);
}

.gy-pos:last-child {
  margin-bottom: 0;
}

.gy-pos__badge {
  display: inline-block;
  padding: 0px 3px;
  margin-bottom: var(--sp-sm);
  background: var(--c-primary);
  color: #fff;
  font-family: var(--ff-serif);
  font-size: var(--fs-base);
  font-weight: 500;
  border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
}

/* ── 国语辞典义项列表 ──────────────────────────────────────── */
.gy-sense-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-md);
}

.gy-sense {
  display: flex;
  gap: var(--sp-xs);
  align-items: flex-start;
}

.gy-sense__num {
  flex-shrink: 0;
  min-width: 28px;
  color: var(--c-primary);
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 600;
  line-height: 1.8;
}

.gy-sense__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-xs);
}

.gy-sense__def {
  margin: 0;
  line-height: 1.8;
  color: var(--c-text);
}

/* 例如 / 书证 子块（guoyu 专属；样式与 xxjs 的 .xxjs-also / .xxjs-citation 一致风格） */
.gy-sense__eg,
.gy-sense__cit {
  margin-left: var(--sp-md);
  padding: var(--sp-xs) 0;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-sm);
  flex-wrap: wrap;
}

/* guoyu 内 xxjs-also（近反义词）与书证对齐缩进 */
.gy-sense__body .xxjs-also {
  margin-left: var(--sp-md);
}

.gy-sense__eg-text {
  flex: 1 1 auto;
  color: var(--c-text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.8;
}

.gy-sense__cit {
  flex-direction: column;
  gap: var(--sp-xs);
}

.gy-sense__cit-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.gy-sense__cit-item {
  padding: 4px 0;
  border-bottom: 1px dashed var(--c-border-light);
  font-family: var(--ff-serif);
  line-height: 1.8;
}

.gy-sense__cit-item:last-child {
  border-bottom: none;
}

/* toggle off 时隐藏 guoyu 的书证块 */
.xxjs-section[data-show-citations="off"] .gy-sense__cit {
  display: none;
}

/* toggle off 时隐藏成语区块的出处 / 示例行（解释 / 语法始终显示） */
.idiom-section[data-show-citations="off"] .idiom-entry__cit-line,
.idiom-section[data-show-citations="off"] .idiom-entry__exam-line {
  display: none;
}

/* ── 移动端 ──────────────────────────────────────────────── */
@media (max-width: 767px) {
  .xxjs-reading__head,
  .jbjs-reading__head,
  .gy-reading__head {
    flex-wrap: wrap;
    gap: var(--sp-xs);
  }
  .xxjs-reading__char,
  .jbjs-reading__char,
  .gy-reading__char {
    font-size: var(--fs-lg);
  }
  .gy-sense__eg,
  .gy-sense__cit {
    margin-left: var(--sp-xs);
  }
  .gy-sense__num {
    min-width: 22px;
    font-size: var(--fs-base);
  }
  .xxjs-item__def::before {
    min-width: 20px;
    font-size: var(--fs-base);
  }
}


/* ============================================================
   字头卡片：元信息字段值 + 异体字行（图稿布局）
   ============================================================ */

/* meta-value：徽章右边的朴素文本值（部外、总笔画、字形分析 的内容） */
.meta-value {
  color: var(--c-text);
  font-size: var(--fs-base);
  font-family: var(--ff-serif);
}

/* mono 变体：统一码、笔顺用等宽字体 */
.meta-value--mono {
  font-family: var(--ff-mono);
  font-size: var(--fs-sm);
  letter-spacing: 0.02em;
}

/* 异体字行 —— 位于 .char-card 底部，横跨整行 */
.char-card__variants {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-sm) var(--sp-md);
  padding: var(--sp-sm) 0 0;
  margin-top: var(--sp-sm);
  border-top: 1px solid var(--c-border-light);
}

.variant-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-xs);
  align-items: center;
}

.variant-item {
  display: inline-flex;
}

.variant-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  min-height: 36px;
  padding: 2px;
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}

.variant-link:hover {
  background: var(--c-surface-alt);
}

.variant-link img {
  width: 28px;
  height: 28px;
  display: block;
}

/* 注：.variant-char 已在 main.css 定义（字号、颜色、hover） */

@media (max-width: 767px) {
  .char-card__variants {
    padding-top: var(--sp-xs);
    margin-top: var(--sp-xs);
  }
  .variant-link {
    min-width: 30px;
    min-height: 30px;
  }
  .variant-link img {
    width: 24px;
    height: 24px;
  }
}

/* ============================================================
   深色模式 meta-value 色
   ============================================================ */
[data-theme="dark"] .meta-value {
  color: var(--c-text);
}


/* ============================================================
   字源字形：各书体字形实例（折叠分组 + 字形图网格）
   --------------------------------------------------------
   - 折叠外壳复用 .phon-groups / .phon-group / .phon-group__summary 等
     （已在音韵方言区段定义），本处只加内部网格样式
   - 网格：自适应列数，每格 SVG 图 + 可选说明文字（source_ref 等）
   ============================================================ */

/* 容器：与音韵方言的 .phon-groups 共用外观 */
.glyph-instances {
  /* 默认 .phon-groups 已给出 gap/padding；这里不覆盖 */
}

/* 网格：每格 60px 宽，按内容伸缩 */
.glyph-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: var(--sp-sm);
  padding: var(--sp-sm) 0;
  align-items: start;
}

.glyph-grid__item {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: var(--sp-xs) 4px;
  border-radius: var(--radius-sm);
  background: var(--c-bg);
  transition: background var(--transition-fast);
}

.glyph-grid__item:hover {
  background: var(--c-surface-alt);
}

.glyph-grid__img {
  display: block;
  width: 80px;
  height: 80px;
  object-fit: contain;
}

.glyph-grid__caption {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
  text-align: center;
  line-height: 1.3;
  font-family: var(--ff-serif);
  /* 太长省略 */
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 深色模式：SVG 字形一般是黑色描边，深色底上需反色显示 */
[data-theme="dark"] .glyph-grid__img,
[data-theme="dark"] .glyph-evolution__item a img,
[data-theme="dark"] .glyph-evolution__link img,
[data-theme="dark"] .glyph-compare__item img {
  filter: invert(0.92) hue-rotate(180deg);
}

[data-theme="dark"] .glyph-grid__item {
  background: var(--c-surface-alt);
}

[data-theme="dark"] .glyph-grid__item:hover {
  background: var(--c-surface);
}

/* 移动端：格子略小 */
@media (max-width: 767px) {
  .glyph-grid {
    grid-template-columns: repeat(auto-fill, minmax(56px, 1fr));
    gap: var(--sp-xs);
  }
  .glyph-grid__img {
    width: 48px;
    height: 48px;
  }
}


/* ============================================================
   侧边栏补充样式
   --------------------------------------------------------
   main.css 已定义：.sidebar / .sidebar__sticky / .sidebar-card /
                    .sidebar-card__title / .related-chars--grid /
                    .related-char-tag（及 hover）
   此处补充：.related-chars 容器 / hint / empty 提示文本
   ============================================================ */
.related-chars {
  /* 与 main.css 里 .related-chars--grid 修饰符组合 */
}

.sidebar-card__hint {
  margin: var(--sp-sm) 0 0;
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
  line-height: 1.5;
}

.sidebar-card__empty {
  margin: 0;
  padding: var(--sp-sm) 0;
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  text-align: center;
  font-style: italic;
}

[data-theme="dark"] .sidebar-card__hint,
[data-theme="dark"] .sidebar-card__empty {
  color: var(--c-text-secondary);
}

/* ── 词典翻译区块 ────────────────────────────────────────────── */
.word-trans {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-sm);
}
.word-trans__row {
  display: flex;
  align-items: baseline;
  gap: var(--sp-md);
}
.word-trans__lang {
  flex-shrink: 0;
  min-width: 2.5em;
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-text-secondary);
}
.word-trans__text {
  font-size: var(--fs-base);
  color: var(--c-text);
  line-height: 1.6;
}

/* ── 词语解释多音分组标题（word 域 reading-head） ─────────────── */
.xxjs-reading-head {
  display: flex;
  align-items: baseline;
  gap: var(--sp-sm);
  padding: var(--sp-sm) 0;
  margin: var(--sp-md) 0 var(--sp-xs);
  border-bottom: 1px dashed var(--c-border-light);
}
.xxjs-reading-head:first-child {
  margin-top: 0;
}

.xxjs-reading__word {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--c-text);
}

/* ── 词典义项内嵌书证 ───────────────────────────────────────── */
.word-inline-cit {
  list-style: none;
  margin: var(--sp-xs) 0 0 var(--sp-md);
  padding: 0;
  border-left: 2px solid var(--c-border);
  padding-left: var(--sp-sm);
}
.word-inline-cit__item {
  margin: var(--sp-xs) 0;
  font-size: var(--fs-sm);
  color: var(--c-text-secondary);
  line-height: 1.6;
}
.word-inline-cit__text {
  font-style: italic;
}
.word-inline-cit__source {
  font-style: normal;
  color: var(--c-text-tertiary, var(--c-text-secondary));
  font-size: var(--fs-xs);
  white-space: nowrap;
}

/* ── sidebar 加载状态 ───────────────────────────────────────── */
.sidebar-card__loading {
  font-size: var(--fs-xs);
  color: var(--c-text-secondary);
}

/* ── 小尺寸播放按钮（reading-head 用）──────────────────────── */
.audio-btn--sm {
  width: 20px;
  height: 20px;
  min-width: 20px;
  opacity: 0.7;
}
.audio-btn--sm:hover {
  opacity: 1;
}
