/* Dashboard v2 — visual reescrito a partir do protótipo light/calmo.
   Convive com dashboard.css (modais, chat, notificações, meetings continuam usando o antigo).
   Prefixo .kvd-* para evitar colisão. */

:root {
    /* Modo claro — camadas (fundo ≠ card ≠ hover) */
    --kvd-bg: #F8FAFC;
    --kvd-sidebar-bg: #FFFFFF;
    --kvd-card: #FFFFFF;
    --kvd-border: #E5E7EB;
    --kvd-divider: #E2E8F0;
    --kvd-text-1: #0F172A;
    --kvd-text-2: #475569;
    --kvd-text-3: #64748B;
    --kvd-accent: #4F46E5;
    --kvd-accent-hover: #4338CA;
    --kvd-accent-weak: #EEF2FF;
    --kvd-accent-muted: #A5B4FC;
    --kvd-ok: #10B981;
    --kvd-ok-weak: #ECFDF5;
    --kvd-warn: #D97706;
    --kvd-warn-weak: #FFFBEB;
    --kvd-err: #DC2626;
    --kvd-hover: #F1F5F9;
    --kvd-shadow-card: 0 1px 3px rgba(0, 0, 0, 0.06);
    --kvd-shadow-card-hover: 0 6px 16px rgba(0, 0, 0, 0.08);
    --kvd-transition: all 0.2s ease;
    --kvd-radius: 12px;
    --kvd-radius-btn: 10px;
    --kvd-sidebar-w: 248px;
    --kvd-topbar-h: 56px;
}

/* ── Reset visual da página quando dashboard v2 está ativo ── */
/* !important: dashboard.css força color/background do body (tema escuro) e quebra o contraste do fundo claro. */
body:has(.kvd-app) {
    background: var(--kvd-bg) !important;
    color: var(--kvd-text-1) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, 'Segoe UI', Tahoma, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.kvd-app, .kvd-app * { box-sizing: border-box; }
.kvd-app a { text-decoration: none; color: inherit; }
.kvd-app button { background: transparent; border: 0; cursor: pointer; font: inherit; color: inherit; }

.kvd-tnum { font-variant-numeric: tabular-nums; }
.kvd-mono { font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace; }

.kvd-h1 { font-size: 27px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.2; margin: 0; color: var(--kvd-text-1); }
.kvd-h2 { font-size: 16px; font-weight: 600; letter-spacing: -0.01em; line-height: 1.3; margin: 0; color: var(--kvd-text-1); }
.kvd-meta { font-size: 13px; font-weight: 500; color: var(--kvd-text-3); margin: 0; line-height: 1.45; }
.kvd-eyebrow { font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--kvd-text-3); }

.kvd-text-1 { color: var(--kvd-text-1); }
.kvd-text-2 { color: var(--kvd-text-2); }
.kvd-text-3 { color: var(--kvd-text-3); }

.kvd-pill {
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 600; color: var(--kvd-text-3);
    background: var(--kvd-hover); padding: 3px 9px; border-radius: 999px;
    border: 1px solid var(--kvd-border);
    font-variant-numeric: tabular-nums;
}

.kvd-card {
    background: #FFFFFF;
    border: 1px solid var(--kvd-border);
    border-radius: var(--kvd-radius);
    box-shadow: var(--kvd-shadow-card);
    transition: var(--kvd-transition);
}
.kvd-card-hover:hover {
    box-shadow: var(--kvd-shadow-card-hover);
    border-color: #D1D5DB;
    transform: translateY(-1px);
}

.kvd-kbd {
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 11px; font-weight: 500; color: var(--kvd-text-2);
    background: var(--kvd-hover); border: 1px solid var(--kvd-border);
    border-bottom-width: 1.5px; border-radius: 4px;
    padding: 1px 5px; line-height: 1.4;
}

/* ── Layout ── */
.kvd-app {
    display: block;
    min-height: 100vh;
    background: var(--kvd-bg);
    color: var(--kvd-text-1);
}

.kvd-sidebar {
    position: fixed; top: 0; left: 0;
    width: var(--kvd-sidebar-w); height: 100vh;
    background: var(--kvd-sidebar-bg);
    border-right: 1px solid var(--kvd-border);
    box-shadow: 4px 0 24px rgba(15, 23, 42, 0.04);
    display: flex; flex-direction: column;
    z-index: 50;
}

.kvd-sidebar-brand {
    display: flex; align-items: center; gap: 8px;
    /* Recuo à esquerda visível (o link já não usa margin negativa horizontal que “comia” este padding). */
    padding: 18px 16px 16px 26px;
    border-bottom: 1px solid var(--kvd-divider);
}
.kvd-sidebar-brand-link {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
    text-decoration: none;
    color: inherit;
    border-radius: 10px;
    padding: 6px 8px 6px 4px;
    /* Só margem vertical: -6px à esquerda/direita anulava o padding do .kvd-sidebar-brand e o logo ficava colado à borda. */
    margin: -4px 0;
    transition: var(--kvd-transition);
}
.kvd-sidebar-brand-link:hover {
    background: var(--kvd-hover);
}
.kvd-sidebar-brand-link:focus-visible {
    outline: 2px solid var(--kvd-accent);
    outline-offset: 2px;
}
.kvd-brand-mark {
    width: 28px; height: 28px; border-radius: 8px;
    background: var(--kvd-accent); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 12px; letter-spacing: -0.02em;
    overflow: hidden; flex-shrink: 0;
}
.kvd-brand-mark img { width: 100%; height: 100%; object-fit: cover; }
.kvd-brand-text { display: flex; flex-direction: column; line-height: 1; min-width: 0; flex: 1; }
.kvd-brand-name { font-size: 14px; font-weight: 700; letter-spacing: 0.04em; color: var(--kvd-text-1); }
.kvd-brand-sub {
    font-size: 13px;
    font-weight: 500;
    color: var(--kvd-text-2);
    margin-top: 5px;
    line-height: 1.25;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.kvd-sidebar-close { display: none; color: var(--kvd-text-2); font-size: 16px; padding: 4px; }

.kvd-sidebar-nav {
    flex: 1; overflow-y: auto;
    padding: 16px 12px;
    display: flex; flex-direction: column;
}
.kvd-sidebar-nav::-webkit-scrollbar { width: 6px; }
.kvd-sidebar-nav::-webkit-scrollbar-thumb { background: #E5E7EB; border-radius: 3px; }
.kvd-sidebar-nav::-webkit-scrollbar-track { background: transparent; }

.kvd-eyebrow-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 8px; margin-bottom: 8px; margin-top: 4px;
}
.kvd-sidebar-nav > .kvd-eyebrow:first-child,
.kvd-sidebar-nav > .kvd-eyebrow-row:first-child { margin-top: 0; padding: 0 8px; margin-bottom: 8px; }

.kvd-nav-group { display: flex; flex-direction: column; gap: 2px; margin-bottom: 18px; }
.kvd-nav-group-servers { gap: 0; }
.kvd-nav-group-servers .kvd-server-item + .kvd-server-item { border-top: 1px solid var(--kvd-divider); }

.kvd-nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px;
    border-radius: var(--kvd-radius-btn);
    border-left: 3px solid transparent;
    color: var(--kvd-text-2);
    font-size: 13.5px; font-weight: 500;
    position: relative;
    cursor: pointer; user-select: none;
    width: 100%; text-align: left;
    transition: var(--kvd-transition);
}
.kvd-nav-item i { font-size: 15px; flex-shrink: 0; width: 16px; text-align: center; color: var(--kvd-text-3); transition: color 0.2s ease; }
.kvd-nav-item span { flex: 1; }
.kvd-nav-item:hover { background: var(--kvd-hover); color: var(--kvd-text-1); }
.kvd-nav-item:hover i { color: var(--kvd-text-2); }
.kvd-nav-item.kvd-nav-active {
    background: #EEF2FF;
    color: #4F46E5;
    font-weight: 500;
    border-left-color: #4F46E5;
}
.kvd-nav-item.kvd-nav-active i { color: var(--kvd-accent); }
.kvd-nav-badge {
    margin-left: auto; font-size: 11px; font-weight: 600;
    color: #fff; background: var(--kvd-accent);
    padding: 1px 6px; border-radius: 999px; line-height: 1.4;
    font-variant-numeric: tabular-nums;
}

.kvd-server-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px;
    color: var(--kvd-text-1);
    font-size: 13.5px; font-weight: 500;
    background: transparent; cursor: pointer;
    transition: var(--kvd-transition);
}
.kvd-server-item:hover { background: var(--kvd-hover); }
.kvd-server-item .kvd-server-name { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kvd-server-item .kvd-server-icon {
    width: 22px; height: 22px; border-radius: 5px; flex-shrink: 0;
    background: var(--kvd-divider); color: var(--kvd-text-1);
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 600;
    overflow: hidden;
}
.kvd-server-item .kvd-server-icon img { width: 100%; height: 100%; object-fit: cover; }
.kvd-server-item .kvd-server-online {
    width: 6px; height: 6px; border-radius: 50%; background: var(--kvd-ok);
}

.kvd-btn-ghost-outline {
    margin-top: 10px;
    display: flex; align-items: center; justify-content: center; gap: 6px;
    border: 1px solid var(--kvd-border);
    background: var(--kvd-card);
    color: var(--kvd-accent);
    padding: 10px 12px;
    border-radius: var(--kvd-radius-btn);
    font-size: 13px; font-weight: 600;
    transition: var(--kvd-transition);
    width: 100%;
    box-shadow: var(--kvd-shadow-card);
}
.kvd-btn-ghost-outline:hover {
    border-color: var(--kvd-accent-muted);
    background: var(--kvd-accent-weak);
    color: var(--kvd-accent-hover);
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.12);
}
.kvd-btn-ghost-outline i { font-size: 16px; }

.kvd-app button.kvd-btn-ghost-outline {
    background: var(--kvd-card);
    color: var(--kvd-accent);
    border: 1px solid var(--kvd-border);
    box-shadow: var(--kvd-shadow-card);
}
.kvd-app button.kvd-btn-ghost-outline:hover {
    background: var(--kvd-accent-weak);
    color: var(--kvd-accent-hover);
    border-color: var(--kvd-accent-muted);
}

.kvd-sidebar-empty {
    padding: 12px 10px;
    font-size: 12px; color: var(--kvd-text-3);
    text-align: center;
}

.kvd-sidebar-footer {
    padding: 10px 12px 14px;
    border-top: 1px solid var(--kvd-divider);
    display: flex; flex-direction: column; gap: 2px;
}
.kvd-sidebar-footer .kvd-nav-item { width: 100%; }
.kvd-sidebar-footer form { margin: 0; padding: 0; }
.kvd-user-pill {
    margin-top: 8px; padding: 8px 8px 0;
    border-top: 1px solid var(--kvd-divider);
    display: flex; align-items: center; gap: 10px;
}
.kvd-user-pill-info { flex: 1; min-width: 0; }
.kvd-user-pill-name { font-size: 13px; font-weight: 600; line-height: 1.1; color: var(--kvd-text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.kvd-user-pill-sub { font-size: 11px; color: var(--kvd-text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Main / Topbar ── */
.kvd-main {
    margin-left: var(--kvd-sidebar-w);
    min-height: 100vh;
    display: flex; flex-direction: column;
    background: var(--kvd-bg);
}

.kvd-topbar {
    position: sticky; top: 0; z-index: 20;
    height: var(--kvd-topbar-h);
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 32px;
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--kvd-divider);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}
.kvd-breadcrumb {
    display: flex; align-items: center; gap: 8px;
    font-size: 15px;
}
.kvd-breadcrumb-workspace-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    text-decoration: none;
    color: inherit;
    border-radius: 10px;
    padding: 6px 10px;
    margin: -4px 0 -4px -6px;
    transition: var(--kvd-transition);
}
.kvd-breadcrumb-workspace-link:hover {
    background: var(--kvd-hover);
}
.kvd-breadcrumb-workspace-link:focus-visible {
    outline: 2px solid var(--kvd-accent);
    outline-offset: 2px;
}
.kvd-breadcrumb i { font-size: 13px; color: var(--kvd-text-3); }
.kvd-breadcrumb-muted { color: var(--kvd-text-2); font-weight: 500; }
.kvd-breadcrumb-current { color: var(--kvd-text-1); font-weight: 600; }
.kvd-status-chip {
    display: inline-flex; align-items: center; gap: 6px;
    margin-left: 8px;
    padding: 4px 10px; border-radius: 999px;
    font-size: 11px; font-weight: 600;
    color: var(--kvd-ok);
    background: var(--kvd-ok-weak);
    border: 1px solid rgba(5, 150, 105, 0.18);
}
.kvd-status-chip-dot {
    width: 6px; height: 6px; border-radius: 50%; background: var(--kvd-ok);
    animation: kvd-pulse 2s infinite;
}
@keyframes kvd-pulse {
    0%   { box-shadow: 0 0 0 0 rgba(16,185,129,0.45); }
    70%  { box-shadow: 0 0 0 6px rgba(16,185,129,0); }
    100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); }
}

.kvd-topbar-actions {
    display: flex; align-items: center; justify-content: flex-end;
    gap: 8px; flex: 1; min-width: 0; flex-wrap: nowrap;
}

.kvd-search-trigger {
    display: flex; align-items: center; gap: 8px;
    flex: 0 1 360px;
    min-width: 0;
    max-width: min(420px, 100%);
    height: 38px; padding: 0 14px;
    background: var(--kvd-card);
    border: 1px solid var(--kvd-border);
    border-radius: var(--kvd-radius-btn);
    color: var(--kvd-text-2); font-size: 13px;
    line-height: 1.2; white-space: nowrap;
    box-shadow: var(--kvd-shadow-card);
    transition: var(--kvd-transition);
}
.kvd-search-trigger:hover {
    background: var(--kvd-card);
    border-color: #CBD5E1;
    box-shadow: var(--kvd-shadow-card-hover);
}
.kvd-search-trigger > i { flex-shrink: 0; font-size: 15px; opacity: 0.85; }
.kvd-search-label {
    flex: 1 1 auto; min-width: 0; text-align: left;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.kvd-search-trigger > .kvd-kbd { flex-shrink: 0; }

.kvd-icon-btn {
    position: relative;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--kvd-border);
    background: var(--kvd-card);
    color: var(--kvd-text-3);
    border-radius: var(--kvd-radius-btn);
    transition: var(--kvd-transition);
}
.kvd-icon-btn:hover {
    color: var(--kvd-accent);
    border-color: #CBD5E1;
    background: var(--kvd-hover);
    transform: translateY(-1px);
    box-shadow: var(--kvd-shadow-card);
}
.kvd-icon-btn i { font-size: 16px; }
.kvd-icon-btn-badge {
    position: absolute; top: -4px; right: -4px;
    font-size: 10px; font-weight: 600; color: #fff;
    background: var(--kvd-accent);
    padding: 1px 5px; border-radius: 999px;
    border: 2px solid var(--kvd-bg);
    font-variant-numeric: tabular-nums;
}

.kvd-topbar-divider { width: 1px; height: 20px; background: var(--kvd-border); margin: 0 4px; }

.kvd-user-chip {
    display: flex; align-items: center; gap: 8px;
    height: 32px; padding: 0 8px 0 4px;
    border-radius: 6px;
}
.kvd-user-chip:hover { background: var(--kvd-hover); }
.kvd-user-chip-name { font-size: 13px; font-weight: 600; color: var(--kvd-text-1); }
.kvd-user-chip i { font-size: 11px; color: var(--kvd-text-3); }

/* ── Avatar ── */
.kvd-avatar {
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: #E5E7EB; color: #1F2937;
    font-weight: 600; letter-spacing: -0.01em;
    position: relative;
    flex-shrink: 0;
}
.kvd-avatar-28 { width: 28px; height: 28px; font-size: 11px; }
.kvd-avatar-30 { width: 30px; height: 30px; font-size: 12px; }
.kvd-avatar-32 { width: 32px; height: 32px; font-size: 12px; }
.kvd-avatar-26 { width: 26px; height: 26px; font-size: 10px; }
.kvd-avatar-24 { width: 24px; height: 24px; font-size: 10px; }
.kvd-avatar-dark { background: #0A0A0A; color: #FAFAFA; }
.kvd-avatar-online::after {
    content: ""; position: absolute; bottom: 0; right: 0;
    width: 9px; height: 9px; border-radius: 50%;
    background: var(--kvd-ok);
    box-shadow: 0 0 0 2px var(--kvd-card);
}
.kvd-avatar-ring { box-shadow: 0 0 0 2px var(--kvd-card), 0 0 0 3.5px var(--kvd-ok); }
.kvd-avatar-ring-off { box-shadow: 0 0 0 2px var(--kvd-card), 0 0 0 3.5px #D1D5DB; }
.kvd-avatar-extra {
    background: var(--kvd-card); border: 1px solid var(--kvd-border);
    color: var(--kvd-text-2); font-size: 11px;
}

/* ── Conteúdo principal (greeting, KPIs, bottom grid) ── */
.kvd-content {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding: 28px 32px 44px;
    flex: 1;
    min-height: 0;
    width: 100%;
    max-width: none;
    box-sizing: border-box;
}

.kvd-greeting {
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    flex-shrink: 0;
    position: relative;
    padding-bottom: 20px;
    margin-bottom: 4px;
}
.kvd-greeting::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: min(160px, 40%);
    height: 3px;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--kvd-accent), rgba(79, 70, 229, 0.25), transparent);
}
.kvd-greeting-text { display: flex; flex-direction: column; gap: 6px; }
.kvd-greeting-text p { margin: 0; }

.kvd-greeting .kvd-h1 {
    font-size: 28px;
    font-weight: 600;
    letter-spacing: -0.025em;
    line-height: 1.2;
    color: var(--kvd-text-1);
}
.kvd-greeting .kvd-meta {
    color: #64748B;
    opacity: 0.92;
}

.kvd-btn-primary {
    display: inline-flex; align-items: center; gap: 8px;
    height: 40px; padding: 0 18px;
    background: var(--kvd-accent); color: #fff;
    border-radius: var(--kvd-radius-btn); font-size: 13px; font-weight: 600;
    border: 0; cursor: pointer;
    transition: var(--kvd-transition);
    box-shadow: 0 1px 3px rgba(79, 70, 229, 0.25), 0 1px 2px rgba(0, 0, 0, 0.04);
}
.kvd-btn-primary:hover {
    background: var(--kvd-accent-hover);
    color: #fff;
    box-shadow: 0 6px 20px rgba(79, 70, 229, 0.38);
    transform: translateY(-1px);
}
.kvd-btn-primary i { font-size: 14px; }
.kvd-btn-block { width: 100%; justify-content: center; }

/* Reset global .kvd-app button deixa <button class="kvd-btn-primary"> transparente — corrigir */
.kvd-app button.kvd-btn-primary {
    background: var(--kvd-accent);
    color: #fff;
    border: 0;
    box-shadow: 0 1px 3px rgba(79, 70, 229, 0.25), 0 1px 2px rgba(0, 0, 0, 0.04);
}
.kvd-app button.kvd-btn-primary:hover {
    background: var(--kvd-accent-hover);
    color: #fff;
    box-shadow: 0 6px 20px rgba(79, 70, 229, 0.38);
    transform: translateY(-1px);
}

/* ── Reuniões externas (painel embutido em dashboard.html) ──
   dashboard.css usa --bg-tertiary / --text-* do tema legado; com data-theme="dark"
   os cartões ficam navy e o título claro, enquanto o v2 força fundo #F8FAFC no body. */
.kvd-app .main-greeting {
    margin-bottom: 24px;
}
.kvd-app .main-greeting-text h1 {
    color: var(--kvd-text-1);
    font-weight: 600;
    letter-spacing: -0.02em;
}
.kvd-app .main-greeting-text h1 i {
    color: var(--kvd-accent);
}
.kvd-app .main-greeting-text p {
    color: var(--kvd-text-3);
}

.kvd-app .meetings-section-in-dashboard {
    background: var(--kvd-card);
    border: 1px solid var(--kvd-border);
    border-radius: var(--kvd-radius);
    box-shadow: var(--kvd-shadow-card);
    padding: 1.35rem 1.5rem;
    margin-bottom: 1.25rem;
}

.kvd-app .meetings-panel-h2 {
    color: var(--kvd-text-1);
    font-weight: 600;
    font-size: 15px;
}
.kvd-app .meetings-panel-h2 i {
    color: var(--kvd-accent);
}

.kvd-app .meetings-form-in-dashboard label {
    color: var(--kvd-text-2);
    font-weight: 500;
}

.kvd-app .meetings-form-in-dashboard input,
.kvd-app .meetings-form-in-dashboard select {
    background: #fff;
    border: 1px solid var(--kvd-border);
    color: var(--kvd-text-1);
    border-radius: var(--kvd-radius-btn);
    padding: 0.55rem 0.85rem;
    box-shadow: none;
}
.kvd-app .meetings-form-in-dashboard input::placeholder {
    color: var(--kvd-text-3);
    opacity: 0.9;
}
.kvd-app .meetings-form-in-dashboard input:focus,
.kvd-app .meetings-form-in-dashboard select:focus {
    outline: none;
    border-color: var(--kvd-accent);
    box-shadow: 0 0 0 3px var(--kvd-accent-weak);
}

.kvd-app .meetings-form-in-dashboard .password-toggle-btn {
    color: var(--kvd-text-3);
    background: transparent !important;
    border: 0 !important;
}
.kvd-app .meetings-form-in-dashboard .password-toggle-btn:hover {
    color: var(--kvd-accent);
}

.kvd-app .meetings-form-in-dashboard button.btn-primary-meetings {
    background: var(--kvd-accent);
    color: #fff;
    border: 0;
    border-radius: var(--kvd-radius-btn);
    font-weight: 600;
    padding: 0.6rem 1.15rem;
    box-shadow: 0 1px 2px rgba(79, 70, 229, 0.2);
}
.kvd-app .meetings-form-in-dashboard button.btn-primary-meetings:hover {
    background: var(--kvd-accent-hover);
    color: #fff;
    filter: none;
    box-shadow: 0 4px 14px rgba(79, 70, 229, 0.3);
}

.kvd-app .meetings-list-in-dashboard li {
    border-bottom-color: var(--kvd-divider);
}
.kvd-app .meetings-list-in-dashboard .room-name {
    color: var(--kvd-text-1);
}
.kvd-app .meetings-list-in-dashboard .room-meta,
.kvd-app .meetings-list-in-dashboard .link-url {
    color: var(--kvd-text-3);
}

.kvd-app button.btn-copy-meetings,
.kvd-app a.btn-copy-meetings {
    background: var(--kvd-card);
    color: var(--kvd-text-2);
    border: 1px solid var(--kvd-border);
    border-radius: 8px;
    font-weight: 500;
    box-shadow: var(--kvd-shadow-card);
}
.kvd-app button.btn-copy-meetings:hover,
.kvd-app a.btn-copy-meetings:hover {
    background: var(--kvd-accent-weak);
    color: var(--kvd-accent);
    border-color: rgba(79, 70, 229, 0.35);
}

.kvd-app .meetings-empty {
    color: var(--kvd-text-3);
    padding: 1.75rem 1rem;
}

.kvd-app .badge-room-active {
    background: var(--kvd-ok-weak);
    color: #047857;
}
.kvd-app .badge-room-scheduled {
    background: var(--kvd-accent-weak);
    color: var(--kvd-accent-hover);
}
.kvd-app .badge-room-ended {
    background: #fef2f2;
    color: #b91c1c;
}

.kvd-btn-secondary {
    display: inline-flex; align-items: center; gap: 8px;
    height: 40px; padding: 0 18px;
    background: var(--kvd-hover);
    border: 1px solid var(--kvd-border);
    border-radius: var(--kvd-radius-btn);
    color: var(--kvd-text-1);
    font-size: 13px; font-weight: 600;
    box-shadow: var(--kvd-shadow-card);
    transition: var(--kvd-transition);
}
.kvd-btn-secondary:hover {
    background: var(--kvd-border);
    border-color: #CBD5E1;
    color: var(--kvd-text-1);
    transform: translateY(-1px);
    box-shadow: var(--kvd-shadow-card-hover);
}

/* KPI grid */
.kvd-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
    flex-shrink: 0;
}
.kvd-kpi-card {
    padding: 22px 24px;
    min-height: 128px;
    display: flex; flex-direction: column; justify-content: space-between;
    position: relative;
    overflow: hidden;
}
/* Barra de cor no topo: identidade visual por tipo de métrica */
.kvd-kpi-card::before {
    content: "";
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--kvd-kpi-accent, var(--kvd-border));
    border-radius: var(--kvd-radius) var(--kvd-radius) 0 0;
}
.kvd-kpi-tone-violet { --kvd-kpi-accent: #7C3AED; }
.kvd-kpi-tone-violet .kvd-kpi-card-head .kvd-icon-mini {
    background: rgba(124, 58, 237, 0.12);
    color: #7C3AED;
}
.kvd-kpi-tone-blue { --kvd-kpi-accent: #4F46E5; }
.kvd-kpi-tone-blue .kvd-kpi-card-head .kvd-icon-mini {
    background: #EEF2FF;
    color: #4F46E5;
}
.kvd-kpi-tone-amber { --kvd-kpi-accent: #D97706; }
.kvd-kpi-tone-amber .kvd-kpi-card-head .kvd-icon-mini {
    background: var(--kvd-warn-weak);
    color: #D97706;
}
.kvd-kpi-tone-emerald { --kvd-kpi-accent: #059669; }
.kvd-kpi-tone-emerald .kvd-kpi-card-head .kvd-icon-mini {
    background: var(--kvd-ok-weak);
    color: #059669;
}

.kvd-kpi-card-head {
    display: flex; align-items: center; justify-content: space-between;
}
.kvd-kpi-card-head .kvd-eyebrow { font-size: 11px; color: #64748B; font-weight: 600; }
.kvd-kpi-card-head .kvd-icon-mini {
    font-size: 15px;
    min-width: 36px;
    min-height: 36px;
    padding: 6px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 8px;
    background: #EEF2FF;
    color: #4F46E5;
    transition: var(--kvd-transition);
}
.kvd-kpi-num {
    font-size: 30px; font-weight: 700; letter-spacing: -0.02em;
    line-height: 1; color: #0F172A;
    font-variant-numeric: tabular-nums;
}
.kvd-kpi-num-sub { font-size: 17px; font-weight: 600; color: #64748B; }
.kvd-kpi-num-empty { color: #64748B; font-weight: 600; }
.kvd-kpi-sub { font-size: 12px; color: #64748B; margin-top: 6px; }

/* Bottom grid: ocupa a altura restante da viewport, cards com respiro */
.kvd-bottom-grid {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(300px, 1fr);
    gap: 32px;
    align-items: stretch;
    flex: 1 1 auto;
    min-height: min(72vh, 900px);
}
.kvd-bottom-grid > .kvd-card {
    min-height: 0;
    display: flex;
    flex-direction: column;
}
.kvd-bottom-grid > .kvd-card .kvd-empty,
.kvd-bottom-grid > .kvd-card .kvd-activity-list {
    flex: 1;
}
.kvd-bottom-grid .kvd-empty {
    flex: 1;
    justify-content: center;
    min-height: 280px;
}
.kvd-side-col { display: flex; flex-direction: column; gap: 32px; min-height: 0; }

/* Card header */
.kvd-card-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid var(--kvd-divider);
}
.kvd-card-title-row { display: flex; align-items: center; gap: 10px; }
.kvd-card-header a.kvd-meta {
    transition: var(--kvd-transition);
    font-weight: 500;
}
.kvd-card-header a.kvd-meta:hover { color: var(--kvd-accent); }

/* Activity feed */
.kvd-activity-list { list-style: none; margin: 0; padding: 0; }
.kvd-activity-list li {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 22px;
    border-bottom: 1px solid var(--kvd-divider);
    transition: background 0.2s ease;
}
.kvd-activity-list li:hover {
    background: rgba(241, 245, 249, 0.65);
}
.kvd-activity-list li:last-child { border-bottom: 0; }
.kvd-activity-info { flex: 1; min-width: 0; }
.kvd-activity-line { font-size: 13.5px; color: var(--kvd-text-1); }
.kvd-activity-line strong { font-weight: 500; }
.kvd-activity-line .kvd-text-2 { color: var(--kvd-text-2); }
.kvd-activity-meta {
    margin-top: 2px;
    font-size: 12px; color: var(--kvd-text-3);
    display: flex; align-items: center; gap: 6px;
}
.kvd-activity-list li > .kvd-chev { color: var(--kvd-text-3); font-size: 12px; }

/* Quick actions — primário (marca) vs secundário (superfície) */
.kvd-quick-list { list-style: none; margin: 0; padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 10px; }
.kvd-quick-action {
    width: 100%;
    display: flex; align-items: center; gap: 12px;
    min-height: 56px;
    padding: 12px 14px;
    border-radius: var(--kvd-radius-btn);
    text-align: left;
    font-size: 13px; font-weight: 600;
    border: 1px solid var(--kvd-border);
    transition: var(--kvd-transition);
    cursor: pointer;
}
.kvd-quick-action > span:nth-child(2) { flex: 1; text-align: left; }

/* .kvd-app button { font: inherit } ganha da classe só .kvd-quick-action — <button> ficava com texto maior que os <a> */
.kvd-app button.kvd-quick-action {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.3;
    letter-spacing: normal;
    font-family: inherit;
}

/* Secundário: card branco, ícone em destaque — menos “cinza pesado” */
.kvd-quick-action--secondary {
    background: #FFFFFF;
    color: var(--kvd-text-1);
    box-shadow: var(--kvd-shadow-card);
}
.kvd-quick-action--secondary:hover {
    background: #F1F5F9;
    border-color: #D1D5DB;
    transform: translateY(-1px);
    box-shadow: var(--kvd-shadow-card-hover);
}
.kvd-quick-action--secondary .kvd-quick-ico {
    width: 40px; height: 40px; border-radius: var(--kvd-radius-btn);
    background: #EEF2FF;
    color: #4F46E5;
    display: flex; align-items: center; justify-content: center;
    font-size: 17px; flex-shrink: 0;
    border: 1px solid rgba(79, 70, 229, 0.18);
    transition: var(--kvd-transition);
}
.kvd-quick-action--secondary:hover .kvd-quick-ico {
    color: var(--kvd-accent-hover);
    border-color: rgba(79, 70, 229, 0.35);
    background: #E0E7FF;
}
.kvd-quick-action--secondary .kvd-shortcut {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10.5px; color: #64748B;
    background: #F8FAFC; border: 1px solid var(--kvd-border);
    border-radius: 6px; padding: 2px 6px;
}

/* Primário: índigo sólido */
.kvd-quick-action--primary {
    background: var(--kvd-accent);
    color: #fff;
    border-color: transparent;
    box-shadow: 0 1px 2px rgba(79, 70, 229, 0.25);
}
.kvd-quick-action--primary:hover {
    background: var(--kvd-accent-hover);
    color: #fff;
    box-shadow: 0 6px 20px rgba(79, 70, 229, 0.38);
    transform: translateY(-1px);
}
.kvd-quick-action--primary .kvd-quick-ico {
    width: 40px; height: 40px; border-radius: var(--kvd-radius-btn);
    background: rgba(255, 255, 255, 0.18);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 17px; flex-shrink: 0;
    border: 1px solid rgba(255, 255, 255, 0.28);
}
.kvd-quick-action--primary .kvd-shortcut {
    font-family: 'JetBrains Mono', monospace;
    font-size: 10.5px;
    color: rgba(255, 255, 255, 0.92);
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 6px; padding: 2px 6px;
}

/* Team online — uma linha por pessoa: foto · bolinha · nome — online */
.kvd-team-body { padding: 18px 22px 22px; }
.kvd-team-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.kvd-team-row {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}
.kvd-team-row-avatar { flex-shrink: 0; }
.kvd-status-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: var(--kvd-ok);
    flex-shrink: 0;
    box-shadow: 0 0 0 2px var(--kvd-card);
}
.kvd-team-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--kvd-text-1);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.kvd-team-sep {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 500;
    color: var(--kvd-text-3);
}
.kvd-team-online {
    flex-shrink: 0;
    font-size: 13px;
    font-weight: 600;
    color: var(--kvd-ok);
    text-transform: lowercase;
}
.kvd-team-cta {
    margin-top: 16px;
    height: auto;
    min-height: 40px;
    padding: 10px 18px;
    line-height: 1.35;
    white-space: normal;
    text-align: center;
}
.kvd-team-body .kvd-avatar-30 { width: 34px; height: 34px; font-size: 13px; border: 2px solid var(--kvd-card); }
.kvd-team-body .kvd-avatar-ring { box-shadow: 0 0 0 2px var(--kvd-card), 0 0 0 4px var(--kvd-ok); }

/* Empty state — card branco, ícone em destaque, CTA primário */
.kvd-empty {
    padding: 40px 28px 44px; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 14px;
    margin: 16px;
    border-radius: var(--kvd-radius);
    background: var(--kvd-card);
    border: 1px solid var(--kvd-border);
    box-shadow: var(--kvd-shadow-card);
}
.kvd-empty .kvd-empty-illu {
    width: 152px; height: 112px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 4px;
    color: var(--kvd-text-3);
}
.kvd-empty .kvd-empty-illu svg { width: 100%; height: auto; max-height: 112px; }
.kvd-empty .kvd-h2 { font-size: 17px; }
.kvd-empty .kvd-meta { max-width: 340px; color: var(--kvd-text-3); }
.kvd-empty-mini {
    margin: 0; padding: 8px 0;
    font-size: 13px; font-weight: 500; color: var(--kvd-text-2); text-align: center;
}

/* ── Mobile ── */
.mobile-hamburger { display: none; }

@media (max-width: 900px) {
    .kvd-sidebar {
        transform: translateX(-100%);
        transition: transform 200ms ease;
        box-shadow: 0 0 24px rgba(0,0,0,0.1);
    }
    .kvd-sidebar.open { transform: translateX(0); }
    .kvd-sidebar-close { display: inline-flex; }
    .kvd-main { margin-left: 0; }
    .kvd-topbar { padding: 0 16px; }
    .kvd-content { padding: 16px; }
    .kvd-search-trigger { display: none; }
    .kvd-user-chip-name { display: none; }
    .kvd-bottom-grid {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .mobile-hamburger {
        display: inline-flex; align-items: center; justify-content: center;
        position: fixed; top: 12px; left: 12px; z-index: 40;
        width: 36px; height: 36px;
        background: var(--kvd-card); border: 1px solid var(--kvd-border);
        border-radius: 8px; color: var(--kvd-text-1);
    }
    .kvd-topbar { padding-left: 60px; }
}

/* Overlay do drawer mobile — sempre abaixo da sidebar (z 50) */
.mobile-overlay {
    position: fixed; inset: 0;
    background: rgba(15, 23, 42, 0.45);
    z-index: 45;
    opacity: 0;
    visibility: hidden;
    transition: opacity 200ms ease, visibility 0s linear 200ms;
}
.mobile-overlay.open {
    opacity: 1;
    visibility: visible;
    transition: opacity 200ms ease, visibility 0s;
}
/* Quando a sidebar mobile estiver aberta, trava o scroll do body */
body.kvd-sidebar-open,
body:has(.kvd-sidebar.open) { overflow: hidden; }

/* ── Modal “Criar servidor” no dashboard v2 (sobrescreve tema escuro de dashboard.css) ── */
body:has(.kvd-app) #createServerModal.modal-overlay {
    background: rgba(15, 23, 42, 0.48);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
body:has(.kvd-app) #createServerModal .modal-container {
    background: var(--kvd-card);
    border: 1px solid var(--kvd-border);
    border-radius: var(--kvd-radius);
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.14);
}
body:has(.kvd-app) #createServerModal .modal-header-custom {
    background: var(--kvd-bg);
    border-bottom: 1px solid var(--kvd-border);
}
body:has(.kvd-app) #createServerModal .modal-title-custom {
    color: var(--kvd-text-1);
    font-size: 18px;
    font-weight: 700;
}
body:has(.kvd-app) #createServerModal .modal-close-btn {
    color: var(--kvd-text-3);
    border-radius: var(--kvd-radius-btn);
    transition: var(--kvd-transition);
}
body:has(.kvd-app) #createServerModal .modal-close-btn:hover {
    color: var(--kvd-text-1);
    background: var(--kvd-hover);
}
body:has(.kvd-app) #createServerModal .modal-body-custom {
    background: var(--kvd-card);
    padding: 22px 24px 26px;
}
body:has(.kvd-app) #createServerModal .server-image-preview {
    background: var(--kvd-bg);
    border: 1px dashed #CBD5E1;
    border-radius: 16px;
}
body:has(.kvd-app) #createServerModal .server-image-preview:hover {
    border-color: var(--kvd-accent);
    box-shadow: 0 8px 24px rgba(79, 70, 229, 0.18);
}
body:has(.kvd-app) #createServerModal .kvd-server-upload-icon {
    font-size: 28px;
    color: var(--kvd-text-3);
}
body:has(.kvd-app) #createServerModal .kvd-server-upload-text {
    margin: 8px 0 0;
    font-size: 12px;
    font-weight: 500;
    color: var(--kvd-text-3);
}
body:has(.kvd-app) #createServerModal .form-label-custom {
    color: var(--kvd-text-1);
}
body:has(.kvd-app) #createServerModal .form-label-custom i {
    color: var(--kvd-accent);
}
body:has(.kvd-app) #createServerModal .form-input-custom {
    background: var(--kvd-card);
    border: 1px solid var(--kvd-border);
    color: var(--kvd-text-1);
    border-radius: var(--kvd-radius-btn);
}
body:has(.kvd-app) #createServerModal .form-input-custom:focus {
    outline: none;
    border-color: var(--kvd-accent);
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.2);
    background: var(--kvd-card);
}
body:has(.kvd-app) #createServerModal .form-input-custom::placeholder {
    color: #94A3B8;
}
body:has(.kvd-app) #createServerModal .form-helper {
    color: var(--kvd-text-3);
}
body:has(.kvd-app) #createServerModal .btn-primary-custom {
    background: var(--kvd-accent);
    color: #fff;
    border-radius: var(--kvd-radius-btn);
    box-shadow: 0 1px 2px rgba(79, 70, 229, 0.25);
    filter: none;
}
body:has(.kvd-app) #createServerModal .btn-primary-custom:hover {
    background: var(--kvd-accent-hover);
    filter: none;
    box-shadow: 0 4px 14px rgba(79, 70, 229, 0.35);
}
body:has(.kvd-app) #createServerModal .btn-secondary-custom {
    background: var(--kvd-hover);
    color: var(--kvd-text-1);
    border: 1px solid var(--kvd-border);
}
body:has(.kvd-app) #createServerModal .btn-secondary-custom:hover {
    background: var(--kvd-border);
    border-color: #CBD5E1;
}
