
.emoji-picker-container {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.emoji-trigger {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 24px;
    padding: 4px 8px;
    opacity: 0.65;
    transition: opacity 0.15s, transform 0.15s, color 0.15s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: inherit;
    line-height: 1;
}

.emoji-trigger:hover {
    opacity: 1;
    color: var(--color-primary, var(--color-primary));
}

.emoji-picker {
    /* fixed — чтобы picker не обрезался parent-контейнером с overflow:hidden
       (например, .post-editor). Позиция вычисляется в EmojiPicker.init() через
       getBoundingClientRect триггера. */
    position: fixed;
    background: #1c1c1c;
    border: 1px solid #333;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.5);
    padding: 10px;
    z-index: 10000;
    width: 320px;
    max-height: 420px;
    box-sizing: border-box;
    overflow-y: auto;       /* вертикальная прокрутка вместо обрезки */
    overflow-x: hidden;
    animation: emojiFadeIn 0.2s ease-out;
}

@media (max-width: 900px) {
    .emoji-picker {
        width: min(340px, calc(100vw - 24px));
        max-height: min(420px, calc(100vh - 80px));
    }
}

@keyframes emojiFadeIn {
    from { opacity: 0; transform: translateY(5px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ── Telegram-style: верхние табы «Эмоции / Стикеры» ───────────────── */
/* Появляются только если caller передал stickerOnPick (см. EmojiPicker.init).
   У picker'а с табами padding=0, табы — sticky-header, контент скроллится. */
/* Фиксированная высота даёт flex-детям корректное распределение и
   гарантирует, что внутренний pane получит scroll при переполнении.
   Без явного height: flex: 1 1 auto + max-height на родителе = pane
   шринкуется по контенту и скролл не появляется. */
.emoji-picker--tabbed {
    padding: 0;
    display: flex;
    flex-direction: column;
    height: 420px;
    max-height: calc(100vh - 80px);
    overflow: hidden; /* скролл живёт внутри .emoji-picker__pane, не двойной */
}
.emoji-picker__tabs {
    display: flex;
    gap: 0;
    background: #1c1c1c;
    border-bottom: 1px solid #2a2a2a;
    flex-shrink: 0;
    position: sticky;
    top: 0;
    z-index: 2;
}
.emoji-picker__tab {
    flex: 1;
    background: none;
    border: none;
    color: #999;
    font-size: 13px;
    font-weight: 600;
    padding: 12px 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    border-bottom: 2px solid transparent;
    transition: color .15s, border-color .15s, background .15s;
    line-height: 1;
}
.emoji-picker__tab:hover { color: #ddd; background: rgba(255,255,255,.04); }
.emoji-picker__tab.is-active {
    color: #fff;
    border-bottom-color: var(--color-primary, var(--color-primary));
}
.emoji-picker__tab i { font-size: 15px; }

.emoji-picker__pane {
    padding: 10px;
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
}
.emoji-picker__pane[hidden] { display: none; }

.emoji-grid {
    display: grid;
    /* Адаптивный grid: колонки сами подстраиваются под ширину picker'а.
       minmax(44px, 1fr) — гарантирует равные ячейки достаточной ширины
       для 28×28 кастомных эмодзи с паддингом без обрезки. */
    grid-template-columns: repeat(auto-fill, minmax(44px, 1fr));
    gap: 4px;
}

.emoji-item {
    font-size: 22px;
    padding: 6px;
    cursor: pointer;
    border-radius: 6px;
    text-align: center;
    transition: background 0.2s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    aspect-ratio: 1 / 1;       /* квадратные ячейки — крупный эмодзи виден целиком */
}

.emoji-item:hover {
    background: rgba(255, 255, 255, 0.1);
}

/* ── Кастомные эмодзи: PNG/WebP вместо системного шрифта ─────────── */
.emoji-item--custom img {
    width: 100%;
    height: 100%;
    max-width: 32px;
    max-height: 32px;
    object-fit: contain;
    pointer-events: none;        /* клик уходит на span, не на img */
}

/* Заголовки секций (Кастомные / Стандартные) */
.emoji-section + .emoji-section {
    margin-top: 8px;
}
.emoji-section--with-divider {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 8px;
}
.emoji-section__title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #888;
    margin-bottom: 6px;
    padding: 0 4px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ── Под-табы кастомных эмодзи (Telegram-style).
   Ряд cover-иконок паков сверху, активный — подсвечен. Скрол по горизонтали
   если паков много (на узких экранах). ───────────────────────────────── */
.emoji-custom-root {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding-top: 4px;
}
.emoji-picker__subtabs {
    display: flex;
    gap: 4px;
    padding: 4px 4px 6px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    overflow-x: auto;
    scrollbar-width: none;
}
.emoji-picker__subtabs::-webkit-scrollbar { display: none; }

.emoji-picker__subtab {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border: 0;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 11px;
    transition: background 0.15s;
    position: relative;
}
.emoji-picker__subtab:hover { background: rgba(255, 255, 255, 0.12); }
.emoji-picker__subtab.is-active {
    background: var(--color-primary, var(--color-primary));
}
.emoji-picker__subtab img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    pointer-events: none;
}
/* Standard-таб использует текстовый emoji вместо <img> — нужен большой font
   чтобы 😀 не выглядел мельче чем 28px-картинки соседних паков. */
.emoji-picker__subtab--standard {
    font-size: 22px;
    line-height: 1;
}
/* Маленькая ★ в углу таба, если пак premium */
.emoji-picker__subtab--premium::after {
    content: '★';
    position: absolute;
    top: -1px;
    right: -1px;
    font-size: 9px;
    color: #f5b324;
    text-shadow: 0 0 2px rgba(0, 0, 0, 0.7);
    pointer-events: none;
}

/* Заголовки подкатегорий внутри PRO-таба. Несколько premium-паков
   агрегируются в одну вкладку, разделители — на названия пакетов. */
.emoji-subgroup__title {
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: #888;
    margin: 4px 4px 6px;
}
.emoji-subgroup__title--with-divider {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    padding-top: 8px;
    margin-top: 10px;
}
.emoji-subgroup__grid {
    margin-bottom: 4px;
}

/* PRO-бейдж над гридом, виден когда активен premium-pak.
   margin-left:auto в block-контексте + align-self:flex-end в flex-column —
   обе техники прижимают к правому краю независимо от типа родителя
   (emoji-pane = flex-column, sticker-pane = block). */
.emoji-picker__active-pro-badge {
    display: block;
    width: fit-content;
    align-self: flex-end;
    margin: -2px 6px 0 auto;
    padding: 1px 6px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #1a1a1a;
    background: linear-gradient(135deg, #ffd76b 0%, #f5b324 100%);
    border-radius: 3px;
    box-shadow: 0 0 4px rgba(245, 179, 36, 0.4);
}

/* PRO-бейдж в заголовке премиум-пака. Жёлтый чтобы выделяться от приглушённого
   серого title-color. На клик/hover не реагирует — это статус-метка, не CTA.
   Legacy от вертикальной структуры — оставлен на случай back-compat рендера. */
.emoji-section__pro-badge {
    display: inline-flex;
    align-items: center;
    padding: 1px 5px;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #1a1a1a;
    background: linear-gradient(135deg, #ffd76b 0%, #f5b324 100%);
    border-radius: 3px;
    box-shadow: 0 0 4px rgba(245, 179, 36, 0.4);
}

/* Заблокированные премиум-эмодзи: визуально приглушены + lock-звёздочка
   в углу. Клик не вставляет токен (см. EmojiPicker.js), кидает CustomEvent
   `emoji:premium-locked` для CTA-модалки в будущем. */
.emoji-item--locked {
    position: relative;
    cursor: not-allowed;
}
.emoji-item--locked img {
    opacity: 0.5;
    filter: grayscale(0.4);
    transition: opacity 0.15s, filter 0.15s;
}
.emoji-item--locked:hover img {
    opacity: 0.85;
    filter: grayscale(0.1);
}
.emoji-item--locked::after {
    content: '★';
    position: absolute;
    top: -2px;
    right: -2px;
    font-size: 10px;
    color: #f5b324;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.6);
    pointer-events: none;
}

/* ── Inline-рендер кастомных эмодзи в любом тексте ───────────────── */
.custom-emoji {
    display: inline-block;
    width: 1.4em;
    height: 1.4em;
    vertical-align: -0.3em;
    object-fit: contain;
    user-select: none;
}

/* ── Contenteditable, замена textarea ────────────────────────────── */
/* Поле ведёт себя как textarea, но рендерит inline картинки эмодзи. */
.emoji-ce {
    white-space: pre-wrap;
    word-break: break-word;
    overflow-y: auto;
    cursor: text;
    outline: none;
    min-height: 52px;       /* гарантия видимости даже когда исходный textarea без высоты */
    box-sizing: border-box;
}
.emoji-ce:empty::before {
    content: attr(data-placeholder);
    color: var(--c-slate-400);
    pointer-events: none;
}
.emoji-ce .custom-emoji {
    /* Картинки внутри editable не должны быть редактируемыми контейнерами */
    user-select: all;
}
/* В contenteditable картинку нельзя resize handle'ом */
.emoji-ce img {
    -webkit-user-modify: read-only;
}
/* В заголовках и крупных блоках чуть крупнее */
h1 .custom-emoji,
h2 .custom-emoji,
h3 .custom-emoji {
    width: 1.2em;
    height: 1.2em;
}

/* В чате — крупнее: у bubble мелкий font, иначе картинки выглядят
   как UI-иконки, а не как полноценные эмодзи. */
.q3f9-bubble .custom-emoji {
    width: 28px;
    height: 28px;
    vertical-align: -8px;
    margin: 0 1px;
}

/* Jumbo-emoji в чате — bubble без фона, эмодзи крупно (как стикер).
   Telegram/WhatsApp-стиль для сообщений из одних только эмодзи (≤10).
   font-size с !important потому что style.css грузится позже и
   .q3f9-bubble { font-size: 14px } имеет ту же специфичность —
   без !important перекрывает обратно. */
.q3f9-bubble--emoji-only {
    background: transparent !important;
    box-shadow: none !important;
    padding: 4px 0 !important;
    font-size: 64px !important;
    line-height: 1.1;
}
.q3f9-bubble--emoji-only .custom-emoji {
    width: 72px;
    height: 72px;
    vertical-align: -16px;
}

/* В комментариях (post + product) — тоже крупнее, чтобы не выглядели как
   мелкие иконки внутри 16px-текста. 2026-05-02.
   Включаем и поле ввода `.comment-input.emoji-ce` — иначе во время набора
   эмодзи мелкие, а после публикации становятся крупными. Один размер
   везде = одинаковое восприятие. */
.comment-body .custom-emoji,
.comment-text .custom-emoji,
.comment-input.emoji-ce .custom-emoji {
    width: 26px;
    height: 26px;
    vertical-align: -7px;
    margin: 0 1px;
}

/* ── Стикер-сообщение в чате ─────────────────────────────────────── */
/* Bubble без фона/паддингов: только картинка + время. */
.q3f9-bubble--sticker {
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 !important;
    border: none !important;
}
.q3f9-bubble--sticker .q3f9-sticker-img {
    display: block;
    max-width: 200px;
    max-height: 200px;
    width: auto;
    height: auto;
    border-radius: 12px;
    user-select: none;
}
.q3f9-bubble--sticker .q3f9-msgstatus,
.q3f9-bubble--sticker .text-extra-small {
    background: rgba(15, 23, 42, 0.06);
    padding: 2px 8px;
    border-radius: 999px;
    margin-top: 4px;
    display: inline-block;
}

/* ── Sticker picker ──────────────────────────────────────────────── */
.sticker-picker {
    width: 360px !important;
    max-height: 460px !important;
    padding: 8px !important;
}
.sticker-picker__tabs {
    display: flex;
    gap: 4px;
    overflow-x: auto;
    padding: 4px 4px 8px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 8px;
    scrollbar-width: thin;
}
.sticker-picker__tab {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border: 0;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 8px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 11px;
    transition: background 0.15s;
}
.sticker-picker__tab:hover { background: rgba(255, 255, 255, 0.12); }
.sticker-picker__tab.is-active {
    background: var(--color-primary, var(--color-primary));
}
.sticker-picker__tab img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    pointer-events: none;
}
/* Маленькая ★ в углу таба для premium-стикерпака — единый паттерн с эмодзи. */
.sticker-picker__tab {
    position: relative;
}
.sticker-picker__tab--premium::after {
    content: '★';
    position: absolute;
    top: -1px;
    right: -1px;
    font-size: 10px;
    color: #f5b324;
    text-shadow: 0 0 2px rgba(0, 0, 0, 0.7);
    pointer-events: none;
}
.sticker-picker__grid {
    grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)) !important;
    gap: 6px !important;
}
.sticker-picker__cell {
    aspect-ratio: 1 / 1;
    padding: 4px !important;
}
.sticker-picker__cell img {
    width: 100%;
    height: 100%;
    max-width: 64px;
    max-height: 64px;
    object-fit: contain;
    pointer-events: none;
}
.sticker-picker__empty {
    color: var(--c-slate-400);
    text-align: center;
    padding: 32px 16px;
    font-size: 14px;
}

/* Scrollbar if many emojis */
.emoji-picker::-webkit-scrollbar {
    width: 4px;
}
.emoji-picker::-webkit-scrollbar-thumb {
    background: #444;
    border-radius: 2px;
}
