/* ───────────────────────────────────────────────────────────────────────────
 *  Dashboard reusable components (Phase 2)
 *
 *  Используется на любой странице LK через единые классы.
 *  Все цвета/отступы — из design-tokens.css.
 * ─────────────────────────────────────────────────────────────────────────── */

/* ── 1. Card (универсальная карточка) ───────────────────────────────────── */

.dash-card {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-xs);
    padding: var(--sp-4);
    transition: box-shadow var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.dash-card:hover { box-shadow: var(--shadow-sm); }
.dash-card.interactive { cursor: pointer; }
.dash-card.interactive:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); border-color: var(--border-strong); }

.dash-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    padding-bottom: var(--sp-3);
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: var(--sp-3);
}
.dash-card-title {
    font-size: var(--fs-base);
    font-weight: var(--fw-semibold);
    color: var(--text-1);
    margin: 0;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.dash-card-subtitle {
    font-size: var(--fs-sm);
    color: var(--text-3);
    margin-top: 2px;
}

/* ── 2. Stat card (метрика с большой цифрой) ────────────────────────────── */

.stat-card {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    padding: var(--sp-4);
    display: flex;
    flex-direction: column;
    gap: var(--sp-1);
    transition: box-shadow var(--t-fast);
    position: relative;
    overflow: hidden;
}
.stat-card:hover { box-shadow: var(--shadow-sm); }
.stat-card .stat-label {
    font-size: var(--fs-sm);
    color: var(--text-3);
    font-weight: var(--fw-medium);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.stat-card .stat-value {
    font-size: var(--fs-2xl);
    font-weight: var(--fw-bold);
    color: var(--text-1);
    line-height: var(--lh-tight);
}
.stat-card .stat-delta {
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
    display: inline-flex;
    align-items: center;
    gap: 2px;
}
.stat-card .stat-delta.up   { color: var(--success-600); }
.stat-card .stat-delta.down { color: var(--danger-600); }

/* ── 3. Status pill (label с цветом + точкой) ───────────────────────────── */

.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 10px;
    border-radius: var(--r-pill);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    line-height: 1.4;
    white-space: nowrap;
}
.status-pill::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: var(--r-pill);
    background: currentColor;
    flex-shrink: 0;
}
.status-pill.success { background: var(--success-bg); color: var(--success-fg); }
.status-pill.warning { background: var(--warning-bg); color: var(--warning-fg); }
.status-pill.danger  { background: var(--danger-bg);  color: var(--danger-fg); }
.status-pill.info    { background: var(--info-bg);    color: var(--info-fg); }
.status-pill.muted   { background: var(--surface-2);  color: var(--text-3); }

/* ── 4. Brand badge (цвет канала/провайдера) ────────────────────────────── */

.brand-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: var(--r-sm);
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    color: #fff;
    white-space: nowrap;
}
.brand-badge.avito    { background: var(--brand-avito); }
.brand-badge.vk       { background: var(--brand-vk); }
.brand-badge.telegram { background: var(--brand-telegram); }
.brand-badge.custom   { background: var(--brand-custom); }
.brand-badge.avitoweb { background: var(--brand-avitoweb); }
.brand-badge.claude   { background: var(--brand-claude); }
.brand-badge.openai   { background: var(--brand-openai); }
.brand-badge.gemini   { background: var(--brand-gemini); }
.brand-badge.coze     { background: var(--brand-coze); }

/* ── 5. Empty state ─────────────────────────────────────────────────────── */

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--sp-7) var(--sp-4);
    text-align: center;
    background: var(--bg-card);
    border: 1px dashed var(--border-subtle);
    border-radius: var(--r-md);
    color: var(--text-3);
}
.empty-state .empty-icon {
    width: 64px; height: 64px;
    color: var(--surface-5);
    margin-bottom: var(--sp-3);
}
.empty-state h4 {
    margin: 0 0 var(--sp-2);
    color: var(--text-1);
    font-size: var(--fs-lg);
    font-weight: var(--fw-semibold);
}
.empty-state p {
    margin: 0 0 var(--sp-4);
    max-width: 420px;
    font-size: var(--fs-md);
    color: var(--text-3);
}
.empty-state .empty-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; justify-content: center; }

/* ── 6. Skeleton loader ─────────────────────────────────────────────────── */

@keyframes skeleton-shimmer {
    0%   { background-position: -200px 0; }
    100% { background-position: calc(200px + 100%) 0; }
}
.skeleton {
    background: linear-gradient(
        90deg,
        var(--surface-2) 0%,
        var(--surface-3) 50%,
        var(--surface-2) 100%
    );
    background-size: 200px 100%;
    background-repeat: no-repeat;
    animation: skeleton-shimmer 1.4s ease-in-out infinite;
    border-radius: var(--r-sm);
    display: inline-block;
}
.skeleton-text { height: 14px; width: 100%; border-radius: var(--r-sm); }
.skeleton-text.short { width: 40%; }
.skeleton-text.medium { width: 70%; }
.skeleton-avatar {
    width: 40px; height: 40px;
    border-radius: var(--r-pill);
    flex-shrink: 0;
}

.skeleton-row {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3);
    border-bottom: 1px solid var(--border-subtle);
}
.skeleton-row .skeleton-body { flex: 1; display: flex; flex-direction: column; gap: 6px; }

/* ── 7. Toast (нотификации) ─────────────────────────────────────────────── */

.toast-stack {
    position: fixed;
    bottom: var(--sp-4);
    right: var(--sp-4);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
    pointer-events: none;
    max-width: 380px;
}
.toast-stack > .toast-item { pointer-events: auto; }

.toast-item {
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-left: 4px solid var(--accent-500);
    box-shadow: var(--shadow-lg);
    border-radius: var(--r-md);
    padding: var(--sp-3) var(--sp-4);
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    color: var(--text-1);
    font-size: var(--fs-md);
    animation: toast-in var(--t-md);
    min-width: 280px;
}
.toast-item.dismiss { animation: toast-out var(--t-md) forwards; }
@keyframes toast-in  { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes toast-out { from { opacity: 1; transform: translateY(0); }    to { opacity: 0; transform: translateX(20px); } }

.toast-item.success { border-left-color: var(--success-500); }
.toast-item.warning { border-left-color: var(--warning-500); }
.toast-item.danger  { border-left-color: var(--danger-500); }
.toast-item.info    { border-left-color: var(--info-500); }

.toast-item .toast-icon {
    flex-shrink: 0;
    width: 20px; height: 20px;
    display: flex; align-items: center; justify-content: center;
}
.toast-item.success .toast-icon { color: var(--success-500); }
.toast-item.warning .toast-icon { color: var(--warning-500); }
.toast-item.danger  .toast-icon { color: var(--danger-500); }
.toast-item.info    .toast-icon { color: var(--info-500); }

.toast-item .toast-body { flex: 1; min-width: 0; }
.toast-item .toast-title { font-weight: var(--fw-semibold); margin-bottom: 2px; line-height: var(--lh-tight); }
.toast-item .toast-msg { font-size: var(--fs-sm); color: var(--text-2); line-height: var(--lh-normal); }

.toast-item .toast-close {
    background: transparent;
    border: none;
    color: var(--text-3);
    cursor: pointer;
    padding: 0;
    width: 20px; height: 20px;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--r-sm);
    transition: background var(--t-fast), color var(--t-fast);
    flex-shrink: 0;
}
.toast-item .toast-close:hover { background: var(--bg-card-hover); color: var(--text-1); }

/* ── 8. Action menu (контекстное "..." меню) ────────────────────────────── */

.action-menu-trigger {
    background: transparent;
    border: none;
    width: 32px; height: 32px;
    border-radius: var(--r-md);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--text-3);
    cursor: pointer;
    transition: background var(--t-fast), color var(--t-fast);
}
.action-menu-trigger:hover { background: var(--bg-card-hover); color: var(--text-1); }
.action-menu-trigger.open  { background: var(--bg-card-hover); color: var(--text-1); }

.action-menu {
    position: absolute;
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-lg);
    padding: var(--sp-1);
    min-width: 180px;
    z-index: 1050;
    display: none;
    flex-direction: column;
}
.action-menu.open { display: flex; animation: toast-in var(--t-fast); }

.action-menu-item {
    display: flex;
    align-items: center;
    gap: var(--sp-2);
    padding: 8px 12px;
    border-radius: var(--r-sm);
    color: var(--text-2);
    text-decoration: none;
    font-size: var(--fs-md);
    cursor: pointer;
    background: transparent;
    border: none;
    text-align: left;
    width: 100%;
}
.action-menu-item:hover { background: var(--bg-card-hover); color: var(--text-1); text-decoration: none; }
.action-menu-item.danger { color: var(--danger-600); }
.action-menu-item.danger:hover { background: var(--danger-bg); }
.action-menu-divider { height: 1px; background: var(--border-subtle); margin: var(--sp-1) 0; }

/* ── 9. List item (компактная строка для списков агентов / каналов) ─────── */

.list-item {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-4);
    background: var(--bg-card);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    transition: background var(--t-fast), border-color var(--t-fast);
    text-decoration: none;
    color: var(--text-2);
}
.list-item:hover { background: var(--bg-card-hover); border-color: var(--border-strong); text-decoration: none; color: var(--text-2); }
.list-item .item-avatar {
    width: 40px; height: 40px;
    border-radius: var(--r-pill);
    background: linear-gradient(135deg, var(--accent-500), var(--accent-700));
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: var(--fw-semibold);
    font-size: var(--fs-md);
    flex-shrink: 0;
}
.list-item .item-body { flex: 1; min-width: 0; }
.list-item .item-title { font-weight: var(--fw-semibold); color: var(--text-1); font-size: var(--fs-md); }
.list-item .item-meta  { font-size: var(--fs-sm); color: var(--text-3); margin-top: 2px; }
.list-item .item-actions { display: flex; gap: var(--sp-1); flex-shrink: 0; }

/* ── 10. Stats grid (responsive auto-fit) ───────────────────────────────── */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: var(--sp-3);
}

/* ── 11. Section header (заголовок секции страницы) ─────────────────────── */

.page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    margin-bottom: var(--sp-4);
    flex-wrap: wrap;
}
.page-title {
    margin: 0;
    font-size: var(--fs-xl);
    font-weight: var(--fw-bold);
    color: var(--text-1);
}
.page-subtitle {
    font-size: var(--fs-sm);
    color: var(--text-3);
    margin-top: 2px;
}
.page-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }

/* ── 12. Voice recording bar (паттерн Telegram/WhatsApp) ────────────────── */

.oc-voice-bar, .chat-voice-bar {
    display: none;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--bg-card);
    border: 1px solid var(--accent-500);
    border-radius: 24px;
    box-shadow: var(--shadow-sm);
    animation: dv-slide-in 180ms ease-out;
}
.oc-voice-bar[style*="flex"], .chat-voice-bar[style*="flex"] { display: flex !important; }

@keyframes dv-slide-in {
    from { opacity: 0; transform: translateY(4px); }
    to   { opacity: 1; transform: translateY(0); }
}

.dv-cancel, .dv-send {
    background: transparent;
    border: none;
    width: 36px; height: 36px;
    border-radius: var(--r-pill);
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: background var(--t-fast), transform var(--t-fast);
    flex-shrink: 0;
}
.dv-cancel { color: var(--danger-500); }
.dv-cancel:hover { background: var(--danger-bg); transform: scale(1.05); }
.dv-send { color: #fff; background: var(--accent-500); }
.dv-send:hover { background: var(--accent-600); transform: scale(1.05); }

.dv-dot {
    width: 12px; height: 12px;
    border-radius: var(--r-pill);
    background: var(--danger-500);
    flex-shrink: 0;
    animation: dv-pulse 1.2s ease-in-out infinite;
    box-shadow: 0 0 0 0 var(--danger-500);
}
@keyframes dv-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.4); }
    70%  { box-shadow: 0 0 0 8px rgba(239, 68, 68, 0); }
    100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0); }
}

.dv-time {
    font-variant-numeric: tabular-nums;
    font-family: var(--font-mono);
    font-size: var(--fs-sm);
    color: var(--text-1);
    font-weight: var(--fw-semibold);
    min-width: 38px;
    flex-shrink: 0;
}

.dv-waveform {
    flex: 1;
    height: 32px;
    color: var(--accent-500);
    min-width: 100px;
    max-width: 280px;
}

/* Voice-bar в стиле test chat редактора — поджимается под dark theme панели */
[data-theme="dark"] .oc-voice-bar,
.panel-right .oc-voice-bar {
    background: var(--bg-card);
    border-color: var(--accent-500);
}

/* ── 13. Mic button (микрофон) — стиль кнопки в строке ввода ────────────── */

.btn-mic, .chat-attach-btn[id$="MicBtn"] {
    background: transparent;
    border: none;
    color: var(--text-3);
    cursor: pointer;
    padding: 8px 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color var(--t-fast), background var(--t-fast);
    border-radius: var(--r-md);
}
.btn-mic:hover, .chat-attach-btn[id$="MicBtn"]:hover { color: var(--accent-500); background: var(--bg-card-hover); }
.btn-mic:active { transform: scale(0.96); }

/* Запись активна — кнопка пульсирует красным */
.btn-mic.recording, .chat-attach-btn[id$="MicBtn"].recording {
    color: var(--danger-500);
    animation: dv-pulse-button 1.2s ease-in-out infinite;
}
@keyframes dv-pulse-button {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}
