.ccg-glossary { border:1px solid #e5e7eb; border-radius:14px; padding:16px; background:#fff; }
.ccg-g-label { position:absolute; left:-9999px; }
.ccg-g-input { width:100%; padding:10px 12px; border:1px solid #e5e7eb; border-radius:10px; }
.ccg-g-meta { margin-top:8px; font-size:12px; color:#6b7280; }

.ccg-g-top { display:flex; justify-content:flex-start; align-items:center; gap:8px; margin-bottom:8px; }
.ccg-g-az { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px; }
.ccg-az-chip { border:1px solid #e5e7eb; background:#f9fafb; border-radius:999px; padding:4px 8px; font-size:12px; cursor:pointer; }
.ccg-az-chip.is-active { background:#111827; color:#fff; border-color:#111827; }

.ccg-g-dl { margin:12px 0 0; }
.ccg-g-item { padding:12px 0; border-bottom:1px solid #f1f5f9; }
.ccg-g-item:last-child { border-bottom:0; }

.ccg-g-term { font-weight:700; margin:0 0 4px; display:flex; gap:8px; align-items:center; }
.ccg-g-anchor { text-decoration:none; opacity:.35; }
.ccg-g-anchor:hover { opacity:.7; }

.ccg-copy { border:1px solid #e5e7eb; background:#fff; border-radius:8px; font-size:12px; padding:2px 6px; cursor:pointer; line-height:1; }
.ccg-copy.ok { border-color:#5cb85c; box-shadow:0 0 0 2px rgba(92,184,92,0.25); }

.ccg-g-def { margin:0; color:#111827; }
.ccg-g-syns { margin-top:4px; font-size:13px; color:#374151; }
.ccg-syn-label { font-weight:600; margin-right:4px; }
.ccg-syn { font-style:italic; }

.ccg-g-tags { margin-top:6px; display:flex; gap:6px; flex-wrap:wrap; }
.ccg-g-tag { --tag-bg:#4A90E2; background:var(--tag-bg); color:#fff; font-size:11px; padding:2px 8px; border-radius:999px; border:0; }

.ccg-g-empty { margin:12px 0; color:#6b7280; }
