/**
 * BLOCKS v5.0 — Premium Cards & Layout
 */

/* ─── КАРТОЧКИ ─────────────────────────────────────── */
.block-card {
    background: var(--card-bg);
    border-radius: var(--radius-card);
    box-shadow: var(--card-shadow);
    padding: 14px 16px;
    margin-bottom: 16px;
    border: 1px solid var(--card-border);
    position: relative;
    overflow: hidden;
    transition: box-shadow 0.2s ease;
}

/* Плоский блок — без рамки, тени, полоски */
.block-flat {
    background: transparent;
    padding: 8px 24px;
    margin-bottom: 0;
    position: relative;
}

/* Невидимый layout-container: без карточки, полоски и встроенных отступов. */
.block-bare {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin-bottom: 16px;
    position: relative;
    overflow: visible;
}

/* ─── ЭЛЕМЕНТ ФИДА (карточка в списке) ──────────────── */
.feed-item {
    background: var(--card-bg);
    border-radius: var(--radius-card);
    box-shadow: var(--card-shadow);
    padding: 12px 14px;
    border: 1px solid var(--card-border);
    overflow: hidden;
}

/* Sidebar отступ: контент не лезет под fixed sidebar */
@media (min-width: 768px) {
    #app-root {
        padding-left: calc(240px + var(--page-sidebar-gap, 0px));
    }
}

/* ─── ЗАГОЛОВКИ БЛОКОВ ─────────────────────────────── */
.block-header {
    font-size: 10px;
    font-weight: 800;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
}

/* ─── СКРОЛЛБАР ЧАТА ───────────────────────────────── */
.feed-container::-webkit-scrollbar {
    width: 3px;
}

.feed-container::-webkit-scrollbar-track {
    background: transparent;
}

.feed-container::-webkit-scrollbar-thumb {
    background: var(--neutral-control);
    border-radius: 10px;
}

/* ─── СКРОЛЛБАР #app-root (split-режим, тонкий) ──── */
#app-root::-webkit-scrollbar {
    width: 5px;
}

#app-root::-webkit-scrollbar-track {
    background: transparent;
}

#app-root::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.12);
    border-radius: 4px;
}

#app-root::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.25);
}

#app-root {
    scrollbar-width: thin;
    /* Firefox */
    scrollbar-color: rgba(0, 0, 0, 0.12) transparent;
}

#app-root.page-stack--managed-gap {
    display: flex;
    flex-direction: column;
    gap: var(--page-block-gap, 16px);
}

#app-root.page-shell--managed-gutter {
    --page-sidebar-gap: 0px;
}

#app-root.page-stack--managed-gap>* {
    width: 100%;
}

#app-root.page-stack--managed-gap>.block-card,
#app-root.page-stack--managed-gap>.block-flat,
#app-root.page-stack--managed-gap>.block-bare,
#app-root.page-stack--managed-gap>.ui-btn-bar,
#app-root.page-stack--managed-gap>.layout-columns {
    margin-bottom: 0;
}

/* ─── ДЕТАЛИ (summary/details) ─────────────────────── */
details>summary {
    list-style: none;
}

details>summary::-webkit-details-marker {
    display: none;
}

/* ─── ЦВЕТНЫЕ ПОЛОСКИ СЛЕВА (АКЦЕНТ КАРТОЧКИ) - УСТАРЕЛО ──────── */
.block-card.legacy-border>div:first-child[class*="bg-"] {
    border-radius: var(--radius-card) 0 0 var(--radius-card);
}

/* ─── НОВЫЕ ПРЕМИУМ-КАРТОЧКИ И СЕТКА ────────────────── */
.card-premium {
    background: var(--card-bg);
    border-radius: var(--radius-card);
    box-shadow: var(--card-shadow);
    padding: 16px;
    margin-bottom: 12px;
    border: 1px solid var(--card-border);
    display: flex;
    flex-direction: column;
    gap: 12px;
}

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

.flex-between {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* ─── НАВИГАЦИЯ: ПИЛЮЛИ (ПЕРЕКЛЮЧАТЕЛЬ КОНТЕКСТА) ───── */
.context-pills {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-bottom: 16px;
    /* Скрываем скроллбар для эстетики */
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.context-pills::-webkit-scrollbar {
    display: none;
}

.pill {
    padding: 6px 12px;
    border-radius: 20px;
    background: var(--surface-card);
    color: var(--text-secondary);
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    border: 1px solid var(--card-border);
    transition: all 0.2s ease;
}

.pill.active {
    background: var(--action-primary-bg);
    color: var(--action-primary-text);
    border-color: var(--action-primary-bg);
    box-shadow: 0 2px 4px var(--action-primary-shadow);
}

/* ─── ЧАТ И STICKY FOOTER ───────────────────────────── */
.chat-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 80px);
    /* Примерная высота с учетом шапки */
    position: relative;
}

.chat-panel {
    flex-grow: 1;
    overflow-y: auto;
    padding: 16px;
    background: var(--chat-panel-bg);
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding-bottom: 24px;
}

.chat-bubble {
    padding: 10px 14px;
    border-radius: 12px;
    max-width: 85%;
    font-size: 13px;
    line-height: 1.4;
    position: relative;
}

.chat-bubble-bot {
    background: var(--chat-bubble-surface-bg);
    border: 1px solid var(--chat-bubble-border);
    border-bottom-left-radius: 4px;
    align-self: flex-start;
}

.chat-bubble-client {
    background: var(--action-accent-soft);
    border: 1px solid var(--action-accent-shadow);
    border-bottom-right-radius: 4px;
    align-self: flex-end;
}

.chat-bubble-manager {
    background: var(--chat-bubble-own-bg);
    border: 1px solid var(--chat-bubble-own-border);
    color: var(--chat-bubble-own-text);
    border-bottom-right-radius: 4px;
    align-self: flex-end;
}

.chat-timestamp {
    font-size: 10px;
    color: var(--text-secondary);
    /* Улучшенный контраст */
    margin-top: 4px;
    text-align: right;
}

/* ─── ДИАЛОГИ: Аватар (32px кружок) ──────────────────── */
.dialog-avatar {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: 50%;
    object-fit: cover;
    margin-top: 18px;
    /* чтобы был на уровне бабла, а не имени */
}

.dialog-avatar--initials {
    background: var(--chat-avatar-bg);
    color: var(--chat-avatar-text);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.05em;
}

/* ─── ДИАЛОГИ: Имя автора ─────────────────────────────── */
.dialog-author-name {
    font-size: 11px;
    font-weight: 700;
    color: var(--text-secondary);
    margin-bottom: 2px;
    letter-spacing: 0.02em;
}

/* ─── ДИАЛОГИ: Бабл «чужое» (белый, лево) ────────────── */
.chat-bubble-theirs {
    background: var(--chat-bubble-surface-bg);
    border: 1px solid var(--chat-bubble-border);
    border-bottom-left-radius: 4px;
    align-self: flex-start;
}

/* ─── ДИАЛОГИ: Бабл «моё» (право) ────────────────────── */
.chat-bubble-mine {
    background: var(--chat-bubble-own-bg);
    border: 1px solid var(--chat-bubble-own-border);
    color: var(--chat-bubble-own-text);
    border-bottom-right-radius: 4px;
    align-self: flex-end;
}

/* ─── ДИАЛОГИ: Системное сообщение (полоска) ──────────── */
.dialog-system-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 2px 16px;
    margin: -4px 0;
}

.dialog-system-text {
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 500;
    text-align: center;
    white-space: pre-wrap;
}

.dialog-system-time {
    font-size: 10px;
    color: var(--text-muted);
    opacity: 0.6;
    white-space: nowrap;
}

/* ─── ДИАЛОГИ: Прокрутка ленты ────────────────────────── */
.dialog-feed-scroll {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    scroll-behavior: smooth;
}

/* Чат-блок: занимает всю доступную высоту (header 64px + nav 56px на мобилке) */
.block-chat-fullheight {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 64px);
    padding: 4px 6px !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
}

@media (max-width: 767px) {
    .block-chat-fullheight {
        height: calc(100vh - 64px - 56px);
    }
}

/* В панели деталей блок не должен быть 100vh, он должен вписываться в высоту панели */
#app-detail .block-chat-fullheight {
    height: 100%;
}

.block-chat-fullheight .block-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

/* Input bar всегда прижат к низу даже при пустом чате */
.block-chat-fullheight .chat-input-bar-v2 {
    margin-top: auto;
}

/* Шапка чата (Чат / ЗАКРЫТЬ) прилипает к верху при скролле */
.block-chat-fullheight .v2-split-row {
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--card-bg);
    padding: 10px 0;
    border-bottom: 1px solid var(--card-border);
}

/* Тонкий скроллбар */
.dialog-feed-scroll::-webkit-scrollbar {
    width: 4px;
}

.dialog-feed-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.dialog-feed-scroll::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.15);
    border-radius: 4px;
}

.dialog-feed-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3);
}

/* ─── CHAT INPUT BAR (form style: chat_input) ─────────── */
.chat-input-bar {
    display: flex;
    align-items: flex-end;
    gap: 6px;
    padding: 8px 12px;
    background: var(--surface-card);
    border-top: 1px solid var(--border-subtle);
    border-radius: 0 0 16px 16px;
    position: sticky;
    bottom: 0;
    z-index: 10;
}

/* Текстовое поле */
.chat-input-text {
    flex: 1;
    border: 1px solid var(--border-control);
    border-radius: 18px;
    padding: 8px 14px;
    font-size: 13px;
    font-family: inherit;
    line-height: 20px;
    resize: none;
    outline: none;
    background: var(--surface-muted);
    transition: border-color 0.2s, background 0.2s;
    min-height: 36px;
    max-height: 112px;
    /* ~5 строк */
}

.chat-input-text:focus {
    border-color: var(--field-control-focus);
    background: var(--surface-card);
}

.chat-input-text::placeholder {
    color: var(--text-muted);
    font-size: 13px;
}

/* Кнопки-иконки (📎, 🎤) */
.chat-input-icon-btn {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.chat-input-icon-btn:hover {
    background: var(--action-primary-soft);
    color: var(--action-primary-bg);
}

.chat-input-icon-btn:active {
    background: var(--action-primary-soft-strong);
    transform: scale(0.92);
}

/* Кнопка «Отправить» (круглая синяя) */
.chat-input-send-btn {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border: none;
    background: var(--action-primary-bg);
    color: var(--action-primary-text);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
    box-shadow: 0 2px 8px var(--action-primary-shadow-strong);
}

.chat-input-send-btn:hover {
    background: var(--action-primary-bg-hover);
}

.chat-input-send-btn:active {
    transform: scale(0.9);
}

/* Обёртка файла */
.chat-input-file-wrap {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

/* Превью выбранного файла */
.chat-file-preview {
    display: flex;
    align-items: center;
    gap: 4px;
}

.chat-file-name {
    font-size: 11px;
    color: var(--text-primary);
    background: var(--action-primary-soft);
    padding: 2px 8px;
    border-radius: 10px;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-file-remove {
    font-size: 12px;
    color: var(--text-muted);
    cursor: pointer;
    background: none;
    border: none;
    padding: 0 2px;
}

.chat-file-remove:hover {
    color: var(--state-danger);
}

/* Обёртка аудио */
.chat-input-audio-wrap {
    flex-shrink: 0;
}

/* ═══════════ CHAT INPUT BAR V2 (WhatsApp-стиль) ═══════════ */
.chat-input-bar-v2 {
    position: sticky;
    bottom: 0;
    z-index: 10;
    background: var(--surface-card);
    border-top: 1px solid var(--border-subtle);
    padding: 6px 10px;
}

.chat-bar-row {
    display: flex;
    align-items: flex-end;
    gap: 4px;
}

.chat-bar-left {
    display: flex;
    align-items: center;
    flex-shrink: 0;
}

.chat-bar-center {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

.chat-bar-right {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-shrink: 0;
    position: relative;
}

/* Кнопки-иконки (😊, 📎) */
.chat-bar-icon-btn {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    cursor: pointer;
    transition: background 0.15s, color 0.15s;
}

.chat-bar-icon-btn:hover {
    background: var(--action-primary-soft);
    color: var(--action-primary-bg);
}

.chat-bar-icon-btn:active {
    background: var(--action-primary-soft-strong);
    transform: scale(0.92);
}

/* Кнопка Отправить / Аудио (круглая) */
.chat-bar-send-btn {
    width: 38px;
    height: 38px;
    min-width: 38px;
    border: none;
    background: var(--action-primary-soft-strong);
    color: var(--text-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    cursor: pointer;
    transition: background 0.25s, color 0.25s, transform 0.1s, box-shadow 0.25s;
}

.chat-bar-send-btn:hover {
    background: var(--action-primary-soft-strong);
}

/* Активная (когда текст набран — становится ✈️ синяя) */
.chat-bar-send-btn.chat-bar-send-active {
    background: var(--action-primary-bg);
    color: var(--action-primary-text);
    box-shadow: 0 2px 8px var(--action-primary-shadow-strong);
}

.chat-bar-send-btn.chat-bar-send-active:hover {
    background: var(--action-primary-bg-hover);
}

.chat-bar-send-btn:active {
    transform: scale(0.9);
}

/* Textarea в строке */
.chat-bar-textarea {
    flex: 1;
    border: 1px solid var(--border-control);
    border-radius: 20px;
    padding: 8px 14px;
    font-size: 13px;
    font-family: inherit;
    line-height: 20px;
    resize: none;
    outline: none;
    background: var(--surface-muted);
    transition: border-color 0.2s, background 0.2s;
    min-height: 36px;
    max-height: 120px;
    overflow-y: auto;
}

.chat-bar-textarea:focus {
    border-color: var(--field-control-focus);
    background: var(--surface-card);
}

.chat-bar-textarea::placeholder {
    color: var(--text-muted);
    font-size: 13px;
}

/* ─── Emoji Popup ─── */
.chat-emoji-popup {
    position: absolute;
    bottom: 100%;
    left: 0;
    margin-bottom: 6px;
    background: var(--surface-card);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
    padding: 8px;
    z-index: 20;
    animation: chatPopupIn 0.15s ease-out;
}

.chat-emoji-grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 2px;
}

.chat-emoji-item {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    cursor: pointer;
    border-radius: 6px;
    transition: background 0.1s;
}

.chat-emoji-item:hover {
    background: var(--action-primary-soft);
}

/* ─── Attach Popup (📎 → вверх) ─── */
.chat-attach-popup {
    position: absolute;
    bottom: 100%;
    right: 0;
    margin-bottom: 6px;
    background: var(--surface-card);
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
    padding: 4px 0;
    flex-direction: column;
    min-width: 180px;
    z-index: 21;
    animation: chatPopupIn 0.15s ease-out;
}

.chat-popup-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    font-size: 13px;
    color: var(--text-primary);
    cursor: pointer;
    transition: background 0.12s;
}

.chat-popup-item:hover {
    background: var(--action-primary-soft);
}

.chat-popup-item i {
    width: 18px;
    text-align: center;
    font-size: 15px;
    color: var(--text-secondary);
}

/* ─── File Info Bar (вложение выбрано) ─── */
.chat-file-info {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--action-primary-soft);
    border-radius: 12px;
    margin-bottom: 6px;
}

.chat-file-info i {
    font-size: 18px;
    color: var(--text-primary);
    flex-shrink: 0;
}

.chat-file-name {
    font-size: 12px;
    color: var(--text-primary);
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 500;
}

.chat-file-close {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-muted);
    font-size: 14px;
    padding: 2px 4px;
    border-radius: 4px;
    transition: color 0.15s;
}

.chat-file-close:hover {
    color: var(--state-danger);
}

/* ─── Attachment Bottom (подпись + кнопка) ─── */
.chat-attachment-bottom {
    display: flex;
    align-items: flex-end;
    gap: 6px;
}

.chat-caption-input {
    flex: 1;
}

.chat-bar-submit-btn {
    padding: 8px 18px;
    background: var(--action-primary-bg);
    color: var(--action-primary-text);
    border: none;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background 0.15s, transform 0.1s;
    box-shadow: 0 2px 6px var(--action-primary-shadow);
}

.chat-bar-submit-btn:hover {
    background: var(--action-primary-bg-hover);
}

.chat-bar-submit-btn:active {
    transform: scale(0.95);
}

/* ─── Audio Recording ─── */
.chat-audio-recording {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px;
    height: 36px;
    background: var(--state-danger-soft);
    border-radius: 20px;
}

.chat-audio-timer {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    font-variant-numeric: tabular-nums;
}

.chat-audio-dot {
    color: var(--state-danger);
    font-size: 10px;
    animation: audioPulse 1s infinite;
}

.chat-audio-cancel {
    color: var(--state-danger) !important;
}

/* ─── Form Containers ─── */
.chat-bar-form-container {
    /* display: contents → детки попадают прямо в flex-родителя */
}

/* ─── Animations ─── */
@keyframes chatPopupIn {
    from {
        opacity: 0;
        transform: translateY(6px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes audioPulse {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.3;
    }
}

/* ═══════════ ЦИТИРОВАНИЕ СООБЩЕНИЙ ═══════════ */

/* Обёртка пузырька (для hover + data-msg-id) */
.chat-bubble-wrap {
    position: relative;
}

/* Кнопка ↩ (действия) — появляется при hover */
.chat-bubble-action-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 24px;
    height: 24px;
    border: none;
    background: var(--chat-action-bg);
    color: var(--text-secondary);
    border-radius: 50%;
    display: none;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    cursor: pointer;
    z-index: 5;
    transition: background 0.15s, color 0.15s;
    box-shadow: var(--chat-action-shadow);
}

.chat-bubble:hover .chat-bubble-action-btn {
    display: flex;
}

.chat-bubble-action-btn:hover {
    background: var(--action-primary-bg);
    color: var(--action-primary-text);
}

/* Dropdown меню (Цитировать, ...) */
.chat-bubble-dropdown {
    position: absolute;
    top: -4px;
    right: 28px;
    background: var(--chat-dropdown-bg);
    border-radius: 10px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.14);
    padding: 4px 0;
    min-width: 160px;
    z-index: 30;
    animation: chatPopupIn 0.12s ease-out;
}

.chat-dropdown-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    font-size: 13px;
    color: var(--text-primary);
    cursor: pointer;
    transition: background 0.1s;
    white-space: nowrap;
}

.chat-dropdown-item:hover {
    background: var(--chat-dropdown-hover-bg);
}

.chat-dropdown-item i {
    font-size: 13px;
    color: var(--text-secondary);
    width: 16px;
    text-align: center;
}

/* Блок цитаты ВНУТРИ пузырька */
.chat-quote-block {
    border-left: 3px solid var(--chat-quote-border);
    background: var(--chat-quote-bg);
    padding: 4px 8px;
    border-radius: 0 4px 4px 0;
    margin-bottom: 4px;
    cursor: pointer;
    transition: background 0.15s;
}

.chat-quote-block:hover {
    background: var(--chat-quote-bg-hover);
}

.chat-quote-author {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 1px;
}

.chat-quote-text {
    font-size: 11px;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-quote-not-found {
    font-style: italic;
    color: var(--text-muted);
    font-size: 11px;
}

/* Превью цитаты НАД textarea (в форме ввода) */
.chat-quote-preview {
    margin-bottom: 4px;
}

.chat-quote-preview-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--chat-quote-bg);
    border-left: 3px solid var(--chat-quote-border);
    border-radius: 0 8px 8px 0;
}

.chat-quote-preview-content {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.chat-quote-preview-author {
    font-size: 11px;
    font-weight: 600;
    color: var(--text-primary);
}

.chat-quote-preview-text {
    font-size: 11px;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-quote-preview-close {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 2px 4px;
    font-size: 12px;
    border-radius: 4px;
    transition: color 0.15s;
    flex-shrink: 0;
}

.chat-quote-preview-close:hover {
    color: var(--state-danger);
}

/* Подсветка при скролле к цитируемому сообщению */
.chat-bubble-highlight .chat-bubble {
    animation: quoteHighlight 1.5s ease-out;
}

@keyframes quoteHighlight {
    0% {
        box-shadow: var(--chat-quote-highlight-shadow);
    }

    100% {
        box-shadow: none;
    }
}

/* ═══════════ ПРОЧИТАННОСТЬ: ГАЛОЧКИ ═══════════ */
.msg-check {
    display: inline;
    font-size: 12px;
    margin-left: 4px;
    color: var(--text-muted);
    letter-spacing: -3px;
    font-weight: 600;
}

.msg-check-read {
    color: var(--chat-msg-read-color);
}


.chat-textarea {
    width: 100%;
    border: 1px solid var(--field-control-border);
    border-radius: var(--radius-button);
    padding: 12px;
    font-family: inherit;
    font-size: 13px;
    color: var(--text-primary);
    background: var(--field-control-bg);
    resize: none;
    min-height: 60px;
    transition: border-color 0.2s, background-color 0.2s, box-shadow 0.2s;
}

.chat-textarea:focus {
    outline: none;
    border-color: var(--field-control-focus);
    box-shadow: 0 0 0 3px var(--action-primary-soft);
}

.chat-textarea::placeholder {
    color: var(--text-muted);
}

.chat-textarea:disabled {
    cursor: not-allowed;
    opacity: 0.65;
    background: var(--surface-subtle);
}

.input-textarea-field {
    width: 100%;
}

/* Плавный аккордеон */
details summary {
    cursor: pointer;
    transition: margin 0.2s ease;
}

details[open] summary {
    margin-bottom: 10px;
}

details summary svg {
    transition: transform 0.2s ease;
}

details[open] summary svg {
    transform: rotate(180deg);
}
