/* ═════════════════════════════════════════════════════════
   ids.css — 汉字拆分查询（IDS）样式
   布局：page-layout grid（main.css）+ content + sidebar
   ═════════════════════════════════════════════════════════ */

/* ── 页面容器 ─────────────────────────────────────── */
.nr-box {
  background: var(--c-surface, #FFF);
  border-radius: var(--radius-lg, 12px);
  padding: var(--sp-lg, 24px);
  border: 1px solid var(--c-border-light, #EAE4DD);
  box-shadow: 0 1px 4px var(--c-shadow, rgba(44,37,32,0.08));
}

/* ── 大标题 ───────────────────────────────────────── */
.nr-box h1 {
  font-family: var(--ff-serif, serif);
  font-size: var(--fs-3xl, 2rem);
  font-weight: 700;
  color: var(--c-primary, #8b411c);
  text-align: center;
  margin-bottom: var(--sp-lg, 24px);
  padding-bottom: var(--sp-md, 16px);
  border-bottom: 2px solid var(--c-primary, #8b411c);
  letter-spacing: 2px;
}

/* ── IDC 图标面板 ────────────────────────────────── */
#idcico {
  max-width: 480px;
  margin: 0 auto var(--sp-lg, 24px);
}

#idcico ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-sm, 8px);
  padding: 0;
  margin: 0;
}

#idcico ul li {
  display: inline-flex;
}

#idcico .idcico {
  display: block;
  width: 44px;
  height: 44px;
  padding: 6px;
  background: var(--c-surface-alt, #FAF7F3);
  border: 1px solid var(--c-border, #D6CEC6);
  border-radius: var(--radius-md, 8px);
  cursor: pointer;
  transition: transform var(--transition-fast, 0.15s ease),
              box-shadow var(--transition-fast, 0.15s ease),
              border-color var(--transition-fast, 0.15s ease);
}

#idcico .idcico:hover {
  transform: translateY(-2px);
  border-color: var(--c-primary, #8b411c);
  box-shadow: 0 2px 8px var(--c-shadow, rgba(44,37,32,0.12));
}

/* ── 搜索表单 ────────────────────────────────────── */
#idssc {
  max-width: 560px;
  margin: 0 auto var(--sp-lg, 24px);
}

#form1 { text-align: center; }

.tp_c {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-sm, 8px);
}

.tp_c label {
  display: inline-flex;
}

#keyboard {
  width: 320px;
  height: 44px;
  padding: 0 var(--sp-md, 16px);
  border: 1px solid var(--c-border, #D6CEC6);
  border-radius: var(--radius-md, 8px);
  font-family: var(--ff-serif, serif);
  font-size: var(--fs-xl, 1.25rem);
  color: var(--c-text, #2C2520);
  background: var(--c-surface, #FFF);
  transition: border-color var(--transition-fast, 0.15s ease),
              box-shadow var(--transition-fast, 0.15s ease);
  outline: none;
}

#keyboard:focus {
  border-color: var(--c-primary, #8b411c);
  box-shadow: 0 0 0 3px rgba(139,65,28,0.12);
}

#keyboard::placeholder {
  color: var(--c-text-secondary, #8C7E72);
  font-size: var(--fs-sm, 0.875rem);
}

#button {
  height: 44px;
  padding: 0 var(--sp-lg, 24px);
  background: var(--c-primary, #8b411c);
  color: #FFF;
  border: none;
  border-radius: var(--radius-md, 8px);
  font-size: var(--fs-base, 1rem);
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition-fast, 0.15s ease),
              transform var(--transition-fast, 0.15s ease);
}

#button:hover {
  background: var(--c-primary-dark, #6B2F10);
  transform: translateY(-1px);
}

/* ── 错误提示 ────────────────────────────────────── */
.ids-error {
  text-align: center;
  font-size: var(--fs-sm, 0.875rem);
  color: #D43A2F;
  background: #FEF0EF;
  border: 1px solid #F5C6C2;
  border-radius: var(--radius-md, 8px);
  padding: var(--sp-sm, 8px) var(--sp-md, 16px);
  margin-bottom: var(--sp-md, 16px);
}

/* ── 生僻字切换开关 ──────────────────────────────── */
.twbon {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-sm, 8px);
  margin: 0 0 var(--sp-md, 16px) 0;
  font-size: var(--fs-sm, 0.875rem);
  color: var(--c-text-secondary, #8C7E72);
}

/* ── 结果标题 ────────────────────────────────────── */
.idssw h3 {
  font-family: var(--ff-serif, serif);
  font-size: var(--fs-lg, 1.125rem);
  font-weight: 600;
  color: var(--c-text, #2C2520);
  margin-bottom: var(--sp-md, 16px);
  padding-bottom: var(--sp-sm, 8px);
  border-bottom: 2px solid var(--c-primary, #8b411c);
}

/* ── 结果网格 ────────────────────────────────────── */
.ids_nr { margin-bottom: var(--sp-md, 16px); }

.ids_nr ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 0;
  margin: 0;
}

.ids_nr li {
  width: 40px;
  height: 40px;
  display: flex;
}

.ids_nr li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid var(--c-border, #D6CEC6);
  border-radius: var(--radius-sm, 4px);
  background: var(--c-surface, #FFF);
  font-family: var(--ff-serif, serif);
  font-size: 22px;
  color: var(--c-text, #2C2520);
  text-decoration: none;
  overflow: hidden;
  transition: border-color var(--transition-fast, 0.15s ease),
              transform var(--transition-fast, 0.15s ease),
              box-shadow var(--transition-fast, 0.15s ease);
}

.ids_nr li a:hover {
  border-color: var(--c-primary, #8b411c);
  transform: translateY(-2px);
  box-shadow: 0 2px 6px var(--c-shadow, rgba(44,37,32,0.12));
}

.ids_nr li img { display: none; }

/* 默认：B区及以上文字隐藏（由JS切换） */
.CJKB_txt,.CJKC_txt,.CJKD_txt,.CJKE_txt,.CJKF_txt,
.CJKG_txt,.CJKH_txt,.CJKI_txt,.CJKJ_txt,.CJKCP_txt,.TIP_txt {
  display: none;
}

/* Unicode 平面分色 */
.ids_nr li.CJK a    { background: #FAFAFA; }
.ids_nr li.CJKA a   { background: #EBF5FB; }
.ids_nr li.CJKB a   { background: #FFFDE7; }
.ids_nr li.CJKC a   { background: #F3E5F5; }
.ids_nr li.CJKD a   { background: #E8F5E9; }
.ids_nr li.CJKE a   { background: #FCE4EC; }
.ids_nr li.CJKF a   { background: #E0F7FA; }
.ids_nr li.CJKG a   { background: #FFF8E1; }
.ids_nr li.CJKH a   { background: #FFF3E0; }
.ids_nr li.CJKI a   { background: #EFEBE9; }
.ids_nr li.CJKJ a   { background: #F9FBE7; }
.ids_nr li.CJKCP a  { background: #FFF; }
.ids_nr li.TIP a    { background: #FFFDE7; }

/* ── 分页导航 ────────────────────────────────────── */
.epages {
  display: flex;
  justify-content: center;
  gap: var(--sp-sm, 8px);
  margin-top: var(--sp-lg, 24px);
  padding-top: var(--sp-md, 16px);
  border-top: 1px solid var(--c-border-light, #EAE4DD);
}

.epages a {
  display: inline-block;
  padding: 6px 16px;
  background: var(--c-surface-alt, #FAF7F3);
  border: 1px solid var(--c-border, #D6CEC6);
  border-radius: var(--radius-sm, 4px);
  font-size: var(--fs-sm, 0.875rem);
  color: var(--c-text, #2C2520);
  text-decoration: none;
  transition: background var(--transition-fast, 0.15s ease),
              border-color var(--transition-fast, 0.15s ease),
              color var(--transition-fast, 0.15s ease);
}

.epages a:hover {
  background: var(--c-primary, #8b411c);
  border-color: var(--c-primary, #8b411c);
  color: #FFF;
}

/* ── Unicode 平面图例 ────────────────────────────── */
.ids_sm {
  margin: var(--sp-md, 16px) 0 0;
  padding-top: var(--sp-md, 16px);
  border-top: 1px solid var(--c-border-light, #EAE4DD);
}

.ids_sm ul {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0;
  margin: 0;
}

.ids_sm li {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs, 0.75rem);
  color: var(--c-text-secondary, #8C7E72);
}

.ids_sm li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-sm, 4px);
  font-size: var(--fs-xs, 0.75rem);
}

/* ── IDC 参考表（复用 .qgg-table） ─────────────────── */
.idssw .qgg-table {
  max-width: 760px;
  margin: var(--sp-md, 16px) auto;
}

/* ── 无结果提示 ──────────────────────────────────── */
.ids-empty {
  text-align: center;
  color: var(--c-text-secondary, #8C7E72);
  font-size: var(--fs-base, 1rem);
  padding: var(--sp-lg, 24px);
}

.idssw > p {
  font-size: var(--fs-sm, 0.875rem);
  color: var(--c-text-secondary, #8C7E72);
  line-height: 1.8;
  margin-bottom: var(--sp-sm, 8px);
}

/* ── 侧边栏（sidebar-card 已在 main.css 定义）─────── */
/* 侧栏内 treebox 微调 */
.sidebar .treebox {
  margin: 0;
}

.sidebar .menu {
  margin: 0;
}

/* ── 响应式 ──────────────────────────────────────── */
@media (max-width: 1023px) {
  .nr-box {
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
}

@media (max-width: 767px) {
  .nr-box {
    padding: var(--sp-md, 16px);
  }

  .nr-box h1 {
    font-size: var(--fs-2xl, 1.5rem);
  }

  .tp_c {
    flex-direction: column;
  }

  #keyboard {
    width: 100%;
    max-width: 280px;
  }

  #idcico .idcico {
    width: 38px;
    height: 38px;
    padding: 5px;
  }

  .ids_nr li, .ids_nr li a {
    width: 36px;
    height: 36px;
  }

  .ids_nr li a {
    font-size: 20px;
  }
}
