/* EmojiGrid — 5 категорий эмодзи (basic + 4 PRO). */

.settings-emoji-panel {
  margin-top: 12px;
  background: var(--panel-solid);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(38px, 1fr));
  gap: 5px;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}
.settings-emoji-panel[hidden] { display: none; }

/* `display: contents` — обёртки .se-grid не создают свой бокс, ячейки встают
   подряд в общий grid-контейнер. */
.settings-emoji-panel .se-grid { display: contents; }

.settings-emoji-panel .se-cell {
  width: 100%;
  aspect-ratio: 1;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 18px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
  color: var(--text);
  transition: background 0.12s, border-color 0.12s, box-shadow var(--t-smooth);
}
.settings-emoji-panel .se-cell:hover { background: var(--surface-hover); }

/* Free — зелёное выделение. */
.settings-emoji-panel .se-cell.selected:not(.se-pro-cell) {
  border-color: rgba(var(--success-rgb), 0.65);
  background: rgba(var(--success-rgb), 0.20);
  box-shadow: 0 0 0 1px rgba(var(--success-rgb), 0.55), 0 0 14px rgba(var(--success-rgb), 0.45);
}
/* PRO — золотое выделение. */
.settings-emoji-panel .se-cell.se-pro-cell.selected {
  border-color: rgba(var(--gold-rgb), 0.65);
  background: rgba(var(--gold-rgb), 0.20);
  box-shadow: 0 0 0 1px rgba(var(--gold-rgb), 0.55), 0 0 14px rgba(var(--gold-rgb), 0.45);
}

.settings-emoji-panel .se-cell.locked {
  opacity: 0.35;
  filter: grayscale(1);
  cursor: not-allowed;
}
